66 lines
2.2 KiB
Ruby
66 lines
2.2 KiB
Ruby
#
|
|
# Cookbook:: sudo
|
|
# Recipe:: default
|
|
#
|
|
# Copyright:: 2008-2018, Chef Software, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
#
|
|
|
|
config_prefix = case node['platform_family']
|
|
when 'smartos'
|
|
'/opt/local/etc'
|
|
when 'freebsd'
|
|
'/usr/local/etc'
|
|
when 'mac_os_x'
|
|
'/private/etc'
|
|
else
|
|
'/etc'
|
|
end
|
|
|
|
if node['authorization']['sudo']['include_sudoers_d']
|
|
directory "#{config_prefix}/sudoers.d" do
|
|
mode node['authorization']['sudo']['sudoers_d_mode']
|
|
owner 'root'
|
|
group node['root_group']
|
|
end
|
|
|
|
cookbook_file "#{config_prefix}/sudoers.d/README" do
|
|
mode '0440'
|
|
owner 'root'
|
|
group node['root_group']
|
|
end
|
|
end
|
|
|
|
template "#{config_prefix}/sudoers" do
|
|
source 'sudoers.erb'
|
|
mode '0440'
|
|
owner 'root'
|
|
group node['root_group']
|
|
variables(
|
|
sudoers_groups: node['authorization']['sudo']['groups'],
|
|
sudoers_users: node['authorization']['sudo']['users'],
|
|
passwordless: node['authorization']['sudo']['passwordless'],
|
|
setenv: node['authorization']['sudo']['setenv'],
|
|
include_sudoers_d: node['authorization']['sudo']['include_sudoers_d'],
|
|
agent_forwarding: node['authorization']['sudo']['agent_forwarding'],
|
|
sudoers_defaults: node['authorization']['sudo']['sudoers_defaults'],
|
|
command_aliases: node['authorization']['sudo']['command_aliases'],
|
|
env_keep_add: node['authorization']['sudo']['env_keep_add'],
|
|
env_keep_subtract: node['authorization']['sudo']['env_keep_subtract'],
|
|
custom_commands_users: node['authorization']['sudo']['custom_commands']['users'],
|
|
custom_commands_groups: node['authorization']['sudo']['custom_commands']['groups'],
|
|
config_prefix: config_prefix
|
|
)
|
|
end
|