chef 16.3.38-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-universal-mingw32.gemspec +0 -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/action_collection.rb +4 -0
- data/lib/chef/api_client/registration.rb +2 -2
- data/lib/chef/application.rb +19 -17
- data/lib/chef/application/apply.rb +17 -12
- 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 +39 -39
- data/lib/chef/application/windows_service_manager.rb +6 -6
- data/lib/chef/chef_class.rb +0 -1
- data/lib/chef/chef_fs/chef_fs_data_store.rb +54 -54
- data/lib/chef/chef_fs/file_system/chef_server/acl_entry.rb +10 -10
- data/lib/chef/chef_fs/file_system/chef_server/organization_invites_entry.rb +8 -8
- data/lib/chef/chef_fs/file_system/chef_server/organization_members_entry.rb +8 -8
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_dir.rb +2 -2
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +1 -1
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +18 -18
- data/lib/chef/chef_fs/file_system/repository/directory.rb +1 -1
- data/lib/chef/chef_fs/file_system/repository/file_system_entry.rb +1 -1
- data/lib/chef/chef_fs/knife.rb +2 -2
- data/lib/chef/chef_fs/parallelizer.rb +0 -1
- data/lib/chef/client.rb +21 -22
- 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 +13 -3
- 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 +9 -9
- 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 +4 -4
- data/lib/chef/event_loggers/windows_eventlog.rb +2 -2
- data/lib/chef/exceptions.rb +5 -5
- data/lib/chef/file_access_control/windows.rb +5 -1
- data/lib/chef/file_content_management/tempfile.rb +9 -9
- 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/handler.rb +2 -0
- data/lib/chef/http.rb +15 -13
- data/lib/chef/http/auth_credentials.rb +5 -1
- data/lib/chef/http/authenticator.rb +3 -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 +2 -2
- data/lib/chef/knife.rb +4 -4
- data/lib/chef/knife/bootstrap.rb +18 -16
- 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 +4 -2
- data/lib/chef/knife/cookbook_download.rb +1 -1
- data/lib/chef/knife/cookbook_metadata.rb +1 -1
- data/lib/chef/knife/cookbook_upload.rb +23 -23
- data/lib/chef/knife/core/bootstrap_context.rb +2 -2
- data/lib/chef/knife/core/generic_presenter.rb +1 -1
- data/lib/chef/knife/core/hashed_command_loader.rb +2 -2
- data/lib/chef/knife/core/object_loader.rb +1 -1
- data/lib/chef/knife/core/windows_bootstrap_context.rb +42 -34
- data/lib/chef/knife/delete.rb +15 -15
- data/lib/chef/knife/exec.rb +4 -4
- data/lib/chef/knife/node_show.rb +2 -2
- data/lib/chef/knife/serve.rb +3 -3
- data/lib/chef/knife/ssh.rb +22 -7
- 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/xargs.rb +19 -19
- 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/checksum.rb +0 -1
- data/lib/chef/mixin/deep_merge.rb +35 -18
- data/lib/chef/mixin/openssl_helper.rb +4 -5
- data/lib/chef/mixin/shell_out.rb +1 -1
- 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/mixin/which.rb +1 -1
- data/lib/chef/monkey_patches/net_http.rb +4 -4
- data/lib/chef/monkey_patches/webrick-utils.rb +10 -10
- data/lib/chef/node/attribute.rb +2 -4
- data/lib/chef/node_map.rb +2 -2
- data/lib/chef/platform/service_helpers.rb +1 -1
- data/lib/chef/policy_builder/policyfile.rb +2 -2
- data/lib/chef/property.rb +1 -1
- data/lib/chef/provider.rb +0 -4
- data/lib/chef/provider/cron/unix.rb +0 -2
- data/lib/chef/provider/file.rb +2 -2
- data/lib/chef/provider/git.rb +5 -5
- data/lib/chef/provider/group.rb +0 -2
- data/lib/chef/provider/group/suse.rb +5 -5
- data/lib/chef/provider/ifconfig.rb +1 -4
- data/lib/chef/provider/launchd.rb +2 -2
- data/lib/chef/provider/mount.rb +0 -2
- data/lib/chef/provider/mount/linux.rb +63 -0
- data/lib/chef/provider/package.rb +0 -2
- data/lib/chef/provider/package/rubygems.rb +22 -19
- data/lib/chef/provider/package/snap.rb +1 -2
- data/lib/chef/provider/package/windows.rb +2 -2
- data/lib/chef/provider/package/windows/registry_uninstall_entry.rb +12 -10
- data/lib/chef/provider/package/zypper.rb +1 -1
- data/lib/chef/provider/powershell_script.rb +21 -5
- 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/arch.rb +1 -1
- data/lib/chef/provider/service/debian.rb +1 -1
- data/lib/chef/provider/service/gentoo.rb +2 -2
- data/lib/chef/provider/service/macosx.rb +4 -4
- data/lib/chef/provider/service/openbsd.rb +1 -4
- data/lib/chef/provider/service/redhat.rb +2 -2
- data/lib/chef/provider/service/upstart.rb +1 -1
- data/lib/chef/provider/service/windows.rb +10 -10
- data/lib/chef/provider/systemd_unit.rb +0 -2
- data/lib/chef/provider/template/content.rb +1 -0
- data/lib/chef/provider/template_finder.rb +2 -10
- data/lib/chef/provider/user/dscl.rb +5 -5
- data/lib/chef/provider/user/mac.rb +10 -10
- data/lib/chef/provider/windows_task.rb +1 -5
- data/lib/chef/provider/zypper_repository.rb +2 -3
- data/lib/chef/provider_resolver.rb +1 -1
- data/lib/chef/providers.rb +1 -1
- data/lib/chef/recipe.rb +2 -2
- data/lib/chef/resource.rb +7 -11
- data/lib/chef/resource/apt_repository.rb +2 -11
- 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 +26 -19
- 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 +14 -14
- 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 +8 -9
- 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 +7 -7
- data/lib/chef/resource/hostname.rb +19 -19
- 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 +29 -5
- data/lib/chef/resource/openssl_ec_private_key.rb +8 -3
- data/lib/chef/resource/openssl_ec_public_key.rb +4 -2
- data/lib/chef/resource/openssl_rsa_private_key.rb +8 -3
- data/lib/chef/resource/openssl_rsa_public_key.rb +2 -0
- data/lib/chef/resource/openssl_x509_certificate.rb +38 -35
- data/lib/chef/resource/openssl_x509_crl.rb +21 -10
- data/lib/chef/resource/openssl_x509_request.rb +37 -36
- data/lib/chef/resource/osx_profile.rb +292 -6
- data/lib/chef/resource/plist.rb +1 -1
- data/lib/chef/resource/powershell_package_source.rb +6 -6
- data/lib/chef/resource/powershell_script.rb +24 -30
- 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/sudo.rb +1 -1
- 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 +6 -10
- data/lib/chef/resource/systemd_unit.rb +2 -2
- data/lib/chef/resource/template.rb +2 -2
- data/lib/chef/resource/timezone.rb +112 -73
- data/lib/chef/resource/windows_ad_join.rb +12 -3
- data/lib/chef/resource/windows_audit_policy.rb +3 -0
- data/lib/chef/resource/windows_auto_run.rb +2 -0
- data/lib/chef/resource/windows_certificate.rb +8 -4
- data/lib/chef/resource/windows_dfs_folder.rb +2 -0
- data/lib/chef/resource/windows_dfs_namespace.rb +2 -0
- data/lib/chef/resource/windows_dfs_server.rb +2 -0
- data/lib/chef/resource/windows_dns_record.rb +10 -7
- data/lib/chef/resource/windows_dns_zone.rb +12 -7
- data/lib/chef/resource/windows_feature.rb +2 -0
- data/lib/chef/resource/windows_feature_dism.rb +10 -0
- data/lib/chef/resource/windows_feature_powershell.rb +14 -2
- data/lib/chef/resource/windows_firewall_profile.rb +24 -20
- data/lib/chef/resource/windows_firewall_rule.rb +5 -3
- data/lib/chef/resource/windows_font.rb +3 -1
- data/lib/chef/resource/windows_package.rb +28 -5
- data/lib/chef/resource/windows_pagefile.rb +4 -0
- data/lib/chef/resource/windows_printer.rb +22 -21
- data/lib/chef/resource/windows_printer_port.rb +20 -17
- data/lib/chef/resource/windows_security_policy.rb +2 -0
- data/lib/chef/resource/windows_share.rb +5 -3
- data/lib/chef/resource/windows_shortcut.rb +2 -0
- data/lib/chef/resource/windows_uac.rb +2 -0
- data/lib/chef/resource/windows_user_privilege.rb +54 -53
- data/lib/chef/resource/windows_workgroup.rb +5 -6
- data/lib/chef/resource/yum_package.rb +2 -2
- data/lib/chef/resource_collection/stepable_iterator.rb +1 -2
- data/lib/chef/resources.rb +3 -1
- data/lib/chef/role.rb +2 -2
- data/lib/chef/run_context.rb +2 -2
- data/lib/chef/run_context/cookbook_compiler.rb +21 -21
- data/lib/chef/run_lock.rb +2 -2
- data/lib/chef/run_status.rb +2 -6
- data/lib/chef/search/query.rb +4 -5
- data/lib/chef/server_api_versions.rb +4 -0
- data/lib/chef/shell.rb +32 -27
- 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/backup.rb +1 -1
- data/lib/chef/util/diff.rb +14 -14
- data/lib/chef/util/powershell/cmdlet.rb +4 -2
- 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/file.rb +2 -2
- data/lib/chef/win32/file/version_info.rb +5 -5
- data/lib/chef/win32/registry.rb +1 -2
- data/spec/data/shef-config.rb +1 -1
- data/spec/data/ssl/chef-rspec.cert +15 -15
- 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 +8 -8
- data/spec/functional/resource/bff_spec.rb +2 -2
- data/spec/functional/resource/cookbook_file_spec.rb +1 -1
- data/spec/functional/resource/dsc_resource_spec.rb +1 -1
- data/spec/functional/resource/dsc_script_spec.rb +0 -1
- data/spec/functional/resource/group_spec.rb +6 -6
- data/spec/functional/resource/insserv_spec.rb +5 -5
- data/spec/functional/resource/link_spec.rb +20 -20
- data/spec/functional/resource/powershell_script_spec.rb +4 -4
- data/spec/functional/resource/rpm_spec.rb +2 -2
- 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_certificate_spec.rb +3 -3
- data/spec/functional/resource/windows_font_spec.rb +49 -0
- data/spec/functional/resource/windows_security_policy_spec.rb +0 -3
- data/spec/functional/resource/windows_task_spec.rb +13 -13
- data/spec/functional/run_lock_spec.rb +24 -24
- data/spec/functional/version_spec.rb +3 -3
- data/spec/functional/win32/registry_spec.rb +8 -8
- data/spec/functional/win32/service_manager_spec.rb +1 -1
- 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/common_options_spec.rb +12 -12
- data/spec/integration/knife/config_list_spec.rb +220 -0
- data/spec/integration/knife/config_show_spec.rb +192 -0
- data/spec/integration/knife/config_use_spec.rb +198 -0
- data/spec/integration/knife/cookbook_api_ipv6_spec.rb +1 -1
- data/spec/integration/knife/diff_spec.rb +3 -1
- data/spec/integration/knife/download_spec.rb +3 -1
- data/spec/integration/knife/serve_spec.rb +5 -5
- data/spec/integration/knife/upload_spec.rb +3 -1
- data/spec/integration/ohai/ohai_spec.rb +61 -0
- data/spec/integration/recipes/lwrp_inline_resources_spec.rb +1 -1
- data/spec/integration/recipes/remote_directory.rb +1 -1
- data/spec/integration/solo/solo_spec.rb +5 -5
- data/spec/spec_helper.rb +12 -9
- 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 +17 -35
- data/spec/support/platforms/win32/spec_service.rb +1 -1
- data/spec/support/shared/functional/directory_resource.rb +1 -1
- data/spec/support/shared/functional/execute_resource.rb +1 -1
- data/spec/support/shared/functional/file_resource.rb +20 -20
- data/spec/support/shared/functional/securable_resource.rb +108 -27
- data/spec/support/shared/functional/win32_service.rb +2 -2
- data/spec/support/shared/functional/windows_script.rb +3 -3
- data/spec/support/shared/integration/integration_helper.rb +22 -52
- data/spec/support/shared/unit/application_dot_d.rb +5 -3
- data/spec/support/shared/unit/script_resource.rb +6 -20
- data/spec/support/shared/unit/windows_script_resource.rb +15 -28
- 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 +28 -113
- data/spec/unit/dsl/declare_resource_spec.rb +1 -1
- data/spec/unit/environment_spec.rb +7 -7
- data/spec/unit/file_access_control_spec.rb +1 -1
- data/spec/unit/http/api_versions_spec.rb +19 -1
- data/spec/unit/knife/bootstrap_spec.rb +20 -20
- data/spec/unit/knife/cookbook_download_spec.rb +4 -4
- data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +1 -1
- data/spec/unit/knife/core/hashed_command_loader_spec.rb +3 -3
- data/spec/unit/knife/core/ui_spec.rb +1 -0
- data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +21 -12
- data/spec/unit/knife/ssh_spec.rb +2 -2
- data/spec/unit/knife/supermarket_share_spec.rb +1 -1
- 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/mixin/template_spec.rb +30 -30
- data/spec/unit/mixin/windows_architecture_helper_spec.rb +4 -4
- data/spec/unit/node/immutable_collections_spec.rb +8 -4
- data/spec/unit/node_spec.rb +5 -5
- 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/powershell_script_spec.rb +11 -4
- data/spec/unit/provider/remote_directory_spec.rb +9 -9
- data/spec/unit/provider/route_spec.rb +0 -2
- data/spec/unit/provider/service/arch_service_spec.rb +3 -2
- data/spec/unit/provider/service/debian_service_spec.rb +1 -1
- data/spec/unit/provider/service/gentoo_service_spec.rb +7 -7
- data/spec/unit/provider/service/macosx_spec.rb +3 -3
- data/spec/unit/provider/service/redhat_spec.rb +2 -2
- data/spec/unit/provider/service/upstart_service_spec.rb +3 -3
- data/spec/unit/provider_resolver_spec.rb +6 -6
- data/spec/unit/recipe_spec.rb +1 -1
- data/spec/unit/resource/batch_spec.rb +6 -6
- 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/execute_spec.rb +113 -118
- data/spec/unit/resource/launchd_spec.rb +8 -0
- data/spec/unit/resource/osx_profile_spec.rb +299 -0
- data/spec/unit/resource/powershell_script_spec.rb +11 -29
- data/spec/unit/resource/rhsm_register_spec.rb +56 -18
- data/spec/unit/resource/script_spec.rb +6 -1
- data/spec/unit/resource/timezone_spec.rb +63 -0
- data/spec/unit/resource/windows_feature_powershell_spec.rb +30 -4
- data/spec/unit/resource/windows_uac_spec.rb +1 -1
- data/spec/unit/resource/windows_user_privilege_spec.rb +55 -0
- data/spec/unit/role_spec.rb +11 -11
- data/spec/unit/run_lock_spec.rb +5 -1
- data/spec/unit/runner_spec.rb +1 -2
- data/spec/unit/server_api_spec.rb +43 -16
- 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 +1 -3
- metadata +42 -33
- data/lib/chef/dist.rb +0 -68
- data/lib/chef/provider/osx_profile.rb +0 -255
- data/spec/integration/knife/config_get_profile_spec.rb +0 -113
- data/spec/integration/knife/config_get_spec.rb +0 -191
- data/spec/integration/knife/config_list_profiles_spec.rb +0 -218
- data/spec/integration/knife/config_use_profile_spec.rb +0 -154
- data/spec/unit/provider/osx_profile_spec.rb +0 -255
data/lib/chef/role.rb
CHANGED
@@ -256,11 +256,11 @@ class Chef
|
|
256
256
|
|
257
257
|
js_path, rb_path = js_files.first, rb_files.first
|
258
258
|
|
259
|
-
if js_path && File.
|
259
|
+
if js_path && File.exist?(js_path)
|
260
260
|
# from_json returns object.class => json_class in the JSON.
|
261
261
|
hsh = Chef::JSONCompat.parse(IO.read(js_path))
|
262
262
|
return from_hash(hsh)
|
263
|
-
elsif rb_path && File.
|
263
|
+
elsif rb_path && File.exist?(rb_path)
|
264
264
|
role = Chef::Role.new
|
265
265
|
role.name(name)
|
266
266
|
role.from_file(rb_path)
|
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
|
@@ -16,7 +16,7 @@
|
|
16
16
|
# limitations under the License.
|
17
17
|
#
|
18
18
|
|
19
|
-
|
19
|
+
autoload :Set, "set"
|
20
20
|
require_relative "../log"
|
21
21
|
require_relative "../recipe"
|
22
22
|
require_relative "../resource/lwrp_base"
|
@@ -169,17 +169,17 @@ class Chef
|
|
169
169
|
def compile_recipes
|
170
170
|
@events.recipe_load_start(run_list_expansion.recipes.size)
|
171
171
|
run_list_expansion.recipes.each do |recipe|
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
|
172
|
+
|
173
|
+
path = resolve_recipe(recipe)
|
174
|
+
@run_context.load_recipe(recipe)
|
175
|
+
@events.recipe_file_loaded(path, recipe)
|
176
|
+
rescue Chef::Exceptions::RecipeNotFound => e
|
177
|
+
@events.recipe_not_found(e)
|
178
|
+
raise
|
179
|
+
rescue Exception => e
|
180
|
+
@events.recipe_file_load_failed(path, e, recipe)
|
181
|
+
raise
|
182
|
+
|
183
183
|
end
|
184
184
|
@events.recipe_load_complete
|
185
185
|
end
|
@@ -231,14 +231,14 @@ class Chef
|
|
231
231
|
|
232
232
|
def load_libraries_from_cookbook(cookbook_name, globs = "**/*.rb")
|
233
233
|
each_file_in_cookbook_by_segment(cookbook_name, :libraries, globs) do |filename|
|
234
|
-
|
235
|
-
|
236
|
-
|
237
|
-
|
238
|
-
|
239
|
-
|
240
|
-
|
241
|
-
|
234
|
+
|
235
|
+
logger.trace("Loading cookbook #{cookbook_name}'s library file: #{filename}")
|
236
|
+
Kernel.require(filename)
|
237
|
+
@events.library_file_loaded(filename)
|
238
|
+
rescue Exception => e
|
239
|
+
@events.library_file_load_failed(filename, e)
|
240
|
+
raise
|
241
|
+
|
242
242
|
end
|
243
243
|
end
|
244
244
|
|
@@ -325,7 +325,7 @@ class Chef
|
|
325
325
|
|
326
326
|
def count_files_by_segment(segment, root_alias = nil)
|
327
327
|
cookbook_collection.inject(0) do |count, cookbook_by_name|
|
328
|
-
count + cookbook_by_name[1].segment_filenames(segment).size + (root_alias ? cookbook_by_name[1].files_for(:root_files).
|
328
|
+
count + cookbook_by_name[1].segment_filenames(segment).size + (root_alias ? cookbook_by_name[1].files_for(:root_files).count { |record| record[:name] == root_alias } : 0)
|
329
329
|
end
|
330
330
|
end
|
331
331
|
|
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/run_status.rb
CHANGED
@@ -25,17 +25,13 @@ class Chef::RunStatus
|
|
25
25
|
|
26
26
|
attr_reader :events
|
27
27
|
|
28
|
-
|
29
|
-
|
30
|
-
attr_writer :run_context
|
28
|
+
attr_accessor :run_context
|
31
29
|
|
32
30
|
attr_reader :start_time
|
33
31
|
|
34
32
|
attr_reader :end_time
|
35
33
|
|
36
|
-
|
37
|
-
|
38
|
-
attr_writer :exception
|
34
|
+
attr_accessor :exception
|
39
35
|
|
40
36
|
attr_accessor :run_id
|
41
37
|
|
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,
|
@@ -339,7 +344,7 @@ module Shell
|
|
339
344
|
config[:config_file] = config_file_for_shell_mode(environment)
|
340
345
|
config_msg = config[:config_file] || "none (standalone session)"
|
341
346
|
puts "loading configuration: #{config_msg}"
|
342
|
-
Chef::Config.from_file(config[:config_file]) if !config[:config_file].nil? && File.
|
347
|
+
Chef::Config.from_file(config[:config_file]) if !config[:config_file].nil? && File.exist?(config[:config_file]) && File.readable?(config[:config_file])
|
343
348
|
Chef::Config.merge!(config)
|
344
349
|
end
|
345
350
|
|
@@ -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
|