chef 16.3.45 → 16.4.35

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.
Files changed (201) hide show
  1. checksums.yaml +4 -4
  2. data/chef-universal-mingw32.gemspec +0 -1
  3. data/lib/chef/action_collection.rb +4 -0
  4. data/lib/chef/api_client/registration.rb +8 -8
  5. data/lib/chef/application.rb +6 -1
  6. data/lib/chef/application/apply.rb +5 -5
  7. data/lib/chef/application/base.rb +2 -0
  8. data/lib/chef/application/client.rb +3 -0
  9. data/lib/chef/application/windows_service.rb +27 -27
  10. data/lib/chef/chef_class.rb +0 -1
  11. data/lib/chef/chef_fs/chef_fs_data_store.rb +54 -54
  12. data/lib/chef/chef_fs/file_system/chef_server/acl_entry.rb +10 -10
  13. data/lib/chef/chef_fs/file_system/chef_server/organization_invites_entry.rb +8 -8
  14. data/lib/chef/chef_fs/file_system/chef_server/organization_members_entry.rb +8 -8
  15. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_dir.rb +2 -2
  16. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +1 -1
  17. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +18 -18
  18. data/lib/chef/chef_fs/file_system/repository/directory.rb +1 -1
  19. data/lib/chef/chef_fs/file_system/repository/file_system_entry.rb +1 -1
  20. data/lib/chef/client.rb +11 -11
  21. data/lib/chef/data_collector/run_end_message.rb +11 -1
  22. data/lib/chef/dsl/platform_introspection.rb +8 -8
  23. data/lib/chef/encrypted_data_bag_item/decryptor.rb +1 -1
  24. data/lib/chef/environment.rb +2 -2
  25. data/lib/chef/exceptions.rb +1 -1
  26. data/lib/chef/file_content_management/tempfile.rb +9 -9
  27. data/lib/chef/http.rb +2 -1
  28. data/lib/chef/json_compat.rb +1 -1
  29. data/lib/chef/knife/bootstrap.rb +2 -2
  30. data/lib/chef/knife/cookbook_download.rb +1 -1
  31. data/lib/chef/knife/cookbook_metadata.rb +1 -1
  32. data/lib/chef/knife/cookbook_upload.rb +23 -23
  33. data/lib/chef/knife/core/generic_presenter.rb +1 -1
  34. data/lib/chef/knife/core/hashed_command_loader.rb +2 -2
  35. data/lib/chef/knife/core/windows_bootstrap_context.rb +32 -24
  36. data/lib/chef/knife/delete.rb +15 -15
  37. data/lib/chef/knife/exec.rb +2 -2
  38. data/lib/chef/knife/ssh.rb +6 -6
  39. data/lib/chef/knife/xargs.rb +19 -19
  40. data/lib/chef/knife/yaml_convert.rb +1 -1
  41. data/lib/chef/mixin/checksum.rb +0 -1
  42. data/lib/chef/mixin/deep_merge.rb +35 -6
  43. data/lib/chef/mixin/openssl_helper.rb +3 -1
  44. data/lib/chef/mixin/shell_out.rb +1 -1
  45. data/lib/chef/mixin/which.rb +1 -1
  46. data/lib/chef/monkey_patches/webrick-utils.rb +10 -10
  47. data/lib/chef/node/attribute.rb +2 -4
  48. data/lib/chef/platform/service_helpers.rb +1 -1
  49. data/lib/chef/property.rb +1 -1
  50. data/lib/chef/provider/cron/unix.rb +0 -2
  51. data/lib/chef/provider/git.rb +5 -5
  52. data/lib/chef/provider/group.rb +0 -2
  53. data/lib/chef/provider/group/suse.rb +5 -5
  54. data/lib/chef/provider/ifconfig.rb +1 -4
  55. data/lib/chef/provider/mount.rb +0 -2
  56. data/lib/chef/provider/package.rb +0 -2
  57. data/lib/chef/provider/package/rubygems.rb +1 -1
  58. data/lib/chef/provider/package/snap.rb +1 -1
  59. data/lib/chef/provider/package/windows/registry_uninstall_entry.rb +9 -9
  60. data/lib/chef/provider/powershell_script.rb +21 -5
  61. data/lib/chef/provider/route.rb +1 -1
  62. data/lib/chef/provider/service/arch.rb +1 -1
  63. data/lib/chef/provider/service/debian.rb +1 -1
  64. data/lib/chef/provider/service/gentoo.rb +2 -2
  65. data/lib/chef/provider/service/macosx.rb +2 -2
  66. data/lib/chef/provider/service/openbsd.rb +1 -4
  67. data/lib/chef/provider/service/redhat.rb +2 -2
  68. data/lib/chef/provider/service/upstart.rb +1 -1
  69. data/lib/chef/provider/service/windows.rb +10 -10
  70. data/lib/chef/provider/systemd_unit.rb +0 -2
  71. data/lib/chef/provider/template/content.rb +1 -0
  72. data/lib/chef/provider/user/dscl.rb +2 -2
  73. data/lib/chef/provider/user/mac.rb +9 -9
  74. data/lib/chef/provider/windows_task.rb +0 -3
  75. data/lib/chef/provider/zypper_repository.rb +0 -1
  76. data/lib/chef/providers.rb +0 -1
  77. data/lib/chef/recipe.rb +1 -1
  78. data/lib/chef/resource.rb +6 -10
  79. data/lib/chef/resource/apt_repository.rb +1 -10
  80. data/lib/chef/resource/chef_client_systemd_timer.rb +2 -2
  81. data/lib/chef/resource/chef_vault_secret.rb +13 -13
  82. data/lib/chef/resource/execute.rb +2 -3
  83. data/lib/chef/resource/homebrew_update.rb +2 -2
  84. data/lib/chef/resource/openssl_dhparam.rb +2 -0
  85. data/lib/chef/resource/openssl_ec_private_key.rb +2 -0
  86. data/lib/chef/resource/openssl_ec_public_key.rb +2 -0
  87. data/lib/chef/resource/openssl_rsa_private_key.rb +2 -0
  88. data/lib/chef/resource/openssl_rsa_public_key.rb +2 -0
  89. data/lib/chef/resource/openssl_x509_certificate.rb +24 -21
  90. data/lib/chef/resource/openssl_x509_crl.rb +2 -0
  91. data/lib/chef/resource/openssl_x509_request.rb +23 -20
  92. data/lib/chef/resource/osx_profile.rb +227 -5
  93. data/lib/chef/resource/powershell_package_source.rb +1 -1
  94. data/lib/chef/resource/powershell_script.rb +24 -30
  95. data/lib/chef/resource/sudo.rb +1 -1
  96. data/lib/chef/resource/sysctl.rb +5 -5
  97. data/lib/chef/resource/windows_ad_join.rb +2 -0
  98. data/lib/chef/resource/windows_audit_policy.rb +3 -0
  99. data/lib/chef/resource/windows_auto_run.rb +2 -0
  100. data/lib/chef/resource/windows_certificate.rb +2 -0
  101. data/lib/chef/resource/windows_dfs_folder.rb +2 -0
  102. data/lib/chef/resource/windows_dfs_namespace.rb +2 -0
  103. data/lib/chef/resource/windows_dfs_server.rb +2 -0
  104. data/lib/chef/resource/windows_dns_record.rb +10 -7
  105. data/lib/chef/resource/windows_dns_zone.rb +12 -7
  106. data/lib/chef/resource/windows_feature.rb +2 -0
  107. data/lib/chef/resource/windows_feature_dism.rb +10 -0
  108. data/lib/chef/resource/windows_feature_powershell.rb +14 -2
  109. data/lib/chef/resource/windows_firewall_profile.rb +4 -2
  110. data/lib/chef/resource/windows_firewall_rule.rb +5 -3
  111. data/lib/chef/resource/windows_font.rb +3 -1
  112. data/lib/chef/resource/windows_pagefile.rb +4 -0
  113. data/lib/chef/resource/windows_printer.rb +17 -18
  114. data/lib/chef/resource/windows_printer_port.rb +14 -13
  115. data/lib/chef/resource/windows_security_policy.rb +2 -0
  116. data/lib/chef/resource/windows_share.rb +5 -3
  117. data/lib/chef/resource/windows_shortcut.rb +2 -0
  118. data/lib/chef/resource/windows_uac.rb +2 -0
  119. data/lib/chef/resource/windows_user_privilege.rb +2 -0
  120. data/lib/chef/resource/windows_workgroup.rb +2 -3
  121. data/lib/chef/resource_collection/stepable_iterator.rb +1 -2
  122. data/lib/chef/role.rb +2 -2
  123. data/lib/chef/run_context/cookbook_compiler.rb +20 -20
  124. data/lib/chef/run_status.rb +2 -6
  125. data/lib/chef/shell.rb +1 -1
  126. data/lib/chef/util/backup.rb +1 -1
  127. data/lib/chef/util/diff.rb +11 -11
  128. data/lib/chef/util/powershell/cmdlet.rb +1 -1
  129. data/lib/chef/version.rb +1 -1
  130. data/lib/chef/win32/file.rb +2 -2
  131. data/lib/chef/win32/file/version_info.rb +5 -5
  132. data/spec/data/ssl/chef-rspec.cert +15 -15
  133. data/spec/functional/resource/aixinit_service_spec.rb +7 -7
  134. data/spec/functional/resource/bff_spec.rb +2 -2
  135. data/spec/functional/resource/cookbook_file_spec.rb +1 -1
  136. data/spec/functional/resource/dsc_resource_spec.rb +1 -1
  137. data/spec/functional/resource/dsc_script_spec.rb +0 -1
  138. data/spec/functional/resource/group_spec.rb +6 -6
  139. data/spec/functional/resource/insserv_spec.rb +4 -4
  140. data/spec/functional/resource/link_spec.rb +20 -20
  141. data/spec/functional/resource/powershell_script_spec.rb +4 -4
  142. data/spec/functional/resource/rpm_spec.rb +2 -2
  143. data/spec/functional/resource/windows_certificate_spec.rb +3 -3
  144. data/spec/functional/resource/windows_font_spec.rb +49 -0
  145. data/spec/functional/resource/windows_security_policy_spec.rb +0 -3
  146. data/spec/functional/run_lock_spec.rb +24 -24
  147. data/spec/functional/win32/registry_spec.rb +8 -8
  148. data/spec/functional/win32/service_manager_spec.rb +1 -1
  149. data/spec/integration/knife/common_options_spec.rb +12 -12
  150. data/spec/integration/knife/config_get_profile_spec.rb +69 -68
  151. data/spec/integration/knife/config_get_spec.rb +126 -125
  152. data/spec/integration/knife/config_list_profiles_spec.rb +181 -180
  153. data/spec/integration/knife/config_use_profile_spec.rb +110 -109
  154. data/spec/integration/knife/diff_spec.rb +3 -1
  155. data/spec/integration/knife/download_spec.rb +3 -1
  156. data/spec/integration/knife/serve_spec.rb +5 -5
  157. data/spec/integration/knife/upload_spec.rb +3 -1
  158. data/spec/integration/recipes/lwrp_inline_resources_spec.rb +1 -1
  159. data/spec/spec_helper.rb +6 -6
  160. data/spec/support/platform_helpers.rb +9 -9
  161. data/spec/support/platforms/win32/spec_service.rb +1 -1
  162. data/spec/support/shared/functional/directory_resource.rb +1 -1
  163. data/spec/support/shared/functional/execute_resource.rb +1 -1
  164. data/spec/support/shared/functional/file_resource.rb +20 -20
  165. data/spec/support/shared/functional/win32_service.rb +1 -1
  166. data/spec/support/shared/functional/windows_script.rb +3 -3
  167. data/spec/support/shared/integration/integration_helper.rb +22 -52
  168. data/spec/support/shared/unit/script_resource.rb +6 -20
  169. data/spec/support/shared/unit/windows_script_resource.rb +15 -28
  170. data/spec/unit/data_collector_spec.rb +22 -0
  171. data/spec/unit/environment_spec.rb +7 -7
  172. data/spec/unit/knife/bootstrap_spec.rb +14 -14
  173. data/spec/unit/knife/cookbook_download_spec.rb +4 -4
  174. data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +1 -1
  175. data/spec/unit/knife/core/hashed_command_loader_spec.rb +3 -3
  176. data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +21 -12
  177. data/spec/unit/knife/supermarket_share_spec.rb +1 -1
  178. data/spec/unit/mixin/template_spec.rb +30 -30
  179. data/spec/unit/mixin/windows_architecture_helper_spec.rb +4 -4
  180. data/spec/unit/node/immutable_collections_spec.rb +6 -2
  181. data/spec/unit/node_spec.rb +5 -5
  182. data/spec/unit/provider/powershell_script_spec.rb +11 -4
  183. data/spec/unit/provider/remote_directory_spec.rb +9 -9
  184. data/spec/unit/provider/service/arch_service_spec.rb +3 -2
  185. data/spec/unit/provider/service/debian_service_spec.rb +1 -1
  186. data/spec/unit/provider/service/gentoo_service_spec.rb +7 -7
  187. data/spec/unit/provider/service/macosx_spec.rb +3 -3
  188. data/spec/unit/provider/service/redhat_spec.rb +2 -2
  189. data/spec/unit/provider/service/upstart_service_spec.rb +3 -3
  190. data/spec/unit/provider_resolver_spec.rb +6 -6
  191. data/spec/unit/resource/batch_spec.rb +6 -6
  192. data/spec/unit/resource/execute_spec.rb +113 -118
  193. data/spec/unit/resource/osx_profile_spec.rb +233 -0
  194. data/spec/unit/resource/powershell_script_spec.rb +11 -29
  195. data/spec/unit/resource/script_spec.rb +6 -1
  196. data/spec/unit/resource/windows_feature_powershell_spec.rb +30 -4
  197. data/spec/unit/role_spec.rb +11 -11
  198. data/tasks/rspec.rb +1 -1
  199. metadata +7 -8
  200. data/lib/chef/provider/osx_profile.rb +0 -255
  201. data/spec/unit/provider/osx_profile_spec.rb +0 -255
@@ -188,7 +188,7 @@ class Chef
188
188
  # Use the API that 'gem install' calls which does not pull down the rubygems universe
189
189
  begin
190
190
  rs = dependency_installer.resolve_dependencies gem_dependency.name, gem_dependency.requirement
191
- rs.specs.select { |s| s.name == gem_dependency.name }.first
191
+ rs.specs.find { |s| s.name == gem_dependency.name }
192
192
  rescue Gem::UnsatisfiableDependencyError
193
193
  nil
194
194
  end
@@ -20,7 +20,7 @@ require_relative "../package"
20
20
  require_relative "../../resource/snap_package"
21
21
  require_relative "../../mixin/shell_out"
22
22
  require "socket" unless defined?(Socket)
23
- require "json"
23
+ require "json" unless defined?(JSON)
24
24
 
25
25
  class Chef
26
26
  class Provider
@@ -37,16 +37,16 @@ class Chef
37
37
  begin
38
38
  ::Win32::Registry.open(hkey[0], UNINSTALL_SUBKEY, desired) do |reg|
39
39
  reg.each_key do |key, _wtime|
40
- begin
41
- entry = reg.open(key, desired)
42
- display_name = read_registry_property(entry, "DisplayName")
43
- if display_name.to_s.rstrip == package_name
44
- quiet_uninstall_string = RegistryUninstallEntry.read_registry_property(entry, "QuietUninstallString")
45
- entries.push(quiet_uninstall_string_key?(quiet_uninstall_string, hkey, key, entry))
46
- end
47
- rescue ::Win32::Registry::Error => ex
48
- logger.trace("Registry error opening key '#{key}' on node #{desired}: #{ex}")
40
+
41
+ entry = reg.open(key, desired)
42
+ display_name = read_registry_property(entry, "DisplayName")
43
+ if display_name.to_s.rstrip == package_name
44
+ quiet_uninstall_string = RegistryUninstallEntry.read_registry_property(entry, "QuietUninstallString")
45
+ entries.push(quiet_uninstall_string_key?(quiet_uninstall_string, hkey, key, entry))
49
46
  end
47
+ rescue ::Win32::Registry::Error => ex
48
+ logger.trace("Registry error opening key '#{key}' on node #{desired}: #{ex}")
49
+
50
50
  end
51
51
  end
52
52
  rescue ::Win32::Registry::Error => ex
@@ -31,21 +31,32 @@ class Chef
31
31
  super()
32
32
  end
33
33
 
34
- def command
35
- # Powershell.exe is always in "v1.0" folder (for backwards compatibility)
36
- interpreter_path = Chef::Util::PathHelper.join(basepath, "WindowsPowerShell", "v1.0", interpreter)
34
+ # Set InputFormat to None as PowerShell will hang if STDIN is redirected
35
+ # http://connect.microsoft.com/PowerShell/feedback/details/572313/powershell-exe-can-hang-if-stdin-is-redirected
36
+ DEFAULT_FLAGS = "-NoLogo -NonInteractive -NoProfile -ExecutionPolicy Bypass -InputFormat None".freeze
37
37
 
38
+ def command
38
39
  # Must use -File rather than -Command to launch the script
39
40
  # file created by the base class that contains the script
40
41
  # code -- otherwise, powershell.exe does not propagate the
41
42
  # error status of a failed Windows process that ran at the
42
43
  # end of the script, it gets changed to '1'.
43
44
  #
44
- "\"#{interpreter_path}\" #{new_resource.flags} -File \"#{script_file_path}\""
45
+ [
46
+ %Q{"#{interpreter_path}"},
47
+ DEFAULT_FLAGS,
48
+ new_resource.flags,
49
+ %Q{-File "#{script_file_path}"},
50
+ ].join(" ")
45
51
  end
46
52
 
47
53
  protected
48
54
 
55
+ def interpreter_path
56
+ # Powershell.exe is always in "v1.0" folder (for backwards compatibility)
57
+ Chef::Util::PathHelper.join(basepath, "WindowsPowerShell", "v1.0", interpreter)
58
+ end
59
+
49
60
  def code
50
61
  code = wrapper_script
51
62
  logger.trace("powershell_script provider called with script code:\n\n#{new_resource.code}\n")
@@ -71,7 +82,12 @@ class Chef
71
82
  # written to the file system at this point, which is required since
72
83
  # the intent is to execute the code just written to it.
73
84
  user_script_file.close
74
- validation_command = "\"#{interpreter}\" #{new_resource.flags} -Command \". '#{user_script_file.path}'\""
85
+ validation_command = [
86
+ %Q{"#{interpreter_path}"},
87
+ DEFAULT_FLAGS,
88
+ new_resource.flags,
89
+ %Q{-Command ". '#{user_script_file.path}'"},
90
+ ].join(" ")
75
91
 
76
92
  # Note that other script providers like bash allow syntax errors
77
93
  # to be suppressed by setting 'returns' to a value that the
@@ -19,7 +19,7 @@
19
19
 
20
20
  require_relative "../log"
21
21
  require_relative "../provider"
22
- require "ipaddr"
22
+ require "ipaddr" unless defined?(IPAddr)
23
23
 
24
24
  class Chef
25
25
  class Provider
@@ -32,7 +32,7 @@ class Chef::Provider::Service::Arch < Chef::Provider::Service::Init
32
32
  end
33
33
 
34
34
  def load_current_resource
35
- raise Chef::Exceptions::Service, "Could not find /etc/rc.conf" unless ::File.exists?("/etc/rc.conf")
35
+ raise Chef::Exceptions::Service, "Could not find /etc/rc.conf" unless ::File.exist?("/etc/rc.conf")
36
36
  raise Chef::Exceptions::Service, "No DAEMONS found in /etc/rc.conf" unless /DAEMONS=\((.*)\)/m.match?(::File.read("/etc/rc.conf"))
37
37
 
38
38
  super
@@ -45,7 +45,7 @@ class Chef
45
45
  shared_resource_requirements
46
46
  requirements.assert(:all_actions) do |a|
47
47
  update_rcd = "/usr/sbin/update-rc.d"
48
- a.assertion { ::File.exists? update_rcd }
48
+ a.assertion { ::File.exist? update_rcd }
49
49
  a.failure_message Chef::Exceptions::Service, "#{update_rcd} does not exist!"
50
50
  # no whyrun recovery - this is a base system component of debian
51
51
  # distros and must be present
@@ -34,7 +34,7 @@ class Chef::Provider::Service::Gentoo < Chef::Provider::Service::Init
34
34
  @current_resource.enabled(
35
35
  Dir.glob("/etc/runlevels/**/#{Chef::Util::PathHelper.escape_glob_dir(@current_resource.service_name)}").any? do |file|
36
36
  @found_script = true
37
- exists = ::File.exists? file
37
+ exists = ::File.exist? file
38
38
  readable = ::File.readable? file
39
39
  logger.trace "#{@new_resource} exists: #{exists}, readable: #{readable}"
40
40
  exists && readable
@@ -47,7 +47,7 @@ class Chef::Provider::Service::Gentoo < Chef::Provider::Service::Init
47
47
 
48
48
  def define_resource_requirements
49
49
  requirements.assert(:all_actions) do |a|
50
- a.assertion { ::File.exists?("/sbin/rc-update") }
50
+ a.assertion { ::File.exist?("/sbin/rc-update") }
51
51
  a.failure_message Chef::Exceptions::Service, "/sbin/rc-update does not exist"
52
52
  # no whyrun recovery -t his is a core component whose presence is
53
53
  # unlikely to be affected by what we do in the course of a chef run
@@ -81,7 +81,7 @@ class Chef
81
81
  end
82
82
 
83
83
  requirements.assert(:all_actions) do |a|
84
- a.assertion { ::File.exists?(@plist.to_s) }
84
+ a.assertion { ::File.exist?(@plist.to_s) }
85
85
  a.failure_message Chef::Exceptions::Service,
86
86
  "Could not find plist for #{@new_resource}"
87
87
  end
@@ -221,7 +221,7 @@ class Chef
221
221
  return nil if @plist.nil?
222
222
 
223
223
  # Plist must exist by this point
224
- raise Chef::Exceptions::FileNotFound, "Cannot find #{@plist}!" unless ::File.exists?(@plist)
224
+ raise Chef::Exceptions::FileNotFound, "Cannot find #{@plist}!" unless ::File.exist?(@plist)
225
225
 
226
226
  # Most services have the same internal label as the name of the
227
227
  # plist file. However, there is no rule saying that *has* to be
@@ -16,7 +16,6 @@
16
16
  # limitations under the License.
17
17
  #
18
18
 
19
- require_relative "../../mixin/shell_out"
20
19
  require_relative "init"
21
20
  require_relative "../../resource/service"
22
21
 
@@ -27,8 +26,6 @@ class Chef
27
26
 
28
27
  provides :service, os: "openbsd"
29
28
 
30
- include Chef::Mixin::ShellOut
31
-
32
29
  attr_reader :init_command, :rc_conf, :rc_conf_local, :enabled_state_found
33
30
 
34
31
  RC_CONF_PATH = "/etc/rc.conf".freeze
@@ -132,7 +129,7 @@ class Chef
132
129
  end
133
130
 
134
131
  def update_rcl(value)
135
- FileUtils.touch RC_CONF_LOCAL_PATH unless ::File.exists? RC_CONF_LOCAL_PATH
132
+ FileUtils.touch RC_CONF_LOCAL_PATH unless ::File.exist? RC_CONF_LOCAL_PATH
136
133
  ::File.write(RC_CONF_LOCAL_PATH, value)
137
134
  @rc_conf_local = value
138
135
  end
@@ -56,7 +56,7 @@ class Chef
56
56
 
57
57
  requirements.assert(:all_actions) do |a|
58
58
  chkconfig_file = "/sbin/chkconfig"
59
- a.assertion { ::File.exists? chkconfig_file }
59
+ a.assertion { ::File.exist? chkconfig_file }
60
60
  a.failure_message Chef::Exceptions::Service, "#{chkconfig_file} does not exist!"
61
61
  end
62
62
 
@@ -80,7 +80,7 @@ class Chef
80
80
 
81
81
  super
82
82
 
83
- if ::File.exists?("/sbin/chkconfig")
83
+ if ::File.exist?("/sbin/chkconfig")
84
84
  chkconfig = shell_out!("/sbin/chkconfig --list #{current_resource.service_name}", returns: [0, 1])
85
85
  unless run_levels.nil? || run_levels.empty?
86
86
  all_levels_match = true
@@ -135,7 +135,7 @@ class Chef
135
135
  end
136
136
  end
137
137
  # Get enabled/disabled state by reading job configuration file
138
- if ::File.exists?("#{@upstart_job_dir}/#{@new_resource.service_name}#{@upstart_conf_suffix}")
138
+ if ::File.exist?("#{@upstart_job_dir}/#{@new_resource.service_name}#{@upstart_conf_suffix}")
139
139
  logger.trace("#{@new_resource} found #{@upstart_job_dir}/#{@new_resource.service_name}#{@upstart_conf_suffix}")
140
140
  ::File.open("#{@upstart_job_dir}/#{@new_resource.service_name}#{@upstart_conf_suffix}", "r") do |file|
141
141
  while line = file.gets
@@ -95,17 +95,17 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
95
95
  shell_out!(@new_resource.start_command)
96
96
  else
97
97
  spawn_command_thread do
98
- begin
99
- Win32::Service.start(@new_resource.service_name)
100
- rescue SystemCallError => ex
101
- if ex.errno == ERROR_SERVICE_LOGON_FAILED
102
- logger.error ex.message
103
- raise Chef::Exceptions::Service,
104
- "Service #{@new_resource} did not start due to a logon failure (error #{ERROR_SERVICE_LOGON_FAILED}): possibly the specified user '#{@new_resource.run_as_user}' does not have the 'log on as a service' privilege, or the password is incorrect."
105
- else
106
- raise ex
107
- end
98
+
99
+ Win32::Service.start(@new_resource.service_name)
100
+ rescue SystemCallError => ex
101
+ if ex.errno == ERROR_SERVICE_LOGON_FAILED
102
+ logger.error ex.message
103
+ raise Chef::Exceptions::Service,
104
+ "Service #{@new_resource} did not start due to a logon failure (error #{ERROR_SERVICE_LOGON_FAILED}): possibly the specified user '#{@new_resource.run_as_user}' does not have the 'log on as a service' privilege, or the password is incorrect."
105
+ else
106
+ raise ex
108
107
  end
108
+
109
109
  end
110
110
  wait_for_state(RUNNING)
111
111
  end
@@ -18,7 +18,6 @@
18
18
 
19
19
  require_relative "../provider"
20
20
  require_relative "../mixin/which"
21
- require_relative "../mixin/shell_out"
22
21
  require_relative "../resource/file"
23
22
  require_relative "../resource/file/verification/systemd_unit"
24
23
  require "iniparse"
@@ -28,7 +27,6 @@ class Chef
28
27
  class Provider
29
28
  class SystemdUnit < Chef::Provider
30
29
  include Chef::Mixin::Which
31
- include Chef::Mixin::ShellOut
32
30
 
33
31
  provides :systemd_unit
34
32
 
@@ -1,3 +1,4 @@
1
+ # rubocop: disable Performance/InefficientHashSearch
1
2
  #
2
3
  # Author:: Lamont Granquist (<lamont@chef.io>)
3
4
  # Copyright:: Copyright (c) Chef Software Inc.
@@ -562,7 +562,7 @@ in 'password', with the associated 'salt' and 'iterations'.")
562
562
  # Sets a value in user information hash using Chef attributes as keys.
563
563
  #
564
564
  def dscl_set(user_hash, key, value)
565
- raise "Unknown dscl key #{key}" unless DSCL_PROPERTY_MAP.keys.include?(key)
565
+ raise "Unknown dscl key #{key}" unless DSCL_PROPERTY_MAP.key?(key)
566
566
 
567
567
  user_hash[DSCL_PROPERTY_MAP[key]] = [ value ]
568
568
  user_hash
@@ -572,7 +572,7 @@ in 'password', with the associated 'salt' and 'iterations'.")
572
572
  # Gets a value from user information hash using Chef attributes as keys.
573
573
  #
574
574
  def dscl_get(user_hash, key)
575
- raise "Unknown dscl key #{key}" unless DSCL_PROPERTY_MAP.keys.include?(key)
575
+ raise "Unknown dscl key #{key}" unless DSCL_PROPERTY_MAP.key?(key)
576
576
 
577
577
  # DSCL values are set as arrays
578
578
  value = user_hash[DSCL_PROPERTY_MAP[key]]
@@ -583,16 +583,16 @@ class Chef
583
583
  timeout = Time.now + 5
584
584
 
585
585
  loop do
586
- begin
587
- run_dscl("read", "/Users/#{new_resource.username}", "ShadowHashData")
588
- break
589
- rescue Chef::Exceptions::DsclCommandFailed => e
590
- if Time.now < timeout
591
- sleep 0.1
592
- else
593
- raise Chef::Exceptions::User, e.message
594
- end
586
+
587
+ run_dscl("read", "/Users/#{new_resource.username}", "ShadowHashData")
588
+ break
589
+ rescue Chef::Exceptions::DsclCommandFailed => e
590
+ if Time.now < timeout
591
+ sleep 0.1
592
+ else
593
+ raise Chef::Exceptions::User, e.message
595
594
  end
595
+
596
596
  end
597
597
  end
598
598
 
@@ -16,7 +16,6 @@
16
16
  # limitations under the License.
17
17
  #
18
18
 
19
- require_relative "../mixin/shell_out"
20
19
  require "rexml/document" unless defined?(REXML::Document)
21
20
  require "iso8601" if ChefUtils.windows?
22
21
  require_relative "../provider"
@@ -26,8 +25,6 @@ require "win32/taskscheduler" if ChefUtils.windows?
26
25
  class Chef
27
26
  class Provider
28
27
  class WindowsTask < Chef::Provider
29
- include Chef::Mixin::ShellOut
30
-
31
28
  if ChefUtils.windows?
32
29
  include Win32
33
30
 
@@ -19,7 +19,6 @@
19
19
  require_relative "../resource"
20
20
  require_relative "../dsl/declare_resource"
21
21
  require_relative "noop"
22
- require_relative "../mixin/shell_out"
23
22
  require "shellwords" unless defined?(Shellwords)
24
23
  require_relative "../dist"
25
24
 
@@ -36,7 +36,6 @@ require_relative "provider/mount"
36
36
  require_relative "provider/noop"
37
37
  require_relative "provider/package"
38
38
  require_relative "provider/powershell_script"
39
- require_relative "provider/osx_profile"
40
39
  require_relative "provider/remote_directory"
41
40
  require_relative "provider/remote_file"
42
41
  require_relative "provider/route"
@@ -17,7 +17,7 @@
17
17
  # limitations under the License.
18
18
  #
19
19
 
20
- require "yaml"
20
+ require "yaml" unless defined?(YAML)
21
21
  require_relative "dsl/recipe"
22
22
  require_relative "mixin/from_file"
23
23
  require_relative "mixin/deprecation"
@@ -19,8 +19,6 @@
19
19
  #
20
20
 
21
21
  require_relative "exceptions"
22
- require_relative "dsl/data_query"
23
- require_relative "dsl/registry_helper"
24
22
  require_relative "dsl/reboot_pending"
25
23
  require_relative "dsl/resources"
26
24
  require_relative "dsl/declare_resource"
@@ -53,8 +51,6 @@ class Chef
53
51
  #
54
52
 
55
53
  include Chef::DSL::DeclareResource
56
- include Chef::DSL::DataQuery
57
- include Chef::DSL::RegistryHelper
58
54
  include Chef::DSL::RebootPending
59
55
  extend Chef::Mixin::Provides
60
56
 
@@ -663,17 +659,17 @@ class Chef
663
659
 
664
660
  all_props = {}
665
661
  self.class.state_properties.map do |p|
666
- begin
667
- all_props[p.name.to_s] = p.sensitive? ? '"*sensitive value suppressed*"' : value_to_text(p.get(self))
668
- rescue Chef::Exceptions::ValidationFailed
669
- # This space left intentionally blank, the property was probably required or had an invalid default.
670
- end
662
+
663
+ all_props[p.name.to_s] = p.sensitive? ? '"*sensitive value suppressed*"' : value_to_text(p.get(self))
664
+ rescue Chef::Exceptions::ValidationFailed
665
+ # This space left intentionally blank, the property was probably required or had an invalid default.
666
+
671
667
  end
672
668
 
673
669
  ivars = instance_variables.map(&:to_sym) - HIDDEN_IVARS
674
670
  ivars.each do |ivar|
675
671
  iv = ivar.to_s.sub(/^@/, "")
676
- if all_props.keys.include?(iv)
672
+ if all_props.key?(iv)
677
673
  text << " #{iv} #{all_props[iv]}\n"
678
674
  elsif (value = instance_variable_get(ivar)) && !(value.respond_to?(:empty?) && value.empty?)
679
675
  text << " #{iv} #{value_to_text(value)}\n"
@@ -192,16 +192,7 @@ class Chef
192
192
  #
193
193
  # @return [Boolean] is the key valid or not
194
194
  def key_is_valid?(key)
195
- valid = true
196
-
197
- so = shell_out("apt-key", "list")
198
- so.stdout.split(/\n/).map do |t|
199
- if t =~ %r{^\/#{key}.*\[expired: .*\]$}
200
- logger.debug "Found expired key: #{t}"
201
- valid = false
202
- break
203
- end
204
- end
195
+ valid = shell_out("apt-key", "list").stdout.each_line.none?(%r{^\/#{key}.*\[expired: .*\]$})
205
196
 
206
197
  logger.debug "key #{key} #{valid ? "is valid" : "is not valid"}"
207
198
  valid
@@ -112,11 +112,11 @@ class Chef
112
112
 
113
113
  action :remove do
114
114
  systemd_unit "#{new_resource.job_name}.service" do
115
- action :remove
115
+ action :delete
116
116
  end
117
117
 
118
118
  systemd_unit "#{new_resource.job_name}.timer" do
119
- action :remove
119
+ action :delete
120
120
  end
121
121
  end
122
122
 
@@ -73,19 +73,19 @@ class Chef
73
73
  description: "The Chef environment of the data if storing per environment values."
74
74
 
75
75
  load_current_value do
76
- begin
77
- item = ChefVault::Item.load(data_bag, id)
78
- raw_data item.raw_data
79
- clients item.get_clients
80
- admins item.get_admins
81
- search item.search
82
- rescue ChefVault::Exceptions::SecretDecryption
83
- current_value_does_not_exist!
84
- rescue ChefVault::Exceptions::KeysNotFound
85
- current_value_does_not_exist!
86
- rescue Net::HTTPClientException => e
87
- current_value_does_not_exist! if e.response_code == "404"
88
- end
76
+
77
+ item = ChefVault::Item.load(data_bag, id)
78
+ raw_data item.raw_data
79
+ clients item.get_clients
80
+ admins item.get_admins
81
+ search item.search
82
+ rescue ChefVault::Exceptions::SecretDecryption
83
+ current_value_does_not_exist!
84
+ rescue ChefVault::Exceptions::KeysNotFound
85
+ current_value_does_not_exist!
86
+ rescue Net::HTTPClientException => e
87
+ current_value_does_not_exist! if e.response_code == "404"
88
+
89
89
  end
90
90
 
91
91
  action :create do