chef 16.0.257 → 16.2.44
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +3 -1
- data/README.md +3 -3
- data/Rakefile +44 -16
- data/chef.gemspec +4 -4
- data/lib/chef/application/apply.rb +2 -2
- data/lib/chef/application/base.rb +1 -1
- data/lib/chef/application/client.rb +1 -1
- data/lib/chef/application/exit_code.rb +2 -2
- data/lib/chef/application/windows_service_manager.rb +1 -1
- data/lib/chef/chef_fs/chef_fs_data_store.rb +3 -3
- data/lib/chef/chef_fs/data_handler/data_bag_item_data_handler.rb +1 -1
- 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/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/multiplexed_dir.rb +1 -1
- 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 +4 -4
- 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_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 +7 -7
- data/lib/chef/data_bag.rb +4 -4
- 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 +5 -1
- data/lib/chef/digester.rb +4 -4
- data/lib/chef/dsl/declare_resource.rb +1 -1
- data/lib/chef/dsl/platform_introspection.rb +1 -1
- 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/file_access_control.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/node_load_error_inspector.rb +2 -2
- data/lib/chef/formatters/error_inspectors/registration_error_inspector.rb +7 -7
- data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +3 -3
- data/lib/chef/http.rb +18 -3
- 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 +2 -2
- data/lib/chef/knife/bootstrap.rb +13 -16
- 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/client_bulk_delete.rb +1 -1
- data/lib/chef/knife/config_get.rb +1 -1
- data/lib/chef/knife/cookbook_delete.rb +1 -1
- data/lib/chef/knife/core/cookbook_scm_repo.rb +1 -1
- data/lib/chef/knife/core/hashed_command_loader.rb +1 -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 +1 -1
- data/lib/chef/knife/core/windows_bootstrap_context.rb +18 -3
- data/lib/chef/knife/data_bag_create.rb +1 -1
- data/lib/chef/knife/environment_compare.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/list.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/role_bulk_delete.rb +1 -1
- data/lib/chef/knife/ssh.rb +2 -2
- data/lib/chef/knife/supermarket_install.rb +1 -1
- data/lib/chef/knife/supermarket_share.rb +1 -1
- data/lib/chef/knife/supermarket_unshare.rb +1 -1
- data/lib/chef/knife/{user_invite_recind.rb → user_invite_rescind.rb} +6 -6
- data/lib/chef/knife/yaml_convert.rb +2 -2
- data/lib/chef/log.rb +1 -1
- data/lib/chef/mixin/api_version_request_handling.rb +1 -1
- data/lib/chef/mixin/checksum.rb +0 -1
- data/lib/chef/mixin/create_path.rb +8 -8
- data/lib/chef/mixin/openssl_helper.rb +4 -4
- data/lib/chef/mixin/properties.rb +4 -2
- data/lib/chef/mixin/securable.rb +2 -2
- data/lib/chef/mixin/shell_out.rb +1 -1
- data/lib/chef/node/attribute.rb +2 -2
- data/lib/chef/node/immutable_collections.rb +1 -1
- data/lib/chef/node/mixin/deep_merge_cache.rb +7 -7
- 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 +3 -2
- data/lib/chef/provider/file.rb +1 -1
- 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/launchd.rb +28 -32
- data/lib/chef/provider/mount/aix.rb +1 -1
- data/lib/chef/provider/mount/windows.rb +2 -2
- data/lib/chef/provider/noop.rb +1 -1
- data/lib/chef/provider/package/cab.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/freebsd/base.rb +2 -1
- data/lib/chef/provider/package/homebrew.rb +1 -1
- data/lib/chef/provider/package/macports.rb +0 -2
- 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 +96 -27
- data/lib/chef/provider/package/windows.rb +27 -52
- 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/powershell_script.rb +11 -15
- 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/arch.rb +2 -2
- data/lib/chef/provider/service/debian.rb +2 -2
- data/lib/chef/provider/service/macosx.rb +13 -2
- data/lib/chef/provider/service/openbsd.rb +4 -4
- data/lib/chef/provider/service/redhat.rb +1 -1
- data/lib/chef/provider/service/simple.rb +3 -3
- 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 +7 -7
- 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 +5 -3
- data/lib/chef/provider/zypper_repository.rb +30 -10
- data/lib/chef/resource.rb +25 -14
- data/lib/chef/resource/alternatives.rb +65 -4
- data/lib/chef/resource/apt_package.rb +31 -2
- data/lib/chef/resource/apt_preference.rb +34 -5
- data/lib/chef/resource/apt_repository.rb +22 -15
- data/lib/chef/resource/apt_update.rb +6 -4
- data/lib/chef/resource/archive_file.rb +33 -12
- data/lib/chef/resource/bash.rb +1 -2
- data/lib/chef/resource/batch.rb +5 -3
- data/lib/chef/resource/bff_package.rb +1 -1
- data/lib/chef/resource/breakpoint.rb +1 -1
- data/lib/chef/resource/build_essential.rb +8 -4
- data/lib/chef/resource/cab_package.rb +1 -1
- data/lib/chef/resource/chef_client_cron.rb +12 -9
- data/lib/chef/resource/chef_client_scheduled_task.rb +22 -7
- data/lib/chef/resource/chef_client_systemd_timer.rb +10 -7
- data/lib/chef/resource/chef_gem.rb +6 -2
- data/lib/chef/resource/chef_handler.rb +3 -3
- data/lib/chef/resource/chef_sleep.rb +7 -4
- data/lib/chef/resource/chef_vault_secret.rb +4 -4
- data/lib/chef/resource/chocolatey_config.rb +5 -3
- data/lib/chef/resource/chocolatey_feature.rb +5 -3
- data/lib/chef/resource/chocolatey_package.rb +5 -3
- data/lib/chef/resource/chocolatey_source.rb +5 -3
- data/lib/chef/resource/cookbook_file.rb +3 -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} +28 -94
- data/lib/chef/resource/cron_access.rb +17 -6
- data/lib/chef/resource/csh.rb +1 -2
- data/lib/chef/resource/directory.rb +1 -1
- data/lib/chef/resource/dmg_package.rb +18 -15
- data/lib/chef/resource/dnf_package.rb +1 -1
- data/lib/chef/resource/dpkg_package.rb +1 -1
- data/lib/chef/resource/execute.rb +479 -9
- data/lib/chef/resource/file.rb +11 -8
- data/lib/chef/resource/freebsd_package.rb +2 -2
- data/lib/chef/resource/gem_package.rb +6 -6
- data/lib/chef/resource/group.rb +1 -1
- data/lib/chef/resource/helpers/cron_validations.rb +6 -3
- data/lib/chef/resource/homebrew_cask.rb +1 -1
- data/lib/chef/resource/homebrew_package.rb +30 -1
- data/lib/chef/resource/homebrew_tap.rb +1 -1
- data/lib/chef/resource/homebrew_update.rb +107 -0
- data/lib/chef/resource/hostname.rb +11 -24
- data/lib/chef/resource/http_request.rb +1 -1
- data/lib/chef/resource/ifconfig.rb +7 -7
- data/lib/chef/resource/ips_package.rb +1 -1
- data/lib/chef/resource/kernel_module.rb +15 -2
- data/lib/chef/resource/ksh.rb +1 -1
- data/lib/chef/resource/launchd.rb +5 -5
- data/lib/chef/resource/link.rb +4 -4
- data/lib/chef/resource/locale.rb +4 -4
- data/lib/chef/resource/log.rb +1 -1
- data/lib/chef/resource/macos_userdefaults.rb +15 -10
- data/lib/chef/resource/macosx_service.rb +1 -1
- data/lib/chef/resource/macports_package.rb +1 -1
- data/lib/chef/resource/mdadm.rb +1 -1
- data/lib/chef/resource/mount.rb +2 -2
- data/lib/chef/resource/msu_package.rb +2 -2
- data/lib/chef/resource/ohai.rb +1 -1
- data/lib/chef/resource/ohai_hint.rb +1 -1
- data/lib/chef/resource/openbsd_package.rb +1 -1
- data/lib/chef/resource/openssl_dhparam.rb +1 -1
- data/lib/chef/resource/openssl_ec_private_key.rb +1 -1
- data/lib/chef/resource/openssl_ec_public_key.rb +1 -1
- data/lib/chef/resource/openssl_rsa_private_key.rb +1 -1
- data/lib/chef/resource/openssl_rsa_public_key.rb +1 -1
- data/lib/chef/resource/openssl_x509_certificate.rb +1 -1
- data/lib/chef/resource/openssl_x509_crl.rb +1 -1
- data/lib/chef/resource/openssl_x509_request.rb +1 -1
- data/lib/chef/resource/osx_profile.rb +1 -1
- data/lib/chef/resource/package.rb +1 -1
- data/lib/chef/resource/pacman_package.rb +1 -1
- data/lib/chef/resource/paludis_package.rb +1 -1
- data/lib/chef/resource/perl.rb +1 -2
- data/lib/chef/resource/plist.rb +24 -5
- data/lib/chef/resource/portage_package.rb +1 -1
- data/lib/chef/resource/powershell_package.rb +1 -1
- data/lib/chef/resource/powershell_package_source.rb +1 -1
- data/lib/chef/resource/powershell_script.rb +5 -3
- data/lib/chef/resource/python.rb +1 -2
- data/lib/chef/resource/reboot.rb +1 -1
- data/lib/chef/resource/registry_key.rb +1 -1
- data/lib/chef/resource/remote_directory.rb +1 -1
- data/lib/chef/resource/remote_file.rb +26 -11
- data/lib/chef/resource/rhsm_errata.rb +1 -3
- data/lib/chef/resource/rhsm_errata_level.rb +1 -1
- data/lib/chef/resource/rhsm_register.rb +1 -2
- data/lib/chef/resource/rhsm_repo.rb +1 -2
- data/lib/chef/resource/rhsm_subscription.rb +1 -3
- data/lib/chef/resource/route.rb +1 -1
- data/lib/chef/resource/rpm_package.rb +5 -2
- data/lib/chef/resource/ruby.rb +1 -2
- data/lib/chef/resource/ruby_block.rb +1 -4
- data/lib/chef/resource/scm/_scm.rb +4 -3
- data/lib/chef/resource/scm/git.rb +2 -2
- data/lib/chef/resource/scm/subversion.rb +2 -2
- data/lib/chef/resource/script.rb +1 -1
- data/lib/chef/resource/service.rb +1 -1
- data/lib/chef/resource/smartos_package.rb +1 -1
- data/lib/chef/resource/snap_package.rb +1 -1
- data/lib/chef/resource/solaris_package.rb +1 -1
- data/lib/chef/resource/ssh_known_hosts_entry.rb +1 -1
- data/lib/chef/resource/sudo.rb +4 -4
- data/lib/chef/resource/swap_file.rb +2 -2
- data/lib/chef/resource/sysctl.rb +61 -2
- data/lib/chef/resource/systemd_unit.rb +2 -2
- data/lib/chef/resource/template.rb +1 -1
- data/lib/chef/resource/timezone.rb +1 -1
- data/lib/chef/resource/user.rb +2 -2
- data/lib/chef/resource/user_ulimit.rb +24 -22
- data/lib/chef/resource/windows_ad_join.rb +31 -2
- data/lib/chef/resource/windows_audit_policy.rb +227 -0
- data/lib/chef/resource/windows_auto_run.rb +13 -2
- data/lib/chef/resource/windows_certificate.rb +28 -2
- data/lib/chef/resource/windows_dfs_folder.rb +1 -1
- data/lib/chef/resource/windows_dfs_namespace.rb +1 -1
- data/lib/chef/resource/windows_dfs_server.rb +2 -2
- data/lib/chef/resource/windows_env.rb +10 -1
- data/lib/chef/resource/windows_feature.rb +57 -2
- data/lib/chef/resource/windows_feature_dism.rb +15 -2
- data/lib/chef/resource/windows_feature_powershell.rb +29 -2
- data/lib/chef/resource/windows_firewall_rule.rb +11 -7
- data/lib/chef/resource/windows_font.rb +13 -4
- data/lib/chef/resource/windows_package.rb +66 -6
- data/lib/chef/resource/windows_pagefile.rb +32 -4
- data/lib/chef/resource/windows_path.rb +18 -1
- data/lib/chef/resource/windows_printer.rb +26 -6
- data/lib/chef/resource/windows_printer_port.rb +29 -1
- data/lib/chef/resource/windows_script.rb +2 -16
- data/lib/chef/resource/windows_security_policy.rb +47 -16
- data/lib/chef/resource/windows_service.rb +1 -1
- data/lib/chef/resource/windows_share.rb +23 -3
- data/lib/chef/resource/windows_shortcut.rb +13 -3
- data/lib/chef/resource/windows_task.rb +143 -29
- data/lib/chef/resource/windows_uac.rb +20 -1
- data/lib/chef/resource/windows_user_privilege.rb +45 -3
- data/lib/chef/resource/windows_workgroup.rb +19 -3
- data/lib/chef/resource/yum_package.rb +88 -6
- data/lib/chef/resource/yum_repository.rb +36 -19
- data/lib/chef/resource/zypper_package.rb +29 -3
- data/lib/chef/resource/zypper_repository.rb +17 -5
- data/lib/chef/resource_inspector.rb +5 -4
- data/lib/chef/resources.rb +4 -2
- data/lib/chef/run_context/cookbook_compiler.rb +1 -1
- data/lib/chef/scan_access_control.rb +1 -1
- data/lib/chef/search/query.rb +1 -1
- data/lib/chef/shell/ext.rb +1 -1
- data/lib/chef/util/diff.rb +2 -2
- data/lib/chef/util/dsc/lcm_output_parser.rb +3 -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 +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 +18 -18
- 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/process.rb +2 -2
- data/lib/chef/win32/registry.rb +2 -2
- 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/resource/cron_spec.rb +10 -0
- data/spec/functional/resource/dnf_package_spec.rb +2 -2
- data/spec/functional/resource/git_spec.rb +6 -6
- data/spec/functional/resource/launchd_spec.rb +232 -0
- data/spec/functional/resource/link_spec.rb +3 -3
- data/spec/functional/resource/remote_file_spec.rb +3 -3
- data/spec/functional/resource/user/dscl_spec.rb +1 -1
- data/spec/functional/resource/user/mac_user_spec.rb +1 -1
- data/spec/functional/resource/windows_task_spec.rb +12 -12
- data/spec/integration/knife/raw_spec.rb +4 -4
- data/spec/integration/knife/redirection_spec.rb +2 -2
- data/spec/support/chef_helpers.rb +1 -1
- data/spec/support/platform_helpers.rb +1 -14
- 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 +1 -1
- data/spec/support/shared/functional/http.rb +2 -2
- data/spec/support/shared/functional/windows_script.rb +1 -1
- data/spec/support/shared/unit/execute_resource.rb +1 -1
- 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_spec.rb +7 -0
- data/spec/unit/data_bag_spec.rb +1 -1
- data/spec/unit/file_access_control_spec.rb +1 -1
- data/spec/unit/http/ssl_policies_spec.rb +20 -0
- data/spec/unit/knife/bootstrap_spec.rb +2 -2
- data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +7 -1
- 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/mixin/openssl_helper_spec.rb +4 -4
- data/spec/unit/mixin/shell_out_spec.rb +25 -31
- data/spec/unit/mixin/user_context_spec.rb +1 -9
- data/spec/unit/node/attribute_spec.rb +1 -1
- data/spec/unit/property_spec.rb +1 -1
- data/spec/unit/provider/apt_repository_spec.rb +27 -27
- data/spec/unit/provider/batch_spec.rb +130 -0
- data/spec/unit/provider/cron_spec.rb +9 -49
- data/spec/unit/provider/git_spec.rb +3 -3
- data/spec/unit/provider/group/groupadd_spec.rb +1 -1
- data/spec/unit/provider/launchd_spec.rb +8 -50
- data/spec/unit/provider/osx_profile_spec.rb +2 -2
- data/spec/unit/provider/package/msu_spec.rb +3 -3
- 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/snap_spec.rb +1 -1
- data/spec/unit/provider/powershell_script_spec.rb +3 -45
- data/spec/unit/provider/script_spec.rb +20 -110
- data/spec/unit/provider/service/gentoo_service_spec.rb +1 -1
- data/spec/unit/provider/zypper_repository_spec.rb +75 -25
- data/spec/unit/provider_resolver_spec.rb +11 -11
- data/spec/unit/resource/archive_file_spec.rb +11 -2
- data/spec/unit/resource/chef_client_scheduled_task_spec.rb +17 -7
- data/spec/unit/resource/cron_spec.rb +2 -2
- 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/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_package_spec.rb +10 -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_spec.rb +67 -1
- data/spec/unit/run_context_spec.rb +1 -1
- data/spec/unit/util/dsc/configuration_generator_spec.rb +1 -1
- data/spec/unit/util/threaded_job_queue_spec.rb +9 -0
- data/spec/unit/win32/registry_spec.rb +1 -1
- metadata +28 -27
- data/lib/chef/resource/cron.rb +0 -157
@@ -22,8 +22,27 @@ class Chef
|
|
22
22
|
class WindowsUac < Chef::Resource
|
23
23
|
provides :windows_uac
|
24
24
|
|
25
|
-
description 'The windows_uac resource configures UAC on Windows hosts by setting registry keys at
|
25
|
+
description 'The *windows_uac* resource configures UAC on Windows hosts by setting registry keys at `HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System`'
|
26
26
|
introduced "15.0"
|
27
|
+
examples <<~DOC
|
28
|
+
**Disable UAC prompts for the admin**:
|
29
|
+
|
30
|
+
``` ruby
|
31
|
+
windows_uac 'Disable UAC prompts for the admin' do
|
32
|
+
enable_uac true
|
33
|
+
prompt_on_secure_desktop false
|
34
|
+
consent_behavior_admins :no_prompt
|
35
|
+
end
|
36
|
+
```
|
37
|
+
|
38
|
+
**Disable UAC entirely**:
|
39
|
+
|
40
|
+
``` ruby
|
41
|
+
windows_uac 'Disable UAC entirely' do
|
42
|
+
enable_uac false
|
43
|
+
end
|
44
|
+
```
|
45
|
+
DOC
|
27
46
|
|
28
47
|
# https://docs.microsoft.com/en-us/windows/security/identity-protection/user-account-control/user-account-control-group-policy-and-registry-key-settings#user-account-control-virtualize-file-and-registry-write-failures-to-per-user-locations
|
29
48
|
property :enable_uac, [TrueClass, FalseClass],
|
@@ -68,10 +68,52 @@ class Chef
|
|
68
68
|
}
|
69
69
|
|
70
70
|
provides :windows_user_privilege
|
71
|
-
description "The windows_user_privilege resource allows to add and set principal (User/Group) to the specified privilege
|
71
|
+
description "The windows_user_privilege resource allows to add and set principal (User/Group) to the specified privilege.\n Ref: https://docs.microsoft.com/en-us/windows/security/threat-protection/security-policy-settings/user-rights-assignment"
|
72
72
|
|
73
73
|
introduced "16.0"
|
74
74
|
|
75
|
+
examples <<~DOC
|
76
|
+
**Set the SeNetworkLogonRight Privilege for the Builtin Administrators Group and Authenticated Users**:
|
77
|
+
|
78
|
+
```ruby
|
79
|
+
windows_user_privilege 'Network Logon Rights' do
|
80
|
+
privilege 'SeNetworkLogonRight'
|
81
|
+
users ['BUILTIN\\Administrators', 'NT AUTHORITY\\Authenticated Users']
|
82
|
+
action :set
|
83
|
+
end
|
84
|
+
```
|
85
|
+
|
86
|
+
**Add the SeDenyRemoteInteractiveLogonRight Privilege to the Builtin Guests and Local Accounts User Groups**:
|
87
|
+
|
88
|
+
```ruby
|
89
|
+
windows_user_privilege 'Remote interactive logon' do
|
90
|
+
privilege 'SeDenyRemoteInteractiveLogonRight'
|
91
|
+
users ['Builtin\\Guests', 'NT AUTHORITY\\Local Account']
|
92
|
+
action :add
|
93
|
+
end
|
94
|
+
```
|
95
|
+
|
96
|
+
**Provide only the Builtin Guests and Administrator Groups with the SeCreatePageFile Privilege**:
|
97
|
+
|
98
|
+
```ruby
|
99
|
+
windows_user_privilege 'Create Pagefile' do
|
100
|
+
privilege 'SeCreatePagefilePrivilege'
|
101
|
+
users ['BUILTIN\\Guests', 'BUILTIN\\Administrators']
|
102
|
+
action :set
|
103
|
+
end
|
104
|
+
```
|
105
|
+
|
106
|
+
**Remove the SeCreatePageFile Privilege from the Builtin Guests Group**:
|
107
|
+
|
108
|
+
```ruby
|
109
|
+
windows_user_privilege 'Create Pagefile' do
|
110
|
+
privilege 'SeCreatePagefilePrivilege'
|
111
|
+
users ['BUILTIN\\Guests']
|
112
|
+
action :remove
|
113
|
+
end
|
114
|
+
```
|
115
|
+
DOC
|
116
|
+
|
75
117
|
property :principal, String,
|
76
118
|
description: "An optional property to add the user to the given privilege. Use only with add and remove action.",
|
77
119
|
name_property: true
|
@@ -84,8 +126,8 @@ class Chef
|
|
84
126
|
required: true,
|
85
127
|
coerce: proc { |v| v.is_a?(String) ? Array[v] : v },
|
86
128
|
callbacks: {
|
87
|
-
"Option privilege must include any of the: #{privilege_opts}" => lambda {
|
88
|
-
|
129
|
+
"Option privilege must include any of the: #{privilege_opts}" => lambda { |v|
|
130
|
+
(privilege_opts & v).size == v.size
|
89
131
|
},
|
90
132
|
}
|
91
133
|
|
@@ -26,8 +26,24 @@ class Chef
|
|
26
26
|
|
27
27
|
include Chef::Mixin::PowershellOut
|
28
28
|
|
29
|
-
description "Use the windows_workgroup resource to join or change the workgroup of a Windows host."
|
29
|
+
description "Use the **windows_workgroup** resource to join or change the workgroup of a Windows host."
|
30
30
|
introduced "14.5"
|
31
|
+
examples <<~DOC
|
32
|
+
**Join a workgroup**:
|
33
|
+
|
34
|
+
``` ruby
|
35
|
+
windows_workgroup 'myworkgroup'
|
36
|
+
```
|
37
|
+
|
38
|
+
**Join a workgroup using a specific user**:
|
39
|
+
|
40
|
+
``` ruby
|
41
|
+
windows_workgroup 'myworkgroup' do
|
42
|
+
user 'Administrator'
|
43
|
+
password 'passw0rd'
|
44
|
+
end
|
45
|
+
```
|
46
|
+
DOC
|
31
47
|
|
32
48
|
property :workgroup_name, String,
|
33
49
|
description: "An optional property to set the workgroup name if it differs from the resource block's name.",
|
@@ -36,11 +52,11 @@ class Chef
|
|
36
52
|
name_property: true
|
37
53
|
|
38
54
|
property :user, String,
|
39
|
-
description: "The local administrator user to use to change the workgroup. Required if using the password property.",
|
55
|
+
description: "The local administrator user to use to change the workgroup. Required if using the `password` property.",
|
40
56
|
desired_state: false
|
41
57
|
|
42
58
|
property :password, String,
|
43
|
-
description: "The password for the local administrator user. Required if using the user property.",
|
59
|
+
description: "The password for the local administrator user. Required if using the `user` property.",
|
44
60
|
desired_state: false
|
45
61
|
|
46
62
|
property :reboot, Symbol,
|
@@ -27,11 +27,92 @@ class Chef
|
|
27
27
|
provides :yum_package
|
28
28
|
provides :package, platform_family: "fedora_derived"
|
29
29
|
|
30
|
-
description "Use the yum_package resource to install, upgrade, and remove packages with Yum"\
|
30
|
+
description "Use the **yum_package** resource to install, upgrade, and remove packages with Yum"\
|
31
31
|
" for the Red Hat and CentOS platforms. The yum_package resource is able to resolve"\
|
32
|
-
" provides data for packages much like Yum can do when it is run from the command line."\
|
32
|
+
" `provides` data for packages much like Yum can do when it is run from the command line."\
|
33
33
|
" This allows a variety of options for installing packages, like minimum versions,"\
|
34
34
|
" virtual provides, and library names."
|
35
|
+
examples <<~DOC
|
36
|
+
**Install an exact version**:
|
37
|
+
|
38
|
+
``` ruby
|
39
|
+
yum_package 'netpbm = 10.35.58-8.el8'
|
40
|
+
```
|
41
|
+
|
42
|
+
**Install a minimum version**:
|
43
|
+
|
44
|
+
``` ruby
|
45
|
+
yum_package 'netpbm >= 10.35.58-8.el8'
|
46
|
+
```
|
47
|
+
|
48
|
+
**Install a minimum version using the default action**:
|
49
|
+
|
50
|
+
``` ruby
|
51
|
+
yum_package 'netpbm'
|
52
|
+
```
|
53
|
+
|
54
|
+
**Install a version without worrying about the exact release**:
|
55
|
+
|
56
|
+
``` ruby
|
57
|
+
yum_package 'netpbm-10.35*'
|
58
|
+
```
|
59
|
+
|
60
|
+
|
61
|
+
**To install a package**:
|
62
|
+
|
63
|
+
``` ruby
|
64
|
+
yum_package 'netpbm' do
|
65
|
+
action :install
|
66
|
+
end
|
67
|
+
```
|
68
|
+
|
69
|
+
**To install a partial minimum version**:
|
70
|
+
|
71
|
+
``` ruby
|
72
|
+
yum_package 'netpbm >= 10'
|
73
|
+
```
|
74
|
+
|
75
|
+
**To install a specific architecture**:
|
76
|
+
|
77
|
+
``` ruby
|
78
|
+
yum_package 'netpbm' do
|
79
|
+
arch 'i386'
|
80
|
+
end
|
81
|
+
```
|
82
|
+
|
83
|
+
or:
|
84
|
+
|
85
|
+
``` ruby
|
86
|
+
yum_package 'netpbm.x86_64'
|
87
|
+
```
|
88
|
+
|
89
|
+
**To install a specific version-release**
|
90
|
+
|
91
|
+
``` ruby
|
92
|
+
yum_package 'netpbm' do
|
93
|
+
version '10.35.58-8.el8'
|
94
|
+
end
|
95
|
+
```
|
96
|
+
|
97
|
+
**Handle cookbook_file and yum_package resources in the same recipe**:
|
98
|
+
|
99
|
+
When a **cookbook_file** resource and a **yum_package** resource are
|
100
|
+
both called from within the same recipe, use the `flush_cache` attribute
|
101
|
+
to dump the in-memory Yum cache, and then use the repository immediately
|
102
|
+
to ensure that the correct package is installed:
|
103
|
+
|
104
|
+
``` ruby
|
105
|
+
cookbook_file '/etc/yum.repos.d/custom.repo' do
|
106
|
+
source 'custom'
|
107
|
+
mode '0755'
|
108
|
+
end
|
109
|
+
|
110
|
+
yum_package 'pkg-that-is-only-in-custom-repo' do
|
111
|
+
action :install
|
112
|
+
flush_cache [ :before ]
|
113
|
+
end
|
114
|
+
```
|
115
|
+
DOC
|
35
116
|
|
36
117
|
# XXX: the coercions here are due to the provider promiscuously updating the properties on the
|
37
118
|
# new_resource which causes immutable modification exceptions when passed an immutable node array.
|
@@ -46,7 +127,7 @@ class Chef
|
|
46
127
|
identity: true, coerce: proc { |x| x.is_a?(Array) ? x.to_a : x }
|
47
128
|
|
48
129
|
property :version, [ String, Array ],
|
49
|
-
description: "The version of a package to be installed or upgraded. This property is ignored when using the
|
130
|
+
description: "The version of a package to be installed or upgraded. This property is ignored when using the `:upgrade` action.",
|
50
131
|
coerce: proc { |x| x.is_a?(Array) ? x.to_a : x }
|
51
132
|
|
52
133
|
property :arch, [ String, Array ],
|
@@ -70,12 +151,13 @@ class Chef
|
|
70
151
|
end
|
71
152
|
}
|
72
153
|
|
73
|
-
property :allow_downgrade, [
|
74
|
-
description: "
|
154
|
+
property :allow_downgrade, [ TrueClass, FalseClass ],
|
155
|
+
description: "Allow downgrading a package to satisfy requested version requirements.",
|
75
156
|
default: true,
|
76
157
|
desired_state: false
|
77
158
|
|
78
|
-
property :yum_binary, String
|
159
|
+
property :yum_binary, String,
|
160
|
+
description: "The path to the yum binary."
|
79
161
|
end
|
80
162
|
end
|
81
163
|
end
|
@@ -25,21 +25,38 @@ class Chef
|
|
25
25
|
|
26
26
|
provides(:yum_repository) { true }
|
27
27
|
|
28
|
-
description "Use the yum_repository resource to manage a Yum repository configuration"
|
29
|
-
" file located at /etc/yum.repos.d/repositoryid.repo on the local machine."\
|
30
|
-
" This configuration file specifies which repositories to reference, how to"\
|
31
|
-
" handle cached data, etc."
|
28
|
+
description "Use the **yum_repository** resource to manage a Yum repository configuration file located at `/etc/yum.repos.d/repositoryid.repo` on the local machine. This configuration file specifies which repositories to reference, how to handle cached data, etc."
|
32
29
|
introduced "12.14"
|
30
|
+
examples <<~DOC
|
31
|
+
**Add an internal company repository**:
|
32
|
+
|
33
|
+
```ruby
|
34
|
+
yum_repository 'OurCo' do
|
35
|
+
description 'OurCo yum repository'
|
36
|
+
mirrorlist 'http://artifacts.ourco.org/mirrorlist?repo=ourco-8&arch=$basearch'
|
37
|
+
gpgkey 'http://artifacts.ourco.org/pub/yum/RPM-GPG-KEY-OURCO-8'
|
38
|
+
action :create
|
39
|
+
end
|
40
|
+
```ruby
|
41
|
+
|
42
|
+
**Delete a repository**:
|
43
|
+
|
44
|
+
```ruby
|
45
|
+
yum_repository 'CentOS-Media' do
|
46
|
+
action :delete
|
47
|
+
end
|
48
|
+
```
|
49
|
+
DOC
|
33
50
|
|
34
51
|
# http://linux.die.net/man/5/yum.conf as well as
|
35
52
|
# http://dnf.readthedocs.io/en/latest/conf_ref.html
|
36
53
|
property :baseurl, [String, Array],
|
37
|
-
description: "URL to the directory where the Yum repository's
|
54
|
+
description: "URL to the directory where the Yum repository's `repodata` directory lives. Can be an `http://`, `https://` or a `ftp://` URLs. You can specify multiple URLs in one `baseurl` statement."
|
38
55
|
|
39
56
|
property :clean_headers, [TrueClass, FalseClass],
|
40
57
|
description: "Specifies whether you want to purge the package data files that are downloaded from a Yum repository and held in a cache directory.",
|
41
58
|
deprecated: true,
|
42
|
-
default: false
|
59
|
+
default: false
|
43
60
|
|
44
61
|
property :clean_metadata, [TrueClass, FalseClass],
|
45
62
|
description: "Specifies whether you want to purge all of the packages downloaded from a Yum repository and held in a cache directory.",
|
@@ -64,7 +81,7 @@ class Chef
|
|
64
81
|
description: "List of packages to exclude from updates or installs. This should be a space separated list. Shell globs using wildcards (eg. * and ?) are allowed."
|
65
82
|
|
66
83
|
property :failovermethod, String,
|
67
|
-
description: "Method to determine how to switch to a new server if the current one fails, which can either be
|
84
|
+
description: "Method to determine how to switch to a new server if the current one fails, which can either be `roundrobin` or `priority`. `roundrobin` randomly selects a URL out of the list of URLs to start with and proceeds through each of them as it encounters a failure contacting the host. `priority` starts from the first `baseurl` listed and reads through them sequentially.",
|
68
85
|
equal_to: %w{priority roundrobin}
|
69
86
|
|
70
87
|
property :fastestmirror_enabled, [TrueClass, FalseClass],
|
@@ -78,44 +95,44 @@ class Chef
|
|
78
95
|
description: "URL pointing to the ASCII-armored GPG key file for the repository. This is used if Yum needs a public key to verify a package and the required key hasn't been imported into the RPM database. If this option is set, Yum will automatically import the key from the specified URL. Multiple URLs may be specified in the same manner as the baseurl option. If a GPG key is required to install a package from a repository, all keys specified for that repository will be installed.\nMultiple URLs may be specified in the same manner as the baseurl option. If a GPG key is required to install a package from a repository, all keys specified for that repository will be installed."
|
79
96
|
|
80
97
|
property :http_caching, String, equal_to: %w{packages all none},
|
81
|
-
description: "Determines how upstream HTTP caches are instructed to handle any HTTP downloads that Yum does. This option can take the following values
|
98
|
+
description: "Determines how upstream HTTP caches are instructed to handle any HTTP downloads that Yum does. This option can take the following values:\n - `all` means all HTTP downloads should be cached\n - `packages` means only RPM package downloads should be cached, but not repository metadata downloads\n - `none` means no HTTP downloads should be cached.\n\nThe default value of `all` is recommended unless you are experiencing caching related issues."
|
82
99
|
|
83
100
|
property :include_config, String,
|
84
|
-
description: "An external configuration file using the format
|
101
|
+
description: "An external configuration file using the format `url://to/some/location`."
|
85
102
|
|
86
103
|
property :includepkgs, String,
|
87
104
|
description: "Inverse of exclude property. This is a list of packages you want to use from a repository. If this option lists only one package then that is all Yum will ever see from the repository."
|
88
105
|
|
89
106
|
property :keepalive, [TrueClass, FalseClass],
|
90
|
-
description: "Determines whether or not HTTP/1.1
|
107
|
+
description: "Determines whether or not HTTP/1.1 `keep-alive` should be used with this repository."
|
91
108
|
|
92
109
|
property :make_cache, [TrueClass, FalseClass],
|
93
110
|
description: "Determines whether package files downloaded by Yum stay in cache directories. By using cached data, you can carry out certain operations without a network connection.",
|
94
111
|
default: true
|
95
112
|
|
96
113
|
property :max_retries, [String, Integer],
|
97
|
-
description: "Number of times any attempt to retrieve a file should retry before returning an error. Setting this to
|
114
|
+
description: "Number of times any attempt to retrieve a file should retry before returning an error. Setting this to `0` makes Yum try forever."
|
98
115
|
|
99
116
|
property :metadata_expire, String, regex: [/^\d+$/, /^\d+[mhd]$/, /never/],
|
100
|
-
description: "Time (in seconds) after which the metadata will expire. If the current metadata downloaded is less than the value specified, then Yum will not update the metadata against the repository. If you find that Yum is not downloading information on updates as often as you would like lower the value of this option. You can also change from the default of using seconds to using days, hours or minutes by appending a
|
101
|
-
validation_message: "The metadata_expire property must be a numeric value for time in seconds, the string 'never', or a numeric value appended with with
|
117
|
+
description: "Time (in seconds) after which the metadata will expire. If the current metadata downloaded is less than the value specified, then Yum will not update the metadata against the repository. If you find that Yum is not downloading information on updates as often as you would like lower the value of this option. You can also change from the default of using seconds to using days, hours or minutes by appending a `d`, `h` or `m` respectively. The default is six hours to compliment yum-updates running once per hour. It is also possible to use the word `never`, meaning that the metadata will never expire. Note: When using a metalink file, the metalink must always be newer than the metadata for the repository due to the validation, so this timeout also applies to the metalink file.",
|
118
|
+
validation_message: "The metadata_expire property must be a numeric value for time in seconds, the string 'never', or a numeric value appended with with `d`, `h`, or `m`!"
|
102
119
|
|
103
120
|
property :metalink, String,
|
104
121
|
description: "Specifies a URL to a metalink file for the repomd.xml, a list of mirrors for the entire repository are generated by converting the mirrors for the repomd.xml file to a baseurl."
|
105
122
|
|
106
123
|
property :mirror_expire, String, regex: [/^\d+$/, /^\d+[mhd]$/],
|
107
|
-
description: "Time (in seconds) after which the mirrorlist locally cached will expire. If the current mirrorlist is less than this many seconds old then Yum will not download another copy of the mirrorlist, it has the same extra format as metadata_expire. If you find that Yum is not downloading the mirrorlists as often as you would like lower the value of this option. You can also change from the default of using seconds to using days, hours or minutes by appending a
|
108
|
-
validation_message: "The mirror_expire property must be a numeric value for time in seconds, the string 'never', or a numeric value appended with with
|
124
|
+
description: "Time (in seconds) after which the mirrorlist locally cached will expire. If the current mirrorlist is less than this many seconds old then Yum will not download another copy of the mirrorlist, it has the same extra format as metadata_expire. If you find that Yum is not downloading the mirrorlists as often as you would like lower the value of this option. You can also change from the default of using seconds to using days, hours or minutes by appending a `d`, `h` or `m` respectively.",
|
125
|
+
validation_message: "The mirror_expire property must be a numeric value for time in seconds, the string 'never', or a numeric value appended with with `d`, `h`, or `m`!"
|
109
126
|
|
110
127
|
property :mirrorlist_expire, String, regex: [/^\d+$/, /^\d+[mhd]$/],
|
111
|
-
description: "Specifies the time (in seconds) after which the mirrorlist locally cached will expire. If the current mirrorlist is less than the value specified, then Yum will not download another copy of the mirrorlist. You can also change from the default of using seconds to using days, hours or minutes by appending a
|
112
|
-
validation_message: "The mirrorlist_expire property must be a numeric value for time in seconds, the string 'never', or a numeric value appended with with
|
128
|
+
description: "Specifies the time (in seconds) after which the mirrorlist locally cached will expire. If the current mirrorlist is less than the value specified, then Yum will not download another copy of the mirrorlist. You can also change from the default of using seconds to using days, hours or minutes by appending a `d`, `h` or `m` respectively.",
|
129
|
+
validation_message: "The mirrorlist_expire property must be a numeric value for time in seconds, the string 'never', or a numeric value appended with with `d`, `h`, or `m`!"
|
113
130
|
|
114
131
|
property :mirrorlist, String,
|
115
132
|
description: "URL to a file containing a list of baseurls. This can be used instead of or with the baseurl option. Substitution variables, described below, can be used with this option."
|
116
133
|
|
117
134
|
property :mode, [String, Integer],
|
118
|
-
description: "Permissions mode of .repo file on disk. This is useful for scenarios where secrets are in the repo file. If this value is set to
|
135
|
+
description: "Permissions mode of .repo file on disk. This is useful for scenarios where secrets are in the repo file. If this value is set to `600`, normal users will not be able to use Yum search, Yum info, etc.",
|
119
136
|
default: "0644"
|
120
137
|
|
121
138
|
property :options, Hash,
|
@@ -125,7 +142,7 @@ class Chef
|
|
125
142
|
description: "Password to use with the username for basic authentication."
|
126
143
|
|
127
144
|
property :priority, String, regex: /^(\d?[1-9]|[0-9][0-9])$/,
|
128
|
-
description: "Assigns a priority to a repository where the priority value is between
|
145
|
+
description: "Assigns a priority to a repository where the priority value is between `1` and `99` inclusive. Priorities are used to enforce ordered protection of repositories. Packages from repositories with a lower priority (higher numerical value) will never be used to upgrade packages that were installed from a repository with a higher priority (lower numerical value). The repositories with the lowest numerical priority number have the highest priority.",
|
129
146
|
validation_message: "The priority property must be a numeric value from 1-99!"
|
130
147
|
|
131
148
|
property :proxy_password, String,
|
@@ -26,10 +26,36 @@ class Chef
|
|
26
26
|
provides :zypper_package
|
27
27
|
provides :package, platform_family: "suse"
|
28
28
|
|
29
|
-
description "Use the zypper_package resource to install, upgrade, and remove packages with Zypper for the SUSE Enterprise and
|
29
|
+
description "Use the **zypper_package** resource to install, upgrade, and remove packages with Zypper for the SUSE Enterprise and openSUSE platforms."
|
30
|
+
examples <<~DOC
|
31
|
+
**Install a package using package manager:**
|
32
|
+
|
33
|
+
``` ruby
|
34
|
+
zypper_package 'name of package' do
|
35
|
+
action :install
|
36
|
+
end
|
37
|
+
```
|
38
|
+
|
39
|
+
**Install a package using local file:**
|
40
|
+
|
41
|
+
``` ruby
|
42
|
+
zypper_package 'jwhois' do
|
43
|
+
action :install
|
44
|
+
source '/path/to/jwhois.rpm'
|
45
|
+
end
|
46
|
+
```
|
47
|
+
|
48
|
+
**Install without using recommend packages as a dependency:**
|
49
|
+
|
50
|
+
``` ruby
|
51
|
+
package 'apache2' do
|
52
|
+
options '--no-recommends'
|
53
|
+
end
|
54
|
+
```
|
55
|
+
DOC
|
30
56
|
|
31
57
|
property :gpg_check, [ TrueClass, FalseClass ],
|
32
|
-
description: "Verify the package's GPG signature. Can also be controlled site-wide using the
|
58
|
+
description: "Verify the package's GPG signature. Can also be controlled site-wide using the `zypper_check_gpg` config option.",
|
33
59
|
default: lazy { Chef::Config[:zypper_check_gpg] }, default_description: "true"
|
34
60
|
|
35
61
|
property :allow_downgrade, [ TrueClass, FalseClass ],
|
@@ -39,7 +65,7 @@ class Chef
|
|
39
65
|
introduced: "13.6"
|
40
66
|
|
41
67
|
property :global_options, [ String, Array ],
|
42
|
-
description: "One (or more) additional command options that are passed to the command. For example, common zypper directives, such as
|
68
|
+
description: "One (or more) additional command options that are passed to the command. For example, common zypper directives, such as `--no-recommends`. See the [zypper man page](https://en.opensuse.org/SDB:Zypper_manual_(plain)) for the full list.",
|
43
69
|
coerce: proc { |x| x.is_a?(String) ? x.shellsplit : x },
|
44
70
|
introduced: "14.6"
|
45
71
|
end
|
@@ -26,17 +26,29 @@ class Chef
|
|
26
26
|
provides(:zypper_repository) { true }
|
27
27
|
provides(:zypper_repo) { true }
|
28
28
|
|
29
|
-
description "Use the zypper_repository resource to create Zypper package repositories on SUSE Enterprise Linux and openSUSE systems. This resource maintains full compatibility with the zypper_repository resource in the existing zypper cookbook."
|
29
|
+
description "Use the **zypper_repository** resource to create Zypper package repositories on SUSE Enterprise Linux and openSUSE systems. This resource maintains full compatibility with the **zypper_repository** resource in the existing **zypper** cookbook."
|
30
30
|
introduced "13.3"
|
31
|
+
examples <<~DOC
|
32
|
+
**Add the Apache repo on openSUSE Leap 15**:
|
33
|
+
|
34
|
+
``` ruby
|
35
|
+
zypper_repository 'apache' do
|
36
|
+
baseurl 'http://download.opensuse.org/repositories/Apache'
|
37
|
+
path '/openSUSE_Leap_15.0'
|
38
|
+
type 'rpm-md'
|
39
|
+
priority '100'
|
40
|
+
end
|
41
|
+
```
|
42
|
+
DOC
|
31
43
|
|
32
44
|
property :repo_name, String,
|
33
45
|
regex: [%r{^[^/]+$}],
|
34
46
|
description: "An optional property to set the repository name if it differs from the resource block's name.",
|
35
|
-
validation_message: "repo_name property cannot contain a forward slash
|
47
|
+
validation_message: "repo_name property cannot contain a forward slash `/`",
|
36
48
|
name_property: true
|
37
49
|
|
38
50
|
property :description, String,
|
39
|
-
description: "The description of the repository that will be shown by the
|
51
|
+
description: "The description of the repository that will be shown by the `zypper repos` command."
|
40
52
|
|
41
53
|
property :type, String,
|
42
54
|
description: "Specifies the repository type.",
|
@@ -58,7 +70,7 @@ class Chef
|
|
58
70
|
description: "The location of the repository key to be imported."
|
59
71
|
|
60
72
|
property :baseurl, String,
|
61
|
-
description: "The base URL for the Zypper repository, such as
|
73
|
+
description: "The base URL for the Zypper repository, such as `http://download.opensuse.org`."
|
62
74
|
|
63
75
|
property :mirrorlist, String,
|
64
76
|
description: "The URL of the mirror list that will be used."
|
@@ -67,7 +79,7 @@ class Chef
|
|
67
79
|
description: "The relative path from the repository's base URL."
|
68
80
|
|
69
81
|
property :priority, Integer,
|
70
|
-
description: "Determines the priority of the Zypper repository.
|
82
|
+
description: "Determines the priority of the Zypper repository.",
|
71
83
|
default: 99
|
72
84
|
|
73
85
|
property :keeppackages, [TrueClass, FalseClass],
|