chef 16.3.38-universal-mingw32 → 16.5.64-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 (405) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +1 -1
  3. data/Rakefile +2 -2
  4. data/bin/knife +1 -1
  5. data/chef-universal-mingw32.gemspec +0 -1
  6. data/chef.gemspec +2 -1
  7. data/distro/templates/powershell/chef/chef.psm1.erb +18 -18
  8. data/ext/win32-eventlog/Rakefile +2 -2
  9. data/ext/win32-eventlog/chef-log.man.erb +4 -4
  10. data/lib/chef/action_collection.rb +4 -0
  11. data/lib/chef/api_client/registration.rb +2 -2
  12. data/lib/chef/application.rb +19 -17
  13. data/lib/chef/application/apply.rb +17 -12
  14. data/lib/chef/application/base.rb +26 -23
  15. data/lib/chef/application/client.rb +10 -4
  16. data/lib/chef/application/exit_code.rb +13 -4
  17. data/lib/chef/application/knife.rb +22 -11
  18. data/lib/chef/application/solo.rb +2 -1
  19. data/lib/chef/application/windows_service.rb +39 -39
  20. data/lib/chef/application/windows_service_manager.rb +6 -6
  21. data/lib/chef/chef_class.rb +0 -1
  22. data/lib/chef/chef_fs/chef_fs_data_store.rb +54 -54
  23. data/lib/chef/chef_fs/file_system/chef_server/acl_entry.rb +10 -10
  24. data/lib/chef/chef_fs/file_system/chef_server/organization_invites_entry.rb +8 -8
  25. data/lib/chef/chef_fs/file_system/chef_server/organization_members_entry.rb +8 -8
  26. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_dir.rb +2 -2
  27. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +1 -1
  28. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +18 -18
  29. data/lib/chef/chef_fs/file_system/repository/directory.rb +1 -1
  30. data/lib/chef/chef_fs/file_system/repository/file_system_entry.rb +1 -1
  31. data/lib/chef/chef_fs/knife.rb +2 -2
  32. data/lib/chef/chef_fs/parallelizer.rb +0 -1
  33. data/lib/chef/client.rb +21 -22
  34. data/lib/chef/cookbook/cookbook_version_loader.rb +1 -1
  35. data/lib/chef/cookbook/synchronizer.rb +2 -2
  36. data/lib/chef/cookbook_site_streaming_uploader.rb +13 -11
  37. data/lib/chef/cookbook_uploader.rb +1 -1
  38. data/lib/chef/data_collector.rb +6 -5
  39. data/lib/chef/data_collector/config_validation.rb +22 -13
  40. data/lib/chef/data_collector/run_end_message.rb +13 -3
  41. data/lib/chef/data_collector/run_start_message.rb +1 -1
  42. data/lib/chef/deprecated.rb +1 -1
  43. data/lib/chef/deprecation/warnings.rb +2 -2
  44. data/lib/chef/digester.rb +2 -2
  45. data/lib/chef/dsl/chef_vault.rb +1 -1
  46. data/lib/chef/dsl/data_query.rb +2 -2
  47. data/lib/chef/dsl/platform_introspection.rb +9 -9
  48. data/lib/chef/encrypted_data_bag_item.rb +3 -4
  49. data/lib/chef/encrypted_data_bag_item/decryptor.rb +3 -3
  50. data/lib/chef/encrypted_data_bag_item/encryptor.rb +3 -3
  51. data/lib/chef/environment.rb +4 -4
  52. data/lib/chef/event_loggers/windows_eventlog.rb +2 -2
  53. data/lib/chef/exceptions.rb +5 -5
  54. data/lib/chef/file_access_control/windows.rb +5 -1
  55. data/lib/chef/file_content_management/tempfile.rb +9 -9
  56. data/lib/chef/formatters/doc.rb +7 -6
  57. data/lib/chef/formatters/error_inspectors/api_error_formatting.rb +6 -5
  58. data/lib/chef/formatters/error_inspectors/node_load_error_inspector.rb +3 -3
  59. data/lib/chef/formatters/error_inspectors/registration_error_inspector.rb +9 -9
  60. data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +2 -2
  61. data/lib/chef/formatters/error_inspectors/run_list_expansion_error_inspector.rb +3 -3
  62. data/lib/chef/formatters/minimal.rb +5 -4
  63. data/lib/chef/handler.rb +2 -0
  64. data/lib/chef/http.rb +15 -13
  65. data/lib/chef/http/auth_credentials.rb +5 -1
  66. data/lib/chef/http/authenticator.rb +3 -1
  67. data/lib/chef/http/basic_client.rb +4 -2
  68. data/lib/chef/http/decompressor.rb +1 -1
  69. data/lib/chef/http/http_request.rb +7 -5
  70. data/lib/chef/http/socketless_chef_zero_client.rb +5 -2
  71. data/lib/chef/http/ssl_policies.rb +1 -1
  72. data/lib/chef/json_compat.rb +2 -2
  73. data/lib/chef/knife.rb +4 -4
  74. data/lib/chef/knife/bootstrap.rb +18 -16
  75. data/lib/chef/knife/bootstrap/chef_vault_handler.rb +1 -1
  76. data/lib/chef/knife/bootstrap/templates/chef-full.erb +3 -3
  77. data/lib/chef/knife/bootstrap/templates/windows-chef-client-msi.erb +7 -7
  78. data/lib/chef/knife/client_create.rb +3 -3
  79. data/lib/chef/knife/config_get.rb +8 -97
  80. data/lib/chef/knife/config_get_profile.rb +9 -9
  81. data/lib/chef/knife/config_list.rb +139 -0
  82. data/lib/chef/knife/config_list_profiles.rb +8 -98
  83. data/lib/chef/knife/config_show.rb +127 -0
  84. data/lib/chef/knife/config_use.rb +61 -0
  85. data/lib/chef/knife/config_use_profile.rb +9 -24
  86. data/lib/chef/knife/configure.rb +4 -2
  87. data/lib/chef/knife/cookbook_download.rb +1 -1
  88. data/lib/chef/knife/cookbook_metadata.rb +1 -1
  89. data/lib/chef/knife/cookbook_upload.rb +23 -23
  90. data/lib/chef/knife/core/bootstrap_context.rb +2 -2
  91. data/lib/chef/knife/core/generic_presenter.rb +1 -1
  92. data/lib/chef/knife/core/hashed_command_loader.rb +2 -2
  93. data/lib/chef/knife/core/object_loader.rb +1 -1
  94. data/lib/chef/knife/core/windows_bootstrap_context.rb +42 -34
  95. data/lib/chef/knife/delete.rb +15 -15
  96. data/lib/chef/knife/exec.rb +4 -4
  97. data/lib/chef/knife/node_show.rb +2 -2
  98. data/lib/chef/knife/serve.rb +3 -3
  99. data/lib/chef/knife/ssh.rb +22 -7
  100. data/lib/chef/knife/ssl_check.rb +3 -3
  101. data/lib/chef/knife/status.rb +2 -2
  102. data/lib/chef/knife/user_create.rb +2 -2
  103. data/lib/chef/knife/xargs.rb +19 -19
  104. data/lib/chef/knife/yaml_convert.rb +1 -1
  105. data/lib/chef/local_mode.rb +2 -2
  106. data/lib/chef/log/syslog.rb +2 -2
  107. data/lib/chef/log/winevt.rb +2 -2
  108. data/lib/chef/mixin/checksum.rb +0 -1
  109. data/lib/chef/mixin/deep_merge.rb +35 -18
  110. data/lib/chef/mixin/openssl_helper.rb +4 -5
  111. data/lib/chef/mixin/shell_out.rb +1 -1
  112. data/lib/chef/mixin/template.rb +2 -2
  113. data/lib/chef/mixin/uris.rb +2 -2
  114. data/lib/chef/mixin/versioned_api.rb +1 -2
  115. data/lib/chef/mixin/which.rb +1 -1
  116. data/lib/chef/monkey_patches/net_http.rb +4 -4
  117. data/lib/chef/monkey_patches/webrick-utils.rb +10 -10
  118. data/lib/chef/node/attribute.rb +2 -4
  119. data/lib/chef/node_map.rb +2 -2
  120. data/lib/chef/platform/service_helpers.rb +1 -1
  121. data/lib/chef/policy_builder/policyfile.rb +2 -2
  122. data/lib/chef/property.rb +1 -1
  123. data/lib/chef/provider.rb +0 -4
  124. data/lib/chef/provider/cron/unix.rb +0 -2
  125. data/lib/chef/provider/file.rb +2 -2
  126. data/lib/chef/provider/git.rb +5 -5
  127. data/lib/chef/provider/group.rb +0 -2
  128. data/lib/chef/provider/group/suse.rb +5 -5
  129. data/lib/chef/provider/ifconfig.rb +1 -4
  130. data/lib/chef/provider/launchd.rb +2 -2
  131. data/lib/chef/provider/mount.rb +0 -2
  132. data/lib/chef/provider/mount/linux.rb +63 -0
  133. data/lib/chef/provider/package.rb +0 -2
  134. data/lib/chef/provider/package/rubygems.rb +22 -19
  135. data/lib/chef/provider/package/snap.rb +1 -2
  136. data/lib/chef/provider/package/windows.rb +2 -2
  137. data/lib/chef/provider/package/windows/registry_uninstall_entry.rb +12 -10
  138. data/lib/chef/provider/package/zypper.rb +1 -1
  139. data/lib/chef/provider/powershell_script.rb +21 -5
  140. data/lib/chef/provider/remote_file/content.rb +3 -0
  141. data/lib/chef/provider/remote_file/ftp.rb +6 -4
  142. data/lib/chef/provider/remote_file/sftp.rb +6 -4
  143. data/lib/chef/provider/route.rb +2 -6
  144. data/lib/chef/provider/service/arch.rb +1 -1
  145. data/lib/chef/provider/service/debian.rb +1 -1
  146. data/lib/chef/provider/service/gentoo.rb +2 -2
  147. data/lib/chef/provider/service/macosx.rb +4 -4
  148. data/lib/chef/provider/service/openbsd.rb +1 -4
  149. data/lib/chef/provider/service/redhat.rb +2 -2
  150. data/lib/chef/provider/service/upstart.rb +1 -1
  151. data/lib/chef/provider/service/windows.rb +10 -10
  152. data/lib/chef/provider/systemd_unit.rb +0 -2
  153. data/lib/chef/provider/template/content.rb +1 -0
  154. data/lib/chef/provider/template_finder.rb +2 -10
  155. data/lib/chef/provider/user/dscl.rb +5 -5
  156. data/lib/chef/provider/user/mac.rb +10 -10
  157. data/lib/chef/provider/windows_task.rb +1 -5
  158. data/lib/chef/provider/zypper_repository.rb +2 -3
  159. data/lib/chef/provider_resolver.rb +1 -1
  160. data/lib/chef/providers.rb +1 -1
  161. data/lib/chef/recipe.rb +2 -2
  162. data/lib/chef/resource.rb +7 -11
  163. data/lib/chef/resource/apt_repository.rb +2 -11
  164. data/lib/chef/resource/bff_package.rb +22 -0
  165. data/lib/chef/resource/breakpoint.rb +57 -2
  166. data/lib/chef/resource/build_essential.rb +1 -1
  167. data/lib/chef/resource/cab_package.rb +29 -0
  168. data/lib/chef/resource/chef_client_cron.rb +32 -25
  169. data/lib/chef/resource/chef_client_launchd.rb +194 -0
  170. data/lib/chef/resource/chef_client_scheduled_task.rb +21 -18
  171. data/lib/chef/resource/chef_client_systemd_timer.rb +26 -19
  172. data/lib/chef/resource/chef_client_trusted_certificate.rb +101 -0
  173. data/lib/chef/resource/chef_gem.rb +10 -10
  174. data/lib/chef/resource/chef_handler.rb +148 -4
  175. data/lib/chef/resource/chef_sleep.rb +2 -2
  176. data/lib/chef/resource/chef_vault_secret.rb +14 -14
  177. data/lib/chef/resource/cookbook_file.rb +2 -2
  178. data/lib/chef/resource/cron/cron_d.rb +0 -1
  179. data/lib/chef/resource/dnf_package.rb +2 -2
  180. data/lib/chef/resource/dsc_resource.rb +0 -1
  181. data/lib/chef/resource/dsc_script.rb +2 -2
  182. data/lib/chef/resource/execute.rb +8 -9
  183. data/lib/chef/resource/file.rb +4 -4
  184. data/lib/chef/resource/gem_package.rb +5 -5
  185. data/lib/chef/resource/homebrew_package.rb +3 -3
  186. data/lib/chef/resource/homebrew_update.rb +7 -7
  187. data/lib/chef/resource/hostname.rb +19 -19
  188. data/lib/chef/resource/launchd.rb +2 -1
  189. data/lib/chef/resource/locale.rb +2 -2
  190. data/lib/chef/resource/macos_userdefaults.rb +3 -3
  191. data/lib/chef/resource/notify_group.rb +0 -1
  192. data/lib/chef/resource/ohai.rb +46 -3
  193. data/lib/chef/resource/ohai_hint.rb +33 -0
  194. data/lib/chef/resource/openssl_dhparam.rb +29 -5
  195. data/lib/chef/resource/openssl_ec_private_key.rb +8 -3
  196. data/lib/chef/resource/openssl_ec_public_key.rb +4 -2
  197. data/lib/chef/resource/openssl_rsa_private_key.rb +8 -3
  198. data/lib/chef/resource/openssl_rsa_public_key.rb +2 -0
  199. data/lib/chef/resource/openssl_x509_certificate.rb +38 -35
  200. data/lib/chef/resource/openssl_x509_crl.rb +21 -10
  201. data/lib/chef/resource/openssl_x509_request.rb +37 -36
  202. data/lib/chef/resource/osx_profile.rb +292 -6
  203. data/lib/chef/resource/plist.rb +1 -1
  204. data/lib/chef/resource/powershell_package_source.rb +6 -6
  205. data/lib/chef/resource/powershell_script.rb +24 -30
  206. data/lib/chef/resource/reboot.rb +2 -2
  207. data/lib/chef/resource/remote_file.rb +3 -3
  208. data/lib/chef/resource/rhsm_register.rb +22 -10
  209. data/lib/chef/resource/ruby_block.rb +2 -2
  210. data/lib/chef/resource/scm/subversion.rb +2 -2
  211. data/lib/chef/resource/service.rb +3 -3
  212. data/lib/chef/resource/ssh_known_hosts_entry.rb +2 -2
  213. data/lib/chef/resource/sudo.rb +1 -1
  214. data/lib/chef/resource/support/cron.d.erb +1 -1
  215. data/lib/chef/resource/support/cron_access.erb +1 -1
  216. data/lib/chef/resource/support/sudoer.erb +1 -1
  217. data/lib/chef/resource/support/ulimit.erb +1 -1
  218. data/lib/chef/resource/sysctl.rb +6 -10
  219. data/lib/chef/resource/systemd_unit.rb +2 -2
  220. data/lib/chef/resource/template.rb +2 -2
  221. data/lib/chef/resource/timezone.rb +112 -73
  222. data/lib/chef/resource/windows_ad_join.rb +12 -3
  223. data/lib/chef/resource/windows_audit_policy.rb +3 -0
  224. data/lib/chef/resource/windows_auto_run.rb +2 -0
  225. data/lib/chef/resource/windows_certificate.rb +8 -4
  226. data/lib/chef/resource/windows_dfs_folder.rb +2 -0
  227. data/lib/chef/resource/windows_dfs_namespace.rb +2 -0
  228. data/lib/chef/resource/windows_dfs_server.rb +2 -0
  229. data/lib/chef/resource/windows_dns_record.rb +10 -7
  230. data/lib/chef/resource/windows_dns_zone.rb +12 -7
  231. data/lib/chef/resource/windows_feature.rb +2 -0
  232. data/lib/chef/resource/windows_feature_dism.rb +10 -0
  233. data/lib/chef/resource/windows_feature_powershell.rb +14 -2
  234. data/lib/chef/resource/windows_firewall_profile.rb +24 -20
  235. data/lib/chef/resource/windows_firewall_rule.rb +5 -3
  236. data/lib/chef/resource/windows_font.rb +3 -1
  237. data/lib/chef/resource/windows_package.rb +28 -5
  238. data/lib/chef/resource/windows_pagefile.rb +4 -0
  239. data/lib/chef/resource/windows_printer.rb +22 -21
  240. data/lib/chef/resource/windows_printer_port.rb +20 -17
  241. data/lib/chef/resource/windows_security_policy.rb +2 -0
  242. data/lib/chef/resource/windows_share.rb +5 -3
  243. data/lib/chef/resource/windows_shortcut.rb +2 -0
  244. data/lib/chef/resource/windows_uac.rb +2 -0
  245. data/lib/chef/resource/windows_user_privilege.rb +54 -53
  246. data/lib/chef/resource/windows_workgroup.rb +5 -6
  247. data/lib/chef/resource/yum_package.rb +2 -2
  248. data/lib/chef/resource_collection/stepable_iterator.rb +1 -2
  249. data/lib/chef/resources.rb +3 -1
  250. data/lib/chef/role.rb +2 -2
  251. data/lib/chef/run_context.rb +2 -2
  252. data/lib/chef/run_context/cookbook_compiler.rb +21 -21
  253. data/lib/chef/run_lock.rb +2 -2
  254. data/lib/chef/run_status.rb +2 -6
  255. data/lib/chef/search/query.rb +4 -5
  256. data/lib/chef/server_api_versions.rb +4 -0
  257. data/lib/chef/shell.rb +32 -27
  258. data/lib/chef/shell/ext.rb +11 -11
  259. data/lib/chef/shell/shell_session.rb +2 -2
  260. data/lib/chef/train_transport.rb +5 -104
  261. data/lib/chef/util/backup.rb +1 -1
  262. data/lib/chef/util/diff.rb +14 -14
  263. data/lib/chef/util/powershell/cmdlet.rb +4 -2
  264. data/lib/chef/util/powershell/ps_credential.rb +18 -14
  265. data/lib/chef/util/threaded_job_queue.rb +0 -2
  266. data/lib/chef/version.rb +1 -1
  267. data/lib/chef/win32/crypto.rb +1 -1
  268. data/lib/chef/win32/file.rb +2 -2
  269. data/lib/chef/win32/file/version_info.rb +5 -5
  270. data/lib/chef/win32/registry.rb +1 -2
  271. data/spec/data/shef-config.rb +1 -1
  272. data/spec/data/ssl/chef-rspec.cert +15 -15
  273. data/spec/functional/event_loggers/windows_eventlog_spec.rb +6 -5
  274. data/spec/functional/resource/aix_service_spec.rb +2 -2
  275. data/spec/functional/resource/aixinit_service_spec.rb +8 -8
  276. data/spec/functional/resource/bff_spec.rb +2 -2
  277. data/spec/functional/resource/cookbook_file_spec.rb +1 -1
  278. data/spec/functional/resource/dsc_resource_spec.rb +1 -1
  279. data/spec/functional/resource/dsc_script_spec.rb +0 -1
  280. data/spec/functional/resource/group_spec.rb +6 -6
  281. data/spec/functional/resource/insserv_spec.rb +5 -5
  282. data/spec/functional/resource/link_spec.rb +20 -20
  283. data/spec/functional/resource/powershell_script_spec.rb +4 -4
  284. data/spec/functional/resource/rpm_spec.rb +2 -2
  285. data/spec/functional/resource/user/dscl_spec.rb +1 -1
  286. data/spec/functional/resource/user/mac_user_spec.rb +1 -1
  287. data/spec/functional/resource/windows_certificate_spec.rb +3 -3
  288. data/spec/functional/resource/windows_font_spec.rb +49 -0
  289. data/spec/functional/resource/windows_security_policy_spec.rb +0 -3
  290. data/spec/functional/resource/windows_task_spec.rb +13 -13
  291. data/spec/functional/run_lock_spec.rb +24 -24
  292. data/spec/functional/version_spec.rb +3 -3
  293. data/spec/functional/win32/registry_spec.rb +8 -8
  294. data/spec/functional/win32/service_manager_spec.rb +1 -1
  295. data/spec/integration/client/client_spec.rb +4 -4
  296. data/spec/integration/client/exit_code_spec.rb +3 -2
  297. data/spec/integration/client/ipv6_spec.rb +1 -1
  298. data/spec/integration/knife/common_options_spec.rb +12 -12
  299. data/spec/integration/knife/config_list_spec.rb +220 -0
  300. data/spec/integration/knife/config_show_spec.rb +192 -0
  301. data/spec/integration/knife/config_use_spec.rb +198 -0
  302. data/spec/integration/knife/cookbook_api_ipv6_spec.rb +1 -1
  303. data/spec/integration/knife/diff_spec.rb +3 -1
  304. data/spec/integration/knife/download_spec.rb +3 -1
  305. data/spec/integration/knife/serve_spec.rb +5 -5
  306. data/spec/integration/knife/upload_spec.rb +3 -1
  307. data/spec/integration/ohai/ohai_spec.rb +61 -0
  308. data/spec/integration/recipes/lwrp_inline_resources_spec.rb +1 -1
  309. data/spec/integration/recipes/remote_directory.rb +1 -1
  310. data/spec/integration/solo/solo_spec.rb +5 -5
  311. data/spec/spec_helper.rb +12 -9
  312. data/spec/stress/win32/file_spec.rb +1 -1
  313. data/spec/support/chef_helpers.rb +2 -2
  314. data/spec/support/matchers/leak.rb +2 -2
  315. data/spec/support/platform_helpers.rb +17 -35
  316. data/spec/support/platforms/win32/spec_service.rb +1 -1
  317. data/spec/support/shared/functional/directory_resource.rb +1 -1
  318. data/spec/support/shared/functional/execute_resource.rb +1 -1
  319. data/spec/support/shared/functional/file_resource.rb +20 -20
  320. data/spec/support/shared/functional/securable_resource.rb +108 -27
  321. data/spec/support/shared/functional/win32_service.rb +2 -2
  322. data/spec/support/shared/functional/windows_script.rb +3 -3
  323. data/spec/support/shared/integration/integration_helper.rb +22 -52
  324. data/spec/support/shared/unit/application_dot_d.rb +5 -3
  325. data/spec/support/shared/unit/script_resource.rb +6 -20
  326. data/spec/support/shared/unit/windows_script_resource.rb +15 -28
  327. data/spec/tiny_server.rb +0 -1
  328. data/spec/unit/application/client_spec.rb +2 -2
  329. data/spec/unit/application/exit_code_spec.rb +10 -0
  330. data/spec/unit/application_spec.rb +4 -6
  331. data/spec/unit/chef_fs/parallelizer_spec.rb +5 -1
  332. data/spec/unit/chef_fs/path_util_spec.rb +1 -1
  333. data/spec/unit/cookbook/synchronizer_spec.rb +2 -2
  334. data/spec/unit/cookbook_spec.rb +2 -2
  335. data/spec/unit/data_collector/config_validation_spec.rb +208 -0
  336. data/spec/unit/data_collector_spec.rb +28 -113
  337. data/spec/unit/dsl/declare_resource_spec.rb +1 -1
  338. data/spec/unit/environment_spec.rb +7 -7
  339. data/spec/unit/file_access_control_spec.rb +1 -1
  340. data/spec/unit/http/api_versions_spec.rb +19 -1
  341. data/spec/unit/knife/bootstrap_spec.rb +20 -20
  342. data/spec/unit/knife/cookbook_download_spec.rb +4 -4
  343. data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +1 -1
  344. data/spec/unit/knife/core/hashed_command_loader_spec.rb +3 -3
  345. data/spec/unit/knife/core/ui_spec.rb +1 -0
  346. data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +21 -12
  347. data/spec/unit/knife/ssh_spec.rb +2 -2
  348. data/spec/unit/knife/supermarket_share_spec.rb +1 -1
  349. data/spec/unit/lwrp_spec.rb +3 -3
  350. data/spec/unit/mixin/deep_merge_spec.rb +15 -0
  351. data/spec/unit/mixin/openssl_helper_spec.rb +1 -1
  352. data/spec/unit/mixin/powershell_exec_spec.rb +1 -1
  353. data/spec/unit/mixin/securable_spec.rb +2 -2
  354. data/spec/unit/mixin/template_spec.rb +30 -30
  355. data/spec/unit/mixin/windows_architecture_helper_spec.rb +4 -4
  356. data/spec/unit/node/immutable_collections_spec.rb +8 -4
  357. data/spec/unit/node_spec.rb +5 -5
  358. data/spec/unit/provider/mount/linux_spec.rb +97 -0
  359. data/spec/unit/provider/package/chocolatey_spec.rb +1 -1
  360. data/spec/unit/provider/package/powershell_spec.rb +1 -1
  361. data/spec/unit/provider/package/rubygems_spec.rb +4 -1
  362. data/spec/unit/provider/powershell_script_spec.rb +11 -4
  363. data/spec/unit/provider/remote_directory_spec.rb +9 -9
  364. data/spec/unit/provider/route_spec.rb +0 -2
  365. data/spec/unit/provider/service/arch_service_spec.rb +3 -2
  366. data/spec/unit/provider/service/debian_service_spec.rb +1 -1
  367. data/spec/unit/provider/service/gentoo_service_spec.rb +7 -7
  368. data/spec/unit/provider/service/macosx_spec.rb +3 -3
  369. data/spec/unit/provider/service/redhat_spec.rb +2 -2
  370. data/spec/unit/provider/service/upstart_service_spec.rb +3 -3
  371. data/spec/unit/provider_resolver_spec.rb +6 -6
  372. data/spec/unit/recipe_spec.rb +1 -1
  373. data/spec/unit/resource/batch_spec.rb +6 -6
  374. data/spec/unit/resource/chef_client_cron_spec.rb +35 -14
  375. data/spec/unit/resource/chef_client_launchd_spec.rb +127 -0
  376. data/spec/unit/resource/chef_client_systemd_timer_spec.rb +36 -1
  377. data/spec/unit/resource/chef_client_trusted_certificate_spec.rb +54 -0
  378. data/spec/unit/resource/execute_spec.rb +113 -118
  379. data/spec/unit/resource/launchd_spec.rb +8 -0
  380. data/spec/unit/resource/osx_profile_spec.rb +299 -0
  381. data/spec/unit/resource/powershell_script_spec.rb +11 -29
  382. data/spec/unit/resource/rhsm_register_spec.rb +56 -18
  383. data/spec/unit/resource/script_spec.rb +6 -1
  384. data/spec/unit/resource/timezone_spec.rb +63 -0
  385. data/spec/unit/resource/windows_feature_powershell_spec.rb +30 -4
  386. data/spec/unit/resource/windows_uac_spec.rb +1 -1
  387. data/spec/unit/resource/windows_user_privilege_spec.rb +55 -0
  388. data/spec/unit/role_spec.rb +11 -11
  389. data/spec/unit/run_lock_spec.rb +5 -1
  390. data/spec/unit/runner_spec.rb +1 -2
  391. data/spec/unit/server_api_spec.rb +43 -16
  392. data/spec/unit/shell/shell_ext_spec.rb +46 -3
  393. data/spec/unit/shell/shell_session_spec.rb +35 -64
  394. data/spec/unit/shell_spec.rb +16 -19
  395. data/spec/unit/train_transport_spec.rb +14 -13
  396. data/spec/unit/util/selinux_spec.rb +2 -0
  397. data/tasks/rspec.rb +1 -3
  398. metadata +42 -33
  399. data/lib/chef/dist.rb +0 -68
  400. data/lib/chef/provider/osx_profile.rb +0 -255
  401. data/spec/integration/knife/config_get_profile_spec.rb +0 -113
  402. data/spec/integration/knife/config_get_spec.rb +0 -191
  403. data/spec/integration/knife/config_list_profiles_spec.rb +0 -218
  404. data/spec/integration/knife/config_use_profile_spec.rb +0 -154
  405. data/spec/unit/provider/osx_profile_spec.rb +0 -255
@@ -256,11 +256,11 @@ class Chef
256
256
 
257
257
  js_path, rb_path = js_files.first, rb_files.first
258
258
 
259
- if js_path && File.exists?(js_path)
259
+ if js_path && File.exist?(js_path)
260
260
  # from_json returns object.class => json_class in the JSON.
261
261
  hsh = Chef::JSONCompat.parse(IO.read(js_path))
262
262
  return from_hash(hsh)
263
- elsif rb_path && File.exists?(rb_path)
263
+ elsif rb_path && File.exist?(rb_path)
264
264
  role = Chef::Role.new
265
265
  role.name(name)
266
266
  role.from_file(rb_path)
@@ -28,7 +28,7 @@ require_relative "event_dispatch/events_output_stream"
28
28
  require_relative "train_transport"
29
29
  require_relative "exceptions"
30
30
  require "forwardable" unless defined?(Forwardable)
31
- require "set" unless defined?(Set)
31
+ autoload :Set, "set"
32
32
 
33
33
  class Chef
34
34
 
@@ -627,7 +627,7 @@ class Chef
627
627
  # @return [Train::Plugins::Transport] The child class for our train transport.
628
628
  #
629
629
  def transport
630
- @transport ||= Chef::TrainTransport.build_transport(logger)
630
+ @transport ||= Chef::TrainTransport.new(logger).build_transport
631
631
  end
632
632
 
633
633
  # Remote connection object from Train
@@ -16,7 +16,7 @@
16
16
  # limitations under the License.
17
17
  #
18
18
 
19
- require "set" unless defined?(Set)
19
+ autoload :Set, "set"
20
20
  require_relative "../log"
21
21
  require_relative "../recipe"
22
22
  require_relative "../resource/lwrp_base"
@@ -169,17 +169,17 @@ class Chef
169
169
  def compile_recipes
170
170
  @events.recipe_load_start(run_list_expansion.recipes.size)
171
171
  run_list_expansion.recipes.each do |recipe|
172
- begin
173
- path = resolve_recipe(recipe)
174
- @run_context.load_recipe(recipe)
175
- @events.recipe_file_loaded(path, recipe)
176
- rescue Chef::Exceptions::RecipeNotFound => e
177
- @events.recipe_not_found(e)
178
- raise
179
- rescue Exception => e
180
- @events.recipe_file_load_failed(path, e, recipe)
181
- raise
182
- end
172
+
173
+ path = resolve_recipe(recipe)
174
+ @run_context.load_recipe(recipe)
175
+ @events.recipe_file_loaded(path, recipe)
176
+ rescue Chef::Exceptions::RecipeNotFound => e
177
+ @events.recipe_not_found(e)
178
+ raise
179
+ rescue Exception => e
180
+ @events.recipe_file_load_failed(path, e, recipe)
181
+ raise
182
+
183
183
  end
184
184
  @events.recipe_load_complete
185
185
  end
@@ -231,14 +231,14 @@ class Chef
231
231
 
232
232
  def load_libraries_from_cookbook(cookbook_name, globs = "**/*.rb")
233
233
  each_file_in_cookbook_by_segment(cookbook_name, :libraries, globs) do |filename|
234
- begin
235
- logger.trace("Loading cookbook #{cookbook_name}'s library file: #{filename}")
236
- Kernel.require(filename)
237
- @events.library_file_loaded(filename)
238
- rescue Exception => e
239
- @events.library_file_load_failed(filename, e)
240
- raise
241
- end
234
+
235
+ logger.trace("Loading cookbook #{cookbook_name}'s library file: #{filename}")
236
+ Kernel.require(filename)
237
+ @events.library_file_loaded(filename)
238
+ rescue Exception => e
239
+ @events.library_file_load_failed(filename, e)
240
+ raise
241
+
242
242
  end
243
243
  end
244
244
 
@@ -325,7 +325,7 @@ class Chef
325
325
 
326
326
  def count_files_by_segment(segment, root_alias = nil)
327
327
  cookbook_collection.inject(0) do |count, cookbook_by_name|
328
- count + cookbook_by_name[1].segment_filenames(segment).size + (root_alias ? cookbook_by_name[1].files_for(:root_files).select { |record| record[:name] == root_alias }.size : 0)
328
+ count + cookbook_by_name[1].segment_filenames(segment).size + (root_alias ? cookbook_by_name[1].files_for(:root_files).count { |record| record[:name] == root_alias } : 0)
329
329
  end
330
330
  end
331
331
 
@@ -23,7 +23,7 @@ end
23
23
  require_relative "config"
24
24
  require_relative "exceptions"
25
25
  require "timeout" unless defined?(Timeout)
26
- require_relative "dist"
26
+ require "chef-utils" unless defined?(ChefUtils)
27
27
 
28
28
  class Chef
29
29
 
@@ -96,7 +96,7 @@ class Chef
96
96
  # Waits until acquiring the system-wide lock.
97
97
  #
98
98
  def wait
99
- Chef::Log.warn("#{Chef::Dist::PRODUCT} #{runpid} is running, will wait for it to finish and then run.")
99
+ Chef::Log.warn("#{ChefUtils::Dist::Infra::PRODUCT} #{runpid} is running, will wait for it to finish and then run.")
100
100
  if ChefUtils.windows?
101
101
  mutex.wait
102
102
  else
@@ -25,17 +25,13 @@ class Chef::RunStatus
25
25
 
26
26
  attr_reader :events
27
27
 
28
- attr_reader :run_context
29
-
30
- attr_writer :run_context
28
+ attr_accessor :run_context
31
29
 
32
30
  attr_reader :start_time
33
31
 
34
32
  attr_reader :end_time
35
33
 
36
- attr_reader :exception
37
-
38
- attr_writer :exception
34
+ attr_accessor :exception
39
35
 
40
36
  attr_accessor :run_id
41
37
 
@@ -20,8 +20,8 @@ require_relative "../config"
20
20
  require_relative "../exceptions"
21
21
  require_relative "../server_api"
22
22
 
23
- require "uri" unless defined?(URI)
24
- require "addressable/uri" unless defined?(Addressable::URI)
23
+ autoload :URI, "uri"
24
+ autoload :Addressable, "addressable/uri"
25
25
 
26
26
  class Chef
27
27
  class Search
@@ -132,10 +132,9 @@ class Chef
132
132
  args_h
133
133
  end
134
134
 
135
- QUERY_PARAM_VALUE = Addressable::URI::CharacterClasses::QUERY + "\\&\\;"
136
-
137
135
  def escape_value(s)
138
- s && Addressable::URI.encode_component(s.to_s, QUERY_PARAM_VALUE)
136
+ query_param_value = Addressable::URI::CharacterClasses::QUERY + "\\&\\;"
137
+ s && Addressable::URI.encode_component(s.to_s, query_param_value)
139
138
  end
140
139
 
141
140
  def create_query_string(type, query, rows, start)
@@ -51,6 +51,10 @@ class Chef
51
51
  @unversioned
52
52
  end
53
53
 
54
+ def negotiated?
55
+ !@versions.nil? || unversioned?
56
+ end
57
+
54
58
  def reset!
55
59
  @versions = nil
56
60
  @unversioned = false
@@ -15,17 +15,22 @@
15
15
  # limitations under the License.
16
16
  #
17
17
 
18
+ module Mixlib
19
+ module Authentication
20
+ autoload :Log, "mixlib/authentication"
21
+ end
22
+ end
18
23
  require "singleton" unless defined?(Singleton)
19
24
  require "pp" unless defined?(PP)
20
25
  require "etc" unless defined?(Etc)
21
26
  require "mixlib/cli" unless defined?(Mixlib::CLI)
27
+ require "chef-utils/dist" unless defined?(ChefUtils::Dist)
22
28
 
23
29
  require_relative "../chef"
24
30
  require_relative "version"
25
31
  require_relative "client"
26
32
  require_relative "config"
27
33
  require_relative "config_fetcher"
28
- require_relative "dist"
29
34
 
30
35
  require_relative "shell/shell_session"
31
36
  require_relative "workstation_config_loader"
@@ -126,11 +131,11 @@ module Shell
126
131
  irb_conf[:IRB_RC] = lambda do |conf|
127
132
  m = conf.main
128
133
 
129
- conf.prompt_c = "#{Chef::Dist::EXEC}#{leader(m)} > "
134
+ conf.prompt_c = "#{ChefUtils::Dist::Infra::EXEC}#{leader(m)} > "
130
135
  conf.return_format = " => %s \n"
131
- conf.prompt_i = "#{Chef::Dist::EXEC}#{leader(m)} (#{Chef::VERSION})> "
132
- conf.prompt_n = "#{Chef::Dist::EXEC}#{leader(m)} ?> "
133
- conf.prompt_s = "#{Chef::Dist::EXEC}#{leader(m)}%l> "
136
+ conf.prompt_i = "#{ChefUtils::Dist::Infra::EXEC}#{leader(m)} (#{Chef::VERSION})> "
137
+ conf.prompt_n = "#{ChefUtils::Dist::Infra::EXEC}#{leader(m)} ?> "
138
+ conf.prompt_s = "#{ChefUtils::Dist::Infra::EXEC}#{leader(m)}%l> "
134
139
  conf.use_tracer = false
135
140
  conf.instance_variable_set(:@use_multiline, false)
136
141
  conf.instance_variable_set(:@use_singleline, false)
@@ -212,17 +217,17 @@ module Shell
212
217
  @footer
213
218
  end
214
219
 
215
- banner("#{Chef::Dist::SHELL} #{Chef::VERSION}\n\nUsage: #{Chef::Dist::SHELL} [NAMED_CONF] (OPTIONS)")
220
+ banner("#{ChefUtils::Dist::Infra::SHELL} #{Chef::VERSION}\n\nUsage: #{ChefUtils::Dist::Infra::SHELL} [NAMED_CONF] (OPTIONS)")
216
221
 
217
222
  footer(<<~FOOTER)
218
- When no CONFIG is specified, #{Chef::Dist::SHELL} attempts to load a default configuration file:
219
- * If a NAMED_CONF is given, #{Chef::Dist::SHELL} will load ~/#{Chef::Dist::USER_CONF_DIR}/NAMED_CONF/#{Chef::Dist::SHELL_CONF}
220
- * If no NAMED_CONF is given #{Chef::Dist::SHELL} will load ~/#{Chef::Dist::USER_CONF_DIR}/#{Chef::Dist::SHELL_CONF} if it exists
221
- * If no #{Chef::Dist::SHELL_CONF} can be found, #{Chef::Dist::SHELL} falls back to load:
222
- #{Chef::Dist::CONF_DIR}/client.rb if -z option is given.
223
- #{Chef::Dist::CONF_DIR}/solo.rb if --solo-legacy-mode option is given.
224
- #{Chef::Dist::USER_CONF_DIR}/config.rb if -s option is given.
225
- #{Chef::Dist::USER_CONF_DIR}/knife.rb if -s option is given.
223
+ When no CONFIG is specified, #{ChefUtils::Dist::Infra::SHELL} attempts to load a default configuration file:
224
+ * If a NAMED_CONF is given, #{ChefUtils::Dist::Infra::SHELL} will load ~/#{ChefUtils::Dist::Infra::USER_CONF_DIR}/NAMED_CONF/#{ChefUtils::Dist::Infra::SHELL_CONF}
225
+ * If no NAMED_CONF is given #{ChefUtils::Dist::Infra::SHELL} will load ~/#{ChefUtils::Dist::Infra::USER_CONF_DIR}/#{ChefUtils::Dist::Infra::SHELL_CONF} if it exists
226
+ * If no #{ChefUtils::Dist::Infra::SHELL_CONF} can be found, #{ChefUtils::Dist::Infra::SHELL} falls back to load:
227
+ #{ChefConfig::Config.etc_chef_dir}/client.rb if -z option is given.
228
+ #{ChefConfig::Config.etc_chef_dir}/solo.rb if --solo-legacy-mode option is given.
229
+ #{ChefUtils::Dist::Infra::USER_CONF_DIR}/config.rb if -s option is given.
230
+ #{ChefUtils::Dist::Infra::USER_CONF_DIR}/knife.rb if -s option is given.
226
231
  FOOTER
227
232
 
228
233
  option :use_multiline,
@@ -269,19 +274,19 @@ module Shell
269
274
  option :solo_shell,
270
275
  short: "-s",
271
276
  long: "--solo",
272
- description: "#{Chef::Dist::SOLO} session",
277
+ description: "#{ChefUtils::Dist::Solo::PRODUCT} session",
273
278
  boolean: true,
274
279
  proc: proc { Chef::Config[:solo] = true }
275
280
 
276
281
  option :client,
277
282
  short: "-z",
278
283
  long: "--client",
279
- description: "#{Chef::Dist::PRODUCT} session",
284
+ description: "#{ChefUtils::Dist::Infra::PRODUCT} session",
280
285
  boolean: true
281
286
 
282
287
  option :solo_legacy_shell,
283
288
  long: "--solo-legacy-mode",
284
- description: "#{Chef::Dist::SOLO} legacy session",
289
+ description: "#{ChefUtils::Dist::Solo::PRODUCT} legacy session",
285
290
  boolean: true,
286
291
  proc: proc { Chef::Config[:solo_legacy_mode] = true }
287
292
 
@@ -294,15 +299,15 @@ module Shell
294
299
  option :chef_server_url,
295
300
  short: "-S CHEFSERVERURL",
296
301
  long: "--server CHEFSERVERURL",
297
- description: "The #{Chef::Dist::SERVER_PRODUCT} URL",
302
+ description: "The #{ChefUtils::Dist::Server::PRODUCT} URL",
298
303
  proc: nil
299
304
 
300
305
  option :version,
301
306
  short: "-v",
302
307
  long: "--version",
303
- description: "Show #{Chef::Dist::PRODUCT} version",
308
+ description: "Show #{ChefUtils::Dist::Infra::PRODUCT} version",
304
309
  boolean: true,
305
- proc: lambda { |v| puts "#{Chef::Dist::PRODUCT}: #{::Chef::VERSION}" },
310
+ proc: lambda { |v| puts "#{ChefUtils::Dist::Infra::PRODUCT}: #{::Chef::VERSION}" },
306
311
  exit: 0
307
312
 
308
313
  option :override_runlist,
@@ -339,7 +344,7 @@ module Shell
339
344
  config[:config_file] = config_file_for_shell_mode(environment)
340
345
  config_msg = config[:config_file] || "none (standalone session)"
341
346
  puts "loading configuration: #{config_msg}"
342
- Chef::Config.from_file(config[:config_file]) if !config[:config_file].nil? && File.exists?(config[:config_file]) && File.readable?(config[:config_file])
347
+ Chef::Config.from_file(config[:config_file]) if !config[:config_file].nil? && File.exist?(config[:config_file]) && File.readable?(config[:config_file])
343
348
  Chef::Config.merge!(config)
344
349
  end
345
350
 
@@ -351,18 +356,18 @@ module Shell
351
356
  config[:config_file]
352
357
  elsif environment
353
358
  Shell.env = environment
354
- config_file_to_try = ::File.join(dot_chef_dir, environment, Chef::Dist::SHELL_CONF)
359
+ config_file_to_try = ::File.join(dot_chef_dir, environment, ChefUtils::Dist::Infra::SHELL_CONF)
355
360
  unless ::File.exist?(config_file_to_try)
356
- puts "could not find #{Chef::Dist::SHELL} config for environment #{environment} at #{config_file_to_try}"
361
+ puts "could not find #{ChefUtils::Dist::Infra::SHELL} config for environment #{environment} at #{config_file_to_try}"
357
362
  exit 1
358
363
  end
359
364
  config_file_to_try
360
- elsif dot_chef_dir && ::File.exist?(File.join(dot_chef_dir, Chef::Dist::SHELL_CONF))
361
- File.join(dot_chef_dir, Chef::Dist::SHELL_CONF)
365
+ elsif dot_chef_dir && ::File.exist?(File.join(dot_chef_dir, ChefUtils::Dist::Infra::SHELL_CONF))
366
+ File.join(dot_chef_dir, ChefUtils::Dist::Infra::SHELL_CONF)
362
367
  elsif config[:solo_legacy_shell]
363
- Chef::Config.platform_specific_path("#{Chef::Dist::CONF_DIR}/solo.rb")
368
+ Chef::Config.platform_specific_path("#{ChefConfig::Config.etc_chef_dir}/solo.rb")
364
369
  elsif config[:client]
365
- Chef::Config.platform_specific_path("#{Chef::Dist::CONF_DIR}/client.rb")
370
+ Chef::Config.platform_specific_path("#{ChefConfig::Config.etc_chef_dir}/client.rb")
366
371
  elsif config[:solo_shell]
367
372
  Chef::WorkstationConfigLoader.new(nil, Chef::Log).config_location
368
373
  else
@@ -25,7 +25,7 @@ require_relative "shell_session"
25
25
  require_relative "model_wrapper"
26
26
  require_relative "../server_api"
27
27
  require_relative "../json_compat"
28
- require_relative "../dist"
28
+ require "chef-utils/dist" unless defined?(ChefUtils::Dist)
29
29
 
30
30
  module Shell
31
31
  module Extensions
@@ -69,7 +69,7 @@ module Shell
69
69
  def help_banner
70
70
  banner = []
71
71
  banner << ""
72
- banner << "#{Chef::Dist::SHELL} Help"
72
+ banner << "#{ChefUtils::Dist::Infra::SHELL} Help"
73
73
  banner << "".ljust(80, "=")
74
74
  banner << "| " + "Command".ljust(25) + "| " + "Description"
75
75
  banner << "".ljust(80, "=")
@@ -194,7 +194,7 @@ module Shell
194
194
  explain(<<~E)
195
195
  ## SUMMARY ##
196
196
  When called with no argument, +help+ prints a table of all
197
- #{Chef::Dist::SHELL} commands. When called with an argument COMMAND, +help+
197
+ #{ChefUtils::Dist::Infra::SHELL} commands. When called with an argument COMMAND, +help+
198
198
  prints a detailed explanation of the command if available, or the
199
199
  description if no explanation is available.
200
200
  E
@@ -208,9 +208,9 @@ module Shell
208
208
  end
209
209
  alias :halp :help
210
210
 
211
- desc "prints information about #{Chef::Dist::PRODUCT}"
211
+ desc "prints information about #{ChefUtils::Dist::Infra::PRODUCT}"
212
212
  def version
213
- puts "Welcome to the #{Chef::Dist::SHELL} #{::Chef::VERSION}\n" +
213
+ puts "Welcome to the #{ChefUtils::Dist::Infra::SHELL} #{::Chef::VERSION}\n" +
214
214
  "For usage see https://docs.chef.io/chef_shell/"
215
215
  :ucanhaz_automation
216
216
  end
@@ -228,7 +228,7 @@ module Shell
228
228
  :attributes
229
229
  end
230
230
 
231
- desc "run #{Chef::Dist::PRODUCT} using the current recipe"
231
+ desc "run #{ChefUtils::Dist::Infra::PRODUCT} using the current recipe"
232
232
  def run_chef
233
233
  Chef::Log.level = :debug
234
234
  session = Shell.session
@@ -237,8 +237,8 @@ module Shell
237
237
  runrun
238
238
  end
239
239
 
240
- desc "returns an object to control a paused #{Chef::Dist::PRODUCT} run"
241
- subcommands resume: "resume the #{Chef::Dist::PRODUCT} run",
240
+ desc "returns an object to control a paused #{ChefUtils::Dist::Infra::PRODUCT} run"
241
+ subcommands resume: "resume the #{ChefUtils::Dist::Infra::PRODUCT} run",
242
242
  step: "run only the next resource",
243
243
  skip_back: "move back in the run list",
244
244
  skip_forward: "move forward in the run list"
@@ -309,9 +309,9 @@ module Shell
309
309
  new_node = edit(existing_node)
310
310
 
311
311
  ## EDITOR SELECTION ##
312
- #{Chef::Dist::SHELL} looks for an editor using the following logic
312
+ #{ChefUtils::Dist::Infra::SHELL} looks for an editor using the following logic
313
313
  1. Looks for an EDITOR set by Shell.editor = "EDITOR"
314
- 2. Looks for an EDITOR configured in your #{Chef::Dist::SHELL} config file
314
+ 2. Looks for an EDITOR configured in your #{ChefUtils::Dist::Infra::SHELL} config file
315
315
  3. Uses the value of the EDITOR environment variable
316
316
  E
317
317
  def edit(object)
@@ -320,7 +320,7 @@ module Shell
320
320
  return :failburger
321
321
  end
322
322
 
323
- filename = "#{Chef::Dist::SHELL}-edit-#{object.class.name}-"
323
+ filename = "#{ChefUtils::Dist::Infra::SHELL}-edit-#{object.class.name}-"
324
324
  if object.respond_to?(:name)
325
325
  filename += object.name
326
326
  elsif object.respond_to?(:id)
@@ -28,7 +28,7 @@ require_relative "../run_list/run_list_expansion"
28
28
  require_relative "../formatters/base"
29
29
  require_relative "../formatters/doc"
30
30
  require_relative "../formatters/minimal"
31
- require_relative "../dist"
31
+ require "chef-utils/dist" unless defined?(ChefUtils::Dist)
32
32
 
33
33
  module Shell
34
34
  class ShellSession
@@ -90,7 +90,7 @@ module Shell
90
90
  end
91
91
 
92
92
  def save_node
93
- raise "Not Supported! #{self.class.name} doesn't support #save_node, maybe you need to run #{Chef::Dist::SHELL} in client mode?"
93
+ raise "Not Supported! #{self.class.name} doesn't support #save_node, maybe you need to run #{ChefUtils::Dist::Infra::SHELL} in client mode?"
94
94
  end
95
95
 
96
96
  def rebuild_context
@@ -15,114 +15,15 @@
15
15
  # limitations under the License.
16
16
  #
17
17
 
18
- require "chef-config/mixin/credentials"
19
- require "train"
20
- require_relative "dist"
18
+ require "chef-config/mixin/train_transport" unless defined?(ChefConfig::Mixin::TrainTransport)
21
19
 
22
20
  class Chef
23
21
  class TrainTransport
24
- extend ChefConfig::Mixin::Credentials
22
+ include ChefConfig::Mixin::TrainTransport
25
23
 
26
- #
27
- # Returns a RFC099 credentials profile as a hash
28
- #
29
- def self.load_credentials(profile)
30
- # Tomlrb.load_file returns a hash with keys as strings
31
- credentials = parse_credentials_file
32
- if contains_split_fqdn?(credentials, profile)
33
- Chef::Log.warn("Credentials file #{credentials_file_path} contains target '#{profile}' as a Hash, expected a string.")
34
- Chef::Log.warn("Hostnames must be surrounded by single quotes, e.g. ['host.example.org']")
35
- end
36
-
37
- # host names must be specified in credentials file as ['foo.example.org'] with quotes
38
- if !credentials.nil? && !credentials[profile].nil?
39
- credentials[profile].map { |k, v| [k.to_sym, v] }.to_h # return symbolized keys to match Train.options()
40
- else
41
- nil
42
- end
43
- end
44
-
45
- # Toml creates hashes when a key is separated by periods, e.g.
46
- # [host.example.org] => { host: { example: { org: {} } } }
47
- #
48
- # Returns true if the above example is true
49
- #
50
- # A hostname has to be specified as ['host.example.org']
51
- # This will be a common mistake so we should catch it
52
- #
53
- def self.contains_split_fqdn?(hash, fqdn)
54
- fqdn.split(".").reduce(hash) do |h, k|
55
- v = h[k]
56
- if Hash === v
57
- v
58
- else
59
- break false
60
- end
61
- end
62
- end
63
-
64
- # ChefConfig::Mixin::Credentials.credentials_file_path is designed around knife,
65
- # overriding it here.
66
- #
67
- # Credentials file preference:
68
- #
69
- # 1) target_mode.credentials_file
70
- # 2) /etc/chef/TARGET_MODE_HOST/credentials
71
- # 3) #credentials_file_path from parent ($HOME/.chef/credentials)
72
- #
73
- def self.credentials_file_path
74
- tm_config = Chef::Config.target_mode
75
- profile = tm_config.host
76
-
77
- credentials_file =
78
- if tm_config.credentials_file && File.exist?(tm_config.credentials_file)
79
- tm_config.credentials_file
80
- elsif File.exist?(Chef::Config.platform_specific_path("#{Chef::Dist::CONF_DIR}/#{profile}/credentials"))
81
- Chef::Config.platform_specific_path("#{Chef::Dist::CONF_DIR}/#{profile}/credentials")
82
- else
83
- super
84
- end
85
-
86
- raise ArgumentError, "No credentials file found for target '#{profile}'" unless credentials_file
87
- raise ArgumentError, "Credentials file specified for target mode does not exist: '#{credentials_file}'" unless File.exist?(credentials_file)
88
-
89
- Chef::Log.debug("Loading credentials file '#{credentials_file}' for target '#{profile}'")
90
-
91
- credentials_file
92
- end
93
-
94
- def self.build_transport(logger = Chef::Log.with_child(subsystem: "transport"))
95
- return nil unless Chef::Config.target_mode?
96
-
97
- # TODO: Consider supporting parsing the protocol from a URI passed to `--target`
98
- #
99
- train_config = {}
100
-
101
- # Load the target_mode config context from Chef::Config, and place any valid settings into the train configuration
102
- tm_config = Chef::Config.target_mode
103
- protocol = tm_config.protocol
104
- train_config = tm_config.to_hash.select { |k| Train.options(protocol).key?(k) }
105
- Chef::Log.trace("Using target mode options from #{Chef::Dist::PRODUCT} config file: #{train_config.keys.join(", ")}") if train_config
106
-
107
- # Load the credentials file, and place any valid settings into the train configuration
108
- credentials = load_credentials(tm_config.host)
109
- if credentials
110
- valid_settings = credentials.select { |k| Train.options(protocol).key?(k) }
111
- valid_settings[:enable_password] = credentials[:enable_password] if credentials.key?(:enable_password)
112
- train_config.merge!(valid_settings)
113
- Chef::Log.trace("Using target mode options from credentials file: #{valid_settings.keys.join(", ")}") if valid_settings
114
- end
115
-
116
- train_config[:logger] = logger
117
-
118
- # Train handles connection retries for us
119
- Train.create(protocol, train_config)
120
- rescue SocketError => e # likely a dns failure, not caught by train
121
- e.message.replace "Error connecting to #{train_config[:target]} - #{e.message}"
122
- raise e
123
- rescue Train::PluginLoadError
124
- logger.error("Invalid target mode protocol: #{protocol}")
125
- exit(false)
24
+ def config
25
+ require "chef/config" unless defined?(Chef::Config)
26
+ Chef::Config
126
27
  end
127
28
  end
128
29
  end