chef 16.18.0-universal-mingw32 → 17.0.242-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 +9 -13
- data/README.md +1 -1
- data/Rakefile +2 -2
- data/chef-universal-mingw32.gemspec +1 -1
- data/chef.gemspec +6 -8
- data/lib/chef/action_collection.rb +1 -1
- data/lib/chef/application/base.rb +1 -1
- data/lib/chef/application.rb +1 -1
- data/lib/chef/applications.rb +0 -1
- data/lib/chef/chef_fs/command_line.rb +5 -2
- data/lib/chef/chef_fs/file_system.rb +9 -10
- data/lib/chef/client.rb +5 -5
- data/lib/chef/compliance/default_attributes.rb +4 -3
- data/lib/chef/compliance/fetcher/automate.rb +0 -7
- data/lib/chef/compliance/reporter/automate.rb +17 -7
- data/lib/chef/compliance/reporter/chef_server_automate.rb +11 -6
- data/lib/chef/compliance/reporter/cli.rb +77 -0
- data/lib/chef/compliance/reporter/compliance_enforcer.rb +4 -0
- data/lib/chef/compliance/reporter/json_file.rb +8 -1
- data/lib/chef/compliance/runner.rb +65 -27
- data/lib/chef/cookbook/gem_installer.rb +1 -5
- data/lib/chef/cookbook/synchronizer.rb +3 -5
- data/lib/chef/cookbook_loader.rb +2 -4
- data/lib/chef/cookbook_uploader.rb +0 -1
- data/lib/chef/cookbook_version.rb +4 -26
- data/lib/chef/data_bag_item.rb +11 -2
- data/lib/chef/data_collector/run_end_message.rb +2 -2
- data/lib/chef/delayed_evaluator.rb +4 -0
- data/lib/chef/deprecated.rb +6 -12
- data/lib/chef/dsl/chef_vault.rb +6 -6
- data/lib/chef/dsl/reboot_pending.rb +1 -2
- data/lib/chef/exceptions.rb +0 -3
- data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +20 -22
- data/lib/chef/formatters/error_mapper.rb +2 -2
- data/lib/chef/group.rb +75 -0
- data/lib/chef/http.rb +5 -5
- data/lib/chef/mixin/get_source_from_package.rb +1 -1
- data/lib/chef/node/attribute.rb +9 -24
- data/lib/chef/node/immutable_collections.rb +13 -0
- data/lib/chef/node/mixin/deep_merge_cache.rb +14 -10
- data/lib/chef/node.rb +19 -20
- data/lib/chef/org.rb +3 -2
- data/lib/chef/policy_builder/policyfile.rb +0 -5
- data/lib/chef/property.rb +18 -0
- data/lib/chef/provider/cron.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 +5 -7
- data/lib/chef/provider/group/dscl.rb +1 -1
- data/lib/chef/provider/group/groupadd.rb +3 -3
- data/lib/chef/provider/group/groupmod.rb +3 -3
- data/lib/chef/provider/group/pw.rb +3 -3
- data/lib/chef/provider/ifconfig.rb +2 -2
- data/lib/chef/provider/link.rb +2 -2
- data/lib/chef/provider/mount/aix.rb +3 -3
- data/lib/chef/provider/mount/mount.rb +5 -5
- data/lib/chef/provider/mount/windows.rb +1 -1
- data/lib/chef/provider/mount.rb +5 -5
- data/lib/chef/provider/package/apt.rb +27 -1
- data/lib/chef/provider/package/deb.rb +3 -3
- data/lib/chef/provider/package/dnf/dnf_helper.py +1 -1
- data/lib/chef/provider/package/portage.rb +2 -2
- data/lib/chef/provider/package/powershell.rb +0 -5
- data/lib/chef/provider/package/rubygems.rb +9 -15
- data/lib/chef/provider/package/windows.rb +2 -4
- data/lib/chef/provider/package/yum/yum_helper.py +1 -1
- data/lib/chef/provider/package.rb +17 -21
- data/lib/chef/provider/route.rb +2 -2
- data/lib/chef/provider/service/aixinit.rb +1 -1
- data/lib/chef/provider/service/debian.rb +1 -1
- data/lib/chef/provider/service/freebsd.rb +15 -21
- data/lib/chef/provider/service/macosx.rb +4 -4
- data/lib/chef/provider/service/systemd.rb +43 -14
- data/lib/chef/provider/service/upstart.rb +2 -13
- data/lib/chef/provider/service/windows.rb +12 -12
- data/lib/chef/provider/service.rb +6 -6
- data/lib/chef/provider/subversion.rb +10 -12
- data/lib/chef/provider/systemd_unit.rb +36 -10
- data/lib/chef/provider/template/content.rb +3 -7
- data/lib/chef/provider/user/dscl.rb +1 -1
- data/lib/chef/provider/user/mac.rb +17 -20
- data/lib/chef/provider/user/pw.rb +1 -1
- data/lib/chef/provider/user/windows.rb +1 -1
- data/lib/chef/provider/user.rb +2 -2
- data/lib/chef/provider/zypper_repository.rb +2 -2
- data/lib/chef/provider.rb +1 -1
- data/lib/chef/providers.rb +0 -1
- data/lib/chef/resource/alternatives.rb +6 -6
- data/lib/chef/resource/apt_package.rb +1 -1
- data/lib/chef/resource/apt_preference.rb +2 -2
- data/lib/chef/resource/apt_repository.rb +6 -6
- data/lib/chef/resource/apt_update.rb +3 -2
- data/lib/chef/resource/archive_file.rb +8 -9
- data/lib/chef/resource/breakpoint.rb +1 -1
- data/lib/chef/resource/build_essential.rb +2 -6
- data/lib/chef/resource/chef_client_config.rb +2 -2
- data/lib/chef/resource/chef_client_cron.rb +4 -4
- data/lib/chef/resource/chef_client_launchd.rb +3 -3
- data/lib/chef/resource/chef_client_scheduled_task.rb +1 -1
- data/lib/chef/resource/chef_client_systemd_timer.rb +2 -2
- data/lib/chef/resource/chef_client_trusted_certificate.rb +0 -1
- data/lib/chef/resource/chef_handler.rb +3 -7
- data/lib/chef/resource/chef_sleep.rb +1 -1
- data/lib/chef/resource/chef_vault_secret.rb +3 -8
- data/lib/chef/resource/chocolatey_config.rb +2 -6
- data/lib/chef/resource/chocolatey_feature.rb +2 -6
- data/lib/chef/resource/chocolatey_source.rb +4 -10
- data/lib/chef/resource/cron/_cron_shared.rb +2 -2
- data/lib/chef/resource/cron_access.rb +2 -4
- data/lib/chef/resource/dmg_package.rb +6 -10
- data/lib/chef/resource/dpkg_package.rb +1 -1
- data/lib/chef/resource/execute.rb +6 -1
- data/lib/chef/resource/file.rb +1 -1
- data/lib/chef/resource/group.rb +2 -2
- data/lib/chef/resource/homebrew_cask.rb +5 -15
- data/lib/chef/resource/homebrew_tap.rb +2 -6
- data/lib/chef/resource/hostname.rb +21 -17
- data/lib/chef/resource/http_request.rb +1 -1
- data/lib/chef/resource/kernel_module.rb +6 -17
- data/lib/chef/resource/locale.rb +2 -3
- data/lib/chef/resource/lwrp_base.rb +4 -0
- data/lib/chef/resource/macos_userdefaults.rb +10 -14
- data/lib/chef/resource/mdadm.rb +53 -7
- data/lib/chef/resource/mount.rb +3 -2
- data/lib/chef/resource/openssl_ec_private_key.rb +2 -2
- data/lib/chef/resource/openssl_rsa_private_key.rb +1 -1
- data/lib/chef/resource/openssl_x509_certificate.rb +2 -2
- data/lib/chef/resource/plist.rb +7 -7
- data/lib/chef/resource/powershell_script.rb +1 -1
- data/lib/chef/resource/remote_file.rb +1 -1
- data/lib/chef/resource/rhsm_errata.rb +16 -1
- data/lib/chef/resource/rhsm_errata_level.rb +10 -1
- data/lib/chef/resource/rhsm_register.rb +12 -6
- data/lib/chef/resource/rhsm_repo.rb +2 -6
- data/lib/chef/resource/rhsm_subscription.rb +7 -11
- data/lib/chef/resource/scm/git.rb +1 -1
- data/lib/chef/resource/sudo.rb +6 -6
- data/lib/chef/resource/support/client.erb +2 -6
- data/lib/chef/resource/sysctl.rb +2 -6
- data/lib/chef/resource/systemd_unit.rb +3 -3
- data/lib/chef/resource/template.rb +1 -1
- data/lib/chef/resource/timezone.rb +1 -3
- data/lib/chef/resource/user/mac_user.rb +1 -1
- data/lib/chef/resource/user_ulimit.rb +2 -3
- data/lib/chef/resource/windows_ad_join.rb +2 -6
- data/lib/chef/resource/windows_audit_policy.rb +1 -1
- data/lib/chef/resource/windows_auto_run.rb +2 -5
- data/lib/chef/resource/windows_certificate.rb +207 -73
- data/lib/chef/resource/windows_dfs_folder.rb +2 -6
- data/lib/chef/resource/windows_dfs_namespace.rb +2 -6
- data/lib/chef/resource/windows_dfs_server.rb +1 -3
- data/lib/chef/resource/windows_dns_record.rb +2 -6
- data/lib/chef/resource/windows_dns_zone.rb +2 -6
- data/lib/chef/resource/windows_env.rb +5 -4
- data/lib/chef/resource/windows_feature.rb +3 -9
- data/lib/chef/resource/windows_feature_dism.rb +2 -6
- data/lib/chef/resource/windows_feature_powershell.rb +3 -3
- data/lib/chef/resource/windows_firewall_profile.rb +4 -4
- data/lib/chef/resource/windows_firewall_rule.rb +2 -5
- data/lib/chef/resource/windows_font.rb +2 -4
- data/lib/chef/resource/windows_pagefile.rb +2 -6
- data/lib/chef/resource/windows_path.rb +2 -2
- data/lib/chef/resource/windows_printer.rb +4 -4
- data/lib/chef/resource/windows_printer_port.rb +6 -6
- data/lib/chef/resource/windows_security_policy.rb +9 -12
- data/lib/chef/resource/windows_share.rb +14 -21
- data/lib/chef/resource/windows_shortcut.rb +4 -6
- data/lib/chef/resource/windows_task.rb +17 -5
- data/lib/chef/resource/windows_uac.rb +2 -4
- data/lib/chef/resource/windows_user_privilege.rb +5 -5
- data/lib/chef/resource/windows_workgroup.rb +1 -2
- data/lib/chef/resource.rb +1 -1
- data/lib/chef/resource_reporter.rb +1 -1
- data/lib/chef/resources.rb +0 -1
- data/lib/chef/shell/ext.rb +3 -3
- data/lib/chef/user.rb +0 -1
- data/lib/chef/user_v1.rb +3 -4
- data/lib/chef/util/dsc/configuration_generator.rb +1 -0
- data/lib/chef/util/dsc/local_configuration_manager.rb +1 -1
- data/lib/chef/version.rb +1 -1
- data/lib/chef/win32/api.rb +2 -9
- data/lib/chef/win32/registry.rb +4 -2
- data/lib/chef/win32/version.rb +1 -2
- data/spec/data/cookbooks/openldap/libraries/openldap.rb +1 -1
- data/spec/data/lwrp/resources/bar.rb +2 -0
- data/spec/data/lwrp/resources/buck_passer.rb +1 -0
- data/spec/data/lwrp/resources/buck_passer_2.rb +1 -0
- data/spec/data/lwrp/resources/embedded_resource_accesses_providers_scope.rb +1 -0
- data/spec/data/lwrp/resources/foo.rb +2 -0
- data/spec/data/lwrp/resources/inline_compiler.rb +1 -0
- data/spec/data/lwrp/resources/monkey_name_printer.rb +1 -0
- data/spec/data/lwrp/resources/paint_drying_watcher.rb +1 -0
- data/spec/data/lwrp/resources/thumb_twiddler.rb +1 -0
- data/spec/data/lwrp/resources_with_default_attributes/nodeattr.rb +2 -0
- data/spec/data/lwrp_const_scoping/resources/conflict.rb +1 -0
- data/spec/data/lwrp_override/resources/foo.rb +1 -0
- data/spec/data/rubygems.org/nonexistent_gem-info +1 -0
- data/spec/data/rubygems.org/sexp_processor-info +49 -0
- data/spec/data/run_context/cookbooks/circular-dep1/resources/resource.rb +1 -0
- data/spec/data/run_context/cookbooks/circular-dep2/resources/resource.rb +1 -0
- data/spec/data/run_context/cookbooks/dependency1/resources/resource.rb +1 -0
- data/spec/data/run_context/cookbooks/dependency2/resources/resource.rb +1 -0
- data/spec/data/run_context/cookbooks/no-default-attr/resources/resource.rb +1 -0
- data/spec/data/run_context/cookbooks/test/resources/resource.rb +2 -0
- data/spec/data/run_context/cookbooks/test-with-circular-deps/resources/resource.rb +2 -0
- data/spec/data/run_context/cookbooks/test-with-deps/resources/resource.rb +1 -0
- data/spec/functional/dsl/registry_helper_spec.rb +1 -1
- data/spec/functional/resource/aixinit_service_spec.rb +7 -7
- data/spec/functional/resource/apt_package_spec.rb +1 -1
- data/spec/functional/resource/chocolatey_package_spec.rb +9 -0
- data/spec/functional/resource/dnf_package_spec.rb +4 -1
- data/spec/functional/resource/group_spec.rb +1 -5
- data/spec/functional/resource/link_spec.rb +0 -8
- data/spec/functional/resource/registry_spec.rb +8 -8
- data/spec/functional/resource/user/mac_user_spec.rb +2 -2
- data/spec/functional/resource/windows_certificate_spec.rb +92 -35
- data/spec/functional/version_spec.rb +1 -1
- data/spec/functional/win32/registry_spec.rb +1 -1
- data/spec/integration/client/client_spec.rb +5 -2
- data/spec/integration/client/exit_code_spec.rb +1 -1
- data/spec/integration/client/ipv6_spec.rb +1 -1
- data/spec/integration/compliance/compliance_spec.rb +1 -1
- data/spec/integration/ohai/ohai_spec.rb +7 -6
- data/spec/integration/recipes/accumulator_spec.rb +13 -1
- data/spec/integration/recipes/lwrp_inline_resources_spec.rb +5 -1
- data/spec/integration/recipes/lwrp_spec.rb +3 -1
- data/spec/integration/recipes/notifies_spec.rb +15 -1
- data/spec/integration/recipes/notifying_block_spec.rb +2 -1
- data/spec/integration/recipes/recipe_dsl_spec.rb +9 -9
- data/spec/integration/recipes/unified_mode_spec.rb +1 -1
- data/spec/integration/recipes/use_partial_spec.rb +4 -1
- data/spec/spec_helper.rb +10 -13
- data/spec/support/chef_helpers.rb +0 -16
- data/spec/support/lib/chef/resource/with_state.rb +0 -1
- data/spec/support/lib/chef/resource/zen_follower.rb +0 -1
- data/spec/support/lib/chef/resource/zen_master.rb +0 -1
- data/spec/support/matchers/leak.rb +7 -9
- data/spec/support/platform_helpers.rb +1 -8
- data/spec/support/shared/integration/integration_helper.rb +0 -1
- data/spec/support/shared/unit/script_resource.rb +2 -2
- data/spec/unit/application/solo_spec.rb +2 -2
- data/spec/unit/chef_fs/diff_spec.rb +1 -1
- data/spec/unit/chef_fs/file_system_spec.rb +1 -1
- data/spec/unit/client_spec.rb +4 -4
- data/spec/unit/compliance/fetcher/automate_spec.rb +0 -16
- data/spec/unit/compliance/reporter/automate_spec.rb +26 -2
- data/spec/unit/compliance/reporter/chef_server_automate_spec.rb +20 -0
- data/spec/unit/compliance/reporter/compliance_enforcer_spec.rb +1 -0
- data/spec/unit/compliance/runner_spec.rb +30 -4
- data/spec/unit/cookbook_version_spec.rb +0 -52
- data/spec/unit/data_bag_item_spec.rb +1 -6
- data/spec/unit/data_collector_spec.rb +2 -71
- data/spec/unit/dsl/reboot_pending_spec.rb +2 -2
- data/spec/unit/dsl/registry_helper_spec.rb +1 -1
- data/spec/unit/lwrp_spec.rb +1 -1
- data/spec/unit/mixin/params_validate_spec.rb +4 -3
- data/spec/unit/mixin/powershell_out_spec.rb +2 -2
- data/spec/unit/node/attribute_spec.rb +1 -1
- data/spec/unit/node_spec.rb +78 -0
- data/spec/unit/org_group_spec.rb +45 -0
- data/spec/unit/policy_builder/policyfile_spec.rb +1 -11
- data/spec/unit/property_spec.rb +23 -22
- data/spec/unit/provider/cron_spec.rb +1 -1
- data/spec/unit/provider/group/gpasswd_spec.rb +2 -2
- data/spec/unit/provider/group/groupmod_spec.rb +2 -2
- data/spec/unit/provider/group/pw_spec.rb +2 -2
- data/spec/unit/provider/group_spec.rb +1 -1
- data/spec/unit/provider/package/apt_spec.rb +84 -18
- data/spec/unit/provider/package/deb_spec.rb +3 -3
- data/spec/unit/provider/package/powershell_spec.rb +12 -74
- data/spec/unit/provider/package/rubygems_spec.rb +18 -30
- data/spec/unit/provider/service/arch_service_spec.rb +1 -0
- data/spec/unit/provider/service/debian_service_spec.rb +1 -0
- data/spec/unit/provider/service/macosx_spec.rb +2 -2
- data/spec/unit/provider/service/systemd_service_spec.rb +138 -23
- data/spec/unit/provider/service/upstart_service_spec.rb +0 -29
- data/spec/unit/provider/service/windows_spec.rb +2 -2
- data/spec/unit/provider/subversion_spec.rb +2 -2
- data/spec/unit/provider/systemd_unit_spec.rb +79 -60
- data/spec/unit/provider/zypper_repository_spec.rb +2 -2
- data/spec/unit/provider_spec.rb +0 -8
- data/spec/unit/resource/archive_file_spec.rb +1 -13
- data/spec/unit/resource/chef_client_trusted_certificate_spec.rb +0 -14
- data/spec/unit/resource/homebrew_cask_spec.rb +11 -29
- data/spec/unit/resource/mount_spec.rb +0 -10
- data/spec/unit/resource/powershell_script_spec.rb +2 -2
- data/spec/unit/resource/rhsm_subscription_spec.rb +3 -50
- data/spec/unit/resource/systemd_unit_spec.rb +1 -1
- data/spec/unit/resource/user_ulimit_spec.rb +1 -14
- data/spec/unit/resource/windows_task_spec.rb +1 -1
- data/spec/unit/resource_spec.rb +2 -7
- data/spec/unit/user_spec.rb +1 -1
- data/spec/unit/user_v1_spec.rb +6 -4
- data/tasks/rspec.rb +15 -7
- metadata +19 -382
- data/bin/knife +0 -24
- data/lib/chef/application/knife.rb +0 -234
- data/lib/chef/application/windows_service.rb +0 -338
- data/lib/chef/application/windows_service_manager.rb +0 -205
- data/lib/chef/chef_fs/knife.rb +0 -160
- data/lib/chef/chef_fs/parallelizer/flatten_enumerable.rb +0 -35
- data/lib/chef/chef_fs/parallelizer/parallel_enumerable.rb +0 -278
- data/lib/chef/chef_fs/parallelizer.rb +0 -102
- data/lib/chef/cookbook_site_streaming_uploader.rb +0 -244
- data/lib/chef/knife/acl_add.rb +0 -57
- data/lib/chef/knife/acl_base.rb +0 -183
- data/lib/chef/knife/acl_bulk_add.rb +0 -78
- data/lib/chef/knife/acl_bulk_remove.rb +0 -83
- data/lib/chef/knife/acl_remove.rb +0 -62
- data/lib/chef/knife/acl_show.rb +0 -56
- data/lib/chef/knife/bootstrap/chef_vault_handler.rb +0 -162
- data/lib/chef/knife/bootstrap/client_builder.rb +0 -212
- data/lib/chef/knife/bootstrap/templates/README.md +0 -11
- data/lib/chef/knife/bootstrap/templates/chef-full.erb +0 -242
- data/lib/chef/knife/bootstrap/templates/windows-chef-client-msi.erb +0 -278
- data/lib/chef/knife/bootstrap/train_connector.rb +0 -336
- data/lib/chef/knife/bootstrap.rb +0 -1192
- data/lib/chef/knife/client_bulk_delete.rb +0 -104
- data/lib/chef/knife/client_create.rb +0 -101
- data/lib/chef/knife/client_delete.rb +0 -62
- data/lib/chef/knife/client_edit.rb +0 -52
- data/lib/chef/knife/client_key_create.rb +0 -73
- data/lib/chef/knife/client_key_delete.rb +0 -80
- data/lib/chef/knife/client_key_edit.rb +0 -83
- data/lib/chef/knife/client_key_list.rb +0 -73
- data/lib/chef/knife/client_key_show.rb +0 -80
- data/lib/chef/knife/client_list.rb +0 -41
- data/lib/chef/knife/client_reregister.rb +0 -58
- data/lib/chef/knife/client_show.rb +0 -48
- data/lib/chef/knife/config_get.rb +0 -39
- data/lib/chef/knife/config_get_profile.rb +0 -37
- data/lib/chef/knife/config_list.rb +0 -139
- data/lib/chef/knife/config_list_profiles.rb +0 -37
- data/lib/chef/knife/config_show.rb +0 -127
- data/lib/chef/knife/config_use.rb +0 -61
- data/lib/chef/knife/config_use_profile.rb +0 -47
- data/lib/chef/knife/configure.rb +0 -150
- data/lib/chef/knife/configure_client.rb +0 -48
- data/lib/chef/knife/cookbook_bulk_delete.rb +0 -71
- data/lib/chef/knife/cookbook_delete.rb +0 -151
- data/lib/chef/knife/cookbook_download.rb +0 -142
- data/lib/chef/knife/cookbook_list.rb +0 -47
- data/lib/chef/knife/cookbook_metadata.rb +0 -106
- data/lib/chef/knife/cookbook_metadata_from_file.rb +0 -49
- data/lib/chef/knife/cookbook_show.rb +0 -98
- data/lib/chef/knife/cookbook_upload.rb +0 -292
- data/lib/chef/knife/core/bootstrap_context.rb +0 -264
- data/lib/chef/knife/core/cookbook_scm_repo.rb +0 -159
- data/lib/chef/knife/core/formatting_options.rb +0 -49
- data/lib/chef/knife/core/gem_glob_loader.rb +0 -138
- data/lib/chef/knife/core/generic_presenter.rb +0 -232
- data/lib/chef/knife/core/hashed_command_loader.rb +0 -100
- data/lib/chef/knife/core/node_editor.rb +0 -130
- data/lib/chef/knife/core/node_presenter.rb +0 -133
- data/lib/chef/knife/core/object_loader.rb +0 -115
- data/lib/chef/knife/core/status_presenter.rb +0 -147
- data/lib/chef/knife/core/subcommand_loader.rb +0 -203
- data/lib/chef/knife/core/text_formatter.rb +0 -85
- data/lib/chef/knife/core/ui.rb +0 -338
- data/lib/chef/knife/core/windows_bootstrap_context.rb +0 -405
- data/lib/chef/knife/data_bag_create.rb +0 -81
- data/lib/chef/knife/data_bag_delete.rb +0 -49
- data/lib/chef/knife/data_bag_edit.rb +0 -74
- data/lib/chef/knife/data_bag_from_file.rb +0 -113
- data/lib/chef/knife/data_bag_list.rb +0 -42
- data/lib/chef/knife/data_bag_secret_options.rb +0 -122
- data/lib/chef/knife/data_bag_show.rb +0 -69
- data/lib/chef/knife/delete.rb +0 -125
- data/lib/chef/knife/deps.rb +0 -156
- data/lib/chef/knife/diff.rb +0 -83
- data/lib/chef/knife/download.rb +0 -84
- data/lib/chef/knife/edit.rb +0 -88
- data/lib/chef/knife/environment_compare.rb +0 -128
- data/lib/chef/knife/environment_create.rb +0 -52
- data/lib/chef/knife/environment_delete.rb +0 -44
- data/lib/chef/knife/environment_edit.rb +0 -44
- data/lib/chef/knife/environment_from_file.rb +0 -84
- data/lib/chef/knife/environment_list.rb +0 -41
- data/lib/chef/knife/environment_show.rb +0 -47
- data/lib/chef/knife/exec.rb +0 -99
- data/lib/chef/knife/group_add.rb +0 -55
- data/lib/chef/knife/group_create.rb +0 -49
- data/lib/chef/knife/group_destroy.rb +0 -53
- data/lib/chef/knife/group_list.rb +0 -43
- data/lib/chef/knife/group_remove.rb +0 -56
- data/lib/chef/knife/group_show.rb +0 -49
- data/lib/chef/knife/key_create.rb +0 -112
- data/lib/chef/knife/key_create_base.rb +0 -50
- data/lib/chef/knife/key_delete.rb +0 -55
- data/lib/chef/knife/key_edit.rb +0 -118
- data/lib/chef/knife/key_edit_base.rb +0 -55
- data/lib/chef/knife/key_list.rb +0 -90
- data/lib/chef/knife/key_list_base.rb +0 -45
- data/lib/chef/knife/key_show.rb +0 -53
- data/lib/chef/knife/list.rb +0 -177
- data/lib/chef/knife/node_bulk_delete.rb +0 -75
- data/lib/chef/knife/node_create.rb +0 -47
- data/lib/chef/knife/node_delete.rb +0 -46
- data/lib/chef/knife/node_edit.rb +0 -70
- data/lib/chef/knife/node_environment_set.rb +0 -53
- data/lib/chef/knife/node_from_file.rb +0 -51
- data/lib/chef/knife/node_list.rb +0 -44
- data/lib/chef/knife/node_policy_set.rb +0 -79
- data/lib/chef/knife/node_run_list_add.rb +0 -104
- data/lib/chef/knife/node_run_list_remove.rb +0 -67
- data/lib/chef/knife/node_run_list_set.rb +0 -66
- data/lib/chef/knife/node_show.rb +0 -63
- data/lib/chef/knife/null.rb +0 -12
- data/lib/chef/knife/raw.rb +0 -123
- data/lib/chef/knife/recipe_list.rb +0 -32
- data/lib/chef/knife/rehash.rb +0 -50
- data/lib/chef/knife/role_bulk_delete.rb +0 -66
- data/lib/chef/knife/role_create.rb +0 -53
- data/lib/chef/knife/role_delete.rb +0 -46
- data/lib/chef/knife/role_edit.rb +0 -45
- data/lib/chef/knife/role_env_run_list_add.rb +0 -87
- data/lib/chef/knife/role_env_run_list_clear.rb +0 -55
- data/lib/chef/knife/role_env_run_list_remove.rb +0 -57
- data/lib/chef/knife/role_env_run_list_replace.rb +0 -60
- data/lib/chef/knife/role_env_run_list_set.rb +0 -70
- data/lib/chef/knife/role_from_file.rb +0 -51
- data/lib/chef/knife/role_list.rb +0 -42
- data/lib/chef/knife/role_run_list_add.rb +0 -87
- data/lib/chef/knife/role_run_list_clear.rb +0 -55
- data/lib/chef/knife/role_run_list_remove.rb +0 -56
- data/lib/chef/knife/role_run_list_replace.rb +0 -60
- data/lib/chef/knife/role_run_list_set.rb +0 -69
- data/lib/chef/knife/role_show.rb +0 -48
- data/lib/chef/knife/search.rb +0 -194
- data/lib/chef/knife/serve.rb +0 -65
- data/lib/chef/knife/show.rb +0 -72
- data/lib/chef/knife/ssh.rb +0 -645
- data/lib/chef/knife/ssl_check.rb +0 -284
- data/lib/chef/knife/ssl_fetch.rb +0 -161
- data/lib/chef/knife/status.rb +0 -95
- data/lib/chef/knife/supermarket_download.rb +0 -121
- data/lib/chef/knife/supermarket_install.rb +0 -192
- data/lib/chef/knife/supermarket_list.rb +0 -76
- data/lib/chef/knife/supermarket_search.rb +0 -53
- data/lib/chef/knife/supermarket_share.rb +0 -166
- data/lib/chef/knife/supermarket_show.rb +0 -66
- data/lib/chef/knife/supermarket_unshare.rb +0 -61
- data/lib/chef/knife/tag_create.rb +0 -52
- data/lib/chef/knife/tag_delete.rb +0 -60
- data/lib/chef/knife/tag_list.rb +0 -47
- data/lib/chef/knife/upload.rb +0 -86
- data/lib/chef/knife/user_create.rb +0 -107
- data/lib/chef/knife/user_delete.rb +0 -44
- data/lib/chef/knife/user_dissociate.rb +0 -42
- data/lib/chef/knife/user_edit.rb +0 -52
- data/lib/chef/knife/user_invite_add.rb +0 -43
- data/lib/chef/knife/user_invite_list.rb +0 -34
- data/lib/chef/knife/user_invite_rescind.rb +0 -63
- data/lib/chef/knife/user_key_create.rb +0 -73
- data/lib/chef/knife/user_key_delete.rb +0 -80
- data/lib/chef/knife/user_key_edit.rb +0 -83
- data/lib/chef/knife/user_key_list.rb +0 -73
- data/lib/chef/knife/user_key_show.rb +0 -80
- data/lib/chef/knife/user_list.rb +0 -42
- data/lib/chef/knife/user_reregister.rb +0 -59
- data/lib/chef/knife/user_show.rb +0 -48
- data/lib/chef/knife/xargs.rb +0 -282
- data/lib/chef/knife/yaml_convert.rb +0 -91
- data/lib/chef/knife.rb +0 -665
- data/lib/chef/resource/user/dscl_user.rb +0 -35
- data/spec/data/knife-home/.chef/plugins/knife/example_home_subcommand.rb +0 -0
- data/spec/data/knife-site-subcommands/plugins/knife/example_subcommand.rb +0 -0
- data/spec/data/knife_subcommand/test_explicit_category.rb +0 -7
- data/spec/data/knife_subcommand/test_name_mapping.rb +0 -4
- data/spec/data/knife_subcommand/test_yourself.rb +0 -21
- data/spec/functional/knife/configure_spec.rb +0 -33
- data/spec/functional/knife/cookbook_delete_spec.rb +0 -156
- data/spec/functional/knife/exec_spec.rb +0 -55
- data/spec/functional/knife/rehash_spec.rb +0 -39
- data/spec/functional/knife/smoke_test.rb +0 -42
- data/spec/functional/knife/ssh_spec.rb +0 -352
- data/spec/functional/resource/user/dscl_spec.rb +0 -188
- data/spec/functional/resource/windows_service_spec.rb +0 -105
- data/spec/functional/win32/service_manager_spec.rb +0 -220
- data/spec/integration/knife/chef_fs_data_store_spec.rb +0 -557
- data/spec/integration/knife/chef_repo_path_spec.rb +0 -962
- data/spec/integration/knife/chef_repository_file_system_spec.rb +0 -200
- data/spec/integration/knife/chefignore_spec.rb +0 -301
- data/spec/integration/knife/client_bulk_delete_spec.rb +0 -131
- data/spec/integration/knife/client_create_spec.rb +0 -70
- data/spec/integration/knife/client_delete_spec.rb +0 -64
- data/spec/integration/knife/client_key_create_spec.rb +0 -66
- data/spec/integration/knife/client_key_delete_spec.rb +0 -43
- data/spec/integration/knife/client_key_list_spec.rb +0 -61
- data/spec/integration/knife/client_key_show_spec.rb +0 -45
- data/spec/integration/knife/client_list_spec.rb +0 -49
- data/spec/integration/knife/client_show_spec.rb +0 -37
- data/spec/integration/knife/common_options_spec.rb +0 -174
- data/spec/integration/knife/config_list_spec.rb +0 -220
- data/spec/integration/knife/config_show_spec.rb +0 -192
- data/spec/integration/knife/config_use_spec.rb +0 -198
- data/spec/integration/knife/cookbook_api_ipv6_spec.rb +0 -113
- data/spec/integration/knife/cookbook_bulk_delete_spec.rb +0 -65
- data/spec/integration/knife/cookbook_download_spec.rb +0 -72
- data/spec/integration/knife/cookbook_list_spec.rb +0 -55
- data/spec/integration/knife/cookbook_show_spec.rb +0 -149
- data/spec/integration/knife/cookbook_upload_spec.rb +0 -128
- data/spec/integration/knife/data_bag_create_spec.rb +0 -125
- data/spec/integration/knife/data_bag_delete_spec.rb +0 -59
- data/spec/integration/knife/data_bag_edit_spec.rb +0 -105
- data/spec/integration/knife/data_bag_from_file_spec.rb +0 -116
- data/spec/integration/knife/data_bag_list_spec.rb +0 -44
- data/spec/integration/knife/data_bag_show_spec.rb +0 -95
- data/spec/integration/knife/delete_spec.rb +0 -1018
- data/spec/integration/knife/deps_spec.rb +0 -703
- data/spec/integration/knife/diff_spec.rb +0 -605
- data/spec/integration/knife/download_spec.rb +0 -1336
- data/spec/integration/knife/environment_compare_spec.rb +0 -75
- data/spec/integration/knife/environment_create_spec.rb +0 -41
- data/spec/integration/knife/environment_delete_spec.rb +0 -37
- data/spec/integration/knife/environment_from_file_spec.rb +0 -116
- data/spec/integration/knife/environment_list_spec.rb +0 -42
- data/spec/integration/knife/environment_show_spec.rb +0 -77
- data/spec/integration/knife/list_spec.rb +0 -1060
- data/spec/integration/knife/node_bulk_delete_spec.rb +0 -52
- data/spec/integration/knife/node_create_spec.rb +0 -47
- data/spec/integration/knife/node_delete_spec.rb +0 -48
- data/spec/integration/knife/node_environment_set_spec.rb +0 -46
- data/spec/integration/knife/node_from_file_spec.rb +0 -59
- data/spec/integration/knife/node_list_spec.rb +0 -45
- data/spec/integration/knife/node_run_list_add_spec.rb +0 -54
- data/spec/integration/knife/node_run_list_remove_spec.rb +0 -36
- data/spec/integration/knife/node_run_list_set_spec.rb +0 -41
- data/spec/integration/knife/node_show_spec.rb +0 -36
- data/spec/integration/knife/raw_spec.rb +0 -297
- data/spec/integration/knife/redirection_spec.rb +0 -64
- data/spec/integration/knife/role_bulk_delete_spec.rb +0 -52
- data/spec/integration/knife/role_create_spec.rb +0 -41
- data/spec/integration/knife/role_delete_spec.rb +0 -48
- data/spec/integration/knife/role_from_file_spec.rb +0 -96
- data/spec/integration/knife/role_list_spec.rb +0 -45
- data/spec/integration/knife/role_show_spec.rb +0 -51
- data/spec/integration/knife/search_node_spec.rb +0 -40
- data/spec/integration/knife/serve_spec.rb +0 -92
- data/spec/integration/knife/show_spec.rb +0 -197
- data/spec/integration/knife/upload_spec.rb +0 -1616
- data/spec/support/shared/functional/knife.rb +0 -37
- data/spec/support/shared/functional/win32_service.rb +0 -57
- data/spec/support/shared/integration/knife_support.rb +0 -192
- data/spec/support/shared/unit/knife_shared.rb +0 -39
- data/spec/unit/application/knife_spec.rb +0 -241
- data/spec/unit/chef_fs/parallelizer_spec.rb +0 -479
- data/spec/unit/cookbook_site_streaming_uploader_spec.rb +0 -198
- data/spec/unit/knife/bootstrap/chef_vault_handler_spec.rb +0 -152
- data/spec/unit/knife/bootstrap/client_builder_spec.rb +0 -207
- data/spec/unit/knife/bootstrap/train_connector_spec.rb +0 -244
- data/spec/unit/knife/bootstrap_spec.rb +0 -2220
- data/spec/unit/knife/client_bulk_delete_spec.rb +0 -166
- data/spec/unit/knife/client_create_spec.rb +0 -169
- data/spec/unit/knife/client_delete_spec.rb +0 -99
- data/spec/unit/knife/client_edit_spec.rb +0 -53
- data/spec/unit/knife/client_list_spec.rb +0 -34
- data/spec/unit/knife/client_reregister_spec.rb +0 -62
- data/spec/unit/knife/client_show_spec.rb +0 -52
- data/spec/unit/knife/configure_client_spec.rb +0 -81
- data/spec/unit/knife/configure_spec.rb +0 -190
- data/spec/unit/knife/cookbook_bulk_delete_spec.rb +0 -87
- data/spec/unit/knife/cookbook_delete_spec.rb +0 -239
- data/spec/unit/knife/cookbook_download_spec.rb +0 -255
- data/spec/unit/knife/cookbook_list_spec.rb +0 -88
- data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +0 -72
- data/spec/unit/knife/cookbook_metadata_spec.rb +0 -182
- data/spec/unit/knife/cookbook_show_spec.rb +0 -253
- data/spec/unit/knife/cookbook_upload_spec.rb +0 -364
- data/spec/unit/knife/core/bootstrap_context_spec.rb +0 -287
- data/spec/unit/knife/core/cookbook_scm_repo_spec.rb +0 -187
- data/spec/unit/knife/core/gem_glob_loader_spec.rb +0 -209
- data/spec/unit/knife/core/hashed_command_loader_spec.rb +0 -112
- data/spec/unit/knife/core/node_editor_spec.rb +0 -211
- data/spec/unit/knife/core/object_loader_spec.rb +0 -81
- data/spec/unit/knife/core/status_presenter_spec.rb +0 -54
- data/spec/unit/knife/core/subcommand_loader_spec.rb +0 -64
- data/spec/unit/knife/core/ui_spec.rb +0 -656
- data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +0 -238
- data/spec/unit/knife/data_bag_create_spec.rb +0 -175
- data/spec/unit/knife/data_bag_edit_spec.rb +0 -126
- data/spec/unit/knife/data_bag_from_file_spec.rb +0 -174
- data/spec/unit/knife/data_bag_secret_options_spec.rb +0 -173
- data/spec/unit/knife/data_bag_show_spec.rb +0 -139
- data/spec/unit/knife/environment_compare_spec.rb +0 -112
- data/spec/unit/knife/environment_create_spec.rb +0 -91
- data/spec/unit/knife/environment_delete_spec.rb +0 -71
- data/spec/unit/knife/environment_edit_spec.rb +0 -79
- data/spec/unit/knife/environment_from_file_spec.rb +0 -90
- data/spec/unit/knife/environment_list_spec.rb +0 -54
- data/spec/unit/knife/environment_show_spec.rb +0 -52
- data/spec/unit/knife/key_create_spec.rb +0 -223
- data/spec/unit/knife/key_delete_spec.rb +0 -133
- data/spec/unit/knife/key_edit_spec.rb +0 -264
- data/spec/unit/knife/key_helper.rb +0 -74
- data/spec/unit/knife/key_list_spec.rb +0 -216
- data/spec/unit/knife/key_show_spec.rb +0 -126
- data/spec/unit/knife/node_bulk_delete_spec.rb +0 -94
- data/spec/unit/knife/node_delete_spec.rb +0 -77
- data/spec/unit/knife/node_edit_spec.rb +0 -116
- data/spec/unit/knife/node_environment_set_spec.rb +0 -61
- data/spec/unit/knife/node_from_file_spec.rb +0 -59
- data/spec/unit/knife/node_list_spec.rb +0 -62
- data/spec/unit/knife/node_policy_set_spec.rb +0 -122
- data/spec/unit/knife/node_run_list_add_spec.rb +0 -145
- data/spec/unit/knife/node_run_list_remove_spec.rb +0 -106
- data/spec/unit/knife/node_run_list_set_spec.rb +0 -115
- data/spec/unit/knife/node_show_spec.rb +0 -65
- data/spec/unit/knife/raw_spec.rb +0 -43
- data/spec/unit/knife/role_bulk_delete_spec.rb +0 -80
- data/spec/unit/knife/role_create_spec.rb +0 -80
- data/spec/unit/knife/role_delete_spec.rb +0 -67
- data/spec/unit/knife/role_edit_spec.rb +0 -77
- data/spec/unit/knife/role_env_run_list_add_spec.rb +0 -217
- data/spec/unit/knife/role_env_run_list_clear_spec.rb +0 -94
- data/spec/unit/knife/role_env_run_list_remove_spec.rb +0 -102
- data/spec/unit/knife/role_env_run_list_replace_spec.rb +0 -105
- data/spec/unit/knife/role_env_run_list_set_spec.rb +0 -99
- data/spec/unit/knife/role_from_file_spec.rb +0 -69
- data/spec/unit/knife/role_list_spec.rb +0 -54
- data/spec/unit/knife/role_run_list_add_spec.rb +0 -179
- data/spec/unit/knife/role_run_list_clear_spec.rb +0 -84
- data/spec/unit/knife/role_run_list_remove_spec.rb +0 -92
- data/spec/unit/knife/role_run_list_replace_spec.rb +0 -98
- data/spec/unit/knife/role_run_list_set_spec.rb +0 -89
- data/spec/unit/knife/role_show_spec.rb +0 -59
- data/spec/unit/knife/ssh_spec.rb +0 -403
- data/spec/unit/knife/ssl_check_spec.rb +0 -256
- data/spec/unit/knife/ssl_fetch_spec.rb +0 -222
- data/spec/unit/knife/status_spec.rb +0 -112
- data/spec/unit/knife/supermarket_download_spec.rb +0 -152
- data/spec/unit/knife/supermarket_install_spec.rb +0 -202
- data/spec/unit/knife/supermarket_list_spec.rb +0 -70
- data/spec/unit/knife/supermarket_search_spec.rb +0 -85
- data/spec/unit/knife/supermarket_share_spec.rb +0 -208
- data/spec/unit/knife/supermarket_unshare_spec.rb +0 -78
- data/spec/unit/knife/tag_create_spec.rb +0 -23
- data/spec/unit/knife/tag_delete_spec.rb +0 -25
- data/spec/unit/knife/tag_list_spec.rb +0 -23
- data/spec/unit/knife/user_create_spec.rb +0 -184
- data/spec/unit/knife/user_delete_spec.rb +0 -46
- data/spec/unit/knife/user_edit_spec.rb +0 -48
- data/spec/unit/knife/user_list_spec.rb +0 -36
- data/spec/unit/knife/user_reregister_spec.rb +0 -56
- data/spec/unit/knife/user_show_spec.rb +0 -46
- data/spec/unit/knife_spec.rb +0 -634
- data/spec/unit/provider/user/dscl_spec.rb +0 -699
- data/spec/unit/windows_service_spec.rb +0 -118
@@ -61,7 +61,7 @@ class Chef
|
|
61
61
|
shell_out!(checkout_command, run_options)
|
62
62
|
end
|
63
63
|
else
|
64
|
-
logger.
|
64
|
+
logger.debug "#{new_resource} checkout destination #{new_resource.destination} already exists or is a non-empty directory - nothing to do"
|
65
65
|
end
|
66
66
|
end
|
67
67
|
|
@@ -69,7 +69,7 @@ class Chef
|
|
69
69
|
if target_dir_non_existent_or_empty?
|
70
70
|
action_force_export
|
71
71
|
else
|
72
|
-
logger.
|
72
|
+
logger.debug "#{new_resource} export destination #{new_resource.destination} already exists or is a non-empty directory - nothing to do"
|
73
73
|
end
|
74
74
|
end
|
75
75
|
|
@@ -121,16 +121,14 @@ class Chef
|
|
121
121
|
# up the revision id by asking the server
|
122
122
|
# If the specified revision is an integer, trust it.
|
123
123
|
def revision_int
|
124
|
-
@revision_int ||=
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
end
|
133
|
-
end
|
124
|
+
@revision_int ||= if /^\d+$/.match?(new_resource.revision)
|
125
|
+
new_resource.revision
|
126
|
+
else
|
127
|
+
command = scm(:info, new_resource.repository, new_resource.svn_info_args, authentication, "-r#{new_resource.revision}")
|
128
|
+
svn_info = shell_out!(command, run_options(cwd: cwd, returns: [0, 1])).stdout
|
129
|
+
|
130
|
+
extract_revision_info(svn_info)
|
131
|
+
end
|
134
132
|
end
|
135
133
|
|
136
134
|
alias :revision_slug :revision_int
|
@@ -55,6 +55,26 @@ class Chef
|
|
55
55
|
end
|
56
56
|
end
|
57
57
|
|
58
|
+
def systemd_unit_status
|
59
|
+
@systemd_unit_status ||= begin
|
60
|
+
# Collect all the status information for a unit and return it at once
|
61
|
+
# This may fail if we are managing a template unit (e.g. with '@'), in which case
|
62
|
+
# we just ignore the error because unit status is irrelevant in that case
|
63
|
+
s = shell_out(*systemctl_cmd, "show", "-p", "UnitFileState", "-p", "ActiveState", new_resource.unit_name, systemctl_opts)
|
64
|
+
# e.g. /bin/systemctl --system show -p UnitFileState -p ActiveState syslog.socket
|
65
|
+
# Returns something like:
|
66
|
+
# ActiveState=inactive
|
67
|
+
# UnitFileState=static
|
68
|
+
status = {}
|
69
|
+
s.stdout.each_line do |line|
|
70
|
+
k, v = line.strip.split("=")
|
71
|
+
status[k] = v
|
72
|
+
end
|
73
|
+
|
74
|
+
status
|
75
|
+
end
|
76
|
+
end
|
77
|
+
|
58
78
|
action :create do
|
59
79
|
if current_resource.content != new_resource.to_ini
|
60
80
|
converge_by("creating unit: #{new_resource.unit_name}") do
|
@@ -87,10 +107,10 @@ class Chef
|
|
87
107
|
|
88
108
|
action :enable do
|
89
109
|
if current_resource.static
|
90
|
-
logger.
|
110
|
+
logger.debug("#{new_resource.unit_name} is a static unit, enabling is a NOP.")
|
91
111
|
end
|
92
112
|
if current_resource.indirect
|
93
|
-
logger.
|
113
|
+
logger.debug("#{new_resource.unit_name} is an indirect unit, enabling is a NOP.")
|
94
114
|
end
|
95
115
|
|
96
116
|
unless current_resource.enabled || current_resource.static || current_resource.indirect
|
@@ -103,11 +123,11 @@ class Chef
|
|
103
123
|
|
104
124
|
action :disable do
|
105
125
|
if current_resource.static
|
106
|
-
logger.
|
126
|
+
logger.debug("#{new_resource.unit_name} is a static unit, disabling is a NOP.")
|
107
127
|
end
|
108
128
|
|
109
129
|
if current_resource.indirect
|
110
|
-
logger.
|
130
|
+
logger.debug("#{new_resource.unit_name} is an indirect unit, enabling is a NOP.")
|
111
131
|
end
|
112
132
|
|
113
133
|
if current_resource.enabled && !current_resource.static && !current_resource.indirect
|
@@ -175,7 +195,7 @@ class Chef
|
|
175
195
|
logger.info("#{new_resource} reloaded")
|
176
196
|
end
|
177
197
|
else
|
178
|
-
logger.
|
198
|
+
logger.debug("#{new_resource.unit_name} is not active, skipping reload.")
|
179
199
|
end
|
180
200
|
end
|
181
201
|
|
@@ -201,23 +221,29 @@ class Chef
|
|
201
221
|
end
|
202
222
|
|
203
223
|
def active?
|
204
|
-
|
224
|
+
# Note: "activating" is not active (as with type=notify or a oneshot)
|
225
|
+
systemd_unit_status["ActiveState"] == "active"
|
205
226
|
end
|
206
227
|
|
207
228
|
def enabled?
|
208
|
-
|
229
|
+
# See https://github.com/systemd/systemd/blob/master/src/systemctl/systemctl-is-enabled.c
|
230
|
+
# Note: enabled-runtime is excluded because this is volatile, and the state of enabled-runtime
|
231
|
+
# specifically means that the service is not enabled
|
232
|
+
%w{enabled static generated alias indirect}.include?(systemd_unit_status["UnitFileState"])
|
209
233
|
end
|
210
234
|
|
211
235
|
def masked?
|
212
|
-
|
236
|
+
# Note: masked-runtime is excluded, because runtime is volatile, and
|
237
|
+
# because masked-runtime is not masked.
|
238
|
+
systemd_unit_status["UnitFileState"] == "masked"
|
213
239
|
end
|
214
240
|
|
215
241
|
def static?
|
216
|
-
|
242
|
+
systemd_unit_status["UnitFileState"] == "static"
|
217
243
|
end
|
218
244
|
|
219
245
|
def indirect?
|
220
|
-
|
246
|
+
systemd_unit_status["UnitFileState"] == "indirect"
|
221
247
|
end
|
222
248
|
|
223
249
|
private
|
@@ -29,9 +29,7 @@ class Chef
|
|
29
29
|
include Chef::Mixin::Template
|
30
30
|
|
31
31
|
def template_location
|
32
|
-
@template_file_cache_location ||=
|
33
|
-
template_finder.find(new_resource.source, local: new_resource.local, cookbook: new_resource.cookbook)
|
34
|
-
end
|
32
|
+
@template_file_cache_location ||= template_finder.find(new_resource.source, local: new_resource.local, cookbook: new_resource.cookbook)
|
35
33
|
end
|
36
34
|
|
37
35
|
private
|
@@ -65,7 +63,7 @@ class Chef
|
|
65
63
|
context[:template_finder] = template_finder
|
66
64
|
|
67
65
|
# helper variables
|
68
|
-
context[:cookbook_name] = new_resource.cookbook_name unless context.keys.include?(:
|
66
|
+
context[:cookbook_name] = new_resource.cookbook_name unless context.keys.include?(:coookbook_name)
|
69
67
|
context[:recipe_name] = new_resource.recipe_name unless context.keys.include?(:recipe_name)
|
70
68
|
context[:recipe_line_string] = new_resource.source_line unless context.keys.include?(:recipe_line_string)
|
71
69
|
context[:recipe_path] = new_resource.source_line_file unless context.keys.include?(:recipe_path)
|
@@ -84,9 +82,7 @@ class Chef
|
|
84
82
|
end
|
85
83
|
|
86
84
|
def template_finder
|
87
|
-
@template_finder ||=
|
88
|
-
TemplateFinder.new(run_context, new_resource.cookbook_name, run_context.node)
|
89
|
-
end
|
85
|
+
@template_finder ||= TemplateFinder.new(run_context, new_resource.cookbook_name, run_context.node)
|
90
86
|
end
|
91
87
|
end
|
92
88
|
end
|
@@ -438,7 +438,7 @@ in 'password', with the associated 'salt' and 'iterations'.")
|
|
438
438
|
#
|
439
439
|
def locked?
|
440
440
|
if authentication_authority
|
441
|
-
!!(authentication_authority
|
441
|
+
!!(authentication_authority.include?("DisabledUser"))
|
442
442
|
else
|
443
443
|
false
|
444
444
|
end
|
@@ -29,13 +29,12 @@ class Chef
|
|
29
29
|
class User
|
30
30
|
# A macOS user provider that is compatible with default TCC restrictions
|
31
31
|
# in macOS 10.14. See resource/user/mac_user.rb for complete description
|
32
|
-
# of the mac_user resource
|
33
|
-
# on previous platforms.
|
32
|
+
# of the mac_user resource
|
34
33
|
class MacUser < Chef::Provider::User
|
35
34
|
include Chef::Mixin::Which
|
36
35
|
|
37
36
|
provides :mac_user
|
38
|
-
provides :user, os: "darwin"
|
37
|
+
provides :user, os: "darwin"
|
39
38
|
|
40
39
|
attr_reader :user_plist, :admin_group_plist
|
41
40
|
|
@@ -394,23 +393,21 @@ class Chef
|
|
394
393
|
# associated group resource. If a group exists we'll modify it, otherwise
|
395
394
|
# create it.
|
396
395
|
def user_group_info
|
397
|
-
@user_group_info ||=
|
398
|
-
|
399
|
-
|
400
|
-
|
401
|
-
|
402
|
-
|
403
|
-
|
404
|
-
|
405
|
-
|
406
|
-
|
407
|
-
|
408
|
-
|
409
|
-
|
410
|
-
|
411
|
-
|
412
|
-
end
|
413
|
-
end
|
396
|
+
@user_group_info ||= if new_resource.gid.is_a?(String)
|
397
|
+
begin
|
398
|
+
g = Etc.getgrnam(new_resource.gid)
|
399
|
+
[g.name, g.gid.to_s, :modify]
|
400
|
+
rescue
|
401
|
+
[new_resource.gid, nil, :create]
|
402
|
+
end
|
403
|
+
else
|
404
|
+
begin
|
405
|
+
g = Etc.getgrgid(new_resource.gid)
|
406
|
+
[g.name, g.gid.to_s, :modify]
|
407
|
+
rescue
|
408
|
+
[g.username, nil, :create]
|
409
|
+
end
|
410
|
+
end
|
414
411
|
end
|
415
412
|
|
416
413
|
def secure_token_enabled?
|
@@ -97,7 +97,7 @@ class Chef
|
|
97
97
|
command = "pw usermod #{new_resource.username} -H 0"
|
98
98
|
shell_out!(command, input: new_resource.password.to_s)
|
99
99
|
else
|
100
|
-
logger.
|
100
|
+
logger.debug("#{new_resource} no change needed to password")
|
101
101
|
end
|
102
102
|
end
|
103
103
|
end
|
@@ -62,7 +62,7 @@ class Chef
|
|
62
62
|
# <false>:: If the users are identical
|
63
63
|
def compare_user
|
64
64
|
@change_desc = []
|
65
|
-
|
65
|
+
if new_resource.password && !@net_user.validate_credentials(new_resource.password)
|
66
66
|
@change_desc << "update password"
|
67
67
|
end
|
68
68
|
|
data/lib/chef/provider/user.rb
CHANGED
@@ -172,7 +172,7 @@ class Chef
|
|
172
172
|
logger.info("#{new_resource} locked")
|
173
173
|
end
|
174
174
|
else
|
175
|
-
logger.
|
175
|
+
logger.debug("#{new_resource} already locked - nothing to do")
|
176
176
|
end
|
177
177
|
end
|
178
178
|
|
@@ -183,7 +183,7 @@ class Chef
|
|
183
183
|
logger.info("#{new_resource} unlocked")
|
184
184
|
end
|
185
185
|
else
|
186
|
-
logger.
|
186
|
+
logger.debug("#{new_resource} already unlocked - nothing to do")
|
187
187
|
end
|
188
188
|
end
|
189
189
|
|
@@ -33,7 +33,7 @@ class Chef
|
|
33
33
|
if new_resource.gpgautoimportkeys
|
34
34
|
install_gpg_key(new_resource.gpgkey)
|
35
35
|
else
|
36
|
-
logger.
|
36
|
+
logger.debug("'gpgautoimportkeys' property is set to false. Skipping key import.")
|
37
37
|
end
|
38
38
|
|
39
39
|
declare_resource(:template, "/etc/zypp/repos.d/#{escaped_repo_name}.repo") do
|
@@ -162,7 +162,7 @@ class Chef
|
|
162
162
|
# @param [String] uri the uri of the local or remote gpg key
|
163
163
|
def install_gpg_key(uri)
|
164
164
|
unless uri
|
165
|
-
logger.
|
165
|
+
logger.debug("'gpgkey' property not provided or set to nil. Skipping key import.")
|
166
166
|
return
|
167
167
|
end
|
168
168
|
|
data/lib/chef/provider.rb
CHANGED
@@ -435,7 +435,7 @@ class Chef
|
|
435
435
|
# this block cannot interact with resources outside, e.g.,
|
436
436
|
# manipulating notifies.
|
437
437
|
|
438
|
-
converge_by
|
438
|
+
converge_by("evaluate block and run any associated actions") do
|
439
439
|
saved_run_context = run_context
|
440
440
|
begin
|
441
441
|
@run_context = run_context.create_child
|
data/lib/chef/providers.rb
CHANGED
@@ -94,7 +94,6 @@ require_relative "provider/service/aixinit"
|
|
94
94
|
require_relative "provider/service/aix"
|
95
95
|
|
96
96
|
require_relative "provider/user/aix"
|
97
|
-
require_relative "provider/user/dscl"
|
98
97
|
require_relative "provider/user/linux"
|
99
98
|
require_relative "provider/user/mac"
|
100
99
|
require_relative "provider/user/pw"
|
@@ -26,7 +26,7 @@ class Chef
|
|
26
26
|
|
27
27
|
provides(:alternatives) { true }
|
28
28
|
|
29
|
-
description "
|
29
|
+
description "Use the **alternatives** resource to configure command alternatives in Linux using the alternatives or update-alternatives packages."
|
30
30
|
introduced "16.0"
|
31
31
|
examples <<~DOC
|
32
32
|
**Install an alternative**:
|
@@ -122,7 +122,7 @@ class Chef
|
|
122
122
|
end
|
123
123
|
end
|
124
124
|
|
125
|
-
action :install do
|
125
|
+
action :install, description: "Install an alternative on the system including symlinks" do
|
126
126
|
if path_priority != new_resource.priority
|
127
127
|
converge_by("adding alternative #{new_resource.link} #{new_resource.link_name} #{new_resource.path} #{new_resource.priority}") do
|
128
128
|
output = shell_out(alternatives_cmd, "--install", new_resource.link, new_resource.link_name, new_resource.path, new_resource.priority)
|
@@ -133,7 +133,7 @@ class Chef
|
|
133
133
|
end
|
134
134
|
end
|
135
135
|
|
136
|
-
action :set do
|
136
|
+
action :set, description: "Set the symlink for an alternative" do
|
137
137
|
if current_path != new_resource.path
|
138
138
|
converge_by("setting alternative #{new_resource.link_name} #{new_resource.path}") do
|
139
139
|
output = shell_out(alternatives_cmd, "--set", new_resource.link_name, new_resource.path)
|
@@ -144,7 +144,7 @@ class Chef
|
|
144
144
|
end
|
145
145
|
end
|
146
146
|
|
147
|
-
action :remove do
|
147
|
+
action :remove, description: "Remove an alternative and all associated links" do
|
148
148
|
if path_exists?
|
149
149
|
converge_by("removing alternative #{new_resource.link_name} #{new_resource.path}") do
|
150
150
|
shell_out(alternatives_cmd, "--remove", new_resource.link_name, new_resource.path)
|
@@ -152,13 +152,13 @@ class Chef
|
|
152
152
|
end
|
153
153
|
end
|
154
154
|
|
155
|
-
action :auto do
|
155
|
+
action :auto, description: "Set an alternative up in automatic mode with the highest priority automatically selected" do
|
156
156
|
converge_by("setting auto alternative #{new_resource.link_name}") do
|
157
157
|
shell_out(alternatives_cmd, "--auto", new_resource.link_name)
|
158
158
|
end
|
159
159
|
end
|
160
160
|
|
161
|
-
action :refresh do
|
161
|
+
action :refresh, description: "Refresh alternatives" do
|
162
162
|
converge_by("refreshing alternative #{new_resource.link_name}") do
|
163
163
|
shell_out(alternatives_cmd, "--refresh", new_resource.link_name)
|
164
164
|
end
|
@@ -91,7 +91,7 @@ class Chef
|
|
91
91
|
end
|
92
92
|
end
|
93
93
|
|
94
|
-
action :add do
|
94
|
+
action :add, description: "Creates a preferences file under `/etc/apt/preferences.d`" do
|
95
95
|
return unless debian?
|
96
96
|
|
97
97
|
preference = build_pref(
|
@@ -130,7 +130,7 @@ class Chef
|
|
130
130
|
end
|
131
131
|
end
|
132
132
|
|
133
|
-
action :remove do
|
133
|
+
action :remove, description: "Removes the preferences file, thus unpinning the package" do
|
134
134
|
return unless debian?
|
135
135
|
|
136
136
|
sanitized_prefname = safe_name(new_resource.package_name)
|
@@ -36,7 +36,7 @@ class Chef
|
|
36
36
|
examples <<~DOC
|
37
37
|
**Add repository with basic settings**:
|
38
38
|
|
39
|
-
|
39
|
+
```ruby
|
40
40
|
apt_repository 'nginx' do
|
41
41
|
uri 'http://nginx.org/packages/ubuntu/'
|
42
42
|
components ['nginx']
|
@@ -128,7 +128,7 @@ class Chef
|
|
128
128
|
|
129
129
|
property :components, Array,
|
130
130
|
description: "Package groupings, such as 'main' and 'stable'.",
|
131
|
-
default:
|
131
|
+
default: [], default_description: "`main` if using a PPA repository."
|
132
132
|
|
133
133
|
property :arch, [String, nil, FalseClass],
|
134
134
|
description: "Constrain packages to a particular CPU architecture such as `i386` or `amd64`."
|
@@ -147,7 +147,7 @@ class Chef
|
|
147
147
|
|
148
148
|
property :key, [String, Array, nil, FalseClass],
|
149
149
|
description: "If a keyserver is provided, this is assumed to be the fingerprint; otherwise it can be either the URI of GPG key for the repo, or a cookbook_file.",
|
150
|
-
default:
|
150
|
+
default: [], coerce: proc { |x| x ? Array(x) : x }
|
151
151
|
|
152
152
|
property :key_proxy, [String, nil, FalseClass],
|
153
153
|
description: "If set, a specified proxy is passed to GPG via `http-proxy=`."
|
@@ -409,7 +409,7 @@ class Chef
|
|
409
409
|
end
|
410
410
|
end
|
411
411
|
|
412
|
-
action :add do
|
412
|
+
action :add, description: "Creates a repository file at `/etc/apt/sources.list.d/` and builds the repository listing" do
|
413
413
|
return unless debian?
|
414
414
|
|
415
415
|
execute "apt-cache gencaches" do
|
@@ -459,7 +459,7 @@ class Chef
|
|
459
459
|
end
|
460
460
|
end
|
461
461
|
|
462
|
-
action :remove do
|
462
|
+
action :remove, description: "Removes the repository listing" do
|
463
463
|
return unless debian?
|
464
464
|
|
465
465
|
cleanup_legacy_file!
|
@@ -477,7 +477,7 @@ class Chef
|
|
477
477
|
end
|
478
478
|
end
|
479
479
|
else
|
480
|
-
logger.
|
480
|
+
logger.debug("/etc/apt/sources.list.d/#{new_resource.repo_name}.list does not exist. Nothing to do")
|
481
481
|
end
|
482
482
|
end
|
483
483
|
|
@@ -17,6 +17,7 @@
|
|
17
17
|
#
|
18
18
|
|
19
19
|
require_relative "../resource"
|
20
|
+
require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
20
21
|
|
21
22
|
class Chef
|
22
23
|
class Resource
|
@@ -85,7 +86,7 @@ class Chef
|
|
85
86
|
end
|
86
87
|
end
|
87
88
|
|
88
|
-
action :periodic do
|
89
|
+
action :periodic, description: "Update the Apt repository at the interval specified by the `frequency` property" do
|
89
90
|
return unless debian?
|
90
91
|
|
91
92
|
unless apt_up_to_date?
|
@@ -95,7 +96,7 @@ class Chef
|
|
95
96
|
end
|
96
97
|
end
|
97
98
|
|
98
|
-
action :update do
|
99
|
+
action :update, description: "Update the Apt repository at the start of a #{ChefUtils::Dist::Infra::PRODUCT} run" do
|
99
100
|
return unless debian?
|
100
101
|
|
101
102
|
converge_by "force update new lists of packages" do
|
@@ -20,12 +20,6 @@
|
|
20
20
|
|
21
21
|
require_relative "../resource"
|
22
22
|
require "fileutils" unless defined?(FileUtils)
|
23
|
-
begin
|
24
|
-
# ffi-libarchive must be eager loaded see: https://github.com/chef/chef/issues/12228
|
25
|
-
require "ffi-libarchive" unless defined?(Archive::Reader)
|
26
|
-
rescue LoadError
|
27
|
-
STDERR.puts "ffi-libarchive could not be loaded, libarchive is probably not installed on system, archive_file will not be available"
|
28
|
-
end
|
29
23
|
|
30
24
|
class Chef
|
31
25
|
class Resource
|
@@ -73,7 +67,7 @@ class Chef
|
|
73
67
|
|
74
68
|
property :mode, [String, Integer],
|
75
69
|
description: "The mode of the extracted files. Integer values are deprecated as octal values (ex. 0755) would not be interpreted correctly.",
|
76
|
-
default: "755"
|
70
|
+
default: "755", default_description: "'755'"
|
77
71
|
|
78
72
|
property :destination, String,
|
79
73
|
description: "The file path to extract the archive file to.",
|
@@ -91,8 +85,9 @@ class Chef
|
|
91
85
|
alias_method :extract_options, :options
|
92
86
|
alias_method :extract_to, :destination
|
93
87
|
|
94
|
-
action :extract do
|
95
|
-
|
88
|
+
action :extract, description: "Extract and archive file." do
|
89
|
+
|
90
|
+
require_libarchive
|
96
91
|
|
97
92
|
unless ::File.exist?(new_resource.path)
|
98
93
|
raise Errno::ENOENT, "No archive found at #{new_resource.path}! Cannot continue."
|
@@ -131,6 +126,10 @@ class Chef
|
|
131
126
|
end
|
132
127
|
|
133
128
|
action_class do
|
129
|
+
def require_libarchive
|
130
|
+
require "ffi-libarchive"
|
131
|
+
end
|
132
|
+
|
134
133
|
def define_resource_requirements
|
135
134
|
if new_resource.mode.is_a?(Integer)
|
136
135
|
Chef.deprecated(:archive_file_integer_file_mode, "The mode property should be passed to archive_file resources as a String and not an Integer to ensure the value is properly interpreted.")
|
@@ -92,7 +92,7 @@ class Chef
|
|
92
92
|
super(caller.first, *args)
|
93
93
|
end
|
94
94
|
|
95
|
-
action :break do
|
95
|
+
action :break, description: "Add a breakpoint for use with #{ChefUtils::Dist::Infra::SHELL}" do
|
96
96
|
if defined?(Shell) && Shell.running?
|
97
97
|
with_run_context :parent do
|
98
98
|
run_context.resource_collection.iterator.pause
|
@@ -57,10 +57,7 @@ class Chef
|
|
57
57
|
introduced: "15.5",
|
58
58
|
default: false, desired_state: false # FIXME: make this default to true
|
59
59
|
|
60
|
-
action :install do
|
61
|
-
|
62
|
-
description "Install build essential packages"
|
63
|
-
|
60
|
+
action :install, description: "Install build essential packages" do
|
64
61
|
case
|
65
62
|
when debian?
|
66
63
|
package %w{ autoconf binutils-doc bison build-essential flex gettext ncurses-dev }
|
@@ -122,8 +119,7 @@ class Chef
|
|
122
119
|
end
|
123
120
|
end
|
124
121
|
|
125
|
-
action :upgrade do
|
126
|
-
description "Upgrade build essential (Xcode Command Line) tools on macOS"
|
122
|
+
action :upgrade, description: "Upgrade the Xcode CLI Tools on macOS hosts. **New in Chef Infra Client 16**" do
|
127
123
|
|
128
124
|
if macos?
|
129
125
|
pkg_label = xcode_cli_package_label
|
@@ -227,7 +227,7 @@ class Chef
|
|
227
227
|
property :additional_config, String,
|
228
228
|
description: "Additional text to add at the bottom of the client.rb config. This can be used to run custom Ruby or to add less common config options"
|
229
229
|
|
230
|
-
action :create do
|
230
|
+
action :create, description: "Create a client.rb config file" do
|
231
231
|
unless ::Dir.exist?(new_resource.config_directory)
|
232
232
|
directory new_resource.config_directory do
|
233
233
|
user new_resource.user unless new_resource.user.nil?
|
@@ -284,7 +284,7 @@ class Chef
|
|
284
284
|
end
|
285
285
|
end
|
286
286
|
|
287
|
-
action :remove do
|
287
|
+
action :remove, description: "Remove a client.rb config file" do
|
288
288
|
file ::File.join(new_resource.config_directory, "client.rb") do
|
289
289
|
action :delete
|
290
290
|
end
|
@@ -131,11 +131,11 @@ class Chef
|
|
131
131
|
description: "The path to the #{ChefUtils::Dist::Infra::CLIENT} binary."
|
132
132
|
|
133
133
|
property :daemon_options, Array,
|
134
|
-
default:
|
134
|
+
default: [],
|
135
135
|
description: "An array of options to pass to the #{ChefUtils::Dist::Infra::CLIENT} command."
|
136
136
|
|
137
137
|
property :environment, Hash,
|
138
|
-
default:
|
138
|
+
default: {},
|
139
139
|
description: "A Hash containing additional arbitrary environment variables under which the cron job will be run in the form of `({'ENV_VARIABLE' => 'VALUE'})`."
|
140
140
|
|
141
141
|
property :nice, [Integer, String],
|
@@ -144,7 +144,7 @@ class Chef
|
|
144
144
|
coerce: proc { |x| Integer(x) },
|
145
145
|
callbacks: { "should be an Integer between -20 and 19" => proc { |v| v >= -20 && v <= 19 } }
|
146
146
|
|
147
|
-
action :add do
|
147
|
+
action :add, description: "Add a cron job to run #{ChefUtils::Dist::Infra::PRODUCT}" do
|
148
148
|
# TODO: Replace this with a :create_if_missing action on directory when that exists
|
149
149
|
unless ::Dir.exist?(new_resource.log_directory)
|
150
150
|
directory new_resource.log_directory do
|
@@ -168,7 +168,7 @@ class Chef
|
|
168
168
|
end
|
169
169
|
end
|
170
170
|
|
171
|
-
action :remove do
|
171
|
+
action :remove, description: "Remove a cron job for #{ChefUtils::Dist::Infra::PRODUCT}" do
|
172
172
|
declare_resource(cron_resource_type, new_resource.job_name) do
|
173
173
|
action :delete
|
174
174
|
end
|
@@ -23,7 +23,7 @@ class Chef
|
|
23
23
|
|
24
24
|
provides :chef_client_launchd
|
25
25
|
|
26
|
-
description "Use the **chef_client_launchd** resource to configure the #{ChefUtils::Dist::Infra::PRODUCT} to run on a schedule."
|
26
|
+
description "Use the **chef_client_launchd** resource to configure the #{ChefUtils::Dist::Infra::PRODUCT} to run on a schedule on macOS systems."
|
27
27
|
introduced "16.5"
|
28
28
|
examples <<~DOC
|
29
29
|
**Set the #{ChefUtils::Dist::Infra::PRODUCT} to run on a schedule**:
|
@@ -86,11 +86,11 @@ class Chef
|
|
86
86
|
|
87
87
|
property :daemon_options, Array,
|
88
88
|
description: "An array of options to pass to the #{ChefUtils::Dist::Infra::CLIENT} command.",
|
89
|
-
default:
|
89
|
+
default: []
|
90
90
|
|
91
91
|
property :environment, Hash,
|
92
92
|
description: "A Hash containing additional arbitrary environment variables under which the launchd daemon will be run in the form of `({'ENV_VARIABLE' => 'VALUE'})`.",
|
93
|
-
default:
|
93
|
+
default: {}
|
94
94
|
|
95
95
|
property :nice, [Integer, String],
|
96
96
|
description: "The process priority to run the #{ChefUtils::Dist::Infra::CLIENT} process at. A value of -20 is the highest priority and 19 is the lowest priority.",
|
@@ -127,7 +127,7 @@ class Chef
|
|
127
127
|
|
128
128
|
property :daemon_options, Array,
|
129
129
|
description: "An array of options to pass to the #{ChefUtils::Dist::Infra::CLIENT} command.",
|
130
|
-
default:
|
130
|
+
default: []
|
131
131
|
|
132
132
|
action :add do
|
133
133
|
# TODO: Replace this with a :create_if_missing action on directory when that exists
|
@@ -92,11 +92,11 @@ class Chef
|
|
92
92
|
|
93
93
|
property :daemon_options, Array,
|
94
94
|
description: "An array of options to pass to the #{ChefUtils::Dist::Infra::CLIENT} command.",
|
95
|
-
default:
|
95
|
+
default: []
|
96
96
|
|
97
97
|
property :environment, Hash,
|
98
98
|
description: "A Hash containing additional arbitrary environment variables under which the systemd timer will be run in the form of `({'ENV_VARIABLE' => 'VALUE'})`.",
|
99
|
-
default:
|
99
|
+
default: {}
|
100
100
|
|
101
101
|
property :cpu_quota, [Integer, String],
|
102
102
|
description: "The systemd CPUQuota to run the #{ChefUtils::Dist::Infra::CLIENT} process with. This is a percentage value of the total CPU time available on the system. If the system has more than 1 core this may be a value greater than 100.",
|