chef 17.0.242-universal-mingw32 → 17.4.25-universal-mingw32
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +4 -14
- data/Rakefile +2 -2
- data/chef.gemspec +10 -20
- data/lib/chef/action_collection.rb +6 -26
- data/lib/chef/application/base.rb +15 -0
- data/lib/chef/application.rb +4 -2
- data/lib/chef/chef_fs/file_pattern.rb +2 -2
- data/lib/chef/client.rb +7 -1
- data/lib/chef/compliance/default_attributes.rb +5 -3
- data/lib/chef/compliance/reporter/automate.rb +1 -1
- data/lib/chef/compliance/runner.rb +17 -3
- data/lib/chef/cookbook/cookbook_version_loader.rb +3 -3
- data/lib/chef/cookbook/gem_installer.rb +5 -1
- data/lib/chef/cookbook_version.rb +26 -4
- data/lib/chef/data_collector/run_end_message.rb +1 -1
- data/lib/chef/data_collector.rb +0 -1
- data/lib/chef/deprecated.rb +14 -4
- data/lib/chef/dsl/declare_resource.rb +5 -10
- data/lib/chef/dsl/render_helpers.rb +44 -0
- data/lib/chef/dsl/secret.rb +64 -0
- data/lib/chef/dsl/toml.rb +116 -0
- data/lib/chef/dsl/universal.rb +5 -0
- data/lib/chef/dsl.rb +1 -0
- data/lib/chef/event_dispatch/base.rb +2 -1
- data/lib/chef/exceptions.rb +23 -0
- data/lib/chef/formatters/doc.rb +2 -1
- data/lib/chef/formatters/error_mapper.rb +2 -2
- data/lib/chef/handler/slow_report.rb +66 -0
- data/lib/chef/handler.rb +46 -8
- data/lib/chef/json_compat.rb +1 -1
- data/lib/chef/node.rb +21 -20
- data/lib/chef/policy_builder/policyfile.rb +88 -45
- data/lib/chef/provider/directory.rb +6 -6
- data/lib/chef/provider/execute.rb +1 -1
- data/lib/chef/provider/file.rb +2 -2
- data/lib/chef/provider/group/dscl.rb +1 -1
- data/lib/chef/provider/launchd.rb +6 -6
- data/lib/chef/provider/link.rb +1 -1
- data/lib/chef/provider/lwrp_base.rb +1 -1
- data/lib/chef/provider/package/dnf/dnf_helper.py +11 -10
- data/lib/chef/provider/package/dnf/python_helper.rb +9 -8
- data/lib/chef/provider/package/habitat.rb +168 -0
- data/lib/chef/provider/package/powershell.rb +5 -0
- data/lib/chef/provider/package/yum/python_helper.rb +15 -10
- data/lib/chef/provider/package/yum/yum_helper.py +46 -62
- data/lib/chef/provider/package/yum.rb +1 -4
- data/lib/chef/provider/registry_key.rb +1 -1
- data/lib/chef/provider/service/systemd.rb +1 -1
- data/lib/chef/provider/subversion.rb +4 -4
- data/lib/chef/provider/support/yum_repo.erb +1 -1
- data/lib/chef/provider/support/zypper_repo.erb +4 -2
- data/lib/chef/provider/systemd_unit.rb +18 -17
- data/lib/chef/provider/template/content.rb +1 -1
- data/lib/chef/provider/user/mac.rb +3 -3
- data/lib/chef/provider/windows_script.rb +1 -1
- data/lib/chef/provider/yum_repository.rb +27 -43
- data/lib/chef/provider/zypper_repository.rb +30 -34
- data/lib/chef/provider.rb +26 -1
- data/lib/chef/provider_resolver.rb +8 -2
- data/lib/chef/providers.rb +1 -0
- data/lib/chef/resource/alternatives.rb +5 -5
- data/lib/chef/resource/apt_preference.rb +2 -2
- data/lib/chef/resource/apt_repository.rb +2 -2
- data/lib/chef/resource/apt_update.rb +4 -4
- data/lib/chef/resource/build_essential.rb +1 -1
- data/lib/chef/resource/chef_client_config.rb +10 -5
- data/lib/chef/resource/chef_client_cron.rb +3 -3
- data/lib/chef/resource/chef_client_launchd.rb +3 -3
- data/lib/chef/resource/chef_client_scheduled_task.rb +15 -15
- data/lib/chef/resource/chef_client_systemd_timer.rb +3 -3
- data/lib/chef/resource/chef_client_trusted_certificate.rb +2 -2
- data/lib/chef/resource/chef_handler.rb +2 -2
- data/lib/chef/resource/chef_sleep.rb +1 -1
- data/lib/chef/resource/chef_vault_secret.rb +2 -2
- data/lib/chef/resource/chocolatey_feature.rb +2 -2
- data/lib/chef/resource/chocolatey_source.rb +1 -1
- data/lib/chef/resource/cron/cron_d.rb +4 -6
- data/lib/chef/resource/cron_access.rb +1 -1
- data/lib/chef/resource/dmg_package.rb +1 -1
- data/lib/chef/resource/dsc_resource.rb +1 -1
- data/lib/chef/resource/execute.rb +5 -5
- data/lib/chef/resource/gem_package.rb +2 -1
- data/lib/chef/resource/group.rb +4 -4
- data/lib/chef/resource/habitat/_habitat_shared.rb +28 -0
- data/lib/chef/resource/habitat/habitat_package.rb +129 -0
- data/lib/chef/resource/habitat/habitat_sup.rb +329 -0
- data/lib/chef/resource/habitat/habitat_sup_systemd.rb +67 -0
- data/lib/chef/resource/habitat/habitat_sup_windows.rb +90 -0
- data/lib/chef/resource/habitat_config.rb +107 -0
- data/lib/chef/resource/habitat_install.rb +247 -0
- data/lib/chef/resource/habitat_service.rb +451 -0
- data/lib/chef/resource/habitat_user_toml.rb +92 -0
- data/lib/chef/resource/homebrew_cask.rb +18 -7
- data/lib/chef/resource/homebrew_package.rb +1 -1
- data/lib/chef/resource/homebrew_tap.rb +4 -3
- data/lib/chef/resource/homebrew_update.rb +2 -2
- data/lib/chef/resource/hostname.rb +49 -7
- data/lib/chef/resource/inspec_waiver_file_entry.rb +156 -0
- data/lib/chef/resource/kernel_module.rb +6 -6
- data/lib/chef/resource/launchd.rb +3 -3
- data/lib/chef/resource/locale.rb +1 -1
- data/lib/chef/resource/lwrp_base.rb +18 -3
- data/lib/chef/resource/macos_userdefaults.rb +2 -2
- data/lib/chef/resource/ohai_hint.rb +2 -6
- data/lib/chef/resource/openbsd_package.rb +17 -0
- data/lib/chef/resource/openssl_dhparam.rb +1 -2
- data/lib/chef/resource/openssl_ec_private_key.rb +1 -3
- data/lib/chef/resource/openssl_ec_public_key.rb +1 -3
- data/lib/chef/resource/openssl_rsa_private_key.rb +1 -3
- data/lib/chef/resource/openssl_rsa_public_key.rb +1 -3
- data/lib/chef/resource/openssl_x509_certificate.rb +1 -4
- data/lib/chef/resource/openssl_x509_crl.rb +1 -3
- data/lib/chef/resource/openssl_x509_request.rb +1 -3
- data/lib/chef/resource/osx_profile.rb +3 -3
- data/lib/chef/resource/plist.rb +1 -1
- data/lib/chef/resource/powershell_package_source.rb +2 -4
- data/lib/chef/resource/reboot.rb +38 -9
- data/lib/chef/resource/remote_directory.rb +2 -2
- data/lib/chef/resource/remote_file.rb +3 -3
- data/lib/chef/resource/rhsm_errata.rb +0 -2
- data/lib/chef/resource/rhsm_errata_level.rb +1 -5
- data/lib/chef/resource/rhsm_repo.rb +15 -0
- data/lib/chef/resource/rhsm_subscription.rb +5 -5
- data/lib/chef/resource/ruby_block.rb +100 -0
- data/lib/chef/resource/scm/subversion.rb +1 -1
- data/lib/chef/resource/ssh_known_hosts_entry.rb +4 -7
- data/lib/chef/resource/sudo.rb +2 -6
- data/lib/chef/resource/support/HabService.dll.config.erb +19 -0
- data/lib/chef/resource/support/client.erb +8 -1
- data/lib/chef/resource/support/sup.toml.erb +179 -0
- data/lib/chef/resource/swap_file.rb +2 -6
- data/lib/chef/resource/sysctl.rb +2 -2
- data/lib/chef/resource/systemd_unit.rb +3 -3
- data/lib/chef/resource/timezone.rb +1 -1
- data/lib/chef/resource/user_ulimit.rb +2 -2
- data/lib/chef/resource/windows_ad_join.rb +2 -2
- data/lib/chef/resource/windows_audit_policy.rb +2 -2
- data/lib/chef/resource/windows_auto_run.rb +2 -2
- data/lib/chef/resource/windows_certificate.rb +1 -1
- data/lib/chef/resource/windows_defender.rb +163 -0
- data/lib/chef/resource/windows_defender_exclusion.rb +125 -0
- data/lib/chef/resource/windows_dfs_folder.rb +2 -2
- data/lib/chef/resource/windows_dfs_namespace.rb +2 -2
- data/lib/chef/resource/windows_dns_record.rb +2 -2
- data/lib/chef/resource/windows_dns_zone.rb +2 -2
- data/lib/chef/resource/windows_env.rb +1 -1
- data/lib/chef/resource/windows_feature.rb +3 -3
- data/lib/chef/resource/windows_feature_dism.rb +3 -5
- data/lib/chef/resource/windows_feature_powershell.rb +3 -3
- data/lib/chef/resource/windows_firewall_profile.rb +2 -2
- data/lib/chef/resource/windows_firewall_rule.rb +20 -6
- data/lib/chef/resource/windows_font.rb +2 -2
- data/lib/chef/resource/windows_pagefile.rb +104 -65
- data/lib/chef/resource/windows_path.rb +4 -4
- data/lib/chef/resource/windows_printer.rb +80 -61
- data/lib/chef/resource/windows_printer_port.rb +48 -65
- data/lib/chef/resource/windows_security_policy.rb +7 -4
- data/lib/chef/resource/windows_share.rb +2 -2
- data/lib/chef/resource/windows_shortcut.rb +1 -1
- data/lib/chef/resource/windows_task.rb +2 -2
- data/lib/chef/resource/windows_uac.rb +3 -5
- data/lib/chef/resource/windows_update_settings.rb +259 -0
- data/lib/chef/resource/windows_user_privilege.rb +2 -2
- data/lib/chef/resource/windows_workgroup.rb +2 -2
- data/lib/chef/resource/yum_package.rb +11 -15
- data/lib/chef/resource/zypper_package.rb +4 -4
- data/lib/chef/resource/zypper_repository.rb +28 -8
- data/lib/chef/resource.rb +20 -25
- data/lib/chef/resource_builder.rb +8 -2
- data/lib/chef/resource_inspector.rb +6 -2
- data/lib/chef/resource_reporter.rb +0 -1
- data/lib/chef/resources.rb +13 -1
- data/lib/chef/run_lock.rb +1 -1
- data/lib/chef/runner.rb +1 -1
- data/lib/chef/secret_fetcher/aws_secrets_manager.rb +65 -0
- data/lib/chef/secret_fetcher/azure_key_vault.rb +78 -0
- data/lib/chef/secret_fetcher/base.rb +76 -0
- data/lib/chef/secret_fetcher/example.rb +46 -0
- data/lib/chef/secret_fetcher.rb +55 -0
- data/lib/chef/shell/ext.rb +3 -3
- data/lib/chef/version.rb +1 -1
- data/lib/chef/win32/api.rb +9 -2
- data/spec/data/knife-home/.chef/plugins/knife/example_home_subcommand.rb +0 -0
- data/spec/data/knife-site-subcommands/plugins/knife/example_subcommand.rb +0 -0
- data/spec/data/knife_subcommand/test_explicit_category.rb +7 -0
- data/spec/data/knife_subcommand/test_name_mapping.rb +4 -0
- data/spec/data/knife_subcommand/test_yourself.rb +21 -0
- data/spec/functional/mixin/from_file_spec.rb +1 -1
- data/spec/functional/resource/dnf_package_spec.rb +857 -537
- data/spec/functional/resource/group_spec.rb +1 -1
- data/spec/functional/resource/link_spec.rb +1 -1
- data/spec/functional/resource/remote_file_spec.rb +1 -1
- data/spec/functional/resource/windows_env_spec.rb +2 -2
- data/spec/functional/resource/windows_hostname_spec.rb +91 -0
- data/spec/functional/resource/windows_pagefile_spec.rb +98 -0
- data/spec/functional/resource/yum_package_spec.rb +495 -428
- data/spec/integration/client/client_spec.rb +0 -20
- data/spec/integration/compliance/compliance_spec.rb +1 -0
- data/spec/integration/recipes/recipe_dsl_spec.rb +1 -1
- data/spec/integration/recipes/resource_action_spec.rb +6 -6
- data/spec/integration/recipes/unified_mode_spec.rb +70 -0
- data/spec/spec_helper.rb +3 -0
- data/spec/support/chef_helpers.rb +1 -1
- data/spec/support/shared/functional/execute_resource.rb +1 -1
- data/spec/support/shared/functional/knife.rb +37 -0
- data/spec/support/shared/integration/knife_support.rb +192 -0
- data/spec/support/shared/unit/knife_shared.rb +39 -0
- data/spec/support/shared/unit/provider/file.rb +3 -9
- data/spec/unit/chef_fs/file_system/repository/directory_spec.rb +1 -1
- data/spec/unit/compliance/runner_spec.rb +46 -2
- data/spec/unit/cookbook_version_spec.rb +52 -0
- data/spec/unit/data_collector_spec.rb +47 -1
- data/spec/unit/dsl/render_helpers_spec.rb +102 -0
- data/spec/unit/dsl/secret_spec.rb +71 -0
- data/spec/unit/handler_spec.rb +8 -2
- data/spec/unit/policy_builder/dynamic_spec.rb +0 -5
- data/spec/unit/policy_builder/policyfile_spec.rb +144 -56
- data/spec/unit/provider/apt_update_spec.rb +3 -1
- data/spec/unit/provider/link_spec.rb +1 -1
- data/spec/unit/provider/mount/aix_spec.rb +1 -1
- data/spec/unit/provider/package/dnf/python_helper_spec.rb +1 -0
- data/spec/unit/provider/package/powershell_spec.rb +74 -12
- data/spec/unit/provider/package/yum/python_helper_spec.rb +1 -0
- data/spec/unit/provider/service/systemd_service_spec.rb +2 -2
- data/spec/unit/provider/systemd_unit_spec.rb +2 -2
- data/spec/unit/provider/zypper_repository_spec.rb +3 -10
- data/spec/unit/provider_spec.rb +23 -0
- data/spec/unit/resource/homebrew_cask_spec.rb +29 -11
- data/spec/unit/resource/inspec_waiver_file_entry_spec.rb +80 -0
- data/spec/unit/resource/rhsm_subscription_spec.rb +50 -3
- data/spec/unit/resource/systemd_unit_spec.rb +1 -1
- data/spec/unit/resource/windows_defender_exclusion_spec.rb +62 -0
- data/spec/unit/resource/windows_defender_spec.rb +71 -0
- data/spec/unit/resource/windows_firewall_rule_spec.rb +12 -7
- data/spec/unit/resource/windows_pagefile_spec.rb +4 -9
- data/spec/unit/resource/windows_update_settings_spec.rb +64 -0
- data/spec/unit/resource/zypper_repository_spec.rb +1 -1
- data/spec/unit/resource_spec.rb +19 -8
- data/spec/unit/secret_fetcher/aws_secrets_manager_spec.rb +70 -0
- data/spec/unit/secret_fetcher/azure_key_vault_spec.rb +70 -0
- data/spec/unit/secret_fetcher_spec.rb +82 -0
- data/tasks/rspec.rb +4 -9
- metadata +65 -161
- data/lib/chef/provider/package/yum/simplejson/LICENSE.txt +0 -79
- data/lib/chef/provider/package/yum/simplejson/__init__.py +0 -318
- data/lib/chef/provider/package/yum/simplejson/__init__.pyc +0 -0
- data/lib/chef/provider/package/yum/simplejson/decoder.py +0 -354
- data/lib/chef/provider/package/yum/simplejson/decoder.pyc +0 -0
- data/lib/chef/provider/package/yum/simplejson/encoder.py +0 -440
- data/lib/chef/provider/package/yum/simplejson/encoder.pyc +0 -0
- data/lib/chef/provider/package/yum/simplejson/scanner.py +0 -65
- data/lib/chef/provider/package/yum/simplejson/scanner.pyc +0 -0
- data/lib/chef/provider/package/yum/simplejson/tool.py +0 -37
@@ -147,7 +147,7 @@ class Chef
|
|
147
147
|
end
|
148
148
|
end
|
149
149
|
|
150
|
-
action :add, description: "Add a user privilege" do
|
150
|
+
action :add, description: "Add a user privilege." do
|
151
151
|
([*new_resource.privilege] - [*current_resource.privilege]).each do |user_right|
|
152
152
|
converge_by("adding user '#{new_resource.principal}' privilege #{user_right}") do
|
153
153
|
Chef::ReservedNames::Win32::Security.add_account_right(new_resource.principal, user_right)
|
@@ -155,7 +155,7 @@ class Chef
|
|
155
155
|
end
|
156
156
|
end
|
157
157
|
|
158
|
-
action :set, description: "Set the privileges that are listed in the `privilege` property for only the users listed in the `users` property" do
|
158
|
+
action :set, description: "Set the privileges that are listed in the `privilege` property for only the users listed in the `users` property." do
|
159
159
|
if new_resource.users.nil? || new_resource.users.empty?
|
160
160
|
raise Chef::Exceptions::ValidationFailed, "Users are required property with set action."
|
161
161
|
end
|
@@ -30,13 +30,13 @@ class Chef
|
|
30
30
|
examples <<~DOC
|
31
31
|
**Join a workgroup**:
|
32
32
|
|
33
|
-
```
|
33
|
+
```ruby
|
34
34
|
windows_workgroup 'myworkgroup'
|
35
35
|
```
|
36
36
|
|
37
37
|
**Join a workgroup using a specific user**:
|
38
38
|
|
39
|
-
```
|
39
|
+
```ruby
|
40
40
|
windows_workgroup 'myworkgroup' do
|
41
41
|
user 'Administrator'
|
42
42
|
password 'passw0rd'
|
@@ -27,40 +27,36 @@ class Chef
|
|
27
27
|
provides :yum_package
|
28
28
|
provides :package, platform_family: "fedora_derived"
|
29
29
|
|
30
|
-
description "Use the **yum_package** resource to install, upgrade, and remove packages with Yum"
|
31
|
-
" for the Red Hat and CentOS platforms. The yum_package resource is able to resolve"\
|
32
|
-
" `provides` data for packages much like Yum can do when it is run from the command line."\
|
33
|
-
" This allows a variety of options for installing packages, like minimum versions,"\
|
34
|
-
" virtual provides, and library names."
|
30
|
+
description "Use the **yum_package** resource to install, upgrade, and remove packages with Yum for the Red Hat and CentOS platforms. The yum_package resource is able to resolve `provides` data for packages much like Yum can do when it is run from the command line. This allows a variety of options for installing packages, like minimum versions, virtual provides, and library names. Note: Support for using file names to install packages (as in `yum_package '/bin/sh'`) is not available because the volume of data required to parse for this is excessive."
|
35
31
|
examples <<~DOC
|
36
32
|
**Install an exact version**:
|
37
33
|
|
38
|
-
```
|
34
|
+
```ruby
|
39
35
|
yum_package 'netpbm = 10.35.58-8.el8'
|
40
36
|
```
|
41
37
|
|
42
38
|
**Install a minimum version**:
|
43
39
|
|
44
|
-
```
|
40
|
+
```ruby
|
45
41
|
yum_package 'netpbm >= 10.35.58-8.el8'
|
46
42
|
```
|
47
43
|
|
48
44
|
**Install a minimum version using the default action**:
|
49
45
|
|
50
|
-
```
|
46
|
+
```ruby
|
51
47
|
yum_package 'netpbm'
|
52
48
|
```
|
53
49
|
|
54
50
|
**Install a version without worrying about the exact release**:
|
55
51
|
|
56
|
-
```
|
52
|
+
```ruby
|
57
53
|
yum_package 'netpbm-10.35*'
|
58
54
|
```
|
59
55
|
|
60
56
|
|
61
57
|
**To install a package**:
|
62
58
|
|
63
|
-
```
|
59
|
+
```ruby
|
64
60
|
yum_package 'netpbm' do
|
65
61
|
action :install
|
66
62
|
end
|
@@ -68,13 +64,13 @@ class Chef
|
|
68
64
|
|
69
65
|
**To install a partial minimum version**:
|
70
66
|
|
71
|
-
```
|
67
|
+
```ruby
|
72
68
|
yum_package 'netpbm >= 10'
|
73
69
|
```
|
74
70
|
|
75
71
|
**To install a specific architecture**:
|
76
72
|
|
77
|
-
```
|
73
|
+
```ruby
|
78
74
|
yum_package 'netpbm' do
|
79
75
|
arch 'i386'
|
80
76
|
end
|
@@ -82,13 +78,13 @@ class Chef
|
|
82
78
|
|
83
79
|
or:
|
84
80
|
|
85
|
-
```
|
81
|
+
```ruby
|
86
82
|
yum_package 'netpbm.x86_64'
|
87
83
|
```
|
88
84
|
|
89
85
|
**To install a specific version-release**
|
90
86
|
|
91
|
-
```
|
87
|
+
```ruby
|
92
88
|
yum_package 'netpbm' do
|
93
89
|
version '10.35.58-8.el8'
|
94
90
|
end
|
@@ -101,7 +97,7 @@ class Chef
|
|
101
97
|
to dump the in-memory Yum cache, and then use the repository immediately
|
102
98
|
to ensure that the correct package is installed:
|
103
99
|
|
104
|
-
```
|
100
|
+
```ruby
|
105
101
|
cookbook_file '/etc/yum.repos.d/custom.repo' do
|
106
102
|
source 'custom'
|
107
103
|
mode '0755'
|
@@ -30,7 +30,7 @@ class Chef
|
|
30
30
|
examples <<~DOC
|
31
31
|
**Install a package using package manager:**
|
32
32
|
|
33
|
-
```
|
33
|
+
```ruby
|
34
34
|
zypper_package 'name of package' do
|
35
35
|
action :install
|
36
36
|
end
|
@@ -38,7 +38,7 @@ class Chef
|
|
38
38
|
|
39
39
|
**Install a package using local file:**
|
40
40
|
|
41
|
-
```
|
41
|
+
```ruby
|
42
42
|
zypper_package 'jwhois' do
|
43
43
|
action :install
|
44
44
|
source '/path/to/jwhois.rpm'
|
@@ -47,10 +47,10 @@ class Chef
|
|
47
47
|
|
48
48
|
**Install without using recommend packages as a dependency:**
|
49
49
|
|
50
|
-
```
|
50
|
+
```ruby
|
51
51
|
package 'apache2' do
|
52
52
|
options '--no-recommends'
|
53
|
-
|
53
|
+
end
|
54
54
|
```
|
55
55
|
DOC
|
56
56
|
|
@@ -24,21 +24,37 @@ class Chef
|
|
24
24
|
unified_mode true
|
25
25
|
|
26
26
|
provides(:zypper_repository) { true }
|
27
|
-
provides(:zypper_repo) { true }
|
27
|
+
provides(:zypper_repo) { true } # legacy cookbook compatibility
|
28
28
|
|
29
29
|
description "Use the **zypper_repository** resource to create Zypper package repositories on SUSE Enterprise Linux and openSUSE systems. This resource maintains full compatibility with the **zypper_repository** resource in the existing **zypper** cookbook."
|
30
30
|
introduced "13.3"
|
31
31
|
examples <<~DOC
|
32
32
|
**Add the Apache repo on openSUSE Leap 15**:
|
33
33
|
|
34
|
-
```
|
34
|
+
```ruby
|
35
35
|
zypper_repository 'apache' do
|
36
36
|
baseurl 'http://download.opensuse.org/repositories/Apache'
|
37
|
-
path '/openSUSE_Leap_15.
|
38
|
-
|
37
|
+
path '/openSUSE_Leap_15.2'
|
38
|
+
type 'rpm-md'
|
39
39
|
priority '100'
|
40
40
|
end
|
41
41
|
```
|
42
|
+
|
43
|
+
**Remove the repo named 'apache'**:
|
44
|
+
|
45
|
+
```ruby
|
46
|
+
zypper_repository 'apache' do
|
47
|
+
action :delete
|
48
|
+
end
|
49
|
+
```
|
50
|
+
|
51
|
+
**Refresh the repo named 'apache'**:
|
52
|
+
|
53
|
+
```ruby
|
54
|
+
zypper_repository 'apache' do
|
55
|
+
action :refresh
|
56
|
+
end
|
57
|
+
```
|
42
58
|
DOC
|
43
59
|
|
44
60
|
property :repo_name, String,
|
@@ -66,8 +82,10 @@ class Chef
|
|
66
82
|
description: "Determines whether or not to perform a GPG signature check on the repository.",
|
67
83
|
default: true
|
68
84
|
|
69
|
-
property :gpgkey, String,
|
70
|
-
description: "The location of the repository key to be imported."
|
85
|
+
property :gpgkey, [String, Array],
|
86
|
+
description: "The location of the repository key(s) to be imported.",
|
87
|
+
coerce: proc { |v| Array(v) },
|
88
|
+
default: []
|
71
89
|
|
72
90
|
property :baseurl, String,
|
73
91
|
description: "The base URL for the Zypper repository, such as `http://download.opensuse.org`."
|
@@ -95,10 +113,12 @@ class Chef
|
|
95
113
|
default: true
|
96
114
|
|
97
115
|
property :source, String,
|
98
|
-
description: "The name of the template for the repository file. Only necessary if you're
|
116
|
+
description: "The name of the template for the repository file. Only necessary if you're using a custom template for the repository file."
|
99
117
|
|
100
118
|
property :cookbook, String,
|
101
|
-
description: "The cookbook to source the repository template file from. Only necessary if you're
|
119
|
+
description: "The cookbook to source the repository template file from. Only necessary if you're using a custom template for the repository file.",
|
120
|
+
default: lazy { cookbook_name },
|
121
|
+
default_description: "The cookbook containing the resource",
|
102
122
|
desired_state: false
|
103
123
|
|
104
124
|
property :gpgautoimportkeys, [TrueClass, FalseClass],
|
data/lib/chef/resource.rb
CHANGED
@@ -42,6 +42,7 @@ require_relative "mixin/deprecation"
|
|
42
42
|
require_relative "mixin/properties"
|
43
43
|
require_relative "mixin/provides"
|
44
44
|
require_relative "dsl/universal"
|
45
|
+
require_relative "constants"
|
45
46
|
|
46
47
|
class Chef
|
47
48
|
class Resource
|
@@ -1062,7 +1063,8 @@ class Chef
|
|
1062
1063
|
# action for the resource.
|
1063
1064
|
#
|
1064
1065
|
# @param name [Symbol] The action name to define.
|
1065
|
-
# @param description [String] optional description for the action
|
1066
|
+
# @param description [String] optional description for the action. Used for
|
1067
|
+
# documentation generation.
|
1066
1068
|
# @param recipe_block The recipe to run when the action is taken. This block
|
1067
1069
|
# takes no parameters, and will be evaluated in a new context containing:
|
1068
1070
|
#
|
@@ -1075,11 +1077,8 @@ class Chef
|
|
1075
1077
|
def self.action(action, description: nil, &recipe_block)
|
1076
1078
|
action = action.to_sym
|
1077
1079
|
declare_action_class
|
1078
|
-
action_class.action(action, &recipe_block)
|
1080
|
+
action_class.action(action, description: description, &recipe_block)
|
1079
1081
|
self.allowed_actions += [ action ]
|
1080
|
-
# Accept any non-nil description, which will correctly override
|
1081
|
-
# any specific inherited description.
|
1082
|
-
action_descriptions[action] = description unless description.nil?
|
1083
1082
|
default_action action if Array(default_action) == [:nothing]
|
1084
1083
|
end
|
1085
1084
|
|
@@ -1089,18 +1088,15 @@ class Chef
|
|
1089
1088
|
# @param action [Symbol,String] the action name
|
1090
1089
|
# @return the description of the action provided, or nil if no description
|
1091
1090
|
# was defined
|
1092
|
-
def
|
1093
|
-
|
1094
|
-
|
1095
|
-
|
1096
|
-
|
1097
|
-
|
1098
|
-
|
1099
|
-
|
1100
|
-
|
1101
|
-
def self.action_descriptions
|
1102
|
-
@action_descriptions ||=
|
1103
|
-
superclass.respond_to?(:action_descriptions) ? superclass.action_descriptions.dup : { nothing: nil }
|
1091
|
+
def action_description(action)
|
1092
|
+
provider_for_action(action).class.action_description(action)
|
1093
|
+
rescue Chef::Exceptions::ProviderNotFound
|
1094
|
+
# If a provider can't be found, there can be no description defined on the provider.
|
1095
|
+
nil
|
1096
|
+
rescue NameError => e
|
1097
|
+
# This can happen when attempting to load a provider in a platform-specific
|
1098
|
+
# environment where we have not required the necessary files yet
|
1099
|
+
raise unless e.message =~ /uninitialized constant/
|
1104
1100
|
end
|
1105
1101
|
|
1106
1102
|
# Define a method to load up this resource's properties with the current
|
@@ -1187,9 +1183,10 @@ class Chef
|
|
1187
1183
|
begin
|
1188
1184
|
is_custom_resource!
|
1189
1185
|
base_provider =
|
1190
|
-
if superclass.custom_resource?
|
1186
|
+
if superclass.custom_resource? || superclass != Chef::Resource
|
1191
1187
|
superclass.action_class
|
1192
1188
|
else
|
1189
|
+
|
1193
1190
|
ActionClass
|
1194
1191
|
end
|
1195
1192
|
|
@@ -1362,8 +1359,9 @@ class Chef
|
|
1362
1359
|
#
|
1363
1360
|
# @param arg [String] version constraint to match against (e.g. "> 14")
|
1364
1361
|
#
|
1365
|
-
def self.chef_version_for_provides(constraint)
|
1366
|
-
@chef_version_for_provides = constraint
|
1362
|
+
def self.chef_version_for_provides(constraint = NOT_PASSED)
|
1363
|
+
@chef_version_for_provides = constraint unless constraint == NOT_PASSED
|
1364
|
+
@chef_version_for_provides ||= nil
|
1367
1365
|
end
|
1368
1366
|
|
1369
1367
|
# Mark this resource as providing particular DSL.
|
@@ -1376,14 +1374,11 @@ class Chef
|
|
1376
1374
|
def self.provides(name, **options, &block)
|
1377
1375
|
name = name.to_sym
|
1378
1376
|
|
1379
|
-
# quell warnings
|
1380
|
-
@chef_version_for_provides = nil unless defined?(@chef_version_for_provides)
|
1381
|
-
|
1382
1377
|
# deliberately do not go through the accessor here
|
1383
1378
|
@resource_name = name if resource_name.nil?
|
1384
1379
|
|
1385
|
-
if
|
1386
|
-
options[:chef_version] =
|
1380
|
+
if chef_version_for_provides && !options.include?(:chef_version)
|
1381
|
+
options[:chef_version] = chef_version_for_provides
|
1387
1382
|
end
|
1388
1383
|
|
1389
1384
|
result = Chef.resource_handler_map.set(name, self, **options, &block)
|
@@ -29,9 +29,10 @@ class Chef
|
|
29
29
|
attr_reader :recipe_name
|
30
30
|
attr_reader :enclosing_provider
|
31
31
|
attr_reader :resource
|
32
|
+
attr_reader :new_resource
|
32
33
|
|
33
34
|
# FIXME (ruby-2.1 syntax): most of these are mandatory
|
34
|
-
def initialize(type: nil, name: nil, created_at: nil, params: nil, run_context: nil, cookbook_name: nil, recipe_name: nil, enclosing_provider: nil)
|
35
|
+
def initialize(type: nil, name: nil, created_at: nil, params: nil, run_context: nil, cookbook_name: nil, recipe_name: nil, enclosing_provider: nil, new_resource: nil)
|
35
36
|
@type = type
|
36
37
|
@name = name
|
37
38
|
@created_at = created_at
|
@@ -40,6 +41,7 @@ class Chef
|
|
40
41
|
@cookbook_name = cookbook_name
|
41
42
|
@recipe_name = recipe_name
|
42
43
|
@enclosing_provider = enclosing_provider
|
44
|
+
@new_resource = new_resource
|
43
45
|
end
|
44
46
|
|
45
47
|
def build(&block)
|
@@ -64,7 +66,11 @@ class Chef
|
|
64
66
|
if block_given?
|
65
67
|
resource.resource_initializing = true
|
66
68
|
begin
|
67
|
-
|
69
|
+
if new_resource.nil?
|
70
|
+
resource.instance_exec(&block)
|
71
|
+
else
|
72
|
+
resource.instance_exec(new_resource, &block)
|
73
|
+
end
|
68
74
|
ensure
|
69
75
|
resource.resource_initializing = false
|
70
76
|
end
|
@@ -23,6 +23,11 @@ require_relative "node"
|
|
23
23
|
require_relative "resources"
|
24
24
|
require_relative "json_compat"
|
25
25
|
|
26
|
+
# We need to require providers so that we can resolve
|
27
|
+
# action documentation that may have been defined on the providers
|
28
|
+
# instead of the resources.
|
29
|
+
require_relative "providers"
|
30
|
+
|
26
31
|
class Chef
|
27
32
|
module ResourceInspector
|
28
33
|
def self.get_default(default)
|
@@ -39,11 +44,10 @@ class Chef
|
|
39
44
|
def self.extract_resource(resource, complete = false)
|
40
45
|
data = {}
|
41
46
|
data[:description] = resource.description
|
42
|
-
# data[:deprecated] = resource.deprecated || false
|
43
47
|
data[:default_action] = resource.default_action
|
44
48
|
data[:actions] = {}
|
45
49
|
resource.allowed_actions.each do |action|
|
46
|
-
data[:actions][action] = resource.action_description(action)
|
50
|
+
data[:actions][action] = resource.new(resource.to_s, nil).action_description(action)
|
47
51
|
end
|
48
52
|
|
49
53
|
data[:examples] = resource.examples
|
data/lib/chef/resources.rb
CHANGED
@@ -58,6 +58,14 @@ require_relative "resource/ips_package"
|
|
58
58
|
require_relative "resource/gem_package"
|
59
59
|
require_relative "resource/scm/git"
|
60
60
|
require_relative "resource/group"
|
61
|
+
require_relative "resource/habitat/habitat_package"
|
62
|
+
require_relative "resource/habitat/habitat_sup"
|
63
|
+
require_relative "resource/habitat/habitat_sup_systemd"
|
64
|
+
require_relative "resource/habitat/habitat_sup_windows"
|
65
|
+
require_relative "resource/habitat_config"
|
66
|
+
require_relative "resource/habitat_install"
|
67
|
+
require_relative "resource/habitat_service"
|
68
|
+
require_relative "resource/habitat_user_toml"
|
61
69
|
require_relative "resource/http_request"
|
62
70
|
require_relative "resource/hostname"
|
63
71
|
require_relative "resource/homebrew_cask"
|
@@ -65,6 +73,7 @@ require_relative "resource/homebrew_package"
|
|
65
73
|
require_relative "resource/homebrew_tap"
|
66
74
|
require_relative "resource/homebrew_update"
|
67
75
|
require_relative "resource/ifconfig"
|
76
|
+
require_relative "resource/inspec_waiver_file_entry"
|
68
77
|
require_relative "resource/kernel_module"
|
69
78
|
require_relative "resource/ksh"
|
70
79
|
require_relative "resource/launchd"
|
@@ -147,6 +156,8 @@ require_relative "resource/windows_ad_join"
|
|
147
156
|
require_relative "resource/windows_audit_policy"
|
148
157
|
require_relative "resource/windows_auto_run"
|
149
158
|
require_relative "resource/windows_certificate"
|
159
|
+
require_relative "resource/windows_defender"
|
160
|
+
require_relative "resource/windows_defender_exclusion"
|
150
161
|
require_relative "resource/windows_dfs_folder"
|
151
162
|
require_relative "resource/windows_dfs_namespace"
|
152
163
|
require_relative "resource/windows_dfs_server"
|
@@ -166,7 +177,8 @@ require_relative "resource/windows_share"
|
|
166
177
|
require_relative "resource/windows_shortcut"
|
167
178
|
require_relative "resource/windows_task"
|
168
179
|
require_relative "resource/windows_uac"
|
180
|
+
require_relative "resource/windows_update_settings"
|
169
181
|
require_relative "resource/windows_workgroup"
|
170
182
|
require_relative "resource/timezone"
|
171
183
|
require_relative "resource/windows_user_privilege"
|
172
|
-
require_relative "resource/windows_security_policy"
|
184
|
+
require_relative "resource/windows_security_policy"
|
data/lib/chef/run_lock.rb
CHANGED
@@ -173,7 +173,7 @@ class Chef
|
|
173
173
|
# Mutex name is case-sensitive contrary to other things in
|
174
174
|
# windows. "\" is the only invalid character.
|
175
175
|
def acquire_win32_mutex
|
176
|
-
@mutex = Chef::ReservedNames::Win32::Mutex.new("Global\\#{runlock_file.tr(
|
176
|
+
@mutex = Chef::ReservedNames::Win32::Mutex.new("Global\\#{runlock_file.tr("\\", "/").downcase}")
|
177
177
|
mutex.test
|
178
178
|
end
|
179
179
|
|
data/lib/chef/runner.rb
CHANGED