chef 15.11.3-universal-mingw32 → 16.1.16-universal-mingw32

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (513) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +3 -7
  3. data/README.md +1 -1
  4. data/Rakefile +44 -16
  5. data/chef.gemspec +6 -4
  6. data/distro/powershell/chef/chef.psm1 +3 -3
  7. data/distro/templates/powershell/chef/chef.psm1.erb +3 -3
  8. data/lib/chef/action_collection.rb +16 -5
  9. data/lib/chef/application.rb +33 -54
  10. data/lib/chef/application/apply.rb +18 -1
  11. data/lib/chef/application/base.rb +8 -3
  12. data/lib/chef/application/knife.rb +1 -1
  13. data/lib/chef/chef_class.rb +4 -4
  14. data/lib/chef/chef_fs/file_system/chef_server/acls_dir.rb +1 -1
  15. data/lib/chef/chef_fs/file_system/chef_server/cookbook_file.rb +1 -1
  16. data/lib/chef/chef_fs/file_system/chef_server/rest_list_entry.rb +6 -2
  17. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +3 -3
  18. data/lib/chef/chef_fs/file_system/repository/directory.rb +1 -1
  19. data/lib/chef/chef_fs/parallelizer/parallel_enumerable.rb +1 -1
  20. data/lib/chef/chef_fs/path_utils.rb +3 -3
  21. data/lib/chef/client.rb +16 -14
  22. data/lib/chef/config.rb +1 -1
  23. data/lib/chef/cookbook/file_system_file_vendor.rb +1 -1
  24. data/lib/chef/cookbook/gem_installer.rb +1 -1
  25. data/lib/chef/cookbook/metadata.rb +45 -22
  26. data/lib/chef/cookbook_loader.rb +1 -1
  27. data/lib/chef/cookbook_manifest.rb +1 -1
  28. data/lib/chef/cookbook_site_streaming_uploader.rb +1 -1
  29. data/lib/chef/cookbook_version.rb +38 -3
  30. data/lib/chef/data_collector.rb +1 -1
  31. data/lib/chef/data_collector/error_handlers.rb +1 -1
  32. data/lib/chef/data_collector/run_end_message.rb +7 -1
  33. data/lib/chef/decorator/lazy_array.rb +2 -2
  34. data/lib/chef/deprecated.rb +4 -0
  35. data/lib/chef/digester.rb +4 -4
  36. data/lib/chef/dist.rb +8 -0
  37. data/lib/chef/dsl/chef_vault.rb +84 -0
  38. data/lib/chef/dsl/declare_resource.rb +7 -5
  39. data/lib/chef/dsl/platform_introspection.rb +3 -2
  40. data/lib/chef/dsl/recipe.rb +7 -12
  41. data/lib/chef/dsl/universal.rb +3 -7
  42. data/lib/chef/encrypted_data_bag_item/decryptor.rb +1 -1
  43. data/lib/chef/encrypted_data_bag_item/encryptor.rb +1 -1
  44. data/lib/chef/event_dispatch/base.rb +3 -0
  45. data/lib/chef/formatters/base.rb +1 -1
  46. data/lib/chef/formatters/doc.rb +1 -1
  47. data/lib/chef/formatters/indentable_output_stream.rb +7 -16
  48. data/lib/chef/http.rb +1 -1
  49. data/lib/chef/http/decompressor.rb +1 -1
  50. data/lib/chef/http/http_request.rb +3 -2
  51. data/lib/chef/json_compat.rb +1 -1
  52. data/lib/chef/key.rb +1 -1
  53. data/lib/chef/knife.rb +2 -4
  54. data/lib/chef/knife/acl_add.rb +57 -0
  55. data/lib/chef/knife/acl_base.rb +183 -0
  56. data/lib/chef/knife/acl_bulk_add.rb +78 -0
  57. data/lib/chef/knife/acl_bulk_remove.rb +83 -0
  58. data/lib/chef/knife/acl_remove.rb +62 -0
  59. data/lib/chef/knife/acl_show.rb +56 -0
  60. data/lib/chef/knife/bootstrap.rb +84 -90
  61. data/lib/chef/knife/bootstrap/chef_vault_handler.rb +2 -2
  62. data/lib/chef/knife/bootstrap/client_builder.rb +2 -2
  63. data/lib/chef/knife/bootstrap/templates/chef-full.erb +11 -11
  64. data/lib/chef/knife/bootstrap/templates/windows-chef-client-msi.erb +12 -12
  65. data/lib/chef/knife/core/bootstrap_context.rb +63 -60
  66. data/lib/chef/knife/core/generic_presenter.rb +4 -3
  67. data/lib/chef/knife/core/hashed_command_loader.rb +1 -1
  68. data/lib/chef/knife/core/node_presenter.rb +2 -2
  69. data/lib/chef/knife/core/status_presenter.rb +5 -5
  70. data/lib/chef/knife/core/subcommand_loader.rb +1 -1
  71. data/lib/chef/knife/core/ui.rb +17 -1
  72. data/lib/chef/knife/core/windows_bootstrap_context.rb +44 -42
  73. data/lib/chef/knife/data_bag_secret_options.rb +18 -45
  74. data/lib/chef/knife/group_add.rb +55 -0
  75. data/lib/chef/knife/{cookbook_site_download.rb → group_create.rb} +21 -12
  76. data/lib/chef/knife/group_destroy.rb +53 -0
  77. data/lib/chef/knife/{cookbook_site_list.rb → group_list.rb} +14 -11
  78. data/lib/chef/knife/group_remove.rb +56 -0
  79. data/lib/chef/knife/{cookbook_site_install.rb → group_show.rb} +21 -12
  80. data/lib/chef/knife/key_create_base.rb +1 -1
  81. data/lib/chef/knife/key_edit_base.rb +1 -1
  82. data/lib/chef/knife/ssh.rb +12 -31
  83. data/lib/chef/knife/status.rb +3 -3
  84. data/lib/chef/knife/supermarket_download.rb +1 -2
  85. data/lib/chef/knife/supermarket_install.rb +2 -3
  86. data/lib/chef/knife/supermarket_list.rb +1 -2
  87. data/lib/chef/knife/supermarket_search.rb +1 -2
  88. data/lib/chef/knife/supermarket_share.rb +1 -2
  89. data/lib/chef/knife/supermarket_show.rb +1 -2
  90. data/lib/chef/knife/supermarket_unshare.rb +1 -2
  91. data/lib/chef/knife/{cookbook_site_show.rb → user_dissociate.rb} +15 -13
  92. data/lib/chef/knife/{cookbook_site_search.rb → user_invite_add.rb} +16 -13
  93. data/lib/chef/knife/user_invite_list.rb +34 -0
  94. data/lib/chef/knife/user_invite_rescind.rb +63 -0
  95. data/lib/chef/knife/yaml_convert.rb +91 -0
  96. data/lib/chef/mixin/api_version_request_handling.rb +1 -1
  97. data/lib/chef/mixin/checksum.rb +0 -1
  98. data/lib/chef/mixin/openssl_helper.rb +4 -4
  99. data/lib/chef/mixin/powershell_exec.rb +10 -1
  100. data/lib/chef/mixin/powershell_out.rb +1 -1
  101. data/lib/chef/mixin/properties.rb +16 -2
  102. data/lib/chef/mixin/shell_out.rb +1 -5
  103. data/lib/chef/monkey_patches/net_http.rb +0 -4
  104. data/lib/chef/node.rb +18 -6
  105. data/lib/chef/node/attribute.rb +2 -2
  106. data/lib/chef/node/immutable_collections.rb +1 -1
  107. data/lib/chef/node/mixin/immutablize_array.rb +4 -0
  108. data/lib/chef/node/mixin/immutablize_hash.rb +3 -0
  109. data/lib/chef/node_map.rb +5 -31
  110. data/lib/chef/platform/priority_map.rb +4 -4
  111. data/lib/chef/platform/query_helpers.rb +6 -34
  112. data/lib/chef/policy_builder/policyfile.rb +1 -1
  113. data/lib/chef/powershell.rb +14 -0
  114. data/lib/chef/property.rb +24 -6
  115. data/lib/chef/provider.rb +40 -6
  116. data/lib/chef/provider/cron.rb +2 -2
  117. data/lib/chef/provider/directory.rb +3 -3
  118. data/lib/chef/provider/dsc_resource.rb +1 -1
  119. data/lib/chef/provider/dsc_script.rb +1 -1
  120. data/lib/chef/provider/execute.rb +3 -9
  121. data/lib/chef/provider/file.rb +6 -6
  122. data/lib/chef/provider/git.rb +84 -27
  123. data/lib/chef/provider/group.rb +4 -4
  124. data/lib/chef/provider/http_request.rb +6 -6
  125. data/lib/chef/provider/ifconfig.rb +4 -4
  126. data/lib/chef/provider/launchd.rb +45 -64
  127. data/lib/chef/provider/link.rb +2 -2
  128. data/lib/chef/provider/mount.rb +5 -5
  129. data/lib/chef/provider/osx_profile.rb +7 -3
  130. data/lib/chef/provider/package.rb +2 -2
  131. data/lib/chef/provider/package/cab.rb +5 -6
  132. data/lib/chef/provider/package/chocolatey.rb +1 -3
  133. data/lib/chef/provider/package/dnf.rb +66 -10
  134. data/lib/chef/provider/package/dnf/dnf_helper.py +85 -26
  135. data/lib/chef/provider/package/dnf/python_helper.rb +79 -36
  136. data/lib/chef/provider/package/dnf/version.rb +5 -1
  137. data/lib/chef/provider/package/dpkg.rb +1 -1
  138. data/lib/chef/provider/package/freebsd/base.rb +2 -1
  139. data/lib/chef/provider/package/homebrew.rb +107 -43
  140. data/lib/chef/provider/package/macports.rb +0 -2
  141. data/lib/chef/provider/package/msu.rb +4 -1
  142. data/lib/chef/provider/package/pacman.rb +25 -34
  143. data/lib/chef/provider/package/portage.rb +1 -0
  144. data/lib/chef/provider/package/powershell.rb +1 -1
  145. data/lib/chef/provider/package/rubygems.rb +30 -3
  146. data/lib/chef/provider/package/windows.rb +29 -53
  147. data/lib/chef/provider/package/windows/msi.rb +2 -2
  148. data/lib/chef/provider/package/yum.rb +1 -9
  149. data/lib/chef/provider/package/yum/yum_cache.rb +1 -1
  150. data/lib/chef/provider/package/zypper.rb +0 -1
  151. data/lib/chef/provider/powershell_script.rb +5 -11
  152. data/lib/chef/provider/registry_key.rb +4 -4
  153. data/lib/chef/provider/remote_directory.rb +5 -5
  154. data/lib/chef/provider/remote_file/ftp.rb +3 -2
  155. data/lib/chef/provider/remote_file/local_file.rb +2 -1
  156. data/lib/chef/provider/remote_file/sftp.rb +3 -2
  157. data/lib/chef/provider/route.rb +5 -3
  158. data/lib/chef/provider/ruby_block.rb +1 -1
  159. data/lib/chef/provider/script.rb +2 -2
  160. data/lib/chef/provider/service.rb +8 -8
  161. data/lib/chef/provider/service/aixinit.rb +1 -1
  162. data/lib/chef/provider/service/arch.rb +1 -1
  163. data/lib/chef/provider/service/debian.rb +30 -28
  164. data/lib/chef/provider/service/macosx.rb +16 -10
  165. data/lib/chef/provider/service/systemd.rb +12 -12
  166. data/lib/chef/provider/service/upstart.rb +1 -1
  167. data/lib/chef/provider/service/windows.rb +5 -11
  168. data/lib/chef/provider/subversion.rb +25 -5
  169. data/lib/chef/provider/systemd_unit.rb +26 -25
  170. data/lib/chef/provider/user.rb +6 -6
  171. data/lib/chef/provider/user/aix.rb +1 -1
  172. data/lib/chef/provider/user/dscl.rb +6 -6
  173. data/lib/chef/provider/user/mac.rb +20 -15
  174. data/lib/chef/provider/whyrun_safe_ruby_block.rb +1 -1
  175. data/lib/chef/provider/windows_env.rb +3 -3
  176. data/lib/chef/provider/windows_script.rb +2 -2
  177. data/lib/chef/provider/windows_task.rb +10 -10
  178. data/lib/chef/providers.rb +0 -6
  179. data/lib/chef/recipe.rb +36 -0
  180. data/lib/chef/resource.rb +44 -57
  181. data/lib/chef/resource/action_class.rb +24 -22
  182. data/lib/chef/resource/alternatives.rb +210 -0
  183. data/lib/chef/resource/apt_package.rb +33 -3
  184. data/lib/chef/resource/apt_preference.rb +103 -7
  185. data/lib/chef/resource/apt_repository.rb +357 -18
  186. data/lib/chef/resource/apt_update.rb +58 -5
  187. data/lib/chef/resource/archive_file.rb +6 -5
  188. data/lib/chef/resource/bash.rb +3 -1
  189. data/lib/chef/resource/batch.rb +1 -1
  190. data/lib/chef/resource/bff_package.rb +10 -2
  191. data/lib/chef/resource/breakpoint.rb +1 -2
  192. data/lib/chef/resource/build_essential.rb +49 -51
  193. data/lib/chef/resource/cab_package.rb +9 -2
  194. data/lib/chef/resource/chef_client_cron.rb +228 -0
  195. data/lib/chef/resource/chef_client_scheduled_task.rb +201 -0
  196. data/lib/chef/resource/chef_client_systemd_timer.rb +180 -0
  197. data/lib/chef/resource/chef_gem.rb +15 -18
  198. data/lib/chef/resource/chef_handler.rb +5 -4
  199. data/lib/chef/resource/chef_sleep.rb +7 -5
  200. data/lib/chef/resource/chef_vault_secret.rb +135 -0
  201. data/lib/chef/resource/chocolatey_config.rb +8 -4
  202. data/lib/chef/resource/chocolatey_feature.rb +7 -4
  203. data/lib/chef/resource/chocolatey_package.rb +7 -4
  204. data/lib/chef/resource/chocolatey_source.rb +7 -4
  205. data/lib/chef/resource/cookbook_file.rb +4 -3
  206. data/lib/chef/resource/cron.rb +34 -80
  207. data/lib/chef/resource/cron_access.rb +10 -6
  208. data/lib/chef/resource/cron_d.rb +44 -95
  209. data/lib/chef/resource/csh.rb +3 -1
  210. data/lib/chef/resource/directory.rb +3 -3
  211. data/lib/chef/resource/dmg_package.rb +22 -19
  212. data/lib/chef/resource/dnf_package.rb +3 -4
  213. data/lib/chef/resource/dpkg_package.rb +3 -2
  214. data/lib/chef/resource/dsc_resource.rb +6 -4
  215. data/lib/chef/resource/dsc_script.rb +3 -2
  216. data/lib/chef/resource/execute.rb +15 -14
  217. data/lib/chef/resource/file.rb +14 -9
  218. data/lib/chef/resource/freebsd_package.rb +3 -2
  219. data/lib/chef/resource/gem_package.rb +19 -11
  220. data/lib/chef/resource/group.rb +5 -2
  221. data/lib/chef/resource/helpers/cron_validations.rb +98 -0
  222. data/lib/chef/resource/homebrew_cask.rb +3 -2
  223. data/lib/chef/resource/homebrew_package.rb +5 -3
  224. data/lib/chef/resource/homebrew_tap.rb +3 -2
  225. data/lib/chef/resource/hostname.rb +26 -20
  226. data/lib/chef/resource/http_request.rb +1 -2
  227. data/lib/chef/resource/ifconfig.rb +8 -8
  228. data/lib/chef/resource/ips_package.rb +11 -3
  229. data/lib/chef/resource/kernel_module.rb +30 -30
  230. data/lib/chef/resource/ksh.rb +3 -1
  231. data/lib/chef/resource/launchd.rb +3 -3
  232. data/lib/chef/resource/link.rb +5 -27
  233. data/lib/chef/resource/locale.rb +60 -26
  234. data/lib/chef/resource/log.rb +13 -2
  235. data/lib/chef/resource/lwrp_base.rb +1 -1
  236. data/lib/chef/resource/macos_userdefaults.rb +18 -10
  237. data/lib/chef/resource/macosx_service.rb +3 -2
  238. data/lib/chef/resource/macports_package.rb +10 -2
  239. data/lib/chef/resource/mdadm.rb +63 -3
  240. data/lib/chef/resource/mount.rb +4 -1
  241. data/lib/chef/resource/msu_package.rb +19 -2
  242. data/lib/chef/resource/notify_group.rb +8 -3
  243. data/lib/chef/resource/ohai.rb +20 -4
  244. data/lib/chef/resource/ohai_hint.rb +4 -13
  245. data/lib/chef/resource/openbsd_package.rb +10 -2
  246. data/lib/chef/resource/openssl_dhparam.rb +11 -2
  247. data/lib/chef/resource/openssl_ec_private_key.rb +24 -2
  248. data/lib/chef/resource/openssl_ec_public_key.rb +22 -2
  249. data/lib/chef/resource/openssl_rsa_private_key.rb +21 -2
  250. data/lib/chef/resource/openssl_rsa_public_key.rb +23 -2
  251. data/lib/chef/resource/openssl_x509_certificate.rb +38 -2
  252. data/lib/chef/resource/openssl_x509_crl.rb +13 -2
  253. data/lib/chef/resource/openssl_x509_request.rb +38 -2
  254. data/lib/chef/resource/osx_profile.rb +4 -3
  255. data/lib/chef/resource/package.rb +3 -2
  256. data/lib/chef/resource/pacman_package.rb +3 -2
  257. data/lib/chef/resource/paludis_package.rb +13 -4
  258. data/lib/chef/resource/perl.rb +3 -1
  259. data/lib/chef/resource/plist.rb +207 -0
  260. data/lib/chef/resource/portage_package.rb +14 -4
  261. data/lib/chef/resource/powershell_package.rb +2 -4
  262. data/lib/chef/resource/powershell_package_source.rb +4 -2
  263. data/lib/chef/resource/powershell_script.rb +8 -18
  264. data/lib/chef/resource/python.rb +3 -1
  265. data/lib/chef/resource/reboot.rb +1 -2
  266. data/lib/chef/resource/registry_key.rb +2 -3
  267. data/lib/chef/resource/remote_directory.rb +3 -1
  268. data/lib/chef/resource/remote_file.rb +3 -2
  269. data/lib/chef/resource/rhsm_errata.rb +1 -4
  270. data/lib/chef/resource/rhsm_errata_level.rb +1 -2
  271. data/lib/chef/resource/rhsm_register.rb +3 -3
  272. data/lib/chef/resource/rhsm_repo.rb +4 -3
  273. data/lib/chef/resource/rhsm_subscription.rb +5 -4
  274. data/lib/chef/resource/route.rb +6 -2
  275. data/lib/chef/resource/rpm_package.rb +13 -3
  276. data/lib/chef/resource/ruby.rb +3 -1
  277. data/lib/chef/resource/ruby_block.rb +2 -5
  278. data/lib/chef/resource/scm/_scm.rb +49 -0
  279. data/lib/chef/resource/{scm.rb → scm/git.rb} +16 -30
  280. data/lib/chef/resource/{subversion.rb → scm/subversion.rb} +10 -7
  281. data/lib/chef/resource/script.rb +7 -4
  282. data/lib/chef/resource/service.rb +7 -8
  283. data/lib/chef/resource/smartos_package.rb +10 -2
  284. data/lib/chef/resource/snap_package.rb +4 -2
  285. data/lib/chef/resource/solaris_package.rb +10 -2
  286. data/lib/chef/resource/ssh_known_hosts_entry.rb +6 -3
  287. data/lib/chef/resource/sudo.rb +11 -11
  288. data/lib/chef/resource/support/cron.d.erb +1 -1
  289. data/lib/chef/resource/support/cron_access.erb +1 -1
  290. data/lib/chef/resource/support/sudoer.erb +1 -2
  291. data/lib/chef/resource/support/ulimit.erb +41 -0
  292. data/lib/chef/resource/swap_file.rb +7 -5
  293. data/lib/chef/resource/sysctl.rb +63 -4
  294. data/lib/chef/resource/systemd_unit.rb +6 -4
  295. data/lib/chef/resource/template.rb +0 -1
  296. data/lib/chef/resource/timezone.rb +8 -19
  297. data/lib/chef/resource/user.rb +3 -5
  298. data/lib/chef/resource/user/aix_user.rb +0 -2
  299. data/lib/chef/resource/user/dscl_user.rb +1 -1
  300. data/lib/chef/resource/user/linux_user.rb +0 -2
  301. data/lib/chef/resource/user/mac_user.rb +1 -1
  302. data/lib/chef/resource/user/pw_user.rb +0 -2
  303. data/lib/chef/resource/user/solaris_user.rb +0 -2
  304. data/lib/chef/resource/user/windows_user.rb +0 -2
  305. data/lib/chef/resource/user_ulimit.rb +116 -0
  306. data/lib/chef/resource/whyrun_safe_ruby_block.rb +1 -0
  307. data/lib/chef/resource/windows_ad_join.rb +20 -7
  308. data/lib/chef/resource/windows_auto_run.rb +2 -3
  309. data/lib/chef/resource/windows_certificate.rb +3 -3
  310. data/lib/chef/resource/windows_dfs_folder.rb +1 -2
  311. data/lib/chef/resource/windows_dfs_namespace.rb +1 -2
  312. data/lib/chef/resource/windows_dfs_server.rb +2 -3
  313. data/lib/chef/resource/windows_dns_record.rb +0 -1
  314. data/lib/chef/resource/windows_dns_zone.rb +0 -1
  315. data/lib/chef/resource/windows_env.rb +12 -4
  316. data/lib/chef/resource/windows_feature.rb +59 -4
  317. data/lib/chef/resource/windows_feature_dism.rb +24 -24
  318. data/lib/chef/resource/windows_feature_powershell.rb +44 -78
  319. data/lib/chef/resource/windows_firewall_rule.rb +121 -8
  320. data/lib/chef/resource/windows_font.rb +10 -2
  321. data/lib/chef/resource/windows_package.rb +76 -7
  322. data/lib/chef/resource/windows_pagefile.rb +31 -4
  323. data/lib/chef/resource/windows_path.rb +18 -2
  324. data/lib/chef/resource/windows_printer.rb +26 -7
  325. data/lib/chef/resource/windows_printer_port.rb +29 -2
  326. data/lib/chef/resource/windows_script.rb +3 -4
  327. data/lib/chef/resource/windows_security_policy.rb +119 -0
  328. data/lib/chef/resource/windows_service.rb +46 -32
  329. data/lib/chef/resource/windows_share.rb +22 -6
  330. data/lib/chef/resource/windows_shortcut.rb +13 -3
  331. data/lib/chef/resource/windows_task.rb +129 -16
  332. data/lib/chef/resource/windows_uac.rb +20 -2
  333. data/lib/chef/resource/windows_user_privilege.rb +199 -0
  334. data/lib/chef/resource/windows_workgroup.rb +19 -4
  335. data/lib/chef/resource/yum_package.rb +91 -7
  336. data/lib/chef/resource/yum_repository.rb +30 -12
  337. data/lib/chef/resource/zypper_package.rb +32 -5
  338. data/lib/chef/resource/zypper_repository.rb +19 -6
  339. data/lib/chef/resource_builder.rb +8 -0
  340. data/lib/chef/resource_inspector.rb +3 -2
  341. data/lib/chef/resource_resolver.rb +7 -14
  342. data/lib/chef/resources.rb +11 -3
  343. data/lib/chef/run_context/cookbook_compiler.rb +29 -5
  344. data/lib/chef/scan_access_control.rb +1 -1
  345. data/lib/chef/shell.rb +22 -0
  346. data/lib/chef/shell/ext.rb +1 -1
  347. data/lib/chef/version.rb +1 -1
  348. data/lib/chef/win32/api.rb +2 -2
  349. data/lib/chef/win32/api/error.rb +3 -1
  350. data/lib/chef/win32/api/file.rb +1 -1
  351. data/lib/chef/win32/api/net.rb +1 -0
  352. data/lib/chef/win32/api/security.rb +6 -0
  353. data/lib/chef/win32/file.rb +1 -9
  354. data/lib/chef/win32/mutex.rb +1 -1
  355. data/lib/chef/win32/net.rb +1 -0
  356. data/lib/chef/win32/security.rb +40 -2
  357. data/lib/chef/win32/security/sid.rb +4 -4
  358. data/spec/functional/assets/inittest +8 -7
  359. data/spec/functional/knife/ssh_spec.rb +23 -19
  360. data/spec/functional/resource/cron_spec.rb +10 -29
  361. data/spec/functional/resource/dnf_package_spec.rb +441 -156
  362. data/spec/functional/resource/git_spec.rb +184 -134
  363. data/spec/functional/resource/insserv_spec.rb +1 -1
  364. data/spec/functional/resource/launchd_spec.rb +232 -0
  365. data/spec/functional/resource/link_spec.rb +3 -3
  366. data/spec/functional/resource/locale_spec.rb +13 -2
  367. data/spec/functional/resource/msu_package_spec.rb +5 -2
  368. data/spec/functional/resource/powershell_script_spec.rb +7 -68
  369. data/spec/functional/resource/remote_file_spec.rb +1 -1
  370. data/spec/functional/resource/windows_security_policy_spec.rb +90 -0
  371. data/spec/functional/resource/windows_task_spec.rb +4 -4
  372. data/spec/functional/resource/windows_user_privilege_spec.rb +193 -0
  373. data/spec/functional/run_lock_spec.rb +1 -1
  374. data/spec/functional/shell_spec.rb +1 -1
  375. data/spec/functional/util/powershell/cmdlet_spec.rb +1 -1
  376. data/spec/functional/version_spec.rb +1 -1
  377. data/spec/functional/win32/registry_spec.rb +0 -6
  378. data/spec/functional/win32/security_spec.rb +22 -0
  379. data/spec/integration/client/client_spec.rb +123 -2
  380. data/spec/integration/knife/cookbook_show_spec.rb +28 -26
  381. data/spec/integration/knife/data_bag_show_spec.rb +1 -1
  382. data/spec/integration/knife/raw_spec.rb +34 -6
  383. data/spec/integration/knife/redirection_spec.rb +2 -2
  384. data/spec/integration/knife/show_spec.rb +32 -3
  385. data/spec/integration/recipes/lwrp_inline_resources_spec.rb +3 -3
  386. data/spec/integration/recipes/noop_resource_spec.rb +1 -1
  387. data/spec/integration/recipes/notifies_spec.rb +49 -20
  388. data/spec/integration/recipes/notifying_block_spec.rb +8 -5
  389. data/spec/integration/recipes/provider_choice.rb +2 -0
  390. data/spec/integration/recipes/recipe_dsl_spec.rb +45 -143
  391. data/spec/integration/recipes/resource_action_spec.rb +16 -11
  392. data/spec/integration/recipes/resource_converge_if_changed_spec.rb +1 -1
  393. data/spec/integration/recipes/resource_load_spec.rb +133 -12
  394. data/spec/integration/recipes/use_partial_spec.rb +112 -0
  395. data/spec/integration/solo/solo_spec.rb +3 -3
  396. data/spec/spec_helper.rb +18 -3
  397. data/spec/support/chef_helpers.rb +2 -2
  398. data/spec/support/lib/chef/resource/zen_follower.rb +2 -0
  399. data/spec/support/platform_helpers.rb +2 -20
  400. data/spec/support/recipe_dsl_helper.rb +83 -0
  401. data/spec/support/shared/functional/http.rb +2 -2
  402. data/spec/support/shared/functional/windows_script.rb +3 -16
  403. data/spec/support/shared/integration/knife_support.rb +9 -6
  404. data/spec/support/shared/unit/mock_shellout.rb +1 -1
  405. data/spec/support/shared/unit/provider/useradd_based_user_provider.rb +4 -4
  406. data/spec/unit/application/apply_spec.rb +3 -0
  407. data/spec/unit/application/client_spec.rb +5 -1
  408. data/spec/unit/application_spec.rb +1 -2
  409. data/spec/unit/client_spec.rb +7 -5
  410. data/spec/unit/cookbook/gem_installer_spec.rb +2 -2
  411. data/spec/unit/cookbook/metadata_spec.rb +38 -19
  412. data/spec/unit/data_collector_spec.rb +39 -18
  413. data/spec/unit/file_access_control_spec.rb +1 -1
  414. data/spec/unit/json_compat_spec.rb +1 -1
  415. data/spec/unit/knife/bootstrap/chef_vault_handler_spec.rb +15 -15
  416. data/spec/unit/knife/bootstrap/client_builder_spec.rb +9 -9
  417. data/spec/unit/knife/bootstrap_spec.rb +20 -38
  418. data/spec/unit/knife/cookbook_show_spec.rb +1 -0
  419. data/spec/unit/knife/core/bootstrap_context_spec.rb +23 -43
  420. data/spec/unit/knife/core/ui_spec.rb +16 -0
  421. data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +9 -63
  422. data/spec/unit/knife/data_bag_secret_options_spec.rb +22 -14
  423. data/spec/unit/knife/ssh_spec.rb +8 -111
  424. data/spec/unit/knife/status_spec.rb +1 -1
  425. data/spec/unit/knife_spec.rb +18 -0
  426. data/spec/unit/mixin/openssl_helper_spec.rb +4 -4
  427. data/spec/unit/mixin/powershell_exec_spec.rb +10 -0
  428. data/spec/unit/mixin/shell_out_spec.rb +25 -31
  429. data/spec/unit/node/attribute_spec.rb +3 -3
  430. data/spec/unit/node_spec.rb +24 -0
  431. data/spec/unit/platform/query_helpers_spec.rb +0 -143
  432. data/spec/unit/property/state_spec.rb +12 -7
  433. data/spec/unit/property/validation_spec.rb +25 -1
  434. data/spec/unit/property_spec.rb +12 -9
  435. data/spec/unit/provider/apt_preference_spec.rb +14 -10
  436. data/spec/unit/provider/apt_repository_spec.rb +34 -36
  437. data/spec/unit/provider/apt_update_spec.rb +12 -11
  438. data/spec/unit/provider/cookbook_file_spec.rb +4 -4
  439. data/spec/unit/provider/cron_spec.rb +2 -2
  440. data/spec/unit/provider/directory_spec.rb +4 -15
  441. data/spec/unit/provider/file_spec.rb +4 -4
  442. data/spec/unit/provider/git_spec.rb +41 -1
  443. data/spec/unit/provider/group/groupadd_spec.rb +1 -1
  444. data/spec/unit/provider/launchd_spec.rb +8 -50
  445. data/spec/unit/provider/link_spec.rb +0 -1
  446. data/spec/unit/provider/log_spec.rb +3 -3
  447. data/spec/unit/provider/mdadm_spec.rb +3 -3
  448. data/spec/unit/provider/package/dnf/python_helper_spec.rb +1 -1
  449. data/spec/unit/provider/package/homebrew_spec.rb +280 -174
  450. data/spec/unit/provider/package/pacman_spec.rb +65 -147
  451. data/spec/unit/provider/package/portage_spec.rb +2 -2
  452. data/spec/unit/provider/package/powershell_spec.rb +3 -2
  453. data/spec/unit/provider/package/rubygems_spec.rb +211 -26
  454. data/spec/unit/provider/package/windows/exe_spec.rb +1 -1
  455. data/spec/unit/provider/powershell_script_spec.rb +21 -61
  456. data/spec/unit/provider/remote_file_spec.rb +3 -4
  457. data/spec/unit/provider/service/debian_service_spec.rb +34 -13
  458. data/spec/unit/provider/service/macosx_spec.rb +210 -214
  459. data/spec/unit/provider/service/systemd_service_spec.rb +23 -23
  460. data/spec/unit/provider/subversion_spec.rb +4 -2
  461. data/spec/unit/provider/template_spec.rb +3 -4
  462. data/spec/unit/provider/zypper_repository_spec.rb +17 -17
  463. data/spec/unit/provider_resolver_spec.rb +4 -4
  464. data/spec/unit/recipe_spec.rb +68 -0
  465. data/spec/unit/resource/alternatives_spec.rb +120 -0
  466. data/spec/unit/resource/apt_preference_spec.rb +0 -18
  467. data/spec/unit/resource/apt_repository_spec.rb +0 -18
  468. data/spec/unit/resource/apt_update_spec.rb +0 -18
  469. data/spec/unit/resource/chef_client_cron_spec.rb +119 -0
  470. data/spec/unit/resource/chef_client_scheduled_task_spec.rb +102 -0
  471. data/spec/unit/resource/chef_client_systemd_timer_spec.rb +70 -0
  472. data/spec/unit/resource/chef_vault_secret_spec.rb +40 -0
  473. data/spec/unit/resource/chocolatey_source_spec.rb +2 -1
  474. data/spec/unit/resource/cron_d_spec.rb +6 -48
  475. data/spec/unit/resource/cron_spec.rb +4 -10
  476. data/spec/unit/resource/gem_package_spec.rb +3 -3
  477. data/spec/unit/resource/helpers/cron_validations_spec.rb +77 -0
  478. data/spec/unit/resource/link_spec.rb +0 -4
  479. data/spec/unit/resource/locale_spec.rb +0 -34
  480. data/spec/unit/resource/msu_package_spec.rb +4 -0
  481. data/spec/unit/resource/ohai_spec.rb +56 -2
  482. data/spec/unit/resource/plist_spec.rb +130 -0
  483. data/spec/unit/resource/powershell_script_spec.rb +0 -5
  484. data/spec/unit/resource/{git_spec.rb → scm/git_spec.rb} +50 -2
  485. data/spec/unit/resource/{scm_spec.rb → scm/scm.rb} +1 -52
  486. data/spec/unit/resource/{subversion_spec.rb → scm/subversion_spec.rb} +2 -3
  487. data/spec/unit/resource/service_spec.rb +4 -0
  488. data/spec/unit/resource/user_spec.rb +2 -2
  489. data/spec/unit/resource/user_ulimit_spec.rb +53 -0
  490. data/spec/unit/resource/windows_feature_dism_spec.rb +2 -17
  491. data/spec/unit/resource/windows_feature_powershell_spec.rb +2 -17
  492. data/spec/unit/resource/windows_firewall_rule_spec.rb +88 -41
  493. data/spec/unit/resource/windows_package_spec.rb +14 -0
  494. data/spec/unit/resource/windows_service_spec.rb +9 -0
  495. data/spec/unit/resource_reporter_spec.rb +2 -6
  496. data/spec/unit/resource_spec.rb +10 -3
  497. data/spec/unit/run_lock_spec.rb +1 -1
  498. data/spec/unit/scan_access_control_spec.rb +1 -1
  499. data/spec/unit/search/query_spec.rb +1 -1
  500. data/spec/unit/win32/registry_spec.rb +1 -1
  501. data/tasks/rspec.rb +6 -14
  502. metadata +92 -37
  503. data/lib/chef/dsl/core.rb +0 -52
  504. data/lib/chef/knife/cookbook_site_share.rb +0 -41
  505. data/lib/chef/knife/cookbook_site_unshare.rb +0 -41
  506. data/lib/chef/provider/apt_preference.rb +0 -93
  507. data/lib/chef/provider/apt_repository.rb +0 -358
  508. data/lib/chef/provider/apt_update.rb +0 -79
  509. data/lib/chef/provider/log.rb +0 -43
  510. data/lib/chef/provider/mdadm.rb +0 -85
  511. data/lib/chef/provider/ohai.rb +0 -45
  512. data/lib/chef/resource/git.rb +0 -37
  513. data/spec/unit/provider/ohai_spec.rb +0 -84
@@ -0,0 +1,56 @@
1
+ #
2
+ # Author:: Steven Danna (steve@chef.io)
3
+ # Copyright:: Copyright (c) Chef Software Inc.
4
+ # License:: Apache License, Version 2.0
5
+ #
6
+ # Licensed under the Apache License, Version 2.0 (the "License");
7
+ # you may not use this file except in compliance with the License.
8
+ # You may obtain a copy of the License at
9
+ #
10
+ # http://www.apache.org/licenses/LICENSE-2.0
11
+ #
12
+ # Unless required by applicable law or agreed to in writing, software
13
+ # distributed under the License is distributed on an "AS IS" BASIS,
14
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ # See the License for the specific language governing permissions and
16
+ # limitations under the License.
17
+ #
18
+
19
+ require_relative "../knife"
20
+
21
+ class Chef
22
+ class Knife
23
+ class AclShow < Chef::Knife
24
+ category "acl"
25
+ banner "knife acl show OBJECT_TYPE OBJECT_NAME"
26
+
27
+ deps do
28
+ require_relative "acl_base"
29
+ include Chef::Knife::AclBase
30
+ end
31
+
32
+ def run
33
+ object_type, object_name = name_args
34
+
35
+ if name_args.length != 2
36
+ show_usage
37
+ ui.fatal "You must specify an object type and object name"
38
+ exit 1
39
+ end
40
+
41
+ validate_object_type!(object_type)
42
+ validate_object_name!(object_name)
43
+ acl = get_acl(object_type, object_name)
44
+ PERM_TYPES.each do |perm|
45
+ # Filter out the actors field if we have
46
+ # users and clients. Note that if one is present,
47
+ # both will be - but we're checking both for completeness.
48
+ if acl[perm].key?("users") && acl[perm].key?("clients")
49
+ acl[perm].delete "actors"
50
+ end
51
+ end
52
+ ui.output acl
53
+ end
54
+ end
55
+ end
56
+ end
@@ -86,7 +86,6 @@ class Chef
86
86
  short: "-w AUTH-METHOD",
87
87
  long: "--winrm-auth-method AUTH-METHOD",
88
88
  description: "The WinRM authentication method to use.",
89
- proc: Proc.new { |protocol| Chef::Config[:knife][:winrm_auth_method] = protocol },
90
89
  in: WINRM_AUTH_PROTOCOL_LIST
91
90
 
92
91
  option :winrm_basic_auth_only,
@@ -95,36 +94,31 @@ class Chef
95
94
  boolean: true
96
95
 
97
96
  # This option was provided in knife bootstrap windows winrm,
98
- # but it is ignored in knife-windows/WinrmSession, and so remains unimplemeneted here.
97
+ # but it is ignored in knife-windows/WinrmSession, and so remains unimplemented here.
99
98
  # option :kerberos_keytab_file,
100
99
  # :short => "-T KEYTAB_FILE",
101
100
  # :long => "--keytab-file KEYTAB_FILE",
102
- # :description => "The Kerberos keytab file used for authentication",
103
- # :proc => Proc.new { |keytab| Chef::Config[:knife][:kerberos_keytab_file] = keytab }
101
+ # :description => "The Kerberos keytab file used for authentication"
104
102
 
105
103
  option :kerberos_realm,
106
104
  short: "-R KERBEROS_REALM",
107
105
  long: "--kerberos-realm KERBEROS_REALM",
108
- description: "The Kerberos realm used for authentication.",
109
- proc: Proc.new { |protocol| Chef::Config[:knife][:kerberos_realm] = protocol }
106
+ description: "The Kerberos realm used for authentication."
110
107
 
111
108
  option :kerberos_service,
112
109
  short: "-S KERBEROS_SERVICE",
113
110
  long: "--kerberos-service KERBEROS_SERVICE",
114
- description: "The Kerberos service used for authentication.",
115
- proc: Proc.new { |protocol| Chef::Config[:knife][:kerberos_service] = protocol }
111
+ description: "The Kerberos service used for authentication."
116
112
 
117
113
  ## SSH Authentication
118
114
  option :ssh_gateway,
119
115
  short: "-G GATEWAY",
120
116
  long: "--ssh-gateway GATEWAY",
121
- description: "The SSH gateway.",
122
- proc: Proc.new { |key| Chef::Config[:knife][:ssh_gateway] = key }
117
+ description: "The SSH gateway."
123
118
 
124
119
  option :ssh_gateway_identity,
125
120
  long: "--ssh-gateway-identity SSH_GATEWAY_IDENTITY",
126
- description: "The SSH identity file used for gateway authentication.",
127
- proc: Proc.new { |key| Chef::Config[:knife][:ssh_gateway_identity] = key }
121
+ description: "The SSH identity file used for gateway authentication."
128
122
 
129
123
  option :ssh_forward_agent,
130
124
  short: "-A",
@@ -140,7 +134,8 @@ class Chef
140
134
  option :ssh_verify_host_key,
141
135
  long: "--ssh-verify-host-key VALUE",
142
136
  description: "Verify host key. Default is 'always'.",
143
- in: %w{always accept_new accept_new_or_local_tunnel never}
137
+ in: %w{always accept_new accept_new_or_local_tunnel never},
138
+ default: "always"
144
139
 
145
140
  #
146
141
  # bootstrap options
@@ -160,8 +155,7 @@ class Chef
160
155
  # client.rb content via chef-full/bootstrap_context
161
156
  option :bootstrap_proxy,
162
157
  long: "--bootstrap-proxy PROXY_URL",
163
- description: "The proxy server for the node being bootstrapped.",
164
- proc: Proc.new { |p| Chef::Config[:knife][:bootstrap_proxy] = p }
158
+ description: "The proxy server for the node being bootstrapped."
165
159
 
166
160
  # client.rb content via bootstrap_context
167
161
  option :bootstrap_proxy_user,
@@ -176,8 +170,7 @@ class Chef
176
170
  # client.rb content via bootstrap_context
177
171
  option :bootstrap_no_proxy,
178
172
  long: "--bootstrap-no-proxy [NO_PROXY_URL|NO_PROXY_IP]",
179
- description: "Do not proxy locations for the node being bootstrapped",
180
- proc: Proc.new { |np| Chef::Config[:knife][:bootstrap_no_proxy] = np }
173
+ description: "Do not proxy locations for the node being bootstrapped"
181
174
 
182
175
  # client.rb content via bootstrap_context
183
176
  option :bootstrap_template,
@@ -270,30 +263,24 @@ class Chef
270
263
  proc: lambda { |o| Chef::JSONCompat.parse(File.read(o)) },
271
264
  default: nil
272
265
 
273
- # Note that several of the below options are used by bootstrap template,
274
- # but only from the passed-in knife config; it does not use the
275
- # config from the CLI for those values. We cannot always used the merged
276
- # config, because in some cases the knife keys thIn those cases, the option
277
- # will have a proc that assigns the value into Chef::Config[:knife]
278
-
279
266
  # bootstrap template
280
267
  # Create ohai hints in /etc/chef/ohai/hints, fname=hintname, content=value
281
- option :hint,
268
+ option :hints,
282
269
  long: "--hint HINT_NAME[=HINT_FILE]",
283
270
  description: "Specify an Ohai hint to be set on the bootstrap target. Use multiple --hint options to specify multiple hints.",
284
- proc: Proc.new { |h|
285
- Chef::Config[:knife][:hints] ||= {}
286
- name, path = h.split("=")
287
- Chef::Config[:knife][:hints][name] = path ? Chef::JSONCompat.parse(::File.read(path)) : {}
271
+ proc: Proc.new { |hint, accumulator|
272
+ accumulator ||= {}
273
+ name, path = hint.split("=", 2)
274
+ accumulator[name] = path ? Chef::JSONCompat.parse(::File.read(path)) : {}
275
+ accumulator
288
276
  }
289
277
 
290
- # bootstrap override: url of a an installer shell script touse in place of omnitruck
278
+ # bootstrap override: url of a an installer shell script to use in place of omnitruck
291
279
  # Note that the bootstrap template _only_ references this out of Chef::Config, and not from
292
280
  # the provided options to knife bootstrap, so we set the Chef::Config option here.
293
281
  option :bootstrap_url,
294
282
  long: "--bootstrap-url URL",
295
- description: "URL to a custom installation script.",
296
- proc: Proc.new { |u| Chef::Config[:knife][:bootstrap_url] = u }
283
+ description: "URL to a custom installation script."
297
284
 
298
285
  option :bootstrap_product,
299
286
  long: "--bootstrap-product PRODUCT",
@@ -309,26 +296,22 @@ class Chef
309
296
  # bootstrap override: Do this instead of our own setup.sh from omnitruck. Causes bootstrap_url to be ignored.
310
297
  option :bootstrap_install_command,
311
298
  long: "--bootstrap-install-command COMMANDS",
312
- description: "Custom command to install #{Chef::Dist::PRODUCT}.",
313
- proc: Proc.new { |ic| Chef::Config[:knife][:bootstrap_install_command] = ic }
299
+ description: "Custom command to install #{Chef::Dist::PRODUCT}."
314
300
 
315
301
  # bootstrap template: Run this command first in the bootstrap script
316
302
  option :bootstrap_preinstall_command,
317
303
  long: "--bootstrap-preinstall-command COMMANDS",
318
- description: "Custom commands to run before installing #{Chef::Dist::PRODUCT}.",
319
- proc: Proc.new { |preic| Chef::Config[:knife][:bootstrap_preinstall_command] = preic }
304
+ description: "Custom commands to run before installing #{Chef::Dist::PRODUCT}."
320
305
 
321
306
  # bootstrap template
322
307
  option :bootstrap_wget_options,
323
308
  long: "--bootstrap-wget-options OPTIONS",
324
- description: "Add options to wget when installing #{Chef::Dist::PRODUCT}.",
325
- proc: Proc.new { |wo| Chef::Config[:knife][:bootstrap_wget_options] = wo }
309
+ description: "Add options to wget when installing #{Chef::Dist::PRODUCT}."
326
310
 
327
311
  # bootstrap template
328
312
  option :bootstrap_curl_options,
329
313
  long: "--bootstrap-curl-options OPTIONS",
330
- description: "Add options to curl when install #{Chef::Dist::PRODUCT}.",
331
- proc: Proc.new { |co| Chef::Config[:knife][:bootstrap_curl_options] = co }
314
+ description: "Add options to curl when install #{Chef::Dist::PRODUCT}."
332
315
 
333
316
  # chef_vault_handler
334
317
  option :bootstrap_vault_file,
@@ -344,12 +327,12 @@ class Chef
344
327
  option :bootstrap_vault_item,
345
328
  long: "--bootstrap-vault-item VAULT_ITEM",
346
329
  description: 'A single vault and item to update as "vault:item".',
347
- proc: Proc.new { |i|
330
+ proc: Proc.new { |i, accumulator|
348
331
  (vault, item) = i.split(/:/)
349
- Chef::Config[:knife][:bootstrap_vault_item] ||= {}
350
- Chef::Config[:knife][:bootstrap_vault_item][vault] ||= []
351
- Chef::Config[:knife][:bootstrap_vault_item][vault].push(item)
352
- Chef::Config[:knife][:bootstrap_vault_item]
332
+ accumulator ||= {}
333
+ accumulator[vault] ||= []
334
+ accumulator[vault].push(item)
335
+ accumulator
353
336
  }
354
337
 
355
338
  # Deprecated options. These must be declared after
@@ -434,14 +417,14 @@ class Chef
434
417
  def client_builder
435
418
  @client_builder ||= Chef::Knife::Bootstrap::ClientBuilder.new(
436
419
  chef_config: Chef::Config,
437
- knife_config: config,
420
+ config: config,
438
421
  ui: ui
439
422
  )
440
423
  end
441
424
 
442
425
  def chef_vault_handler
443
426
  @chef_vault_handler ||= Chef::Knife::Bootstrap::ChefVaultHandler.new(
444
- knife_config: config,
427
+ config: config,
445
428
  ui: ui
446
429
  )
447
430
  end
@@ -466,7 +449,7 @@ class Chef
466
449
  # @return [String] Default bootstrap template
467
450
  def default_bootstrap_template
468
451
  if connection.windows?
469
- "windows-#{Chef::Dist::CLIENT}-msi"
452
+ "windows-chef-client-msi"
470
453
  else
471
454
  "chef-full"
472
455
  end
@@ -686,9 +669,8 @@ class Chef
686
669
  return @connection_protocol if @connection_protocol
687
670
 
688
671
  from_url = host_descriptor =~ %r{^(.*)://} ? $1 : nil
689
- from_cli = config[:connection_protocol]
690
- from_knife = Chef::Config[:knife][:connection_protocol]
691
- @connection_protocol = from_url || from_cli || from_knife || "ssh"
672
+ from_knife = config[:connection_protocol]
673
+ @connection_protocol = from_url || from_knife || "ssh"
692
674
  end
693
675
 
694
676
  def do_connect(conn_options)
@@ -724,16 +706,20 @@ class Chef
724
706
  true
725
707
  end
726
708
 
709
+ def winrm_auth_method
710
+ config_value(:winrm_auth_method, :winrm_authentication_protocol, "negotiate")
711
+ end
712
+
727
713
  # Fail if using plaintext auth without ssl because
728
714
  # this can expose keys in plaintext on the wire.
729
715
  # TODO test for this method
730
- # TODO check that the protoocol is valid.
716
+ # TODO check that the protocol is valid.
731
717
  def validate_winrm_transport_opts!
732
718
  return true unless winrm?
733
719
 
734
720
  if Chef::Config[:validation_key] && !File.exist?(File.expand_path(Chef::Config[:validation_key]))
735
- if config_value(:winrm_auth_method) == "plaintext" &&
736
- config_value(:winrm_ssl) != true
721
+ if winrm_auth_method == "plaintext" &&
722
+ config[:winrm_ssl] != true
737
723
  ui.error <<~EOM
738
724
  Validatorless bootstrap over unsecure winrm channels could expose your
739
725
  key to network sniffing.
@@ -857,9 +843,9 @@ class Chef
857
843
  # Reference:
858
844
  # https://github.com/chef/knife-windows/blob/92d151298142be4a4750c5b54bb264f8d5b81b8a/lib/chef/knife/winrm_knife_base.rb#L271-L273
859
845
  # TODO Seems like we should also do a similar warning if ssh_verify_host == false
860
- if config_value(:ca_trust_file).nil? &&
861
- config_value(:winrm_no_verify_cert) &&
862
- config_value(:winrm_ssl_peer_fingerprint).nil?
846
+ if config[:ca_trust_file].nil? &&
847
+ config[:winrm_no_verify_cert] &&
848
+ config[:winrm_ssl_peer_fingerprint].nil?
863
849
  ui.warn <<~WARN
864
850
  * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
865
851
  SSL validation of HTTPS requests for the WinRM transport is disabled.
@@ -905,16 +891,13 @@ class Chef
905
891
 
906
892
  # Common configuration for all protocols
907
893
  def base_opts
908
- port = config_value(:connection_port,
909
- knife_key_for_protocol(connection_protocol, :port))
910
- user = config_value(:connection_user,
911
- knife_key_for_protocol(connection_protocol, :user))
894
+ port = config_for_protocol(:port)
895
+ user = config_for_protocol(:user)
912
896
  {}.tap do |opts|
913
897
  opts[:logger] = Chef::Log
914
- # We do not store password in Chef::Config, so only use CLI `config` here
915
898
  opts[:password] = config[:connection_password] if config.key?(:connection_password)
916
899
  opts[:user] = user if user
917
- opts[:max_wait_until_ready] = config_value(:max_wait).to_f unless config_value(:max_wait).nil?
900
+ opts[:max_wait_until_ready] = config[:max_wait].to_f unless config[:max_wait].nil?
918
901
  # TODO - when would we need to provide rdp_port vs port? Or are they not mutually exclusive?
919
902
  opts[:port] = port if port
920
903
  end
@@ -922,7 +905,7 @@ class Chef
922
905
 
923
906
  def host_verify_opts
924
907
  if winrm?
925
- { self_signed: config_value(:winrm_no_verify_cert) === true }
908
+ { self_signed: config[:winrm_no_verify_cert] === true }
926
909
  elsif ssh?
927
910
  # Fall back to the old knife config key name for back compat.
928
911
  { verify_host_key: config_value(:ssh_verify_host_key, :host_key_verify, "always") }
@@ -936,7 +919,7 @@ class Chef
936
919
  return opts if winrm?
937
920
 
938
921
  opts[:non_interactive] = true # Prevent password prompts from underlying net/ssh
939
- opts[:forward_agent] = (config_value(:ssh_forward_agent) === true)
922
+ opts[:forward_agent] = (config[:ssh_forward_agent] === true)
940
923
  opts[:connection_timeout] = session_timeout
941
924
  opts
942
925
  end
@@ -945,7 +928,7 @@ class Chef
945
928
  opts = {}
946
929
  return opts if winrm?
947
930
 
948
- identity_file = config_value(:ssh_identity_file)
931
+ identity_file = config[:ssh_identity_file]
949
932
  if identity_file
950
933
  opts[:key_files] = [identity_file]
951
934
  # We only set keys_only based on the explicit ssh_identity_file;
@@ -965,7 +948,7 @@ class Chef
965
948
  opts[:keys_only] = false
966
949
  end
967
950
 
968
- gateway_identity_file = config_value(:ssh_gateway) ? config_value(:ssh_gateway_identity) : nil
951
+ gateway_identity_file = config[:ssh_gateway] ? config[:ssh_gateway_identity] : nil
969
952
  unless gateway_identity_file.nil?
970
953
  opts[:key_files] << gateway_identity_file
971
954
  end
@@ -975,8 +958,8 @@ class Chef
975
958
 
976
959
  def gateway_opts
977
960
  opts = {}
978
- if config_value(:ssh_gateway)
979
- split = config_value(:ssh_gateway).split("@", 2)
961
+ if config[:ssh_gateway]
962
+ split = config[:ssh_gateway].split("@", 2)
980
963
  if split.length == 1
981
964
  gw_host = split[0]
982
965
  else
@@ -984,7 +967,7 @@ class Chef
984
967
  gw_host = split[1]
985
968
  end
986
969
  gw_host, gw_port = gw_host.split(":", 2)
987
- # TODO - validate convertable port in config validation?
970
+ # TODO - validate convertible port in config validation?
988
971
  gw_port = Integer(gw_port) rescue nil
989
972
  opts[:bastion_host] = gw_host
990
973
  opts[:bastion_user] = gw_user
@@ -1022,21 +1005,20 @@ class Chef
1022
1005
  def winrm_opts
1023
1006
  return {} unless winrm?
1024
1007
 
1025
- auth_method = config_value(:winrm_auth_method, :winrm_auth_method, "negotiate")
1026
1008
  opts = {
1027
- winrm_transport: auth_method, # winrm gem and train calls auth method 'transport'
1028
- winrm_basic_auth_only: config_value(:winrm_basic_auth_only) || false,
1029
- ssl: config_value(:winrm_ssl) === true,
1030
- ssl_peer_fingerprint: config_value(:winrm_ssl_peer_fingerprint),
1009
+ winrm_transport: winrm_auth_method, # winrm gem and train calls auth method 'transport'
1010
+ winrm_basic_auth_only: config[:winrm_basic_auth_only] || false,
1011
+ ssl: config[:winrm_ssl] === true,
1012
+ ssl_peer_fingerprint: config[:winrm_ssl_peer_fingerprint],
1031
1013
  }
1032
1014
 
1033
- if auth_method == "kerberos"
1034
- opts[:kerberos_service] = config_value(:kerberos_service) if config_value(:kerberos_service)
1035
- opts[:kerberos_realm] = config_value(:kerberos_realm) if config_value(:kerberos_service)
1015
+ if winrm_auth_method == "kerberos"
1016
+ opts[:kerberos_service] = config[:kerberos_service] if config[:kerberos_service]
1017
+ opts[:kerberos_realm] = config[:kerberos_realm] if config[:kerberos_service]
1036
1018
  end
1037
1019
 
1038
- if config_value(:ca_trust_file)
1039
- opts[:ca_trust_path] = config_value(:ca_trust_file)
1020
+ if config[:ca_trust_file]
1021
+ opts[:ca_trust_path] = config[:ca_trust_file]
1040
1022
  end
1041
1023
 
1042
1024
  opts[:operation_timeout] = session_timeout
@@ -1061,17 +1043,18 @@ class Chef
1061
1043
  }
1062
1044
  end
1063
1045
 
1064
- # Knife plugins should just use the config hash and not call this method. In the
1065
- # future there will be a way to deprecate Chef::Config options in addition to the
1066
- # CLI options, which will eliminate this methods primary purpose.
1046
+ # This is for deprecating config options. The fallback_key can be used
1047
+ # to pull an old knife config option out of the config file when the
1048
+ # cli value has been renamed. This is different from the deprecated
1049
+ # cli values, since these are for config options that have no corresponding
1050
+ # cli value.
1067
1051
  #
1068
- # In Chef-16 the single-argument verison of this function will be deprecated and
1069
- # config_value(:whatver) should be converted to config[:whatever]. That never had
1070
- # any purpose and never should have been used this way.
1052
+ # DO NOT USE - this whole API is considered deprecated
1071
1053
  #
1072
1054
  # @api deprecated
1073
1055
  #
1074
1056
  def config_value(key, fallback_key = nil, default = nil)
1057
+ Chef.deprecated(:knife_bootstrap_apis, "Use of config_value without a fallback_key is deprecated. Knife plugin authors should access the config hash directly, which does correct merging of cli and config options.") if fallback_key.nil?
1075
1058
  if config.key?(key)
1076
1059
  # the first key is the primary key so we check the merged hash first
1077
1060
  config[key]
@@ -1090,7 +1073,7 @@ class Chef
1090
1073
  remote_path
1091
1074
  end
1092
1075
 
1093
- # build the command string for bootrapping
1076
+ # build the command string for bootstrapping
1094
1077
  # @return String
1095
1078
  def bootstrap_command(remote_path)
1096
1079
  if connection.windows?
@@ -1100,6 +1083,8 @@ class Chef
1100
1083
  end
1101
1084
  end
1102
1085
 
1086
+ private
1087
+
1103
1088
  # To avoid cluttering the CLI options, some flags (such as port and user)
1104
1089
  # are shared between protocols. However, there is still a need to allow the operator
1105
1090
  # to specify defaults separately, since they may not be the same values for different
@@ -1108,11 +1093,20 @@ class Chef
1108
1093
  # These keys are available in Chef::Config, and are prefixed with the protocol name.
1109
1094
  # For example, :user CLI option will map to :winrm_user and :ssh_user Chef::Config keys,
1110
1095
  # based on the connection protocol in use.
1111
- def knife_key_for_protocol(protocol, option)
1112
- "#{connection_protocol}_#{option}".to_sym
1096
+
1097
+ # @api private
1098
+ def config_for_protocol(option)
1099
+ if option == :port
1100
+ config[:connection_port] || config[knife_key_for_protocol(option)]
1101
+ else
1102
+ config[:connection_user] || config[knife_key_for_protocol(option)]
1103
+ end
1113
1104
  end
1114
1105
 
1115
- private
1106
+ # @api private
1107
+ def knife_key_for_protocol(option)
1108
+ "#{connection_protocol}_#{option}".to_sym
1109
+ end
1116
1110
 
1117
1111
  # True if policy_name and run_list are both given
1118
1112
  def policyfile_and_run_list_given?
@@ -1135,7 +1129,7 @@ class Chef
1135
1129
  # session_timeout option has a default that may not arrive, particularly if
1136
1130
  # we're being invoked from a plugin that doesn't merge_config.
1137
1131
  def session_timeout
1138
- timeout = config_value(:session_timeout)
1132
+ timeout = config[:session_timeout]
1139
1133
  return options[:session_timeout][:default] if timeout.nil?
1140
1134
 
1141
1135
  timeout.to_i