chef 16.4.41-universal-mingw32 → 16.5.64-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 +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
|