chef 16.1.0-universal-mingw32 → 16.3.38-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 +6 -7
- data/README.md +3 -3
- data/Rakefile +4 -3
- data/chef-universal-mingw32.gemspec +2 -2
- data/chef.gemspec +7 -6
- data/distro/powershell/chef/chef.psm1 +3 -3
- data/distro/templates/powershell/chef/chef.psm1.erb +3 -3
- data/lib/chef/application.rb +12 -0
- data/lib/chef/application/apply.rb +2 -1
- data/lib/chef/application/base.rb +1 -1
- data/lib/chef/application/client.rb +1 -1
- data/lib/chef/application/windows_service_manager.rb +1 -1
- data/lib/chef/{whitelist.rb → attribute_allowlist.rb} +11 -11
- data/lib/chef/{blacklist.rb → attribute_blocklist.rb} +9 -9
- data/lib/chef/chef_fs/data_handler/data_bag_item_data_handler.rb +1 -1
- data/lib/chef/chef_fs/data_handler/organization_data_handler.rb +1 -2
- 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 +2 -2
- data/lib/chef/chef_fs/file_system/chef_server/cookbooks_dir.rb +1 -5
- data/lib/chef/chef_fs/file_system/repository/base_file.rb +1 -0
- data/lib/chef/chef_fs/file_system/repository/directory.rb +1 -1
- data/lib/chef/chef_fs/parallelizer/parallel_enumerable.rb +2 -2
- data/lib/chef/chef_fs/path_utils.rb +4 -4
- data/lib/chef/client.rb +3 -3
- data/lib/chef/cookbook/chefignore.rb +1 -1
- data/lib/chef/cookbook/file_system_file_vendor.rb +1 -1
- data/lib/chef/cookbook/metadata.rb +2 -2
- data/lib/chef/cookbook/remote_file_vendor.rb +1 -3
- data/lib/chef/cookbook/syntax_check.rb +1 -2
- data/lib/chef/cookbook_loader.rb +16 -30
- data/lib/chef/cookbook_manifest.rb +1 -1
- data/lib/chef/cookbook_site_streaming_uploader.rb +1 -1
- data/lib/chef/cookbook_version.rb +4 -4
- data/lib/chef/data_bag.rb +5 -6
- data/lib/chef/data_collector.rb +1 -1
- data/lib/chef/data_collector/error_handlers.rb +1 -1
- data/lib/chef/decorator/lazy_array.rb +2 -2
- data/lib/chef/deprecated.rb +12 -0
- data/lib/chef/digester.rb +5 -4
- data/lib/chef/dsl/declare_resource.rb +1 -1
- data/lib/chef/dsl/platform_introspection.rb +2 -0
- 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/environment.rb +1 -2
- data/lib/chef/exceptions.rb +3 -0
- data/lib/chef/file_access_control.rb +1 -1
- data/lib/chef/file_access_control/windows.rb +2 -2
- data/lib/chef/file_content_management/deploy/mv_unix.rb +1 -1
- data/lib/chef/formatters/base.rb +1 -1
- data/lib/chef/formatters/error_inspectors/compile_error_inspector.rb +1 -1
- data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +3 -3
- data/lib/chef/http.rb +19 -4
- data/lib/chef/http/authenticator.rb +1 -1
- data/lib/chef/http/decompressor.rb +1 -1
- data/lib/chef/http/http_request.rb +1 -1
- data/lib/chef/http/json_output.rb +1 -1
- data/lib/chef/http/ssl_policies.rb +18 -0
- data/lib/chef/json_compat.rb +1 -1
- data/lib/chef/key.rb +1 -1
- data/lib/chef/knife.rb +6 -6
- data/lib/chef/knife/bootstrap.rb +24 -24
- 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 +9 -9
- data/lib/chef/knife/bootstrap/templates/windows-chef-client-msi.erb +3 -1
- data/lib/chef/knife/bootstrap/train_connector.rb +1 -0
- data/lib/chef/knife/client_bulk_delete.rb +1 -1
- data/lib/chef/knife/config_get.rb +2 -1
- data/lib/chef/knife/config_list_profiles.rb +4 -1
- data/lib/chef/knife/config_use_profile.rb +15 -5
- data/lib/chef/knife/configure.rb +1 -1
- data/lib/chef/knife/cookbook_delete.rb +1 -1
- data/lib/chef/knife/cookbook_upload.rb +6 -14
- data/lib/chef/knife/core/bootstrap_context.rb +1 -1
- data/lib/chef/knife/core/cookbook_scm_repo.rb +1 -1
- data/lib/chef/knife/core/gem_glob_loader.rb +1 -1
- data/lib/chef/knife/core/hashed_command_loader.rb +2 -1
- data/lib/chef/knife/core/node_presenter.rb +1 -1
- data/lib/chef/knife/core/status_presenter.rb +1 -1
- data/lib/chef/knife/core/subcommand_loader.rb +21 -2
- data/lib/chef/knife/core/ui.rb +8 -2
- data/lib/chef/knife/core/windows_bootstrap_context.rb +18 -4
- data/lib/chef/knife/data_bag_create.rb +1 -1
- data/lib/chef/knife/key_create_base.rb +1 -1
- data/lib/chef/knife/key_edit_base.rb +1 -1
- data/lib/chef/knife/node_bulk_delete.rb +1 -1
- data/lib/chef/knife/node_run_list_remove.rb +1 -1
- data/lib/chef/knife/rehash.rb +3 -21
- data/lib/chef/knife/role_bulk_delete.rb +1 -1
- data/lib/chef/knife/ssh.rb +7 -3
- data/lib/chef/knife/supermarket_share.rb +1 -1
- data/lib/chef/knife/supermarket_unshare.rb +1 -1
- data/lib/chef/log.rb +8 -3
- data/lib/chef/mixin/api_version_request_handling.rb +1 -1
- data/lib/chef/mixin/checksum.rb +0 -1
- data/{spec/functional/resource/base.rb → lib/chef/mixin/chef_utils_wiring.rb} +24 -12
- data/{spec/unit/log_spec.rb → lib/chef/mixin/default_paths.rb} +13 -5
- data/lib/chef/mixin/openssl_helper.rb +31 -9
- data/lib/chef/mixin/path_sanity.rb +5 -4
- data/lib/chef/mixin/properties.rb +2 -2
- data/lib/chef/mixin/securable.rb +2 -2
- data/lib/chef/mixin/shell_out.rb +4 -188
- data/lib/chef/mixin/template.rb +1 -0
- data/lib/chef/mixin/which.rb +6 -3
- data/lib/chef/mixins.rb +1 -0
- data/lib/chef/node.rb +36 -12
- data/lib/chef/node/attribute.rb +2 -2
- data/lib/chef/node/immutable_collections.rb +1 -1
- data/lib/chef/node_map.rb +21 -18
- data/lib/chef/platform/service_helpers.rb +31 -28
- data/lib/chef/policy_builder/policyfile.rb +1 -1
- data/lib/chef/powershell.rb +1 -1
- data/lib/chef/property.rb +2 -2
- data/lib/chef/provider.rb +3 -3
- data/lib/chef/provider/batch.rb +3 -10
- data/lib/chef/provider/cron.rb +2 -14
- data/lib/chef/provider/directory.rb +1 -1
- data/lib/chef/provider/execute.rb +2 -1
- data/lib/chef/provider/file.rb +1 -1
- data/lib/chef/provider/git.rb +12 -4
- data/lib/chef/provider/group/dscl.rb +2 -2
- data/lib/chef/provider/group/windows.rb +1 -1
- data/lib/chef/provider/ifconfig.rb +7 -7
- data/lib/chef/provider/mount/aix.rb +1 -1
- data/lib/chef/provider/mount/solaris.rb +0 -1
- data/lib/chef/provider/mount/windows.rb +2 -2
- data/lib/chef/provider/noop.rb +1 -1
- data/lib/chef/provider/package/chocolatey.rb +1 -1
- data/lib/chef/provider/package/dpkg.rb +1 -1
- data/lib/chef/provider/package/openbsd.rb +1 -1
- data/lib/chef/provider/package/portage.rb +3 -2
- data/lib/chef/provider/package/powershell.rb +6 -2
- data/lib/chef/provider/package/rubygems.rb +3 -3
- data/lib/chef/provider/package/snap.rb +97 -29
- data/lib/chef/provider/package/windows.rb +11 -6
- data/lib/chef/provider/package/windows/msi.rb +3 -3
- data/lib/chef/provider/package/windows/registry_uninstall_entry.rb +1 -1
- data/lib/chef/provider/package/yum.rb +1 -1
- 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 +10 -14
- data/lib/chef/provider/remote_directory.rb +2 -2
- data/lib/chef/provider/remote_file/http.rb +4 -1
- data/lib/chef/provider/script.rb +4 -75
- data/lib/chef/provider/service.rb +2 -2
- data/lib/chef/provider/service/arch.rb +2 -2
- data/lib/chef/provider/service/debian.rb +2 -2
- data/lib/chef/provider/service/openbsd.rb +4 -4
- data/lib/chef/provider/service/redhat.rb +1 -1
- data/lib/chef/provider/service/upstart.rb +1 -1
- data/lib/chef/provider/service/windows.rb +1 -1
- data/lib/chef/provider/subversion.rb +2 -2
- data/lib/chef/provider/user/aix.rb +1 -1
- data/lib/chef/provider/user/dscl.rb +6 -6
- data/lib/chef/provider/user/linux.rb +3 -3
- data/lib/chef/provider/user/mac.rb +15 -11
- data/lib/chef/provider/windows_script.rb +87 -25
- data/lib/chef/provider/windows_task.rb +4 -2
- data/lib/chef/provider/yum_repository.rb +1 -1
- data/lib/chef/provider/zypper_repository.rb +31 -11
- data/lib/chef/resource.rb +27 -14
- data/lib/chef/resource/alternatives.rb +1 -1
- data/lib/chef/resource/apt_package.rb +1 -1
- data/lib/chef/resource/archive_file.rb +28 -8
- data/lib/chef/resource/bash.rb +0 -1
- data/lib/chef/resource/batch.rb +4 -2
- data/lib/chef/resource/build_essential.rb +2 -2
- data/lib/chef/resource/chef_client_scheduled_task.rb +14 -2
- data/lib/chef/resource/chef_gem.rb +57 -21
- data/lib/chef/resource/chef_handler.rb +2 -2
- data/lib/chef/resource/chef_vault_secret.rb +1 -1
- data/lib/chef/resource/chocolatey_feature.rb +1 -2
- data/lib/chef/resource/cron/_cron_shared.rb +98 -0
- data/lib/chef/resource/cron/cron.rb +46 -0
- data/lib/chef/resource/{cron_d.rb → cron/cron_d.rb} +7 -87
- data/lib/chef/resource/cron_access.rb +13 -5
- data/lib/chef/resource/csh.rb +0 -1
- data/lib/chef/resource/dmg_package.rb +2 -2
- data/lib/chef/resource/execute.rb +480 -10
- data/lib/chef/resource/file.rb +10 -8
- data/lib/chef/resource/freebsd_package.rb +1 -1
- data/lib/chef/resource/gem_package.rb +35 -2
- data/lib/chef/resource/helpers/cron_validations.rb +6 -3
- data/lib/chef/resource/homebrew_package.rb +30 -1
- data/lib/chef/resource/homebrew_update.rb +107 -0
- data/lib/chef/resource/hostname.rb +7 -20
- data/lib/chef/resource/kernel_module.rb +14 -1
- data/lib/chef/resource/launchd.rb +1 -1
- data/lib/chef/resource/locale.rb +3 -3
- data/lib/chef/resource/lwrp_base.rb +1 -0
- data/lib/chef/resource/macos_userdefaults.rb +176 -56
- data/lib/chef/resource/mount.rb +1 -1
- data/lib/chef/resource/openssl_x509_certificate.rb +11 -14
- data/lib/chef/resource/openssl_x509_crl.rb +1 -2
- data/lib/chef/resource/perl.rb +0 -1
- data/lib/chef/resource/plist.rb +23 -4
- data/lib/chef/resource/powershell_script.rb +4 -2
- data/lib/chef/resource/python.rb +0 -1
- data/lib/chef/resource/remote_file.rb +26 -10
- data/lib/chef/resource/ruby.rb +0 -1
- data/lib/chef/resource/scm/git.rb +1 -1
- data/lib/chef/resource/service.rb +2 -2
- data/lib/chef/resource/ssh_known_hosts_entry.rb +16 -1
- data/lib/chef/resource/sudo.rb +30 -3
- data/lib/chef/resource/swap_file.rb +17 -0
- data/lib/chef/resource/template.rb +1 -1
- data/lib/chef/resource/timezone.rb +15 -0
- data/lib/chef/resource/user_ulimit.rb +1 -1
- data/lib/chef/resource/windows_ad_join.rb +30 -1
- data/lib/chef/resource/windows_audit_policy.rb +227 -0
- data/lib/chef/resource/windows_auto_run.rb +11 -0
- data/lib/chef/resource/windows_certificate.rb +27 -1
- data/lib/chef/resource/windows_dfs_server.rb +1 -1
- data/lib/chef/resource/windows_dns_record.rb +17 -0
- data/lib/chef/resource/windows_firewall_profile.rb +197 -0
- data/lib/chef/resource/windows_font.rb +3 -3
- data/lib/chef/resource/windows_package.rb +1 -1
- data/lib/chef/resource/windows_pagefile.rb +2 -2
- data/lib/chef/resource/windows_script.rb +2 -16
- data/lib/chef/resource/windows_security_policy.rb +67 -36
- data/lib/chef/resource/windows_shortcut.rb +1 -2
- data/lib/chef/resource/windows_task.rb +10 -10
- data/lib/chef/resource/windows_user_privilege.rb +33 -10
- data/lib/chef/resource/yum_repository.rb +9 -9
- data/lib/chef/resource_inspector.rb +11 -4
- data/lib/chef/resources.rb +5 -2
- data/lib/chef/role.rb +1 -2
- data/lib/chef/run_context/cookbook_compiler.rb +1 -1
- data/lib/chef/search/query.rb +1 -1
- data/lib/chef/shell/ext.rb +1 -1
- data/lib/chef/shell/shell_session.rb +2 -0
- data/lib/chef/util/diff.rb +2 -3
- data/lib/chef/util/windows/net_user.rb +1 -1
- data/lib/chef/util/windows/volume.rb +1 -1
- data/lib/chef/version.rb +2 -2
- 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/file.rb +1 -1
- data/lib/chef/win32/mutex.rb +1 -1
- data/lib/chef/win32/net.rb +1 -0
- data/lib/chef/win32/registry.rb +3 -4
- data/lib/chef/win32/security.rb +1 -1
- data/lib/chef/win32/security/sid.rb +4 -4
- data/spec/data/lwrp/providers/buck_passer.rb +1 -1
- data/spec/data/lwrp/providers/buck_passer_2.rb +1 -1
- data/spec/data/lwrp/providers/embedded_resource_accesses_providers_scope.rb +1 -1
- data/spec/functional/knife/configure_spec.rb +1 -1
- data/spec/functional/knife/ssh_spec.rb +5 -16
- data/spec/functional/resource/aix_service_spec.rb +9 -2
- data/spec/functional/resource/aixinit_service_spec.rb +1 -2
- data/spec/functional/resource/apt_package_spec.rb +0 -1
- data/spec/functional/resource/bash_spec.rb +3 -2
- data/spec/functional/resource/bff_spec.rb +1 -1
- data/spec/functional/resource/chocolatey_package_spec.rb +4 -0
- data/spec/functional/resource/cron_spec.rb +20 -2
- data/spec/functional/resource/dnf_package_spec.rb +6 -3
- data/spec/functional/resource/execute_spec.rb +1 -1
- data/spec/functional/resource/git_spec.rb +29 -7
- data/spec/functional/resource/group_spec.rb +15 -3
- data/spec/functional/resource/ifconfig_spec.rb +9 -1
- data/spec/functional/resource/insserv_spec.rb +3 -3
- data/spec/functional/resource/link_spec.rb +2 -5
- data/spec/functional/resource/mount_spec.rb +9 -1
- data/spec/functional/resource/msu_package_spec.rb +9 -3
- data/spec/functional/resource/powershell_script_spec.rb +4 -4
- data/spec/functional/resource/remote_file_spec.rb +9 -15
- data/spec/functional/resource/rpm_spec.rb +1 -1
- data/spec/functional/resource/timezone_spec.rb +2 -0
- data/spec/functional/resource/windows_package_spec.rb +0 -1
- data/spec/functional/resource/windows_path_spec.rb +4 -0
- data/spec/functional/resource/windows_security_policy_spec.rb +0 -1
- data/spec/functional/resource/windows_service_spec.rb +4 -0
- data/spec/functional/resource/windows_task_spec.rb +16 -15
- data/spec/functional/resource/windows_user_privilege_spec.rb +1 -2
- data/spec/functional/resource/yum_package_spec.rb +4 -1
- data/spec/functional/resource/zypper_package_spec.rb +4 -1
- data/spec/functional/run_lock_spec.rb +2 -1
- data/spec/functional/shell_spec.rb +5 -6
- data/spec/functional/util/powershell/cmdlet_spec.rb +1 -1
- data/spec/functional/version_spec.rb +1 -1
- data/spec/functional/win32/crypto_spec.rb +1 -1
- data/spec/integration/knife/config_list_profiles_spec.rb +30 -2
- data/spec/integration/knife/config_use_profile_spec.rb +55 -2
- data/spec/integration/knife/cookbook_upload_spec.rb +28 -1
- data/spec/integration/knife/data_bag_from_file_spec.rb +1 -1
- data/spec/integration/knife/environment_from_file_spec.rb +1 -1
- data/spec/integration/knife/node_from_file_spec.rb +1 -1
- data/spec/integration/knife/role_from_file_spec.rb +1 -1
- data/spec/integration/recipes/accumulator_spec.rb +1 -1
- data/spec/integration/recipes/lwrp_inline_resources_spec.rb +1 -1
- data/spec/integration/recipes/lwrp_spec.rb +1 -1
- data/spec/integration/recipes/notifies_spec.rb +1 -1
- data/spec/integration/recipes/notifying_block_spec.rb +1 -1
- data/spec/integration/recipes/recipe_dsl_spec.rb +5 -1
- data/spec/integration/recipes/resource_converge_if_changed_spec.rb +2 -0
- data/spec/integration/recipes/resource_load_spec.rb +4 -2
- data/spec/integration/recipes/unified_mode_spec.rb +1 -1
- data/spec/integration/recipes/use_partial_spec.rb +1 -1
- data/spec/scripts/ssl-serve.rb +1 -1
- data/spec/spec_helper.rb +10 -4
- data/spec/support/chef_helpers.rb +2 -21
- data/spec/support/platform_helpers.rb +1 -3
- data/spec/support/platforms/win32/spec_service.rb +1 -1
- data/spec/support/shared/functional/execute_resource.rb +1 -1
- data/spec/support/shared/functional/file_resource.rb +0 -1
- data/spec/support/shared/functional/securable_resource.rb +1 -2
- data/spec/support/shared/functional/securable_resource_with_reporting.rb +0 -1
- data/spec/support/shared/functional/windows_script.rb +3 -3
- data/spec/support/shared/integration/knife_support.rb +2 -9
- data/spec/support/shared/unit/application_dot_d.rb +0 -1
- data/spec/support/shared/unit/execute_resource.rb +1 -1
- data/spec/support/shared/unit/provider/file.rb +12 -8
- data/spec/support/shared/unit/provider/useradd_based_user_provider.rb +4 -4
- data/spec/unit/application/solo_spec.rb +4 -2
- data/spec/unit/application_spec.rb +11 -2
- data/spec/unit/chef_fs/config_spec.rb +2 -2
- data/spec/unit/chef_fs/diff_spec.rb +8 -8
- data/spec/unit/chef_fs/file_system/operation_failed_error_spec.rb +2 -4
- data/spec/unit/chef_fs/{parallelizer.rb → parallelizer_spec.rb} +1 -1
- data/spec/unit/client_spec.rb +4 -1
- data/spec/unit/cookbook/gem_installer_spec.rb +2 -1
- data/spec/unit/cookbook/synchronizer_spec.rb +26 -24
- data/spec/unit/data_bag_spec.rb +6 -3
- data/spec/unit/data_collector_spec.rb +1 -1
- data/spec/unit/decorator_spec.rb +23 -23
- data/spec/unit/dsl/platform_introspection_spec.rb +1 -0
- data/spec/unit/environment_spec.rb +5 -1
- data/spec/unit/event_dispatch/dispatcher_spec.rb +3 -0
- data/spec/unit/guard_interpreter_spec.rb +1 -1
- data/spec/unit/http/api_versions_spec.rb +1 -1
- data/spec/unit/http/ssl_policies_spec.rb +20 -0
- data/spec/unit/json_compat_spec.rb +1 -1
- data/spec/unit/knife/bootstrap_spec.rb +5 -8
- data/spec/unit/knife/cookbook_download_spec.rb +2 -2
- data/spec/unit/knife/cookbook_show_spec.rb +6 -7
- data/spec/unit/knife/cookbook_upload_spec.rb +7 -10
- data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +7 -1
- data/spec/unit/knife/data_bag_edit_spec.rb +1 -1
- data/spec/unit/log/syslog_spec.rb +6 -10
- data/spec/unit/log/winevt_spec.rb +21 -13
- data/spec/unit/lwrp_spec.rb +9 -6
- data/spec/unit/mixin/{path_sanity_spec.rb → default_paths_spec.rb} +14 -14
- data/spec/unit/mixin/openssl_helper_spec.rb +4 -4
- data/spec/unit/mixin/powershell_exec_spec.rb +1 -1
- data/spec/unit/mixin/powershell_out_spec.rb +2 -4
- data/spec/unit/mixin/powershell_type_coercions_spec.rb +1 -1
- data/spec/unit/mixin/securable_spec.rb +0 -1
- data/spec/unit/mixin/shell_out_spec.rb +25 -26
- data/spec/unit/mixin/subclass_directive_spec.rb +2 -2
- data/spec/unit/mixin/unformatter_spec.rb +2 -2
- data/spec/unit/mixin/uris_spec.rb +1 -1
- data/spec/unit/mixin/user_context_spec.rb +1 -9
- data/spec/unit/mixin/which.rb +8 -0
- data/spec/unit/node/attribute_spec.rb +1 -1
- data/spec/unit/node_spec.rb +98 -11
- data/spec/unit/property_spec.rb +6 -6
- data/spec/unit/provider/batch_spec.rb +130 -0
- data/spec/unit/provider/cron/unix_spec.rb +1 -1
- data/spec/unit/provider/cron_spec.rb +9 -49
- data/spec/unit/provider/dsc_resource_spec.rb +22 -38
- data/spec/unit/provider/dsc_script_spec.rb +10 -10
- data/spec/unit/provider/execute_spec.rb +1 -8
- data/spec/unit/provider/git_spec.rb +3 -3
- data/spec/unit/provider/group/groupadd_spec.rb +1 -1
- data/spec/unit/provider/ifconfig_spec.rb +0 -1
- data/spec/unit/provider/mdadm_spec.rb +1 -3
- data/spec/unit/provider/package/dnf/python_helper_spec.rb +1 -1
- data/spec/unit/provider/package/openbsd_spec.rb +1 -1
- data/spec/unit/provider/package/pacman_spec.rb +17 -20
- data/spec/unit/provider/package/portage_spec.rb +2 -2
- data/spec/unit/provider/package/powershell_spec.rb +96 -87
- data/spec/unit/provider/package/rubygems_spec.rb +5 -10
- data/spec/unit/provider/package/smartos_spec.rb +1 -1
- data/spec/unit/provider/package/snap_spec.rb +1 -1
- data/spec/unit/provider/package/windows/registry_uninstall_entry_spec.rb +3 -3
- data/spec/unit/provider/package/windows_spec.rb +30 -53
- data/spec/unit/provider/powershell_script_spec.rb +3 -45
- data/spec/unit/provider/script_spec.rb +20 -110
- data/spec/unit/provider/service/redhat_spec.rb +1 -1
- data/spec/unit/provider/service/windows_spec.rb +2 -6
- data/spec/unit/provider/systemd_unit_spec.rb +28 -24
- data/spec/unit/provider/user/dscl_spec.rb +2 -2
- data/spec/unit/provider/windows_env_spec.rb +5 -4
- data/spec/unit/provider/zypper_repository_spec.rb +60 -10
- data/spec/unit/provider_spec.rb +1 -0
- data/spec/unit/resource/archive_file_spec.rb +11 -2
- data/spec/unit/resource/chef_client_cron_spec.rb +23 -7
- data/spec/unit/resource/chef_client_scheduled_task_spec.rb +17 -7
- data/spec/unit/resource/chef_client_systemd_timer_spec.rb +7 -4
- data/spec/unit/resource/cron_spec.rb +2 -2
- data/spec/unit/resource/execute_spec.rb +10 -0
- data/spec/unit/resource/file/verification_spec.rb +2 -1
- data/spec/unit/resource/helpers/cron_validations_spec.rb +5 -1
- data/spec/unit/resource/homebrew_update_spec.rb +30 -0
- data/spec/unit/resource/macos_user_defaults_spec.rb +103 -2
- data/spec/unit/resource/powershell_script_spec.rb +10 -15
- data/spec/unit/resource/timezone_spec.rb +1 -1
- data/spec/unit/resource/windows_audit_policy_spec.rb +64 -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_firewall_profile_spec.rb +77 -0
- data/spec/unit/resource/windows_package_spec.rb +1 -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 -1
- data/spec/unit/resource_spec.rb +84 -1
- data/spec/unit/role_spec.rb +23 -21
- data/spec/unit/run_context/cookbook_compiler_spec.rb +1 -1
- data/spec/unit/run_lock_spec.rb +1 -1
- data/spec/unit/scan_access_control_spec.rb +1 -1
- data/spec/unit/util/backup_spec.rb +1 -1
- data/spec/unit/util/diff_spec.rb +1 -15
- data/spec/unit/util/dsc/configuration_generator_spec.rb +1 -1
- data/spec/unit/util/powershell/ps_credential_spec.rb +2 -2
- data/spec/unit/util/selinux_spec.rb +2 -1
- data/spec/unit/util/threaded_job_queue_spec.rb +9 -0
- data/spec/unit/win32/registry_spec.rb +1 -1
- data/spec/unit/win32/security_spec.rb +4 -3
- metadata +68 -40
- data/lib/chef/resource/cron.rb +0 -157
@@ -145,7 +145,7 @@ class Chef
|
|
145
145
|
|
146
146
|
def each_with_exceptions_unordered
|
147
147
|
if @each_running
|
148
|
-
raise "each() called on parallel enumerable twice simultaneously!
|
148
|
+
raise "each() called on parallel enumerable twice simultaneously! Bad mojo"
|
149
149
|
end
|
150
150
|
|
151
151
|
@each_running = true
|
@@ -235,7 +235,7 @@ class Chef
|
|
235
235
|
# The order of these checks is important, as well, to be thread safe.
|
236
236
|
# 1. If @unconsumed_input.empty? is true, then we will never have any more
|
237
237
|
# work legitimately picked up.
|
238
|
-
# 2. If @in_process == 0, then there is no work in process, and because
|
238
|
+
# 2. If @in_process == 0, then there is no work in process, and because of when unconsumed_input is empty, it will never go back up, because
|
239
239
|
# this is called after the input enumerator is finished. Note that switching #2 and #1
|
240
240
|
# could cause a race, because in_process is incremented *before* consuming input.
|
241
241
|
# 3. If @unconsumed_output.empty? is true, then we are done with outputs.
|
@@ -71,9 +71,9 @@ class Chef
|
|
71
71
|
# part that actually exists. The paths operated on here are not Chef-FS paths.
|
72
72
|
# These are OS paths that may contain symlinks but may not also fully exist.
|
73
73
|
#
|
74
|
-
# If /x is a symlink to /
|
75
|
-
# PathUtils.realest_path('/x/y/z') == '/
|
76
|
-
# PathUtils.realest_path('/x/*/z') == '/
|
74
|
+
# If /x is a symlink to /foo_bar, and has no subdirectories, then:
|
75
|
+
# PathUtils.realest_path('/x/y/z') == '/foo_bar/y/z'
|
76
|
+
# PathUtils.realest_path('/x/*/z') == '/foo_bar/*/z'
|
77
77
|
# PathUtils.realest_path('/*/y/z') == '/*/y/z'
|
78
78
|
#
|
79
79
|
# TODO: Move this to wherever util/path_helper is these days.
|
@@ -118,7 +118,7 @@ class Chef
|
|
118
118
|
|
119
119
|
if ancestor.length == path.length
|
120
120
|
""
|
121
|
-
elsif path[ancestor.length, 1]
|
121
|
+
elsif /#{PathUtils.regexp_path_separator}/.match?(path[ancestor.length, 1])
|
122
122
|
path[ancestor.length + 1..-1]
|
123
123
|
else
|
124
124
|
nil
|
data/lib/chef/client.rb
CHANGED
@@ -20,7 +20,7 @@
|
|
20
20
|
|
21
21
|
require_relative "config"
|
22
22
|
require_relative "mixin/params_validate"
|
23
|
-
require "chef-utils/dsl/
|
23
|
+
require "chef-utils/dsl/default_paths" unless defined?(ChefUtils::DSL::DefaultPaths)
|
24
24
|
require_relative "log"
|
25
25
|
require_relative "deprecated"
|
26
26
|
require_relative "server_api"
|
@@ -250,7 +250,7 @@ class Chef
|
|
250
250
|
logger.info "#{Chef::Dist::CLIENT.capitalize} pid: #{Process.pid}"
|
251
251
|
logger.info "Targeting node: #{Chef::Config.target_mode.host}" if Chef::Config.target_mode?
|
252
252
|
logger.debug("#{Chef::Dist::CLIENT.capitalize} request_id: #{request_id}")
|
253
|
-
ENV["PATH"] = ChefUtils::DSL::
|
253
|
+
ENV["PATH"] = ChefUtils::DSL::DefaultPaths.default_paths if Chef::Config[:enforce_default_paths] || Chef::Config[:enforce_path_sanity]
|
254
254
|
|
255
255
|
if Chef::Config.target_mode?
|
256
256
|
get_ohai_data_remotely
|
@@ -343,7 +343,7 @@ class Chef
|
|
343
343
|
formatters_for_run.map do |formatter_name, output_path|
|
344
344
|
if output_path.nil?
|
345
345
|
Chef::Formatters.new(formatter_name, STDOUT_FD, STDERR_FD)
|
346
|
-
|
346
|
+
elsif output_path.is_a?(String)
|
347
347
|
io = File.open(output_path, "a+")
|
348
348
|
io.sync = true
|
349
349
|
Chef::Formatters.new(formatter_name, io, io)
|
@@ -50,7 +50,7 @@ class Chef
|
|
50
50
|
ignore_globs = []
|
51
51
|
if @ignore_file && readable_file_or_symlink?(@ignore_file)
|
52
52
|
File.foreach(@ignore_file) do |line|
|
53
|
-
ignore_globs << line.strip unless line
|
53
|
+
ignore_globs << line.strip unless COMMENTS_AND_WHITESPACE.match?(line)
|
54
54
|
end
|
55
55
|
else
|
56
56
|
Chef::Log.debug("No chefignore file found. No files will be ignored!")
|
@@ -27,7 +27,7 @@ class Chef
|
|
27
27
|
# and throws the rest away then re-builds the list of files on the
|
28
28
|
# disk. This is due to the manifest not having the on-disk file
|
29
29
|
# locations, since in the chef-client case, that information is
|
30
|
-
#
|
30
|
+
# nonsensical.
|
31
31
|
class FileSystemFileVendor < FileVendor
|
32
32
|
|
33
33
|
attr_reader :cookbook_name
|
@@ -357,7 +357,7 @@ class Chef
|
|
357
357
|
# Array<String> - array of files or globs to eagerly load, otherwise it is treated like `false`
|
358
358
|
#
|
359
359
|
# @params arg [Array,String,TrueClass,FalseClass]
|
360
|
-
# @params [Array,TrueClass,
|
360
|
+
# @params [Array,TrueClass,FalseClass]
|
361
361
|
def eager_load_libraries(arg = nil)
|
362
362
|
set_or_return(
|
363
363
|
:eager_load_libraries,
|
@@ -391,7 +391,7 @@ class Chef
|
|
391
391
|
def recipes_from_cookbook_version(cookbook)
|
392
392
|
cookbook.fully_qualified_recipe_names.map do |recipe_name|
|
393
393
|
unqualified_name =
|
394
|
-
if
|
394
|
+
if /::default$/.match?(recipe_name)
|
395
395
|
name.to_s
|
396
396
|
else
|
397
397
|
recipe_name
|
@@ -72,10 +72,8 @@ class Chef
|
|
72
72
|
Chef::Log.trace("Current checksum: #{current_checksum}; manifest checksum: #{found_manifest_record["checksum"]})")
|
73
73
|
end
|
74
74
|
|
75
|
-
full_path_cache_filename = Chef::FileCache.load(cache_filename, false)
|
76
|
-
|
77
75
|
# return the filename, not the contents (second argument= false)
|
78
|
-
|
76
|
+
Chef::FileCache.load(cache_filename, false)
|
79
77
|
end
|
80
78
|
|
81
79
|
def validate_cached_copy(cache_filename)
|
@@ -120,8 +120,7 @@ class Chef
|
|
120
120
|
path = Chef::Util::PathHelper.escape_glob_dir(cookbook_path)
|
121
121
|
files = Dir[File.join(path, "**", "*.rb")]
|
122
122
|
files = remove_ignored_files(files)
|
123
|
-
|
124
|
-
files
|
123
|
+
remove_uninteresting_ruby_files(files)
|
125
124
|
end
|
126
125
|
|
127
126
|
def untested_ruby_files
|
data/lib/chef/cookbook_loader.rb
CHANGED
@@ -44,14 +44,11 @@ class Chef
|
|
44
44
|
# @return [Array<String>] the array of repo paths containing cookbook dirs
|
45
45
|
attr_reader :repo_paths
|
46
46
|
|
47
|
-
attr_accessor :tmp_working_dir_path
|
48
|
-
|
49
47
|
# XXX: this is highly questionable combined with the Hash-style each method
|
50
48
|
include Enumerable
|
51
49
|
|
52
50
|
# @param repo_paths [Array<String>] the array of repo paths containing cookbook dirs
|
53
51
|
def initialize(*repo_paths)
|
54
|
-
@tmp_working_dir_path = nil
|
55
52
|
@repo_paths = repo_paths.flatten.compact.map { |p| File.expand_path(p) }
|
56
53
|
raise ArgumentError, "You must specify at least one cookbook repo path" if @repo_paths.empty?
|
57
54
|
end
|
@@ -138,29 +135,25 @@ class Chef
|
|
138
135
|
cookbooks_by_name.values
|
139
136
|
end
|
140
137
|
|
141
|
-
# This method creates tmp directory and copies all cookbooks into it and creates cookbook
|
138
|
+
# This method creates tmp directory and copies all cookbooks into it and creates cookbook loader object which points to tmp directory
|
142
139
|
def self.copy_to_tmp_dir_from_array(cookbooks)
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
dest = File.join(@tmp_working_dir_path, cookbook.name.to_s, path_in_cookbook)
|
154
|
-
FileUtils.mkdir_p(File.dirname(dest))
|
155
|
-
FileUtils.cp_r(on_disk_path, dest)
|
140
|
+
Dir.mktmpdir do |tmp_dir|
|
141
|
+
cookbooks.each do |cookbook|
|
142
|
+
checksums_to_on_disk_paths = cookbook.checksums
|
143
|
+
cookbook.each_file do |manifest_record|
|
144
|
+
path_in_cookbook = manifest_record[:path]
|
145
|
+
on_disk_path = checksums_to_on_disk_paths[manifest_record[:checksum]]
|
146
|
+
dest = File.join(tmp_dir, cookbook.name.to_s, path_in_cookbook)
|
147
|
+
FileUtils.mkdir_p(File.dirname(dest))
|
148
|
+
FileUtils.cp_r(on_disk_path, dest)
|
149
|
+
end
|
156
150
|
end
|
151
|
+
tmp_cookbook_loader ||= begin
|
152
|
+
Chef::Cookbook::FileVendor.fetch_from_disk(tmp_dir)
|
153
|
+
CookbookLoader.new(tmp_dir)
|
154
|
+
end
|
155
|
+
yield tmp_cookbook_loader
|
157
156
|
end
|
158
|
-
tmp_cookbook_loader ||= begin
|
159
|
-
Chef::Cookbook::FileVendor.fetch_from_disk(@tmp_working_dir_path)
|
160
|
-
CookbookLoader.new(@tmp_working_dir_path)
|
161
|
-
end
|
162
|
-
tmp_cookbook_loader.tmp_working_dir_path = @tmp_working_dir_path
|
163
|
-
tmp_cookbook_loader
|
164
157
|
end
|
165
158
|
|
166
159
|
# generates metadata.json adds it in the manifest
|
@@ -181,13 +174,6 @@ class Chef
|
|
181
174
|
end
|
182
175
|
end
|
183
176
|
|
184
|
-
# removes the tmp_dir_path
|
185
|
-
def unlink!
|
186
|
-
raise "Invalid directory path." if @tmp_working_dir_path.nil?
|
187
|
-
|
188
|
-
FileUtils.rm_rf(@tmp_working_dir_path)
|
189
|
-
end
|
190
|
-
|
191
177
|
alias :cookbooks :values
|
192
178
|
|
193
179
|
private
|
@@ -44,7 +44,7 @@ class Chef
|
|
44
44
|
# cookbook_version in the "manifest" format, or #to_json to get a JSON
|
45
45
|
# representation of the cookbook_version.
|
46
46
|
#
|
47
|
-
# The
|
47
|
+
# The interface for this behavior is expected to change as we implement new
|
48
48
|
# manifest formats. The entire class should be considered a private API for
|
49
49
|
# now.
|
50
50
|
#
|
@@ -147,7 +147,7 @@ class Chef
|
|
147
147
|
class << res
|
148
148
|
alias :to_s :body
|
149
149
|
|
150
|
-
#
|
150
|
+
# BUG this makes the response compatible with what response_steps expects to test headers (response.headers[] -> response[])
|
151
151
|
def headers # rubocop:disable Lint/NestedMethodDefinition
|
152
152
|
self
|
153
153
|
end
|
@@ -358,7 +358,7 @@ class Chef
|
|
358
358
|
|
359
359
|
# extract the preference part from the path.
|
360
360
|
if manifest_record_path =~ %r{(#{Regexp.escape(segment.to_s)}/[^/]+/#{Regexp.escape(dirname)})/.+$}
|
361
|
-
# Note the
|
361
|
+
# Note the specificity_dirname includes the segment and
|
362
362
|
# dirname argument as above, which is what
|
363
363
|
# preferences_for_path returns. It could be
|
364
364
|
# "files/ubuntu-9.10/dirname", for example.
|
@@ -392,7 +392,7 @@ class Chef
|
|
392
392
|
platform, version = Chef::Platform.find_platform_and_version(node)
|
393
393
|
rescue ArgumentError => e
|
394
394
|
# Skip platform/version if they were not found by find_platform_and_version
|
395
|
-
if
|
395
|
+
if /Cannot find a (?:platform|version)/.match?(e.message)
|
396
396
|
platform = "/unknown_platform/"
|
397
397
|
version = "/unknown_platform_version/"
|
398
398
|
else
|
@@ -527,7 +527,7 @@ class Chef
|
|
527
527
|
cb["version"]
|
528
528
|
end
|
529
529
|
rescue Net::HTTPClientException => e
|
530
|
-
if e.to_s
|
530
|
+
if /^404/.match?(e.to_s)
|
531
531
|
Chef::Log.error("Cannot find a cookbook named #{cookbook_name}")
|
532
532
|
nil
|
533
533
|
else
|
@@ -566,7 +566,7 @@ class Chef
|
|
566
566
|
def find_preferred_manifest_record(node, segment, filename)
|
567
567
|
preferences = preferences_for_path(node, segment, filename)
|
568
568
|
|
569
|
-
# in order of
|
569
|
+
# in order of preference, look for the filename in the manifest
|
570
570
|
preferences.find { |preferred_filename| manifest_records_by_path[preferred_filename] }
|
571
571
|
end
|
572
572
|
|
data/lib/chef/data_bag.rb
CHANGED
@@ -36,10 +36,10 @@ class Chef
|
|
36
36
|
RESERVED_NAMES = /^(node|role|environment|client)$/.freeze
|
37
37
|
|
38
38
|
def self.validate_name!(name)
|
39
|
-
unless name
|
39
|
+
unless VALID_NAME.match?(name)
|
40
40
|
raise Exceptions::InvalidDataBagName, "DataBags must have a name matching #{VALID_NAME.inspect}, you gave #{name.inspect}"
|
41
41
|
end
|
42
|
-
if name
|
42
|
+
if RESERVED_NAMES.match?(name)
|
43
43
|
raise Exceptions::InvalidDataBagName, "DataBags may not have a name matching #{RESERVED_NAMES.inspect}, you gave #{name.inspect}"
|
44
44
|
end
|
45
45
|
end
|
@@ -59,12 +59,11 @@ class Chef
|
|
59
59
|
end
|
60
60
|
|
61
61
|
def to_h
|
62
|
-
|
62
|
+
{
|
63
63
|
"name" => @name,
|
64
64
|
"json_class" => self.class.name,
|
65
65
|
"chef_type" => "data_bag",
|
66
66
|
}
|
67
|
-
result
|
68
67
|
end
|
69
68
|
|
70
69
|
alias_method :to_hash, :to_h
|
@@ -94,7 +93,7 @@ class Chef
|
|
94
93
|
names = []
|
95
94
|
paths.each do |path|
|
96
95
|
unless File.directory?(path)
|
97
|
-
raise Chef::Exceptions::InvalidDataBagPath, "Data bag path '#{path}'
|
96
|
+
raise Chef::Exceptions::InvalidDataBagPath, "Data bag path '#{path}' not found. Please create this directory."
|
98
97
|
end
|
99
98
|
|
100
99
|
names += Dir.glob(File.join(
|
@@ -122,7 +121,7 @@ class Chef
|
|
122
121
|
data_bag = {}
|
123
122
|
paths.each do |path|
|
124
123
|
unless File.directory?(path)
|
125
|
-
raise Chef::Exceptions::InvalidDataBagPath, "Data bag path '#{path}'
|
124
|
+
raise Chef::Exceptions::InvalidDataBagPath, "Data bag path '#{path}' not found. Please create this directory."
|
126
125
|
end
|
127
126
|
|
128
127
|
Dir.glob(File.join(Chef::Util::PathHelper.escape_glob_dir(path, name.to_s), "*.json")).inject({}) do |bag, f|
|
data/lib/chef/data_collector.rb
CHANGED
@@ -18,7 +18,7 @@
|
|
18
18
|
class Chef
|
19
19
|
class DataCollector
|
20
20
|
|
21
|
-
# This module isolates the handling of collecting error descriptions to insert into the
|
21
|
+
# This module isolates the handling of collecting error descriptions to insert into the data_collector
|
22
22
|
# report output. For very early errors it is responsible for collecting the node_name for the report
|
23
23
|
# to use. For all failure conditions that have an ErrorMapper it collects the output.
|
24
24
|
#
|
@@ -21,8 +21,8 @@ class Chef
|
|
21
21
|
class Decorator
|
22
22
|
# Lazy Array around Lazy Objects
|
23
23
|
#
|
24
|
-
# This
|
25
|
-
# know how many items we have and what their indexes are, so we'd have to
|
24
|
+
# This makes access lazy through `#[]`. In order to implement #each we need to
|
25
|
+
# know how many items we have and what their indexes are, so we'd have to evaluate
|
26
26
|
# the proc which makes that impossible. You can call methods like #each and the
|
27
27
|
# decorator will forward the method, but item access will not be lazy.
|
28
28
|
#
|
data/lib/chef/deprecated.rb
CHANGED
@@ -237,6 +237,18 @@ class Chef
|
|
237
237
|
target 29
|
238
238
|
end
|
239
239
|
|
240
|
+
class ArchiveFileIntegerFileMode < Base
|
241
|
+
target 30
|
242
|
+
end
|
243
|
+
|
244
|
+
class ResourceNameWithoutProvides < Base
|
245
|
+
target 31
|
246
|
+
end
|
247
|
+
|
248
|
+
class AttributeBlacklistConfiguration < Base
|
249
|
+
target 32
|
250
|
+
end
|
251
|
+
|
240
252
|
class Generic < Base
|
241
253
|
def url
|
242
254
|
"https://docs.chef.io/chef_deprecations_client/"
|
data/lib/chef/digester.rb
CHANGED
@@ -19,6 +19,7 @@
|
|
19
19
|
#
|
20
20
|
|
21
21
|
require "openssl" unless defined?(OpenSSL)
|
22
|
+
require "digest" unless defined?(Digest)
|
22
23
|
require "singleton" unless defined?(Singleton)
|
23
24
|
|
24
25
|
class Chef
|
@@ -39,9 +40,9 @@ class Chef
|
|
39
40
|
|
40
41
|
def generate_checksum(file)
|
41
42
|
if file.is_a?(StringIO)
|
42
|
-
checksum_io(file, OpenSSL::Digest
|
43
|
+
checksum_io(file, OpenSSL::Digest.new("SHA256"))
|
43
44
|
else
|
44
|
-
checksum_file(file, OpenSSL::Digest
|
45
|
+
checksum_file(file, OpenSSL::Digest.new("SHA256"))
|
45
46
|
end
|
46
47
|
end
|
47
48
|
|
@@ -50,11 +51,11 @@ class Chef
|
|
50
51
|
end
|
51
52
|
|
52
53
|
def generate_md5_checksum_for_file(file)
|
53
|
-
checksum_file(file,
|
54
|
+
checksum_file(file, ::Digest::MD5.new)
|
54
55
|
end
|
55
56
|
|
56
57
|
def generate_md5_checksum(io)
|
57
|
-
checksum_io(io,
|
58
|
+
checksum_io(io, ::Digest::MD5.new)
|
58
59
|
end
|
59
60
|
|
60
61
|
private
|
@@ -151,7 +151,7 @@ class Chef
|
|
151
151
|
# source "y.txt.erb"
|
152
152
|
# variables {}
|
153
153
|
# end
|
154
|
-
# resource.variables.merge!({ home: "/home/
|
154
|
+
# resource.variables.merge!({ home: "/home/clowns" })
|
155
155
|
#
|
156
156
|
def edit_resource(type, name, created_at: nil, run_context: self.run_context, &resource_attrs_block)
|
157
157
|
edit_resource!(type, name, created_at: created_at, run_context: run_context, &resource_attrs_block)
|
@@ -17,6 +17,7 @@
|
|
17
17
|
#
|
18
18
|
|
19
19
|
require "chef-utils" unless defined?(ChefUtils::CANARY)
|
20
|
+
require "chef/mixin/chef_utils_wiring" unless defined?(Chef::Mixin::ChefUtilsWiring)
|
20
21
|
|
21
22
|
class Chef
|
22
23
|
module DSL
|
@@ -25,6 +26,7 @@ class Chef
|
|
25
26
|
# #value_for_platform.
|
26
27
|
module PlatformIntrospection
|
27
28
|
include ChefUtils
|
29
|
+
include Chef::Mixin::ChefUtilsWiring
|
28
30
|
|
29
31
|
# Implementation class for determining platform dependent values
|
30
32
|
class PlatformDependentValue
|
@@ -158,7 +158,7 @@ class Chef::EncryptedDataBagItem
|
|
158
158
|
d = OpenSSL::Cipher.new(algorithm)
|
159
159
|
d.decrypt
|
160
160
|
# We must set key before iv: https://bugs.ruby-lang.org/issues/8221
|
161
|
-
d.key = OpenSSL::Digest
|
161
|
+
d.key = OpenSSL::Digest.digest("SHA256", key)
|
162
162
|
d.iv = iv
|
163
163
|
d
|
164
164
|
end
|
@@ -102,7 +102,7 @@ class Chef::EncryptedDataBagItem
|
|
102
102
|
encryptor = OpenSSL::Cipher.new(algorithm)
|
103
103
|
encryptor.encrypt
|
104
104
|
# We must set key before iv: https://bugs.ruby-lang.org/issues/8221
|
105
|
-
encryptor.key = OpenSSL::Digest
|
105
|
+
encryptor.key = OpenSSL::Digest.digest("SHA256", key)
|
106
106
|
@iv ||= encryptor.random_iv
|
107
107
|
encryptor.iv = @iv
|
108
108
|
encryptor
|