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
@@ -34,8 +34,8 @@ class Chef
|
|
34
34
|
def initialize(config: {}, knife_config: nil, ui: nil)
|
35
35
|
@config = config
|
36
36
|
unless knife_config.nil?
|
37
|
-
# the knife_config argument becomes deprecated in Chef-16, don't use it
|
38
37
|
@config = knife_config
|
38
|
+
Chef.deprecated(:knife_bootstrap_apis, "The knife_config option to the Bootstrap::ClientBuilder object is deprecated and has been renamed to just 'config'")
|
39
39
|
end
|
40
40
|
@ui = ui
|
41
41
|
end
|
@@ -102,7 +102,7 @@ class Chef
|
|
102
102
|
config[:bootstrap_vault_item]
|
103
103
|
end
|
104
104
|
|
105
|
-
# Helper to return a ruby object
|
105
|
+
# Helper to return a ruby object representing all the data bags and items
|
106
106
|
# to update via chef-vault.
|
107
107
|
#
|
108
108
|
# @return [Hash] deserialized ruby hash with all the vault items
|
@@ -42,8 +42,8 @@ class Chef
|
|
42
42
|
def initialize(config: {}, knife_config: nil, chef_config: {}, ui: nil)
|
43
43
|
@config = config
|
44
44
|
unless knife_config.nil?
|
45
|
-
# the knife_config argument becomes deprecated in Chef-16, don't use it
|
46
45
|
@config = knife_config
|
46
|
+
Chef.deprecated(:knife_bootstrap_apis, "The knife_config option to the Bootstrap::ClientBuilder object is deprecated and has been renamed to just 'config'")
|
47
47
|
end
|
48
48
|
@chef_config = chef_config
|
49
49
|
@ui = ui
|
@@ -86,7 +86,7 @@ class Chef
|
|
86
86
|
config[:chef_node_name]
|
87
87
|
end
|
88
88
|
|
89
|
-
# @return [String]
|
89
|
+
# @return [String] environment from the config
|
90
90
|
def environment
|
91
91
|
config[:environment]
|
92
92
|
end
|
@@ -1,5 +1,5 @@
|
|
1
|
-
<%= "https_proxy=\"#{
|
2
|
-
<%= "no_proxy=\"#{
|
1
|
+
<%= "https_proxy=\"#{@config[:bootstrap_proxy]}\" export https_proxy" if @config[:bootstrap_proxy] %>
|
2
|
+
<%= "no_proxy=\"#{@config[:bootstrap_no_proxy]}\" export no_proxy" if @config[:bootstrap_no_proxy] %>
|
3
3
|
|
4
4
|
if test "x$TMPDIR" = "x"; then
|
5
5
|
tmp="/tmp"
|
@@ -37,7 +37,7 @@ capture_tmp_stderr() {
|
|
37
37
|
# do_wget URL FILENAME
|
38
38
|
do_wget() {
|
39
39
|
echo "trying wget..."
|
40
|
-
wget <%= "--proxy=on " if
|
40
|
+
wget <%= "--proxy=on " if @config[:bootstrap_proxy] %> <%= @config[:bootstrap_wget_options] %> -O "$2" "$1" 2>$tmp_dir/stderr
|
41
41
|
rc=$?
|
42
42
|
# check for 404
|
43
43
|
grep "ERROR 404" $tmp_dir/stderr 2>&1 >/dev/null
|
@@ -57,7 +57,7 @@ do_wget() {
|
|
57
57
|
# do_curl URL FILENAME
|
58
58
|
do_curl() {
|
59
59
|
echo "trying curl..."
|
60
|
-
curl -sL <%= "--proxy \"#{
|
60
|
+
curl -sL <%= "--proxy \"#{@config[:bootstrap_proxy]}\" " if @config[:bootstrap_proxy] %> <%= @config[:bootstrap_curl_options] %> -D $tmp_dir/stderr -o "$2" "$1" 2>$tmp_dir/stderr
|
61
61
|
rc=$?
|
62
62
|
# check for 404
|
63
63
|
grep "404 Not Found" $tmp_dir/stderr 2>&1 >/dev/null
|
@@ -164,14 +164,14 @@ do_download() {
|
|
164
164
|
|
165
165
|
<%# Run any custom commands before installing chef-client -%>
|
166
166
|
<%# Ex. wait for cloud-init to complete -%>
|
167
|
-
<% if
|
168
|
-
<%=
|
167
|
+
<% if @config[:bootstrap_preinstall_command] %>
|
168
|
+
<%= @config[:bootstrap_preinstall_command] %>
|
169
169
|
<% end %>
|
170
170
|
|
171
|
-
<% if
|
172
|
-
<%=
|
171
|
+
<% if @config[:bootstrap_install_command] %>
|
172
|
+
<%= @config[:bootstrap_install_command] %>
|
173
173
|
<% else %>
|
174
|
-
install_sh="<%=
|
174
|
+
install_sh="<%= @config[:bootstrap_url] ? @config[:bootstrap_url] : "https://omnitruck.chef.io/chef/install.sh" %>"
|
175
175
|
if test -f /usr/bin/<%= Chef::Dist::CLIENT %>; then
|
176
176
|
echo "-----> Existing <%= Chef::Dist::PRODUCT %> installation detected"
|
177
177
|
else
|
@@ -214,10 +214,10 @@ mkdir -p <%= ChefConfig::Config.etc_chef_dir(false) %>/trusted_certs
|
|
214
214
|
<% end -%>
|
215
215
|
|
216
216
|
<%# Generate Ohai Hints -%>
|
217
|
-
<% unless @
|
217
|
+
<% unless @config[:hints].nil? || @config[:hints].empty? -%>
|
218
218
|
mkdir -p <%= ChefConfig::Config.etc_chef_dir(false) %>/ohai/hints
|
219
219
|
|
220
|
-
<% @
|
220
|
+
<% @config[:hints].each do |name, hash| -%>
|
221
221
|
cat > <%= ChefConfig::Config.etc_chef_dir(false) %>/ohai/hints/<%= name %>.json <<'EOP'
|
222
222
|
<%= Chef::JSONCompat.to_json(hash) %>
|
223
223
|
EOP
|
@@ -21,7 +21,7 @@
|
|
21
21
|
@rem the line is read. See help for the /E switch from cmd.exe /? .
|
22
22
|
@setlocal ENABLEDELAYEDEXPANSION
|
23
23
|
|
24
|
-
<%= "SETX HTTP_PROXY \"#{
|
24
|
+
<%= "SETX HTTP_PROXY \"#{@config[:bootstrap_proxy]}\"" if @config[:bootstrap_proxy] %>
|
25
25
|
|
26
26
|
@set BOOTSTRAP_DIRECTORY=<%= bootstrap_directory %>
|
27
27
|
@echo Checking for existing directory "%BOOTSTRAP_DIRECTORY%"...
|
@@ -92,10 +92,10 @@ goto architecture_select
|
|
92
92
|
goto Version10.0
|
93
93
|
|
94
94
|
:architecture_select
|
95
|
-
<% if
|
96
|
-
@set MACHINE_ARCH=<%=
|
95
|
+
<% if @config[:architecture] %>
|
96
|
+
@set MACHINE_ARCH=<%= @config[:architecture] %>
|
97
97
|
|
98
|
-
<% if
|
98
|
+
<% if @config[:architecture] == "x86_64" %>
|
99
99
|
IF "%PROCESSOR_ARCHITECTURE%"=="x86" IF not defined PROCESSOR_ARCHITEW6432 (
|
100
100
|
echo You specified bootstrap_architecture as x86_64 but the target machine is i386. A 64 bit program cannot run on a 32 bit machine. > "&2"
|
101
101
|
echo Exiting without bootstrapping. > "&2"
|
@@ -109,20 +109,20 @@ goto Version10.0
|
|
109
109
|
goto chef_installed
|
110
110
|
|
111
111
|
:chef_installed
|
112
|
-
@echo Checking for existing
|
112
|
+
@echo Checking for existing <%= Chef::Dist::PRODUCT %> installation
|
113
113
|
WHERE <%= Chef::Dist::CLIENT %> >nul 2>nul
|
114
114
|
If !ERRORLEVEL!==0 (
|
115
|
-
@echo Existing Chef installation detected, skipping download
|
115
|
+
@echo Existing <%= Chef::Dist::PRODUCT %> installation detected, skipping download
|
116
116
|
goto key_create
|
117
117
|
) else (
|
118
|
-
@echo No existing installation of
|
118
|
+
@echo No existing installation of <%= Chef::Dist::PRODUCT %> detected
|
119
119
|
goto install
|
120
120
|
)
|
121
121
|
|
122
122
|
:install
|
123
123
|
@rem If user has provided the custom installation command, execute it
|
124
|
-
<% if @
|
125
|
-
<%= @
|
124
|
+
<% if @config[:bootstrap_install_command] %>
|
125
|
+
<%= @config[:bootstrap_install_command] %>
|
126
126
|
<% else %>
|
127
127
|
@rem Install Chef using the MSI installer
|
128
128
|
|
@@ -246,12 +246,12 @@ echo Validation key written.
|
|
246
246
|
<% end -%>
|
247
247
|
|
248
248
|
<%# Generate Ohai Hints -%>
|
249
|
-
<% unless @
|
249
|
+
<% unless @config[:hints].nil? || @config[:hints].empty? -%>
|
250
250
|
@if NOT EXIST <%= bootstrap_directory %>\ohai\hints (
|
251
251
|
mkdir <%= bootstrap_directory %>\ohai\hints
|
252
252
|
)
|
253
253
|
|
254
|
-
<% @
|
254
|
+
<% @config[:hints].each do |name, hash| -%>
|
255
255
|
> <%= bootstrap_directory %>\ohai\hints\<%= name %>.json (
|
256
256
|
<%= escape_and_echo(hash.to_json) %>
|
257
257
|
)
|
@@ -274,5 +274,5 @@ echo Validation key written.
|
|
274
274
|
<%= client_d %>
|
275
275
|
<% end -%>
|
276
276
|
|
277
|
-
@echo Starting
|
277
|
+
@echo Starting <%= Chef::Dist::CLIENT %> to bootstrap the node...
|
278
278
|
<%= start_chef %>
|
@@ -33,6 +33,8 @@ class Chef
|
|
33
33
|
class BootstrapContext
|
34
34
|
|
35
35
|
attr_accessor :client_pem
|
36
|
+
attr_accessor :config
|
37
|
+
attr_accessor :chef_config
|
36
38
|
|
37
39
|
def initialize(config, run_list, chef_config, secret = nil)
|
38
40
|
@config = config
|
@@ -42,13 +44,13 @@ class Chef
|
|
42
44
|
end
|
43
45
|
|
44
46
|
def bootstrap_environment
|
45
|
-
|
47
|
+
config[:environment]
|
46
48
|
end
|
47
49
|
|
48
50
|
def validation_key
|
49
|
-
if
|
50
|
-
File.exist?(File.expand_path(
|
51
|
-
IO.read(File.expand_path(
|
51
|
+
if chef_config[:validation_key] &&
|
52
|
+
File.exist?(File.expand_path(chef_config[:validation_key]))
|
53
|
+
IO.read(File.expand_path(chef_config[:validation_key]))
|
52
54
|
else
|
53
55
|
false
|
54
56
|
end
|
@@ -69,18 +71,18 @@ class Chef
|
|
69
71
|
end
|
70
72
|
|
71
73
|
def get_log_location
|
72
|
-
if !(
|
74
|
+
if !(chef_config[:config_log_location].class == IO ) && (chef_config[:config_log_location].nil? || chef_config[:config_log_location].to_s.empty?)
|
73
75
|
"STDOUT"
|
74
|
-
elsif
|
76
|
+
elsif chef_config[:config_log_location].equal?(:win_evt)
|
75
77
|
raise "The value :win_evt is not supported for config_log_location on Linux Platforms \n"
|
76
|
-
elsif
|
78
|
+
elsif chef_config[:config_log_location].equal?(:syslog)
|
77
79
|
":syslog"
|
78
|
-
elsif
|
80
|
+
elsif chef_config[:config_log_location].equal?(STDOUT)
|
79
81
|
"STDOUT"
|
80
|
-
elsif
|
82
|
+
elsif chef_config[:config_log_location].equal?(STDERR)
|
81
83
|
"STDERR"
|
82
|
-
elsif
|
83
|
-
%Q{"#{
|
84
|
+
elsif chef_config[:config_log_location]
|
85
|
+
%Q{"#{chef_config[:config_log_location]}"}
|
84
86
|
else
|
85
87
|
"STDOUT"
|
86
88
|
end
|
@@ -88,43 +90,43 @@ class Chef
|
|
88
90
|
|
89
91
|
def config_content
|
90
92
|
client_rb = <<~CONFIG
|
91
|
-
chef_server_url "#{
|
92
|
-
validation_client_name "#{
|
93
|
+
chef_server_url "#{chef_config[:chef_server_url]}"
|
94
|
+
validation_client_name "#{chef_config[:validation_client_name]}"
|
93
95
|
CONFIG
|
94
96
|
|
95
|
-
unless
|
96
|
-
client_rb << "chef_license \"#{
|
97
|
+
unless chef_config[:chef_license].nil?
|
98
|
+
client_rb << "chef_license \"#{chef_config[:chef_license]}\"\n"
|
97
99
|
end
|
98
100
|
|
99
|
-
unless
|
100
|
-
client_rb << %Q{log_level :#{
|
101
|
+
unless chef_config[:config_log_level].nil? || chef_config[:config_log_level].empty?
|
102
|
+
client_rb << %Q{log_level :#{chef_config[:config_log_level]}\n}
|
101
103
|
end
|
102
104
|
|
103
105
|
client_rb << "log_location #{get_log_location}\n"
|
104
106
|
|
105
|
-
if
|
106
|
-
client_rb << %Q{node_name "#{
|
107
|
+
if config[:chef_node_name]
|
108
|
+
client_rb << %Q{node_name "#{config[:chef_node_name]}"\n}
|
107
109
|
else
|
108
110
|
client_rb << "# Using default node name (fqdn)\n"
|
109
111
|
end
|
110
112
|
|
111
113
|
# We configure :verify_api_cert only when it's overridden on the CLI
|
112
114
|
# or when specified in the knife config.
|
113
|
-
if
|
114
|
-
value =
|
115
|
+
if !config[:node_verify_api_cert].nil? || config.key?(:verify_api_cert)
|
116
|
+
value = config[:node_verify_api_cert].nil? ? config[:verify_api_cert] : config[:node_verify_api_cert]
|
115
117
|
client_rb << %Q{verify_api_cert #{value}\n}
|
116
118
|
end
|
117
119
|
|
118
120
|
# We configure :ssl_verify_mode only when it's overridden on the CLI
|
119
121
|
# or when specified in the knife config.
|
120
|
-
if
|
121
|
-
value = case
|
122
|
+
if config[:node_ssl_verify_mode] || config.key?(:ssl_verify_mode)
|
123
|
+
value = case config[:node_ssl_verify_mode]
|
122
124
|
when "peer"
|
123
125
|
:verify_peer
|
124
126
|
when "none"
|
125
127
|
:verify_none
|
126
128
|
when nil
|
127
|
-
|
129
|
+
config[:ssl_verify_mode]
|
128
130
|
else
|
129
131
|
nil
|
130
132
|
end
|
@@ -134,27 +136,27 @@ class Chef
|
|
134
136
|
end
|
135
137
|
end
|
136
138
|
|
137
|
-
if
|
138
|
-
client_rb << %Q{ssl_verify_mode :#{
|
139
|
+
if config[:ssl_verify_mode]
|
140
|
+
client_rb << %Q{ssl_verify_mode :#{config[:ssl_verify_mode]}\n}
|
139
141
|
end
|
140
142
|
|
141
|
-
if
|
142
|
-
client_rb << %Q{http_proxy "#{
|
143
|
-
client_rb << %Q{https_proxy "#{
|
143
|
+
if config[:bootstrap_proxy]
|
144
|
+
client_rb << %Q{http_proxy "#{config[:bootstrap_proxy]}"\n}
|
145
|
+
client_rb << %Q{https_proxy "#{config[:bootstrap_proxy]}"\n}
|
144
146
|
end
|
145
147
|
|
146
|
-
if
|
147
|
-
client_rb << %Q{http_proxy_user "#{
|
148
|
-
client_rb << %Q{https_proxy_user "#{
|
148
|
+
if config[:bootstrap_proxy_user]
|
149
|
+
client_rb << %Q{http_proxy_user "#{config[:bootstrap_proxy_user]}"\n}
|
150
|
+
client_rb << %Q{https_proxy_user "#{config[:bootstrap_proxy_user]}"\n}
|
149
151
|
end
|
150
152
|
|
151
|
-
if
|
152
|
-
client_rb << %Q{http_proxy_pass "#{
|
153
|
-
client_rb << %Q{https_proxy_pass "#{
|
153
|
+
if config[:bootstrap_proxy_pass]
|
154
|
+
client_rb << %Q{http_proxy_pass "#{config[:bootstrap_proxy_pass]}"\n}
|
155
|
+
client_rb << %Q{https_proxy_pass "#{config[:bootstrap_proxy_pass]}"\n}
|
154
156
|
end
|
155
157
|
|
156
|
-
if
|
157
|
-
client_rb << %Q{no_proxy "#{
|
158
|
+
if config[:bootstrap_no_proxy]
|
159
|
+
client_rb << %Q{no_proxy "#{config[:bootstrap_no_proxy]}"\n}
|
158
160
|
end
|
159
161
|
|
160
162
|
if encrypted_data_bag_secret
|
@@ -165,41 +167,43 @@ class Chef
|
|
165
167
|
client_rb << %Q{trusted_certs_dir "/etc/chef/trusted_certs"\n}
|
166
168
|
end
|
167
169
|
|
168
|
-
if
|
170
|
+
if chef_config[:fips]
|
169
171
|
client_rb << "fips true\n"
|
170
172
|
end
|
171
173
|
|
174
|
+
unless chef_config[:file_cache_path].nil?
|
175
|
+
client_rb << "file_cache_path \"#{chef_config[:file_cache_path]}\"\n"
|
176
|
+
end
|
177
|
+
|
178
|
+
unless chef_config[:file_backup_path].nil?
|
179
|
+
client_rb << "file_backup_path \"#{chef_config[:file_backup_path]}\"\n"
|
180
|
+
end
|
181
|
+
|
172
182
|
client_rb
|
173
183
|
end
|
174
184
|
|
175
185
|
def start_chef
|
176
186
|
# If the user doesn't have a client path configure, let bash use the PATH for what it was designed for
|
177
|
-
client_path =
|
187
|
+
client_path = chef_config[:chef_client_path] || "#{Chef::Dist::CLIENT}"
|
178
188
|
s = "#{client_path} -j /etc/chef/first-boot.json"
|
179
|
-
if
|
189
|
+
if config[:verbosity] && config[:verbosity] >= 3
|
180
190
|
s << " -l trace"
|
181
|
-
elsif
|
191
|
+
elsif config[:verbosity] && config[:verbosity] >= 2
|
182
192
|
s << " -l debug"
|
183
193
|
end
|
184
194
|
s << " -E #{bootstrap_environment}" unless bootstrap_environment.nil?
|
185
|
-
s << " --no-color" unless
|
195
|
+
s << " --no-color" unless config[:color]
|
186
196
|
s
|
187
197
|
end
|
188
198
|
|
189
|
-
# XXX: this reads values only out of the config file and is NOT merged with the CLI options, and it is most likely
|
190
|
-
# a bug to be using this accessor and we should be using config and not knife_config.
|
191
|
-
def knife_config
|
192
|
-
@chef_config.key?(:knife) ? @chef_config[:knife] : {}
|
193
|
-
end
|
194
|
-
|
195
199
|
#
|
196
200
|
# Returns the version of Chef to install (as recognized by the Omnitruck API)
|
197
201
|
#
|
198
202
|
# @return [String] download version string
|
199
203
|
def version_to_install
|
200
|
-
return
|
204
|
+
return config[:bootstrap_version] if config[:bootstrap_version]
|
201
205
|
|
202
|
-
if
|
206
|
+
if config[:channel] == "stable"
|
203
207
|
Chef::VERSION.split(".").first
|
204
208
|
else
|
205
209
|
"latest"
|
@@ -207,16 +211,15 @@ class Chef
|
|
207
211
|
end
|
208
212
|
|
209
213
|
def first_boot
|
210
|
-
(
|
211
|
-
if
|
212
|
-
attributes[:policy_name] =
|
213
|
-
attributes[:policy_group] =
|
214
|
+
(config[:first_boot_attributes] = Mash.new(config[:first_boot_attributes]) || Mash.new).tap do |attributes|
|
215
|
+
if config[:policy_name] && config[:policy_group]
|
216
|
+
attributes[:policy_name] = config[:policy_name]
|
217
|
+
attributes[:policy_group] = config[:policy_group]
|
214
218
|
else
|
215
219
|
attributes[:run_list] = @run_list
|
216
220
|
end
|
217
|
-
|
218
221
|
attributes.delete(:run_list) if attributes[:policy_name] && !attributes[:policy_name].empty?
|
219
|
-
attributes.merge!(tags:
|
222
|
+
attributes.merge!(tags: config[:tags]) if config[:tags] && !config[:tags].empty?
|
220
223
|
end
|
221
224
|
end
|
222
225
|
|
@@ -226,8 +229,8 @@ class Chef
|
|
226
229
|
# This string should contain both the commands necessary to both create the files, as well as their content
|
227
230
|
def trusted_certs_content
|
228
231
|
content = ""
|
229
|
-
if
|
230
|
-
Dir.glob(File.join(Chef::Util::PathHelper.escape_glob_dir(
|
232
|
+
if chef_config[:trusted_certs_dir]
|
233
|
+
Dir.glob(File.join(Chef::Util::PathHelper.escape_glob_dir(chef_config[:trusted_certs_dir]), "*.{crt,pem}")).each do |cert|
|
231
234
|
content << "cat > /etc/chef/trusted_certs/#{File.basename(cert)} <<'EOP'\n" +
|
232
235
|
IO.read(File.expand_path(cert)) + "\nEOP\n"
|
233
236
|
end
|
@@ -237,8 +240,8 @@ class Chef
|
|
237
240
|
|
238
241
|
def client_d_content
|
239
242
|
content = ""
|
240
|
-
if
|
241
|
-
root = Pathname(
|
243
|
+
if chef_config[:client_d_dir] && File.exist?(chef_config[:client_d_dir])
|
244
|
+
root = Pathname(chef_config[:client_d_dir])
|
242
245
|
root.find do |f|
|
243
246
|
relative = f.relative_path_from(root)
|
244
247
|
if f != root
|
@@ -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
|
@@ -44,7 +44,7 @@ class Chef
|
|
44
44
|
else
|
45
45
|
commands = manifest[KEY]["plugins_by_category"]
|
46
46
|
end
|
47
|
-
# If any of the specified plugins in the manifest
|
47
|
+
# If any of the specified plugins in the manifest don't have a valid path we will
|
48
48
|
# eventually get an error and the user will need to rehash - instead, lets just
|
49
49
|
# print out 1 error here telling them to rehash
|
50
50
|
errors = {}
|
@@ -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 thing.
|
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)}
|