chef 16.13.16-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 -10
- data/README.md +1 -1
- data/Rakefile +2 -2
- data/chef-universal-mingw32.gemspec +1 -1
- data/chef.gemspec +6 -8
- data/lib/chef/application/base.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 +2 -2
- 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/synchronizer.rb +3 -5
- data/lib/chef/cookbook_loader.rb +2 -4
- data/lib/chef/cookbook_uploader.rb +0 -1
- data/lib/chef/data_bag_item.rb +11 -2
- data/lib/chef/delayed_evaluator.rb +4 -0
- data/lib/chef/deprecated.rb +4 -0
- data/lib/chef/dsl/chef_vault.rb +6 -6
- data/lib/chef/dsl/reboot_pending.rb +1 -2
- data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +20 -22
- data/lib/chef/group.rb +75 -0
- data/lib/chef/mixin/get_source_from_package.rb +1 -1
- data/lib/chef/node/attribute.rb +6 -4
- data/lib/chef/node/immutable_collections.rb +13 -0
- data/lib/chef/node/mixin/deep_merge_cache.rb +11 -7
- data/lib/chef/org.rb +3 -2
- data/lib/chef/property.rb +18 -0
- data/lib/chef/provider.rb +1 -1
- 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/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.rb +5 -5
- 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/package.rb +17 -21
- 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/rubygems.rb +11 -17
- data/lib/chef/provider/package/windows.rb +2 -4
- data/lib/chef/provider/package/yum/yum_helper.py +1 -1
- data/lib/chef/provider/route.rb +2 -2
- data/lib/chef/provider/service.rb +6 -6
- 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/subversion.rb +10 -12
- data/lib/chef/provider/systemd_unit.rb +36 -10
- data/lib/chef/provider/template/content.rb +2 -6
- data/lib/chef/provider/user.rb +2 -2
- 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/zypper_repository.rb +2 -2
- 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 +2 -3
- 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_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 +2 -6
- 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 +2 -1
- 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 +2 -6
- data/lib/chef/resource/scm/git.rb +1 -1
- data/lib/chef/resource/sudo.rb +6 -6
- data/lib/chef/resource/sysctl.rb +2 -6
- data/lib/chef/resource/systemd_unit.rb +2 -2
- 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 -2
- 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 +53 -40
- 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 +1 -1
- data/lib/chef/resource/windows_user_privilege.rb +4 -4
- data/lib/chef/resource/windows_workgroup.rb +1 -2
- data/lib/chef/resources.rb +0 -1
- 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/registry.rb +4 -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-with-circular-deps/resources/resource.rb +2 -0
- data/spec/data/run_context/cookbooks/test-with-deps/resources/resource.rb +1 -0
- data/spec/data/run_context/cookbooks/test/resources/resource.rb +2 -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 +13 -0
- data/spec/functional/resource/dnf_package_spec.rb +4 -1
- 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/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/data_bag_item_spec.rb +1 -6
- 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/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/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/rubygems_spec.rb +21 -33
- 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/powershell_script_spec.rb +2 -2
- data/spec/unit/resource/windows_task_spec.rb +1 -1
- data/spec/unit/user_spec.rb +1 -1
- data/spec/unit/user_v1_spec.rb +6 -4
- data/tasks/rspec.rb +16 -8
- 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.rb +0 -102
- 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/cookbook_site_streaming_uploader.rb +0 -244
- data/lib/chef/knife.rb +0 -665
- 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.rb +0 -1192
- 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/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 -406
- 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/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 -1617
- 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
@@ -76,6 +76,30 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
76
76
|
end
|
77
77
|
end
|
78
78
|
|
79
|
+
def systemd_service_status
|
80
|
+
@systemd_service_status ||= begin
|
81
|
+
# Collect all the status information for a service and returns it at once
|
82
|
+
options, args = get_systemctl_options_args
|
83
|
+
s = shell_out!(systemctl_path, args, "show", "-p", "UnitFileState", "-p", "ActiveState", new_resource.service_name, options)
|
84
|
+
# e.g. /bin/systemctl --system show -p UnitFileState -p ActiveState sshd.service
|
85
|
+
# Returns something like:
|
86
|
+
# ActiveState=active
|
87
|
+
# UnitFileState=enabled
|
88
|
+
status = {}
|
89
|
+
s.stdout.each_line do |line|
|
90
|
+
k, v = line.strip.split("=")
|
91
|
+
status[k] = v
|
92
|
+
end
|
93
|
+
|
94
|
+
# Assert requisite keys exist
|
95
|
+
unless status.key?("UnitFileState") && status.key?("ActiveState")
|
96
|
+
raise Chef::Exceptions::Service, "'#{systemctl_path} show' not reporting status for #{new_resource.service_name}!"
|
97
|
+
end
|
98
|
+
|
99
|
+
status
|
100
|
+
end
|
101
|
+
end
|
102
|
+
|
79
103
|
def get_systemctl_options_args
|
80
104
|
if new_resource.user
|
81
105
|
raise NotImplementedError, "#{new_resource} does not support the user property on a target_mode host (yet)" if Chef::Config.target_mode?
|
@@ -98,7 +122,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
98
122
|
|
99
123
|
def start_service
|
100
124
|
if current_resource.running
|
101
|
-
logger.
|
125
|
+
logger.debug("#{new_resource} already running, not starting")
|
102
126
|
else
|
103
127
|
if new_resource.start_command
|
104
128
|
super
|
@@ -111,7 +135,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
111
135
|
|
112
136
|
def stop_service
|
113
137
|
unless current_resource.running
|
114
|
-
logger.
|
138
|
+
logger.debug("#{new_resource} not running, not stopping")
|
115
139
|
else
|
116
140
|
if new_resource.stop_command
|
117
141
|
super
|
@@ -146,7 +170,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
146
170
|
|
147
171
|
def enable_service
|
148
172
|
if current_resource.masked || current_resource.indirect
|
149
|
-
logger.
|
173
|
+
logger.debug("#{new_resource} cannot be enabled: it is masked or indirect")
|
150
174
|
return
|
151
175
|
end
|
152
176
|
options, args = get_systemctl_options_args
|
@@ -155,7 +179,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
155
179
|
|
156
180
|
def disable_service
|
157
181
|
if current_resource.masked || current_resource.indirect
|
158
|
-
logger.
|
182
|
+
logger.debug("#{new_resource} cannot be disabled: it is masked or indirect")
|
159
183
|
return
|
160
184
|
end
|
161
185
|
options, args = get_systemctl_options_args
|
@@ -173,25 +197,30 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
173
197
|
end
|
174
198
|
|
175
199
|
def is_active?
|
176
|
-
|
177
|
-
|
200
|
+
# Note: "activating" is not active (as with type=notify or a oneshot)
|
201
|
+
systemd_service_status["ActiveState"] == "active"
|
178
202
|
end
|
179
203
|
|
180
204
|
def is_enabled?
|
181
|
-
|
182
|
-
|
205
|
+
# if the service is in sysv compat mode, shellout to determine if enabled
|
206
|
+
if systemd_service_status["UnitFileState"] == "bad"
|
207
|
+
options, args = get_systemctl_options_args
|
208
|
+
return shell_out(systemctl_path, args, "is-enabled", new_resource.service_name, "--quiet", **options).exitstatus == 0
|
209
|
+
end
|
210
|
+
# See https://github.com/systemd/systemd/blob/master/src/systemctl/systemctl-is-enabled.c
|
211
|
+
# Note: enabled-runtime is excluded because this is volatile, and the state of enabled-runtime
|
212
|
+
# specifically means that the service is not enabled
|
213
|
+
%w{enabled static generated alias indirect}.include?(systemd_service_status["UnitFileState"])
|
183
214
|
end
|
184
215
|
|
185
216
|
def is_indirect?
|
186
|
-
|
187
|
-
s = shell_out(systemctl_path, args, "is-enabled", new_resource.service_name, **options)
|
188
|
-
s.stdout.include?("indirect")
|
217
|
+
systemd_service_status["UnitFileState"] == "indirect"
|
189
218
|
end
|
190
219
|
|
191
220
|
def is_masked?
|
192
|
-
|
193
|
-
|
194
|
-
|
221
|
+
# Note: masked-runtime is excluded, because runtime is volatile, and
|
222
|
+
# because masked-runtime is not masked.
|
223
|
+
systemd_service_status["UnitFileState"] == "masked"
|
195
224
|
end
|
196
225
|
|
197
226
|
private
|
@@ -28,10 +28,6 @@ class Chef
|
|
28
28
|
# to maintain a local state of service across restart's internal calls
|
29
29
|
attr_accessor :upstart_service_running
|
30
30
|
|
31
|
-
provides :service, platform_family: "debian", override: true do
|
32
|
-
upstart?
|
33
|
-
end
|
34
|
-
|
35
31
|
UPSTART_STATE_FORMAT = %r{\S+ \(?(start|stop)?\)? ?[/ ](\w+)}.freeze
|
36
32
|
|
37
33
|
# Returns true if the configs for the service name has upstart variable
|
@@ -65,15 +61,8 @@ class Chef
|
|
65
61
|
end
|
66
62
|
end
|
67
63
|
|
68
|
-
|
69
|
-
|
70
|
-
@upstart_job_dir = "/etc/event.d"
|
71
|
-
@upstart_conf_suffix = ""
|
72
|
-
else
|
73
|
-
@upstart_job_dir = "/etc/init"
|
74
|
-
@upstart_conf_suffix = ".conf"
|
75
|
-
end
|
76
|
-
|
64
|
+
@upstart_job_dir = "/etc/init"
|
65
|
+
@upstart_conf_suffix = ".conf"
|
77
66
|
@command_success = true # new_resource.status_command= false, means upstart used
|
78
67
|
@config_file_found = true
|
79
68
|
@upstart_command_success = true
|
@@ -85,7 +85,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
85
85
|
|
86
86
|
state = current_state
|
87
87
|
if state == RUNNING
|
88
|
-
logger.
|
88
|
+
logger.debug "#{@new_resource} already started - nothing to do"
|
89
89
|
elsif state == START_PENDING
|
90
90
|
logger.trace "#{@new_resource} already sent start signal - waiting for start"
|
91
91
|
wait_for_state(RUNNING)
|
@@ -114,7 +114,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
114
114
|
raise Chef::Exceptions::Service, "Service #{@new_resource} can't be started from state [#{state}]"
|
115
115
|
end
|
116
116
|
else
|
117
|
-
logger.
|
117
|
+
logger.debug "#{@new_resource} does not exist - nothing to do"
|
118
118
|
end
|
119
119
|
end
|
120
120
|
|
@@ -133,7 +133,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
133
133
|
end
|
134
134
|
@new_resource.updated_by_last_action(true)
|
135
135
|
elsif state == STOPPED
|
136
|
-
logger.
|
136
|
+
logger.debug "#{@new_resource} already stopped - nothing to do"
|
137
137
|
elsif state == STOP_PENDING
|
138
138
|
logger.trace "#{@new_resource} already sent stop signal - waiting for stop"
|
139
139
|
wait_for_state(STOPPED)
|
@@ -141,7 +141,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
141
141
|
raise Chef::Exceptions::Service, "Service #{@new_resource} can't be stopped from state [#{state}]"
|
142
142
|
end
|
143
143
|
else
|
144
|
-
logger.
|
144
|
+
logger.debug "#{@new_resource} does not exist - nothing to do"
|
145
145
|
end
|
146
146
|
end
|
147
147
|
|
@@ -156,7 +156,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
156
156
|
end
|
157
157
|
@new_resource.updated_by_last_action(true)
|
158
158
|
else
|
159
|
-
logger.
|
159
|
+
logger.debug "#{@new_resource} does not exist - nothing to do"
|
160
160
|
end
|
161
161
|
end
|
162
162
|
|
@@ -164,7 +164,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
164
164
|
if Win32::Service.exists?(@new_resource.service_name)
|
165
165
|
set_startup_type(:automatic)
|
166
166
|
else
|
167
|
-
logger.
|
167
|
+
logger.debug "#{@new_resource} does not exist - nothing to do"
|
168
168
|
end
|
169
169
|
end
|
170
170
|
|
@@ -172,13 +172,13 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
172
172
|
if Win32::Service.exists?(@new_resource.service_name)
|
173
173
|
set_startup_type(:disabled)
|
174
174
|
else
|
175
|
-
logger.
|
175
|
+
logger.debug "#{@new_resource} does not exist - nothing to do"
|
176
176
|
end
|
177
177
|
end
|
178
178
|
|
179
179
|
action :create do
|
180
180
|
if Win32::Service.exists?(new_resource.service_name)
|
181
|
-
logger.
|
181
|
+
logger.debug "#{new_resource} already exists - nothing to do"
|
182
182
|
return
|
183
183
|
end
|
184
184
|
|
@@ -191,7 +191,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
191
191
|
|
192
192
|
action :delete do
|
193
193
|
unless Win32::Service.exists?(new_resource.service_name)
|
194
|
-
logger.
|
194
|
+
logger.debug "#{new_resource} does not exist - nothing to do"
|
195
195
|
return
|
196
196
|
end
|
197
197
|
|
@@ -222,7 +222,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
222
222
|
logger.info("#{@new_resource} enabled")
|
223
223
|
end
|
224
224
|
else
|
225
|
-
logger.
|
225
|
+
logger.debug("#{@new_resource} already enabled - nothing to do")
|
226
226
|
end
|
227
227
|
load_new_resource_state
|
228
228
|
@new_resource.enabled(true)
|
@@ -235,7 +235,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
235
235
|
logger.info("#{@new_resource} disabled")
|
236
236
|
end
|
237
237
|
else
|
238
|
-
logger.
|
238
|
+
logger.debug("#{@new_resource} already disabled - nothing to do")
|
239
239
|
end
|
240
240
|
load_new_resource_state
|
241
241
|
@new_resource.enabled(false)
|
@@ -248,7 +248,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
248
248
|
set_startup_type(startup_type)
|
249
249
|
end
|
250
250
|
else
|
251
|
-
logger.
|
251
|
+
logger.debug("#{@new_resource} startup_type already #{startup_type} - nothing to do")
|
252
252
|
end
|
253
253
|
|
254
254
|
converge_delayed_start
|
@@ -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
|
@@ -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
|
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
|
|
@@ -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?
|