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
@@ -113,7 +113,7 @@ class Chef
|
|
113
113
|
end
|
114
114
|
end
|
115
115
|
|
116
|
-
|
116
|
+
action :create do
|
117
117
|
unless registry.key_exists?(current_resource.key)
|
118
118
|
converge_by("create key #{new_resource.key}") do
|
119
119
|
registry.create_key(new_resource.key, new_resource.recursive)
|
@@ -150,7 +150,7 @@ class Chef
|
|
150
150
|
end
|
151
151
|
end
|
152
152
|
|
153
|
-
|
153
|
+
action :create_if_missing do
|
154
154
|
unless registry.key_exists?(new_resource.key)
|
155
155
|
converge_by("create key #{new_resource.key}") do
|
156
156
|
registry.create_key(new_resource.key, new_resource.recursive)
|
@@ -171,7 +171,7 @@ class Chef
|
|
171
171
|
end
|
172
172
|
end
|
173
173
|
|
174
|
-
|
174
|
+
action :delete do
|
175
175
|
if registry.key_exists?(new_resource.key)
|
176
176
|
new_resource.unscrubbed_values.each do |value|
|
177
177
|
if @name_hash.key?(value[:name].downcase)
|
@@ -186,7 +186,7 @@ class Chef
|
|
186
186
|
end
|
187
187
|
end
|
188
188
|
|
189
|
-
|
189
|
+
action :delete_key do
|
190
190
|
if registry.key_exists?(new_resource.key)
|
191
191
|
converge_by("delete key #{new_resource.key}") do
|
192
192
|
registry.delete_key(new_resource.key, new_resource.recursive)
|
@@ -58,8 +58,8 @@ class Chef
|
|
58
58
|
|
59
59
|
# Handle action :create.
|
60
60
|
#
|
61
|
-
|
62
|
-
super
|
61
|
+
action :create do
|
62
|
+
super()
|
63
63
|
|
64
64
|
# Transfer files
|
65
65
|
files_to_transfer.each do |cookbook_file_relative_path|
|
@@ -73,7 +73,7 @@ class Chef
|
|
73
73
|
|
74
74
|
# Handle action :create_if_missing.
|
75
75
|
#
|
76
|
-
|
76
|
+
action :create_if_missing do
|
77
77
|
# if this action is called, ignore the existing overwrite flag
|
78
78
|
@overwrite = false
|
79
79
|
action_create
|
@@ -147,7 +147,7 @@ class Chef
|
|
147
147
|
new_resource.updated_by_last_action(true) if res.updated?
|
148
148
|
end
|
149
149
|
|
150
|
-
# Get the files to
|
150
|
+
# Get the files to transfer. This returns files in lexicographical sort order.
|
151
151
|
#
|
152
152
|
# FIXME: it should do breadth-first, see CHEF-5080 (please use a performant sort)
|
153
153
|
#
|
@@ -245,7 +245,7 @@ class Chef
|
|
245
245
|
res = Chef::Resource::Directory.new(dir, run_context)
|
246
246
|
res.cookbook_name = resource_cookbook
|
247
247
|
if ChefUtils.windows? && rights
|
248
|
-
# rights are only meant to be applied to the
|
248
|
+
# rights are only meant to be applied to the most top-level directory;
|
249
249
|
# Windows will handle inheritance.
|
250
250
|
if dir == path
|
251
251
|
rights.each do |r|
|
@@ -17,6 +17,7 @@
|
|
17
17
|
#
|
18
18
|
|
19
19
|
require "uri" unless defined?(URI)
|
20
|
+
require "cgi" unless defined?(CGI)
|
20
21
|
require "tempfile" unless defined?(Tempfile)
|
21
22
|
require "net/ftp"
|
22
23
|
require_relative "../remote_file"
|
@@ -57,7 +58,7 @@ class Chef
|
|
57
58
|
|
58
59
|
def user
|
59
60
|
if uri.userinfo
|
60
|
-
|
61
|
+
CGI.unescape(uri.user)
|
61
62
|
else
|
62
63
|
"anonymous"
|
63
64
|
end
|
@@ -65,7 +66,7 @@ class Chef
|
|
65
66
|
|
66
67
|
def pass
|
67
68
|
if uri.userinfo
|
68
|
-
|
69
|
+
CGI.unescape(uri.password)
|
69
70
|
else
|
70
71
|
nil
|
71
72
|
end
|
@@ -17,6 +17,7 @@
|
|
17
17
|
#
|
18
18
|
|
19
19
|
require "uri" unless defined?(URI)
|
20
|
+
require "cgi" unless defined?(CGI)
|
20
21
|
require "tempfile" unless defined?(Tempfile)
|
21
22
|
require_relative "../remote_file"
|
22
23
|
|
@@ -40,7 +41,7 @@ class Chef
|
|
40
41
|
|
41
42
|
def source_path
|
42
43
|
@source_path ||= begin
|
43
|
-
path =
|
44
|
+
path = CGI.unescape(uri.path)
|
44
45
|
ChefUtils.windows? ? fix_windows_path(path) : path
|
45
46
|
end
|
46
47
|
end
|
@@ -17,6 +17,7 @@
|
|
17
17
|
#
|
18
18
|
|
19
19
|
require "uri" unless defined?(URI)
|
20
|
+
require "cgi" unless defined?(CGI)
|
20
21
|
require "tempfile" unless defined?(Tempfile)
|
21
22
|
require "net/sftp"
|
22
23
|
require_relative "../remote_file"
|
@@ -47,7 +48,7 @@ class Chef
|
|
47
48
|
end
|
48
49
|
|
49
50
|
def user
|
50
|
-
|
51
|
+
CGI.unescape(uri.user)
|
51
52
|
end
|
52
53
|
|
53
54
|
def fetch
|
@@ -62,7 +63,7 @@ class Chef
|
|
62
63
|
end
|
63
64
|
|
64
65
|
def pass
|
65
|
-
|
66
|
+
CGI.unescape(uri.password)
|
66
67
|
end
|
67
68
|
|
68
69
|
def validate_path!
|
data/lib/chef/provider/route.rb
CHANGED
@@ -128,7 +128,7 @@ class Chef
|
|
128
128
|
route_file.close
|
129
129
|
end
|
130
130
|
|
131
|
-
|
131
|
+
action :add do
|
132
132
|
# check to see if load_current_resource found the route
|
133
133
|
if is_running
|
134
134
|
logger.trace("#{new_resource} route already active - nothing to do")
|
@@ -144,7 +144,7 @@ class Chef
|
|
144
144
|
generate_config
|
145
145
|
end
|
146
146
|
|
147
|
-
|
147
|
+
action :delete do
|
148
148
|
if is_running
|
149
149
|
command = generate_command(:delete)
|
150
150
|
converge_by("run #{command.join(" ")} to delete route ") do
|
@@ -162,8 +162,10 @@ class Chef
|
|
162
162
|
def generate_config
|
163
163
|
if platform_family?("rhel", "amazon", "fedora")
|
164
164
|
conf = {}
|
165
|
+
# FIXME FIXME FIXME FIXME: whatever this walking-the-run-context API is, it needs to be removed.
|
165
166
|
# walk the collection
|
166
|
-
run_context.
|
167
|
+
rc = run_context.parent_run_context || run_context
|
168
|
+
rc.resource_collection.each do |resource|
|
167
169
|
next unless resource.is_a? Chef::Resource::Route
|
168
170
|
|
169
171
|
# default to eth0
|
data/lib/chef/provider/script.rb
CHANGED
@@ -80,7 +80,7 @@ class Chef
|
|
80
80
|
end
|
81
81
|
end
|
82
82
|
|
83
|
-
|
83
|
+
action :enable do
|
84
84
|
if current_resource.enabled
|
85
85
|
logger.trace("#{new_resource} already enabled - nothing to do")
|
86
86
|
else
|
@@ -93,7 +93,7 @@ class Chef
|
|
93
93
|
new_resource.enabled(true)
|
94
94
|
end
|
95
95
|
|
96
|
-
|
96
|
+
action :disable do
|
97
97
|
if current_resource.enabled
|
98
98
|
converge_by("disable service #{new_resource}") do
|
99
99
|
disable_service
|
@@ -106,7 +106,7 @@ class Chef
|
|
106
106
|
new_resource.enabled(false)
|
107
107
|
end
|
108
108
|
|
109
|
-
|
109
|
+
action :mask do
|
110
110
|
if current_resource.masked
|
111
111
|
logger.trace("#{new_resource} already masked - nothing to do")
|
112
112
|
else
|
@@ -119,7 +119,7 @@ class Chef
|
|
119
119
|
new_resource.masked(true)
|
120
120
|
end
|
121
121
|
|
122
|
-
|
122
|
+
action :unmask do
|
123
123
|
if current_resource.masked
|
124
124
|
converge_by("unmask service #{new_resource}") do
|
125
125
|
unmask_service
|
@@ -132,7 +132,7 @@ class Chef
|
|
132
132
|
new_resource.masked(false)
|
133
133
|
end
|
134
134
|
|
135
|
-
|
135
|
+
action :start do
|
136
136
|
unless current_resource.running
|
137
137
|
converge_by("start service #{new_resource}") do
|
138
138
|
start_service
|
@@ -145,7 +145,7 @@ class Chef
|
|
145
145
|
new_resource.running(true)
|
146
146
|
end
|
147
147
|
|
148
|
-
|
148
|
+
action :stop do
|
149
149
|
if current_resource.running
|
150
150
|
converge_by("stop service #{new_resource}") do
|
151
151
|
stop_service
|
@@ -158,7 +158,7 @@ class Chef
|
|
158
158
|
new_resource.running(false)
|
159
159
|
end
|
160
160
|
|
161
|
-
|
161
|
+
action :restart do
|
162
162
|
converge_by("restart service #{new_resource}") do
|
163
163
|
restart_service
|
164
164
|
logger.info("#{new_resource} restarted")
|
@@ -167,7 +167,7 @@ class Chef
|
|
167
167
|
new_resource.running(true)
|
168
168
|
end
|
169
169
|
|
170
|
-
|
170
|
+
action :reload do
|
171
171
|
if current_resource.running
|
172
172
|
converge_by("reload service #{new_resource}") do
|
173
173
|
reload_service
|
@@ -42,7 +42,7 @@ class Chef::Provider::Service::Arch < Chef::Provider::Service::Init
|
|
42
42
|
end
|
43
43
|
|
44
44
|
# Get list of all daemons from the file '/etc/rc.conf'.
|
45
|
-
#
|
45
|
+
# Multiple lines and background form are supported. Example:
|
46
46
|
# DAEMONS=(\
|
47
47
|
# foobar \
|
48
48
|
# @example \
|
@@ -130,7 +130,7 @@ class Chef
|
|
130
130
|
end
|
131
131
|
|
132
132
|
# Override method from parent to ensure priority is up-to-date
|
133
|
-
|
133
|
+
action :enable do
|
134
134
|
if new_resource.priority.nil?
|
135
135
|
priority_ok = true
|
136
136
|
else
|
@@ -149,44 +149,46 @@ class Chef
|
|
149
149
|
end
|
150
150
|
|
151
151
|
def enable_service
|
152
|
-
if
|
153
|
-
|
154
|
-
|
155
|
-
elsif new_resource.priority.is_a? Hash
|
156
|
-
# we call the same command regardless of we're enabling or disabling
|
157
|
-
# users passing a Hash are responsible for setting their own start priorities
|
152
|
+
# We call the same command regardless if we're enabling or disabling
|
153
|
+
# Users passing a Hash are responsible for setting their own stop priorities
|
154
|
+
if new_resource.priority.is_a? Hash
|
158
155
|
set_priority
|
159
|
-
|
160
|
-
shell_out!("/usr/sbin/update-rc.d -f #{new_resource.service_name} remove")
|
161
|
-
shell_out!("/usr/sbin/update-rc.d #{new_resource.service_name} defaults")
|
156
|
+
return
|
162
157
|
end
|
158
|
+
|
159
|
+
start_priority = new_resource.priority.is_a?(Integer) ? new_resource.priority : 20
|
160
|
+
# Stop processes in reverse order of start using '100 - start_priority'.
|
161
|
+
stop_priority = 100 - start_priority
|
162
|
+
|
163
|
+
shell_out!("/usr/sbin/update-rc.d -f #{new_resource.service_name} remove")
|
164
|
+
shell_out!("/usr/sbin/update-rc.d #{new_resource.service_name} defaults #{start_priority} #{stop_priority}")
|
163
165
|
end
|
164
166
|
|
165
167
|
def disable_service
|
166
|
-
if new_resource.priority.is_a?
|
167
|
-
#
|
168
|
-
|
169
|
-
shell_out!("/usr/sbin/update-rc.d -f #{new_resource.service_name} stop #{100 - new_resource.priority} 2 3 4 5 .")
|
170
|
-
elsif new_resource.priority.is_a? Hash
|
171
|
-
# we call the same command regardless of we're enabling or disabling
|
172
|
-
# users passing a Hash are responsible for setting their own stop priorities
|
168
|
+
if new_resource.priority.is_a? Hash
|
169
|
+
# We call the same command regardless if we're enabling or disabling
|
170
|
+
# Users passing a Hash are responsible for setting their own stop priorities
|
173
171
|
set_priority
|
174
|
-
|
175
|
-
# no priority, using '100 - 20 (update-rc.d default)' to stop in reverse order of start
|
176
|
-
shell_out!("/usr/sbin/update-rc.d -f #{new_resource.service_name} remove")
|
177
|
-
shell_out!("/usr/sbin/update-rc.d -f #{new_resource.service_name} stop 80 2 3 4 5 .")
|
172
|
+
return
|
178
173
|
end
|
174
|
+
|
175
|
+
shell_out!("/usr/sbin/update-rc.d -f #{new_resource.service_name} remove")
|
176
|
+
shell_out!("/usr/sbin/update-rc.d #{new_resource.service_name} defaults")
|
177
|
+
shell_out!("/usr/sbin/update-rc.d #{new_resource.service_name} disable")
|
179
178
|
end
|
180
179
|
|
181
180
|
def set_priority
|
182
|
-
args = ""
|
183
|
-
new_resource.priority.each do |level, o|
|
184
|
-
action = o[0]
|
185
|
-
priority = o[1]
|
186
|
-
args += "#{action} #{priority} #{level} . "
|
187
|
-
end
|
188
181
|
shell_out!("/usr/sbin/update-rc.d -f #{new_resource.service_name} remove")
|
189
|
-
|
182
|
+
|
183
|
+
# Reset priorities to default values before applying customizations. This way
|
184
|
+
# the final state will always be consistent, regardless if all runlevels were
|
185
|
+
# provided.
|
186
|
+
shell_out!("/usr/sbin/update-rc.d #{new_resource.service_name} defaults")
|
187
|
+
new_resource.priority.each do |level, (action, _priority)|
|
188
|
+
disable_or_enable = (action == :start ? "enable" : "disable")
|
189
|
+
|
190
|
+
shell_out!("/usr/sbin/update-rc.d #{new_resource.service_name} #{disable_or_enable} #{level}")
|
191
|
+
end
|
190
192
|
end
|
191
193
|
end
|
192
194
|
end
|
@@ -1,6 +1,7 @@
|
|
1
1
|
#
|
2
2
|
# Author:: Igor Afonov <afonov@gmail.com>
|
3
3
|
# Copyright:: Copyright 2011-2016, Igor Afonov
|
4
|
+
# Copyright:: Copyright (c) Chef Software Inc.
|
4
5
|
# License:: Apache License, Version 2.0
|
5
6
|
#
|
6
7
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
@@ -42,10 +43,6 @@ class Chef
|
|
42
43
|
|
43
44
|
PLIST_DIRS = gather_plist_dirs
|
44
45
|
|
45
|
-
def this_version_or_newer?(this_version)
|
46
|
-
Gem::Version.new(node["platform_version"]) >= Gem::Version.new(this_version)
|
47
|
-
end
|
48
|
-
|
49
46
|
def load_current_resource
|
50
47
|
@current_resource = Chef::Resource::MacosxService.new(@new_resource.name)
|
51
48
|
@current_resource.service_name(@new_resource.service_name)
|
@@ -59,10 +56,10 @@ class Chef
|
|
59
56
|
if @console_user
|
60
57
|
@console_user = Etc.getpwuid(::File.stat("/dev/console").uid).name
|
61
58
|
logger.trace("#{new_resource} console_user: '#{@console_user}'")
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
59
|
+
|
60
|
+
@base_user_cmd = "su -l #{@console_user} -c"
|
61
|
+
logger.trace("#{new_resource} base_user_cmd: '#{@base_user_cmd}'")
|
62
|
+
|
66
63
|
# Default LaunchAgent session should be Aqua
|
67
64
|
@session_type = "Aqua" if @session_type.nil?
|
68
65
|
end
|
@@ -140,11 +137,20 @@ class Chef
|
|
140
137
|
end
|
141
138
|
end
|
142
139
|
|
143
|
-
# On
|
140
|
+
# On macOS, enabling a service has the side-effect of starting it,
|
144
141
|
# and disabling a service has the side-effect of stopping it.
|
145
142
|
#
|
146
|
-
# This makes some sense on
|
143
|
+
# This makes some sense on macOS since launchctl is an "init"-style
|
147
144
|
# supervisor that will restart daemons that are crashing, etc.
|
145
|
+
#
|
146
|
+
# FIXME: Does this make any sense at all? The difference between enabled and
|
147
|
+
# running as state would seem to only be useful for completely broken
|
148
|
+
# services (enabled, not restarting, but not running => totally broken?).
|
149
|
+
#
|
150
|
+
# It seems like otherwise :enable is equivalent to :start, and :disable is
|
151
|
+
# equivalent to :stop? But just with strangely different behavior in the
|
152
|
+
# face of a broken service?
|
153
|
+
#
|
148
154
|
def enable_service
|
149
155
|
if @current_resource.enabled
|
150
156
|
logger.trace("#{@new_resource} already enabled, not enabling")
|
@@ -104,7 +104,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
104
104
|
super
|
105
105
|
else
|
106
106
|
options, args = get_systemctl_options_args
|
107
|
-
shell_out!(
|
107
|
+
shell_out!(systemctl_path, args, "start", new_resource.service_name, default_env: false, **options)
|
108
108
|
end
|
109
109
|
end
|
110
110
|
end
|
@@ -117,7 +117,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
117
117
|
super
|
118
118
|
else
|
119
119
|
options, args = get_systemctl_options_args
|
120
|
-
shell_out!(
|
120
|
+
shell_out!(systemctl_path, args, "stop", new_resource.service_name, default_env: false, **options)
|
121
121
|
end
|
122
122
|
end
|
123
123
|
end
|
@@ -127,7 +127,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
127
127
|
super
|
128
128
|
else
|
129
129
|
options, args = get_systemctl_options_args
|
130
|
-
shell_out!(
|
130
|
+
shell_out!(systemctl_path, args, "restart", new_resource.service_name, default_env: false, **options)
|
131
131
|
end
|
132
132
|
end
|
133
133
|
|
@@ -137,7 +137,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
137
137
|
else
|
138
138
|
if current_resource.running
|
139
139
|
options, args = get_systemctl_options_args
|
140
|
-
shell_out!(
|
140
|
+
shell_out!(systemctl_path, args, "reload", new_resource.service_name, default_env: false, **options)
|
141
141
|
else
|
142
142
|
start_service
|
143
143
|
end
|
@@ -150,7 +150,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
150
150
|
return
|
151
151
|
end
|
152
152
|
options, args = get_systemctl_options_args
|
153
|
-
shell_out!(
|
153
|
+
shell_out!(systemctl_path, args, "enable", new_resource.service_name, **options)
|
154
154
|
end
|
155
155
|
|
156
156
|
def disable_service
|
@@ -159,38 +159,38 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
159
159
|
return
|
160
160
|
end
|
161
161
|
options, args = get_systemctl_options_args
|
162
|
-
shell_out!(
|
162
|
+
shell_out!(systemctl_path, args, "disable", new_resource.service_name, **options)
|
163
163
|
end
|
164
164
|
|
165
165
|
def mask_service
|
166
166
|
options, args = get_systemctl_options_args
|
167
|
-
shell_out!(
|
167
|
+
shell_out!(systemctl_path, args, "mask", new_resource.service_name, **options)
|
168
168
|
end
|
169
169
|
|
170
170
|
def unmask_service
|
171
171
|
options, args = get_systemctl_options_args
|
172
|
-
shell_out!(
|
172
|
+
shell_out!(systemctl_path, args, "unmask", new_resource.service_name, **options)
|
173
173
|
end
|
174
174
|
|
175
175
|
def is_active?
|
176
176
|
options, args = get_systemctl_options_args
|
177
|
-
shell_out(
|
177
|
+
shell_out(systemctl_path, args, "is-active", new_resource.service_name, "--quiet", **options).exitstatus == 0
|
178
178
|
end
|
179
179
|
|
180
180
|
def is_enabled?
|
181
181
|
options, args = get_systemctl_options_args
|
182
|
-
shell_out(
|
182
|
+
shell_out(systemctl_path, args, "is-enabled", new_resource.service_name, "--quiet", **options).exitstatus == 0
|
183
183
|
end
|
184
184
|
|
185
185
|
def is_indirect?
|
186
186
|
options, args = get_systemctl_options_args
|
187
|
-
s = shell_out(
|
187
|
+
s = shell_out(systemctl_path, args, "is-enabled", new_resource.service_name, **options)
|
188
188
|
s.stdout.include?("indirect")
|
189
189
|
end
|
190
190
|
|
191
191
|
def is_masked?
|
192
192
|
options, args = get_systemctl_options_args
|
193
|
-
s = shell_out(
|
193
|
+
s = shell_out(systemctl_path, args, "is-enabled", new_resource.service_name, **options)
|
194
194
|
s.exitstatus != 0 && s.stdout.include?("masked")
|
195
195
|
end
|
196
196
|
|