chef 16.4.41-universal-mingw32 → 16.5.64-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 +1 -1
- data/Rakefile +2 -2
- data/bin/knife +1 -1
- data/chef.gemspec +2 -1
- data/distro/templates/powershell/chef/chef.psm1.erb +18 -18
- data/ext/win32-eventlog/Rakefile +2 -2
- data/ext/win32-eventlog/chef-log.man.erb +4 -4
- data/lib/chef/application.rb +18 -16
- data/lib/chef/application/apply.rb +12 -7
- data/lib/chef/application/base.rb +26 -23
- data/lib/chef/application/client.rb +10 -4
- data/lib/chef/application/exit_code.rb +13 -4
- data/lib/chef/application/knife.rb +22 -11
- data/lib/chef/application/solo.rb +2 -1
- data/lib/chef/application/windows_service.rb +14 -14
- data/lib/chef/application/windows_service_manager.rb +6 -6
- data/lib/chef/chef_fs/knife.rb +2 -2
- data/lib/chef/chef_fs/parallelizer.rb +0 -1
- data/lib/chef/client.rb +10 -11
- data/lib/chef/cookbook/cookbook_version_loader.rb +1 -1
- data/lib/chef/cookbook/synchronizer.rb +2 -2
- data/lib/chef/cookbook_site_streaming_uploader.rb +13 -11
- data/lib/chef/cookbook_uploader.rb +1 -1
- data/lib/chef/data_collector.rb +6 -5
- data/lib/chef/data_collector/config_validation.rb +22 -13
- data/lib/chef/data_collector/run_end_message.rb +2 -2
- data/lib/chef/data_collector/run_start_message.rb +1 -1
- data/lib/chef/deprecated.rb +1 -1
- data/lib/chef/deprecation/warnings.rb +2 -2
- data/lib/chef/digester.rb +2 -2
- data/lib/chef/dsl/chef_vault.rb +1 -1
- data/lib/chef/dsl/data_query.rb +2 -2
- data/lib/chef/dsl/platform_introspection.rb +1 -1
- data/lib/chef/encrypted_data_bag_item.rb +3 -4
- data/lib/chef/encrypted_data_bag_item/decryptor.rb +3 -3
- data/lib/chef/encrypted_data_bag_item/encryptor.rb +3 -3
- data/lib/chef/environment.rb +2 -2
- data/lib/chef/event_loggers/windows_eventlog.rb +2 -2
- data/lib/chef/exceptions.rb +4 -4
- data/lib/chef/file_access_control/windows.rb +5 -1
- data/lib/chef/formatters/doc.rb +7 -6
- data/lib/chef/formatters/error_inspectors/api_error_formatting.rb +6 -5
- data/lib/chef/formatters/error_inspectors/node_load_error_inspector.rb +3 -3
- data/lib/chef/formatters/error_inspectors/registration_error_inspector.rb +9 -9
- data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +2 -2
- data/lib/chef/formatters/error_inspectors/run_list_expansion_error_inspector.rb +3 -3
- data/lib/chef/formatters/minimal.rb +5 -4
- data/lib/chef/http.rb +6 -4
- data/lib/chef/http/auth_credentials.rb +5 -1
- data/lib/chef/http/authenticator.rb +1 -1
- data/lib/chef/http/basic_client.rb +4 -2
- data/lib/chef/http/decompressor.rb +1 -1
- data/lib/chef/http/http_request.rb +7 -5
- data/lib/chef/http/socketless_chef_zero_client.rb +5 -2
- data/lib/chef/http/ssl_policies.rb +1 -1
- data/lib/chef/json_compat.rb +1 -1
- data/lib/chef/knife.rb +4 -4
- data/lib/chef/knife/bootstrap.rb +16 -14
- data/lib/chef/knife/bootstrap/chef_vault_handler.rb +1 -1
- data/lib/chef/knife/bootstrap/templates/chef-full.erb +3 -3
- data/lib/chef/knife/bootstrap/templates/windows-chef-client-msi.erb +7 -7
- data/lib/chef/knife/client_create.rb +3 -3
- data/lib/chef/knife/config_get.rb +8 -97
- data/lib/chef/knife/config_get_profile.rb +9 -9
- data/lib/chef/knife/config_list.rb +139 -0
- data/lib/chef/knife/config_list_profiles.rb +8 -98
- data/lib/chef/knife/config_show.rb +127 -0
- data/lib/chef/knife/config_use.rb +61 -0
- data/lib/chef/knife/config_use_profile.rb +9 -24
- data/lib/chef/knife/configure.rb +2 -2
- data/lib/chef/knife/core/bootstrap_context.rb +2 -2
- data/lib/chef/knife/core/object_loader.rb +1 -1
- data/lib/chef/knife/core/windows_bootstrap_context.rb +11 -11
- data/lib/chef/knife/exec.rb +2 -2
- data/lib/chef/knife/node_show.rb +2 -2
- data/lib/chef/knife/serve.rb +3 -3
- data/lib/chef/knife/ssh.rb +16 -1
- data/lib/chef/knife/ssl_check.rb +3 -3
- data/lib/chef/knife/status.rb +2 -2
- data/lib/chef/knife/user_create.rb +2 -2
- data/lib/chef/knife/yaml_convert.rb +1 -1
- data/lib/chef/local_mode.rb +2 -2
- data/lib/chef/log/syslog.rb +2 -2
- data/lib/chef/log/winevt.rb +2 -2
- data/lib/chef/mixin/deep_merge.rb +0 -12
- data/lib/chef/mixin/openssl_helper.rb +1 -4
- data/lib/chef/mixin/template.rb +2 -2
- data/lib/chef/mixin/uris.rb +2 -2
- data/lib/chef/mixin/versioned_api.rb +1 -2
- data/lib/chef/monkey_patches/net_http.rb +4 -4
- data/lib/chef/node_map.rb +2 -2
- data/lib/chef/policy_builder/policyfile.rb +2 -2
- data/lib/chef/provider.rb +0 -4
- data/lib/chef/provider/file.rb +2 -2
- data/lib/chef/provider/ifconfig.rb +1 -1
- data/lib/chef/provider/launchd.rb +2 -2
- data/lib/chef/provider/mount/linux.rb +63 -0
- data/lib/chef/provider/package/rubygems.rb +21 -18
- data/lib/chef/provider/package/snap.rb +0 -1
- data/lib/chef/provider/package/windows.rb +2 -2
- data/lib/chef/provider/package/windows/registry_uninstall_entry.rb +3 -1
- data/lib/chef/provider/package/zypper.rb +1 -1
- data/lib/chef/provider/remote_file/content.rb +3 -0
- data/lib/chef/provider/remote_file/ftp.rb +6 -4
- data/lib/chef/provider/remote_file/sftp.rb +6 -4
- data/lib/chef/provider/route.rb +2 -6
- data/lib/chef/provider/service/macosx.rb +2 -2
- data/lib/chef/provider/template_finder.rb +2 -10
- data/lib/chef/provider/user/dscl.rb +3 -3
- data/lib/chef/provider/user/mac.rb +1 -1
- data/lib/chef/provider/windows_task.rb +1 -2
- data/lib/chef/provider/zypper_repository.rb +2 -2
- data/lib/chef/provider_resolver.rb +1 -1
- data/lib/chef/providers.rb +1 -0
- data/lib/chef/recipe.rb +2 -2
- data/lib/chef/resource.rb +1 -1
- data/lib/chef/resource/apt_repository.rb +1 -1
- data/lib/chef/resource/bff_package.rb +22 -0
- data/lib/chef/resource/breakpoint.rb +57 -2
- data/lib/chef/resource/build_essential.rb +1 -1
- data/lib/chef/resource/cab_package.rb +29 -0
- data/lib/chef/resource/chef_client_cron.rb +32 -25
- data/lib/chef/resource/chef_client_launchd.rb +194 -0
- data/lib/chef/resource/chef_client_scheduled_task.rb +21 -18
- data/lib/chef/resource/chef_client_systemd_timer.rb +24 -17
- data/lib/chef/resource/chef_client_trusted_certificate.rb +101 -0
- data/lib/chef/resource/chef_gem.rb +10 -10
- data/lib/chef/resource/chef_handler.rb +148 -4
- data/lib/chef/resource/chef_sleep.rb +2 -2
- data/lib/chef/resource/chef_vault_secret.rb +1 -1
- data/lib/chef/resource/cookbook_file.rb +2 -2
- data/lib/chef/resource/cron/cron_d.rb +0 -1
- data/lib/chef/resource/dnf_package.rb +2 -2
- data/lib/chef/resource/dsc_resource.rb +0 -1
- data/lib/chef/resource/dsc_script.rb +2 -2
- data/lib/chef/resource/execute.rb +6 -6
- data/lib/chef/resource/file.rb +4 -4
- data/lib/chef/resource/gem_package.rb +5 -5
- data/lib/chef/resource/homebrew_package.rb +3 -3
- data/lib/chef/resource/homebrew_update.rb +5 -5
- data/lib/chef/resource/hostname.rb +2 -2
- data/lib/chef/resource/launchd.rb +2 -1
- data/lib/chef/resource/locale.rb +2 -2
- data/lib/chef/resource/macos_userdefaults.rb +3 -3
- data/lib/chef/resource/notify_group.rb +0 -1
- data/lib/chef/resource/ohai.rb +46 -3
- data/lib/chef/resource/ohai_hint.rb +33 -0
- data/lib/chef/resource/openssl_dhparam.rb +27 -5
- data/lib/chef/resource/openssl_ec_private_key.rb +6 -3
- data/lib/chef/resource/openssl_ec_public_key.rb +2 -2
- data/lib/chef/resource/openssl_rsa_private_key.rb +6 -3
- data/lib/chef/resource/openssl_x509_certificate.rb +14 -14
- data/lib/chef/resource/openssl_x509_crl.rb +19 -10
- data/lib/chef/resource/openssl_x509_request.rb +14 -16
- data/lib/chef/resource/osx_profile.rb +77 -13
- data/lib/chef/resource/plist.rb +1 -1
- data/lib/chef/resource/powershell_package_source.rb +5 -5
- data/lib/chef/resource/reboot.rb +2 -2
- data/lib/chef/resource/remote_file.rb +3 -3
- data/lib/chef/resource/rhsm_register.rb +22 -10
- data/lib/chef/resource/ruby_block.rb +2 -2
- data/lib/chef/resource/scm/subversion.rb +2 -2
- data/lib/chef/resource/service.rb +3 -3
- data/lib/chef/resource/ssh_known_hosts_entry.rb +2 -2
- data/lib/chef/resource/support/cron.d.erb +1 -1
- data/lib/chef/resource/support/cron_access.erb +1 -1
- data/lib/chef/resource/support/sudoer.erb +1 -1
- data/lib/chef/resource/support/ulimit.erb +1 -1
- data/lib/chef/resource/sysctl.rb +1 -5
- data/lib/chef/resource/systemd_unit.rb +2 -2
- data/lib/chef/resource/template.rb +2 -2
- data/lib/chef/resource/windows_ad_join.rb +10 -3
- data/lib/chef/resource/windows_certificate.rb +6 -4
- data/lib/chef/resource/windows_firewall_profile.rb +22 -20
- data/lib/chef/resource/windows_package.rb +28 -5
- data/lib/chef/resource/windows_printer.rb +5 -3
- data/lib/chef/resource/windows_printer_port.rb +6 -4
- data/lib/chef/resource/windows_user_privilege.rb +53 -54
- data/lib/chef/resource/windows_workgroup.rb +3 -3
- data/lib/chef/resource/yum_package.rb +2 -2
- data/lib/chef/resources.rb +3 -1
- data/lib/chef/run_context.rb +2 -2
- data/lib/chef/run_context/cookbook_compiler.rb +1 -1
- data/lib/chef/run_lock.rb +2 -2
- data/lib/chef/search/query.rb +4 -5
- data/lib/chef/shell.rb +31 -26
- data/lib/chef/shell/ext.rb +11 -11
- data/lib/chef/shell/shell_session.rb +2 -2
- data/lib/chef/train_transport.rb +5 -104
- data/lib/chef/util/diff.rb +3 -3
- data/lib/chef/util/powershell/cmdlet.rb +3 -1
- data/lib/chef/util/powershell/ps_credential.rb +18 -14
- data/lib/chef/util/threaded_job_queue.rb +0 -2
- data/lib/chef/version.rb +1 -1
- data/lib/chef/win32/crypto.rb +1 -1
- data/lib/chef/win32/registry.rb +1 -2
- data/spec/data/shef-config.rb +1 -1
- data/spec/functional/event_loggers/windows_eventlog_spec.rb +6 -5
- data/spec/functional/resource/aix_service_spec.rb +2 -2
- data/spec/functional/resource/aixinit_service_spec.rb +1 -1
- data/spec/functional/resource/insserv_spec.rb +1 -1
- data/spec/functional/resource/user/dscl_spec.rb +1 -1
- data/spec/functional/resource/user/mac_user_spec.rb +1 -1
- data/spec/functional/resource/windows_task_spec.rb +13 -13
- data/spec/functional/version_spec.rb +3 -3
- data/spec/integration/client/client_spec.rb +4 -4
- data/spec/integration/client/exit_code_spec.rb +3 -2
- data/spec/integration/client/ipv6_spec.rb +1 -1
- data/spec/integration/knife/{config_list_profiles_spec.rb → config_list_spec.rb} +30 -29
- data/spec/integration/knife/{config_get_spec.rb → config_show_spec.rb} +3 -3
- data/spec/integration/knife/{config_use_profile_spec.rb → config_use_spec.rb} +53 -10
- data/spec/integration/knife/cookbook_api_ipv6_spec.rb +1 -1
- data/spec/integration/ohai/ohai_spec.rb +61 -0
- data/spec/integration/recipes/remote_directory.rb +1 -1
- data/spec/integration/solo/solo_spec.rb +5 -5
- data/spec/spec_helper.rb +6 -3
- data/spec/stress/win32/file_spec.rb +1 -1
- data/spec/support/chef_helpers.rb +2 -2
- data/spec/support/matchers/leak.rb +2 -2
- data/spec/support/platform_helpers.rb +16 -34
- data/spec/support/shared/functional/securable_resource.rb +108 -27
- data/spec/support/shared/functional/win32_service.rb +1 -1
- data/spec/support/shared/unit/application_dot_d.rb +5 -3
- data/spec/tiny_server.rb +0 -1
- data/spec/unit/application/client_spec.rb +2 -2
- data/spec/unit/application/exit_code_spec.rb +10 -0
- data/spec/unit/application_spec.rb +4 -6
- data/spec/unit/chef_fs/parallelizer_spec.rb +5 -1
- data/spec/unit/chef_fs/path_util_spec.rb +1 -1
- data/spec/unit/cookbook/synchronizer_spec.rb +2 -2
- data/spec/unit/cookbook_spec.rb +2 -2
- data/spec/unit/data_collector/config_validation_spec.rb +208 -0
- data/spec/unit/data_collector_spec.rb +0 -113
- data/spec/unit/dsl/declare_resource_spec.rb +1 -1
- data/spec/unit/file_access_control_spec.rb +1 -1
- data/spec/unit/knife/bootstrap_spec.rb +6 -6
- data/spec/unit/knife/core/ui_spec.rb +1 -0
- data/spec/unit/knife/ssh_spec.rb +2 -2
- data/spec/unit/lwrp_spec.rb +3 -3
- data/spec/unit/mixin/deep_merge_spec.rb +15 -0
- data/spec/unit/mixin/openssl_helper_spec.rb +1 -1
- data/spec/unit/mixin/powershell_exec_spec.rb +1 -1
- data/spec/unit/mixin/securable_spec.rb +2 -2
- data/spec/unit/node/immutable_collections_spec.rb +2 -2
- data/spec/unit/provider/mount/linux_spec.rb +97 -0
- data/spec/unit/provider/package/chocolatey_spec.rb +1 -1
- data/spec/unit/provider/package/powershell_spec.rb +1 -1
- data/spec/unit/provider/package/rubygems_spec.rb +4 -1
- data/spec/unit/provider/route_spec.rb +0 -2
- data/spec/unit/recipe_spec.rb +1 -1
- data/spec/unit/resource/chef_client_cron_spec.rb +35 -14
- data/spec/unit/resource/chef_client_launchd_spec.rb +127 -0
- data/spec/unit/resource/chef_client_systemd_timer_spec.rb +36 -1
- data/spec/unit/resource/chef_client_trusted_certificate_spec.rb +54 -0
- data/spec/unit/resource/launchd_spec.rb +8 -0
- data/spec/unit/resource/osx_profile_spec.rb +67 -1
- data/spec/unit/resource/rhsm_register_spec.rb +56 -18
- data/spec/unit/resource/windows_uac_spec.rb +1 -1
- data/spec/unit/resource/windows_user_privilege_spec.rb +55 -0
- data/spec/unit/run_lock_spec.rb +5 -1
- data/spec/unit/runner_spec.rb +1 -2
- data/spec/unit/shell/shell_ext_spec.rb +46 -3
- data/spec/unit/shell/shell_session_spec.rb +35 -64
- data/spec/unit/shell_spec.rb +16 -19
- data/spec/unit/train_transport_spec.rb +14 -13
- data/spec/unit/util/selinux_spec.rb +2 -0
- data/tasks/rspec.rb +0 -2
- metadata +41 -17
- data/lib/chef/dist.rb +0 -68
- data/spec/integration/knife/config_get_profile_spec.rb +0 -114
@@ -16,7 +16,7 @@
|
|
16
16
|
#
|
17
17
|
|
18
18
|
require_relative "../resource"
|
19
|
-
|
19
|
+
require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
20
20
|
|
21
21
|
class Chef
|
22
22
|
class Resource
|
@@ -59,8 +59,8 @@ class Chef
|
|
59
59
|
|
60
60
|
property :reboot, Symbol,
|
61
61
|
equal_to: %i{never request_reboot reboot_now},
|
62
|
-
validation_message: "The reboot property accepts :immediate (reboot as soon as the resource completes), :delayed (reboot once the #{
|
63
|
-
description: "Controls the system reboot behavior post workgroup joining. Reboot immediately, after the #{
|
62
|
+
validation_message: "The reboot property accepts :immediate (reboot as soon as the resource completes), :delayed (reboot once the #{ChefUtils::Dist::Infra::PRODUCT} run completes), and :never (Don't reboot)",
|
63
|
+
description: "Controls the system reboot behavior post workgroup joining. Reboot immediately, after the #{ChefUtils::Dist::Infra::PRODUCT} run completes, or never. Note that a reboot is necessary for changes to take effect.",
|
64
64
|
coerce: proc { |x| clarify_reboot(x) },
|
65
65
|
default: :immediate, desired_state: false
|
66
66
|
|
@@ -17,7 +17,7 @@
|
|
17
17
|
#
|
18
18
|
|
19
19
|
require_relative "package"
|
20
|
-
|
20
|
+
require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
21
21
|
|
22
22
|
class Chef
|
23
23
|
class Resource
|
@@ -135,7 +135,7 @@ class Chef
|
|
135
135
|
coerce: proc { |x| x.is_a?(Array) ? x.to_a : x }
|
136
136
|
|
137
137
|
property :flush_cache, Hash,
|
138
|
-
description: "Flush the in-memory cache before or after a Yum operation that installs, upgrades, or removes a package. Accepts a Hash in the form: { :before => true/false, :after => true/false } or an Array in the form [ :before, :after ].\nYum automatically synchronizes remote metadata to a local cache. The #{
|
138
|
+
description: "Flush the in-memory cache before or after a Yum operation that installs, upgrades, or removes a package. Accepts a Hash in the form: { :before => true/false, :after => true/false } or an Array in the form [ :before, :after ].\nYum automatically synchronizes remote metadata to a local cache. The #{ChefUtils::Dist::Infra::CLIENT} creates a copy of the local cache, and then stores it in-memory during the #{ChefUtils::Dist::Infra::CLIENT} run. The in-memory cache allows packages to be installed during the #{ChefUtils::Dist::Infra::CLIENT} run without the need to continue synchronizing the remote metadata to the local cache while the #{ChefUtils::Dist::Infra::CLIENT} run is in-progress.",
|
139
139
|
default: { before: false, after: false },
|
140
140
|
coerce: proc { |v|
|
141
141
|
if v.is_a?(Hash)
|
data/lib/chef/resources.rb
CHANGED
@@ -28,8 +28,10 @@ require_relative "resource/breakpoint"
|
|
28
28
|
require_relative "resource/build_essential"
|
29
29
|
require_relative "resource/cookbook_file"
|
30
30
|
require_relative "resource/chef_client_cron"
|
31
|
+
require_relative "resource/chef_client_launchd"
|
31
32
|
require_relative "resource/chef_client_scheduled_task"
|
32
33
|
require_relative "resource/chef_client_systemd_timer"
|
34
|
+
require_relative "resource/chef_client_trusted_certificate"
|
33
35
|
require_relative "resource/chef_gem"
|
34
36
|
require_relative "resource/chef_handler"
|
35
37
|
require_relative "resource/chef_sleep"
|
@@ -167,4 +169,4 @@ require_relative "resource/windows_uac"
|
|
167
169
|
require_relative "resource/windows_workgroup"
|
168
170
|
require_relative "resource/timezone"
|
169
171
|
require_relative "resource/windows_user_privilege"
|
170
|
-
require_relative "resource/windows_security_policy"
|
172
|
+
require_relative "resource/windows_security_policy"
|
data/lib/chef/run_context.rb
CHANGED
@@ -28,7 +28,7 @@ require_relative "event_dispatch/events_output_stream"
|
|
28
28
|
require_relative "train_transport"
|
29
29
|
require_relative "exceptions"
|
30
30
|
require "forwardable" unless defined?(Forwardable)
|
31
|
-
|
31
|
+
autoload :Set, "set"
|
32
32
|
|
33
33
|
class Chef
|
34
34
|
|
@@ -627,7 +627,7 @@ class Chef
|
|
627
627
|
# @return [Train::Plugins::Transport] The child class for our train transport.
|
628
628
|
#
|
629
629
|
def transport
|
630
|
-
@transport ||= Chef::TrainTransport.
|
630
|
+
@transport ||= Chef::TrainTransport.new(logger).build_transport
|
631
631
|
end
|
632
632
|
|
633
633
|
# Remote connection object from Train
|
data/lib/chef/run_lock.rb
CHANGED
@@ -23,7 +23,7 @@ end
|
|
23
23
|
require_relative "config"
|
24
24
|
require_relative "exceptions"
|
25
25
|
require "timeout" unless defined?(Timeout)
|
26
|
-
|
26
|
+
require "chef-utils" unless defined?(ChefUtils)
|
27
27
|
|
28
28
|
class Chef
|
29
29
|
|
@@ -96,7 +96,7 @@ class Chef
|
|
96
96
|
# Waits until acquiring the system-wide lock.
|
97
97
|
#
|
98
98
|
def wait
|
99
|
-
Chef::Log.warn("#{
|
99
|
+
Chef::Log.warn("#{ChefUtils::Dist::Infra::PRODUCT} #{runpid} is running, will wait for it to finish and then run.")
|
100
100
|
if ChefUtils.windows?
|
101
101
|
mutex.wait
|
102
102
|
else
|
data/lib/chef/search/query.rb
CHANGED
@@ -20,8 +20,8 @@ require_relative "../config"
|
|
20
20
|
require_relative "../exceptions"
|
21
21
|
require_relative "../server_api"
|
22
22
|
|
23
|
-
|
24
|
-
|
23
|
+
autoload :URI, "uri"
|
24
|
+
autoload :Addressable, "addressable/uri"
|
25
25
|
|
26
26
|
class Chef
|
27
27
|
class Search
|
@@ -132,10 +132,9 @@ class Chef
|
|
132
132
|
args_h
|
133
133
|
end
|
134
134
|
|
135
|
-
QUERY_PARAM_VALUE = Addressable::URI::CharacterClasses::QUERY + "\\&\\;"
|
136
|
-
|
137
135
|
def escape_value(s)
|
138
|
-
|
136
|
+
query_param_value = Addressable::URI::CharacterClasses::QUERY + "\\&\\;"
|
137
|
+
s && Addressable::URI.encode_component(s.to_s, query_param_value)
|
139
138
|
end
|
140
139
|
|
141
140
|
def create_query_string(type, query, rows, start)
|
data/lib/chef/shell.rb
CHANGED
@@ -15,17 +15,22 @@
|
|
15
15
|
# limitations under the License.
|
16
16
|
#
|
17
17
|
|
18
|
+
module Mixlib
|
19
|
+
module Authentication
|
20
|
+
autoload :Log, "mixlib/authentication"
|
21
|
+
end
|
22
|
+
end
|
18
23
|
require "singleton" unless defined?(Singleton)
|
19
24
|
require "pp" unless defined?(PP)
|
20
25
|
require "etc" unless defined?(Etc)
|
21
26
|
require "mixlib/cli" unless defined?(Mixlib::CLI)
|
27
|
+
require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
22
28
|
|
23
29
|
require_relative "../chef"
|
24
30
|
require_relative "version"
|
25
31
|
require_relative "client"
|
26
32
|
require_relative "config"
|
27
33
|
require_relative "config_fetcher"
|
28
|
-
require_relative "dist"
|
29
34
|
|
30
35
|
require_relative "shell/shell_session"
|
31
36
|
require_relative "workstation_config_loader"
|
@@ -126,11 +131,11 @@ module Shell
|
|
126
131
|
irb_conf[:IRB_RC] = lambda do |conf|
|
127
132
|
m = conf.main
|
128
133
|
|
129
|
-
conf.prompt_c = "#{
|
134
|
+
conf.prompt_c = "#{ChefUtils::Dist::Infra::EXEC}#{leader(m)} > "
|
130
135
|
conf.return_format = " => %s \n"
|
131
|
-
conf.prompt_i = "#{
|
132
|
-
conf.prompt_n = "#{
|
133
|
-
conf.prompt_s = "#{
|
136
|
+
conf.prompt_i = "#{ChefUtils::Dist::Infra::EXEC}#{leader(m)} (#{Chef::VERSION})> "
|
137
|
+
conf.prompt_n = "#{ChefUtils::Dist::Infra::EXEC}#{leader(m)} ?> "
|
138
|
+
conf.prompt_s = "#{ChefUtils::Dist::Infra::EXEC}#{leader(m)}%l> "
|
134
139
|
conf.use_tracer = false
|
135
140
|
conf.instance_variable_set(:@use_multiline, false)
|
136
141
|
conf.instance_variable_set(:@use_singleline, false)
|
@@ -212,17 +217,17 @@ module Shell
|
|
212
217
|
@footer
|
213
218
|
end
|
214
219
|
|
215
|
-
banner("#{
|
220
|
+
banner("#{ChefUtils::Dist::Infra::SHELL} #{Chef::VERSION}\n\nUsage: #{ChefUtils::Dist::Infra::SHELL} [NAMED_CONF] (OPTIONS)")
|
216
221
|
|
217
222
|
footer(<<~FOOTER)
|
218
|
-
When no CONFIG is specified, #{
|
219
|
-
* If a NAMED_CONF is given, #{
|
220
|
-
* If no NAMED_CONF is given #{
|
221
|
-
* If no #{
|
222
|
-
#{
|
223
|
-
#{
|
224
|
-
#{
|
225
|
-
#{
|
223
|
+
When no CONFIG is specified, #{ChefUtils::Dist::Infra::SHELL} attempts to load a default configuration file:
|
224
|
+
* If a NAMED_CONF is given, #{ChefUtils::Dist::Infra::SHELL} will load ~/#{ChefUtils::Dist::Infra::USER_CONF_DIR}/NAMED_CONF/#{ChefUtils::Dist::Infra::SHELL_CONF}
|
225
|
+
* If no NAMED_CONF is given #{ChefUtils::Dist::Infra::SHELL} will load ~/#{ChefUtils::Dist::Infra::USER_CONF_DIR}/#{ChefUtils::Dist::Infra::SHELL_CONF} if it exists
|
226
|
+
* If no #{ChefUtils::Dist::Infra::SHELL_CONF} can be found, #{ChefUtils::Dist::Infra::SHELL} falls back to load:
|
227
|
+
#{ChefConfig::Config.etc_chef_dir}/client.rb if -z option is given.
|
228
|
+
#{ChefConfig::Config.etc_chef_dir}/solo.rb if --solo-legacy-mode option is given.
|
229
|
+
#{ChefUtils::Dist::Infra::USER_CONF_DIR}/config.rb if -s option is given.
|
230
|
+
#{ChefUtils::Dist::Infra::USER_CONF_DIR}/knife.rb if -s option is given.
|
226
231
|
FOOTER
|
227
232
|
|
228
233
|
option :use_multiline,
|
@@ -269,19 +274,19 @@ module Shell
|
|
269
274
|
option :solo_shell,
|
270
275
|
short: "-s",
|
271
276
|
long: "--solo",
|
272
|
-
description: "#{
|
277
|
+
description: "#{ChefUtils::Dist::Solo::PRODUCT} session",
|
273
278
|
boolean: true,
|
274
279
|
proc: proc { Chef::Config[:solo] = true }
|
275
280
|
|
276
281
|
option :client,
|
277
282
|
short: "-z",
|
278
283
|
long: "--client",
|
279
|
-
description: "#{
|
284
|
+
description: "#{ChefUtils::Dist::Infra::PRODUCT} session",
|
280
285
|
boolean: true
|
281
286
|
|
282
287
|
option :solo_legacy_shell,
|
283
288
|
long: "--solo-legacy-mode",
|
284
|
-
description: "#{
|
289
|
+
description: "#{ChefUtils::Dist::Solo::PRODUCT} legacy session",
|
285
290
|
boolean: true,
|
286
291
|
proc: proc { Chef::Config[:solo_legacy_mode] = true }
|
287
292
|
|
@@ -294,15 +299,15 @@ module Shell
|
|
294
299
|
option :chef_server_url,
|
295
300
|
short: "-S CHEFSERVERURL",
|
296
301
|
long: "--server CHEFSERVERURL",
|
297
|
-
description: "The #{
|
302
|
+
description: "The #{ChefUtils::Dist::Server::PRODUCT} URL",
|
298
303
|
proc: nil
|
299
304
|
|
300
305
|
option :version,
|
301
306
|
short: "-v",
|
302
307
|
long: "--version",
|
303
|
-
description: "Show #{
|
308
|
+
description: "Show #{ChefUtils::Dist::Infra::PRODUCT} version",
|
304
309
|
boolean: true,
|
305
|
-
proc: lambda { |v| puts "#{
|
310
|
+
proc: lambda { |v| puts "#{ChefUtils::Dist::Infra::PRODUCT}: #{::Chef::VERSION}" },
|
306
311
|
exit: 0
|
307
312
|
|
308
313
|
option :override_runlist,
|
@@ -351,18 +356,18 @@ module Shell
|
|
351
356
|
config[:config_file]
|
352
357
|
elsif environment
|
353
358
|
Shell.env = environment
|
354
|
-
config_file_to_try = ::File.join(dot_chef_dir, environment,
|
359
|
+
config_file_to_try = ::File.join(dot_chef_dir, environment, ChefUtils::Dist::Infra::SHELL_CONF)
|
355
360
|
unless ::File.exist?(config_file_to_try)
|
356
|
-
puts "could not find #{
|
361
|
+
puts "could not find #{ChefUtils::Dist::Infra::SHELL} config for environment #{environment} at #{config_file_to_try}"
|
357
362
|
exit 1
|
358
363
|
end
|
359
364
|
config_file_to_try
|
360
|
-
elsif dot_chef_dir && ::File.exist?(File.join(dot_chef_dir,
|
361
|
-
File.join(dot_chef_dir,
|
365
|
+
elsif dot_chef_dir && ::File.exist?(File.join(dot_chef_dir, ChefUtils::Dist::Infra::SHELL_CONF))
|
366
|
+
File.join(dot_chef_dir, ChefUtils::Dist::Infra::SHELL_CONF)
|
362
367
|
elsif config[:solo_legacy_shell]
|
363
|
-
Chef::Config.platform_specific_path("#{
|
368
|
+
Chef::Config.platform_specific_path("#{ChefConfig::Config.etc_chef_dir}/solo.rb")
|
364
369
|
elsif config[:client]
|
365
|
-
Chef::Config.platform_specific_path("#{
|
370
|
+
Chef::Config.platform_specific_path("#{ChefConfig::Config.etc_chef_dir}/client.rb")
|
366
371
|
elsif config[:solo_shell]
|
367
372
|
Chef::WorkstationConfigLoader.new(nil, Chef::Log).config_location
|
368
373
|
else
|
data/lib/chef/shell/ext.rb
CHANGED
@@ -25,7 +25,7 @@ require_relative "shell_session"
|
|
25
25
|
require_relative "model_wrapper"
|
26
26
|
require_relative "../server_api"
|
27
27
|
require_relative "../json_compat"
|
28
|
-
|
28
|
+
require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
29
29
|
|
30
30
|
module Shell
|
31
31
|
module Extensions
|
@@ -69,7 +69,7 @@ module Shell
|
|
69
69
|
def help_banner
|
70
70
|
banner = []
|
71
71
|
banner << ""
|
72
|
-
banner << "#{
|
72
|
+
banner << "#{ChefUtils::Dist::Infra::SHELL} Help"
|
73
73
|
banner << "".ljust(80, "=")
|
74
74
|
banner << "| " + "Command".ljust(25) + "| " + "Description"
|
75
75
|
banner << "".ljust(80, "=")
|
@@ -194,7 +194,7 @@ module Shell
|
|
194
194
|
explain(<<~E)
|
195
195
|
## SUMMARY ##
|
196
196
|
When called with no argument, +help+ prints a table of all
|
197
|
-
#{
|
197
|
+
#{ChefUtils::Dist::Infra::SHELL} commands. When called with an argument COMMAND, +help+
|
198
198
|
prints a detailed explanation of the command if available, or the
|
199
199
|
description if no explanation is available.
|
200
200
|
E
|
@@ -208,9 +208,9 @@ module Shell
|
|
208
208
|
end
|
209
209
|
alias :halp :help
|
210
210
|
|
211
|
-
desc "prints information about #{
|
211
|
+
desc "prints information about #{ChefUtils::Dist::Infra::PRODUCT}"
|
212
212
|
def version
|
213
|
-
puts "Welcome to the #{
|
213
|
+
puts "Welcome to the #{ChefUtils::Dist::Infra::SHELL} #{::Chef::VERSION}\n" +
|
214
214
|
"For usage see https://docs.chef.io/chef_shell/"
|
215
215
|
:ucanhaz_automation
|
216
216
|
end
|
@@ -228,7 +228,7 @@ module Shell
|
|
228
228
|
:attributes
|
229
229
|
end
|
230
230
|
|
231
|
-
desc "run #{
|
231
|
+
desc "run #{ChefUtils::Dist::Infra::PRODUCT} using the current recipe"
|
232
232
|
def run_chef
|
233
233
|
Chef::Log.level = :debug
|
234
234
|
session = Shell.session
|
@@ -237,8 +237,8 @@ module Shell
|
|
237
237
|
runrun
|
238
238
|
end
|
239
239
|
|
240
|
-
desc "returns an object to control a paused #{
|
241
|
-
subcommands resume: "resume the #{
|
240
|
+
desc "returns an object to control a paused #{ChefUtils::Dist::Infra::PRODUCT} run"
|
241
|
+
subcommands resume: "resume the #{ChefUtils::Dist::Infra::PRODUCT} run",
|
242
242
|
step: "run only the next resource",
|
243
243
|
skip_back: "move back in the run list",
|
244
244
|
skip_forward: "move forward in the run list"
|
@@ -309,9 +309,9 @@ module Shell
|
|
309
309
|
new_node = edit(existing_node)
|
310
310
|
|
311
311
|
## EDITOR SELECTION ##
|
312
|
-
#{
|
312
|
+
#{ChefUtils::Dist::Infra::SHELL} looks for an editor using the following logic
|
313
313
|
1. Looks for an EDITOR set by Shell.editor = "EDITOR"
|
314
|
-
2. Looks for an EDITOR configured in your #{
|
314
|
+
2. Looks for an EDITOR configured in your #{ChefUtils::Dist::Infra::SHELL} config file
|
315
315
|
3. Uses the value of the EDITOR environment variable
|
316
316
|
E
|
317
317
|
def edit(object)
|
@@ -320,7 +320,7 @@ module Shell
|
|
320
320
|
return :failburger
|
321
321
|
end
|
322
322
|
|
323
|
-
filename = "#{
|
323
|
+
filename = "#{ChefUtils::Dist::Infra::SHELL}-edit-#{object.class.name}-"
|
324
324
|
if object.respond_to?(:name)
|
325
325
|
filename += object.name
|
326
326
|
elsif object.respond_to?(:id)
|
@@ -28,7 +28,7 @@ require_relative "../run_list/run_list_expansion"
|
|
28
28
|
require_relative "../formatters/base"
|
29
29
|
require_relative "../formatters/doc"
|
30
30
|
require_relative "../formatters/minimal"
|
31
|
-
|
31
|
+
require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
32
32
|
|
33
33
|
module Shell
|
34
34
|
class ShellSession
|
@@ -90,7 +90,7 @@ module Shell
|
|
90
90
|
end
|
91
91
|
|
92
92
|
def save_node
|
93
|
-
raise "Not Supported! #{self.class.name} doesn't support #save_node, maybe you need to run #{
|
93
|
+
raise "Not Supported! #{self.class.name} doesn't support #save_node, maybe you need to run #{ChefUtils::Dist::Infra::SHELL} in client mode?"
|
94
94
|
end
|
95
95
|
|
96
96
|
def rebuild_context
|
data/lib/chef/train_transport.rb
CHANGED
@@ -15,114 +15,15 @@
|
|
15
15
|
# limitations under the License.
|
16
16
|
#
|
17
17
|
|
18
|
-
require "chef-config/mixin/
|
19
|
-
require "train"
|
20
|
-
require_relative "dist"
|
18
|
+
require "chef-config/mixin/train_transport" unless defined?(ChefConfig::Mixin::TrainTransport)
|
21
19
|
|
22
20
|
class Chef
|
23
21
|
class TrainTransport
|
24
|
-
|
22
|
+
include ChefConfig::Mixin::TrainTransport
|
25
23
|
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
def self.load_credentials(profile)
|
30
|
-
# Tomlrb.load_file returns a hash with keys as strings
|
31
|
-
credentials = parse_credentials_file
|
32
|
-
if contains_split_fqdn?(credentials, profile)
|
33
|
-
Chef::Log.warn("Credentials file #{credentials_file_path} contains target '#{profile}' as a Hash, expected a string.")
|
34
|
-
Chef::Log.warn("Hostnames must be surrounded by single quotes, e.g. ['host.example.org']")
|
35
|
-
end
|
36
|
-
|
37
|
-
# host names must be specified in credentials file as ['foo.example.org'] with quotes
|
38
|
-
if !credentials.nil? && !credentials[profile].nil?
|
39
|
-
credentials[profile].map { |k, v| [k.to_sym, v] }.to_h # return symbolized keys to match Train.options()
|
40
|
-
else
|
41
|
-
nil
|
42
|
-
end
|
43
|
-
end
|
44
|
-
|
45
|
-
# Toml creates hashes when a key is separated by periods, e.g.
|
46
|
-
# [host.example.org] => { host: { example: { org: {} } } }
|
47
|
-
#
|
48
|
-
# Returns true if the above example is true
|
49
|
-
#
|
50
|
-
# A hostname has to be specified as ['host.example.org']
|
51
|
-
# This will be a common mistake so we should catch it
|
52
|
-
#
|
53
|
-
def self.contains_split_fqdn?(hash, fqdn)
|
54
|
-
fqdn.split(".").reduce(hash) do |h, k|
|
55
|
-
v = h[k]
|
56
|
-
if Hash === v
|
57
|
-
v
|
58
|
-
else
|
59
|
-
break false
|
60
|
-
end
|
61
|
-
end
|
62
|
-
end
|
63
|
-
|
64
|
-
# ChefConfig::Mixin::Credentials.credentials_file_path is designed around knife,
|
65
|
-
# overriding it here.
|
66
|
-
#
|
67
|
-
# Credentials file preference:
|
68
|
-
#
|
69
|
-
# 1) target_mode.credentials_file
|
70
|
-
# 2) /etc/chef/TARGET_MODE_HOST/credentials
|
71
|
-
# 3) #credentials_file_path from parent ($HOME/.chef/credentials)
|
72
|
-
#
|
73
|
-
def self.credentials_file_path
|
74
|
-
tm_config = Chef::Config.target_mode
|
75
|
-
profile = tm_config.host
|
76
|
-
|
77
|
-
credentials_file =
|
78
|
-
if tm_config.credentials_file && File.exist?(tm_config.credentials_file)
|
79
|
-
tm_config.credentials_file
|
80
|
-
elsif File.exist?(Chef::Config.platform_specific_path("#{Chef::Dist::CONF_DIR}/#{profile}/credentials"))
|
81
|
-
Chef::Config.platform_specific_path("#{Chef::Dist::CONF_DIR}/#{profile}/credentials")
|
82
|
-
else
|
83
|
-
super
|
84
|
-
end
|
85
|
-
|
86
|
-
raise ArgumentError, "No credentials file found for target '#{profile}'" unless credentials_file
|
87
|
-
raise ArgumentError, "Credentials file specified for target mode does not exist: '#{credentials_file}'" unless File.exist?(credentials_file)
|
88
|
-
|
89
|
-
Chef::Log.debug("Loading credentials file '#{credentials_file}' for target '#{profile}'")
|
90
|
-
|
91
|
-
credentials_file
|
92
|
-
end
|
93
|
-
|
94
|
-
def self.build_transport(logger = Chef::Log.with_child(subsystem: "transport"))
|
95
|
-
return nil unless Chef::Config.target_mode?
|
96
|
-
|
97
|
-
# TODO: Consider supporting parsing the protocol from a URI passed to `--target`
|
98
|
-
#
|
99
|
-
train_config = {}
|
100
|
-
|
101
|
-
# Load the target_mode config context from Chef::Config, and place any valid settings into the train configuration
|
102
|
-
tm_config = Chef::Config.target_mode
|
103
|
-
protocol = tm_config.protocol
|
104
|
-
train_config = tm_config.to_hash.select { |k| Train.options(protocol).key?(k) }
|
105
|
-
Chef::Log.trace("Using target mode options from #{Chef::Dist::PRODUCT} config file: #{train_config.keys.join(", ")}") if train_config
|
106
|
-
|
107
|
-
# Load the credentials file, and place any valid settings into the train configuration
|
108
|
-
credentials = load_credentials(tm_config.host)
|
109
|
-
if credentials
|
110
|
-
valid_settings = credentials.select { |k| Train.options(protocol).key?(k) }
|
111
|
-
valid_settings[:enable_password] = credentials[:enable_password] if credentials.key?(:enable_password)
|
112
|
-
train_config.merge!(valid_settings)
|
113
|
-
Chef::Log.trace("Using target mode options from credentials file: #{valid_settings.keys.join(", ")}") if valid_settings
|
114
|
-
end
|
115
|
-
|
116
|
-
train_config[:logger] = logger
|
117
|
-
|
118
|
-
# Train handles connection retries for us
|
119
|
-
Train.create(protocol, train_config)
|
120
|
-
rescue SocketError => e # likely a dns failure, not caught by train
|
121
|
-
e.message.replace "Error connecting to #{train_config[:target]} - #{e.message}"
|
122
|
-
raise e
|
123
|
-
rescue Train::PluginLoadError
|
124
|
-
logger.error("Invalid target mode protocol: #{protocol}")
|
125
|
-
exit(false)
|
24
|
+
def config
|
25
|
+
require "chef/config" unless defined?(Chef::Config)
|
26
|
+
Chef::Config
|
126
27
|
end
|
127
28
|
end
|
128
29
|
end
|