chef 17.10.114 → 18.0.169
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +19 -12
- data/README.md +7 -7
- data/Rakefile +3 -22
- data/{chef-universal-mingw32.gemspec → chef-universal-mingw-ucrt.gemspec} +8 -7
- data/chef.gemspec +15 -8
- data/lib/chef/api_client_v1.rb +9 -1
- data/lib/chef/application/exit_code.rb +3 -3
- data/lib/chef/client.rb +171 -20
- data/lib/chef/compliance/input.rb +1 -1
- data/lib/chef/compliance/profile.rb +1 -1
- data/lib/chef/compliance/profile_collection.rb +0 -1
- data/lib/chef/compliance/waiver.rb +1 -1
- data/lib/chef/cookbook/syntax_check.rb +2 -2
- data/lib/chef/dsl/reader_helpers.rb +1 -1
- data/lib/chef/dsl/rest_resource.rb +77 -0
- data/lib/chef/event_dispatch/base.rb +3 -0
- data/lib/chef/exceptions.rb +8 -0
- data/lib/chef/http/authenticator.rb +170 -3
- data/lib/chef/http/ssl_policies.rb +3 -3
- data/lib/chef/mixin/checksum.rb +0 -6
- data/lib/chef/mixin/homebrew_user.rb +5 -15
- data/lib/chef/mixin/powershell_exec.rb +5 -28
- data/lib/chef/node/mixin/immutablize_array.rb +1 -0
- data/lib/chef/property.rb +5 -3
- data/lib/chef/provider/file.rb +2 -2
- data/lib/chef/provider/group/windows.rb +1 -1
- data/lib/chef/provider/http_request.rb +11 -9
- data/lib/chef/provider/mount/linux.rb +5 -0
- data/lib/chef/provider/mount/mount.rb +8 -0
- data/lib/chef/provider/mount/windows.rb +1 -1
- data/lib/chef/provider/package/chocolatey.rb +1 -18
- data/lib/chef/provider/package/rubygems.rb +1 -1
- data/lib/chef/provider/package/windows/msi.rb +2 -2
- data/lib/chef/provider/package/windows/registry_uninstall_entry.rb +1 -1
- data/lib/chef/provider/package/windows.rb +1 -1
- data/lib/chef/provider/package/zypper/version.rb +60 -0
- data/lib/chef/provider/package/zypper.rb +47 -8
- data/lib/chef/provider/service/windows.rb +1 -2
- data/lib/chef/provider/user/aix.rb +5 -0
- data/lib/chef/provider/user/linux.rb +29 -0
- data/lib/chef/provider/user/mac.rb +1 -1
- data/lib/chef/provider/user.rb +46 -14
- data/lib/chef/provider.rb +1 -1
- data/lib/chef/recipe.rb +1 -1
- data/lib/chef/resource/_rest_resource.rb +389 -0
- data/lib/chef/resource/alternatives.rb +0 -1
- data/lib/chef/resource/apt_package.rb +0 -1
- data/lib/chef/resource/apt_preference.rb +0 -1
- data/lib/chef/resource/apt_repository.rb +0 -1
- data/lib/chef/resource/apt_update.rb +0 -1
- data/lib/chef/resource/archive_file.rb +0 -1
- data/lib/chef/resource/bash.rb +0 -1
- data/lib/chef/resource/batch.rb +0 -1
- data/lib/chef/resource/bff_package.rb +0 -1
- data/lib/chef/resource/breakpoint.rb +0 -1
- data/lib/chef/resource/build_essential.rb +0 -1
- data/lib/chef/resource/cab_package.rb +0 -1
- data/lib/chef/resource/chef_client_config.rb +12 -14
- data/lib/chef/resource/chef_client_cron.rb +1 -2
- data/lib/chef/resource/chef_client_launchd.rb +2 -2
- data/lib/chef/resource/chef_client_scheduled_task.rb +3 -3
- data/lib/chef/resource/chef_client_systemd_timer.rb +1 -2
- data/lib/chef/resource/chef_client_trusted_certificate.rb +0 -1
- data/lib/chef/resource/chef_gem.rb +0 -1
- data/lib/chef/resource/chef_handler.rb +0 -1
- data/lib/chef/resource/chef_sleep.rb +1 -3
- data/lib/chef/resource/chef_vault_secret.rb +0 -1
- data/lib/chef/resource/chocolatey_config.rb +0 -1
- data/lib/chef/resource/chocolatey_feature.rb +0 -1
- data/lib/chef/resource/chocolatey_package.rb +0 -1
- data/lib/chef/resource/chocolatey_source.rb +0 -1
- data/lib/chef/resource/cookbook_file.rb +0 -1
- data/lib/chef/resource/cron/_cron_shared.rb +0 -1
- data/lib/chef/resource/cron/cron.rb +0 -1
- data/lib/chef/resource/cron/cron_d.rb +15 -1
- data/lib/chef/resource/cron_access.rb +0 -1
- data/lib/chef/resource/csh.rb +0 -1
- data/lib/chef/resource/directory.rb +0 -1
- data/lib/chef/resource/dmg_package.rb +0 -1
- data/lib/chef/resource/dnf_package.rb +0 -1
- data/lib/chef/resource/dpkg_package.rb +0 -1
- data/lib/chef/resource/dsc_resource.rb +0 -1
- data/lib/chef/resource/dsc_script.rb +0 -1
- data/lib/chef/resource/execute.rb +0 -1
- data/lib/chef/resource/file.rb +0 -1
- data/lib/chef/resource/freebsd_package.rb +0 -1
- data/lib/chef/resource/gem_package.rb +0 -1
- data/lib/chef/resource/group.rb +25 -2
- data/lib/chef/resource/habitat/habitat_package.rb +0 -1
- data/lib/chef/resource/habitat/habitat_sup.rb +6 -7
- data/lib/chef/resource/habitat/habitat_sup_windows.rb +1 -1
- data/lib/chef/resource/habitat_config.rb +0 -1
- data/lib/chef/resource/habitat_install.rb +0 -1
- data/lib/chef/resource/habitat_service.rb +0 -1
- data/lib/chef/resource/habitat_user_toml.rb +0 -1
- data/lib/chef/resource/homebrew_cask.rb +8 -8
- data/lib/chef/resource/homebrew_package.rb +1 -2
- data/lib/chef/resource/homebrew_tap.rb +5 -6
- data/lib/chef/resource/homebrew_update.rb +0 -2
- data/lib/chef/resource/hostname.rb +0 -1
- data/lib/chef/resource/http_request.rb +0 -1
- data/lib/chef/resource/ifconfig.rb +0 -1
- data/lib/chef/resource/inspec_input.rb +0 -1
- data/lib/chef/resource/inspec_waiver.rb +0 -1
- data/lib/chef/resource/inspec_waiver_file_entry.rb +2 -3
- data/lib/chef/resource/ips_package.rb +0 -1
- data/lib/chef/resource/kernel_module.rb +0 -1
- data/lib/chef/resource/ksh.rb +0 -1
- data/lib/chef/resource/launchd.rb +0 -1
- data/lib/chef/resource/link.rb +0 -1
- data/lib/chef/resource/locale.rb +2 -6
- data/lib/chef/resource/log.rb +0 -1
- data/lib/chef/resource/lwrp_base.rb +0 -4
- data/lib/chef/resource/macos_userdefaults.rb +5 -10
- data/lib/chef/resource/macosx_service.rb +0 -1
- data/lib/chef/resource/macports_package.rb +0 -1
- data/lib/chef/resource/mdadm.rb +0 -1
- data/lib/chef/resource/mount.rb +0 -1
- data/lib/chef/resource/msu_package.rb +0 -1
- data/lib/chef/resource/notify_group.rb +0 -2
- data/lib/chef/resource/ohai.rb +0 -1
- data/lib/chef/resource/ohai_hint.rb +0 -1
- data/lib/chef/resource/openbsd_package.rb +0 -1
- data/lib/chef/resource/openssl_dhparam.rb +0 -2
- data/lib/chef/resource/openssl_ec_private_key.rb +0 -2
- data/lib/chef/resource/openssl_ec_public_key.rb +0 -2
- data/lib/chef/resource/openssl_rsa_private_key.rb +0 -2
- data/lib/chef/resource/openssl_rsa_public_key.rb +0 -2
- data/lib/chef/resource/openssl_x509_certificate.rb +0 -2
- data/lib/chef/resource/openssl_x509_crl.rb +0 -2
- data/lib/chef/resource/openssl_x509_request.rb +0 -2
- data/lib/chef/resource/osx_profile.rb +0 -1
- data/lib/chef/resource/package.rb +0 -1
- data/lib/chef/resource/pacman_package.rb +0 -1
- data/lib/chef/resource/paludis_package.rb +0 -1
- data/lib/chef/resource/perl.rb +0 -1
- data/lib/chef/resource/plist.rb +7 -3
- data/lib/chef/resource/portage_package.rb +0 -1
- data/lib/chef/resource/powershell_package.rb +0 -1
- data/lib/chef/resource/powershell_package_source.rb +0 -1
- data/lib/chef/resource/powershell_script.rb +0 -1
- data/lib/chef/resource/python.rb +0 -1
- data/lib/chef/resource/reboot.rb +0 -1
- data/lib/chef/resource/registry_key.rb +0 -1
- data/lib/chef/resource/remote_directory.rb +0 -1
- data/lib/chef/resource/remote_file.rb +0 -1
- data/lib/chef/resource/rhsm_errata.rb +0 -1
- data/lib/chef/resource/rhsm_errata_level.rb +0 -1
- data/lib/chef/resource/rhsm_register.rb +0 -3
- data/lib/chef/resource/rhsm_repo.rb +0 -1
- data/lib/chef/resource/rhsm_subscription.rb +0 -1
- data/lib/chef/resource/route.rb +0 -1
- data/lib/chef/resource/rpm_package.rb +0 -1
- data/lib/chef/resource/ruby.rb +0 -1
- data/lib/chef/resource/ruby_block.rb +0 -1
- data/lib/chef/resource/scm/_scm.rb +0 -2
- data/lib/chef/resource/scm/git.rb +0 -2
- data/lib/chef/resource/scm/subversion.rb +0 -2
- data/lib/chef/resource/script.rb +0 -1
- data/lib/chef/resource/selinux/common_helpers.rb +47 -0
- data/lib/chef/resource/selinux/selinux_debian.erb +18 -0
- data/lib/chef/resource/selinux/selinux_default.erb +15 -0
- data/lib/chef/resource/selinux_boolean.rb +101 -0
- data/lib/chef/resource/selinux_fcontext.rb +160 -0
- data/lib/chef/resource/selinux_install.rb +107 -0
- data/lib/chef/resource/selinux_module.rb +143 -0
- data/lib/chef/resource/selinux_permissive.rb +64 -0
- data/lib/chef/resource/selinux_port.rb +118 -0
- data/lib/chef/resource/selinux_state.rb +166 -0
- data/lib/chef/resource/service.rb +0 -1
- data/lib/chef/resource/smartos_package.rb +0 -1
- data/lib/chef/resource/snap_package.rb +0 -1
- data/lib/chef/resource/solaris_package.rb +0 -1
- data/lib/chef/resource/ssh_known_hosts_entry.rb +0 -1
- data/lib/chef/resource/sudo.rb +0 -1
- data/lib/chef/resource/support/client.erb +2 -2
- data/lib/chef/resource/swap_file.rb +0 -1
- data/lib/chef/resource/sysctl.rb +1 -2
- data/lib/chef/resource/systemd_unit.rb +0 -1
- data/lib/chef/resource/template.rb +0 -1
- data/lib/chef/resource/timezone.rb +0 -1
- data/lib/chef/resource/user/aix_user.rb +0 -1
- data/lib/chef/resource/user/linux_user.rb +0 -1
- data/lib/chef/resource/user/mac_user.rb +0 -1
- data/lib/chef/resource/user/pw_user.rb +0 -1
- data/lib/chef/resource/user/solaris_user.rb +0 -1
- data/lib/chef/resource/user/windows_user.rb +0 -1
- data/lib/chef/resource/user.rb +10 -1
- data/lib/chef/resource/user_ulimit.rb +0 -1
- data/lib/chef/resource/whyrun_safe_ruby_block.rb +0 -1
- data/lib/chef/resource/windows_ad_join.rb +0 -2
- data/lib/chef/resource/windows_audit_policy.rb +0 -2
- data/lib/chef/resource/windows_auto_run.rb +0 -1
- data/lib/chef/resource/windows_defender.rb +0 -1
- data/lib/chef/resource/windows_defender_exclusion.rb +0 -1
- data/lib/chef/resource/windows_dfs_folder.rb +0 -1
- data/lib/chef/resource/windows_dfs_namespace.rb +0 -1
- data/lib/chef/resource/windows_dfs_server.rb +0 -1
- data/lib/chef/resource/windows_dns_record.rb +0 -1
- data/lib/chef/resource/windows_dns_zone.rb +0 -1
- data/lib/chef/resource/windows_env.rb +0 -1
- data/lib/chef/resource/windows_feature.rb +0 -1
- data/lib/chef/resource/windows_feature_dism.rb +0 -1
- data/lib/chef/resource/windows_feature_powershell.rb +0 -1
- data/lib/chef/resource/windows_firewall_profile.rb +0 -2
- data/lib/chef/resource/windows_firewall_rule.rb +0 -1
- data/lib/chef/resource/windows_font.rb +2 -3
- data/lib/chef/resource/windows_package.rb +0 -1
- data/lib/chef/resource/windows_pagefile.rb +0 -2
- data/lib/chef/resource/windows_path.rb +0 -1
- data/lib/chef/resource/windows_printer.rb +0 -1
- data/lib/chef/resource/windows_printer_port.rb +0 -1
- data/lib/chef/resource/windows_script.rb +0 -2
- data/lib/chef/resource/windows_security_policy.rb +0 -1
- data/lib/chef/resource/windows_service.rb +0 -1
- data/lib/chef/resource/windows_share.rb +0 -1
- data/lib/chef/resource/windows_shortcut.rb +1 -2
- data/lib/chef/resource/windows_task.rb +0 -1
- data/lib/chef/resource/windows_uac.rb +0 -1
- data/lib/chef/resource/windows_update_settings.rb +0 -1
- data/lib/chef/resource/windows_user_privilege.rb +0 -1
- data/lib/chef/resource/windows_workgroup.rb +0 -1
- data/lib/chef/resource/yum_package.rb +0 -1
- data/lib/chef/resource/yum_repository.rb +0 -1
- data/lib/chef/resource/zypper_package.rb +0 -1
- data/lib/chef/resource/zypper_repository.rb +0 -1
- data/lib/chef/resource.rb +12 -5
- data/lib/chef/resources.rb +7 -0
- data/lib/chef/run_context.rb +3 -3
- data/lib/chef/secret_fetcher/azure_key_vault.rb +3 -3
- data/lib/chef/version.rb +1 -1
- data/lib/chef/win32/handle.rb +6 -7
- data/lib/chef/win32/registry.rb +7 -3
- data/spec/data/rubygems.org/sexp_processor-info +2 -1
- data/spec/data/trusted_certs/example.crt +20 -29
- data/spec/data/trusted_certs/example_no_cn.crt +34 -30
- data/spec/data/trusted_certs/opscode.pem +54 -33
- data/spec/functional/resource/chocolatey_package_spec.rb +20 -32
- data/spec/functional/resource/dsc_script_spec.rb +1 -1
- data/spec/functional/resource/group_spec.rb +10 -6
- data/spec/functional/resource/link_spec.rb +8 -8
- data/spec/functional/resource/macos_userdefaults_spec.rb +4 -4
- data/spec/functional/resource/plist_spec.rb +25 -0
- data/spec/functional/resource/user/linux_user_spec.rb +127 -0
- data/spec/functional/resource/windows_certificate_spec.rb +1 -26
- data/spec/functional/resource/windows_font_spec.rb +12 -9
- data/spec/functional/resource/yum_package_spec.rb +1 -1
- data/spec/functional/resource/zypper_package_spec.rb +12 -10
- data/spec/functional/shell_spec.rb +1 -2
- data/spec/functional/version_spec.rb +1 -1
- data/spec/integration/client/client_spec.rb +82 -3
- data/spec/integration/client/exit_code_spec.rb +1 -1
- data/spec/integration/client/ipv6_spec.rb +1 -1
- data/spec/integration/compliance/compliance_spec.rb +1 -1
- data/spec/integration/recipes/accumulator_spec.rb +1 -1
- data/spec/integration/recipes/lwrp_inline_resources_spec.rb +1 -1
- data/spec/integration/recipes/lwrp_spec.rb +1 -1
- data/spec/integration/recipes/notifies_spec.rb +1 -1
- data/spec/integration/recipes/notifying_block_spec.rb +1 -1
- data/spec/integration/recipes/remote_directory.rb +1 -1
- data/spec/integration/recipes/unified_mode_spec.rb +1 -1
- data/spec/integration/recipes/use_partial_spec.rb +2 -1
- data/spec/integration/solo/solo_spec.rb +2 -2
- data/spec/spec_helper.rb +1 -0
- data/spec/support/platform_helpers.rb +4 -0
- data/spec/support/ruby_installer.rb +1 -1
- data/spec/support/shared/functional/windows_script.rb +2 -2
- data/spec/unit/application/client_spec.rb +0 -10
- data/spec/unit/client_spec.rb +57 -8
- data/spec/unit/compliance/reporter/chef_server_automate_spec.rb +1 -1
- data/spec/unit/cookbook/syntax_check_spec.rb +3 -0
- data/spec/unit/http/authenticator_spec.rb +68 -0
- data/spec/unit/mixin/checksum_spec.rb +0 -28
- data/spec/unit/mixin/homebrew_user_spec.rb +7 -30
- data/spec/unit/mixin/powershell_exec_spec.rb +5 -5
- data/spec/unit/platform/query_helpers_spec.rb +2 -17
- data/spec/unit/provider/http_request_spec.rb +60 -72
- data/spec/unit/provider/mount/linux_spec.rb +10 -0
- data/spec/unit/provider/package/chocolatey_spec.rb +3 -19
- data/spec/unit/provider/package/rubygems_spec.rb +1 -1
- data/spec/unit/provider/package/zypper_spec.rb +32 -0
- data/spec/unit/provider/user/linux_spec.rb +51 -11
- data/spec/unit/provider/user_spec.rb +24 -6
- data/spec/unit/resource/archive_file_spec.rb +1 -1
- data/spec/unit/resource/chef_client_cron_spec.rb +5 -0
- data/spec/unit/resource/chef_client_launchd_spec.rb +5 -0
- data/spec/unit/resource/chef_client_scheduled_task_spec.rb +5 -0
- data/spec/unit/resource/chef_client_systemd_timer_spec.rb +2 -2
- data/spec/unit/resource/cron_d_spec.rb +37 -1
- data/spec/unit/resource/macos_user_defaults_spec.rb +4 -4
- data/spec/unit/resource/rest_resource_spec.rb +381 -0
- data/spec/unit/resource/selinux_boolean_spec.rb +92 -0
- data/spec/unit/resource/selinux_fcontext_spec.rb +65 -0
- data/spec/unit/resource/selinux_install_spec.rb +60 -0
- data/spec/unit/resource/selinux_module_spec.rb +55 -0
- data/spec/unit/resource/selinux_permissive_spec.rb +39 -0
- data/spec/unit/resource/selinux_port_spec.rb +42 -0
- data/spec/unit/resource/selinux_state_spec.rb +46 -0
- data/spec/unit/resource/sysctl_spec.rb +2 -2
- data/spec/unit/resource/user/linux_user_spec.rb +42 -0
- data/spec/unit/resource_spec.rb +0 -1
- data/spec/unit/util/dsc/local_configuration_manager_spec.rb +1 -1
- data/tasks/rspec.rb +1 -1
- metadata +103 -37
- /data/spec/functional/assets/chocolatey_feed/{test-A.1.0.0.nupkg → test-A.1.0.nupkg} +0 -0
- /data/spec/functional/assets/chocolatey_feed/{test-A.1.5.0.nupkg → test-A.1.5.nupkg} +0 -0
- /data/spec/functional/assets/chocolatey_feed/{test-A.2.0.0.nupkg → test-A.2.0.nupkg} +0 -0
- /data/spec/functional/assets/chocolatey_feed/{test-B.1.0.0.nupkg → test-B.1.0.nupkg} +0 -0
- /data/spec/functional/assets/yumrepo/repodata/{01a3b-filelists.sqlite.bz2 → 4632d67cb92636e7575d911c24f0e04d3505a944e97c483abe0c3e73a7c62d33-filelists.sqlite.bz2} +0 -0
- /data/spec/functional/assets/yumrepo/repodata/{6bf96-other.xml.gz → 74599b793e54d877323837d2d81a1c3c594c44e4335f9528234bb490f7b9b439-other.xml.gz} +0 -0
- /data/spec/functional/assets/yumrepo/repodata/{5dc1e-primary.sqlite.bz2 → a845d418f919d2115ab95a56b2c76f6825ad0d0bede49181a55c04f58995d057-primary.sqlite.bz2} +0 -0
- /data/spec/functional/assets/yumrepo/repodata/{7c365-other.sqlite.bz2 → af9b7cf9ef23bd7b43068d74a460f3b5d06753d638e58e4a0c9edc35bfb9cdc4-other.sqlite.bz2} +0 -0
- /data/spec/functional/assets/yumrepo/repodata/{401dc-filelists.xml.gz → bdb4f5f1492a3b9532f22c43110a81500dd744f23da0aec5c33b2a41317c737d-filelists.xml.gz} +0 -0
- /data/spec/functional/assets/yumrepo/repodata/{dabe2-primary.xml.gz → c10d1d34ce99e02f12ec96ef68360543ab1bb7c3cb81a4a2bf78df7d8597e9df-primary.xml.gz} +0 -0
data/lib/chef/resource/bash.rb
CHANGED
data/lib/chef/resource/batch.rb
CHANGED
@@ -20,7 +20,6 @@ require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
|
20
20
|
class Chef
|
21
21
|
class Resource
|
22
22
|
class ChefClientConfig < Chef::Resource
|
23
|
-
unified_mode true
|
24
23
|
|
25
24
|
provides :chef_client_config
|
26
25
|
|
@@ -253,21 +252,20 @@ class Chef
|
|
253
252
|
description: "The data collector token to interact with the data collector server URL (Automate). Note: If possible, use Chef Infra Server to do all data collection reporting, as this removes the need to distribute tokens to individual nodes.",
|
254
253
|
introduced: "17.8"
|
255
254
|
|
256
|
-
action :create, description: "Create a client.rb config file for configuring #{ChefUtils::Dist::Infra::PRODUCT}." do
|
257
|
-
|
258
|
-
|
255
|
+
action :create, description: "Create a client.rb config file and folders for configuring #{ChefUtils::Dist::Infra::PRODUCT}." do
|
256
|
+
[
|
257
|
+
new_resource.config_directory,
|
258
|
+
(::File.dirname(new_resource.log_location) unless new_resource.log_location.nil?),
|
259
|
+
new_resource.file_backup_path,
|
260
|
+
new_resource.file_cache_path,
|
261
|
+
::File.join(new_resource.config_directory, "client.d"),
|
262
|
+
(::File.dirname(new_resource.pid_file) unless new_resource.pid_file.nil?),
|
263
|
+
].compact.each do |dir_path|
|
264
|
+
|
265
|
+
directory dir_path do
|
259
266
|
user new_resource.user unless new_resource.user.nil?
|
260
267
|
group new_resource.group unless new_resource.group.nil?
|
261
|
-
mode "0750"
|
262
|
-
recursive true
|
263
|
-
end
|
264
|
-
end
|
265
|
-
|
266
|
-
unless ::Dir.exist?(::File.join(new_resource.config_directory, "client.d"))
|
267
|
-
directory ::File.join(new_resource.config_directory, "client.d") do
|
268
|
-
user new_resource.user unless new_resource.user.nil?
|
269
|
-
group new_resource.group unless new_resource.group.nil?
|
270
|
-
mode "0750"
|
268
|
+
mode dir_path == ::File.dirname(new_resource.log_location) ? "0755" : "0750"
|
271
269
|
recursive true
|
272
270
|
end
|
273
271
|
end
|
@@ -22,7 +22,6 @@ require "digest/md5" unless defined?(Digest::MD5)
|
|
22
22
|
class Chef
|
23
23
|
class Resource
|
24
24
|
class ChefClientCron < Chef::Resource
|
25
|
-
unified_mode true
|
26
25
|
|
27
26
|
provides :chef_client_cron
|
28
27
|
|
@@ -99,7 +98,7 @@ class Chef
|
|
99
98
|
property :splay, [Integer, String],
|
100
99
|
default: 300,
|
101
100
|
coerce: proc { |x| Integer(x) },
|
102
|
-
callbacks: { "should be a positive number" => proc { |v| v
|
101
|
+
callbacks: { "should be a positive number" => proc { |v| v >= 0 } },
|
103
102
|
description: "A random number of seconds between 0 and X to add to interval so that all #{ChefUtils::Dist::Infra::CLIENT} commands don't execute at the same time."
|
104
103
|
|
105
104
|
property :mailto, String,
|
@@ -19,7 +19,6 @@ require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
|
19
19
|
class Chef
|
20
20
|
class Resource
|
21
21
|
class ChefClientLaunchd < Chef::Resource
|
22
|
-
unified_mode true
|
23
22
|
|
24
23
|
provides :chef_client_launchd
|
25
24
|
|
@@ -61,7 +60,7 @@ class Chef
|
|
61
60
|
property :splay, [Integer, String],
|
62
61
|
default: 300,
|
63
62
|
coerce: proc { |x| Integer(x) },
|
64
|
-
callbacks: { "should be a positive number" => proc { |v| v
|
63
|
+
callbacks: { "should be a positive number" => proc { |v| v >= 0 } },
|
65
64
|
description: "A random number of seconds between 0 and X to add to interval so that all #{ChefUtils::Dist::Infra::CLIENT} commands don't execute at the same time."
|
66
65
|
|
67
66
|
property :accept_chef_license, [true, false],
|
@@ -135,6 +134,7 @@ class Chef
|
|
135
134
|
program_arguments ["/bin/bash",
|
136
135
|
"-c",
|
137
136
|
"echo; echo #{ChefUtils::Dist::Infra::PRODUCT} launchd daemon config has been updated. Manually unloading and reloading the daemon; echo Now unloading the daemon; sudo /bin/launchctl unload /Library/LaunchDaemons/com.#{ChefUtils::Dist::Infra::SHORT}.#{ChefUtils::Dist::Infra::CLIENT}.plist; sleep 2; echo Now loading the daemon; sudo /bin/launchctl load /Library/LaunchDaemons/com.#{ChefUtils::Dist::Infra::SHORT}.#{ChefUtils::Dist::Infra::CLIENT}.plist"]
|
137
|
+
run_at_load true
|
138
138
|
action :enable # enable creates the plist & triggers service restarts on change
|
139
139
|
end
|
140
140
|
|
@@ -20,7 +20,6 @@ require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
|
20
20
|
class Chef
|
21
21
|
class Resource
|
22
22
|
class ChefClientScheduledTask < Chef::Resource
|
23
|
-
unified_mode true
|
24
23
|
|
25
24
|
provides :chef_client_scheduled_task
|
26
25
|
|
@@ -108,7 +107,7 @@ class Chef
|
|
108
107
|
|
109
108
|
property :splay, [Integer, String],
|
110
109
|
coerce: proc { |x| Integer(x) },
|
111
|
-
callbacks: { "should be a positive number" => proc { |v| v
|
110
|
+
callbacks: { "should be a positive number" => proc { |v| v >= 0 } },
|
112
111
|
description: "A random number of seconds between 0 and X to add to interval so that all #{ChefUtils::Dist::Infra::CLIENT} commands don't execute at the same time.",
|
113
112
|
default: 300
|
114
113
|
|
@@ -123,7 +122,8 @@ class Chef
|
|
123
122
|
|
124
123
|
property :config_directory, String,
|
125
124
|
description: "The path of the config directory.",
|
126
|
-
default: ChefConfig::Config.etc_chef_dir
|
125
|
+
default: ChefConfig::Config.etc_chef_dir,
|
126
|
+
default_description: ChefConfig::Config.c_chef_dir
|
127
127
|
|
128
128
|
property :log_directory, String,
|
129
129
|
description: "The path of the directory to create the log file in.",
|
@@ -20,7 +20,6 @@ require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
|
20
20
|
class Chef
|
21
21
|
class Resource
|
22
22
|
class ChefClientSystemdTimer < Chef::Resource
|
23
|
-
unified_mode true
|
24
23
|
|
25
24
|
provides :chef_client_systemd_timer
|
26
25
|
|
@@ -177,7 +176,7 @@ class Chef
|
|
177
176
|
}
|
178
177
|
|
179
178
|
unit["Service"]["ConditionACPower"] = "true" unless new_resource.run_on_battery
|
180
|
-
unit["Service"]["CPUQuota"] =
|
179
|
+
unit["Service"]["CPUQuota"] = new_resource.cpu_quota if new_resource.cpu_quota
|
181
180
|
unit["Service"]["Environment"] = new_resource.environment.collect { |k, v| "\"#{k}=#{v}\"" } unless new_resource.environment.empty?
|
182
181
|
unit
|
183
182
|
end
|
@@ -22,8 +22,6 @@ class Chef
|
|
22
22
|
class ChefSleep < Chef::Resource
|
23
23
|
provides :chef_sleep
|
24
24
|
|
25
|
-
unified_mode true
|
26
|
-
|
27
25
|
description "Use the **chef_sleep** resource to pause (sleep) for a number of seconds during a #{ChefUtils::Dist::Infra::PRODUCT} run. Only use this resource when a command or service exits successfully but is not ready for the next step in a recipe."
|
28
26
|
introduced "15.5"
|
29
27
|
examples <<~DOC
|
@@ -47,7 +45,7 @@ class Chef
|
|
47
45
|
service 'Service that is slow to start and reports as started' do
|
48
46
|
service_name 'my_database'
|
49
47
|
action :start
|
50
|
-
notifies :sleep, chef_sleep[
|
48
|
+
notifies :sleep, 'chef_sleep[wait for service start]'
|
51
49
|
end
|
52
50
|
|
53
51
|
chef_sleep 'wait for service start' do
|
@@ -17,7 +17,6 @@
|
|
17
17
|
class Chef
|
18
18
|
class Resource
|
19
19
|
class ChocolateyFeature < Chef::Resource
|
20
|
-
unified_mode true
|
21
20
|
provides :chocolatey_feature
|
22
21
|
|
23
22
|
description "Use the **chocolatey_feature** resource to enable and disable Chocolatey features. Note: The Chocolatey package manager is not installed on Windows by default. You will need to install it prior to using this resource by adding the [Chocolatey cookbook](https://supermarket.chef.io/cookbooks/chocolatey/) to your node's run list."
|
@@ -17,7 +17,6 @@
|
|
17
17
|
class Chef
|
18
18
|
class Resource
|
19
19
|
class ChocolateySource < Chef::Resource
|
20
|
-
unified_mode true
|
21
20
|
provides :chocolatey_source
|
22
21
|
|
23
22
|
description "Use the **chocolatey_source** resource to add, remove, enable, or disable Chocolatey sources. Note: The Chocolatey package manager is not installed on Windows by default. You will need to install it prior to using this resource by adding the [Chocolatey cookbook](https://supermarket.chef.io/cookbooks/chocolatey/) to your node's run list."
|
@@ -23,7 +23,6 @@ require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
|
23
23
|
class Chef
|
24
24
|
class Resource
|
25
25
|
class CronD < Chef::Resource
|
26
|
-
unified_mode true
|
27
26
|
|
28
27
|
use "cron_shared"
|
29
28
|
|
@@ -146,6 +145,21 @@ class Chef
|
|
146
145
|
new_resource.cron_name.tr(".", "-")
|
147
146
|
end
|
148
147
|
|
148
|
+
def define_resource_requirements
|
149
|
+
requirements.assert(:create, :create_if_missing) do |a|
|
150
|
+
a.assertion do
|
151
|
+
# ensure valid cron job names for linux, otherwise the jobs won't be executed
|
152
|
+
if linux?
|
153
|
+
new_resource.cron_name =~ /^[a-zA-Z0-9_-]+$/
|
154
|
+
else
|
155
|
+
true
|
156
|
+
end
|
157
|
+
end
|
158
|
+
a.failure_message("The cron job name should contain letters, numbers, hyphens and underscores only.")
|
159
|
+
a.block_action!
|
160
|
+
end
|
161
|
+
end
|
162
|
+
|
149
163
|
def create_template(create_action)
|
150
164
|
# cleanup the legacy named job if it exists
|
151
165
|
file "#{new_resource.cron_name} legacy named cron.d file" do
|
data/lib/chef/resource/csh.rb
CHANGED
data/lib/chef/resource/file.rb
CHANGED
data/lib/chef/resource/group.rb
CHANGED
@@ -20,11 +20,34 @@
|
|
20
20
|
class Chef
|
21
21
|
class Resource
|
22
22
|
class Group < Chef::Resource
|
23
|
-
unified_mode true
|
24
23
|
state_attrs :members
|
25
24
|
|
26
25
|
description "Use the **group** resource to manage a local group."
|
27
26
|
|
27
|
+
examples <<~EXAMPLES
|
28
|
+
The following examples demonstrate various approaches for using the **group** resource in recipes:
|
29
|
+
|
30
|
+
Append users to groups:
|
31
|
+
|
32
|
+
```ruby
|
33
|
+
group 'www-data' do
|
34
|
+
action :modify
|
35
|
+
members 'maintenance'
|
36
|
+
append true
|
37
|
+
end
|
38
|
+
```
|
39
|
+
|
40
|
+
Add a user to group on the Windows platform:
|
41
|
+
|
42
|
+
```ruby
|
43
|
+
group 'Administrators' do
|
44
|
+
members ['domain\\foo']
|
45
|
+
append true
|
46
|
+
action :modify
|
47
|
+
end
|
48
|
+
```
|
49
|
+
EXAMPLES
|
50
|
+
|
28
51
|
provides :group
|
29
52
|
|
30
53
|
allowed_actions :create, :remove, :modify, :manage
|
@@ -39,7 +62,7 @@ class Chef
|
|
39
62
|
|
40
63
|
property :members, [String, Array], default: [],
|
41
64
|
coerce: proc { |arg| arg.is_a?(String) ? arg.split(/\s*,\s*/) : arg },
|
42
|
-
description: "Which users should be set or appended to a group. When more than one group member is identified, the list of members should be an array: members ['user1', 'user2']
|
65
|
+
description: "Which users should be set or appended to a group. When more than one group member is identified, the list of members should be an array: `members ['user1', 'user2']`."
|
43
66
|
|
44
67
|
property :excluded_members, [String, Array], default: [],
|
45
68
|
coerce: proc { |arg| arg.is_a?(String) ? arg.split(/\s*,\s*/) : arg },
|
@@ -20,7 +20,6 @@ require_relative "../../resource"
|
|
20
20
|
class Chef
|
21
21
|
class Resource
|
22
22
|
class HabitatSup < Chef::Resource
|
23
|
-
unified_mode true
|
24
23
|
|
25
24
|
provides :habitat_sup do |_node|
|
26
25
|
false
|
@@ -49,7 +48,7 @@ class Chef
|
|
49
48
|
|
50
49
|
```ruby
|
51
50
|
habitat_sup 'default' do
|
52
|
-
bldr_url 'https://bldr.
|
51
|
+
bldr_url 'https://bldr.example.com'
|
53
52
|
end
|
54
53
|
```
|
55
54
|
|
@@ -57,13 +56,13 @@ class Chef
|
|
57
56
|
|
58
57
|
```ruby
|
59
58
|
habitat_sup 'default' do
|
60
|
-
bldr_url 'https://bldr.
|
59
|
+
bldr_url 'https://bldr.example.com'
|
61
60
|
habitat_channel 'dev'
|
62
61
|
update_condition 'track-channel'
|
63
62
|
end
|
64
63
|
```
|
65
64
|
|
66
|
-
**Provide
|
65
|
+
**Provide event stream information**
|
67
66
|
|
68
67
|
```ruby
|
69
68
|
habitat_sup 'default' do
|
@@ -71,7 +70,7 @@ class Chef
|
|
71
70
|
event_stream_application 'myapp'
|
72
71
|
event_stream_environment 'production'
|
73
72
|
event_stream_site 'MySite'
|
74
|
-
event_stream_url 'automate.
|
73
|
+
event_stream_url 'automate.example.com:4222'
|
75
74
|
event_stream_token 'myawesomea2clitoken='
|
76
75
|
event_stream_cert '/hab/cache/ssl/mycert.crt'
|
77
76
|
end
|
@@ -81,7 +80,7 @@ class Chef
|
|
81
80
|
|
82
81
|
```ruby
|
83
82
|
habitat_sup 'default' do
|
84
|
-
bldr_url 'https://bldr.
|
83
|
+
bldr_url 'https://bldr.example.com'
|
85
84
|
sup_version '1.5.50'
|
86
85
|
launcher_version '13458'
|
87
86
|
service_version '0.6.0' # WINDOWS ONLY
|
@@ -91,7 +90,7 @@ class Chef
|
|
91
90
|
**Set latest version of packages to retain**
|
92
91
|
|
93
92
|
habitat_sup 'default' do
|
94
|
-
bldr_url 'https://bldr.
|
93
|
+
bldr_url 'https://bldr.example.com'
|
95
94
|
sup_version '1.5.86'
|
96
95
|
launcher_version '13458'
|
97
96
|
service_version '0.6.0' # WINDOWS ONLY
|
@@ -20,7 +20,6 @@ require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
|
20
20
|
class Chef
|
21
21
|
class Resource
|
22
22
|
class HabitatService < Chef::Resource
|
23
|
-
unified_mode true
|
24
23
|
provides :habitat_service
|
25
24
|
|
26
25
|
description "Use the **habitat_service** resource to manage Chef Habitat services. This requires that `core/hab-sup` be running as a service. See the `habitat_sup` resource documentation for more information. Note: Applications may run as a specific user. Often with Habitat, the default is `hab`, or `root`. If the application requires another user, then it should be created with Chef's `user` resource."
|