chef 17.0.242-universal-mingw32 → 17.4.25-universal-mingw32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- 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
data/lib/chef/provider/file.rb
CHANGED
@@ -157,7 +157,7 @@ class Chef
|
|
157
157
|
end
|
158
158
|
|
159
159
|
action :delete do
|
160
|
-
if ::File.
|
160
|
+
if ::File.exist?(new_resource.path)
|
161
161
|
converge_by("delete file #{new_resource.path}") do
|
162
162
|
do_backup unless file_class.symlink?(new_resource.path)
|
163
163
|
::File.delete(new_resource.path)
|
@@ -393,7 +393,7 @@ class Chef
|
|
393
393
|
# a nil tempfile is okay, means the resource has no content or no new content
|
394
394
|
return if tempfile.nil?
|
395
395
|
# but a tempfile that has no path or doesn't exist should not happen
|
396
|
-
if tempfile.path.nil? || !::File.
|
396
|
+
if tempfile.path.nil? || !::File.exist?(tempfile.path)
|
397
397
|
raise "#{ChefUtils::Dist::Infra::CLIENT} is confused, trying to deploy a file that has no path or does not exist..."
|
398
398
|
end
|
399
399
|
|
@@ -158,7 +158,7 @@ class Chef
|
|
158
158
|
if new_resource.group_name && (current_resource.group_name != new_resource.group_name)
|
159
159
|
dscl_create_group
|
160
160
|
end
|
161
|
-
if new_resource.gid && (current_resource.gid != new_resource.gid)
|
161
|
+
if new_resource.gid && (current_resource.gid != new_resource.gid.to_s)
|
162
162
|
set_gid
|
163
163
|
end
|
164
164
|
if new_resource.members || new_resource.excluded_members
|
@@ -43,22 +43,22 @@ class Chef
|
|
43
43
|
types[type]
|
44
44
|
end
|
45
45
|
|
46
|
-
action :create do
|
46
|
+
action :create, description: "Create a launchd property list." do
|
47
47
|
manage_plist(:create)
|
48
48
|
end
|
49
49
|
|
50
|
-
action :create_if_missing do
|
50
|
+
action :create_if_missing, description: "Create a launchd property list, if it does not already exist." do
|
51
51
|
manage_plist(:create_if_missing)
|
52
52
|
end
|
53
53
|
|
54
|
-
action :delete do
|
54
|
+
action :delete, description: "Delete a launchd property list. This will unload a daemon or agent, if loaded." do
|
55
55
|
if ::File.exists?(path)
|
56
56
|
manage_service(:disable)
|
57
57
|
end
|
58
58
|
manage_plist(:delete)
|
59
59
|
end
|
60
60
|
|
61
|
-
action :enable do
|
61
|
+
action :enable, description: "Create a launchd property list, and then ensure that it is enabled. If a launchd property list already exists, but does not match, updates the property list to match, and then restarts the daemon or agent." do
|
62
62
|
manage_service(:nothing)
|
63
63
|
manage_plist(:create) do
|
64
64
|
notifies :restart, "macosx_service[#{label}]", :immediately
|
@@ -66,13 +66,13 @@ class Chef
|
|
66
66
|
manage_service(:enable)
|
67
67
|
end
|
68
68
|
|
69
|
-
action :disable do
|
69
|
+
action :disable, description: "Disable a launchd property list." do
|
70
70
|
return unless ::File.exist?(path)
|
71
71
|
|
72
72
|
manage_service(:disable)
|
73
73
|
end
|
74
74
|
|
75
|
-
action :restart do
|
75
|
+
action :restart, description: "Restart a launchd managed daemon or agent." do
|
76
76
|
manage_service(:restart)
|
77
77
|
end
|
78
78
|
|
data/lib/chef/provider/link.rb
CHANGED
@@ -78,12 +78,12 @@ def version_tuple(versionstr):
|
|
78
78
|
def versioncompare(versions):
|
79
79
|
sack = get_sack()
|
80
80
|
if (versions[0] is None) or (versions[1] is None):
|
81
|
-
|
82
|
-
|
81
|
+
outpipe.write('0\n')
|
82
|
+
outpipe.flush()
|
83
83
|
else:
|
84
|
-
|
85
|
-
|
86
|
-
|
84
|
+
evr_comparison = dnf.rpm.rpm.labelCompare(version_tuple(versions[0]), version_tuple(versions[1]))
|
85
|
+
outpipe.write('{}\n'.format(evr_comparison))
|
86
|
+
outpipe.flush()
|
87
87
|
|
88
88
|
def query(command):
|
89
89
|
sack = get_sack()
|
@@ -152,20 +152,21 @@ def setup_exit_handler():
|
|
152
152
|
signal.signal(signal.SIGQUIT, exit_handler)
|
153
153
|
|
154
154
|
if len(sys.argv) < 3:
|
155
|
-
|
156
|
-
|
155
|
+
inpipe = sys.stdin
|
156
|
+
outpipe = sys.stdout
|
157
157
|
else:
|
158
|
-
|
159
|
-
|
158
|
+
os.set_blocking(int(sys.argv[1]), True)
|
159
|
+
inpipe = os.fdopen(int(sys.argv[1]), "r")
|
160
|
+
outpipe = os.fdopen(int(sys.argv[2]), "w")
|
160
161
|
|
161
162
|
try:
|
163
|
+
setup_exit_handler()
|
162
164
|
while 1:
|
163
165
|
# stop the process if the parent proc goes away
|
164
166
|
ppid = os.getppid()
|
165
167
|
if ppid == 1:
|
166
168
|
raise RuntimeError("orphaned")
|
167
169
|
|
168
|
-
setup_exit_handler()
|
169
170
|
line = inpipe.readline()
|
170
171
|
|
171
172
|
# only way to detect EOF in python
|
@@ -52,7 +52,6 @@ class Chef
|
|
52
52
|
end
|
53
53
|
|
54
54
|
def start
|
55
|
-
ENV["PYTHONUNBUFFERED"] = "1"
|
56
55
|
@inpipe, inpipe_write = IO.pipe
|
57
56
|
outpipe_read, @outpipe = IO.pipe
|
58
57
|
@stdin, @stdout, @stderr, @wait_thr = Open3.popen3("#{dnf_command} #{outpipe_read.fileno} #{inpipe_write.fileno}", outpipe_read.fileno => outpipe_read, inpipe_write.fileno => inpipe_write, close_others: false)
|
@@ -75,6 +74,7 @@ class Chef
|
|
75
74
|
stderr.close unless stderr.nil?
|
76
75
|
inpipe.close unless inpipe.nil?
|
77
76
|
outpipe.close unless outpipe.nil?
|
77
|
+
@stdin = @stdout = @stderr = @inpipe = @outpipe = @wait_thr = nil
|
78
78
|
end
|
79
79
|
end
|
80
80
|
|
@@ -114,7 +114,7 @@ class Chef
|
|
114
114
|
query_output = query(action, parameters)
|
115
115
|
version = parse_response(query_output.lines.last)
|
116
116
|
Chef::Log.trace "parsed #{version} from python helper"
|
117
|
-
|
117
|
+
reap unless repo_opts.empty?
|
118
118
|
version
|
119
119
|
end
|
120
120
|
|
@@ -148,10 +148,11 @@ class Chef
|
|
148
148
|
with_helper do
|
149
149
|
json = build_query(action, parameters)
|
150
150
|
Chef::Log.trace "sending '#{json}' to python helper"
|
151
|
-
outpipe.
|
152
|
-
|
151
|
+
outpipe.puts json
|
152
|
+
outpipe.flush
|
153
|
+
output = inpipe.readline.chomp
|
153
154
|
Chef::Log.trace "got '#{output}' from python helper"
|
154
|
-
|
155
|
+
output
|
155
156
|
end
|
156
157
|
end
|
157
158
|
|
@@ -199,13 +200,13 @@ class Chef
|
|
199
200
|
Chef::Log.trace "discarding output on stderr/stdout from python helper: #{output}"
|
200
201
|
end
|
201
202
|
ret
|
202
|
-
rescue
|
203
|
+
rescue => e
|
203
204
|
output = drain_fds
|
204
|
-
|
205
|
+
restart
|
206
|
+
if ( max_retries -= 1 ) > 0 && !ENV["DNF_HELPER_NO_RETRIES"]
|
205
207
|
unless output.empty?
|
206
208
|
Chef::Log.trace "discarding output on stderr/stdout from python helper: #{output}"
|
207
209
|
end
|
208
|
-
restart
|
209
210
|
retry
|
210
211
|
else
|
211
212
|
raise e if output.empty?
|
@@ -0,0 +1,168 @@
|
|
1
|
+
#
|
2
|
+
# Copyright:: Chef Software Inc.
|
3
|
+
#
|
4
|
+
# License:: Apache License, Version 2.0
|
5
|
+
#
|
6
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
+
# you may not use this file except in compliance with the License.
|
8
|
+
# You may obtain a copy of the License at
|
9
|
+
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
+
#
|
12
|
+
# Unless required by applicable law or agreed to in writing, software
|
13
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
15
|
+
# See the License for the specific language governing permissions and
|
16
|
+
# limitations under the License.
|
17
|
+
#
|
18
|
+
require_relative "../../http/simple"
|
19
|
+
require_relative "../../json_compat"
|
20
|
+
require_relative "../../exceptions"
|
21
|
+
require_relative "../package"
|
22
|
+
# Bring in needed shared methods
|
23
|
+
|
24
|
+
class Chef
|
25
|
+
class Provider
|
26
|
+
class Package
|
27
|
+
class Habitat < Chef::Provider::Package
|
28
|
+
use_multipackage_api
|
29
|
+
use "../../resource/habitat/habitat_shared"
|
30
|
+
provides :habitat_package
|
31
|
+
|
32
|
+
def load_current_resource
|
33
|
+
@current_resource = Chef::Resource::HabitatPackage.new(new_resource.name)
|
34
|
+
current_resource.package_name(strip_version(new_resource.package_name))
|
35
|
+
|
36
|
+
@candidate_version = candidate_versions
|
37
|
+
current_resource.version(current_versions)
|
38
|
+
|
39
|
+
current_resource
|
40
|
+
end
|
41
|
+
|
42
|
+
def install_package(names, versions)
|
43
|
+
names.zip(versions).map do |n, v|
|
44
|
+
opts = ["pkg", "install", "--channel", new_resource.channel, "--url", new_resource.bldr_url]
|
45
|
+
opts += ["--auth", new_resource.auth_token] if new_resource.auth_token
|
46
|
+
opts += ["#{strip_version(n)}/#{v}", new_resource.options]
|
47
|
+
opts += ["--binlink"] if new_resource.binlink
|
48
|
+
opts += ["--force"] if new_resource.binlink.eql? :force
|
49
|
+
hab(opts)
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
alias_method :upgrade_package, :install_package
|
54
|
+
|
55
|
+
def remove_package(names, versions)
|
56
|
+
# raise 'It is too dangerous to :remove packages with the habitat_package resource right now. This functionality should be deferred to the hab cli.'
|
57
|
+
names.zip(versions).map do |n, v|
|
58
|
+
opts = %w{pkg uninstall}
|
59
|
+
opts += ["--keep-latest", new_resource.keep_latest ] if new_resource.keep_latest
|
60
|
+
opts += ["#{strip_version(n).chomp("/")}#{v}", new_resource.options]
|
61
|
+
opts += ["--exclude"] if new_resource.exclude
|
62
|
+
opts += ["--no-deps"] if new_resource.no_deps
|
63
|
+
hab(opts)
|
64
|
+
# action :remove
|
65
|
+
end
|
66
|
+
end
|
67
|
+
|
68
|
+
alias_method :purge_package, :remove_package
|
69
|
+
|
70
|
+
private
|
71
|
+
|
72
|
+
def validate_name!(name)
|
73
|
+
raise ArgumentError, "package name must be specified as 'origin/name', use the 'version' property to specify a version" unless name.squeeze("/").count("/") < 2
|
74
|
+
end
|
75
|
+
|
76
|
+
def strip_version(name)
|
77
|
+
validate_name!(name)
|
78
|
+
n = name.squeeze("/").chomp("/").sub(%r{^\/}, "")
|
79
|
+
n = n[0..(n.rindex("/") - 1)] while n.count("/") >= 2
|
80
|
+
n
|
81
|
+
end
|
82
|
+
|
83
|
+
def platform_target
|
84
|
+
if windows?
|
85
|
+
"target=x86_64-windows"
|
86
|
+
elsif node["kernel"]["release"].to_i < 3
|
87
|
+
"target=x86_64-linux-kernel2"
|
88
|
+
else
|
89
|
+
""
|
90
|
+
end
|
91
|
+
end
|
92
|
+
|
93
|
+
def depot_package(name, version = nil)
|
94
|
+
@depot_package ||= {}
|
95
|
+
@depot_package[name] ||=
|
96
|
+
begin
|
97
|
+
origin, pkg_name = name.split("/")
|
98
|
+
name_version = [pkg_name, version].compact.join("/").squeeze("/").chomp("/").sub(%r{^\/}, "")
|
99
|
+
url = if new_resource.bldr_url.include?("/v1/")
|
100
|
+
"#{new_resource.bldr_url.chomp("/")}/depot/channels/#{origin}/#{new_resource.channel}/pkgs/#{name_version}"
|
101
|
+
else
|
102
|
+
"#{new_resource.bldr_url.chomp("/")}/v1/depot/channels/#{origin}/#{new_resource.channel}/pkgs/#{name_version}"
|
103
|
+
end
|
104
|
+
url << "/latest" unless name_version.count("/") >= 2
|
105
|
+
url << "?#{platform_target}" unless platform_target.empty?
|
106
|
+
|
107
|
+
headers = {}
|
108
|
+
headers["Authorization"] = "Bearer #{new_resource.auth_token}" if new_resource.auth_token
|
109
|
+
|
110
|
+
Chef::JSONCompat.parse(http.get(url, headers))
|
111
|
+
rescue Net::HTTPServerException
|
112
|
+
nil
|
113
|
+
end
|
114
|
+
end
|
115
|
+
|
116
|
+
def package_version(name, version = nil)
|
117
|
+
p = depot_package(name, version)
|
118
|
+
"#{p["ident"]["version"]}/#{p["ident"]["release"]}" unless p.nil?
|
119
|
+
end
|
120
|
+
|
121
|
+
def http
|
122
|
+
# FIXME: use SimpleJSON when the depot mime-type is fixed
|
123
|
+
@http ||= Chef::HTTP::Simple.new(new_resource.bldr_url.to_s)
|
124
|
+
end
|
125
|
+
|
126
|
+
def candidate_versions
|
127
|
+
package_name_array.zip(new_version_array).map do |n, v|
|
128
|
+
package_version(n, v)
|
129
|
+
end
|
130
|
+
end
|
131
|
+
|
132
|
+
def current_versions
|
133
|
+
package_name_array.map do |n|
|
134
|
+
installed_version(n)
|
135
|
+
end
|
136
|
+
end
|
137
|
+
|
138
|
+
def installed_version(ident)
|
139
|
+
hab("pkg", "path", ident).stdout.chomp.split(windows? ? "\\" : "/")[-2..-1].join("/")
|
140
|
+
rescue Mixlib::ShellOut::ShellCommandFailed
|
141
|
+
nil
|
142
|
+
end
|
143
|
+
|
144
|
+
# This is used by the superclass Chef::Provider::Package
|
145
|
+
def version_requirement_satisfied?(current_version, new_version)
|
146
|
+
return false if new_version.nil? || current_version.nil?
|
147
|
+
|
148
|
+
nv_parts = new_version.squeeze("/").split("/")
|
149
|
+
|
150
|
+
if nv_parts.count < 2
|
151
|
+
current_version.squeeze("/").split("/")[0] == new_version.squeeze("/")
|
152
|
+
else
|
153
|
+
current_version.squeeze("/") == new_resource.version.squeeze("/")
|
154
|
+
end
|
155
|
+
end
|
156
|
+
|
157
|
+
# This is used by the superclass Chef::Provider::Package
|
158
|
+
def version_compare(v1, v2)
|
159
|
+
require "mixlib/versioning" unless defined?(Mixlib::Versioning)
|
160
|
+
# Convert the package version (X.Y.Z/DATE) into a version that Mixlib::Versioning understands (X.Y.Z+DATE)
|
161
|
+
hab_v1 = Mixlib::Versioning.parse(v1.tr("/", "+"))
|
162
|
+
hab_v2 = Mixlib::Versioning.parse(v2.tr("/", "+"))
|
163
|
+
hab_v1 <=> hab_v2
|
164
|
+
end
|
165
|
+
end
|
166
|
+
end
|
167
|
+
end
|
168
|
+
end
|
@@ -124,6 +124,11 @@ class Chef
|
|
124
124
|
command.push("-RequiredVersion #{version}") if version
|
125
125
|
command.push("-Source #{new_resource.source}") if new_resource.source && cmdlet_name =~ Regexp.union(/Install-Package/, /Find-Package/)
|
126
126
|
command.push("-SkipPublisherCheck") if new_resource.skip_publisher_check && cmdlet_name !~ /Find-Package/
|
127
|
+
if new_resource.options && cmdlet_name !~ Regexp.union(/Get-Package/, /Find-Package/)
|
128
|
+
new_resource.options.each do |arg|
|
129
|
+
command.push(arg) unless command.include?(arg)
|
130
|
+
end
|
131
|
+
end
|
127
132
|
command.push(").Version")
|
128
133
|
command.join(" ")
|
129
134
|
end
|
@@ -51,7 +51,6 @@ class Chef
|
|
51
51
|
end
|
52
52
|
|
53
53
|
def start
|
54
|
-
ENV["PYTHONUNBUFFERED"] = "1"
|
55
54
|
@inpipe, inpipe_write = IO.pipe
|
56
55
|
outpipe_read, @outpipe = IO.pipe
|
57
56
|
@stdin, @stdout, @stderr, @wait_thr = Open3.popen3("#{yum_command} #{outpipe_read.fileno} #{inpipe_write.fileno}", outpipe_read.fileno => outpipe_read, inpipe_write.fileno => inpipe_write, close_others: false)
|
@@ -74,6 +73,7 @@ class Chef
|
|
74
73
|
stderr.close unless stderr.nil?
|
75
74
|
inpipe.close unless inpipe.nil?
|
76
75
|
outpipe.close unless outpipe.nil?
|
76
|
+
@stdin = @stdout = @stderr = @inpipe = @outpipe = @wait_thr = nil
|
77
77
|
end
|
78
78
|
end
|
79
79
|
|
@@ -81,6 +81,10 @@ class Chef
|
|
81
81
|
start if stdin.nil?
|
82
82
|
end
|
83
83
|
|
84
|
+
def close_rpmdb
|
85
|
+
query("close_rpmdb", {})
|
86
|
+
end
|
87
|
+
|
84
88
|
def compare_versions(version1, version2)
|
85
89
|
query("versioncompare", { "versions" => [version1, version2] }).to_i
|
86
90
|
end
|
@@ -117,12 +121,12 @@ class Chef
|
|
117
121
|
parameters = { "provides" => provides, "version" => version, "arch" => arch }
|
118
122
|
repo_opts = options_params(options || {})
|
119
123
|
parameters.merge!(repo_opts)
|
120
|
-
# XXX: for now we
|
121
|
-
|
124
|
+
# XXX: for now we close the rpmdb before and after every query with an enablerepo/disablerepo to clean the helpers internal state
|
125
|
+
close_rpmdb unless repo_opts.empty?
|
122
126
|
query_output = query(action, parameters)
|
123
127
|
version = parse_response(query_output.lines.last)
|
124
128
|
Chef::Log.trace "parsed #{version} from python helper"
|
125
|
-
|
129
|
+
close_rpmdb unless repo_opts.empty?
|
126
130
|
version
|
127
131
|
end
|
128
132
|
|
@@ -156,10 +160,11 @@ class Chef
|
|
156
160
|
with_helper do
|
157
161
|
json = build_query(action, parameters)
|
158
162
|
Chef::Log.trace "sending '#{json}' to python helper"
|
159
|
-
outpipe.
|
160
|
-
|
163
|
+
outpipe.puts json
|
164
|
+
outpipe.flush
|
165
|
+
output = inpipe.readline.chomp
|
161
166
|
Chef::Log.trace "got '#{output}' from python helper"
|
162
|
-
|
167
|
+
output
|
163
168
|
end
|
164
169
|
end
|
165
170
|
|
@@ -207,13 +212,13 @@ class Chef
|
|
207
212
|
Chef::Log.trace "discarding output on stderr/stdout from python helper: #{output}"
|
208
213
|
end
|
209
214
|
ret
|
210
|
-
rescue
|
215
|
+
rescue => e
|
211
216
|
output = drain_fds
|
212
|
-
|
217
|
+
restart
|
218
|
+
if ( max_retries -= 1 ) > 0 && !ENV["YUM_HELPER_NO_RETRIES"]
|
213
219
|
unless output.empty?
|
214
220
|
Chef::Log.trace "discarding output on stderr/stdout from python helper: #{output}"
|
215
221
|
end
|
216
|
-
restart
|
217
222
|
retry
|
218
223
|
else
|
219
224
|
raise e if output.empty?
|