chef 15.17.4-universal-mingw32 → 16.0.257-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 +14 -20
- data/README.md +6 -6
- data/Rakefile +18 -23
- data/chef-universal-mingw32.gemspec +4 -4
- data/chef.gemspec +10 -26
- 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/api_client/registration.rb +2 -2
- data/lib/chef/application.rb +33 -54
- data/lib/chef/application/apply.rb +20 -3
- data/lib/chef/application/base.rb +8 -3
- data/lib/chef/application/exit_code.rb +2 -2
- data/lib/chef/application/knife.rb +1 -1
- data/lib/chef/chef_class.rb +4 -4
- data/lib/chef/chef_fs/chef_fs_data_store.rb +3 -3
- data/lib/chef/chef_fs/file_system/chef_server/policies_dir.rb +1 -1
- data/lib/chef/chef_fs/file_system/chef_server/rest_list_dir.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/multiplexed_dir.rb +1 -1
- data/lib/chef/chef_fs/file_system/repository/base_file.rb +0 -1
- 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 +5 -5
- 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/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_version.rb +40 -5
- data/lib/chef/data_bag.rb +2 -2
- data/lib/chef/data_collector/error_handlers.rb +1 -1
- data/lib/chef/data_collector/run_end_message.rb +7 -1
- data/lib/chef/deprecated.rb +1 -9
- 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 +2 -3
- data/lib/chef/dsl/recipe.rb +7 -12
- data/lib/chef/dsl/universal.rb +3 -7
- data/lib/chef/environment.rb +2 -2
- data/lib/chef/event_dispatch/base.rb +3 -0
- data/lib/chef/exceptions.rb +0 -3
- data/lib/chef/formatters/doc.rb +1 -1
- data/lib/chef/formatters/error_inspectors/node_load_error_inspector.rb +2 -2
- data/lib/chef/formatters/error_inspectors/registration_error_inspector.rb +7 -7
- data/lib/chef/formatters/indentable_output_stream.rb +7 -16
- data/lib/chef/http.rb +1 -2
- data/lib/chef/http/http_request.rb +3 -2
- data/lib/chef/knife.rb +1 -3
- 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 +93 -97
- data/lib/chef/knife/bootstrap/chef_vault_handler.rb +1 -1
- data/lib/chef/knife/bootstrap/client_builder.rb +1 -1
- data/lib/chef/knife/bootstrap/templates/chef-full.erb +20 -20
- data/lib/chef/knife/bootstrap/templates/windows-chef-client-msi.erb +13 -15
- data/lib/chef/knife/bootstrap/train_connector.rb +0 -1
- data/lib/chef/knife/cookbook_download.rb +1 -1
- data/lib/chef/knife/cookbook_metadata.rb +1 -1
- data/lib/chef/knife/core/bootstrap_context.rb +63 -60
- data/lib/chef/knife/core/gem_glob_loader.rb +1 -1
- data/lib/chef/knife/core/generic_presenter.rb +4 -3
- data/lib/chef/knife/core/hashed_command_loader.rb +2 -3
- 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 +45 -58
- data/lib/chef/knife/data_bag_secret_options.rb +18 -45
- data/lib/chef/knife/environment_compare.rb +1 -1
- data/lib/chef/knife/exec.rb +2 -2
- 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/list.rb +1 -1
- data/lib/chef/knife/ssh.rb +12 -50
- data/lib/chef/knife/status.rb +3 -3
- data/lib/chef/knife/supermarket_download.rb +1 -2
- data/lib/chef/knife/supermarket_install.rb +1 -2
- 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_recind.rb +63 -0
- data/lib/chef/knife/yaml_convert.rb +91 -0
- data/lib/chef/log.rb +1 -1
- data/lib/chef/mixin/create_path.rb +8 -8
- data/lib/chef/mixin/openssl_helper.rb +3 -26
- data/lib/chef/mixin/powershell_exec.rb +10 -1
- data/lib/chef/mixin/powershell_out.rb +1 -1
- data/lib/chef/mixin/properties.rb +13 -1
- data/lib/chef/mixin/shell_out.rb +0 -4
- data/lib/chef/mixin/template.rb +0 -1
- data/lib/chef/monkey_patches/net_http.rb +0 -4
- data/lib/chef/node.rb +18 -6
- data/lib/chef/node/mixin/deep_merge_cache.rb +7 -7
- 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 +7 -36
- data/lib/chef/platform/priority_map.rb +4 -4
- data/lib/chef/platform/query_helpers.rb +6 -34
- data/lib/chef/powershell.rb +14 -0
- data/lib/chef/property.rb +22 -4
- data/lib/chef/provider.rb +40 -6
- data/lib/chef/provider/cron.rb +2 -2
- data/lib/chef/provider/directory.rb +2 -2
- data/lib/chef/provider/dsc_resource.rb +1 -1
- data/lib/chef/provider/dsc_script.rb +1 -1
- data/lib/chef/provider/execute.rb +2 -8
- data/lib/chef/provider/file.rb +5 -5
- 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 +36 -51
- data/lib/chef/provider/link.rb +2 -2
- data/lib/chef/provider/mount.rb +5 -5
- data/lib/chef/provider/mount/solaris.rb +1 -0
- data/lib/chef/provider/osx_profile.rb +7 -3
- data/lib/chef/provider/package.rb +2 -2
- data/lib/chef/provider/package/cab.rb +3 -4
- 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 +84 -30
- 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/freebsd/pkgng.rb +1 -3
- data/lib/chef/provider/package/homebrew.rb +106 -42
- data/lib/chef/provider/package/msu.rb +3 -1
- data/lib/chef/provider/package/pacman.rb +25 -34
- data/lib/chef/provider/package/powershell.rb +2 -6
- data/lib/chef/provider/package/rubygems.rb +29 -2
- data/lib/chef/provider/package/snap.rb +27 -96
- data/lib/chef/provider/package/windows.rb +3 -2
- data/lib/chef/provider/package/windows/msi.rb +2 -2
- data/lib/chef/provider/package/yum.rb +0 -8
- data/lib/chef/provider/package/yum/yum_helper.py +0 -4
- data/lib/chef/provider/package/zypper.rb +1 -1
- data/lib/chef/provider/powershell_script.rb +4 -10
- data/lib/chef/provider/registry_key.rb +4 -4
- data/lib/chef/provider/remote_directory.rb +3 -3
- 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 +2 -2
- data/lib/chef/provider/service/debian.rb +31 -29
- data/lib/chef/provider/service/gentoo.rb +2 -2
- data/lib/chef/provider/service/macosx.rb +7 -12
- data/lib/chef/provider/service/openbsd.rb +1 -1
- data/lib/chef/provider/service/redhat.rb +2 -2
- data/lib/chef/provider/service/simple.rb +3 -3
- 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/dscl.rb +3 -3
- data/lib/chef/provider/user/mac.rb +10 -9
- 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 +7 -9
- data/lib/chef/provider/yum_repository.rb +1 -1
- data/lib/chef/provider/zypper_repository.rb +11 -31
- data/lib/chef/providers.rb +0 -6
- data/lib/chef/recipe.rb +36 -0
- data/lib/chef/resource.rb +41 -56
- data/lib/chef/resource/action_class.rb +24 -22
- data/lib/chef/resource/alternatives.rb +149 -0
- data/lib/chef/resource/apt_package.rb +2 -1
- data/lib/chef/resource/apt_preference.rb +69 -2
- data/lib/chef/resource/apt_repository.rb +337 -5
- data/lib/chef/resource/apt_update.rb +52 -1
- data/lib/chef/resource/archive_file.rb +9 -29
- data/lib/chef/resource/bash.rb +2 -0
- data/lib/chef/resource/bff_package.rb +9 -1
- data/lib/chef/resource/breakpoint.rb +0 -1
- data/lib/chef/resource/build_essential.rb +42 -48
- data/lib/chef/resource/cab_package.rb +8 -1
- data/lib/chef/resource/chef_client_cron.rb +225 -0
- data/lib/chef/resource/chef_client_scheduled_task.rb +198 -0
- data/lib/chef/resource/chef_client_systemd_timer.rb +177 -0
- data/lib/chef/resource/chef_gem.rb +9 -16
- data/lib/chef/resource/chef_handler.rb +2 -1
- data/lib/chef/resource/chef_sleep.rb +0 -1
- data/lib/chef/resource/chef_vault_secret.rb +135 -0
- data/lib/chef/resource/chocolatey_config.rb +3 -1
- data/lib/chef/resource/chocolatey_feature.rb +2 -1
- data/lib/chef/resource/chocolatey_package.rb +2 -1
- data/lib/chef/resource/chocolatey_source.rb +2 -1
- data/lib/chef/resource/cookbook_file.rb +1 -1
- data/lib/chef/resource/cron.rb +22 -68
- data/lib/chef/resource/cron_access.rb +8 -15
- data/lib/chef/resource/cron_d.rb +9 -75
- data/lib/chef/resource/csh.rb +2 -0
- data/lib/chef/resource/directory.rb +2 -2
- data/lib/chef/resource/dmg_package.rb +4 -4
- data/lib/chef/resource/dnf_package.rb +2 -3
- data/lib/chef/resource/dpkg_package.rb +2 -1
- data/lib/chef/resource/dsc_resource.rb +6 -4
- data/lib/chef/resource/dsc_script.rb +3 -2
- data/lib/chef/resource/execute.rb +13 -12
- data/lib/chef/resource/file.rb +3 -1
- data/lib/chef/resource/freebsd_package.rb +2 -1
- data/lib/chef/resource/gem_package.rb +14 -6
- data/lib/chef/resource/group.rb +4 -1
- data/lib/chef/resource/helpers/cron_validations.rb +98 -0
- data/lib/chef/resource/homebrew_cask.rb +5 -4
- data/lib/chef/resource/homebrew_package.rb +4 -2
- data/lib/chef/resource/homebrew_tap.rb +2 -1
- data/lib/chef/resource/hostname.rb +41 -36
- data/lib/chef/resource/http_request.rb +0 -1
- data/lib/chef/resource/ifconfig.rb +1 -1
- data/lib/chef/resource/ips_package.rb +10 -2
- data/lib/chef/resource/kernel_module.rb +29 -29
- data/lib/chef/resource/ksh.rb +2 -0
- data/lib/chef/resource/launchd.rb +6 -6
- data/lib/chef/resource/link.rb +1 -23
- data/lib/chef/resource/locale.rb +58 -24
- data/lib/chef/resource/log.rb +12 -1
- data/lib/chef/resource/lwrp_base.rb +1 -8
- data/lib/chef/resource/macos_userdefaults.rb +9 -6
- data/lib/chef/resource/macosx_service.rb +2 -1
- data/lib/chef/resource/macports_package.rb +10 -2
- data/lib/chef/resource/mdadm.rb +62 -2
- data/lib/chef/resource/mount.rb +3 -0
- data/lib/chef/resource/msu_package.rb +13 -1
- data/lib/chef/resource/notify_group.rb +8 -3
- data/lib/chef/resource/ohai.rb +19 -3
- data/lib/chef/resource/ohai_hint.rb +3 -12
- data/lib/chef/resource/openbsd_package.rb +9 -1
- data/lib/chef/resource/openssl_dhparam.rb +10 -1
- data/lib/chef/resource/openssl_ec_private_key.rb +23 -1
- data/lib/chef/resource/openssl_ec_public_key.rb +21 -1
- data/lib/chef/resource/openssl_rsa_private_key.rb +20 -1
- data/lib/chef/resource/openssl_rsa_public_key.rb +22 -1
- data/lib/chef/resource/openssl_x509_certificate.rb +37 -1
- data/lib/chef/resource/openssl_x509_crl.rb +12 -1
- data/lib/chef/resource/openssl_x509_request.rb +37 -1
- data/lib/chef/resource/osx_profile.rb +3 -2
- data/lib/chef/resource/package.rb +2 -1
- data/lib/chef/resource/pacman_package.rb +2 -1
- data/lib/chef/resource/paludis_package.rb +12 -3
- data/lib/chef/resource/perl.rb +2 -0
- data/lib/chef/resource/plist.rb +207 -0
- data/lib/chef/resource/portage_package.rb +13 -3
- data/lib/chef/resource/powershell_package.rb +1 -3
- data/lib/chef/resource/powershell_package_source.rb +3 -1
- data/lib/chef/resource/powershell_script.rb +7 -17
- data/lib/chef/resource/python.rb +2 -0
- data/lib/chef/resource/reboot.rb +0 -1
- data/lib/chef/resource/registry_key.rb +1 -2
- data/lib/chef/resource/remote_directory.rb +2 -0
- data/lib/chef/resource/remote_file.rb +2 -0
- data/lib/chef/resource/rhsm_errata.rb +0 -1
- data/lib/chef/resource/rhsm_errata_level.rb +0 -1
- data/lib/chef/resource/rhsm_register.rb +2 -1
- data/lib/chef/resource/rhsm_repo.rb +3 -1
- data/lib/chef/resource/rhsm_subscription.rb +4 -1
- data/lib/chef/resource/route.rb +5 -1
- data/lib/chef/resource/rpm_package.rb +9 -2
- data/lib/chef/resource/ruby.rb +2 -0
- data/lib/chef/resource/ruby_block.rb +1 -1
- data/lib/chef/resource/scm/_scm.rb +48 -0
- data/lib/chef/resource/{scm.rb → scm/git.rb} +16 -30
- data/lib/chef/resource/{subversion.rb → scm/subversion.rb} +8 -5
- data/lib/chef/resource/script.rb +6 -3
- data/lib/chef/resource/service.rb +6 -7
- data/lib/chef/resource/smartos_package.rb +9 -1
- data/lib/chef/resource/snap_package.rb +3 -1
- data/lib/chef/resource/solaris_package.rb +9 -1
- data/lib/chef/resource/ssh_known_hosts_entry.rb +6 -3
- data/lib/chef/resource/sudo.rb +9 -9
- 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 +5 -3
- data/lib/chef/resource/sysctl.rb +2 -2
- data/lib/chef/resource/systemd_unit.rb +4 -2
- data/lib/chef/resource/template.rb +0 -1
- data/lib/chef/resource/timezone.rb +7 -18
- data/lib/chef/resource/user.rb +1 -3
- 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 +114 -0
- data/lib/chef/resource/whyrun_safe_ruby_block.rb +1 -0
- data/lib/chef/resource/windows_ad_join.rb +19 -6
- data/lib/chef/resource/windows_auto_run.rb +0 -1
- data/lib/chef/resource/windows_certificate.rb +1 -1
- data/lib/chef/resource/windows_dfs_folder.rb +0 -1
- data/lib/chef/resource/windows_dfs_namespace.rb +0 -1
- data/lib/chef/resource/windows_dfs_server.rb +0 -1
- 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 +2 -3
- data/lib/chef/resource/windows_feature.rb +2 -2
- data/lib/chef/resource/windows_feature_dism.rb +9 -22
- data/lib/chef/resource/windows_feature_powershell.rb +17 -82
- data/lib/chef/resource/windows_firewall_rule.rb +119 -10
- data/lib/chef/resource/windows_font.rb +1 -3
- data/lib/chef/resource/windows_package.rb +13 -4
- data/lib/chef/resource/windows_pagefile.rb +0 -1
- data/lib/chef/resource/windows_path.rb +0 -1
- data/lib/chef/resource/windows_printer.rb +0 -1
- data/lib/chef/resource/windows_printer_port.rb +0 -1
- data/lib/chef/resource/windows_script.rb +3 -4
- data/lib/chef/resource/windows_security_policy.rb +90 -0
- data/lib/chef/resource/windows_service.rb +45 -31
- data/lib/chef/resource/windows_share.rb +3 -7
- data/lib/chef/resource/windows_shortcut.rb +0 -1
- data/lib/chef/resource/windows_task.rb +14 -15
- data/lib/chef/resource/windows_uac.rb +0 -1
- data/lib/chef/resource/windows_user_privilege.rb +157 -0
- data/lib/chef/resource/windows_workgroup.rb +0 -1
- data/lib/chef/resource/yum_package.rb +3 -1
- data/lib/chef/resource/yum_repository.rb +2 -1
- data/lib/chef/resource/zypper_package.rb +3 -2
- data/lib/chef/resource/zypper_repository.rb +2 -1
- data/lib/chef/resource_builder.rb +8 -0
- data/lib/chef/resource_inspector.rb +6 -6
- data/lib/chef/resource_resolver.rb +7 -14
- data/lib/chef/resources.rb +11 -3
- data/lib/chef/role.rb +2 -2
- data/lib/chef/run_context/cookbook_compiler.rb +29 -5
- data/lib/chef/shell.rb +23 -32
- data/lib/chef/shell/shell_session.rb +0 -2
- data/lib/chef/util/diff.rb +1 -1
- data/lib/chef/util/dsc/configuration_generator.rb +1 -1
- data/lib/chef/util/dsc/lcm_output_parser.rb +3 -3
- data/lib/chef/util/powershell/cmdlet.rb +1 -1
- data/lib/chef/version.rb +2 -2
- data/lib/chef/version_string.rb +1 -1
- data/lib/chef/win32/api/file.rb +18 -18
- data/lib/chef/win32/api/security.rb +6 -0
- data/lib/chef/win32/file.rb +3 -11
- data/lib/chef/win32/process.rb +2 -2
- data/lib/chef/win32/security.rb +40 -2
- data/spec/functional/assets/inittest +8 -7
- data/spec/functional/knife/ssh_spec.rb +27 -23
- data/spec/functional/resource/aix_service_spec.rb +1 -0
- data/spec/functional/resource/aixinit_service_spec.rb +8 -7
- data/spec/functional/resource/apt_package_spec.rb +1 -0
- data/spec/functional/resource/bff_spec.rb +2 -2
- data/spec/functional/resource/cookbook_file_spec.rb +1 -1
- data/spec/functional/resource/cron_spec.rb +11 -29
- data/spec/functional/resource/dnf_package_spec.rb +441 -156
- data/spec/functional/resource/dsc_resource_spec.rb +1 -1
- data/spec/functional/resource/git_spec.rb +184 -134
- data/spec/functional/resource/insserv_spec.rb +6 -5
- data/spec/functional/resource/link_spec.rb +17 -17
- data/spec/functional/resource/locale_spec.rb +13 -2
- data/spec/functional/resource/powershell_script_spec.rb +7 -68
- data/spec/functional/resource/rpm_spec.rb +2 -2
- data/spec/functional/resource/user/dscl_spec.rb +2 -2
- data/spec/functional/resource/user/mac_user_spec.rb +2 -2
- data/spec/functional/resource/windows_certificate_spec.rb +3 -3
- data/spec/functional/resource/windows_security_policy_spec.rb +90 -0
- data/spec/functional/resource/windows_task_spec.rb +8 -8
- data/spec/functional/resource/windows_user_privilege_spec.rb +193 -0
- data/spec/functional/run_lock_spec.rb +1 -2
- data/spec/functional/shell_spec.rb +6 -6
- 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/functional/win32/service_manager_spec.rb +1 -1
- 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 +30 -2
- data/spec/integration/knife/show_spec.rb +32 -3
- data/spec/integration/recipes/accumulator_spec.rb +1 -1
- data/spec/integration/recipes/lwrp_inline_resources_spec.rb +5 -5
- data/spec/integration/recipes/lwrp_spec.rb +1 -1
- data/spec/integration/recipes/noop_resource_spec.rb +1 -1
- data/spec/integration/recipes/notifies_spec.rb +50 -21
- data/spec/integration/recipes/notifying_block_spec.rb +9 -6
- data/spec/integration/recipes/provider_choice.rb +2 -0
- data/spec/integration/recipes/recipe_dsl_spec.rb +46 -144
- data/spec/integration/recipes/resource_action_spec.rb +16 -11
- data/spec/integration/recipes/resource_converge_if_changed_spec.rb +1 -3
- data/spec/integration/recipes/resource_load_spec.rb +133 -13
- data/spec/integration/recipes/unified_mode_spec.rb +1 -1
- data/spec/integration/recipes/use_partial_spec.rb +112 -0
- data/spec/integration/solo/solo_spec.rb +3 -3
- data/spec/scripts/ssl-serve.rb +1 -1
- data/spec/spec_helper.rb +11 -14
- 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 +44 -19
- data/spec/support/platforms/win32/spec_service.rb +1 -1
- data/spec/support/recipe_dsl_helper.rb +83 -0
- 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 +3 -3
- data/spec/support/shared/functional/win32_service.rb +1 -1
- data/spec/support/shared/functional/windows_script.rb +5 -18
- data/spec/support/shared/integration/knife_support.rb +14 -8
- 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 -9
- data/spec/unit/chef_fs/file_system/operation_failed_error_spec.rb +4 -2
- data/spec/unit/client_spec.rb +7 -5
- data/spec/unit/cookbook/gem_installer_spec.rb +3 -4
- data/spec/unit/cookbook/metadata_spec.rb +38 -19
- data/spec/unit/data_bag_spec.rb +1 -1
- data/spec/unit/data_collector_spec.rb +38 -17
- data/spec/unit/dsl/platform_introspection_spec.rb +0 -1
- data/spec/unit/environment_spec.rb +7 -7
- data/spec/unit/event_dispatch/dispatcher_spec.rb +0 -3
- data/spec/unit/file_access_control_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 +36 -54
- 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/cookbook_show_spec.rb +1 -0
- data/spec/unit/knife/cookbook_upload_spec.rb +6 -5
- data/spec/unit/knife/core/bootstrap_context_spec.rb +23 -43
- data/spec/unit/knife/core/hashed_command_loader_spec.rb +3 -3
- data/spec/unit/knife/core/ui_spec.rb +16 -0
- data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +8 -68
- data/spec/unit/knife/data_bag_secret_options_spec.rb +22 -14
- data/spec/unit/knife/role_env_run_list_add_spec.rb +6 -6
- data/spec/unit/knife/role_env_run_list_clear_spec.rb +4 -4
- data/spec/unit/knife/role_env_run_list_remove_spec.rb +4 -4
- data/spec/unit/knife/role_env_run_list_replace_spec.rb +4 -4
- data/spec/unit/knife/role_env_run_list_set_spec.rb +4 -4
- data/spec/unit/knife/role_run_list_add_spec.rb +6 -6
- data/spec/unit/knife/role_run_list_clear_spec.rb +4 -4
- data/spec/unit/knife/role_run_list_remove_spec.rb +4 -4
- data/spec/unit/knife/role_run_list_replace_spec.rb +4 -4
- data/spec/unit/knife/role_run_list_set_spec.rb +4 -4
- data/spec/unit/knife/ssh_spec.rb +10 -113
- data/spec/unit/knife/status_spec.rb +1 -1
- data/spec/unit/knife/supermarket_share_spec.rb +3 -5
- data/spec/unit/knife_spec.rb +18 -0
- data/spec/unit/lwrp_spec.rb +4 -4
- data/spec/unit/mixin/powershell_exec_spec.rb +10 -0
- data/spec/unit/mixin/securable_spec.rb +1 -0
- data/spec/unit/mixin/user_context_spec.rb +9 -1
- data/spec/unit/node/attribute_spec.rb +2 -2
- 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 +18 -15
- data/spec/unit/provider/apt_preference_spec.rb +14 -10
- data/spec/unit/provider/apt_repository_spec.rb +9 -11
- 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 +44 -4
- 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/osx_profile_spec.rb +2 -2
- data/spec/unit/provider/package/dnf/python_helper_spec.rb +2 -2
- data/spec/unit/provider/package/freebsd/pkgng_spec.rb +1 -1
- data/spec/unit/provider/package/homebrew_spec.rb +280 -174
- data/spec/unit/provider/package/msu_spec.rb +3 -3
- data/spec/unit/provider/package/pacman_spec.rb +65 -147
- data/spec/unit/provider/package/powershell_spec.rb +88 -96
- data/spec/unit/provider/package/rubygems_spec.rb +221 -31
- data/spec/unit/provider/package/snap_spec.rb +1 -1
- data/spec/unit/provider/package/windows/exe_spec.rb +1 -1
- data/spec/unit/provider/package/windows_spec.rb +53 -30
- 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/arch_service_spec.rb +2 -3
- data/spec/unit/provider/service/debian_service_spec.rb +35 -14
- data/spec/unit/provider/service/gentoo_service_spec.rb +8 -8
- data/spec/unit/provider/service/macosx_spec.rb +210 -214
- data/spec/unit/provider/service/redhat_spec.rb +2 -2
- data/spec/unit/provider/service/systemd_service_spec.rb +23 -23
- data/spec/unit/provider/service/upstart_service_spec.rb +3 -3
- data/spec/unit/provider/service/windows_spec.rb +6 -2
- data/spec/unit/provider/subversion_spec.rb +4 -2
- data/spec/unit/provider/systemd_unit_spec.rb +24 -28
- data/spec/unit/provider/template_spec.rb +3 -4
- data/spec/unit/provider/zypper_repository_spec.rb +25 -75
- data/spec/unit/provider_resolver_spec.rb +11 -11
- data/spec/unit/provider_spec.rb +0 -1
- 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/archive_file_spec.rb +2 -11
- 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/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_dns_record_spec.rb +3 -3
- data/spec/unit/resource/windows_dns_zone_spec.rb +2 -2
- data/spec/unit/resource/windows_feature_dism_spec.rb +2 -17
- data/spec/unit/resource/windows_feature_powershell_spec.rb +6 -47
- data/spec/unit/resource/windows_firewall_rule_spec.rb +88 -41
- data/spec/unit/resource/windows_package_spec.rb +4 -1
- data/spec/unit/resource/windows_service_spec.rb +9 -0
- data/spec/unit/resource/windows_task_spec.rb +1 -1
- data/spec/unit/resource/windows_uac_spec.rb +2 -2
- data/spec/unit/resource/yum_repository_spec.rb +21 -21
- data/spec/unit/resource_reporter_spec.rb +1 -5
- data/spec/unit/resource_spec.rb +11 -4
- data/spec/unit/role_spec.rb +11 -11
- data/spec/unit/run_context/cookbook_compiler_spec.rb +1 -1
- data/spec/unit/run_context_spec.rb +1 -1
- data/spec/unit/search/query_spec.rb +1 -1
- data/spec/unit/util/threaded_job_queue_spec.rb +0 -9
- data/spec/unit/win32/security_spec.rb +3 -4
- data/tasks/rspec.rb +1 -1
- metadata +116 -87
- 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/functional/resource/windows_font_spec.rb +0 -49
- data/spec/unit/provider/ohai_spec.rb +0 -84
@@ -47,7 +47,7 @@ class Chef
|
|
47
47
|
|
48
48
|
def find_subcommands_via_dirglob
|
49
49
|
# The "require paths" of the core knife subcommands bundled with chef
|
50
|
-
files = Dir[File.join(Chef::Util::PathHelper.escape_glob_dir(File.expand_path("
|
50
|
+
files = Dir[File.join(Chef::Util::PathHelper.escape_glob_dir(File.expand_path("../../../knife", __FILE__)), "*.rb")]
|
51
51
|
subcommand_files = {}
|
52
52
|
files.each do |knife_file|
|
53
53
|
rel_path = knife_file[/#{CHEF_ROOT}#{Regexp.escape(File::SEPARATOR)}(.*)\.rb/, 1]
|
@@ -37,9 +37,10 @@ class Chef
|
|
37
37
|
short: "-a ATTR1 [-a ATTR2]",
|
38
38
|
long: "--attribute ATTR1 [--attribute ATTR2] ",
|
39
39
|
description: "Show one or more attributes",
|
40
|
-
proc: Proc.new { |
|
41
|
-
|
42
|
-
|
40
|
+
proc: Proc.new { |arg, accumulator|
|
41
|
+
accumulator ||= []
|
42
|
+
accumulator << arg
|
43
|
+
accumulator
|
43
44
|
}
|
44
45
|
end
|
45
46
|
end
|
@@ -27,7 +27,6 @@ class Chef
|
|
27
27
|
KEY = "_autogenerated_command_paths".freeze
|
28
28
|
|
29
29
|
attr_accessor :manifest
|
30
|
-
|
31
30
|
def initialize(chef_config_dir, plugin_manifest)
|
32
31
|
super(chef_config_dir)
|
33
32
|
@manifest = plugin_manifest
|
@@ -53,7 +52,7 @@ class Chef
|
|
53
52
|
paths = manifest[KEY]["plugins_paths"][command]
|
54
53
|
if paths && paths.is_a?(Array)
|
55
54
|
# It is only an error if all the paths don't exist
|
56
|
-
if paths.all? { |sc| !File.
|
55
|
+
if paths.all? { |sc| !File.exists?(sc) }
|
57
56
|
errors[command] = paths
|
58
57
|
end
|
59
58
|
end
|
@@ -77,7 +76,7 @@ class Chef
|
|
77
76
|
false
|
78
77
|
else
|
79
78
|
paths.each do |sc|
|
80
|
-
if File.
|
79
|
+
if File.exists?(sc)
|
81
80
|
Kernel.load sc
|
82
81
|
else
|
83
82
|
return false
|
@@ -94,8 +94,8 @@ class Chef
|
|
94
94
|
def summarize(data)
|
95
95
|
if data.is_a?(Chef::Node)
|
96
96
|
node = data
|
97
|
-
# special case
|
98
|
-
ip = (node[:
|
97
|
+
# special case clouds with their split horizon whatsis.
|
98
|
+
ip = (node[:cloud] && node[:cloud][:public_ipv4_addrs] && node[:cloud][:public_ipv4_addrs].first) || node[:ipaddress]
|
99
99
|
|
100
100
|
summarized = <<~SUMMARY
|
101
101
|
#{ui.color("Node Name:", :bold)} #{ui.color(node.name, :bold)}
|
@@ -67,8 +67,8 @@ class Chef
|
|
67
67
|
|
68
68
|
result["name"] = node["name"] || node.name
|
69
69
|
result["chef_environment"] = node["chef_environment"]
|
70
|
-
ip = (node["
|
71
|
-
fqdn = (node["
|
70
|
+
ip = (node["cloud"] && node["cloud"]["public_ipv4_addrs"].first) || node["ipaddress"]
|
71
|
+
fqdn = (node["cloud"] && node["cloud"]["public_hostname"]) || node["fqdn"]
|
72
72
|
result["ip"] = ip if ip
|
73
73
|
result["fqdn"] = fqdn if fqdn
|
74
74
|
result["run_list"] = node.run_list if config["run_list"]
|
@@ -95,9 +95,9 @@ class Chef
|
|
95
95
|
summarized = ""
|
96
96
|
list.each do |data|
|
97
97
|
node = data
|
98
|
-
# special case
|
99
|
-
ip = (node[:
|
100
|
-
fqdn = (node[:
|
98
|
+
# special case clouds with their split horizon whatsis.
|
99
|
+
ip = (node[:cloud] && node[:cloud][:public_ipv4_addrs] && node[:cloud][:public_ipv4_addrs].first) || node[:ipaddress]
|
100
|
+
fqdn = (node[:cloud] && node[:cloud][:public_hostname]) || node[:fqdn]
|
101
101
|
name = node["name"] || node.name
|
102
102
|
|
103
103
|
if config[:run_list]
|
@@ -125,7 +125,7 @@ class Chef
|
|
125
125
|
#
|
126
126
|
def find_subcommands_via_dirglob
|
127
127
|
# The "require paths" of the core knife subcommands bundled with chef
|
128
|
-
files = Dir[File.join(Chef::Util::PathHelper.escape_glob_dir(File.expand_path("
|
128
|
+
files = Dir[File.join(Chef::Util::PathHelper.escape_glob_dir(File.expand_path("../../../knife", __FILE__)), "*.rb")]
|
129
129
|
subcommand_files = {}
|
130
130
|
files.each do |knife_file|
|
131
131
|
rel_path = knife_file[/#{CHEF_ROOT}#{Regexp.escape(File::SEPARATOR)}(.*)\.rb/, 1]
|
data/lib/chef/knife/core/ui.rb
CHANGED
@@ -61,6 +61,14 @@ class Chef
|
|
61
61
|
end
|
62
62
|
end
|
63
63
|
|
64
|
+
# pastel.decorate is a lightweight replacement for highline.color
|
65
|
+
def pastel
|
66
|
+
@pastel ||= begin
|
67
|
+
require "pastel"
|
68
|
+
Pastel.new
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
64
72
|
# Prints a message to stdout. Aliased as +info+ for compatibility with
|
65
73
|
# the logger API.
|
66
74
|
#
|
@@ -132,9 +140,17 @@ class Chef
|
|
132
140
|
log("#{color("FATAL:", :red, :bold)} #{message}")
|
133
141
|
end
|
134
142
|
|
143
|
+
# Print a message describing a fatal error and exit 1
|
144
|
+
#
|
145
|
+
# @param message [String] the text string
|
146
|
+
def fatal!(message)
|
147
|
+
fatal(message)
|
148
|
+
exit 1
|
149
|
+
end
|
150
|
+
|
135
151
|
def color(string, *colors)
|
136
152
|
if color?
|
137
|
-
|
153
|
+
pastel.decorate(string, *colors)
|
138
154
|
else
|
139
155
|
string
|
140
156
|
end
|
@@ -30,6 +30,8 @@ class Chef
|
|
30
30
|
# * @run_list - the run list for the node to boostrap
|
31
31
|
#
|
32
32
|
class WindowsBootstrapContext < BootstrapContext
|
33
|
+
attr_accessor :config
|
34
|
+
attr_accessor :chef_config
|
33
35
|
|
34
36
|
def initialize(config, run_list, chef_config, secret = nil)
|
35
37
|
@config = config
|
@@ -39,31 +41,16 @@ class Chef
|
|
39
41
|
super(config, run_list, chef_config, secret)
|
40
42
|
end
|
41
43
|
|
42
|
-
# This is a duplicate of ChefConfig::PathHelper.cleanpath, however
|
43
|
-
# this presumes Windows so we can avoid changing the method definitions
|
44
|
-
# across Chef, ChefConfig, and ChefUtils for the circumstance where
|
45
|
-
# the methods are being run for a system other than the one Ruby is
|
46
|
-
# executing on.
|
47
|
-
#
|
48
|
-
# We only need to cleanpath the paths that we are passing to cmd.exe,
|
49
|
-
# anything written to a configuration file or passed as an argument
|
50
|
-
# will be interpreted by ruby later and do the right thing.
|
51
|
-
def cleanpath(path)
|
52
|
-
path = Pathname.new(path).cleanpath.to_s
|
53
|
-
path = path.gsub(File::SEPARATOR, '\\')
|
54
|
-
path
|
55
|
-
end
|
56
|
-
|
57
44
|
def validation_key
|
58
|
-
if File.exist?(File.expand_path(
|
59
|
-
IO.read(File.expand_path(
|
45
|
+
if File.exist?(File.expand_path(chef_config[:validation_key]))
|
46
|
+
IO.read(File.expand_path(chef_config[:validation_key]))
|
60
47
|
else
|
61
48
|
false
|
62
49
|
end
|
63
50
|
end
|
64
51
|
|
65
52
|
def secret
|
66
|
-
escape_and_echo(
|
53
|
+
escape_and_echo(config[:secret])
|
67
54
|
end
|
68
55
|
|
69
56
|
def trusted_certs_script
|
@@ -72,25 +59,25 @@ class Chef
|
|
72
59
|
|
73
60
|
def config_content
|
74
61
|
client_rb = <<~CONFIG
|
75
|
-
chef_server_url "#{
|
76
|
-
validation_client_name "#{
|
62
|
+
chef_server_url "#{chef_config[:chef_server_url]}"
|
63
|
+
validation_client_name "#{chef_config[:validation_client_name]}"
|
77
64
|
file_cache_path "#{ChefConfig::Config.var_chef_dir(true)}/cache"
|
78
65
|
file_backup_path "#{ChefConfig::Config.var_chef_dir(true)}/backup"
|
79
66
|
cache_options ({:path => "#{ChefConfig::Config.etc_chef_dir(true)}/cache/checksums", :skip_expires => true})
|
80
67
|
CONFIG
|
81
68
|
|
82
|
-
unless
|
83
|
-
client_rb << "chef_license \"#{
|
69
|
+
unless chef_config[:chef_license].nil?
|
70
|
+
client_rb << "chef_license \"#{chef_config[:chef_license]}\"\n"
|
84
71
|
end
|
85
72
|
|
86
|
-
if
|
87
|
-
client_rb << %Q{node_name "#{
|
73
|
+
if config[:chef_node_name]
|
74
|
+
client_rb << %Q{node_name "#{config[:chef_node_name]}"\n}
|
88
75
|
else
|
89
76
|
client_rb << "# Using default node name (fqdn)\n"
|
90
77
|
end
|
91
78
|
|
92
|
-
if
|
93
|
-
client_rb << %Q{log_level :#{
|
79
|
+
if chef_config[:config_log_level]
|
80
|
+
client_rb << %Q{log_level :#{chef_config[:config_log_level]}\n}
|
94
81
|
else
|
95
82
|
client_rb << "log_level :auto\n"
|
96
83
|
end
|
@@ -99,21 +86,21 @@ class Chef
|
|
99
86
|
|
100
87
|
# We configure :verify_api_cert only when it's overridden on the CLI
|
101
88
|
# or when specified in the knife config.
|
102
|
-
if
|
103
|
-
value =
|
89
|
+
if !config[:node_verify_api_cert].nil? || config.key?(:verify_api_cert)
|
90
|
+
value = config[:node_verify_api_cert].nil? ? config[:verify_api_cert] : config[:node_verify_api_cert]
|
104
91
|
client_rb << %Q{verify_api_cert #{value}\n}
|
105
92
|
end
|
106
93
|
|
107
94
|
# We configure :ssl_verify_mode only when it's overridden on the CLI
|
108
95
|
# or when specified in the knife config.
|
109
|
-
if
|
110
|
-
value = case
|
96
|
+
if config[:node_ssl_verify_mode] || config.key?(:ssl_verify_mode)
|
97
|
+
value = case config[:node_ssl_verify_mode]
|
111
98
|
when "peer"
|
112
99
|
:verify_peer
|
113
100
|
when "none"
|
114
101
|
:verify_none
|
115
102
|
when nil
|
116
|
-
|
103
|
+
config[:ssl_verify_mode]
|
117
104
|
else
|
118
105
|
nil
|
119
106
|
end
|
@@ -123,22 +110,22 @@ class Chef
|
|
123
110
|
end
|
124
111
|
end
|
125
112
|
|
126
|
-
if
|
127
|
-
client_rb << %Q{ssl_verify_mode :#{
|
113
|
+
if config[:ssl_verify_mode]
|
114
|
+
client_rb << %Q{ssl_verify_mode :#{config[:ssl_verify_mode]}\n}
|
128
115
|
end
|
129
116
|
|
130
|
-
if
|
117
|
+
if config[:bootstrap_proxy]
|
131
118
|
client_rb << "\n"
|
132
|
-
client_rb << %Q{http_proxy "#{
|
133
|
-
client_rb << %Q{https_proxy "#{
|
134
|
-
client_rb << %Q{no_proxy "#{
|
119
|
+
client_rb << %Q{http_proxy "#{config[:bootstrap_proxy]}"\n}
|
120
|
+
client_rb << %Q{https_proxy "#{config[:bootstrap_proxy]}"\n}
|
121
|
+
client_rb << %Q{no_proxy "#{config[:bootstrap_no_proxy]}"\n} if config[:bootstrap_no_proxy]
|
135
122
|
end
|
136
123
|
|
137
|
-
if
|
138
|
-
client_rb << %Q{no_proxy "#{
|
124
|
+
if config[:bootstrap_no_proxy]
|
125
|
+
client_rb << %Q{no_proxy "#{config[:bootstrap_no_proxy]}"\n}
|
139
126
|
end
|
140
127
|
|
141
|
-
if
|
128
|
+
if config[:secret]
|
142
129
|
client_rb << %Q{encrypted_data_bag_secret "#{ChefConfig::Config.etc_chef_dir(true)}/encrypted_data_bag_secret"\n}
|
143
130
|
end
|
144
131
|
|
@@ -146,7 +133,7 @@ class Chef
|
|
146
133
|
client_rb << %Q{trusted_certs_dir "#{ChefConfig::Config.etc_chef_dir(true)}/trusted_certs"\n}
|
147
134
|
end
|
148
135
|
|
149
|
-
if
|
136
|
+
if chef_config[:fips]
|
150
137
|
client_rb << "fips true\n"
|
151
138
|
end
|
152
139
|
|
@@ -154,18 +141,18 @@ class Chef
|
|
154
141
|
end
|
155
142
|
|
156
143
|
def get_log_location
|
157
|
-
if
|
158
|
-
%Q{:#{
|
159
|
-
elsif
|
144
|
+
if chef_config[:config_log_location].equal?(:win_evt)
|
145
|
+
%Q{:#{chef_config[:config_log_location]}\n}
|
146
|
+
elsif chef_config[:config_log_location].equal?(:syslog)
|
160
147
|
raise "syslog is not supported for log_location on Windows OS\n"
|
161
|
-
elsif
|
148
|
+
elsif chef_config[:config_log_location].equal?(STDOUT)
|
162
149
|
"STDOUT\n"
|
163
|
-
elsif
|
150
|
+
elsif chef_config[:config_log_location].equal?(STDERR)
|
164
151
|
"STDERR\n"
|
165
|
-
elsif
|
152
|
+
elsif chef_config[:config_log_location].nil? || chef_config[:config_log_location].empty?
|
166
153
|
"STDOUT\n"
|
167
|
-
elsif
|
168
|
-
%Q{"#{
|
154
|
+
elsif chef_config[:config_log_location]
|
155
|
+
%Q{"#{chef_config[:config_log_location]}"\n}
|
169
156
|
else
|
170
157
|
"STDOUT\n"
|
171
158
|
end
|
@@ -173,7 +160,7 @@ class Chef
|
|
173
160
|
|
174
161
|
def start_chef
|
175
162
|
bootstrap_environment_option = bootstrap_environment.nil? ? "" : " -E #{bootstrap_environment}"
|
176
|
-
start_chef = "SET \"PATH=%SystemRoot%\\system32;%SystemRoot%;%SystemRoot%\\System32\\Wbem;%SYSTEMROOT%\\System32\\WindowsPowerShell\\v1.0\\;C:\\ruby\\bin;#{ChefConfig::Config.c_opscode_dir}\\bin;#{ChefConfig::Config.c_opscode_dir}\\embedded\\bin\;%PATH%\"\n"
|
163
|
+
start_chef = "SET \"PATH=%SystemRoot%\\system32;%SystemRoot%;%SystemRoot%\\System32\\Wbem;%SYSTEMROOT%\\System32\\WindowsPowerShell\\v1.0\\;C:\\ruby\\bin;#{ChefConfig::Config.c_opscode_dir}\\#{ChefConfig::Dist::DIR_SUFFIX}\\bin;#{ChefConfig::Config.c_opscode_dir}\\#{ChefConfig::Dist::DIR_SUFFIX}\\embedded\\bin\;%PATH%\"\n"
|
177
164
|
start_chef << "#{Chef::Dist::CLIENT} -c #{ChefConfig::Config.etc_chef_dir(true)}/client.rb -j #{ChefConfig::Config.etc_chef_dir(true)}/first-boot.json#{bootstrap_environment_option}\n"
|
178
165
|
end
|
179
166
|
|
@@ -275,7 +262,7 @@ class Chef
|
|
275
262
|
end
|
276
263
|
|
277
264
|
def bootstrap_directory
|
278
|
-
|
265
|
+
ChefConfig::Config.etc_chef_dir(true)
|
279
266
|
end
|
280
267
|
|
281
268
|
def local_download_path
|
@@ -285,15 +272,15 @@ class Chef
|
|
285
272
|
# Build a URL to query www.chef.io that will redirect to the correct
|
286
273
|
# Chef Infra msi download.
|
287
274
|
def msi_url(machine_os = nil, machine_arch = nil, download_context = nil)
|
288
|
-
if
|
275
|
+
if config[:msi_url].nil? || config[:msi_url].empty?
|
289
276
|
url = "https://www.chef.io/chef/download?p=windows"
|
290
277
|
url += "&pv=#{machine_os}" unless machine_os.nil?
|
291
278
|
url += "&m=#{machine_arch}" unless machine_arch.nil?
|
292
279
|
url += "&DownloadContext=#{download_context}" unless download_context.nil?
|
293
|
-
url += "&channel=#{
|
280
|
+
url += "&channel=#{config[:channel]}"
|
294
281
|
url += "&v=#{version_to_install}"
|
295
282
|
else
|
296
|
-
|
283
|
+
config[:msi_url]
|
297
284
|
end
|
298
285
|
end
|
299
286
|
|
@@ -318,8 +305,8 @@ class Chef
|
|
318
305
|
# This string should contain both the commands necessary to both create the files, as well as their content
|
319
306
|
def trusted_certs_content
|
320
307
|
content = ""
|
321
|
-
if
|
322
|
-
Dir.glob(File.join(Chef::Util::PathHelper.escape_glob_dir(
|
308
|
+
if chef_config[:trusted_certs_dir]
|
309
|
+
Dir.glob(File.join(Chef::Util::PathHelper.escape_glob_dir(chef_config[:trusted_certs_dir]), "*.{crt,pem}")).each do |cert|
|
323
310
|
content << "> #{bootstrap_directory}/trusted_certs/#{File.basename(cert)} (\n" +
|
324
311
|
escape_and_echo(IO.read(File.expand_path(cert))) + "\n)\n"
|
325
312
|
end
|
@@ -329,8 +316,8 @@ class Chef
|
|
329
316
|
|
330
317
|
def client_d_content
|
331
318
|
content = ""
|
332
|
-
if
|
333
|
-
root = Pathname(
|
319
|
+
if chef_config[:client_d_dir] && File.exist?(chef_config[:client_d_dir])
|
320
|
+
root = Pathname(chef_config[:client_d_dir])
|
334
321
|
root.find do |f|
|
335
322
|
relative = f.relative_path_from(root)
|
336
323
|
if f != root
|
@@ -34,18 +34,13 @@ class Chef
|
|
34
34
|
# are provided.
|
35
35
|
|
36
36
|
def self.included(base)
|
37
|
-
base.option :
|
38
|
-
short: "-s SECRET",
|
37
|
+
base.option :cl_secret,
|
39
38
|
long: "--secret SECRET",
|
40
|
-
description: "The secret key to use to encrypt data bag item values. Can also be defaulted in your config with the key 'secret'."
|
41
|
-
# Need to store value from command line in separate variable - knife#merge_configs populates same keys
|
42
|
-
# on config object from
|
43
|
-
proc: Proc.new { |s| set_cl_secret(s) }
|
39
|
+
description: "The secret key to use to encrypt data bag item values. Can also be defaulted in your config with the key 'secret'."
|
44
40
|
|
45
|
-
base.option :
|
41
|
+
base.option :cl_secret_file,
|
46
42
|
long: "--secret-file SECRET_FILE",
|
47
|
-
description: "A file containing the secret key to use to encrypt data bag item values. Can also be defaulted in your config with the key 'secret_file'."
|
48
|
-
proc: Proc.new { |sf| set_cl_secret_file(sf) }
|
43
|
+
description: "A file containing the secret key to use to encrypt data bag item values. Can also be defaulted in your config with the key 'secret_file'."
|
49
44
|
|
50
45
|
base.option :encrypt,
|
51
46
|
long: "--encrypt",
|
@@ -67,32 +62,25 @@ class Chef
|
|
67
62
|
# IE, if we are not running 'knife data bag *' we don't need to load 'chef/encrypted_data_bag_item'
|
68
63
|
require_relative "../encrypted_data_bag_item"
|
69
64
|
|
70
|
-
if
|
71
|
-
config[:
|
72
|
-
elsif
|
73
|
-
Chef::EncryptedDataBagItem.load_secret(config[:
|
74
|
-
elsif secret =
|
65
|
+
if config[:cl_secret]
|
66
|
+
config[:cl_secret]
|
67
|
+
elsif config[:cl_secret_file]
|
68
|
+
Chef::EncryptedDataBagItem.load_secret(config[:cl_secret_file])
|
69
|
+
elsif secret = config[:secret]
|
75
70
|
secret
|
76
71
|
else
|
77
|
-
secret_file =
|
72
|
+
secret_file = config[:secret_file]
|
78
73
|
Chef::EncryptedDataBagItem.load_secret(secret_file)
|
79
74
|
end
|
80
75
|
end
|
81
76
|
|
82
77
|
def validate_secrets
|
83
|
-
if
|
84
|
-
|
85
|
-
|
86
|
-
")
|
87
|
-
end
|
88
|
-
|
89
|
-
if has_cl_secret_file?
|
90
|
-
ui.fatal("Please specify only one of --secret, --secret-file")
|
91
|
-
exit(1)
|
92
|
-
end
|
78
|
+
if config[:cl_secret] && config[:cl_secret_file]
|
79
|
+
ui.fatal("Please specify only one of --secret, --secret-file")
|
80
|
+
exit(1)
|
93
81
|
end
|
94
82
|
|
95
|
-
if
|
83
|
+
if config[:secret] && config[:secret_file]
|
96
84
|
ui.fatal("Please specify only one of 'secret' or 'secret_file' in your config file")
|
97
85
|
exit(1)
|
98
86
|
end
|
@@ -106,41 +94,26 @@ class Chef
|
|
106
94
|
def base_encryption_secret_provided?(need_encrypt_flag = true)
|
107
95
|
validate_secrets
|
108
96
|
|
109
|
-
return true if
|
97
|
+
return true if config[:cl_secret] || config[:cl_secret_file]
|
110
98
|
|
111
99
|
if need_encrypt_flag
|
112
100
|
if config[:encrypt]
|
113
|
-
unless
|
101
|
+
unless config[:secret] || config[:secret_file]
|
114
102
|
ui.fatal("No secret or secret_file specified in config, unable to encrypt item.")
|
115
103
|
exit(1)
|
116
104
|
end
|
117
105
|
return true
|
118
106
|
end
|
119
107
|
return false
|
120
|
-
elsif
|
108
|
+
elsif config[:secret] || config[:secret_file]
|
121
109
|
# Certain situations (show and bootstrap) don't need a --encrypt flag to use the config file secret
|
122
110
|
return true
|
123
111
|
end
|
124
112
|
false
|
125
113
|
end
|
126
114
|
|
127
|
-
def has_cl_secret?
|
128
|
-
Chef::Config[:knife].key?(:cl_secret)
|
129
|
-
end
|
130
|
-
|
131
|
-
def self.set_cl_secret(s)
|
132
|
-
Chef::Config[:knife][:cl_secret] = s
|
133
|
-
end
|
134
|
-
|
135
|
-
def has_cl_secret_file?
|
136
|
-
Chef::Config[:knife].key?(:cl_secret_file)
|
137
|
-
end
|
138
|
-
|
139
|
-
def self.set_cl_secret_file(sf)
|
140
|
-
Chef::Config[:knife][:cl_secret_file] = sf
|
141
|
-
end
|
142
|
-
|
143
115
|
def knife_config
|
116
|
+
Chef.deprecated(:knife_bootstrap_apis, "The `knife_config` bootstrap helper has been deprecated, use the properly merged `config` helper instead")
|
144
117
|
Chef::Config.key?(:knife) ? Chef::Config[:knife] : {}
|
145
118
|
end
|
146
119
|
|