chef 18.5.0 → 18.7.3

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 (241) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +11 -6
  3. data/chef-universal-mingw-ucrt.gemspec +1 -1
  4. data/chef.gemspec +19 -15
  5. data/lib/chef/application/client.rb +0 -12
  6. data/lib/chef/client.rb +1 -10
  7. data/lib/chef/compliance/default_attributes.rb +2 -2
  8. data/lib/chef/compliance/runner.rb +6 -11
  9. data/lib/chef/cookbook/metadata.rb +1 -1
  10. data/lib/chef/cookbook/remote_file_vendor.rb +1 -3
  11. data/lib/chef/cookbook/synchronizer.rb +0 -5
  12. data/lib/chef/event_dispatch/dispatcher.rb +0 -1
  13. data/lib/chef/exceptions.rb +1 -1
  14. data/lib/chef/file_access_control/unix.rb +9 -9
  15. data/lib/chef/file_content_management/deploy.rb +1 -4
  16. data/lib/chef/mixin/file_class.rb +1 -3
  17. data/lib/chef/mixin/get_source_from_package.rb +1 -1
  18. data/lib/chef/mixin/{homebrew_user.rb → homebrew.rb} +13 -16
  19. data/lib/chef/mixin/openssl_helper.rb +1 -12
  20. data/lib/chef/provider/cookbook_file.rb +1 -1
  21. data/lib/chef/provider/cron.rb +1 -1
  22. data/lib/chef/provider/directory.rb +15 -15
  23. data/lib/chef/provider/file.rb +29 -42
  24. data/lib/chef/provider/git.rb +8 -8
  25. data/lib/chef/provider/group/aix.rb +1 -1
  26. data/lib/chef/provider/group/dscl.rb +1 -1
  27. data/lib/chef/provider/group/gpasswd.rb +2 -2
  28. data/lib/chef/provider/group/groupadd.rb +1 -1
  29. data/lib/chef/provider/group/groupmod.rb +2 -2
  30. data/lib/chef/provider/group/pw.rb +2 -2
  31. data/lib/chef/provider/group/solaris.rb +2 -2
  32. data/lib/chef/provider/group/usermod.rb +2 -2
  33. data/lib/chef/provider/group.rb +1 -1
  34. data/lib/chef/provider/http_request.rb +3 -2
  35. data/lib/chef/provider/ifconfig/aix.rb +1 -1
  36. data/lib/chef/provider/ifconfig/debian.rb +3 -3
  37. data/lib/chef/provider/ifconfig/redhat.rb +1 -1
  38. data/lib/chef/provider/ifconfig.rb +1 -1
  39. data/lib/chef/provider/link.rb +10 -10
  40. data/lib/chef/provider/mount/aix.rb +4 -4
  41. data/lib/chef/provider/mount/linux.rb +4 -4
  42. data/lib/chef/provider/mount/mount.rb +11 -11
  43. data/lib/chef/provider/package/apt.rb +11 -2
  44. data/lib/chef/provider/package/bff.rb +3 -3
  45. data/lib/chef/provider/package/chocolatey.rb +2 -2
  46. data/lib/chef/provider/package/dnf/dnf_helper.py +7 -0
  47. data/lib/chef/provider/package/dpkg.rb +3 -3
  48. data/lib/chef/provider/package/freebsd/base.rb +1 -1
  49. data/lib/chef/provider/package/habitat.rb +3 -5
  50. data/lib/chef/provider/package/homebrew.rb +6 -9
  51. data/lib/chef/provider/package/ips.rb +2 -2
  52. data/lib/chef/provider/package/openbsd.rb +2 -3
  53. data/lib/chef/provider/package/pacman.rb +4 -4
  54. data/lib/chef/provider/package/paludis.rb +2 -2
  55. data/lib/chef/provider/package/portage.rb +1 -1
  56. data/lib/chef/provider/package/rpm.rb +2 -2
  57. data/lib/chef/provider/package/rubygems.rb +4 -0
  58. data/lib/chef/provider/package/smartos.rb +2 -2
  59. data/lib/chef/provider/package/snap.rb +2 -2
  60. data/lib/chef/provider/package/solaris.rb +4 -4
  61. data/lib/chef/provider/package/zypper.rb +4 -4
  62. data/lib/chef/provider/package.rb +1 -1
  63. data/lib/chef/provider/registry_key.rb +6 -0
  64. data/lib/chef/provider/remote_directory.rb +5 -5
  65. data/lib/chef/provider/remote_file/http.rb +3 -2
  66. data/lib/chef/provider/remote_file.rb +1 -1
  67. data/lib/chef/provider/route.rb +9 -9
  68. data/lib/chef/provider/service/aix.rb +1 -1
  69. data/lib/chef/provider/service/aixinit.rb +4 -4
  70. data/lib/chef/provider/service/arch.rb +6 -6
  71. data/lib/chef/provider/service/debian.rb +5 -5
  72. data/lib/chef/provider/service/freebsd.rb +7 -7
  73. data/lib/chef/provider/service/gentoo.rb +5 -5
  74. data/lib/chef/provider/service/init.rb +2 -2
  75. data/lib/chef/provider/service/insserv.rb +2 -2
  76. data/lib/chef/provider/service/invokercd.rb +1 -1
  77. data/lib/chef/provider/service/openbsd.rb +7 -7
  78. data/lib/chef/provider/service/redhat.rb +3 -3
  79. data/lib/chef/provider/service/solaris.rb +2 -2
  80. data/lib/chef/provider/service/systemd.rb +2 -2
  81. data/lib/chef/provider/service/upstart.rb +2 -2
  82. data/lib/chef/provider/subversion.rb +8 -8
  83. data/lib/chef/provider/systemd_unit.rb +3 -3
  84. data/lib/chef/provider/template.rb +1 -1
  85. data/lib/chef/provider/user/aix.rb +3 -3
  86. data/lib/chef/provider/user/linux.rb +2 -7
  87. data/lib/chef/provider/user/pw.rb +3 -3
  88. data/lib/chef/provider/user/solaris.rb +7 -7
  89. data/lib/chef/provider/user/windows.rb +5 -0
  90. data/lib/chef/provider/user.rb +8 -7
  91. data/lib/chef/provider/yum_repository.rb +3 -1
  92. data/lib/chef/provider/zypper_repository.rb +1 -1
  93. data/lib/chef/providers.rb +0 -1
  94. data/lib/chef/resource/alternatives.rb +2 -2
  95. data/lib/chef/resource/apt_preference.rb +1 -1
  96. data/lib/chef/resource/apt_repository.rb +90 -15
  97. data/lib/chef/resource/apt_update.rb +3 -3
  98. data/lib/chef/resource/bff_package.rb +1 -1
  99. data/lib/chef/resource/chef_client_config.rb +3 -2
  100. data/lib/chef/resource/chef_sleep.rb +1 -1
  101. data/lib/chef/resource/cookbook_file.rb +1 -1
  102. data/lib/chef/resource/cron/cron.rb +1 -1
  103. data/lib/chef/resource/cron/cron_d.rb +1 -1
  104. data/lib/chef/resource/cron_access.rb +1 -1
  105. data/lib/chef/resource/directory.rb +1 -1
  106. data/lib/chef/resource/dpkg_package.rb +1 -1
  107. data/lib/chef/resource/file/verification/json.rb +1 -1
  108. data/lib/chef/resource/file/verification/systemd_unit.rb +1 -1
  109. data/lib/chef/resource/file/verification/yaml.rb +1 -1
  110. data/lib/chef/resource/file.rb +1 -1
  111. data/lib/chef/resource/freebsd_package.rb +2 -2
  112. data/lib/chef/resource/group.rb +1 -1
  113. data/lib/chef/resource/habitat/habitat_package.rb +1 -1
  114. data/lib/chef/resource/habitat/habitat_sup.rb +9 -9
  115. data/lib/chef/resource/habitat/habitat_sup_systemd.rb +2 -2
  116. data/lib/chef/resource/habitat_install.rb +3 -3
  117. data/lib/chef/resource/homebrew_cask.rb +19 -30
  118. data/lib/chef/resource/homebrew_tap.rb +32 -17
  119. data/lib/chef/resource/homebrew_update.rb +4 -4
  120. data/lib/chef/resource/hostname.rb +10 -11
  121. data/lib/chef/resource/http_request.rb +1 -1
  122. data/lib/chef/resource/ifconfig.rb +1 -1
  123. data/lib/chef/resource/inspec_input.rb +1 -3
  124. data/lib/chef/resource/inspec_waiver.rb +1 -1
  125. data/lib/chef/resource/inspec_waiver_file_entry.rb +1 -1
  126. data/lib/chef/resource/ips_package.rb +2 -2
  127. data/lib/chef/resource/kernel_module.rb +2 -2
  128. data/lib/chef/resource/link.rb +1 -1
  129. data/lib/chef/resource/locale.rb +2 -2
  130. data/lib/chef/resource/mount.rb +1 -1
  131. data/lib/chef/resource/notify_group.rb +1 -1
  132. data/lib/chef/resource/ohai.rb +1 -1
  133. data/lib/chef/resource/ohai_hint.rb +1 -1
  134. data/lib/chef/resource/openbsd_package.rb +2 -2
  135. data/lib/chef/resource/package.rb +1 -1
  136. data/lib/chef/resource/pacman_package.rb +1 -1
  137. data/lib/chef/resource/paludis_package.rb +1 -1
  138. data/lib/chef/resource/portage_package.rb +1 -1
  139. data/lib/chef/resource/reboot.rb +1 -1
  140. data/lib/chef/resource/registry_key.rb +18 -0
  141. data/lib/chef/resource/remote_directory.rb +1 -1
  142. data/lib/chef/resource/remote_file.rb +1 -1
  143. data/lib/chef/resource/rhsm_errata.rb +1 -1
  144. data/lib/chef/resource/rhsm_errata_level.rb +1 -1
  145. data/lib/chef/resource/rhsm_register.rb +1 -1
  146. data/lib/chef/resource/rhsm_repo.rb +4 -3
  147. data/lib/chef/resource/rhsm_subscription.rb +9 -8
  148. data/lib/chef/resource/route.rb +1 -1
  149. data/lib/chef/resource/rpm_package.rb +1 -1
  150. data/lib/chef/resource/scm/git.rb +1 -1
  151. data/lib/chef/resource/scm/subversion.rb +1 -1
  152. data/lib/chef/resource/selinux/common_helpers.rb +1 -1
  153. data/lib/chef/resource/selinux_boolean.rb +1 -1
  154. data/lib/chef/resource/selinux_fcontext.rb +3 -3
  155. data/lib/chef/resource/selinux_install.rb +1 -1
  156. data/lib/chef/resource/selinux_login.rb +1 -1
  157. data/lib/chef/resource/selinux_module.rb +5 -5
  158. data/lib/chef/resource/selinux_permissive.rb +2 -2
  159. data/lib/chef/resource/selinux_port.rb +2 -2
  160. data/lib/chef/resource/selinux_state.rb +2 -2
  161. data/lib/chef/resource/selinux_user.rb +1 -1
  162. data/lib/chef/resource/smartos_package.rb +2 -2
  163. data/lib/chef/resource/snap_package.rb +1 -1
  164. data/lib/chef/resource/solaris_package.rb +1 -1
  165. data/lib/chef/resource/ssh_known_hosts_entry.rb +1 -1
  166. data/lib/chef/resource/sudo.rb +5 -5
  167. data/lib/chef/resource/support/client.erb +3 -2
  168. data/lib/chef/resource/swap_file.rb +6 -6
  169. data/lib/chef/resource/sysctl.rb +5 -5
  170. data/lib/chef/resource/systemd_unit.rb +1 -1
  171. data/lib/chef/resource/template.rb +1 -1
  172. data/lib/chef/resource/timezone.rb +5 -5
  173. data/lib/chef/resource/user/aix_user.rb +2 -2
  174. data/lib/chef/resource/user/linux_user.rb +2 -2
  175. data/lib/chef/resource/user/pw_user.rb +2 -2
  176. data/lib/chef/resource/user/solaris_user.rb +2 -2
  177. data/lib/chef/resource/user_ulimit.rb +1 -1
  178. data/lib/chef/resource/yum_repository.rb +1 -1
  179. data/lib/chef/resource/zypper_package.rb +2 -2
  180. data/lib/chef/resource/zypper_repository.rb +2 -2
  181. data/lib/chef/resource.rb +1 -0
  182. data/lib/chef/resource_inspector.rb +25 -7
  183. data/lib/chef/resource_reporter.rb +1 -0
  184. data/lib/chef/run_lock.rb +0 -3
  185. data/lib/chef/scan_access_control.rb +6 -6
  186. data/lib/chef/util/backup.rb +1 -1
  187. data/lib/chef/util/diff.rb +1 -14
  188. data/lib/chef/util/file_edit.rb +4 -4
  189. data/lib/chef/util/powershell/ps_credential.rb +10 -0
  190. data/lib/chef/version.rb +1 -1
  191. data/lib/chef/win32/registry.rb +5 -1
  192. data/lib/chef/win32/security.rb +9 -0
  193. data/lib/chef.rb +0 -2
  194. data/spec/functional/assets/yumrepo-empty/repodata/repomd.xml +6 -6
  195. data/spec/functional/resource/cookbook_file_spec.rb +1 -1
  196. data/spec/functional/resource/registry_spec.rb +276 -609
  197. data/spec/integration/client/open_ssl_spec.rb +1 -1
  198. data/spec/spec_helper.rb +1 -0
  199. data/spec/support/chef_helpers.rb +2 -2
  200. data/spec/support/platform_helpers.rb +8 -0
  201. data/spec/support/shared/functional/file_resource.rb +3 -3
  202. data/spec/tiny_server.rb +5 -2
  203. data/spec/unit/mixin/homebrew_spec.rb +118 -0
  204. data/spec/unit/provider/apt_repository_spec.rb +14 -9
  205. data/spec/unit/provider/package/chocolatey_spec.rb +1 -1
  206. data/spec/unit/provider/package/homebrew_spec.rb +4 -1
  207. data/spec/unit/provider/registry_key_spec.rb +18 -17
  208. data/spec/unit/provider/route_spec.rb +4 -6
  209. data/spec/unit/provider/user/windows_spec.rb +1 -0
  210. data/spec/unit/resource/rhsm_repo_spec.rb +0 -1
  211. data/spec/unit/resource/rhsm_subscription_spec.rb +0 -2
  212. data/spec/unit/resource_inspector_spec.rb +36 -0
  213. data/spec/unit/util/powershell/ps_credential_spec.rb +6 -0
  214. metadata +36 -44
  215. data/lib/chef/file_content_management/deploy/target_io.rb +0 -29
  216. data/lib/chef/provider/.gitkeep +0 -0
  217. data/lib/chef/provider/package/snap_tm.rb +0 -79
  218. data/lib/chef/resource/.gitkeep +0 -0
  219. data/lib/chef/target_io/dir.rb +0 -12
  220. data/lib/chef/target_io/etc.rb +0 -16
  221. data/lib/chef/target_io/file.rb +0 -12
  222. data/lib/chef/target_io/fileutils.rb +0 -12
  223. data/lib/chef/target_io/http.rb +0 -22
  224. data/lib/chef/target_io/io.rb +0 -12
  225. data/lib/chef/target_io/shadow.rb +0 -44
  226. data/lib/chef/target_io/train/dir.rb +0 -69
  227. data/lib/chef/target_io/train/etc.rb +0 -112
  228. data/lib/chef/target_io/train/file.rb +0 -219
  229. data/lib/chef/target_io/train/fileutils.rb +0 -220
  230. data/lib/chef/target_io/train/http.rb +0 -117
  231. data/lib/chef/target_io/train/io.rb +0 -13
  232. data/lib/chef/target_io/train/shadow.rb +0 -52
  233. data/lib/chef/target_io/train_compat.rb +0 -7
  234. data/lib/chef/target_io.rb +0 -9
  235. data/spec/unit/mixin/homebrew_user_spec.rb +0 -119
  236. /data/spec/functional/assets/yumrepo-empty/repodata/{01a3b489a465bcac22a43492163df43451dc6ce47d27f66de289756b91635523-filelists.sqlite.bz2 → 01a3b-filelists.sqlite.bz2} +0 -0
  237. /data/spec/functional/assets/yumrepo-empty/repodata/{401dc19bda88c82c403423fb835844d64345f7e95f5b9835888189c03834cc93-filelists.xml.gz → 401dc-filelists.xml.gz} +0 -0
  238. /data/spec/functional/assets/yumrepo-empty/repodata/{5dc1e6e73c84803f059bb3065e684e56adfc289a7e398946574d79dac6643945-primary.sqlite.bz2 → 5dc1e-primary.sqlite.bz2} +0 -0
  239. /data/spec/functional/assets/yumrepo-empty/repodata/{6bf9672d0862e8ef8b8ff05a2fd0208a922b1f5978e6589d87944c88259cb670-other.xml.gz → 6bf96-other.xml.gz} +0 -0
  240. /data/spec/functional/assets/yumrepo-empty/repodata/{7c36572015e075add2b38b900837bcdbb8a504130ddff49b2351a7fc0affa3d4-other.sqlite.bz2 → 7c365-other.sqlite.bz2} +0 -0
  241. /data/spec/functional/assets/yumrepo-empty/repodata/{dabe2ce5481d23de1f4f52bdcfee0f9af98316c9e0de2ce8123adeefa0dd08b9-primary.xml.gz → dabe2-primary.xml.gz} +0 -0
@@ -36,7 +36,7 @@ class Chef
36
36
 
37
37
  def convert_group_name
38
38
  if new_resource.gid.is_a?(String) && new_resource.gid.to_i == 0
39
- new_resource.gid(TargetIO::Etc.getgrnam(new_resource.gid).gid)
39
+ new_resource.gid(Etc.getgrnam(new_resource.gid).gid)
40
40
  end
41
41
  rescue ArgumentError
42
42
  @group_name_resolved = false
@@ -47,7 +47,7 @@ class Chef
47
47
  current_resource.username(new_resource.username)
48
48
 
49
49
  begin
50
- user_info = TargetIO::Etc.getpwnam(new_resource.username)
50
+ user_info = Etc.getpwnam(new_resource.username)
51
51
  rescue ArgumentError
52
52
  @user_exists = false
53
53
  logger.trace("#{new_resource} user does not exist")
@@ -68,13 +68,10 @@ class Chef
68
68
 
69
69
  begin
70
70
  require "shadow"
71
-
72
- # Cannot use this library remotely
73
- @shadow_lib_ok = false if ChefConfig::Config.target_mode?
74
71
  rescue LoadError
75
72
  @shadow_lib_ok = false
76
73
  else
77
- @shadow_info = TargetIO::Shadow::Passwd.getspnam(new_resource.username)
74
+ @shadow_info = Shadow::Passwd.getspnam(new_resource.username)
78
75
  # This conditional remains in place until we can sort out whether we need it.
79
76
  # Currently removing it causes tests to fail, but that /seems/ to be mocking/setup issues.
80
77
  # Some notes for context:
@@ -156,7 +153,11 @@ class Chef
156
153
  new_val = new_resource.send(user_attrib)
157
154
  cur_val = current_resource.send(user_attrib)
158
155
  if !new_val.nil? && new_val.to_s != cur_val.to_s
159
- @change_desc << "change #{user_attrib} from #{cur_val} to #{new_val}"
156
+ if user_attrib.to_s == "password" && new_resource.sensitive
157
+ @change_desc << "change #{user_attrib} from ******** to ********"
158
+ else
159
+ @change_desc << "change #{user_attrib} from #{cur_val} to #{new_val}"
160
+ end
160
161
  end
161
162
  end
162
163
 
@@ -25,7 +25,9 @@ class Chef
25
25
  class YumRepository < Chef::Provider
26
26
  extend Chef::Mixin::Which
27
27
 
28
- provides(:yum_repository, target_mode: true) { which "yum" }
28
+ provides :yum_repository do
29
+ which "yum"
30
+ end
29
31
 
30
32
  def load_current_resource; end
31
33
 
@@ -25,7 +25,7 @@ require "chef-utils/dist" unless defined?(ChefUtils::Dist)
25
25
  class Chef
26
26
  class Provider
27
27
  class ZypperRepository < Chef::Provider
28
- provides :zypper_repository, platform_family: "suse", target_mode: true
28
+ provides :zypper_repository, platform_family: "suse"
29
29
 
30
30
  def load_current_resource; end
31
31
 
@@ -74,7 +74,6 @@ require_relative "provider/package/cab"
74
74
  require_relative "provider/package/powershell"
75
75
  require_relative "provider/package/msu"
76
76
  require_relative "provider/package/snap"
77
- require_relative "provider/package/snap_tm"
78
77
  require_relative "provider/package/habitat"
79
78
 
80
79
  require_relative "provider/service/arch"
@@ -23,7 +23,7 @@ class Chef
23
23
  class Resource
24
24
  class Alternatives < Chef::Resource
25
25
 
26
- provides(:alternatives, target_mode: true) { true }
26
+ provides(:alternatives) { true }
27
27
 
28
28
  description "Use the **alternatives** resource to configure command alternatives in Linux using the alternatives or update-alternatives packages."
29
29
  introduced "16.0"
@@ -113,7 +113,7 @@ class Chef
113
113
 
114
114
  requirements.assert(:install, :set, :remove) do |a|
115
115
  a.assertion do
116
- ::TargetIO::File.exist?(new_resource.path)
116
+ ::File.exist?(new_resource.path)
117
117
  end
118
118
 
119
119
  a.whyrun("Assuming file #{new_resource.path} already exists or was created already")
@@ -22,7 +22,7 @@ class Chef
22
22
  class Resource
23
23
  class AptPreference < Chef::Resource
24
24
 
25
- provides(:apt_preference, target_mode: true) { true }
25
+ provides(:apt_preference) { true }
26
26
 
27
27
  description "Use the **apt_preference** resource to create APT [preference files](https://wiki.debian.org/AptPreferences). Preference files are used to control which package versions and sources are prioritized during installation."
28
28
  introduced "13.3"
@@ -17,6 +17,7 @@
17
17
  #
18
18
 
19
19
  require_relative "../resource"
20
+ require_relative "../http/simple"
20
21
  require "tmpdir" unless defined?(Dir.mktmpdir)
21
22
  module Addressable
22
23
  autoload :URI, "addressable/uri"
@@ -26,7 +27,7 @@ class Chef
26
27
  class Resource
27
28
  class AptRepository < Chef::Resource
28
29
 
29
- provides(:apt_repository, target_mode: true) { true }
30
+ provides(:apt_repository) { true }
30
31
 
31
32
  description "Use the **apt_repository** resource to specify additional APT repositories. Adding a new repository will update the APT package cache immediately."
32
33
  introduced "12.9"
@@ -98,6 +99,7 @@ class Chef
98
99
  ```
99
100
 
100
101
  **Add repository that needs custom options**:
102
+
101
103
  ```ruby
102
104
  apt_repository 'corretto' do
103
105
  uri 'https://apt.corretto.aws'
@@ -162,6 +164,10 @@ class Chef
162
164
  property :key_proxy, [String, nil, FalseClass],
163
165
  description: "If set, a specified proxy is passed to GPG via `http-proxy=`."
164
166
 
167
+ property :signed_by, [String, true, false, nil],
168
+ description: "If a string, specify the file and/or fingerprint the repo is signed with. If true, set Signed-With to use the specified key",
169
+ default: true
170
+
165
171
  property :cookbook, [String, nil, FalseClass],
166
172
  description: "If key should be a cookbook_file, specify a cookbook where the key is located for files/default. Default value is nil, so it will use the cookbook where the resource is used.",
167
173
  desired_state: false
@@ -171,7 +177,7 @@ class Chef
171
177
  default: true, desired_state: false
172
178
 
173
179
  property :options, [String, Array],
174
- description: "Additional options to set for the repository",
180
+ description: "Additional options to set for the repository.",
175
181
  default: [], coerce: proc { |x| Array(x) }
176
182
 
177
183
  default_action :add
@@ -231,6 +237,17 @@ class Chef
231
237
  valid
232
238
  end
233
239
 
240
+ # validate the key against the a gpg keyring to see if that version is expired
241
+ # @param [String] key
242
+ #
243
+ # @return [Boolean] is the key valid or not
244
+ def keyring_key_is_valid?(keyring, key)
245
+ valid = shell_out("gpg", "--no-default-keyring", "--keyring", keyring, "--list-public-keys", key).stdout.each_line.none?(/\[(expired|revoked):/)
246
+
247
+ logger.debug "key #{key} #{valid ? "is valid" : "is not valid"}"
248
+ valid
249
+ end
250
+
234
251
  # return the specified cookbook name or the cookbook containing the
235
252
  # resource.
236
253
  #
@@ -277,6 +294,10 @@ class Chef
277
294
  end
278
295
  end
279
296
 
297
+ def keyring_path
298
+ "/etc/apt/keyrings/#{new_resource.repo_name}.gpg"
299
+ end
300
+
280
301
  # Fetch the key using either cookbook_file or remote_file, validate it,
281
302
  # and install it with apt-key add
282
303
  # @param [String] key the key to install
@@ -286,11 +307,19 @@ class Chef
286
307
  # @return [void]
287
308
  def install_key_from_uri(key)
288
309
  key_name = key.gsub(/[^0-9A-Za-z\-]/, "_")
289
- cached_keyfile = ::File.join(Chef::Config[:file_cache_path], key_name)
310
+ keyfile_path = ::File.join(Chef::Config[:file_cache_path], key_name)
290
311
  tmp_dir = TargetIO::Dir.mktmpdir(".gpg")
291
312
  at_exit { TargetIO::FileUtils.remove_entry(tmp_dir) }
292
313
 
293
- declare_resource(key_type(key), cached_keyfile) do
314
+ if new_resource.signed_by
315
+ keyfile_path = keyring_path
316
+
317
+ directory "/etc/apt/keyrings" do
318
+ mode "0755"
319
+ end
320
+ end
321
+
322
+ declare_resource(key_type(key), keyfile_path) do
294
323
  source key
295
324
  mode "0644"
296
325
  sensitive new_resource.sensitive
@@ -298,13 +327,17 @@ class Chef
298
327
  verify "gpg --homedir #{tmp_dir} %{path}"
299
328
  end
300
329
 
301
- execute "apt-key add #{cached_keyfile}" do
302
- command [ "apt-key", "add", cached_keyfile ]
303
- default_env true
304
- sensitive new_resource.sensitive
305
- action :run
306
- not_if { no_new_keys?(cached_keyfile) }
307
- notifies :run, "execute[apt-cache gencaches]", :immediately
330
+ # If signed by is true, then we don't need to
331
+ # add to the default keyring
332
+ unless new_resource.signed_by
333
+ execute "apt-key add #{keyfile_path}" do
334
+ command [ "apt-key", "add", keyfile_path ]
335
+ default_env true
336
+ sensitive new_resource.sensitive
337
+ action :run
338
+ not_if { no_new_keys?(keyfile_path) }
339
+ notifies :run, "execute[apt-cache gencaches]", :immediately
340
+ end
308
341
  end
309
342
  end
310
343
 
@@ -334,6 +367,10 @@ class Chef
334
367
  #
335
368
  # @return [void]
336
369
  def install_key_from_keyserver(key, keyserver = new_resource.keyserver)
370
+ if new_resource.signed_by
371
+ install_key_from_keyserver_to_keyring(key, keyserver, keyring_path)
372
+ return
373
+ end
337
374
  execute "install-key #{key}" do
338
375
  command keyserver_install_cmd(key, keyserver)
339
376
  default_env true
@@ -350,6 +387,31 @@ class Chef
350
387
  raise "The key #{key} is invalid and cannot be used to verify an apt repository." unless key_is_valid?(key.upcase)
351
388
  end
352
389
 
390
+ # @param [String] key
391
+ # @param [String] keyserver
392
+ # @param [String] keyring
393
+ def install_key_from_keyserver_to_keyring(key, keyserver, keyring)
394
+ keyserver = "hkp://#{keyserver}:80" unless keyserver.start_with?("hkp://")
395
+
396
+ cmd = "gpg --no-default-keyring --keyring #{keyring}"
397
+ cmd << " --keyserver-options http-proxy=#{new_resource.key_proxy}" if new_resource.key_proxy
398
+ cmd << " --keyserver #{keyserver}"
399
+ cmd << " --recv #{key}"
400
+
401
+ execute "install-key #{key}" do
402
+ command cmd
403
+ default_env true
404
+ sensitive new_resource.sensitive
405
+ not_if do
406
+ present = shell_out(*%W{gpg --no-default-keyring --keyring #{keyring} --list-public-keys --with-fingerprint --with-colons #{key}}).exitstatus != 0
407
+ present && keyring_key_is_valid?(keyring, key.upcase)
408
+ end
409
+ notifies :run, "execute[apt-cache gencaches]", :immediately
410
+ end
411
+
412
+ raise "The key #{key} is invalid and cannot be used to verify an apt repository." unless keyring_key_is_valid?(keyring, key.upcase)
413
+ end
414
+
353
415
  # @param [String] owner
354
416
  # @param [String] repo
355
417
  #
@@ -358,7 +420,7 @@ class Chef
358
420
  # @return [void]
359
421
  def install_ppa_key(owner, repo)
360
422
  url = "https://launchpad.net/api/1.0/~#{owner}/+archive/#{repo}"
361
- key_id = TargetIO::HTTP.new(url).get("signing_key_fingerprint").delete('"')
423
+ key_id = Chef::HTTP::Simple.new(url).get("signing_key_fingerprint").delete('"')
362
424
  install_key_from_keyserver(key_id, "keyserver.ubuntu.com")
363
425
  rescue Net::HTTPClientException => e
364
426
  raise "Could not access Launchpad ppa API: #{e.message}"
@@ -403,11 +465,12 @@ class Chef
403
465
  # @param [Array] components
404
466
  # @param [Boolean] trusted
405
467
  # @param [String] arch
468
+ # @param [String] signed_by
406
469
  # @param [Array] options
407
470
  # @param [Boolean] add_src
408
471
  #
409
472
  # @return [String] complete repo config text
410
- def build_repo(uri, distribution, components, trusted, arch, options, add_src = false)
473
+ def build_repo(uri, distribution, components, trusted, arch, signed_by, options, add_src = false)
411
474
  uri = make_ppa_url(uri) if is_ppa_url?(uri)
412
475
 
413
476
  uri = Addressable::URI.parse(uri)
@@ -415,6 +478,7 @@ class Chef
415
478
  options_list = []
416
479
  options_list << "arch=#{arch}" if arch
417
480
  options_list << "trusted=yes" if trusted
481
+ options_list << "signed-by=#{signed_by}" if signed_by
418
482
  options_list += options
419
483
  optstr = unless options_list.empty?
420
484
  "[" + options_list.join(" ") + "]"
@@ -432,7 +496,7 @@ class Chef
432
496
  # @return [void]
433
497
  def cleanup_legacy_file!
434
498
  legacy_path = "/etc/apt/sources.list.d/#{new_resource.name}.list"
435
- if new_resource.name != new_resource.repo_name && ::TargetIO::File.exist?(legacy_path)
499
+ if new_resource.name != new_resource.repo_name && ::File.exist?(legacy_path)
436
500
  converge_by "Cleaning up legacy #{legacy_path} repo file" do
437
501
  file legacy_path do
438
502
  action :delete
@@ -472,12 +536,18 @@ class Chef
472
536
 
473
537
  cleanup_legacy_file!
474
538
 
539
+ signed_by = new_resource.signed_by
540
+ if signed_by == true
541
+ signed_by = keyring_path
542
+ end
543
+
475
544
  repo = build_repo(
476
545
  new_resource.uri,
477
546
  new_resource.distribution,
478
547
  repo_components,
479
548
  new_resource.trusted,
480
549
  new_resource.arch,
550
+ signed_by,
481
551
  new_resource.options,
482
552
  new_resource.deb_src
483
553
  )
@@ -498,13 +568,18 @@ class Chef
498
568
  return unless debian?
499
569
 
500
570
  cleanup_legacy_file!
501
- if ::TargetIO::File.exist?("/etc/apt/sources.list.d/#{new_resource.repo_name}.list")
571
+ if ::File.exist?("/etc/apt/sources.list.d/#{new_resource.repo_name}.list")
502
572
  converge_by "Removing #{new_resource.repo_name} repository from /etc/apt/sources.list.d/" do
503
573
  apt_update new_resource.name do
504
574
  ignore_failure true
505
575
  action :nothing
506
576
  end
507
577
 
578
+ file keyring_path do
579
+ sensitive new_resource.sensitive
580
+ action :delete
581
+ end
582
+
508
583
  file "/etc/apt/sources.list.d/#{new_resource.repo_name}.list" do
509
584
  sensitive new_resource.sensitive
510
585
  action :delete
@@ -23,7 +23,7 @@ class Chef
23
23
  class Resource
24
24
  class AptUpdate < Chef::Resource
25
25
 
26
- provides(:apt_update, target_mode: true) { true }
26
+ provides(:apt_update) { true }
27
27
 
28
28
  description "Use the **apt_update** resource to manage APT repository updates on Debian and Ubuntu platforms."
29
29
  introduced "12.7"
@@ -62,8 +62,8 @@ class Chef
62
62
  #
63
63
  # @return [Boolean]
64
64
  def apt_up_to_date?
65
- ::TargetIO::File.exist?("#{STAMP_DIR}/update-success-stamp") &&
66
- ::TargetIO::File.mtime("#{STAMP_DIR}/update-success-stamp") > Time.now - new_resource.frequency
65
+ ::File.exist?("#{STAMP_DIR}/update-success-stamp") &&
66
+ ::File.mtime("#{STAMP_DIR}/update-success-stamp") > Time.now - new_resource.frequency
67
67
  end
68
68
 
69
69
  def do_update
@@ -23,7 +23,7 @@ class Chef
23
23
  class Resource
24
24
  class BffPackage < Chef::Resource::Package
25
25
 
26
- provides :bff_package, target_mode: true
26
+ provides :bff_package
27
27
 
28
28
  description "Use the **bff_package** resource to manage packages for the AIX platform using the installp utility. When a package is installed from a local file, it must be added to the node using the **remote_file** or **cookbook_file** resources."
29
29
  introduced "12.0"
@@ -21,7 +21,7 @@ class Chef
21
21
  class Resource
22
22
  class ChefClientConfig < Chef::Resource
23
23
 
24
- provides :chef_client_config, target_mode: true
24
+ provides :chef_client_config
25
25
 
26
26
  description "Use the **chef_client_config** resource to create a client.rb file in the #{ChefUtils::Dist::Infra::PRODUCT} configuration directory. See the [client.rb docs](https://docs.chef.io/config_rb_client/) for more details on options available in the client.rb configuration file."
27
27
  introduced "16.6"
@@ -195,7 +195,8 @@ class Chef
195
195
 
196
196
  property :policy_persist_run_list, [true, false],
197
197
  description: "Override run lists defined in a Policyfile with the `run_list` defined on the #{ChefUtils::Dist::Server::PRODUCT}.",
198
- introduced: "17.3"
198
+ introduced: "17.3",
199
+ default: false
199
200
 
200
201
  property :minimal_ohai, [true, false],
201
202
  description: "Run a minimal set of Ohai plugins providing data necessary for the execution of #{ChefUtils::Dist::Infra::PRODUCT}'s built-in resources. Setting this to true will skip many large and time consuming data sets such as `cloud` or `packages`. Setting this to true may break cookbooks that assume all Ohai data will be present.",
@@ -20,7 +20,7 @@ require "chef-utils/dist" unless defined?(ChefUtils::Dist)
20
20
  class Chef
21
21
  class Resource
22
22
  class ChefSleep < Chef::Resource
23
- provides :chef_sleep, target_mode: true
23
+ provides :chef_sleep
24
24
 
25
25
  description "Use the **chef_sleep** resource to pause (sleep) for a number of seconds during a #{ChefUtils::Dist::Infra::PRODUCT} run. Only use this resource when a command or service exits successfully but is not ready for the next step in a recipe."
26
26
  introduced "15.5"
@@ -28,7 +28,7 @@ class Chef
28
28
  class CookbookFile < Chef::Resource::File
29
29
  include Chef::Mixin::Securable
30
30
 
31
- provides :cookbook_file, target_mode: true
31
+ provides :cookbook_file
32
32
 
33
33
  description "Use the **cookbook_file** resource to transfer files from a sub-directory of COOKBOOK_NAME/files/ to a specified path located on a host that is running the #{ChefUtils::Dist::Infra::PRODUCT}. The file is selected according to file specificity, which allows different source files to be used based on the hostname, host platform (operating system, distro, or as appropriate), or platform version. Files that are located in the COOKBOOK_NAME/files/default sub-directory may be used on any platform.\n\nDuring a #{ChefUtils::Dist::Infra::PRODUCT} run, the checksum for each local file is calculated and then compared against the checksum for the same file as it currently exists in the cookbook on the #{ChefUtils::Dist::Server::PRODUCT}. A file is not transferred when the checksums match. Only files that require an update are transferred from the #{ChefUtils::Dist::Server::PRODUCT} to a node."
34
34
 
@@ -28,7 +28,7 @@ class Chef
28
28
 
29
29
  use "cron_shared"
30
30
 
31
- provides :cron, target_mode: true
31
+ provides :cron
32
32
 
33
33
  description "Use the **cron** resource to manage cron entries for time-based job scheduling. Properties for a schedule will default to * if not provided. The cron resource requires access to a crontab program, typically cron. Warning: The cron resource should only be used to modify an entry in a crontab file. The `cron_d` resource directly manages `cron.d` files. This resource ships in #{ChefUtils::Dist::Infra::PRODUCT} 14.4 or later and can also be found in the [cron](https://github.com/chef-cookbooks/cron) cookbook) for previous #{ChefUtils::Dist::Infra::PRODUCT} releases."
34
34
 
@@ -26,7 +26,7 @@ class Chef
26
26
 
27
27
  use "cron_shared"
28
28
 
29
- provides :cron_d, target_mode: true
29
+ provides :cron_d
30
30
 
31
31
  introduced "14.4"
32
32
  description "Use the **cron_d** resource to manage cron job files in the `/etc/cron.d` directory. Warning: #{ChefUtils::Dist::Infra::PRODUCT} also ships with the **cron** resource for managing the monolithic `/etc/crontab` file on platforms that lack cron.d support. See the [cron resource](/resources/cron/) for information on using that resource."
@@ -23,7 +23,7 @@ require_relative "../resource"
23
23
  class Chef
24
24
  class Resource
25
25
  class CronAccess < Chef::Resource
26
- provides :cron_access, target_mode: true
26
+ provides :cron_access
27
27
  provides(:cron_manage) # legacy name @todo in Chef 15 we should { true } this so it wins over the cookbook
28
28
 
29
29
  introduced "14.4"
@@ -25,7 +25,7 @@ class Chef
25
25
  class Resource
26
26
  class Directory < Chef::Resource
27
27
 
28
- provides :directory, target_mode: true
28
+ provides :directory
29
29
 
30
30
  description "Use the **directory** resource to manage a directory, which is a hierarchy"\
31
31
  " of folders that comprises all of the information stored on a computer."\
@@ -22,7 +22,7 @@ class Chef
22
22
  class Resource
23
23
  class DpkgPackage < Chef::Resource::Package
24
24
 
25
- provides :dpkg_package, target_mode: true
25
+ provides :dpkg_package
26
26
 
27
27
  description "Use the **dpkg_package** resource to manage packages for the dpkg platform. When a package is installed from a local file, it must be added to the node using the **remote_file** or **cookbook_file** resources."
28
28
 
@@ -37,7 +37,7 @@ class Chef
37
37
  provides :json
38
38
 
39
39
  def verify(path, opts = {})
40
- Chef::JSONCompat.parse(TargetIO::IO.read(path))
40
+ Chef::JSONCompat.parse(IO.read(path))
41
41
  true
42
42
  rescue Chef::Exceptions::JSON::ParseError => e
43
43
  Chef::Log.error("Json syntax verify failed with : #{e.message}")
@@ -49,7 +49,7 @@ class Chef
49
49
 
50
50
  Dir.mktmpdir("chef-systemd-unit") do |dir|
51
51
  temp = "#{dir}/#{::File.basename(@parent_resource.path)}"
52
- ::TargetIO::FileUtils.cp(path, temp)
52
+ ::FileUtils.cp(path, temp)
53
53
  verify_command(temp, opts)
54
54
  end
55
55
  end
@@ -39,7 +39,7 @@ class Chef
39
39
  provides :yaml
40
40
 
41
41
  def verify(path, opts = {})
42
- Psych.parse(TargetIO::IO.read(path))
42
+ Psych.parse_file(path)
43
43
  true
44
44
  rescue Psych::SyntaxError => e
45
45
  Chef::Log.error("Yaml syntax verify failed with : #{e.message}")
@@ -29,7 +29,7 @@ class Chef
29
29
  class File < Chef::Resource
30
30
  include Chef::Mixin::Securable
31
31
 
32
- provides :file, target_mode: true
32
+ provides :file
33
33
 
34
34
  description "Use the **file** resource to manage files directly on a node. Note: Use the **cookbook_file** resource to copy a file from a cookbook's `/files` directory. Use the **template** resource to create a file based on a template in a cookbook's `/templates` directory. And use the **remote_file** resource to transfer a file to a node from a remote location."
35
35
 
@@ -25,8 +25,8 @@ require_relative "../provider/package/freebsd/pkgng"
25
25
  class Chef
26
26
  class Resource
27
27
  class FreebsdPackage < Chef::Resource::Package
28
- provides :freebsd_package, target_mode: true
29
- provides :package, platform: "freebsd", target_mode: true
28
+ provides :freebsd_package
29
+ provides :package, platform: "freebsd"
30
30
 
31
31
  description "Use the **freebsd_package** resource to manage packages for the FreeBSD platform."
32
32
 
@@ -48,7 +48,7 @@ class Chef
48
48
  ```
49
49
  EXAMPLES
50
50
 
51
- provides :group, target_mode: true
51
+ provides :group
52
52
 
53
53
  allowed_actions :create, :remove, :modify, :manage
54
54
  default_action :create
@@ -22,7 +22,7 @@ class Chef
22
22
  class Resource
23
23
  class HabitatPackage < Chef::Resource::Package
24
24
 
25
- provides :habitat_package, target_mode: true
25
+ provides :habitat_package
26
26
  use "habitat_shared"
27
27
  description "Use the **habitat_package** to install or remove Chef Habitat packages from Habitat Builder."
28
28
  introduced "17.3"
@@ -21,7 +21,7 @@ class Chef
21
21
  class Resource
22
22
  class HabitatSup < Chef::Resource
23
23
 
24
- provides(:habitat_sup, target_mode: true) do |_node|
24
+ provides :habitat_sup do |_node|
25
25
  false
26
26
  end
27
27
 
@@ -186,10 +186,10 @@ class Chef
186
186
  habitat_install new_resource.name do
187
187
  license new_resource.license
188
188
  hab_version new_resource.sup_version if new_resource.sup_version
189
- not_if { ::TargetIO::File.exist?("/bin/hab") }
190
- not_if { ::TargetIO::File.exist?("/usr/bin/hab") }
191
- not_if { ::TargetIO::File.exist?("c:/habitat/hab.exe") }
192
- not_if { ::TargetIO::File.exist?("c:/ProgramData/Habitat/hab.exe") }
189
+ not_if { ::File.exist?("/bin/hab") }
190
+ not_if { ::File.exist?("/usr/bin/hab") }
191
+ not_if { ::File.exist?("c:/habitat/hab.exe") }
192
+ not_if { ::File.exist?("c:/ProgramData/Habitat/hab.exe") }
193
193
  end
194
194
 
195
195
  habitat_package "core/hab-sup" do
@@ -205,7 +205,7 @@ class Chef
205
205
  if windows?
206
206
  directory "C:/hab/sup/default/config" do
207
207
  recursive true
208
- only_if { ::TargetIO::Dir.exist?("C:/hab") }
208
+ only_if { ::Dir.exist?("C:/hab") }
209
209
  only_if { use_toml_config }
210
210
  action :create
211
211
  end
@@ -235,14 +235,14 @@ class Chef
235
235
  keep_latest_packages: new_resource.keep_latest
236
236
  )
237
237
  only_if { use_toml_config }
238
- only_if { ::TargetIO::Dir.exist?("C:/hab/sup/default/config") }
238
+ only_if { ::Dir.exist?("C:/hab/sup/default/config") }
239
239
  end
240
240
  else
241
241
  directory "/hab/sup/default/config" do
242
242
  mode "0755"
243
243
  recursive true
244
244
  only_if { use_toml_config }
245
- only_if { ::TargetIO::Dir.exist?("/hab") }
245
+ only_if { ::Dir.exist?("/hab") }
246
246
  action :create
247
247
  end
248
248
 
@@ -271,7 +271,7 @@ class Chef
271
271
  keep_latest_packages: new_resource.keep_latest
272
272
  )
273
273
  only_if { use_toml_config }
274
- only_if { ::TargetIO::Dir.exist?("/hab/sup/default/config") }
274
+ only_if { ::Dir.exist?("/hab/sup/default/config") }
275
275
  end
276
276
  end
277
277
  end
@@ -20,8 +20,8 @@ require_relative "habitat_sup"
20
20
  class Chef
21
21
  class Resource
22
22
  class HabitatSupSystemd < HabitatSup
23
- provides :habitat_sup, os: "linux", target_mode: true
24
- provides :habitat_sup_systemd, target_mode: true
23
+ provides :habitat_sup, os: "linux"
24
+ provides :habitat_sup_systemd
25
25
 
26
26
  action :run do
27
27
  super()
@@ -19,7 +19,7 @@ require_relative "../resource"
19
19
  class Chef
20
20
  class Resource
21
21
  class HabitatInstall < Chef::Resource
22
- provides :habitat_install, target_mode: true
22
+ provides :habitat_install
23
23
 
24
24
  description "Use the **habitat_install** resource to install Chef Habitat."
25
25
  introduced "17.3"
@@ -70,7 +70,7 @@ class Chef
70
70
  description: "Specify the version of `Habitat` you would like to install."
71
71
 
72
72
  action :install, description: "Installs Habitat. Does nothing if the `hab` binary is found in the default location for the system (`/bin/hab` on Linux, `/usr/local/bin/hab` on macOS, `C:/habitat/hab.exe` on Windows)" do
73
- if ::TargetIO::File.exist?(hab_path)
73
+ if ::File.exist?(hab_path)
74
74
  cmd = shell_out!([hab_path, "--version"].flatten.compact.join(" "))
75
75
  version = %r{hab (\d*\.\d*\.\d[^\/]*)}.match(cmd.stdout)[1]
76
76
  return if version == new_resource.hab_version
@@ -94,7 +94,7 @@ class Chef
94
94
  path habfile
95
95
  destination "#{Chef::Config[:file_cache_path]}/habitat"
96
96
  action :extract
97
- not_if { ::TargetIO::Dir.exist?("c:\\habitat") }
97
+ not_if { ::Dir.exist?("c:\\habitat") }
98
98
  end
99
99
 
100
100
  directory "c:\\habitat" do