chef 15.11.3-universal-mingw32 → 16.1.16-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 +3 -7
- data/README.md +1 -1
- data/Rakefile +44 -16
- data/chef.gemspec +6 -4
- data/distro/powershell/chef/chef.psm1 +3 -3
- data/distro/templates/powershell/chef/chef.psm1.erb +3 -3
- data/lib/chef/action_collection.rb +16 -5
- data/lib/chef/application.rb +33 -54
- data/lib/chef/application/apply.rb +18 -1
- data/lib/chef/application/base.rb +8 -3
- data/lib/chef/application/knife.rb +1 -1
- data/lib/chef/chef_class.rb +4 -4
- data/lib/chef/chef_fs/file_system/chef_server/acls_dir.rb +1 -1
- data/lib/chef/chef_fs/file_system/chef_server/cookbook_file.rb +1 -1
- data/lib/chef/chef_fs/file_system/chef_server/rest_list_entry.rb +6 -2
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +3 -3
- data/lib/chef/chef_fs/file_system/repository/directory.rb +1 -1
- data/lib/chef/chef_fs/parallelizer/parallel_enumerable.rb +1 -1
- data/lib/chef/chef_fs/path_utils.rb +3 -3
- data/lib/chef/client.rb +16 -14
- data/lib/chef/config.rb +1 -1
- data/lib/chef/cookbook/file_system_file_vendor.rb +1 -1
- data/lib/chef/cookbook/gem_installer.rb +1 -1
- data/lib/chef/cookbook/metadata.rb +45 -22
- data/lib/chef/cookbook_loader.rb +1 -1
- data/lib/chef/cookbook_manifest.rb +1 -1
- data/lib/chef/cookbook_site_streaming_uploader.rb +1 -1
- data/lib/chef/cookbook_version.rb +38 -3
- data/lib/chef/data_collector.rb +1 -1
- data/lib/chef/data_collector/error_handlers.rb +1 -1
- data/lib/chef/data_collector/run_end_message.rb +7 -1
- data/lib/chef/decorator/lazy_array.rb +2 -2
- data/lib/chef/deprecated.rb +4 -0
- data/lib/chef/digester.rb +4 -4
- data/lib/chef/dist.rb +8 -0
- data/lib/chef/dsl/chef_vault.rb +84 -0
- data/lib/chef/dsl/declare_resource.rb +7 -5
- data/lib/chef/dsl/platform_introspection.rb +3 -2
- data/lib/chef/dsl/recipe.rb +7 -12
- data/lib/chef/dsl/universal.rb +3 -7
- data/lib/chef/encrypted_data_bag_item/decryptor.rb +1 -1
- data/lib/chef/encrypted_data_bag_item/encryptor.rb +1 -1
- data/lib/chef/event_dispatch/base.rb +3 -0
- data/lib/chef/formatters/base.rb +1 -1
- data/lib/chef/formatters/doc.rb +1 -1
- data/lib/chef/formatters/indentable_output_stream.rb +7 -16
- data/lib/chef/http.rb +1 -1
- data/lib/chef/http/decompressor.rb +1 -1
- data/lib/chef/http/http_request.rb +3 -2
- data/lib/chef/json_compat.rb +1 -1
- data/lib/chef/key.rb +1 -1
- data/lib/chef/knife.rb +2 -4
- data/lib/chef/knife/acl_add.rb +57 -0
- data/lib/chef/knife/acl_base.rb +183 -0
- data/lib/chef/knife/acl_bulk_add.rb +78 -0
- data/lib/chef/knife/acl_bulk_remove.rb +83 -0
- data/lib/chef/knife/acl_remove.rb +62 -0
- data/lib/chef/knife/acl_show.rb +56 -0
- data/lib/chef/knife/bootstrap.rb +84 -90
- data/lib/chef/knife/bootstrap/chef_vault_handler.rb +2 -2
- data/lib/chef/knife/bootstrap/client_builder.rb +2 -2
- data/lib/chef/knife/bootstrap/templates/chef-full.erb +11 -11
- data/lib/chef/knife/bootstrap/templates/windows-chef-client-msi.erb +12 -12
- data/lib/chef/knife/core/bootstrap_context.rb +63 -60
- data/lib/chef/knife/core/generic_presenter.rb +4 -3
- data/lib/chef/knife/core/hashed_command_loader.rb +1 -1
- data/lib/chef/knife/core/node_presenter.rb +2 -2
- data/lib/chef/knife/core/status_presenter.rb +5 -5
- data/lib/chef/knife/core/subcommand_loader.rb +1 -1
- data/lib/chef/knife/core/ui.rb +17 -1
- data/lib/chef/knife/core/windows_bootstrap_context.rb +44 -42
- data/lib/chef/knife/data_bag_secret_options.rb +18 -45
- data/lib/chef/knife/group_add.rb +55 -0
- data/lib/chef/knife/{cookbook_site_download.rb → group_create.rb} +21 -12
- data/lib/chef/knife/group_destroy.rb +53 -0
- data/lib/chef/knife/{cookbook_site_list.rb → group_list.rb} +14 -11
- data/lib/chef/knife/group_remove.rb +56 -0
- data/lib/chef/knife/{cookbook_site_install.rb → group_show.rb} +21 -12
- data/lib/chef/knife/key_create_base.rb +1 -1
- data/lib/chef/knife/key_edit_base.rb +1 -1
- data/lib/chef/knife/ssh.rb +12 -31
- data/lib/chef/knife/status.rb +3 -3
- data/lib/chef/knife/supermarket_download.rb +1 -2
- data/lib/chef/knife/supermarket_install.rb +2 -3
- data/lib/chef/knife/supermarket_list.rb +1 -2
- data/lib/chef/knife/supermarket_search.rb +1 -2
- data/lib/chef/knife/supermarket_share.rb +1 -2
- data/lib/chef/knife/supermarket_show.rb +1 -2
- data/lib/chef/knife/supermarket_unshare.rb +1 -2
- data/lib/chef/knife/{cookbook_site_show.rb → user_dissociate.rb} +15 -13
- data/lib/chef/knife/{cookbook_site_search.rb → user_invite_add.rb} +16 -13
- data/lib/chef/knife/user_invite_list.rb +34 -0
- data/lib/chef/knife/user_invite_rescind.rb +63 -0
- data/lib/chef/knife/yaml_convert.rb +91 -0
- data/lib/chef/mixin/api_version_request_handling.rb +1 -1
- data/lib/chef/mixin/checksum.rb +0 -1
- data/lib/chef/mixin/openssl_helper.rb +4 -4
- data/lib/chef/mixin/powershell_exec.rb +10 -1
- data/lib/chef/mixin/powershell_out.rb +1 -1
- data/lib/chef/mixin/properties.rb +16 -2
- data/lib/chef/mixin/shell_out.rb +1 -5
- data/lib/chef/monkey_patches/net_http.rb +0 -4
- data/lib/chef/node.rb +18 -6
- data/lib/chef/node/attribute.rb +2 -2
- data/lib/chef/node/immutable_collections.rb +1 -1
- data/lib/chef/node/mixin/immutablize_array.rb +4 -0
- data/lib/chef/node/mixin/immutablize_hash.rb +3 -0
- data/lib/chef/node_map.rb +5 -31
- data/lib/chef/platform/priority_map.rb +4 -4
- data/lib/chef/platform/query_helpers.rb +6 -34
- data/lib/chef/policy_builder/policyfile.rb +1 -1
- data/lib/chef/powershell.rb +14 -0
- data/lib/chef/property.rb +24 -6
- data/lib/chef/provider.rb +40 -6
- data/lib/chef/provider/cron.rb +2 -2
- data/lib/chef/provider/directory.rb +3 -3
- data/lib/chef/provider/dsc_resource.rb +1 -1
- data/lib/chef/provider/dsc_script.rb +1 -1
- data/lib/chef/provider/execute.rb +3 -9
- data/lib/chef/provider/file.rb +6 -6
- data/lib/chef/provider/git.rb +84 -27
- data/lib/chef/provider/group.rb +4 -4
- data/lib/chef/provider/http_request.rb +6 -6
- data/lib/chef/provider/ifconfig.rb +4 -4
- data/lib/chef/provider/launchd.rb +45 -64
- data/lib/chef/provider/link.rb +2 -2
- data/lib/chef/provider/mount.rb +5 -5
- data/lib/chef/provider/osx_profile.rb +7 -3
- data/lib/chef/provider/package.rb +2 -2
- data/lib/chef/provider/package/cab.rb +5 -6
- data/lib/chef/provider/package/chocolatey.rb +1 -3
- data/lib/chef/provider/package/dnf.rb +66 -10
- data/lib/chef/provider/package/dnf/dnf_helper.py +85 -26
- data/lib/chef/provider/package/dnf/python_helper.rb +79 -36
- data/lib/chef/provider/package/dnf/version.rb +5 -1
- data/lib/chef/provider/package/dpkg.rb +1 -1
- data/lib/chef/provider/package/freebsd/base.rb +2 -1
- data/lib/chef/provider/package/homebrew.rb +107 -43
- data/lib/chef/provider/package/macports.rb +0 -2
- data/lib/chef/provider/package/msu.rb +4 -1
- data/lib/chef/provider/package/pacman.rb +25 -34
- data/lib/chef/provider/package/portage.rb +1 -0
- data/lib/chef/provider/package/powershell.rb +1 -1
- data/lib/chef/provider/package/rubygems.rb +30 -3
- data/lib/chef/provider/package/windows.rb +29 -53
- data/lib/chef/provider/package/windows/msi.rb +2 -2
- data/lib/chef/provider/package/yum.rb +1 -9
- data/lib/chef/provider/package/yum/yum_cache.rb +1 -1
- data/lib/chef/provider/package/zypper.rb +0 -1
- data/lib/chef/provider/powershell_script.rb +5 -11
- data/lib/chef/provider/registry_key.rb +4 -4
- data/lib/chef/provider/remote_directory.rb +5 -5
- data/lib/chef/provider/remote_file/ftp.rb +3 -2
- data/lib/chef/provider/remote_file/local_file.rb +2 -1
- data/lib/chef/provider/remote_file/sftp.rb +3 -2
- data/lib/chef/provider/route.rb +5 -3
- data/lib/chef/provider/ruby_block.rb +1 -1
- data/lib/chef/provider/script.rb +2 -2
- data/lib/chef/provider/service.rb +8 -8
- data/lib/chef/provider/service/aixinit.rb +1 -1
- data/lib/chef/provider/service/arch.rb +1 -1
- data/lib/chef/provider/service/debian.rb +30 -28
- data/lib/chef/provider/service/macosx.rb +16 -10
- data/lib/chef/provider/service/systemd.rb +12 -12
- data/lib/chef/provider/service/upstart.rb +1 -1
- data/lib/chef/provider/service/windows.rb +5 -11
- data/lib/chef/provider/subversion.rb +25 -5
- data/lib/chef/provider/systemd_unit.rb +26 -25
- data/lib/chef/provider/user.rb +6 -6
- data/lib/chef/provider/user/aix.rb +1 -1
- data/lib/chef/provider/user/dscl.rb +6 -6
- data/lib/chef/provider/user/mac.rb +20 -15
- data/lib/chef/provider/whyrun_safe_ruby_block.rb +1 -1
- data/lib/chef/provider/windows_env.rb +3 -3
- data/lib/chef/provider/windows_script.rb +2 -2
- data/lib/chef/provider/windows_task.rb +10 -10
- data/lib/chef/providers.rb +0 -6
- data/lib/chef/recipe.rb +36 -0
- data/lib/chef/resource.rb +44 -57
- data/lib/chef/resource/action_class.rb +24 -22
- data/lib/chef/resource/alternatives.rb +210 -0
- data/lib/chef/resource/apt_package.rb +33 -3
- data/lib/chef/resource/apt_preference.rb +103 -7
- data/lib/chef/resource/apt_repository.rb +357 -18
- data/lib/chef/resource/apt_update.rb +58 -5
- data/lib/chef/resource/archive_file.rb +6 -5
- data/lib/chef/resource/bash.rb +3 -1
- data/lib/chef/resource/batch.rb +1 -1
- data/lib/chef/resource/bff_package.rb +10 -2
- data/lib/chef/resource/breakpoint.rb +1 -2
- data/lib/chef/resource/build_essential.rb +49 -51
- data/lib/chef/resource/cab_package.rb +9 -2
- data/lib/chef/resource/chef_client_cron.rb +228 -0
- data/lib/chef/resource/chef_client_scheduled_task.rb +201 -0
- data/lib/chef/resource/chef_client_systemd_timer.rb +180 -0
- data/lib/chef/resource/chef_gem.rb +15 -18
- data/lib/chef/resource/chef_handler.rb +5 -4
- data/lib/chef/resource/chef_sleep.rb +7 -5
- data/lib/chef/resource/chef_vault_secret.rb +135 -0
- data/lib/chef/resource/chocolatey_config.rb +8 -4
- data/lib/chef/resource/chocolatey_feature.rb +7 -4
- data/lib/chef/resource/chocolatey_package.rb +7 -4
- data/lib/chef/resource/chocolatey_source.rb +7 -4
- data/lib/chef/resource/cookbook_file.rb +4 -3
- data/lib/chef/resource/cron.rb +34 -80
- data/lib/chef/resource/cron_access.rb +10 -6
- data/lib/chef/resource/cron_d.rb +44 -95
- data/lib/chef/resource/csh.rb +3 -1
- data/lib/chef/resource/directory.rb +3 -3
- data/lib/chef/resource/dmg_package.rb +22 -19
- data/lib/chef/resource/dnf_package.rb +3 -4
- data/lib/chef/resource/dpkg_package.rb +3 -2
- data/lib/chef/resource/dsc_resource.rb +6 -4
- data/lib/chef/resource/dsc_script.rb +3 -2
- data/lib/chef/resource/execute.rb +15 -14
- data/lib/chef/resource/file.rb +14 -9
- data/lib/chef/resource/freebsd_package.rb +3 -2
- data/lib/chef/resource/gem_package.rb +19 -11
- data/lib/chef/resource/group.rb +5 -2
- data/lib/chef/resource/helpers/cron_validations.rb +98 -0
- data/lib/chef/resource/homebrew_cask.rb +3 -2
- data/lib/chef/resource/homebrew_package.rb +5 -3
- data/lib/chef/resource/homebrew_tap.rb +3 -2
- data/lib/chef/resource/hostname.rb +26 -20
- data/lib/chef/resource/http_request.rb +1 -2
- data/lib/chef/resource/ifconfig.rb +8 -8
- data/lib/chef/resource/ips_package.rb +11 -3
- data/lib/chef/resource/kernel_module.rb +30 -30
- data/lib/chef/resource/ksh.rb +3 -1
- data/lib/chef/resource/launchd.rb +3 -3
- data/lib/chef/resource/link.rb +5 -27
- data/lib/chef/resource/locale.rb +60 -26
- data/lib/chef/resource/log.rb +13 -2
- data/lib/chef/resource/lwrp_base.rb +1 -1
- data/lib/chef/resource/macos_userdefaults.rb +18 -10
- data/lib/chef/resource/macosx_service.rb +3 -2
- data/lib/chef/resource/macports_package.rb +10 -2
- data/lib/chef/resource/mdadm.rb +63 -3
- data/lib/chef/resource/mount.rb +4 -1
- data/lib/chef/resource/msu_package.rb +19 -2
- data/lib/chef/resource/notify_group.rb +8 -3
- data/lib/chef/resource/ohai.rb +20 -4
- data/lib/chef/resource/ohai_hint.rb +4 -13
- data/lib/chef/resource/openbsd_package.rb +10 -2
- data/lib/chef/resource/openssl_dhparam.rb +11 -2
- data/lib/chef/resource/openssl_ec_private_key.rb +24 -2
- data/lib/chef/resource/openssl_ec_public_key.rb +22 -2
- data/lib/chef/resource/openssl_rsa_private_key.rb +21 -2
- data/lib/chef/resource/openssl_rsa_public_key.rb +23 -2
- data/lib/chef/resource/openssl_x509_certificate.rb +38 -2
- data/lib/chef/resource/openssl_x509_crl.rb +13 -2
- data/lib/chef/resource/openssl_x509_request.rb +38 -2
- data/lib/chef/resource/osx_profile.rb +4 -3
- data/lib/chef/resource/package.rb +3 -2
- data/lib/chef/resource/pacman_package.rb +3 -2
- data/lib/chef/resource/paludis_package.rb +13 -4
- data/lib/chef/resource/perl.rb +3 -1
- data/lib/chef/resource/plist.rb +207 -0
- data/lib/chef/resource/portage_package.rb +14 -4
- data/lib/chef/resource/powershell_package.rb +2 -4
- data/lib/chef/resource/powershell_package_source.rb +4 -2
- data/lib/chef/resource/powershell_script.rb +8 -18
- data/lib/chef/resource/python.rb +3 -1
- data/lib/chef/resource/reboot.rb +1 -2
- data/lib/chef/resource/registry_key.rb +2 -3
- data/lib/chef/resource/remote_directory.rb +3 -1
- data/lib/chef/resource/remote_file.rb +3 -2
- data/lib/chef/resource/rhsm_errata.rb +1 -4
- data/lib/chef/resource/rhsm_errata_level.rb +1 -2
- data/lib/chef/resource/rhsm_register.rb +3 -3
- data/lib/chef/resource/rhsm_repo.rb +4 -3
- data/lib/chef/resource/rhsm_subscription.rb +5 -4
- data/lib/chef/resource/route.rb +6 -2
- data/lib/chef/resource/rpm_package.rb +13 -3
- data/lib/chef/resource/ruby.rb +3 -1
- data/lib/chef/resource/ruby_block.rb +2 -5
- data/lib/chef/resource/scm/_scm.rb +49 -0
- data/lib/chef/resource/{scm.rb → scm/git.rb} +16 -30
- data/lib/chef/resource/{subversion.rb → scm/subversion.rb} +10 -7
- data/lib/chef/resource/script.rb +7 -4
- data/lib/chef/resource/service.rb +7 -8
- data/lib/chef/resource/smartos_package.rb +10 -2
- data/lib/chef/resource/snap_package.rb +4 -2
- data/lib/chef/resource/solaris_package.rb +10 -2
- data/lib/chef/resource/ssh_known_hosts_entry.rb +6 -3
- data/lib/chef/resource/sudo.rb +11 -11
- 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 -2
- data/lib/chef/resource/support/ulimit.erb +41 -0
- data/lib/chef/resource/swap_file.rb +7 -5
- data/lib/chef/resource/sysctl.rb +63 -4
- data/lib/chef/resource/systemd_unit.rb +6 -4
- data/lib/chef/resource/template.rb +0 -1
- data/lib/chef/resource/timezone.rb +8 -19
- data/lib/chef/resource/user.rb +3 -5
- data/lib/chef/resource/user/aix_user.rb +0 -2
- data/lib/chef/resource/user/dscl_user.rb +1 -1
- data/lib/chef/resource/user/linux_user.rb +0 -2
- data/lib/chef/resource/user/mac_user.rb +1 -1
- data/lib/chef/resource/user/pw_user.rb +0 -2
- data/lib/chef/resource/user/solaris_user.rb +0 -2
- data/lib/chef/resource/user/windows_user.rb +0 -2
- data/lib/chef/resource/user_ulimit.rb +116 -0
- data/lib/chef/resource/whyrun_safe_ruby_block.rb +1 -0
- data/lib/chef/resource/windows_ad_join.rb +20 -7
- data/lib/chef/resource/windows_auto_run.rb +2 -3
- data/lib/chef/resource/windows_certificate.rb +3 -3
- data/lib/chef/resource/windows_dfs_folder.rb +1 -2
- data/lib/chef/resource/windows_dfs_namespace.rb +1 -2
- data/lib/chef/resource/windows_dfs_server.rb +2 -3
- data/lib/chef/resource/windows_dns_record.rb +0 -1
- data/lib/chef/resource/windows_dns_zone.rb +0 -1
- data/lib/chef/resource/windows_env.rb +12 -4
- data/lib/chef/resource/windows_feature.rb +59 -4
- data/lib/chef/resource/windows_feature_dism.rb +24 -24
- data/lib/chef/resource/windows_feature_powershell.rb +44 -78
- data/lib/chef/resource/windows_firewall_rule.rb +121 -8
- data/lib/chef/resource/windows_font.rb +10 -2
- data/lib/chef/resource/windows_package.rb +76 -7
- data/lib/chef/resource/windows_pagefile.rb +31 -4
- data/lib/chef/resource/windows_path.rb +18 -2
- data/lib/chef/resource/windows_printer.rb +26 -7
- data/lib/chef/resource/windows_printer_port.rb +29 -2
- data/lib/chef/resource/windows_script.rb +3 -4
- data/lib/chef/resource/windows_security_policy.rb +119 -0
- data/lib/chef/resource/windows_service.rb +46 -32
- data/lib/chef/resource/windows_share.rb +22 -6
- data/lib/chef/resource/windows_shortcut.rb +13 -3
- data/lib/chef/resource/windows_task.rb +129 -16
- data/lib/chef/resource/windows_uac.rb +20 -2
- data/lib/chef/resource/windows_user_privilege.rb +199 -0
- data/lib/chef/resource/windows_workgroup.rb +19 -4
- data/lib/chef/resource/yum_package.rb +91 -7
- data/lib/chef/resource/yum_repository.rb +30 -12
- data/lib/chef/resource/zypper_package.rb +32 -5
- data/lib/chef/resource/zypper_repository.rb +19 -6
- data/lib/chef/resource_builder.rb +8 -0
- data/lib/chef/resource_inspector.rb +3 -2
- data/lib/chef/resource_resolver.rb +7 -14
- data/lib/chef/resources.rb +11 -3
- data/lib/chef/run_context/cookbook_compiler.rb +29 -5
- data/lib/chef/scan_access_control.rb +1 -1
- data/lib/chef/shell.rb +22 -0
- data/lib/chef/shell/ext.rb +1 -1
- data/lib/chef/version.rb +1 -1
- data/lib/chef/win32/api.rb +2 -2
- data/lib/chef/win32/api/error.rb +3 -1
- data/lib/chef/win32/api/file.rb +1 -1
- data/lib/chef/win32/api/net.rb +1 -0
- data/lib/chef/win32/api/security.rb +6 -0
- data/lib/chef/win32/file.rb +1 -9
- data/lib/chef/win32/mutex.rb +1 -1
- data/lib/chef/win32/net.rb +1 -0
- data/lib/chef/win32/security.rb +40 -2
- data/lib/chef/win32/security/sid.rb +4 -4
- data/spec/functional/assets/inittest +8 -7
- data/spec/functional/knife/ssh_spec.rb +23 -19
- data/spec/functional/resource/cron_spec.rb +10 -29
- data/spec/functional/resource/dnf_package_spec.rb +441 -156
- data/spec/functional/resource/git_spec.rb +184 -134
- data/spec/functional/resource/insserv_spec.rb +1 -1
- data/spec/functional/resource/launchd_spec.rb +232 -0
- data/spec/functional/resource/link_spec.rb +3 -3
- data/spec/functional/resource/locale_spec.rb +13 -2
- data/spec/functional/resource/msu_package_spec.rb +5 -2
- data/spec/functional/resource/powershell_script_spec.rb +7 -68
- data/spec/functional/resource/remote_file_spec.rb +1 -1
- data/spec/functional/resource/windows_security_policy_spec.rb +90 -0
- data/spec/functional/resource/windows_task_spec.rb +4 -4
- data/spec/functional/resource/windows_user_privilege_spec.rb +193 -0
- data/spec/functional/run_lock_spec.rb +1 -1
- data/spec/functional/shell_spec.rb +1 -1
- data/spec/functional/util/powershell/cmdlet_spec.rb +1 -1
- data/spec/functional/version_spec.rb +1 -1
- data/spec/functional/win32/registry_spec.rb +0 -6
- data/spec/functional/win32/security_spec.rb +22 -0
- data/spec/integration/client/client_spec.rb +123 -2
- data/spec/integration/knife/cookbook_show_spec.rb +28 -26
- data/spec/integration/knife/data_bag_show_spec.rb +1 -1
- data/spec/integration/knife/raw_spec.rb +34 -6
- data/spec/integration/knife/redirection_spec.rb +2 -2
- data/spec/integration/knife/show_spec.rb +32 -3
- data/spec/integration/recipes/lwrp_inline_resources_spec.rb +3 -3
- data/spec/integration/recipes/noop_resource_spec.rb +1 -1
- data/spec/integration/recipes/notifies_spec.rb +49 -20
- data/spec/integration/recipes/notifying_block_spec.rb +8 -5
- data/spec/integration/recipes/provider_choice.rb +2 -0
- data/spec/integration/recipes/recipe_dsl_spec.rb +45 -143
- data/spec/integration/recipes/resource_action_spec.rb +16 -11
- data/spec/integration/recipes/resource_converge_if_changed_spec.rb +1 -1
- data/spec/integration/recipes/resource_load_spec.rb +133 -12
- data/spec/integration/recipes/use_partial_spec.rb +112 -0
- data/spec/integration/solo/solo_spec.rb +3 -3
- data/spec/spec_helper.rb +18 -3
- data/spec/support/chef_helpers.rb +2 -2
- data/spec/support/lib/chef/resource/zen_follower.rb +2 -0
- data/spec/support/platform_helpers.rb +2 -20
- data/spec/support/recipe_dsl_helper.rb +83 -0
- data/spec/support/shared/functional/http.rb +2 -2
- data/spec/support/shared/functional/windows_script.rb +3 -16
- data/spec/support/shared/integration/knife_support.rb +9 -6
- data/spec/support/shared/unit/mock_shellout.rb +1 -1
- data/spec/support/shared/unit/provider/useradd_based_user_provider.rb +4 -4
- data/spec/unit/application/apply_spec.rb +3 -0
- data/spec/unit/application/client_spec.rb +5 -1
- data/spec/unit/application_spec.rb +1 -2
- data/spec/unit/client_spec.rb +7 -5
- data/spec/unit/cookbook/gem_installer_spec.rb +2 -2
- data/spec/unit/cookbook/metadata_spec.rb +38 -19
- data/spec/unit/data_collector_spec.rb +39 -18
- data/spec/unit/file_access_control_spec.rb +1 -1
- data/spec/unit/json_compat_spec.rb +1 -1
- data/spec/unit/knife/bootstrap/chef_vault_handler_spec.rb +15 -15
- data/spec/unit/knife/bootstrap/client_builder_spec.rb +9 -9
- data/spec/unit/knife/bootstrap_spec.rb +20 -38
- data/spec/unit/knife/cookbook_show_spec.rb +1 -0
- data/spec/unit/knife/core/bootstrap_context_spec.rb +23 -43
- data/spec/unit/knife/core/ui_spec.rb +16 -0
- data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +9 -63
- data/spec/unit/knife/data_bag_secret_options_spec.rb +22 -14
- data/spec/unit/knife/ssh_spec.rb +8 -111
- data/spec/unit/knife/status_spec.rb +1 -1
- data/spec/unit/knife_spec.rb +18 -0
- data/spec/unit/mixin/openssl_helper_spec.rb +4 -4
- data/spec/unit/mixin/powershell_exec_spec.rb +10 -0
- data/spec/unit/mixin/shell_out_spec.rb +25 -31
- data/spec/unit/node/attribute_spec.rb +3 -3
- data/spec/unit/node_spec.rb +24 -0
- data/spec/unit/platform/query_helpers_spec.rb +0 -143
- data/spec/unit/property/state_spec.rb +12 -7
- data/spec/unit/property/validation_spec.rb +25 -1
- data/spec/unit/property_spec.rb +12 -9
- data/spec/unit/provider/apt_preference_spec.rb +14 -10
- data/spec/unit/provider/apt_repository_spec.rb +34 -36
- data/spec/unit/provider/apt_update_spec.rb +12 -11
- data/spec/unit/provider/cookbook_file_spec.rb +4 -4
- data/spec/unit/provider/cron_spec.rb +2 -2
- data/spec/unit/provider/directory_spec.rb +4 -15
- data/spec/unit/provider/file_spec.rb +4 -4
- data/spec/unit/provider/git_spec.rb +41 -1
- data/spec/unit/provider/group/groupadd_spec.rb +1 -1
- data/spec/unit/provider/launchd_spec.rb +8 -50
- data/spec/unit/provider/link_spec.rb +0 -1
- data/spec/unit/provider/log_spec.rb +3 -3
- data/spec/unit/provider/mdadm_spec.rb +3 -3
- data/spec/unit/provider/package/dnf/python_helper_spec.rb +1 -1
- data/spec/unit/provider/package/homebrew_spec.rb +280 -174
- data/spec/unit/provider/package/pacman_spec.rb +65 -147
- data/spec/unit/provider/package/portage_spec.rb +2 -2
- data/spec/unit/provider/package/powershell_spec.rb +3 -2
- data/spec/unit/provider/package/rubygems_spec.rb +211 -26
- data/spec/unit/provider/package/windows/exe_spec.rb +1 -1
- data/spec/unit/provider/powershell_script_spec.rb +21 -61
- data/spec/unit/provider/remote_file_spec.rb +3 -4
- data/spec/unit/provider/service/debian_service_spec.rb +34 -13
- data/spec/unit/provider/service/macosx_spec.rb +210 -214
- data/spec/unit/provider/service/systemd_service_spec.rb +23 -23
- data/spec/unit/provider/subversion_spec.rb +4 -2
- data/spec/unit/provider/template_spec.rb +3 -4
- data/spec/unit/provider/zypper_repository_spec.rb +17 -17
- data/spec/unit/provider_resolver_spec.rb +4 -4
- data/spec/unit/recipe_spec.rb +68 -0
- data/spec/unit/resource/alternatives_spec.rb +120 -0
- data/spec/unit/resource/apt_preference_spec.rb +0 -18
- data/spec/unit/resource/apt_repository_spec.rb +0 -18
- data/spec/unit/resource/apt_update_spec.rb +0 -18
- data/spec/unit/resource/chef_client_cron_spec.rb +119 -0
- data/spec/unit/resource/chef_client_scheduled_task_spec.rb +102 -0
- data/spec/unit/resource/chef_client_systemd_timer_spec.rb +70 -0
- data/spec/unit/resource/chef_vault_secret_spec.rb +40 -0
- data/spec/unit/resource/chocolatey_source_spec.rb +2 -1
- data/spec/unit/resource/cron_d_spec.rb +6 -48
- data/spec/unit/resource/cron_spec.rb +4 -10
- data/spec/unit/resource/gem_package_spec.rb +3 -3
- data/spec/unit/resource/helpers/cron_validations_spec.rb +77 -0
- data/spec/unit/resource/link_spec.rb +0 -4
- data/spec/unit/resource/locale_spec.rb +0 -34
- data/spec/unit/resource/msu_package_spec.rb +4 -0
- data/spec/unit/resource/ohai_spec.rb +56 -2
- data/spec/unit/resource/plist_spec.rb +130 -0
- data/spec/unit/resource/powershell_script_spec.rb +0 -5
- data/spec/unit/resource/{git_spec.rb → scm/git_spec.rb} +50 -2
- data/spec/unit/resource/{scm_spec.rb → scm/scm.rb} +1 -52
- data/spec/unit/resource/{subversion_spec.rb → scm/subversion_spec.rb} +2 -3
- data/spec/unit/resource/service_spec.rb +4 -0
- data/spec/unit/resource/user_spec.rb +2 -2
- data/spec/unit/resource/user_ulimit_spec.rb +53 -0
- data/spec/unit/resource/windows_feature_dism_spec.rb +2 -17
- data/spec/unit/resource/windows_feature_powershell_spec.rb +2 -17
- data/spec/unit/resource/windows_firewall_rule_spec.rb +88 -41
- data/spec/unit/resource/windows_package_spec.rb +14 -0
- data/spec/unit/resource/windows_service_spec.rb +9 -0
- data/spec/unit/resource_reporter_spec.rb +2 -6
- data/spec/unit/resource_spec.rb +10 -3
- data/spec/unit/run_lock_spec.rb +1 -1
- data/spec/unit/scan_access_control_spec.rb +1 -1
- data/spec/unit/search/query_spec.rb +1 -1
- data/spec/unit/win32/registry_spec.rb +1 -1
- data/tasks/rspec.rb +6 -14
- metadata +92 -37
- data/lib/chef/dsl/core.rb +0 -52
- data/lib/chef/knife/cookbook_site_share.rb +0 -41
- data/lib/chef/knife/cookbook_site_unshare.rb +0 -41
- data/lib/chef/provider/apt_preference.rb +0 -93
- data/lib/chef/provider/apt_repository.rb +0 -358
- data/lib/chef/provider/apt_update.rb +0 -79
- data/lib/chef/provider/log.rb +0 -43
- data/lib/chef/provider/mdadm.rb +0 -85
- data/lib/chef/provider/ohai.rb +0 -45
- data/lib/chef/resource/git.rb +0 -37
- data/spec/unit/provider/ohai_spec.rb +0 -84
@@ -0,0 +1,56 @@
|
|
1
|
+
#
|
2
|
+
# Author:: Steven Danna (steve@chef.io)
|
3
|
+
# Copyright:: Copyright (c) Chef Software Inc.
|
4
|
+
# License:: Apache License, Version 2.0
|
5
|
+
#
|
6
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
+
# you may not use this file except in compliance with the License.
|
8
|
+
# You may obtain a copy of the License at
|
9
|
+
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
+
#
|
12
|
+
# Unless required by applicable law or agreed to in writing, software
|
13
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
15
|
+
# See the License for the specific language governing permissions and
|
16
|
+
# limitations under the License.
|
17
|
+
#
|
18
|
+
|
19
|
+
require_relative "../knife"
|
20
|
+
|
21
|
+
class Chef
|
22
|
+
class Knife
|
23
|
+
class AclShow < Chef::Knife
|
24
|
+
category "acl"
|
25
|
+
banner "knife acl show OBJECT_TYPE OBJECT_NAME"
|
26
|
+
|
27
|
+
deps do
|
28
|
+
require_relative "acl_base"
|
29
|
+
include Chef::Knife::AclBase
|
30
|
+
end
|
31
|
+
|
32
|
+
def run
|
33
|
+
object_type, object_name = name_args
|
34
|
+
|
35
|
+
if name_args.length != 2
|
36
|
+
show_usage
|
37
|
+
ui.fatal "You must specify an object type and object name"
|
38
|
+
exit 1
|
39
|
+
end
|
40
|
+
|
41
|
+
validate_object_type!(object_type)
|
42
|
+
validate_object_name!(object_name)
|
43
|
+
acl = get_acl(object_type, object_name)
|
44
|
+
PERM_TYPES.each do |perm|
|
45
|
+
# Filter out the actors field if we have
|
46
|
+
# users and clients. Note that if one is present,
|
47
|
+
# both will be - but we're checking both for completeness.
|
48
|
+
if acl[perm].key?("users") && acl[perm].key?("clients")
|
49
|
+
acl[perm].delete "actors"
|
50
|
+
end
|
51
|
+
end
|
52
|
+
ui.output acl
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|
data/lib/chef/knife/bootstrap.rb
CHANGED
@@ -86,7 +86,6 @@ class Chef
|
|
86
86
|
short: "-w AUTH-METHOD",
|
87
87
|
long: "--winrm-auth-method AUTH-METHOD",
|
88
88
|
description: "The WinRM authentication method to use.",
|
89
|
-
proc: Proc.new { |protocol| Chef::Config[:knife][:winrm_auth_method] = protocol },
|
90
89
|
in: WINRM_AUTH_PROTOCOL_LIST
|
91
90
|
|
92
91
|
option :winrm_basic_auth_only,
|
@@ -95,36 +94,31 @@ class Chef
|
|
95
94
|
boolean: true
|
96
95
|
|
97
96
|
# This option was provided in knife bootstrap windows winrm,
|
98
|
-
# but it is ignored in knife-windows/WinrmSession, and so remains
|
97
|
+
# but it is ignored in knife-windows/WinrmSession, and so remains unimplemented here.
|
99
98
|
# option :kerberos_keytab_file,
|
100
99
|
# :short => "-T KEYTAB_FILE",
|
101
100
|
# :long => "--keytab-file KEYTAB_FILE",
|
102
|
-
# :description => "The Kerberos keytab file used for authentication"
|
103
|
-
# :proc => Proc.new { |keytab| Chef::Config[:knife][:kerberos_keytab_file] = keytab }
|
101
|
+
# :description => "The Kerberos keytab file used for authentication"
|
104
102
|
|
105
103
|
option :kerberos_realm,
|
106
104
|
short: "-R KERBEROS_REALM",
|
107
105
|
long: "--kerberos-realm KERBEROS_REALM",
|
108
|
-
description: "The Kerberos realm used for authentication."
|
109
|
-
proc: Proc.new { |protocol| Chef::Config[:knife][:kerberos_realm] = protocol }
|
106
|
+
description: "The Kerberos realm used for authentication."
|
110
107
|
|
111
108
|
option :kerberos_service,
|
112
109
|
short: "-S KERBEROS_SERVICE",
|
113
110
|
long: "--kerberos-service KERBEROS_SERVICE",
|
114
|
-
description: "The Kerberos service used for authentication."
|
115
|
-
proc: Proc.new { |protocol| Chef::Config[:knife][:kerberos_service] = protocol }
|
111
|
+
description: "The Kerberos service used for authentication."
|
116
112
|
|
117
113
|
## SSH Authentication
|
118
114
|
option :ssh_gateway,
|
119
115
|
short: "-G GATEWAY",
|
120
116
|
long: "--ssh-gateway GATEWAY",
|
121
|
-
description: "The SSH gateway."
|
122
|
-
proc: Proc.new { |key| Chef::Config[:knife][:ssh_gateway] = key }
|
117
|
+
description: "The SSH gateway."
|
123
118
|
|
124
119
|
option :ssh_gateway_identity,
|
125
120
|
long: "--ssh-gateway-identity SSH_GATEWAY_IDENTITY",
|
126
|
-
description: "The SSH identity file used for gateway authentication."
|
127
|
-
proc: Proc.new { |key| Chef::Config[:knife][:ssh_gateway_identity] = key }
|
121
|
+
description: "The SSH identity file used for gateway authentication."
|
128
122
|
|
129
123
|
option :ssh_forward_agent,
|
130
124
|
short: "-A",
|
@@ -140,7 +134,8 @@ class Chef
|
|
140
134
|
option :ssh_verify_host_key,
|
141
135
|
long: "--ssh-verify-host-key VALUE",
|
142
136
|
description: "Verify host key. Default is 'always'.",
|
143
|
-
in: %w{always accept_new accept_new_or_local_tunnel never}
|
137
|
+
in: %w{always accept_new accept_new_or_local_tunnel never},
|
138
|
+
default: "always"
|
144
139
|
|
145
140
|
#
|
146
141
|
# bootstrap options
|
@@ -160,8 +155,7 @@ class Chef
|
|
160
155
|
# client.rb content via chef-full/bootstrap_context
|
161
156
|
option :bootstrap_proxy,
|
162
157
|
long: "--bootstrap-proxy PROXY_URL",
|
163
|
-
description: "The proxy server for the node being bootstrapped."
|
164
|
-
proc: Proc.new { |p| Chef::Config[:knife][:bootstrap_proxy] = p }
|
158
|
+
description: "The proxy server for the node being bootstrapped."
|
165
159
|
|
166
160
|
# client.rb content via bootstrap_context
|
167
161
|
option :bootstrap_proxy_user,
|
@@ -176,8 +170,7 @@ class Chef
|
|
176
170
|
# client.rb content via bootstrap_context
|
177
171
|
option :bootstrap_no_proxy,
|
178
172
|
long: "--bootstrap-no-proxy [NO_PROXY_URL|NO_PROXY_IP]",
|
179
|
-
description: "Do not proxy locations for the node being bootstrapped"
|
180
|
-
proc: Proc.new { |np| Chef::Config[:knife][:bootstrap_no_proxy] = np }
|
173
|
+
description: "Do not proxy locations for the node being bootstrapped"
|
181
174
|
|
182
175
|
# client.rb content via bootstrap_context
|
183
176
|
option :bootstrap_template,
|
@@ -270,30 +263,24 @@ class Chef
|
|
270
263
|
proc: lambda { |o| Chef::JSONCompat.parse(File.read(o)) },
|
271
264
|
default: nil
|
272
265
|
|
273
|
-
# Note that several of the below options are used by bootstrap template,
|
274
|
-
# but only from the passed-in knife config; it does not use the
|
275
|
-
# config from the CLI for those values. We cannot always used the merged
|
276
|
-
# config, because in some cases the knife keys thIn those cases, the option
|
277
|
-
# will have a proc that assigns the value into Chef::Config[:knife]
|
278
|
-
|
279
266
|
# bootstrap template
|
280
267
|
# Create ohai hints in /etc/chef/ohai/hints, fname=hintname, content=value
|
281
|
-
option :
|
268
|
+
option :hints,
|
282
269
|
long: "--hint HINT_NAME[=HINT_FILE]",
|
283
270
|
description: "Specify an Ohai hint to be set on the bootstrap target. Use multiple --hint options to specify multiple hints.",
|
284
|
-
proc: Proc.new { |
|
285
|
-
|
286
|
-
name, path =
|
287
|
-
|
271
|
+
proc: Proc.new { |hint, accumulator|
|
272
|
+
accumulator ||= {}
|
273
|
+
name, path = hint.split("=", 2)
|
274
|
+
accumulator[name] = path ? Chef::JSONCompat.parse(::File.read(path)) : {}
|
275
|
+
accumulator
|
288
276
|
}
|
289
277
|
|
290
|
-
# bootstrap override: url of a an installer shell script
|
278
|
+
# bootstrap override: url of a an installer shell script to use in place of omnitruck
|
291
279
|
# Note that the bootstrap template _only_ references this out of Chef::Config, and not from
|
292
280
|
# the provided options to knife bootstrap, so we set the Chef::Config option here.
|
293
281
|
option :bootstrap_url,
|
294
282
|
long: "--bootstrap-url URL",
|
295
|
-
description: "URL to a custom installation script."
|
296
|
-
proc: Proc.new { |u| Chef::Config[:knife][:bootstrap_url] = u }
|
283
|
+
description: "URL to a custom installation script."
|
297
284
|
|
298
285
|
option :bootstrap_product,
|
299
286
|
long: "--bootstrap-product PRODUCT",
|
@@ -309,26 +296,22 @@ class Chef
|
|
309
296
|
# bootstrap override: Do this instead of our own setup.sh from omnitruck. Causes bootstrap_url to be ignored.
|
310
297
|
option :bootstrap_install_command,
|
311
298
|
long: "--bootstrap-install-command COMMANDS",
|
312
|
-
description: "Custom command to install #{Chef::Dist::PRODUCT}."
|
313
|
-
proc: Proc.new { |ic| Chef::Config[:knife][:bootstrap_install_command] = ic }
|
299
|
+
description: "Custom command to install #{Chef::Dist::PRODUCT}."
|
314
300
|
|
315
301
|
# bootstrap template: Run this command first in the bootstrap script
|
316
302
|
option :bootstrap_preinstall_command,
|
317
303
|
long: "--bootstrap-preinstall-command COMMANDS",
|
318
|
-
description: "Custom commands to run before installing #{Chef::Dist::PRODUCT}."
|
319
|
-
proc: Proc.new { |preic| Chef::Config[:knife][:bootstrap_preinstall_command] = preic }
|
304
|
+
description: "Custom commands to run before installing #{Chef::Dist::PRODUCT}."
|
320
305
|
|
321
306
|
# bootstrap template
|
322
307
|
option :bootstrap_wget_options,
|
323
308
|
long: "--bootstrap-wget-options OPTIONS",
|
324
|
-
description: "Add options to wget when installing #{Chef::Dist::PRODUCT}."
|
325
|
-
proc: Proc.new { |wo| Chef::Config[:knife][:bootstrap_wget_options] = wo }
|
309
|
+
description: "Add options to wget when installing #{Chef::Dist::PRODUCT}."
|
326
310
|
|
327
311
|
# bootstrap template
|
328
312
|
option :bootstrap_curl_options,
|
329
313
|
long: "--bootstrap-curl-options OPTIONS",
|
330
|
-
description: "Add options to curl when install #{Chef::Dist::PRODUCT}."
|
331
|
-
proc: Proc.new { |co| Chef::Config[:knife][:bootstrap_curl_options] = co }
|
314
|
+
description: "Add options to curl when install #{Chef::Dist::PRODUCT}."
|
332
315
|
|
333
316
|
# chef_vault_handler
|
334
317
|
option :bootstrap_vault_file,
|
@@ -344,12 +327,12 @@ class Chef
|
|
344
327
|
option :bootstrap_vault_item,
|
345
328
|
long: "--bootstrap-vault-item VAULT_ITEM",
|
346
329
|
description: 'A single vault and item to update as "vault:item".',
|
347
|
-
proc: Proc.new { |i|
|
330
|
+
proc: Proc.new { |i, accumulator|
|
348
331
|
(vault, item) = i.split(/:/)
|
349
|
-
|
350
|
-
|
351
|
-
|
352
|
-
|
332
|
+
accumulator ||= {}
|
333
|
+
accumulator[vault] ||= []
|
334
|
+
accumulator[vault].push(item)
|
335
|
+
accumulator
|
353
336
|
}
|
354
337
|
|
355
338
|
# Deprecated options. These must be declared after
|
@@ -434,14 +417,14 @@ class Chef
|
|
434
417
|
def client_builder
|
435
418
|
@client_builder ||= Chef::Knife::Bootstrap::ClientBuilder.new(
|
436
419
|
chef_config: Chef::Config,
|
437
|
-
|
420
|
+
config: config,
|
438
421
|
ui: ui
|
439
422
|
)
|
440
423
|
end
|
441
424
|
|
442
425
|
def chef_vault_handler
|
443
426
|
@chef_vault_handler ||= Chef::Knife::Bootstrap::ChefVaultHandler.new(
|
444
|
-
|
427
|
+
config: config,
|
445
428
|
ui: ui
|
446
429
|
)
|
447
430
|
end
|
@@ -466,7 +449,7 @@ class Chef
|
|
466
449
|
# @return [String] Default bootstrap template
|
467
450
|
def default_bootstrap_template
|
468
451
|
if connection.windows?
|
469
|
-
"windows
|
452
|
+
"windows-chef-client-msi"
|
470
453
|
else
|
471
454
|
"chef-full"
|
472
455
|
end
|
@@ -686,9 +669,8 @@ class Chef
|
|
686
669
|
return @connection_protocol if @connection_protocol
|
687
670
|
|
688
671
|
from_url = host_descriptor =~ %r{^(.*)://} ? $1 : nil
|
689
|
-
|
690
|
-
|
691
|
-
@connection_protocol = from_url || from_cli || from_knife || "ssh"
|
672
|
+
from_knife = config[:connection_protocol]
|
673
|
+
@connection_protocol = from_url || from_knife || "ssh"
|
692
674
|
end
|
693
675
|
|
694
676
|
def do_connect(conn_options)
|
@@ -724,16 +706,20 @@ class Chef
|
|
724
706
|
true
|
725
707
|
end
|
726
708
|
|
709
|
+
def winrm_auth_method
|
710
|
+
config_value(:winrm_auth_method, :winrm_authentication_protocol, "negotiate")
|
711
|
+
end
|
712
|
+
|
727
713
|
# Fail if using plaintext auth without ssl because
|
728
714
|
# this can expose keys in plaintext on the wire.
|
729
715
|
# TODO test for this method
|
730
|
-
# TODO check that the
|
716
|
+
# TODO check that the protocol is valid.
|
731
717
|
def validate_winrm_transport_opts!
|
732
718
|
return true unless winrm?
|
733
719
|
|
734
720
|
if Chef::Config[:validation_key] && !File.exist?(File.expand_path(Chef::Config[:validation_key]))
|
735
|
-
if
|
736
|
-
|
721
|
+
if winrm_auth_method == "plaintext" &&
|
722
|
+
config[:winrm_ssl] != true
|
737
723
|
ui.error <<~EOM
|
738
724
|
Validatorless bootstrap over unsecure winrm channels could expose your
|
739
725
|
key to network sniffing.
|
@@ -857,9 +843,9 @@ class Chef
|
|
857
843
|
# Reference:
|
858
844
|
# https://github.com/chef/knife-windows/blob/92d151298142be4a4750c5b54bb264f8d5b81b8a/lib/chef/knife/winrm_knife_base.rb#L271-L273
|
859
845
|
# TODO Seems like we should also do a similar warning if ssh_verify_host == false
|
860
|
-
if
|
861
|
-
|
862
|
-
|
846
|
+
if config[:ca_trust_file].nil? &&
|
847
|
+
config[:winrm_no_verify_cert] &&
|
848
|
+
config[:winrm_ssl_peer_fingerprint].nil?
|
863
849
|
ui.warn <<~WARN
|
864
850
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
865
851
|
SSL validation of HTTPS requests for the WinRM transport is disabled.
|
@@ -905,16 +891,13 @@ class Chef
|
|
905
891
|
|
906
892
|
# Common configuration for all protocols
|
907
893
|
def base_opts
|
908
|
-
port =
|
909
|
-
|
910
|
-
user = config_value(:connection_user,
|
911
|
-
knife_key_for_protocol(connection_protocol, :user))
|
894
|
+
port = config_for_protocol(:port)
|
895
|
+
user = config_for_protocol(:user)
|
912
896
|
{}.tap do |opts|
|
913
897
|
opts[:logger] = Chef::Log
|
914
|
-
# We do not store password in Chef::Config, so only use CLI `config` here
|
915
898
|
opts[:password] = config[:connection_password] if config.key?(:connection_password)
|
916
899
|
opts[:user] = user if user
|
917
|
-
opts[:max_wait_until_ready] =
|
900
|
+
opts[:max_wait_until_ready] = config[:max_wait].to_f unless config[:max_wait].nil?
|
918
901
|
# TODO - when would we need to provide rdp_port vs port? Or are they not mutually exclusive?
|
919
902
|
opts[:port] = port if port
|
920
903
|
end
|
@@ -922,7 +905,7 @@ class Chef
|
|
922
905
|
|
923
906
|
def host_verify_opts
|
924
907
|
if winrm?
|
925
|
-
{ self_signed:
|
908
|
+
{ self_signed: config[:winrm_no_verify_cert] === true }
|
926
909
|
elsif ssh?
|
927
910
|
# Fall back to the old knife config key name for back compat.
|
928
911
|
{ verify_host_key: config_value(:ssh_verify_host_key, :host_key_verify, "always") }
|
@@ -936,7 +919,7 @@ class Chef
|
|
936
919
|
return opts if winrm?
|
937
920
|
|
938
921
|
opts[:non_interactive] = true # Prevent password prompts from underlying net/ssh
|
939
|
-
opts[:forward_agent] = (
|
922
|
+
opts[:forward_agent] = (config[:ssh_forward_agent] === true)
|
940
923
|
opts[:connection_timeout] = session_timeout
|
941
924
|
opts
|
942
925
|
end
|
@@ -945,7 +928,7 @@ class Chef
|
|
945
928
|
opts = {}
|
946
929
|
return opts if winrm?
|
947
930
|
|
948
|
-
identity_file =
|
931
|
+
identity_file = config[:ssh_identity_file]
|
949
932
|
if identity_file
|
950
933
|
opts[:key_files] = [identity_file]
|
951
934
|
# We only set keys_only based on the explicit ssh_identity_file;
|
@@ -965,7 +948,7 @@ class Chef
|
|
965
948
|
opts[:keys_only] = false
|
966
949
|
end
|
967
950
|
|
968
|
-
gateway_identity_file =
|
951
|
+
gateway_identity_file = config[:ssh_gateway] ? config[:ssh_gateway_identity] : nil
|
969
952
|
unless gateway_identity_file.nil?
|
970
953
|
opts[:key_files] << gateway_identity_file
|
971
954
|
end
|
@@ -975,8 +958,8 @@ class Chef
|
|
975
958
|
|
976
959
|
def gateway_opts
|
977
960
|
opts = {}
|
978
|
-
if
|
979
|
-
split =
|
961
|
+
if config[:ssh_gateway]
|
962
|
+
split = config[:ssh_gateway].split("@", 2)
|
980
963
|
if split.length == 1
|
981
964
|
gw_host = split[0]
|
982
965
|
else
|
@@ -984,7 +967,7 @@ class Chef
|
|
984
967
|
gw_host = split[1]
|
985
968
|
end
|
986
969
|
gw_host, gw_port = gw_host.split(":", 2)
|
987
|
-
# TODO - validate
|
970
|
+
# TODO - validate convertible port in config validation?
|
988
971
|
gw_port = Integer(gw_port) rescue nil
|
989
972
|
opts[:bastion_host] = gw_host
|
990
973
|
opts[:bastion_user] = gw_user
|
@@ -1022,21 +1005,20 @@ class Chef
|
|
1022
1005
|
def winrm_opts
|
1023
1006
|
return {} unless winrm?
|
1024
1007
|
|
1025
|
-
auth_method = config_value(:winrm_auth_method, :winrm_auth_method, "negotiate")
|
1026
1008
|
opts = {
|
1027
|
-
winrm_transport:
|
1028
|
-
winrm_basic_auth_only:
|
1029
|
-
ssl:
|
1030
|
-
ssl_peer_fingerprint:
|
1009
|
+
winrm_transport: winrm_auth_method, # winrm gem and train calls auth method 'transport'
|
1010
|
+
winrm_basic_auth_only: config[:winrm_basic_auth_only] || false,
|
1011
|
+
ssl: config[:winrm_ssl] === true,
|
1012
|
+
ssl_peer_fingerprint: config[:winrm_ssl_peer_fingerprint],
|
1031
1013
|
}
|
1032
1014
|
|
1033
|
-
if
|
1034
|
-
opts[:kerberos_service] =
|
1035
|
-
opts[:kerberos_realm] =
|
1015
|
+
if winrm_auth_method == "kerberos"
|
1016
|
+
opts[:kerberos_service] = config[:kerberos_service] if config[:kerberos_service]
|
1017
|
+
opts[:kerberos_realm] = config[:kerberos_realm] if config[:kerberos_service]
|
1036
1018
|
end
|
1037
1019
|
|
1038
|
-
if
|
1039
|
-
opts[:ca_trust_path] =
|
1020
|
+
if config[:ca_trust_file]
|
1021
|
+
opts[:ca_trust_path] = config[:ca_trust_file]
|
1040
1022
|
end
|
1041
1023
|
|
1042
1024
|
opts[:operation_timeout] = session_timeout
|
@@ -1061,17 +1043,18 @@ class Chef
|
|
1061
1043
|
}
|
1062
1044
|
end
|
1063
1045
|
|
1064
|
-
#
|
1065
|
-
#
|
1066
|
-
#
|
1046
|
+
# This is for deprecating config options. The fallback_key can be used
|
1047
|
+
# to pull an old knife config option out of the config file when the
|
1048
|
+
# cli value has been renamed. This is different from the deprecated
|
1049
|
+
# cli values, since these are for config options that have no corresponding
|
1050
|
+
# cli value.
|
1067
1051
|
#
|
1068
|
-
#
|
1069
|
-
# config_value(:whatver) should be converted to config[:whatever]. That never had
|
1070
|
-
# any purpose and never should have been used this way.
|
1052
|
+
# DO NOT USE - this whole API is considered deprecated
|
1071
1053
|
#
|
1072
1054
|
# @api deprecated
|
1073
1055
|
#
|
1074
1056
|
def config_value(key, fallback_key = nil, default = nil)
|
1057
|
+
Chef.deprecated(:knife_bootstrap_apis, "Use of config_value without a fallback_key is deprecated. Knife plugin authors should access the config hash directly, which does correct merging of cli and config options.") if fallback_key.nil?
|
1075
1058
|
if config.key?(key)
|
1076
1059
|
# the first key is the primary key so we check the merged hash first
|
1077
1060
|
config[key]
|
@@ -1090,7 +1073,7 @@ class Chef
|
|
1090
1073
|
remote_path
|
1091
1074
|
end
|
1092
1075
|
|
1093
|
-
# build the command string for
|
1076
|
+
# build the command string for bootstrapping
|
1094
1077
|
# @return String
|
1095
1078
|
def bootstrap_command(remote_path)
|
1096
1079
|
if connection.windows?
|
@@ -1100,6 +1083,8 @@ class Chef
|
|
1100
1083
|
end
|
1101
1084
|
end
|
1102
1085
|
|
1086
|
+
private
|
1087
|
+
|
1103
1088
|
# To avoid cluttering the CLI options, some flags (such as port and user)
|
1104
1089
|
# are shared between protocols. However, there is still a need to allow the operator
|
1105
1090
|
# to specify defaults separately, since they may not be the same values for different
|
@@ -1108,11 +1093,20 @@ class Chef
|
|
1108
1093
|
# These keys are available in Chef::Config, and are prefixed with the protocol name.
|
1109
1094
|
# For example, :user CLI option will map to :winrm_user and :ssh_user Chef::Config keys,
|
1110
1095
|
# based on the connection protocol in use.
|
1111
|
-
|
1112
|
-
|
1096
|
+
|
1097
|
+
# @api private
|
1098
|
+
def config_for_protocol(option)
|
1099
|
+
if option == :port
|
1100
|
+
config[:connection_port] || config[knife_key_for_protocol(option)]
|
1101
|
+
else
|
1102
|
+
config[:connection_user] || config[knife_key_for_protocol(option)]
|
1103
|
+
end
|
1113
1104
|
end
|
1114
1105
|
|
1115
|
-
private
|
1106
|
+
# @api private
|
1107
|
+
def knife_key_for_protocol(option)
|
1108
|
+
"#{connection_protocol}_#{option}".to_sym
|
1109
|
+
end
|
1116
1110
|
|
1117
1111
|
# True if policy_name and run_list are both given
|
1118
1112
|
def policyfile_and_run_list_given?
|
@@ -1135,7 +1129,7 @@ class Chef
|
|
1135
1129
|
# session_timeout option has a default that may not arrive, particularly if
|
1136
1130
|
# we're being invoked from a plugin that doesn't merge_config.
|
1137
1131
|
def session_timeout
|
1138
|
-
timeout =
|
1132
|
+
timeout = config[:session_timeout]
|
1139
1133
|
return options[:session_timeout][:default] if timeout.nil?
|
1140
1134
|
|
1141
1135
|
timeout.to_i
|