chef 12.8.1-universal-mingw32 → 12.9.38-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 (1862) hide show
  1. checksums.yaml +4 -4
  2. data/CONTRIBUTING.md +208 -208
  3. data/Gemfile +54 -49
  4. data/LICENSE +201 -201
  5. data/README.md +139 -139
  6. data/Rakefile +87 -86
  7. data/VERSION +1 -1
  8. data/acceptance/.gitignore +2 -2
  9. data/acceptance/.shared/kitchen_acceptance/.kitchen.digitalocean.yml +33 -33
  10. data/acceptance/.shared/kitchen_acceptance/.kitchen.ec2.yml +292 -290
  11. data/acceptance/.shared/kitchen_acceptance/.kitchen.vagrant.yml +59 -59
  12. data/acceptance/.shared/kitchen_acceptance/libraries/kitchen.rb +51 -51
  13. data/acceptance/.shared/kitchen_acceptance/metadata.rb +1 -1
  14. data/acceptance/Gemfile +13 -14
  15. data/acceptance/README.md +132 -132
  16. data/acceptance/basics/.acceptance/acceptance-cookbook/.gitignore +2 -2
  17. data/acceptance/basics/.acceptance/acceptance-cookbook/metadata.rb +3 -3
  18. data/acceptance/basics/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  19. data/acceptance/basics/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  20. data/acceptance/basics/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
  21. data/acceptance/basics/.kitchen.yml +4 -4
  22. data/acceptance/basics/test/integration/chef-current-install/serverspec/chef_client_spec.rb +19 -19
  23. data/acceptance/basics/test/integration/chef-current-install/serverspec/spec_helper.rb +6 -6
  24. data/acceptance/fips/.acceptance/acceptance-cookbook/.gitignore +2 -2
  25. data/acceptance/fips/.acceptance/acceptance-cookbook/metadata.rb +2 -2
  26. data/acceptance/fips/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  27. data/acceptance/fips/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  28. data/acceptance/fips/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
  29. data/acceptance/fips/.kitchen.yml +4 -4
  30. data/acceptance/fips/test/integration/fips/serverspec/Gemfile +3 -3
  31. data/acceptance/fips/test/integration/fips/serverspec/fips_spec.rb +39 -39
  32. data/acceptance/omnitruck/.acceptance/acceptance-cookbook/.gitignore +2 -0
  33. data/acceptance/omnitruck/.acceptance/acceptance-cookbook/metadata.rb +1 -0
  34. data/acceptance/omnitruck/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -0
  35. data/acceptance/omnitruck/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -0
  36. data/acceptance/omnitruck/.acceptance/acceptance-cookbook/recipes/verify.rb +61 -0
  37. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/.gitignore +2 -2
  38. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/libraries/cookbook_kitchen.rb +43 -43
  39. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/libraries/top_cookbooks.rb +45 -23
  40. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/metadata.rb +3 -3
  41. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  42. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  43. data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
  44. data/acceptance/top-cookbooks/.gitignore +1 -1
  45. data/acceptance/top-cookbooks/.kitchen.chocolatey.yml +6 -0
  46. data/acceptance/top-cookbooks/.kitchen.docker.yml +12 -12
  47. data/acceptance/top-cookbooks/.kitchen.git.yml +11 -11
  48. data/acceptance/top-cookbooks/.kitchen.iis.yml +4 -0
  49. data/acceptance/top-cookbooks/.kitchen.learn-the-basics-rhel.yml +7 -7
  50. data/acceptance/top-cookbooks/.kitchen.learn-the-basics-ubuntu.yml +7 -7
  51. data/acceptance/top-cookbooks/.kitchen.learn-the-basics-windows.yml +7 -7
  52. data/acceptance/top-cookbooks/.kitchen.powershell.yml +4 -0
  53. data/acceptance/top-cookbooks/.kitchen.sql_server.yml +5 -0
  54. data/acceptance/top-cookbooks/.kitchen.winbox.yml +8 -0
  55. data/acceptance/top-cookbooks/.kitchen.windows.yml +38 -0
  56. data/acceptance/trivial/.acceptance/acceptance-cookbook/.gitignore +2 -2
  57. data/acceptance/trivial/.acceptance/acceptance-cookbook/metadata.rb +2 -2
  58. data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  59. data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  60. data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
  61. data/acceptance/trivial/.kitchen.yml +7 -7
  62. data/acceptance/trivial/test/integration/chef-current-install/inspec/chef_client_spec.rb +5 -5
  63. data/acceptance/windows-service/.acceptance/acceptance-cookbook/.gitignore +2 -2
  64. data/acceptance/windows-service/.acceptance/acceptance-cookbook/metadata.rb +2 -2
  65. data/acceptance/windows-service/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
  66. data/acceptance/windows-service/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
  67. data/acceptance/windows-service/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
  68. data/acceptance/windows-service/.kitchen.yml +7 -7
  69. data/acceptance/windows-service/test/integration/chef-windows-service/inspec/chef_windows_service_spec.rb +58 -58
  70. data/bin/chef-apply +25 -25
  71. data/bin/chef-client +26 -26
  72. data/bin/chef-service-manager +38 -38
  73. data/bin/chef-shell +34 -34
  74. data/bin/chef-solo +25 -25
  75. data/bin/chef-windows-service +35 -35
  76. data/bin/knife +25 -25
  77. data/chef-windows.gemspec +24 -24
  78. data/chef.gemspec +64 -63
  79. data/distro/common/html/_sources/ctl_chef_client.txt +35 -35
  80. data/distro/common/html/_sources/ctl_chef_server.txt +341 -341
  81. data/distro/common/html/_sources/ctl_chef_shell.txt +15 -15
  82. data/distro/common/html/_sources/ctl_chef_solo.txt +25 -25
  83. data/distro/common/html/_sources/index.txt +135 -135
  84. data/distro/common/html/_sources/knife.txt +74 -74
  85. data/distro/common/html/_sources/knife_bootstrap.txt +56 -56
  86. data/distro/common/html/_sources/knife_client.txt +150 -150
  87. data/distro/common/html/_sources/knife_common_options.txt +6 -6
  88. data/distro/common/html/_sources/knife_configure.txt +29 -29
  89. data/distro/common/html/_sources/knife_cookbook.txt +236 -236
  90. data/distro/common/html/_sources/knife_cookbook_site.txt +157 -157
  91. data/distro/common/html/_sources/knife_data_bag.txt +159 -159
  92. data/distro/common/html/_sources/knife_delete.txt +26 -26
  93. data/distro/common/html/_sources/knife_deps.txt +61 -61
  94. data/distro/common/html/_sources/knife_diff.txt +34 -34
  95. data/distro/common/html/_sources/knife_download.txt +44 -44
  96. data/distro/common/html/_sources/knife_edit.txt +26 -26
  97. data/distro/common/html/_sources/knife_environment.txt +158 -158
  98. data/distro/common/html/_sources/knife_exec.txt +47 -47
  99. data/distro/common/html/_sources/knife_index_rebuild.txt +20 -20
  100. data/distro/common/html/_sources/knife_list.txt +33 -33
  101. data/distro/common/html/_sources/knife_node.txt +250 -250
  102. data/distro/common/html/_sources/knife_raw.txt +35 -35
  103. data/distro/common/html/_sources/knife_recipe_list.txt +23 -23
  104. data/distro/common/html/_sources/knife_role.txt +157 -157
  105. data/distro/common/html/_sources/knife_search.txt +53 -53
  106. data/distro/common/html/_sources/knife_serve.txt +18 -18
  107. data/distro/common/html/_sources/knife_show.txt +26 -26
  108. data/distro/common/html/_sources/knife_ssh.txt +43 -43
  109. data/distro/common/html/_sources/knife_ssl_check.txt +41 -41
  110. data/distro/common/html/_sources/knife_ssl_fetch.txt +41 -41
  111. data/distro/common/html/_sources/knife_status.txt +37 -37
  112. data/distro/common/html/_sources/knife_tag.txt +69 -69
  113. data/distro/common/html/_sources/knife_upload.txt +49 -49
  114. data/distro/common/html/_sources/knife_user.txt +127 -127
  115. data/distro/common/html/_sources/knife_using.txt +43 -43
  116. data/distro/common/html/_sources/knife_xargs.txt +30 -30
  117. data/distro/common/html/_static/basic.css +536 -536
  118. data/distro/common/html/_static/doctools.js +238 -238
  119. data/distro/common/html/_static/guide.css +504 -504
  120. data/distro/common/html/_static/pygments.css +61 -61
  121. data/distro/common/html/_static/searchtools.js +621 -621
  122. data/distro/common/html/_static/underscore.js +31 -31
  123. data/distro/common/html/_static/websupport.js +808 -808
  124. data/distro/common/html/ctl_chef_client.html +269 -269
  125. data/distro/common/html/ctl_chef_server.html +727 -727
  126. data/distro/common/html/ctl_chef_shell.html +162 -162
  127. data/distro/common/html/ctl_chef_solo.html +193 -193
  128. data/distro/common/html/index.html +201 -201
  129. data/distro/common/html/knife.html +169 -169
  130. data/distro/common/html/knife_bootstrap.html +284 -284
  131. data/distro/common/html/knife_client.html +284 -284
  132. data/distro/common/html/knife_common_options.html +95 -95
  133. data/distro/common/html/knife_configure.html +104 -104
  134. data/distro/common/html/knife_cookbook.html +486 -486
  135. data/distro/common/html/knife_cookbook_site.html +375 -375
  136. data/distro/common/html/knife_data_bag.html +373 -373
  137. data/distro/common/html/knife_delete.html +92 -92
  138. data/distro/common/html/knife_deps.html +142 -142
  139. data/distro/common/html/knife_diff.html +122 -122
  140. data/distro/common/html/knife_download.html +144 -144
  141. data/distro/common/html/knife_edit.html +88 -88
  142. data/distro/common/html/knife_environment.html +325 -325
  143. data/distro/common/html/knife_exec.html +219 -219
  144. data/distro/common/html/knife_index_rebuild.html +82 -82
  145. data/distro/common/html/knife_list.html +113 -113
  146. data/distro/common/html/knife_node.html +457 -457
  147. data/distro/common/html/knife_raw.html +109 -109
  148. data/distro/common/html/knife_recipe_list.html +90 -90
  149. data/distro/common/html/knife_role.html +294 -294
  150. data/distro/common/html/knife_search.html +202 -202
  151. data/distro/common/html/knife_serve.html +78 -78
  152. data/distro/common/html/knife_show.html +103 -103
  153. data/distro/common/html/knife_ssh.html +176 -176
  154. data/distro/common/html/knife_ssl_check.html +150 -150
  155. data/distro/common/html/knife_ssl_fetch.html +150 -150
  156. data/distro/common/html/knife_status.html +143 -143
  157. data/distro/common/html/knife_tag.html +137 -137
  158. data/distro/common/html/knife_upload.html +152 -152
  159. data/distro/common/html/knife_user.html +241 -241
  160. data/distro/common/html/knife_using.html +209 -209
  161. data/distro/common/html/knife_xargs.html +121 -121
  162. data/distro/common/html/search.html +81 -81
  163. data/distro/common/man/man1/README.md +58 -58
  164. data/distro/common/man/man1/chef-shell.1 +194 -194
  165. data/distro/common/man/man1/knife-bootstrap.1 +215 -215
  166. data/distro/common/man/man1/knife-client.1 +443 -443
  167. data/distro/common/man/man1/knife-configure.1 +161 -161
  168. data/distro/common/man/man1/knife-cookbook-site.1 +552 -552
  169. data/distro/common/man/man1/knife-cookbook.1 +770 -770
  170. data/distro/common/man/man1/knife-data-bag.1 +617 -617
  171. data/distro/common/man/man1/knife-delete.1 +127 -127
  172. data/distro/common/man/man1/knife-deps.1 +246 -246
  173. data/distro/common/man/man1/knife-diff.1 +226 -226
  174. data/distro/common/man/man1/knife-download.1 +258 -258
  175. data/distro/common/man/man1/knife-edit.1 +121 -121
  176. data/distro/common/man/man1/knife-environment.1 +508 -508
  177. data/distro/common/man/man1/knife-exec.1 +362 -362
  178. data/distro/common/man/man1/knife-index-rebuild.1 +63 -63
  179. data/distro/common/man/man1/knife-list.1 +174 -174
  180. data/distro/common/man/man1/knife-node.1 +716 -716
  181. data/distro/common/man/man1/knife-raw.1 +172 -172
  182. data/distro/common/man/man1/knife-recipe-list.1 +85 -85
  183. data/distro/common/man/man1/knife-role.1 +426 -426
  184. data/distro/common/man/man1/knife-search.1 +359 -359
  185. data/distro/common/man/man1/knife-serve.1 +109 -109
  186. data/distro/common/man/man1/knife-show.1 +160 -160
  187. data/distro/common/man/man1/knife-ssh.1 +284 -284
  188. data/distro/common/man/man1/knife-ssl-check.1 +207 -207
  189. data/distro/common/man/man1/knife-ssl-fetch.1 +207 -207
  190. data/distro/common/man/man1/knife-status.1 +234 -234
  191. data/distro/common/man/man1/knife-tag.1 +189 -189
  192. data/distro/common/man/man1/knife-upload.1 +280 -280
  193. data/distro/common/man/man1/knife-user.1 +356 -356
  194. data/distro/common/man/man1/knife-xargs.1 +189 -189
  195. data/distro/common/man/man1/knife.1 +332 -332
  196. data/distro/common/man/man8/chef-apply.8 +86 -86
  197. data/distro/common/man/man8/chef-client.8 +398 -398
  198. data/distro/common/man/man8/chef-solo.8 +260 -260
  199. data/distro/common/markdown/README +3 -3
  200. data/distro/common/markdown/man1/chef-shell.mkd +195 -195
  201. data/distro/common/markdown/man1/knife-bootstrap.mkd +141 -141
  202. data/distro/common/markdown/man1/knife-client.mkd +103 -103
  203. data/distro/common/markdown/man1/knife-configure.mkd +70 -70
  204. data/distro/common/markdown/man1/knife-cookbook-site.mkd +123 -123
  205. data/distro/common/markdown/man1/knife-cookbook.mkd +263 -263
  206. data/distro/common/markdown/man1/knife-data-bag.mkd +121 -121
  207. data/distro/common/markdown/man1/knife-environment.mkd +151 -151
  208. data/distro/common/markdown/man1/knife-exec.mkd +42 -42
  209. data/distro/common/markdown/man1/knife-index.mkd +30 -30
  210. data/distro/common/markdown/man1/knife-node.mkd +130 -130
  211. data/distro/common/markdown/man1/knife-role.mkd +85 -85
  212. data/distro/common/markdown/man1/knife-search.mkd +180 -180
  213. data/distro/common/markdown/man1/knife-ssh.mkd +69 -69
  214. data/distro/common/markdown/man1/knife-status.mkd +36 -36
  215. data/distro/common/markdown/man1/knife-tag.mkd +39 -39
  216. data/distro/common/markdown/man1/knife.mkd +213 -213
  217. data/distro/common/markdown/man8/chef-client.mkd +75 -75
  218. data/distro/common/markdown/man8/chef-expander.mkd +81 -81
  219. data/distro/common/markdown/man8/chef-expanderctl.mkd +57 -57
  220. data/distro/common/markdown/man8/chef-server-webui.mkd +121 -121
  221. data/distro/common/markdown/man8/chef-server.mkd +120 -120
  222. data/distro/common/markdown/man8/chef-solo.mkd +107 -107
  223. data/distro/common/markdown/man8/chef-solr.mkd +89 -89
  224. data/distro/powershell/chef/chef.psm1 +327 -327
  225. data/ext/win32-eventlog/Rakefile +53 -53
  226. data/ext/win32-eventlog/chef-log.man +56 -56
  227. data/lib-backcompat/chef/chef_fs/file_system/acl_entry.rb +5 -5
  228. data/lib-backcompat/chef/chef_fs/file_system/chef_repository_file_system_root_dir.rb +5 -5
  229. data/lib-backcompat/chef/chef_fs/file_system/chef_server_root_dir.rb +5 -5
  230. data/lib/chef.rb +35 -35
  231. data/lib/chef/api_client.rb +233 -233
  232. data/lib/chef/api_client/registration.rb +192 -192
  233. data/lib/chef/api_client_v1.rb +325 -325
  234. data/lib/chef/application.rb +357 -342
  235. data/lib/chef/application/apply.rb +221 -221
  236. data/lib/chef/application/client.rb +520 -513
  237. data/lib/chef/application/knife.rb +208 -208
  238. data/lib/chef/application/solo.rb +334 -334
  239. data/lib/chef/application/windows_service.rb +338 -338
  240. data/lib/chef/application/windows_service_manager.rb +202 -202
  241. data/lib/chef/applications.rb +4 -4
  242. data/lib/chef/audit/audit_event_proxy.rb +93 -93
  243. data/lib/chef/audit/audit_reporter.rb +172 -172
  244. data/lib/chef/audit/control_group_data.rb +139 -139
  245. data/lib/chef/audit/logger.rb +36 -36
  246. data/lib/chef/audit/rspec_formatter.rb +37 -37
  247. data/lib/chef/audit/runner.rb +196 -196
  248. data/lib/chef/chef_class.rb +228 -228
  249. data/lib/chef/chef_fs.rb +59 -59
  250. data/lib/chef/chef_fs/chef_fs_data_store.rb +871 -871
  251. data/lib/chef/chef_fs/command_line.rb +285 -285
  252. data/lib/chef/chef_fs/config.rb +284 -283
  253. data/lib/chef/chef_fs/data_handler/acl_data_handler.rb +26 -26
  254. data/lib/chef/chef_fs/data_handler/client_data_handler.rb +39 -39
  255. data/lib/chef/chef_fs/data_handler/client_key_data_handler.rb +11 -11
  256. data/lib/chef/chef_fs/data_handler/container_data_handler.rb +35 -35
  257. data/lib/chef/chef_fs/data_handler/cookbook_data_handler.rb +38 -38
  258. data/lib/chef/chef_fs/data_handler/data_bag_item_data_handler.rb +62 -62
  259. data/lib/chef/chef_fs/data_handler/data_handler_base.rb +204 -204
  260. data/lib/chef/chef_fs/data_handler/environment_data_handler.rb +40 -40
  261. data/lib/chef/chef_fs/data_handler/group_data_handler.rb +55 -55
  262. data/lib/chef/chef_fs/data_handler/node_data_handler.rb +36 -36
  263. data/lib/chef/chef_fs/data_handler/organization_data_handler.rb +36 -36
  264. data/lib/chef/chef_fs/data_handler/organization_invites_data_handler.rb +17 -17
  265. data/lib/chef/chef_fs/data_handler/organization_members_data_handler.rb +17 -17
  266. data/lib/chef/chef_fs/data_handler/policy_data_handler.rb +48 -48
  267. data/lib/chef/chef_fs/data_handler/policy_group_data_handler.rb +33 -33
  268. data/lib/chef/chef_fs/data_handler/role_data_handler.rb +40 -40
  269. data/lib/chef/chef_fs/data_handler/user_data_handler.rb +29 -29
  270. data/lib/chef/chef_fs/file_pattern.rb +301 -301
  271. data/lib/chef/chef_fs/file_system.rb +429 -429
  272. data/lib/chef/chef_fs/file_system/already_exists_error.rb +28 -28
  273. data/lib/chef/chef_fs/file_system/base_fs_dir.rb +47 -47
  274. data/lib/chef/chef_fs/file_system/base_fs_object.rb +183 -183
  275. data/lib/chef/chef_fs/file_system/chef_server/acl_dir.rb +65 -65
  276. data/lib/chef/chef_fs/file_system/chef_server/acl_entry.rb +60 -60
  277. data/lib/chef/chef_fs/file_system/chef_server/acls_dir.rb +75 -75
  278. data/lib/chef/chef_fs/file_system/chef_server/chef_server_root_dir.rb +196 -196
  279. data/lib/chef/chef_fs/file_system/chef_server/cookbook_artifact_dir.rb +38 -38
  280. data/lib/chef/chef_fs/file_system/chef_server/cookbook_artifacts_dir.rb +102 -102
  281. data/lib/chef/chef_fs/file_system/chef_server/cookbook_dir.rb +222 -222
  282. data/lib/chef/chef_fs/file_system/chef_server/cookbook_file.rb +84 -84
  283. data/lib/chef/chef_fs/file_system/chef_server/cookbook_subdir.rb +61 -61
  284. data/lib/chef/chef_fs/file_system/chef_server/cookbooks_acl_dir.rb +42 -42
  285. data/lib/chef/chef_fs/file_system/chef_server/cookbooks_dir.rb +102 -102
  286. data/lib/chef/chef_fs/file_system/chef_server/data_bag_dir.rb +71 -71
  287. data/lib/chef/chef_fs/file_system/chef_server/data_bags_dir.rb +69 -69
  288. data/lib/chef/chef_fs/file_system/chef_server/environments_dir.rb +57 -57
  289. data/lib/chef/chef_fs/file_system/chef_server/nodes_dir.rb +53 -53
  290. data/lib/chef/chef_fs/file_system/chef_server/org_entry.rb +31 -31
  291. data/lib/chef/chef_fs/file_system/chef_server/organization_invites_entry.rb +61 -61
  292. data/lib/chef/chef_fs/file_system/chef_server/organization_members_entry.rb +60 -60
  293. data/lib/chef/chef_fs/file_system/chef_server/policies_acl_dir.rb +41 -41
  294. data/lib/chef/chef_fs/file_system/chef_server/policies_dir.rb +160 -160
  295. data/lib/chef/chef_fs/file_system/chef_server/policy_group_entry.rb +137 -137
  296. data/lib/chef/chef_fs/file_system/chef_server/policy_groups_dir.rb +43 -43
  297. data/lib/chef/chef_fs/file_system/chef_server/policy_revision_entry.rb +34 -34
  298. data/lib/chef/chef_fs/file_system/chef_server/rest_list_dir.rb +178 -178
  299. data/lib/chef/chef_fs/file_system/chef_server/rest_list_entry.rb +187 -187
  300. data/lib/chef/chef_fs/file_system/chef_server/versioned_cookbook_dir.rb +45 -45
  301. data/lib/chef/chef_fs/file_system/chef_server/versioned_cookbooks_dir.rb +107 -107
  302. data/lib/chef/chef_fs/file_system/cookbook_frozen_error.rb +28 -28
  303. data/lib/chef/chef_fs/file_system/default_environment_cannot_be_modified_error.rb +32 -32
  304. data/lib/chef/chef_fs/file_system/file_system_error.rb +44 -44
  305. data/lib/chef/chef_fs/file_system/memory/memory_dir.rb +53 -53
  306. data/lib/chef/chef_fs/file_system/memory/memory_file.rb +20 -20
  307. data/lib/chef/chef_fs/file_system/memory/memory_root.rb +23 -23
  308. data/lib/chef/chef_fs/file_system/multiplexed_dir.rb +64 -64
  309. data/lib/chef/chef_fs/file_system/must_delete_recursively_error.rb +28 -28
  310. data/lib/chef/chef_fs/file_system/nonexistent_fs_object.rb +36 -36
  311. data/lib/chef/chef_fs/file_system/not_found_error.rb +28 -28
  312. data/lib/chef/chef_fs/file_system/operation_failed_error.rb +42 -42
  313. data/lib/chef/chef_fs/file_system/operation_not_allowed_error.rb +46 -46
  314. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_acls_dir.rb +39 -39
  315. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_client_keys_dir.rb +38 -38
  316. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_artifact_dir.rb +41 -41
  317. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_dir.rb +146 -146
  318. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +176 -176
  319. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_entry.rb +83 -83
  320. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_policies_dir.rb +38 -38
  321. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +214 -214
  322. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_versioned_cookbook_dir.rb +42 -42
  323. data/lib/chef/chef_fs/file_system/repository/cookbook_artifacts_dir.rb +36 -36
  324. data/lib/chef/chef_fs/file_system/repository/cookbooks_dir.rb +52 -52
  325. data/lib/chef/chef_fs/file_system/repository/data_bag.rb +39 -39
  326. data/lib/chef/chef_fs/file_system/repository/data_bag_item.rb +114 -114
  327. data/lib/chef/chef_fs/file_system/repository/data_bags_dir.rb +39 -39
  328. data/lib/chef/chef_fs/file_system/repository/directory.rb +139 -139
  329. data/lib/chef/chef_fs/file_system/repository/file_system_entry.rb +117 -117
  330. data/lib/chef/chef_fs/file_system/repository/file_system_root_dir.rb +33 -33
  331. data/lib/chef/chef_fs/file_system/repository/versioned_cookbooks_dir.rb +34 -34
  332. data/lib/chef/chef_fs/knife.rb +161 -161
  333. data/lib/chef/chef_fs/parallelizer.rb +105 -105
  334. data/lib/chef/chef_fs/parallelizer/flatten_enumerable.rb +35 -35
  335. data/lib/chef/chef_fs/parallelizer/parallel_enumerable.rb +281 -281
  336. data/lib/chef/chef_fs/path_utils.rb +127 -127
  337. data/lib/chef/client.rb +966 -967
  338. data/lib/chef/config.rb +85 -85
  339. data/lib/chef/config_fetcher.rb +72 -72
  340. data/lib/chef/constants.rb +28 -28
  341. data/lib/chef/cookbook/chefignore.rb +74 -74
  342. data/lib/chef/cookbook/cookbook_collection.rb +63 -63
  343. data/lib/chef/cookbook/cookbook_version_loader.rb +352 -352
  344. data/lib/chef/cookbook/file_system_file_vendor.rb +59 -59
  345. data/lib/chef/cookbook/file_vendor.rb +71 -71
  346. data/lib/chef/cookbook/gem_installer.rb +83 -118
  347. data/lib/chef/cookbook/metadata.rb +904 -904
  348. data/lib/chef/cookbook/remote_file_vendor.rb +87 -87
  349. data/lib/chef/cookbook/synchronizer.rb +298 -298
  350. data/lib/chef/cookbook/syntax_check.rb +260 -260
  351. data/lib/chef/cookbook_loader.rb +200 -200
  352. data/lib/chef/cookbook_manifest.rb +290 -290
  353. data/lib/chef/cookbook_site_streaming_uploader.rb +243 -244
  354. data/lib/chef/cookbook_uploader.rb +157 -157
  355. data/lib/chef/cookbook_version.rb +637 -631
  356. data/lib/chef/daemon.rb +131 -131
  357. data/lib/chef/data_bag.rb +176 -176
  358. data/lib/chef/data_bag_item.rb +218 -218
  359. data/lib/chef/delayed_evaluator.rb +21 -21
  360. data/lib/chef/deprecation/mixin/template.rb +48 -48
  361. data/lib/chef/deprecation/provider/cookbook_file.rb +54 -54
  362. data/lib/chef/deprecation/provider/file.rb +198 -198
  363. data/lib/chef/deprecation/provider/remote_directory.rb +52 -52
  364. data/lib/chef/deprecation/provider/remote_file.rb +85 -85
  365. data/lib/chef/deprecation/provider/template.rb +63 -63
  366. data/lib/chef/deprecation/warnings.rb +37 -38
  367. data/lib/chef/digester.rb +74 -74
  368. data/lib/chef/dsl.rb +6 -6
  369. data/lib/chef/dsl/audit.rb +51 -51
  370. data/lib/chef/dsl/chef_provisioning.rb +57 -57
  371. data/lib/chef/dsl/cheffish.rb +64 -64
  372. data/lib/chef/dsl/core.rb +42 -0
  373. data/lib/chef/dsl/data_query.rb +89 -89
  374. data/lib/chef/dsl/declare_resource.rb +106 -108
  375. data/lib/chef/dsl/definitions.rb +43 -43
  376. data/lib/chef/dsl/include_attribute.rb +61 -61
  377. data/lib/chef/dsl/include_recipe.rb +44 -44
  378. data/lib/chef/dsl/method_missing.rb +75 -0
  379. data/lib/chef/dsl/platform_introspection.rb +254 -254
  380. data/lib/chef/dsl/powershell.rb +29 -29
  381. data/lib/chef/dsl/reboot_pending.rb +64 -64
  382. data/lib/chef/dsl/recipe.rb +89 -134
  383. data/lib/chef/dsl/registry_helper.rb +63 -63
  384. data/lib/chef/dsl/resources.rb +58 -58
  385. data/lib/chef/encrypted_data_bag_item.rb +155 -155
  386. data/lib/chef/encrypted_data_bag_item/assertions.rb +54 -54
  387. data/lib/chef/encrypted_data_bag_item/check_encrypted.rb +56 -56
  388. data/lib/chef/encrypted_data_bag_item/decryption_failure.rb +22 -22
  389. data/lib/chef/encrypted_data_bag_item/decryptor.rb +227 -227
  390. data/lib/chef/encrypted_data_bag_item/encrypted_data_bag_item_assertions.rb +37 -37
  391. data/lib/chef/encrypted_data_bag_item/encryption_failure.rb +22 -22
  392. data/lib/chef/encrypted_data_bag_item/encryptor.rb +225 -225
  393. data/lib/chef/encrypted_data_bag_item/unacceptable_encrypted_data_bag_item_format.rb +22 -22
  394. data/lib/chef/encrypted_data_bag_item/unsupported_cipher.rb +22 -22
  395. data/lib/chef/encrypted_data_bag_item/unsupported_encrypted_data_bag_item_format.rb +22 -22
  396. data/lib/chef/environment.rb +326 -326
  397. data/lib/chef/event_dispatch/base.rb +426 -420
  398. data/lib/chef/event_dispatch/dispatcher.rb +62 -62
  399. data/lib/chef/event_dispatch/dsl.rb +65 -65
  400. data/lib/chef/event_dispatch/events_output_stream.rb +37 -37
  401. data/lib/chef/event_loggers/base.rb +62 -62
  402. data/lib/chef/event_loggers/windows_eventlog.rb +101 -101
  403. data/lib/chef/exceptions.rb +504 -504
  404. data/lib/chef/file_access_control.rb +75 -75
  405. data/lib/chef/file_access_control/unix.rb +290 -290
  406. data/lib/chef/file_access_control/windows.rb +335 -335
  407. data/lib/chef/file_cache.rb +221 -221
  408. data/lib/chef/file_content_management/content_base.rb +56 -56
  409. data/lib/chef/file_content_management/deploy.rb +37 -37
  410. data/lib/chef/file_content_management/deploy/cp.rb +48 -48
  411. data/lib/chef/file_content_management/deploy/mv_unix.rb +76 -76
  412. data/lib/chef/file_content_management/deploy/mv_windows.rb +103 -103
  413. data/lib/chef/file_content_management/tempfile.rb +97 -97
  414. data/lib/chef/formatters/base.rb +237 -237
  415. data/lib/chef/formatters/doc.rb +438 -422
  416. data/lib/chef/formatters/{error_descriptor.rb → error_description.rb} +69 -67
  417. data/lib/chef/formatters/error_inspectors.rb +19 -19
  418. data/lib/chef/formatters/error_inspectors/api_error_formatting.rb +184 -184
  419. data/lib/chef/formatters/error_inspectors/compile_error_inspector.rb +154 -154
  420. data/lib/chef/formatters/error_inspectors/cookbook_resolve_error_inspector.rb +168 -168
  421. data/lib/chef/formatters/error_inspectors/cookbook_sync_error_inspector.rb +82 -82
  422. data/lib/chef/formatters/error_inspectors/node_load_error_inspector.rb +128 -128
  423. data/lib/chef/formatters/error_inspectors/registration_error_inspector.rb +147 -147
  424. data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +124 -124
  425. data/lib/chef/formatters/error_inspectors/run_list_expansion_error_inspector.rb +121 -121
  426. data/lib/chef/formatters/error_mapper.rb +85 -85
  427. data/lib/chef/formatters/indentable_output_stream.rb +170 -170
  428. data/lib/chef/formatters/minimal.rb +233 -233
  429. data/lib/chef/guard_interpreter.rb +32 -32
  430. data/lib/chef/guard_interpreter/default_guard_interpreter.rb +43 -43
  431. data/lib/chef/guard_interpreter/resource_guard_interpreter.rb +138 -138
  432. data/lib/chef/handler.rb +235 -235
  433. data/lib/chef/handler/error_report.rb +33 -33
  434. data/lib/chef/handler/json_file.rb +63 -63
  435. data/lib/chef/http.rb +460 -430
  436. data/lib/chef/http/auth_credentials.rb +57 -57
  437. data/lib/chef/http/authenticator.rb +106 -106
  438. data/lib/chef/http/basic_client.rb +149 -169
  439. data/lib/chef/http/cookie_jar.rb +31 -31
  440. data/lib/chef/http/cookie_manager.rb +59 -59
  441. data/lib/chef/http/decompressor.rb +142 -142
  442. data/lib/chef/http/http_request.rb +186 -186
  443. data/lib/chef/http/json_input.rb +73 -73
  444. data/lib/chef/http/json_output.rb +78 -78
  445. data/lib/chef/http/json_to_model_output.rb +34 -34
  446. data/lib/chef/http/remote_request_id.rb +46 -46
  447. data/lib/chef/http/simple.rb +40 -40
  448. data/lib/chef/http/simple_json.rb +43 -43
  449. data/lib/chef/http/socketless_chef_zero_client.rb +208 -207
  450. data/lib/chef/http/ssl_policies.rb +130 -130
  451. data/lib/chef/http/validate_content_length.rb +114 -115
  452. data/lib/chef/json_compat.rb +164 -164
  453. data/lib/chef/key.rb +273 -273
  454. data/lib/chef/knife.rb +587 -587
  455. data/lib/chef/knife/bootstrap.rb +480 -480
  456. data/lib/chef/knife/bootstrap/chef_vault_handler.rb +159 -159
  457. data/lib/chef/knife/bootstrap/client_builder.rb +208 -208
  458. data/lib/chef/knife/bootstrap/templates/README.md +11 -11
  459. data/lib/chef/knife/bootstrap/templates/chef-full.erb +236 -236
  460. data/lib/chef/knife/client_bulk_delete.rb +104 -104
  461. data/lib/chef/knife/client_create.rb +111 -111
  462. data/lib/chef/knife/client_delete.rb +60 -60
  463. data/lib/chef/knife/client_edit.rb +53 -53
  464. data/lib/chef/knife/client_key_create.rb +67 -67
  465. data/lib/chef/knife/client_key_delete.rb +76 -76
  466. data/lib/chef/knife/client_key_edit.rb +79 -79
  467. data/lib/chef/knife/client_key_list.rb +69 -69
  468. data/lib/chef/knife/client_key_show.rb +76 -76
  469. data/lib/chef/knife/client_list.rb +42 -42
  470. data/lib/chef/knife/client_reregister.rb +59 -59
  471. data/lib/chef/knife/client_show.rb +49 -49
  472. data/lib/chef/knife/configure.rb +171 -171
  473. data/lib/chef/knife/configure_client.rb +50 -50
  474. data/lib/chef/knife/cookbook_bulk_delete.rb +71 -71
  475. data/lib/chef/knife/cookbook_create.rb +458 -448
  476. data/lib/chef/knife/cookbook_delete.rb +151 -151
  477. data/lib/chef/knife/cookbook_download.rb +143 -143
  478. data/lib/chef/knife/cookbook_list.rb +47 -47
  479. data/lib/chef/knife/cookbook_metadata.rb +107 -108
  480. data/lib/chef/knife/cookbook_metadata_from_file.rb +44 -44
  481. data/lib/chef/knife/cookbook_show.rb +98 -98
  482. data/lib/chef/knife/cookbook_site_download.rb +109 -109
  483. data/lib/chef/knife/cookbook_site_install.rb +192 -192
  484. data/lib/chef/knife/cookbook_site_list.rb +58 -58
  485. data/lib/chef/knife/cookbook_site_search.rb +46 -46
  486. data/lib/chef/knife/cookbook_site_share.rb +169 -169
  487. data/lib/chef/knife/cookbook_site_show.rb +55 -55
  488. data/lib/chef/knife/cookbook_site_unshare.rb +56 -56
  489. data/lib/chef/knife/cookbook_site_vendor.rb +46 -46
  490. data/lib/chef/knife/cookbook_test.rb +95 -95
  491. data/lib/chef/knife/cookbook_upload.rb +308 -308
  492. data/lib/chef/knife/core/bootstrap_context.rb +233 -233
  493. data/lib/chef/knife/core/cookbook_scm_repo.rb +159 -159
  494. data/lib/chef/knife/core/custom_manifest_loader.rb +69 -69
  495. data/lib/chef/knife/core/gem_glob_loader.rb +138 -138
  496. data/lib/chef/knife/core/generic_presenter.rb +222 -222
  497. data/lib/chef/knife/core/hashed_command_loader.rb +99 -99
  498. data/lib/chef/knife/core/node_editor.rb +130 -130
  499. data/lib/chef/knife/core/node_presenter.rb +159 -159
  500. data/lib/chef/knife/core/object_loader.rb +115 -115
  501. data/lib/chef/knife/core/status_presenter.rb +157 -157
  502. data/lib/chef/knife/core/subcommand_loader.rb +212 -212
  503. data/lib/chef/knife/core/text_formatter.rb +85 -85
  504. data/lib/chef/knife/core/ui.rb +284 -284
  505. data/lib/chef/knife/data_bag_create.rb +78 -78
  506. data/lib/chef/knife/data_bag_delete.rb +49 -49
  507. data/lib/chef/knife/data_bag_edit.rb +74 -74
  508. data/lib/chef/knife/data_bag_from_file.rb +114 -114
  509. data/lib/chef/knife/data_bag_list.rb +42 -42
  510. data/lib/chef/knife/data_bag_secret_options.rb +142 -142
  511. data/lib/chef/knife/data_bag_show.rb +69 -69
  512. data/lib/chef/knife/delete.rb +107 -107
  513. data/lib/chef/knife/deps.rb +140 -140
  514. data/lib/chef/knife/diff.rb +68 -68
  515. data/lib/chef/knife/download.rb +68 -68
  516. data/lib/chef/knife/edit.rb +72 -72
  517. data/lib/chef/knife/environment_compare.rb +127 -127
  518. data/lib/chef/knife/environment_create.rb +53 -53
  519. data/lib/chef/knife/environment_delete.rb +45 -45
  520. data/lib/chef/knife/environment_edit.rb +45 -45
  521. data/lib/chef/knife/environment_from_file.rb +82 -82
  522. data/lib/chef/knife/environment_list.rb +42 -42
  523. data/lib/chef/knife/environment_show.rb +48 -48
  524. data/lib/chef/knife/exec.rb +87 -87
  525. data/lib/chef/knife/help.rb +101 -101
  526. data/lib/chef/knife/help_topics.rb +4 -4
  527. data/lib/chef/knife/index_rebuild.rb +133 -133
  528. data/lib/chef/knife/key_create.rb +112 -112
  529. data/lib/chef/knife/key_create_base.rb +50 -50
  530. data/lib/chef/knife/key_delete.rb +55 -55
  531. data/lib/chef/knife/key_edit.rb +118 -118
  532. data/lib/chef/knife/key_edit_base.rb +55 -55
  533. data/lib/chef/knife/key_list.rb +88 -88
  534. data/lib/chef/knife/key_list_base.rb +45 -45
  535. data/lib/chef/knife/key_show.rb +53 -53
  536. data/lib/chef/knife/list.rb +157 -157
  537. data/lib/chef/knife/node_bulk_delete.rb +74 -74
  538. data/lib/chef/knife/node_create.rb +47 -47
  539. data/lib/chef/knife/node_delete.rb +46 -46
  540. data/lib/chef/knife/node_edit.rb +70 -70
  541. data/lib/chef/knife/node_environment_set.rb +54 -54
  542. data/lib/chef/knife/node_from_file.rb +51 -51
  543. data/lib/chef/knife/node_list.rb +44 -44
  544. data/lib/chef/knife/node_run_list_add.rb +104 -104
  545. data/lib/chef/knife/node_run_list_remove.rb +67 -67
  546. data/lib/chef/knife/node_run_list_set.rb +66 -66
  547. data/lib/chef/knife/node_show.rb +66 -66
  548. data/lib/chef/knife/null.rb +10 -10
  549. data/lib/chef/knife/osc_user_create.rb +97 -97
  550. data/lib/chef/knife/osc_user_delete.rb +51 -51
  551. data/lib/chef/knife/osc_user_edit.rb +58 -58
  552. data/lib/chef/knife/osc_user_list.rb +47 -47
  553. data/lib/chef/knife/osc_user_reregister.rb +64 -64
  554. data/lib/chef/knife/osc_user_show.rb +54 -54
  555. data/lib/chef/knife/raw.rb +103 -103
  556. data/lib/chef/knife/recipe_list.rb +32 -32
  557. data/lib/chef/knife/rehash.rb +65 -65
  558. data/lib/chef/knife/role_bulk_delete.rb +65 -65
  559. data/lib/chef/knife/role_create.rb +53 -53
  560. data/lib/chef/knife/role_delete.rb +46 -46
  561. data/lib/chef/knife/role_edit.rb +45 -45
  562. data/lib/chef/knife/role_env_run_list_add.rb +86 -86
  563. data/lib/chef/knife/role_env_run_list_clear.rb +55 -55
  564. data/lib/chef/knife/role_env_run_list_remove.rb +57 -57
  565. data/lib/chef/knife/role_env_run_list_replace.rb +59 -59
  566. data/lib/chef/knife/role_env_run_list_set.rb +70 -70
  567. data/lib/chef/knife/role_from_file.rb +51 -51
  568. data/lib/chef/knife/role_list.rb +42 -42
  569. data/lib/chef/knife/role_run_list_add.rb +86 -86
  570. data/lib/chef/knife/role_run_list_clear.rb +55 -55
  571. data/lib/chef/knife/role_run_list_remove.rb +57 -57
  572. data/lib/chef/knife/role_run_list_replace.rb +59 -59
  573. data/lib/chef/knife/role_run_list_set.rb +70 -70
  574. data/lib/chef/knife/role_show.rb +49 -49
  575. data/lib/chef/knife/search.rb +201 -201
  576. data/lib/chef/knife/serve.rb +48 -48
  577. data/lib/chef/knife/show.rb +56 -56
  578. data/lib/chef/knife/ssh.rb +582 -572
  579. data/lib/chef/knife/ssl_check.rb +282 -281
  580. data/lib/chef/knife/ssl_fetch.rb +157 -157
  581. data/lib/chef/knife/status.rb +110 -110
  582. data/lib/chef/knife/tag_create.rb +52 -52
  583. data/lib/chef/knife/tag_delete.rb +60 -60
  584. data/lib/chef/knife/tag_list.rb +47 -47
  585. data/lib/chef/knife/upload.rb +70 -70
  586. data/lib/chef/knife/user_create.rb +150 -150
  587. data/lib/chef/knife/user_delete.rb +95 -95
  588. data/lib/chef/knife/user_edit.rb +81 -81
  589. data/lib/chef/knife/user_key_create.rb +69 -69
  590. data/lib/chef/knife/user_key_delete.rb +76 -76
  591. data/lib/chef/knife/user_key_edit.rb +79 -79
  592. data/lib/chef/knife/user_key_list.rb +69 -69
  593. data/lib/chef/knife/user_key_show.rb +76 -76
  594. data/lib/chef/knife/user_list.rb +45 -45
  595. data/lib/chef/knife/user_reregister.rb +89 -89
  596. data/lib/chef/knife/user_show.rb +78 -78
  597. data/lib/chef/knife/xargs.rb +266 -266
  598. data/lib/chef/local_mode.rb +128 -128
  599. data/lib/chef/log.rb +68 -68
  600. data/lib/chef/log/syslog.rb +45 -45
  601. data/lib/chef/log/winevt.rb +99 -99
  602. data/lib/chef/mash.rb +226 -226
  603. data/lib/chef/mixin/api_version_request_handling.rb +66 -66
  604. data/lib/chef/mixin/checksum.rb +32 -32
  605. data/lib/chef/mixin/command.rb +193 -193
  606. data/lib/chef/mixin/command/unix.rb +220 -220
  607. data/lib/chef/mixin/command/windows.rb +71 -71
  608. data/lib/chef/mixin/convert_to_class_name.rb +126 -126
  609. data/lib/chef/mixin/create_path.rb +73 -73
  610. data/lib/chef/mixin/deep_merge.rb +140 -140
  611. data/lib/chef/mixin/deprecation.rb +123 -123
  612. data/lib/chef/mixin/descendants_tracker.rb +81 -81
  613. data/lib/chef/mixin/enforce_ownership_and_permissions.rb +39 -39
  614. data/lib/chef/mixin/file_class.rb +35 -35
  615. data/lib/chef/mixin/from_file.rb +50 -50
  616. data/lib/chef/mixin/get_source_from_package.rb +47 -47
  617. data/lib/chef/mixin/homebrew_user.rb +68 -68
  618. data/lib/chef/mixin/language.rb +48 -48
  619. data/lib/chef/mixin/language_include_attribute.rb +34 -34
  620. data/lib/chef/mixin/language_include_recipe.rb +31 -31
  621. data/lib/chef/mixin/lazy_module_include.rb +77 -0
  622. data/lib/chef/mixin/params_validate.rb +489 -489
  623. data/lib/chef/mixin/path_sanity.rb +68 -68
  624. data/lib/chef/mixin/powershell_out.rb +98 -98
  625. data/lib/chef/mixin/powershell_type_coercions.rb +84 -84
  626. data/lib/chef/mixin/properties.rb +303 -303
  627. data/lib/chef/mixin/provides.rb +28 -28
  628. data/lib/chef/mixin/proxified_socket.rb +42 -38
  629. data/lib/chef/mixin/recipe_definition_dsl_core.rb +35 -35
  630. data/lib/chef/mixin/securable.rb +196 -196
  631. data/lib/chef/mixin/shell_out.rb +117 -117
  632. data/lib/chef/mixin/subclass_directive.rb +37 -37
  633. data/lib/chef/mixin/template.rb +262 -262
  634. data/lib/chef/mixin/unformatter.rb +32 -32
  635. data/lib/chef/mixin/uris.rb +43 -43
  636. data/lib/chef/mixin/which.rb +37 -37
  637. data/lib/chef/mixin/why_run.rb +331 -331
  638. data/lib/chef/mixin/wide_string.rb +72 -72
  639. data/lib/chef/mixin/windows_architecture_helper.rb +114 -114
  640. data/lib/chef/mixin/windows_env_helper.rb +67 -67
  641. data/lib/chef/mixin/xml_escape.rb +140 -140
  642. data/lib/chef/mixins.rb +13 -13
  643. data/lib/chef/monkey_patches/net-ssh-multi.rb +141 -140
  644. data/lib/chef/monkey_patches/net_http.rb +60 -60
  645. data/lib/chef/monkey_patches/webrick-utils.rb +51 -51
  646. data/lib/chef/monkey_patches/win32/registry.rb +75 -72
  647. data/lib/chef/monologger.rb +88 -88
  648. data/lib/chef/nil_argument.rb +3 -3
  649. data/lib/chef/node.rb +700 -700
  650. data/lib/chef/node/attribute.rb +586 -586
  651. data/lib/chef/node/attribute_collections.rb +323 -323
  652. data/lib/chef/node/immutable_collections.rb +219 -219
  653. data/lib/chef/node_map.rb +222 -222
  654. data/lib/chef/null_logger.rb +72 -72
  655. data/lib/chef/org.rb +149 -149
  656. data/lib/chef/platform.rb +30 -30
  657. data/lib/chef/platform/handler_map.rb +40 -40
  658. data/lib/chef/platform/priority_map.rb +41 -41
  659. data/lib/chef/platform/provider_handler_map.rb +29 -29
  660. data/lib/chef/platform/provider_mapping.rb +214 -214
  661. data/lib/chef/platform/provider_priority_map.rb +11 -11
  662. data/lib/chef/platform/query_helpers.rb +112 -112
  663. data/lib/chef/platform/rebooter.rb +54 -54
  664. data/lib/chef/platform/resource_handler_map.rb +29 -29
  665. data/lib/chef/platform/resource_priority_map.rb +11 -11
  666. data/lib/chef/platform/service_helpers.rb +122 -122
  667. data/lib/chef/policy_builder.rb +42 -42
  668. data/lib/chef/policy_builder/dynamic.rb +185 -185
  669. data/lib/chef/policy_builder/expand_node_object.rb +278 -278
  670. data/lib/chef/policy_builder/policyfile.rb +523 -527
  671. data/lib/chef/property.rb +674 -673
  672. data/lib/chef/provider.rb +458 -461
  673. data/lib/chef/provider/apt_repository.rb +255 -0
  674. data/lib/chef/provider/apt_update.rb +80 -79
  675. data/lib/chef/provider/batch.rb +45 -45
  676. data/lib/chef/provider/breakpoint.rb +38 -38
  677. data/lib/chef/provider/cookbook_file.rb +53 -53
  678. data/lib/chef/provider/cookbook_file/content.rb +49 -49
  679. data/lib/chef/provider/cron.rb +263 -263
  680. data/lib/chef/provider/cron/aix.rb +50 -50
  681. data/lib/chef/provider/cron/solaris.rb +22 -22
  682. data/lib/chef/provider/cron/unix.rb +83 -83
  683. data/lib/chef/provider/deploy.rb +476 -476
  684. data/lib/chef/provider/deploy/revision.rb +109 -109
  685. data/lib/chef/provider/deploy/timestamped.rb +34 -34
  686. data/lib/chef/provider/directory.rb +152 -152
  687. data/lib/chef/provider/dsc_resource.rb +197 -197
  688. data/lib/chef/provider/dsc_script.rb +185 -185
  689. data/lib/chef/provider/env.rb +169 -169
  690. data/lib/chef/provider/env/windows.rb +72 -72
  691. data/lib/chef/provider/erl_call.rb +108 -108
  692. data/lib/chef/provider/execute.rb +125 -125
  693. data/lib/chef/provider/file.rb +495 -495
  694. data/lib/chef/provider/file/content.rb +39 -39
  695. data/lib/chef/provider/git.rb +332 -332
  696. data/lib/chef/provider/group.rb +183 -183
  697. data/lib/chef/provider/group/aix.rb +86 -86
  698. data/lib/chef/provider/group/dscl.rb +170 -170
  699. data/lib/chef/provider/group/gpasswd.rb +58 -58
  700. data/lib/chef/provider/group/groupadd.rb +137 -137
  701. data/lib/chef/provider/group/groupmod.rb +128 -128
  702. data/lib/chef/provider/group/pw.rb +140 -140
  703. data/lib/chef/provider/group/suse.rb +64 -62
  704. data/lib/chef/provider/group/usermod.rb +91 -91
  705. data/lib/chef/provider/group/windows.rb +98 -98
  706. data/lib/chef/provider/http_request.rb +122 -122
  707. data/lib/chef/provider/ifconfig.rb +226 -226
  708. data/lib/chef/provider/ifconfig/aix.rb +99 -99
  709. data/lib/chef/provider/ifconfig/debian.rb +84 -84
  710. data/lib/chef/provider/ifconfig/redhat.rb +48 -48
  711. data/lib/chef/provider/launchd.rb +208 -208
  712. data/lib/chef/provider/link.rb +159 -159
  713. data/lib/chef/provider/log.rb +57 -57
  714. data/lib/chef/provider/lwrp_base.rb +99 -99
  715. data/lib/chef/provider/mdadm.rb +92 -92
  716. data/lib/chef/provider/mount.rb +169 -173
  717. data/lib/chef/provider/mount/aix.rb +180 -180
  718. data/lib/chef/provider/mount/mount.rb +270 -270
  719. data/lib/chef/provider/mount/solaris.rb +271 -271
  720. data/lib/chef/provider/mount/windows.rb +92 -86
  721. data/lib/chef/provider/noop.rb +37 -0
  722. data/lib/chef/provider/ohai.rb +49 -49
  723. data/lib/chef/provider/osx_profile.rb +256 -256
  724. data/lib/chef/provider/package.rb +565 -565
  725. data/lib/chef/provider/package/aix.rb +136 -136
  726. data/lib/chef/provider/package/apt.rb +185 -185
  727. data/lib/chef/provider/package/chocolatey.rb +275 -275
  728. data/lib/chef/provider/package/dpkg.rb +226 -226
  729. data/lib/chef/provider/package/easy_install.rb +133 -133
  730. data/lib/chef/provider/package/freebsd/base.rb +89 -89
  731. data/lib/chef/provider/package/freebsd/pkg.rb +114 -114
  732. data/lib/chef/provider/package/freebsd/pkgng.rb +78 -78
  733. data/lib/chef/provider/package/freebsd/port.rb +60 -60
  734. data/lib/chef/provider/package/homebrew.rb +137 -137
  735. data/lib/chef/provider/package/ips.rb +91 -91
  736. data/lib/chef/provider/package/macports.rb +101 -101
  737. data/lib/chef/provider/package/openbsd.rb +136 -136
  738. data/lib/chef/provider/package/pacman.rb +104 -104
  739. data/lib/chef/provider/package/paludis.rb +86 -86
  740. data/lib/chef/provider/package/portage.rb +140 -140
  741. data/lib/chef/provider/package/rpm.rb +123 -123
  742. data/lib/chef/provider/package/rubygems.rb +586 -586
  743. data/lib/chef/provider/package/smartos.rb +92 -92
  744. data/lib/chef/provider/package/solaris.rb +138 -138
  745. data/lib/chef/provider/package/windows.rb +269 -269
  746. data/lib/chef/provider/package/windows/exe.rb +117 -117
  747. data/lib/chef/provider/package/windows/msi.rb +93 -93
  748. data/lib/chef/provider/package/windows/registry_uninstall_entry.rb +89 -89
  749. data/lib/chef/provider/package/yum-dump.py +307 -307
  750. data/lib/chef/provider/package/yum.rb +1421 -1421
  751. data/lib/chef/provider/package/zypper.rb +143 -143
  752. data/lib/chef/provider/powershell_script.rb +215 -215
  753. data/lib/chef/provider/reboot.rb +70 -70
  754. data/lib/chef/provider/registry_key.rb +155 -155
  755. data/lib/chef/provider/remote_directory.rb +281 -281
  756. data/lib/chef/provider/remote_file.rb +53 -53
  757. data/lib/chef/provider/remote_file/cache_control_data.rb +195 -195
  758. data/lib/chef/provider/remote_file/content.rb +81 -81
  759. data/lib/chef/provider/remote_file/fetcher.rb +57 -55
  760. data/lib/chef/provider/remote_file/ftp.rb +172 -183
  761. data/lib/chef/provider/remote_file/http.rb +135 -117
  762. data/lib/chef/provider/remote_file/local_file.rb +60 -60
  763. data/lib/chef/provider/remote_file/network_file.rb +48 -48
  764. data/lib/chef/provider/remote_file/sftp.rb +105 -0
  765. data/lib/chef/provider/resource_update.rb +52 -52
  766. data/lib/chef/provider/route.rb +229 -229
  767. data/lib/chef/provider/ruby_block.rb +44 -44
  768. data/lib/chef/provider/script.rb +85 -85
  769. data/lib/chef/provider/service.rb +259 -250
  770. data/lib/chef/provider/service/aix.rb +129 -129
  771. data/lib/chef/provider/service/aixinit.rb +117 -117
  772. data/lib/chef/provider/service/arch.rb +118 -118
  773. data/lib/chef/provider/service/debian.rb +182 -182
  774. data/lib/chef/provider/service/freebsd.rb +195 -195
  775. data/lib/chef/provider/service/gentoo.rb +71 -71
  776. data/lib/chef/provider/service/init.rb +94 -94
  777. data/lib/chef/provider/service/insserv.rb +59 -59
  778. data/lib/chef/provider/service/invokercd.rb +41 -41
  779. data/lib/chef/provider/service/macosx.rb +250 -250
  780. data/lib/chef/provider/service/openbsd.rb +217 -217
  781. data/lib/chef/provider/service/redhat.rb +126 -120
  782. data/lib/chef/provider/service/simple.rb +175 -175
  783. data/lib/chef/provider/service/solaris.rb +122 -117
  784. data/lib/chef/provider/service/systemd.rb +188 -155
  785. data/lib/chef/provider/service/upstart.rb +242 -242
  786. data/lib/chef/provider/service/windows.rb +313 -313
  787. data/lib/chef/provider/subversion.rb +233 -221
  788. data/lib/chef/provider/template.rb +65 -65
  789. data/lib/chef/provider/template/content.rb +70 -70
  790. data/lib/chef/provider/template_finder.rb +62 -62
  791. data/lib/chef/provider/user.rb +211 -211
  792. data/lib/chef/provider/user/aix.rb +97 -97
  793. data/lib/chef/provider/user/dscl.rb +710 -710
  794. data/lib/chef/provider/user/pw.rb +114 -114
  795. data/lib/chef/provider/user/solaris.rb +121 -121
  796. data/lib/chef/provider/user/useradd.rb +163 -163
  797. data/lib/chef/provider/user/windows.rb +128 -128
  798. data/lib/chef/provider/whyrun_safe_ruby_block.rb +32 -32
  799. data/lib/chef/provider/windows_script.rb +72 -72
  800. data/lib/chef/provider_resolver.rb +170 -170
  801. data/lib/chef/providers.rb +145 -142
  802. data/lib/chef/recipe.rb +118 -119
  803. data/lib/chef/request_id.rb +37 -37
  804. data/lib/chef/reserved_names.rb +9 -9
  805. data/lib/chef/resource.rb +1581 -1581
  806. data/lib/chef/resource/action_class.rb +90 -87
  807. data/lib/chef/resource/apt_package.rb +32 -32
  808. data/lib/chef/resource/apt_repository.rb +47 -0
  809. data/lib/chef/resource/apt_update.rb +33 -33
  810. data/lib/chef/resource/bash.rb +33 -33
  811. data/lib/chef/resource/batch.rb +33 -33
  812. data/lib/chef/resource/bff_package.rb +27 -27
  813. data/lib/chef/resource/breakpoint.rb +32 -32
  814. data/lib/chef/resource/chef_gem.rb +51 -51
  815. data/lib/chef/resource/chocolatey_package.rb +39 -39
  816. data/lib/chef/resource/conditional.rb +127 -127
  817. data/lib/chef/resource/conditional_action_not_nothing.rb +48 -48
  818. data/lib/chef/resource/cookbook_file.rb +49 -49
  819. data/lib/chef/resource/cron.rb +216 -216
  820. data/lib/chef/resource/csh.rb +33 -33
  821. data/lib/chef/resource/deploy.rb +443 -443
  822. data/lib/chef/resource/deploy_revision.rb +31 -31
  823. data/lib/chef/resource/directory.rb +62 -62
  824. data/lib/chef/resource/dpkg_package.rb +30 -30
  825. data/lib/chef/resource/dsc_resource.rb +121 -121
  826. data/lib/chef/resource/dsc_script.rb +140 -140
  827. data/lib/chef/resource/easy_install_package.rb +32 -32
  828. data/lib/chef/resource/env.rb +65 -65
  829. data/lib/chef/resource/erl_call.rb +85 -85
  830. data/lib/chef/resource/execute.rb +172 -172
  831. data/lib/chef/resource/file.rb +83 -83
  832. data/lib/chef/resource/file/verification.rb +128 -128
  833. data/lib/chef/resource/freebsd_package.rb +62 -62
  834. data/lib/chef/resource/gem_package.rb +41 -41
  835. data/lib/chef/resource/git.rb +44 -44
  836. data/lib/chef/resource/group.rb +102 -102
  837. data/lib/chef/resource/homebrew_package.rb +34 -34
  838. data/lib/chef/resource/http_request.rb +66 -66
  839. data/lib/chef/resource/ifconfig.rb +147 -147
  840. data/lib/chef/resource/ips_package.rb +34 -34
  841. data/lib/chef/resource/ksh.rb +32 -32
  842. data/lib/chef/resource/launchd.rb +104 -104
  843. data/lib/chef/resource/link.rb +107 -107
  844. data/lib/chef/resource/log.rb +76 -76
  845. data/lib/chef/resource/lwrp_base.rb +124 -124
  846. data/lib/chef/resource/macosx_service.rb +58 -58
  847. data/lib/chef/resource/macports_package.rb +27 -27
  848. data/lib/chef/resource/mdadm.rb +103 -103
  849. data/lib/chef/resource/mount.rb +187 -187
  850. data/lib/chef/resource/ohai.rb +53 -53
  851. data/lib/chef/resource/openbsd_package.rb +35 -35
  852. data/lib/chef/resource/osx_profile.rb +74 -74
  853. data/lib/chef/resource/package.rb +47 -47
  854. data/lib/chef/resource/pacman_package.rb +28 -28
  855. data/lib/chef/resource/paludis_package.rb +33 -33
  856. data/lib/chef/resource/perl.rb +32 -32
  857. data/lib/chef/resource/portage_package.rb +32 -32
  858. data/lib/chef/resource/powershell_script.rb +50 -50
  859. data/lib/chef/resource/python.rb +31 -31
  860. data/lib/chef/resource/reboot.rb +48 -48
  861. data/lib/chef/resource/registry_key.rb +144 -144
  862. data/lib/chef/resource/remote_directory.rb +122 -122
  863. data/lib/chef/resource/remote_file.rb +158 -149
  864. data/lib/chef/resource/resource_notification.rb +122 -122
  865. data/lib/chef/resource/route.rb +137 -137
  866. data/lib/chef/resource/rpm_package.rb +32 -32
  867. data/lib/chef/resource/ruby.rb +31 -31
  868. data/lib/chef/resource/ruby_block.rb +53 -53
  869. data/lib/chef/resource/scm.rb +185 -185
  870. data/lib/chef/resource/script.rb +74 -74
  871. data/lib/chef/resource/service.rb +217 -208
  872. data/lib/chef/resource/smartos_package.rb +29 -29
  873. data/lib/chef/resource/solaris_package.rb +31 -31
  874. data/lib/chef/resource/subversion.rb +44 -44
  875. data/lib/chef/resource/template.rb +215 -215
  876. data/lib/chef/resource/timestamped_deploy.rb +26 -26
  877. data/lib/chef/resource/user.rb +160 -160
  878. data/lib/chef/resource/whyrun_safe_ruby_block.rb +24 -24
  879. data/lib/chef/resource/windows_package.rb +55 -55
  880. data/lib/chef/resource/windows_script.rb +65 -65
  881. data/lib/chef/resource/windows_service.rb +71 -71
  882. data/lib/chef/resource/yum_package.rb +47 -47
  883. data/lib/chef/resource/zypper_package.rb +28 -28
  884. data/lib/chef/resource_builder.rb +151 -151
  885. data/lib/chef/resource_collection.rb +131 -89
  886. data/lib/chef/resource_collection/resource_collection_serialization.rb +59 -59
  887. data/lib/chef/resource_collection/resource_list.rb +90 -90
  888. data/lib/chef/resource_collection/resource_set.rb +170 -170
  889. data/lib/chef/resource_collection/stepable_iterator.rb +124 -124
  890. data/lib/chef/resource_definition.rb +68 -68
  891. data/lib/chef/resource_definition_list.rb +38 -38
  892. data/lib/chef/resource_reporter.rb +327 -327
  893. data/lib/chef/resource_resolver.rb +185 -185
  894. data/lib/chef/resources.rb +89 -88
  895. data/lib/chef/rest.rb +209 -209
  896. data/lib/chef/role.rb +280 -280
  897. data/lib/chef/run_context.rb +694 -670
  898. data/lib/chef/run_context/cookbook_compiler.rb +290 -289
  899. data/lib/chef/run_list.rb +168 -168
  900. data/lib/chef/run_list/run_list_expansion.rb +234 -234
  901. data/lib/chef/run_list/run_list_item.rb +98 -98
  902. data/lib/chef/run_list/versioned_recipe_list.rb +102 -102
  903. data/lib/chef/run_lock.rb +197 -197
  904. data/lib/chef/run_status.rb +125 -125
  905. data/lib/chef/runner.rb +143 -141
  906. data/lib/chef/sandbox.rb +20 -20
  907. data/lib/chef/scan_access_control.rb +138 -138
  908. data/lib/chef/search/query.rb +180 -180
  909. data/lib/chef/server_api.rb +78 -78
  910. data/lib/chef/shell.rb +327 -327
  911. data/lib/chef/shell/ext.rb +593 -593
  912. data/lib/chef/shell/model_wrapper.rb +120 -120
  913. data/lib/chef/shell/shell_session.rb +299 -299
  914. data/lib/chef/shell_out.rb +13 -13
  915. data/lib/chef/tasks/chef_repo.rake +200 -200
  916. data/lib/chef/user.rb +199 -199
  917. data/lib/chef/user_v1.rb +330 -330
  918. data/lib/chef/util/backup.rb +94 -94
  919. data/lib/chef/util/diff.rb +184 -184
  920. data/lib/chef/util/dsc/configuration_generator.rb +139 -139
  921. data/lib/chef/util/dsc/lcm_output_parser.rb +137 -137
  922. data/lib/chef/util/dsc/local_configuration_manager.rb +141 -141
  923. data/lib/chef/util/dsc/resource_info.rb +26 -26
  924. data/lib/chef/util/dsc/resource_store.rb +109 -109
  925. data/lib/chef/util/editor.rb +91 -91
  926. data/lib/chef/util/file_edit.rb +100 -100
  927. data/lib/chef/util/path_helper.rb +25 -25
  928. data/lib/chef/util/powershell/cmdlet.rb +170 -170
  929. data/lib/chef/util/powershell/cmdlet_result.rb +61 -61
  930. data/lib/chef/util/powershell/ps_credential.rb +41 -41
  931. data/lib/chef/util/selinux.rb +92 -92
  932. data/lib/chef/util/threaded_job_queue.rb +61 -61
  933. data/lib/chef/util/windows.rb +24 -24
  934. data/lib/chef/util/windows/net_group.rb +84 -84
  935. data/lib/chef/util/windows/net_use.rb +85 -85
  936. data/lib/chef/util/windows/net_user.rb +170 -170
  937. data/lib/chef/util/windows/volume.rb +59 -59
  938. data/lib/chef/version.rb +34 -34
  939. data/lib/chef/version/platform.rb +44 -44
  940. data/lib/chef/version_class.rb +70 -70
  941. data/lib/chef/version_constraint.rb +118 -118
  942. data/lib/chef/version_constraint/platform.rb +26 -26
  943. data/lib/chef/whitelist.rb +86 -86
  944. data/lib/chef/win32/api.rb +374 -374
  945. data/lib/chef/win32/api/crypto.rb +63 -63
  946. data/lib/chef/win32/api/error.rb +953 -953
  947. data/lib/chef/win32/api/file.rb +625 -625
  948. data/lib/chef/win32/api/installer.rb +165 -165
  949. data/lib/chef/win32/api/memory.rb +105 -105
  950. data/lib/chef/win32/api/net.rb +312 -312
  951. data/lib/chef/win32/api/process.rb +42 -42
  952. data/lib/chef/win32/api/psapi.rb +51 -51
  953. data/lib/chef/win32/api/registry.rb +51 -51
  954. data/lib/chef/win32/api/security.rb +460 -460
  955. data/lib/chef/win32/api/synchronization.rb +89 -89
  956. data/lib/chef/win32/api/system.rb +238 -238
  957. data/lib/chef/win32/api/unicode.rb +135 -135
  958. data/lib/chef/win32/crypto.rb +50 -50
  959. data/lib/chef/win32/error.rb +86 -86
  960. data/lib/chef/win32/eventlog.rb +31 -31
  961. data/lib/chef/win32/file.rb +218 -218
  962. data/lib/chef/win32/file/info.rb +99 -99
  963. data/lib/chef/win32/file/version_info.rb +93 -93
  964. data/lib/chef/win32/handle.rb +55 -55
  965. data/lib/chef/win32/memory.rb +101 -101
  966. data/lib/chef/win32/mutex.rb +116 -116
  967. data/lib/chef/win32/net.rb +311 -311
  968. data/lib/chef/win32/process.rb +97 -97
  969. data/lib/chef/win32/registry.rb +374 -372
  970. data/lib/chef/win32/security.rb +665 -665
  971. data/lib/chef/win32/security/ace.rb +123 -123
  972. data/lib/chef/win32/security/acl.rb +103 -103
  973. data/lib/chef/win32/security/securable_object.rb +109 -109
  974. data/lib/chef/win32/security/security_descriptor.rb +93 -93
  975. data/lib/chef/win32/security/sid.rb +304 -304
  976. data/lib/chef/win32/security/token.rb +72 -72
  977. data/lib/chef/win32/system.rb +62 -62
  978. data/lib/chef/win32/unicode.rb +60 -60
  979. data/lib/chef/win32/version.rb +158 -158
  980. data/lib/chef/workstation_config_loader.rb +23 -23
  981. data/spec/data/apt/chef-integration-test-1.0/debian/changelog +5 -5
  982. data/spec/data/apt/chef-integration-test-1.0/debian/compat +1 -1
  983. data/spec/data/apt/chef-integration-test-1.0/debian/control +13 -13
  984. data/spec/data/apt/chef-integration-test-1.0/debian/copyright +34 -34
  985. data/spec/data/apt/chef-integration-test-1.0/debian/files +1 -1
  986. data/spec/data/apt/chef-integration-test-1.0/debian/rules +13 -13
  987. data/spec/data/apt/chef-integration-test-1.0/debian/source/format +1 -1
  988. data/spec/data/apt/chef-integration-test-1.1/debian/changelog +11 -11
  989. data/spec/data/apt/chef-integration-test-1.1/debian/compat +1 -1
  990. data/spec/data/apt/chef-integration-test-1.1/debian/control +13 -13
  991. data/spec/data/apt/chef-integration-test-1.1/debian/copyright +34 -34
  992. data/spec/data/apt/chef-integration-test-1.1/debian/files +1 -1
  993. data/spec/data/apt/chef-integration-test-1.1/debian/rules +13 -13
  994. data/spec/data/apt/chef-integration-test-1.1/debian/source/format +1 -1
  995. data/spec/data/apt/chef-integration-test2-1.0/debian/changelog +5 -5
  996. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2.debhelper.log +45 -45
  997. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2.substvars +1 -1
  998. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2/DEBIAN/conffiles +1 -1
  999. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2/DEBIAN/control +10 -10
  1000. data/spec/data/apt/chef-integration-test2-1.0/debian/chef-integration-test2/DEBIAN/md5sums +1 -1
  1001. data/spec/data/apt/chef-integration-test2-1.0/debian/compat +1 -1
  1002. data/spec/data/apt/chef-integration-test2-1.0/debian/conffiles +1 -1
  1003. data/spec/data/apt/chef-integration-test2-1.0/debian/control +13 -13
  1004. data/spec/data/apt/chef-integration-test2-1.0/debian/copyright +34 -34
  1005. data/spec/data/apt/chef-integration-test2-1.0/debian/files +1 -1
  1006. data/spec/data/apt/chef-integration-test2-1.0/debian/rules +13 -13
  1007. data/spec/data/apt/chef-integration-test2-1.0/debian/source/format +1 -1
  1008. data/spec/data/apt/chef-integration-test2_1.0-1.dsc +18 -18
  1009. data/spec/data/apt/chef-integration-test2_1.0-1_amd64.build +91 -91
  1010. data/spec/data/apt/chef-integration-test2_1.0-1_amd64.changes +31 -31
  1011. data/spec/data/apt/chef-integration-test_1.0-1_amd64.changes +22 -22
  1012. data/spec/data/apt/chef-integration-test_1.1-1_amd64.changes +22 -22
  1013. data/spec/data/apt/var/www/apt/conf/distributions +7 -7
  1014. data/spec/data/apt/var/www/apt/conf/incoming +4 -4
  1015. data/spec/data/apt/var/www/apt/conf/pulls +3 -3
  1016. data/spec/data/apt/var/www/apt/db/version +4 -4
  1017. data/spec/data/apt/var/www/apt/dists/sid/Release +19 -19
  1018. data/spec/data/apt/var/www/apt/dists/sid/main/binary-amd64/Packages +16 -16
  1019. data/spec/data/apt/var/www/apt/dists/sid/main/binary-amd64/Release +5 -5
  1020. data/spec/data/bootstrap/encrypted_data_bag_secret +1 -1
  1021. data/spec/data/bootstrap/no_proxy.erb +2 -2
  1022. data/spec/data/bootstrap/secret.erb +9 -9
  1023. data/spec/data/bootstrap/test-hints.erb +12 -12
  1024. data/spec/data/bootstrap/test.erb +1 -1
  1025. data/spec/data/cb_version_cookbooks/tatft/README.rdoc +2 -2
  1026. data/spec/data/cb_version_cookbooks/tatft/attributes/default.rb +1 -1
  1027. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-600hhz-0 +1 -1
  1028. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ahd2gq-0 +1 -1
  1029. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-api8ux-0 +1 -1
  1030. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-b0r1m1-0 +1 -1
  1031. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-bfygsi-0 +1 -1
  1032. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-el14l6-0 +1 -1
  1033. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ivrl3y-0 +1 -1
  1034. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-kkbs85-0 +1 -1
  1035. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ory1ux-0 +1 -1
  1036. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-pgsq76-0 +1 -1
  1037. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ra8uim-0 +1 -1
  1038. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t7k1g-0 +1 -1
  1039. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t8g0sv-0 +1 -1
  1040. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ufy6g3-0 +1 -1
  1041. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-x2d6j9-0 +1 -1
  1042. data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-xi0l6h-0 +1 -1
  1043. data/spec/data/client.d_00/00-foo.rb +2 -2
  1044. data/spec/data/client.d_00/01-bar.rb +1 -1
  1045. data/spec/data/client.d_00/bar +1 -1
  1046. data/spec/data/client.d_01/foo/bar.rb +1 -1
  1047. data/spec/data/client.d_02/foo.rb/foo.txt +1 -1
  1048. data/spec/data/config.rb +6 -6
  1049. data/spec/data/cookbooks/angrybash/metadata.rb +2 -2
  1050. data/spec/data/cookbooks/angrybash/recipes/default.rb +8 -8
  1051. data/spec/data/cookbooks/apache2/files/default/apache2_module_conf_generate.pl +2 -2
  1052. data/spec/data/cookbooks/apache2/metadata.rb +2 -2
  1053. data/spec/data/cookbooks/apache2/recipes/default.rb +2 -2
  1054. data/spec/data/cookbooks/borken/metadata.rb +2 -2
  1055. data/spec/data/cookbooks/borken/recipes/default.rb +1 -1
  1056. data/spec/data/cookbooks/borken/templates/default/borken.erb +1 -1
  1057. data/spec/data/cookbooks/chefignore +8 -8
  1058. data/spec/data/cookbooks/ignorken/files/default/not_me.rb +2 -2
  1059. data/spec/data/cookbooks/ignorken/metadata.rb +2 -2
  1060. data/spec/data/cookbooks/ignorken/recipes/ignoreme.rb +1 -1
  1061. data/spec/data/cookbooks/ignorken/templates/ubuntu-12.10/not_me.rb +2 -2
  1062. data/spec/data/cookbooks/java/files/default/java.response +1 -1
  1063. data/spec/data/cookbooks/java/metadata.rb +2 -2
  1064. data/spec/data/cookbooks/name-mismatch-versionnumber/README.md +4 -4
  1065. data/spec/data/cookbooks/name-mismatch-versionnumber/metadata.rb +8 -8
  1066. data/spec/data/cookbooks/name-mismatch-versionnumber/recipes/default.rb +8 -8
  1067. data/spec/data/cookbooks/openldap/attributes/default.rb +16 -16
  1068. data/spec/data/cookbooks/openldap/attributes/smokey.rb +1 -1
  1069. data/spec/data/cookbooks/openldap/definitions/client.rb +5 -5
  1070. data/spec/data/cookbooks/openldap/definitions/server.rb +5 -5
  1071. data/spec/data/cookbooks/openldap/files/default/.dotfile +1 -1
  1072. data/spec/data/cookbooks/openldap/files/default/remotedir/.a_dotdir/.a_dotfile_in_a_dotdir +1 -1
  1073. data/spec/data/cookbooks/openldap/files/default/remotedir/not_a_template.erb +2 -2
  1074. data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file1.txt +2 -2
  1075. data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file2.txt +2 -2
  1076. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/.a_dotfile +1 -1
  1077. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file1.txt +2 -2
  1078. data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file2.txt +2 -2
  1079. data/spec/data/cookbooks/openldap/files/default/remotedir/subdir_with_no_file_just_a_subsubdir/the_subsubdir/some_file.txt +3 -3
  1080. data/spec/data/cookbooks/openldap/libraries/openldap.rb +4 -4
  1081. data/spec/data/cookbooks/openldap/libraries/openldap/version.rb +3 -3
  1082. data/spec/data/cookbooks/openldap/metadata.rb +8 -8
  1083. data/spec/data/cookbooks/openldap/recipes/default.rb +4 -4
  1084. data/spec/data/cookbooks/openldap/recipes/gigantor.rb +3 -3
  1085. data/spec/data/cookbooks/openldap/recipes/one.rb +15 -15
  1086. data/spec/data/cookbooks/openldap/recipes/return.rb +2 -2
  1087. data/spec/data/cookbooks/openldap/templates/default/helper_test.erb +1 -1
  1088. data/spec/data/cookbooks/openldap/templates/default/helpers.erb +14 -14
  1089. data/spec/data/cookbooks/openldap/templates/default/helpers_via_partial_test.erb +1 -1
  1090. data/spec/data/cookbooks/openldap/templates/default/nested_openldap_partials.erb +1 -1
  1091. data/spec/data/cookbooks/openldap/templates/default/nested_partial.erb +1 -1
  1092. data/spec/data/cookbooks/openldap/templates/default/no_windows_line_endings.erb +4 -4
  1093. data/spec/data/cookbooks/openldap/templates/default/openldap_variable_stuff.conf.erb +1 -1
  1094. data/spec/data/cookbooks/openldap/templates/default/test.erb +1 -1
  1095. data/spec/data/cookbooks/preseed/files/default/preseed-file.seed +1 -1
  1096. data/spec/data/cookbooks/preseed/files/default/preseed-template.seed +4 -4
  1097. data/spec/data/cookbooks/preseed/metadata.rb +2 -2
  1098. data/spec/data/cookbooks/preseed/templates/default/preseed-template-variables.seed +1 -1
  1099. data/spec/data/cookbooks/preseed/templates/default/preseed-template.seed +1 -1
  1100. data/spec/data/cookbooks/supports-platform-constraints/metadata.rb +5 -5
  1101. data/spec/data/definitions/test.rb +4 -4
  1102. data/spec/data/environment-config.rb +4 -4
  1103. data/spec/data/file-providers-method-snapshot-chef-11-4.json +127 -127
  1104. data/spec/data/fileedit/hosts +4 -4
  1105. data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/README.md +4 -4
  1106. data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/metadata.rb +13 -13
  1107. data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/recipes/default.rb +8 -8
  1108. data/spec/data/invalid-metadata-chef-repo/invalid-metadata/README.md +4 -4
  1109. data/spec/data/invalid-metadata-chef-repo/invalid-metadata/metadata.rb +9 -9
  1110. data/spec/data/invalid-metadata-chef-repo/invalid-metadata/recipes/default.rb +8 -8
  1111. data/spec/data/kitchen/chefignore +6 -6
  1112. data/spec/data/kitchen/openldap/attributes/default.rb +3 -3
  1113. data/spec/data/kitchen/openldap/attributes/robinson.rb +2 -2
  1114. data/spec/data/kitchen/openldap/definitions/client.rb +3 -3
  1115. data/spec/data/kitchen/openldap/definitions/drewbarrymore.rb +2 -2
  1116. data/spec/data/kitchen/openldap/recipes/gigantor.rb +2 -2
  1117. data/spec/data/kitchen/openldap/recipes/ignoreme.rb +2 -2
  1118. data/spec/data/kitchen/openldap/recipes/woot.rb +3 -3
  1119. data/spec/data/knife_subcommand/test_explicit_category.rb +6 -6
  1120. data/spec/data/knife_subcommand/test_name_mapping.rb +4 -4
  1121. data/spec/data/knife_subcommand/test_yourself.rb +21 -21
  1122. data/spec/data/lwrp/providers/buck_passer.rb +28 -28
  1123. data/spec/data/lwrp/providers/buck_passer_2.rb +26 -26
  1124. data/spec/data/lwrp/providers/embedded_resource_accesses_providers_scope.rb +28 -28
  1125. data/spec/data/lwrp/providers/inline_compiler.rb +26 -26
  1126. data/spec/data/lwrp/providers/monkey_name_printer.rb +5 -5
  1127. data/spec/data/lwrp/providers/paint_drying_watcher.rb +7 -7
  1128. data/spec/data/lwrp/providers/thumb_twiddler.rb +7 -7
  1129. data/spec/data/lwrp/resources/bar.rb +2 -2
  1130. data/spec/data/lwrp/resources/foo.rb +4 -4
  1131. data/spec/data/lwrp/resources_with_default_attributes/nodeattr.rb +1 -1
  1132. data/spec/data/lwrp_override/providers/buck_passer.rb +5 -5
  1133. data/spec/data/lwrp_override/resources/foo.rb +10 -10
  1134. data/spec/data/mac_users/10.7-8.plist.xml +559 -559
  1135. data/spec/data/mac_users/10.7-8.shadow.xml +11 -11
  1136. data/spec/data/mac_users/10.7.plist.xml +559 -559
  1137. data/spec/data/mac_users/10.7.shadow.xml +11 -11
  1138. data/spec/data/mac_users/10.8.plist.xml +559 -559
  1139. data/spec/data/mac_users/10.8.shadow.xml +21 -21
  1140. data/spec/data/mac_users/10.9.plist.xml +560 -560
  1141. data/spec/data/mac_users/10.9.shadow.xml +21 -21
  1142. data/spec/data/metadata/quick_start/metadata.rb +19 -19
  1143. data/spec/data/nested.json +2 -2
  1144. data/spec/data/nodes/default.rb +15 -15
  1145. data/spec/data/nodes/test.example.com.rb +17 -17
  1146. data/spec/data/nodes/test.rb +15 -15
  1147. data/spec/data/null_config.rb +1 -1
  1148. data/spec/data/object_loader/environments/test.json +7 -7
  1149. data/spec/data/object_loader/environments/test.rb +2 -2
  1150. data/spec/data/object_loader/environments/test_json_class.json +8 -8
  1151. data/spec/data/object_loader/nodes/test.json +7 -7
  1152. data/spec/data/object_loader/nodes/test.rb +2 -2
  1153. data/spec/data/object_loader/nodes/test_json_class.json +8 -8
  1154. data/spec/data/object_loader/roles/test.json +7 -7
  1155. data/spec/data/object_loader/roles/test.rb +2 -2
  1156. data/spec/data/object_loader/roles/test_json_class.json +8 -8
  1157. data/spec/data/partial_one.erb +1 -1
  1158. data/spec/data/recipes/test.rb +7 -7
  1159. data/spec/data/run_context/cookbooks/circular-dep1/attributes/default.rb +4 -4
  1160. data/spec/data/run_context/cookbooks/circular-dep1/definitions/circular_dep1_res.rb +1 -1
  1161. data/spec/data/run_context/cookbooks/circular-dep1/libraries/lib.rb +2 -2
  1162. data/spec/data/run_context/cookbooks/circular-dep1/metadata.rb +2 -2
  1163. data/spec/data/run_context/cookbooks/circular-dep1/providers/provider.rb +1 -1
  1164. data/spec/data/run_context/cookbooks/circular-dep1/resources/resource.rb +1 -1
  1165. data/spec/data/run_context/cookbooks/circular-dep2/attributes/default.rb +3 -3
  1166. data/spec/data/run_context/cookbooks/circular-dep2/definitions/circular_dep2_res.rb +1 -1
  1167. data/spec/data/run_context/cookbooks/circular-dep2/libraries/lib.rb +2 -2
  1168. data/spec/data/run_context/cookbooks/circular-dep2/metadata.rb +2 -2
  1169. data/spec/data/run_context/cookbooks/circular-dep2/providers/provider.rb +1 -1
  1170. data/spec/data/run_context/cookbooks/circular-dep2/resources/resource.rb +1 -1
  1171. data/spec/data/run_context/cookbooks/dependency1/attributes/aa_first.rb +2 -2
  1172. data/spec/data/run_context/cookbooks/dependency1/attributes/default.rb +2 -2
  1173. data/spec/data/run_context/cookbooks/dependency1/attributes/zz_last.rb +3 -3
  1174. data/spec/data/run_context/cookbooks/dependency1/definitions/dependency1_res.rb +1 -1
  1175. data/spec/data/run_context/cookbooks/dependency1/libraries/lib.rb +2 -2
  1176. data/spec/data/run_context/cookbooks/dependency1/providers/provider.rb +1 -1
  1177. data/spec/data/run_context/cookbooks/dependency1/resources/resource.rb +1 -1
  1178. data/spec/data/run_context/cookbooks/dependency2/attributes/default.rb +3 -3
  1179. data/spec/data/run_context/cookbooks/dependency2/definitions/dependency2_res.rb +1 -1
  1180. data/spec/data/run_context/cookbooks/dependency2/libraries/lib.rb +2 -2
  1181. data/spec/data/run_context/cookbooks/dependency2/providers/provider.rb +1 -1
  1182. data/spec/data/run_context/cookbooks/dependency2/resources/resource.rb +1 -1
  1183. data/spec/data/run_context/cookbooks/include/recipes/default.rb +24 -24
  1184. data/spec/data/run_context/cookbooks/include/recipes/includee.rb +3 -3
  1185. data/spec/data/run_context/cookbooks/no-default-attr/attributes/server.rb +3 -3
  1186. data/spec/data/run_context/cookbooks/no-default-attr/definitions/no_default-attr_res.rb +1 -1
  1187. data/spec/data/run_context/cookbooks/no-default-attr/providers/provider.rb +1 -1
  1188. data/spec/data/run_context/cookbooks/no-default-attr/resources/resource.rb +1 -1
  1189. data/spec/data/run_context/cookbooks/test-with-circular-deps/attributes/default.rb +3 -3
  1190. data/spec/data/run_context/cookbooks/test-with-circular-deps/definitions/test_with-circular-deps_res.rb +1 -1
  1191. data/spec/data/run_context/cookbooks/test-with-circular-deps/libraries/lib.rb +2 -2
  1192. data/spec/data/run_context/cookbooks/test-with-circular-deps/metadata.rb +2 -2
  1193. data/spec/data/run_context/cookbooks/test-with-circular-deps/providers/provider.rb +1 -1
  1194. data/spec/data/run_context/cookbooks/test-with-circular-deps/resources/resource.rb +1 -1
  1195. data/spec/data/run_context/cookbooks/test-with-deps/attributes/default.rb +3 -3
  1196. data/spec/data/run_context/cookbooks/test-with-deps/definitions/test_with-deps_res.rb +1 -1
  1197. data/spec/data/run_context/cookbooks/test-with-deps/libraries/lib.rb +1 -1
  1198. data/spec/data/run_context/cookbooks/test-with-deps/metadata.rb +3 -3
  1199. data/spec/data/run_context/cookbooks/test-with-deps/providers/provider.rb +1 -1
  1200. data/spec/data/run_context/cookbooks/test-with-deps/resources/resource.rb +1 -1
  1201. data/spec/data/run_context/cookbooks/test/attributes/george.rb +1 -1
  1202. data/spec/data/run_context/cookbooks/test/definitions/new_animals.rb +9 -9
  1203. data/spec/data/run_context/cookbooks/test/definitions/new_cat.rb +5 -5
  1204. data/spec/data/run_context/cookbooks/test/definitions/test_res.rb +1 -1
  1205. data/spec/data/run_context/cookbooks/test/providers/provider.rb +1 -1
  1206. data/spec/data/run_context/cookbooks/test/recipes/default.rb +5 -5
  1207. data/spec/data/run_context/cookbooks/test/recipes/one.rb +7 -7
  1208. data/spec/data/run_context/cookbooks/test/recipes/two.rb +7 -7
  1209. data/spec/data/run_context/cookbooks/test/resources/resource.rb +1 -1
  1210. data/spec/data/run_context/nodes/run_context.rb +5 -5
  1211. data/spec/data/search_queries_to_transform.txt +98 -98
  1212. data/spec/data/shef-config.rb +10 -10
  1213. data/spec/data/ssl/5e707473.0 +18 -18
  1214. data/spec/data/ssl/chef-rspec.cert +27 -27
  1215. data/spec/data/ssl/chef-rspec.key +27 -27
  1216. data/spec/data/ssl/key.pem +15 -15
  1217. data/spec/data/ssl/private_key.pem +27 -27
  1218. data/spec/data/ssl/private_key_with_whitespace.pem +32 -32
  1219. data/spec/data/standalone_cookbook/chefignore +9 -9
  1220. data/spec/data/standalone_cookbook/recipes/default.rb +2 -2
  1221. data/spec/data/trusted_certs/example.crt +22 -22
  1222. data/spec/data/trusted_certs/intermediate.pem +27 -27
  1223. data/spec/data/trusted_certs/opscode.pem +57 -57
  1224. data/spec/data/trusted_certs/root.pem +22 -22
  1225. data/spec/functional/application_spec.rb +58 -58
  1226. data/spec/functional/assets/chefinittest +34 -34
  1227. data/spec/functional/assets/testchefsubsys +10 -10
  1228. data/spec/functional/audit/rspec_formatter_spec.rb +54 -54
  1229. data/spec/functional/audit/runner_spec.rb +121 -121
  1230. data/spec/functional/dsl/reboot_pending_spec.rb +106 -106
  1231. data/spec/functional/dsl/registry_helper_spec.rb +61 -61
  1232. data/spec/functional/event_loggers/windows_eventlog_spec.rb +101 -101
  1233. data/spec/functional/file_content_management/deploy_strategies_spec.rb +229 -229
  1234. data/spec/functional/http/simple_spec.rb +140 -140
  1235. data/spec/functional/knife/configure_spec.rb +33 -33
  1236. data/spec/functional/knife/cookbook_delete_spec.rb +167 -167
  1237. data/spec/functional/knife/exec_spec.rb +55 -55
  1238. data/spec/functional/knife/rehash_spec.rb +39 -39
  1239. data/spec/functional/knife/smoke_test.rb +42 -42
  1240. data/spec/functional/knife/ssh_spec.rb +284 -284
  1241. data/spec/functional/mixin/powershell_out_spec.rb +43 -43
  1242. data/spec/functional/mixin/shell_out_spec.rb +48 -48
  1243. data/spec/functional/notifications_spec.rb +238 -238
  1244. data/spec/functional/provider/remote_file/cache_control_data_spec.rb +100 -100
  1245. data/spec/functional/provider/whyrun_safe_ruby_block_spec.rb +51 -51
  1246. data/spec/functional/rebooter_spec.rb +105 -105
  1247. data/spec/functional/resource/aix_service_spec.rb +138 -138
  1248. data/spec/functional/resource/aixinit_service_spec.rb +211 -211
  1249. data/spec/functional/resource/base.rb +28 -28
  1250. data/spec/functional/resource/bash_spec.rb +88 -88
  1251. data/spec/functional/resource/batch_spec.rb +30 -30
  1252. data/spec/functional/resource/bff_spec.rb +120 -120
  1253. data/spec/functional/resource/chocolatey_package_spec.rb +130 -130
  1254. data/spec/functional/resource/cookbook_file_spec.rb +81 -81
  1255. data/spec/functional/resource/cron_spec.rb +172 -172
  1256. data/spec/functional/resource/deploy_revision_spec.rb +881 -881
  1257. data/spec/functional/resource/directory_spec.rb +43 -43
  1258. data/spec/functional/resource/dpkg_package_spec.rb +339 -339
  1259. data/spec/functional/resource/dsc_resource_spec.rb +90 -90
  1260. data/spec/functional/resource/dsc_script_spec.rb +479 -479
  1261. data/spec/functional/resource/env_spec.rb +192 -192
  1262. data/spec/functional/resource/execute_spec.rb +154 -154
  1263. data/spec/functional/resource/file_spec.rb +167 -167
  1264. data/spec/functional/resource/git_spec.rb +259 -259
  1265. data/spec/functional/resource/group_spec.rb +461 -461
  1266. data/spec/functional/resource/ifconfig_spec.rb +165 -165
  1267. data/spec/functional/resource/link_spec.rb +613 -613
  1268. data/spec/functional/resource/mount_spec.rb +203 -203
  1269. data/spec/functional/resource/ohai_spec.rb +62 -62
  1270. data/spec/functional/resource/package_spec.rb +386 -386
  1271. data/spec/functional/resource/powershell_script_spec.rb +601 -601
  1272. data/spec/functional/resource/reboot_spec.rb +103 -103
  1273. data/spec/functional/resource/registry_spec.rb +560 -560
  1274. data/spec/functional/resource/remote_directory_spec.rb +220 -220
  1275. data/spec/functional/resource/remote_file_spec.rb +240 -240
  1276. data/spec/functional/resource/rpm_spec.rb +123 -123
  1277. data/spec/functional/resource/template_spec.rb +212 -212
  1278. data/spec/functional/resource/user/dscl_spec.rb +198 -198
  1279. data/spec/functional/resource/user/useradd_spec.rb +692 -692
  1280. data/spec/functional/resource/user/windows_spec.rb +133 -133
  1281. data/spec/functional/resource/windows_package_spec.rb +168 -168
  1282. data/spec/functional/resource/windows_service_spec.rb +102 -102
  1283. data/spec/functional/rest_spec.rb +95 -95
  1284. data/spec/functional/run_lock_spec.rb +466 -466
  1285. data/spec/functional/shell_spec.rb +148 -148
  1286. data/spec/functional/tiny_server_spec.rb +78 -78
  1287. data/spec/functional/util/path_helper_spec.rb +37 -37
  1288. data/spec/functional/util/powershell/cmdlet_spec.rb +111 -111
  1289. data/spec/functional/version_spec.rb +35 -35
  1290. data/spec/functional/win32/crypto_spec.rb +54 -54
  1291. data/spec/functional/win32/registry_spec.rb +623 -623
  1292. data/spec/functional/win32/security_spec.rb +100 -100
  1293. data/spec/functional/win32/service_manager_spec.rb +220 -220
  1294. data/spec/functional/win32/sid_spec.rb +55 -55
  1295. data/spec/functional/win32/version_info_spec.rb +50 -50
  1296. data/spec/functional/win32/versions_spec.rb +117 -117
  1297. data/spec/integration/client/client_spec.rb +500 -500
  1298. data/spec/integration/client/ipv6_spec.rb +134 -134
  1299. data/spec/integration/knife/chef_fs_data_store_spec.rb +556 -556
  1300. data/spec/integration/knife/chef_repo_path_spec.rb +890 -890
  1301. data/spec/integration/knife/chef_repository_file_system_spec.rb +296 -292
  1302. data/spec/integration/knife/chefignore_spec.rb +300 -300
  1303. data/spec/integration/knife/common_options_spec.rb +155 -155
  1304. data/spec/integration/knife/cookbook_api_ipv6_spec.rb +112 -112
  1305. data/spec/integration/knife/delete_spec.rb +1017 -1017
  1306. data/spec/integration/knife/deps_spec.rb +706 -706
  1307. data/spec/integration/knife/diff_spec.rb +602 -602
  1308. data/spec/integration/knife/download_spec.rb +1314 -1314
  1309. data/spec/integration/knife/list_spec.rb +1067 -1067
  1310. data/spec/integration/knife/raw_spec.rb +242 -242
  1311. data/spec/integration/knife/redirection_spec.rb +52 -52
  1312. data/spec/integration/knife/serve_spec.rb +57 -57
  1313. data/spec/integration/knife/show_spec.rb +167 -167
  1314. data/spec/integration/knife/upload_spec.rb +1529 -1529
  1315. data/spec/integration/recipes/lwrp_inline_resources_spec.rb +175 -148
  1316. data/spec/integration/recipes/lwrp_spec.rb +53 -53
  1317. data/spec/integration/recipes/noop_resource_spec.rb +24 -0
  1318. data/spec/integration/recipes/notifies_spec.rb +334 -0
  1319. data/spec/integration/recipes/provider_choice.rb +37 -37
  1320. data/spec/integration/recipes/recipe_dsl_spec.rb +1519 -1519
  1321. data/spec/integration/recipes/remote_directory.rb +74 -74
  1322. data/spec/integration/recipes/resource_action_spec.rb +569 -569
  1323. data/spec/integration/recipes/resource_converge_if_changed_spec.rb +496 -496
  1324. data/spec/integration/recipes/resource_load_spec.rb +208 -208
  1325. data/spec/integration/solo/solo_spec.rb +176 -176
  1326. data/spec/rcov.opts +2 -2
  1327. data/spec/scripts/ssl-serve.rb +47 -47
  1328. data/spec/spec_helper.rb +248 -248
  1329. data/spec/stress/win32/file_spec.rb +37 -37
  1330. data/spec/stress/win32/memory_spec.rb +22 -22
  1331. data/spec/stress/win32/security_spec.rb +69 -69
  1332. data/spec/support/chef_helpers.rb +95 -95
  1333. data/spec/support/key_helpers.rb +104 -104
  1334. data/spec/support/lib/chef/provider/easy.rb +35 -35
  1335. data/spec/support/lib/chef/provider/openldap_includer.rb +29 -29
  1336. data/spec/support/lib/chef/provider/snakeoil.rb +41 -41
  1337. data/spec/support/lib/chef/resource/cat.rb +38 -38
  1338. data/spec/support/lib/chef/resource/one_two_three_four.rb +37 -37
  1339. data/spec/support/lib/chef/resource/openldap_includer.rb +26 -26
  1340. data/spec/support/lib/chef/resource/with_state.rb +28 -28
  1341. data/spec/support/lib/chef/resource/zen_follower.rb +35 -35
  1342. data/spec/support/lib/chef/resource/zen_master.rb +41 -41
  1343. data/spec/support/lib/library_load_order.rb +20 -20
  1344. data/spec/support/matchers/leak.rb +98 -98
  1345. data/spec/support/mock/constant.rb +52 -52
  1346. data/spec/support/mock/platform.rb +25 -25
  1347. data/spec/support/platform_helpers.rb +214 -214
  1348. data/spec/support/platforms/prof/gc.rb +53 -53
  1349. data/spec/support/platforms/prof/win32.rb +45 -45
  1350. data/spec/support/platforms/win32/spec_service.rb +59 -59
  1351. data/spec/support/shared/context/client.rb +285 -285
  1352. data/spec/support/shared/context/config.rb +21 -21
  1353. data/spec/support/shared/context/win32.rb +34 -34
  1354. data/spec/support/shared/examples/client.rb +53 -53
  1355. data/spec/support/shared/functional/diff_disabled.rb +10 -10
  1356. data/spec/support/shared/functional/directory_resource.rb +176 -176
  1357. data/spec/support/shared/functional/file_resource.rb +1049 -1049
  1358. data/spec/support/shared/functional/http.rb +248 -248
  1359. data/spec/support/shared/functional/knife.rb +37 -37
  1360. data/spec/support/shared/functional/securable_resource.rb +547 -547
  1361. data/spec/support/shared/functional/securable_resource_with_reporting.rb +394 -394
  1362. data/spec/support/shared/functional/win32_service.rb +59 -59
  1363. data/spec/support/shared/functional/windows_script.rb +202 -202
  1364. data/spec/support/shared/integration/app_server_support.rb +42 -42
  1365. data/spec/support/shared/integration/integration_helper.rb +154 -154
  1366. data/spec/support/shared/integration/knife_support.rb +173 -173
  1367. data/spec/support/shared/matchers/exit_with_code.rb +32 -32
  1368. data/spec/support/shared/matchers/match_environment_variable.rb +17 -17
  1369. data/spec/support/shared/shared_examples.rb +14 -14
  1370. data/spec/support/shared/unit/api_error_inspector.rb +190 -190
  1371. data/spec/support/shared/unit/api_versioning.rb +77 -77
  1372. data/spec/support/shared/unit/application_dot_d.rb +70 -70
  1373. data/spec/support/shared/unit/execute_resource.rb +133 -133
  1374. data/spec/support/shared/unit/file_system_support.rb +69 -69
  1375. data/spec/support/shared/unit/knife_shared.rb +39 -39
  1376. data/spec/support/shared/unit/mock_shellout.rb +49 -49
  1377. data/spec/support/shared/unit/platform_introspector.rb +189 -189
  1378. data/spec/support/shared/unit/provider/file.rb +835 -835
  1379. data/spec/support/shared/unit/provider/useradd_based_user_provider.rb +433 -433
  1380. data/spec/support/shared/unit/resource/static_provider_resolution.rb +63 -63
  1381. data/spec/support/shared/unit/script_resource.rb +98 -98
  1382. data/spec/support/shared/unit/user_and_client_shared.rb +114 -114
  1383. data/spec/support/shared/unit/windows_script_resource.rb +80 -80
  1384. data/spec/tiny_server.rb +207 -207
  1385. data/spec/unit/api_client/registration_spec.rb +278 -278
  1386. data/spec/unit/api_client_spec.rb +341 -341
  1387. data/spec/unit/api_client_v1_spec.rb +455 -455
  1388. data/spec/unit/application/apply_spec.rb +110 -110
  1389. data/spec/unit/application/client_spec.rb +495 -435
  1390. data/spec/unit/application/knife_spec.rb +229 -229
  1391. data/spec/unit/application/solo_spec.rb +170 -170
  1392. data/spec/unit/application_spec.rb +411 -384
  1393. data/spec/unit/audit/audit_event_proxy_spec.rb +311 -311
  1394. data/spec/unit/audit/audit_reporter_spec.rb +430 -430
  1395. data/spec/unit/audit/control_group_data_spec.rb +477 -477
  1396. data/spec/unit/audit/logger_spec.rb +42 -42
  1397. data/spec/unit/audit/rspec_formatter_spec.rb +29 -29
  1398. data/spec/unit/audit/runner_spec.rb +144 -144
  1399. data/spec/unit/chef_class_spec.rb +110 -110
  1400. data/spec/unit/chef_fs/config_spec.rb +106 -106
  1401. data/spec/unit/chef_fs/data_handler/group_handler_spec.rb +63 -63
  1402. data/spec/unit/chef_fs/diff_spec.rb +328 -328
  1403. data/spec/unit/chef_fs/file_pattern_spec.rb +512 -512
  1404. data/spec/unit/chef_fs/file_system/cookbook_subdir_spec.rb +34 -34
  1405. data/spec/unit/chef_fs/file_system/operation_failed_error_spec.rb +47 -47
  1406. data/spec/unit/chef_fs/file_system_spec.rb +148 -148
  1407. data/spec/unit/chef_fs/parallelizer.rb +479 -479
  1408. data/spec/unit/chef_fs/path_util_spec.rb +108 -108
  1409. data/spec/unit/chef_spec.rb +25 -25
  1410. data/spec/unit/client_spec.rb +544 -544
  1411. data/spec/unit/config_fetcher_spec.rb +125 -125
  1412. data/spec/unit/config_spec.rb +31 -31
  1413. data/spec/unit/cookbook/chefignore_spec.rb +49 -49
  1414. data/spec/unit/cookbook/cookbook_version_loader_spec.rb +198 -198
  1415. data/spec/unit/cookbook/file_vendor_spec.rb +97 -97
  1416. data/spec/unit/cookbook/metadata_spec.rb +952 -952
  1417. data/spec/unit/cookbook/synchronizer_spec.rb +520 -520
  1418. data/spec/unit/cookbook/syntax_check_spec.rb +219 -219
  1419. data/spec/unit/cookbook_loader_spec.rb +299 -299
  1420. data/spec/unit/cookbook_manifest_spec.rb +243 -243
  1421. data/spec/unit/cookbook_site_streaming_uploader_spec.rb +203 -203
  1422. data/spec/unit/cookbook_spec.rb +66 -66
  1423. data/spec/unit/cookbook_uploader_spec.rb +199 -199
  1424. data/spec/unit/cookbook_version_file_specificity_spec.rb +576 -553
  1425. data/spec/unit/cookbook_version_spec.rb +359 -359
  1426. data/spec/unit/daemon_spec.rb +174 -174
  1427. data/spec/unit/data_bag_item_spec.rb +388 -388
  1428. data/spec/unit/data_bag_spec.rb +260 -260
  1429. data/spec/unit/deprecation_spec.rb +150 -150
  1430. data/spec/unit/digester_spec.rb +49 -49
  1431. data/spec/unit/dsl/audit_spec.rb +43 -43
  1432. data/spec/unit/dsl/data_query_spec.rb +106 -106
  1433. data/spec/unit/dsl/platform_introspection_spec.rb +129 -129
  1434. data/spec/unit/dsl/reboot_pending_spec.rb +100 -100
  1435. data/spec/unit/dsl/recipe_spec.rb +93 -80
  1436. data/spec/unit/dsl/{regsitry_helper_spec.rb → registry_helper_spec.rb} +52 -52
  1437. data/spec/unit/dsl/resources_spec.rb +85 -85
  1438. data/spec/unit/encrypted_data_bag_item/check_encrypted_spec.rb +95 -95
  1439. data/spec/unit/encrypted_data_bag_item_spec.rb +437 -437
  1440. data/spec/unit/environment_spec.rb +470 -470
  1441. data/spec/unit/event_dispatch/dispatcher_spec.rb +122 -122
  1442. data/spec/unit/event_dispatch/dsl_spec.rb +83 -83
  1443. data/spec/unit/exceptions_spec.rb +130 -130
  1444. data/spec/unit/file_access_control_spec.rb +308 -308
  1445. data/spec/unit/file_cache_spec.rb +114 -114
  1446. data/spec/unit/file_content_management/deploy/cp_spec.rb +44 -44
  1447. data/spec/unit/file_content_management/deploy/mv_unix_spec.rb +101 -101
  1448. data/spec/unit/file_content_management/deploy/mv_windows_spec.rb +232 -232
  1449. data/spec/unit/file_content_management/tempfile_spec.rb +85 -85
  1450. data/spec/unit/formatters/base_spec.rb +71 -71
  1451. data/spec/unit/formatters/doc_spec.rb +92 -78
  1452. data/spec/unit/formatters/error_description_spec.rb +96 -0
  1453. data/spec/unit/formatters/error_inspectors/api_error_formatting_spec.rb +76 -76
  1454. data/spec/unit/formatters/error_inspectors/compile_error_inspector_spec.rb +265 -265
  1455. data/spec/unit/formatters/error_inspectors/cookbook_resolve_error_inspector_spec.rb +126 -126
  1456. data/spec/unit/formatters/error_inspectors/cookbook_sync_error_inspector_spec.rb +43 -43
  1457. data/spec/unit/formatters/error_inspectors/node_load_error_inspector_spec.rb +26 -26
  1458. data/spec/unit/formatters/error_inspectors/registration_error_inspector_spec.rb +26 -26
  1459. data/spec/unit/formatters/error_inspectors/resource_failure_inspector_spec.rb +191 -191
  1460. data/spec/unit/formatters/error_inspectors/run_list_expansion_error_inspector_spec.rb +91 -91
  1461. data/spec/unit/guard_interpreter/resource_guard_interpreter_spec.rb +155 -155
  1462. data/spec/unit/guard_interpreter_spec.rb +41 -41
  1463. data/spec/unit/handler/json_file_spec.rb +63 -63
  1464. data/spec/unit/handler_spec.rb +215 -215
  1465. data/spec/unit/http/authenticator_spec.rb +80 -80
  1466. data/spec/unit/http/basic_client_spec.rb +52 -129
  1467. data/spec/unit/http/http_request_spec.rb +91 -91
  1468. data/spec/unit/http/json_input_spec.rb +128 -128
  1469. data/spec/unit/http/simple_spec.rb +32 -32
  1470. data/spec/unit/http/socketless_chef_zero_client_spec.rb +173 -173
  1471. data/spec/unit/http/ssl_policies_spec.rb +169 -169
  1472. data/spec/unit/http/validate_content_length_spec.rb +207 -207
  1473. data/spec/unit/http_spec.rb +206 -206
  1474. data/spec/unit/json_compat_spec.rb +105 -105
  1475. data/spec/unit/key_spec.rb +631 -631
  1476. data/spec/unit/knife/bootstrap/chef_vault_handler_spec.rb +152 -152
  1477. data/spec/unit/knife/bootstrap/client_builder_spec.rb +207 -207
  1478. data/spec/unit/knife/bootstrap_spec.rb +822 -822
  1479. data/spec/unit/knife/client_bulk_delete_spec.rb +166 -166
  1480. data/spec/unit/knife/client_create_spec.rb +186 -186
  1481. data/spec/unit/knife/client_delete_spec.rb +83 -83
  1482. data/spec/unit/knife/client_edit_spec.rb +53 -53
  1483. data/spec/unit/knife/client_list_spec.rb +34 -34
  1484. data/spec/unit/knife/client_reregister_spec.rb +62 -62
  1485. data/spec/unit/knife/client_show_spec.rb +52 -52
  1486. data/spec/unit/knife/configure_client_spec.rb +83 -83
  1487. data/spec/unit/knife/configure_spec.rb +241 -241
  1488. data/spec/unit/knife/cookbook_bulk_delete_spec.rb +87 -87
  1489. data/spec/unit/knife/cookbook_create_spec.rb +260 -260
  1490. data/spec/unit/knife/cookbook_delete_spec.rb +239 -239
  1491. data/spec/unit/knife/cookbook_download_spec.rb +237 -237
  1492. data/spec/unit/knife/cookbook_list_spec.rb +88 -88
  1493. data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +65 -65
  1494. data/spec/unit/knife/cookbook_metadata_spec.rb +179 -179
  1495. data/spec/unit/knife/cookbook_show_spec.rb +222 -222
  1496. data/spec/unit/knife/cookbook_site_download_spec.rb +149 -149
  1497. data/spec/unit/knife/cookbook_site_install_spec.rb +197 -197
  1498. data/spec/unit/knife/cookbook_site_share_spec.rb +209 -209
  1499. data/spec/unit/knife/cookbook_site_unshare_spec.rb +77 -77
  1500. data/spec/unit/knife/cookbook_test_spec.rb +84 -84
  1501. data/spec/unit/knife/cookbook_upload_spec.rb +331 -331
  1502. data/spec/unit/knife/core/bootstrap_context_spec.rb +257 -257
  1503. data/spec/unit/knife/core/cookbook_scm_repo_spec.rb +187 -187
  1504. data/spec/unit/knife/core/custom_manifest_loader_spec.rb +41 -41
  1505. data/spec/unit/knife/core/gem_glob_loader_spec.rb +209 -209
  1506. data/spec/unit/knife/core/hashed_command_loader_spec.rb +109 -109
  1507. data/spec/unit/knife/core/node_editor_spec.rb +211 -211
  1508. data/spec/unit/knife/core/object_loader_spec.rb +81 -81
  1509. data/spec/unit/knife/core/subcommand_loader_spec.rb +70 -70
  1510. data/spec/unit/knife/core/ui_spec.rb +598 -598
  1511. data/spec/unit/knife/data_bag_create_spec.rb +109 -109
  1512. data/spec/unit/knife/data_bag_edit_spec.rb +127 -127
  1513. data/spec/unit/knife/data_bag_from_file_spec.rb +172 -172
  1514. data/spec/unit/knife/data_bag_secret_options_spec.rb +165 -165
  1515. data/spec/unit/knife/data_bag_show_spec.rb +123 -123
  1516. data/spec/unit/knife/environment_compare_spec.rb +112 -112
  1517. data/spec/unit/knife/environment_create_spec.rb +91 -91
  1518. data/spec/unit/knife/environment_delete_spec.rb +71 -71
  1519. data/spec/unit/knife/environment_edit_spec.rb +79 -79
  1520. data/spec/unit/knife/environment_from_file_spec.rb +90 -90
  1521. data/spec/unit/knife/environment_list_spec.rb +54 -54
  1522. data/spec/unit/knife/environment_show_spec.rb +52 -52
  1523. data/spec/unit/knife/index_rebuild_spec.rb +125 -125
  1524. data/spec/unit/knife/key_create_spec.rb +223 -223
  1525. data/spec/unit/knife/key_delete_spec.rb +133 -133
  1526. data/spec/unit/knife/key_edit_spec.rb +264 -264
  1527. data/spec/unit/knife/key_helper.rb +74 -74
  1528. data/spec/unit/knife/key_list_spec.rb +216 -216
  1529. data/spec/unit/knife/key_show_spec.rb +126 -126
  1530. data/spec/unit/knife/knife_help.rb +92 -92
  1531. data/spec/unit/knife/node_bulk_delete_spec.rb +94 -94
  1532. data/spec/unit/knife/node_delete_spec.rb +68 -68
  1533. data/spec/unit/knife/node_edit_spec.rb +114 -114
  1534. data/spec/unit/knife/node_environment_set_spec.rb +80 -80
  1535. data/spec/unit/knife/node_from_file_spec.rb +59 -59
  1536. data/spec/unit/knife/node_list_spec.rb +62 -62
  1537. data/spec/unit/knife/node_run_list_add_spec.rb +145 -145
  1538. data/spec/unit/knife/node_run_list_remove_spec.rb +106 -106
  1539. data/spec/unit/knife/node_run_list_set_spec.rb +140 -140
  1540. data/spec/unit/knife/node_show_spec.rb +65 -65
  1541. data/spec/unit/knife/osc_user_create_spec.rb +93 -93
  1542. data/spec/unit/knife/osc_user_delete_spec.rb +44 -44
  1543. data/spec/unit/knife/osc_user_edit_spec.rb +52 -52
  1544. data/spec/unit/knife/osc_user_list_spec.rb +37 -37
  1545. data/spec/unit/knife/osc_user_reregister_spec.rb +58 -58
  1546. data/spec/unit/knife/osc_user_show_spec.rb +46 -46
  1547. data/spec/unit/knife/raw_spec.rb +43 -43
  1548. data/spec/unit/knife/role_bulk_delete_spec.rb +80 -80
  1549. data/spec/unit/knife/role_create_spec.rb +80 -80
  1550. data/spec/unit/knife/role_delete_spec.rb +67 -67
  1551. data/spec/unit/knife/role_edit_spec.rb +77 -77
  1552. data/spec/unit/knife/role_env_run_list_add_spec.rb +217 -217
  1553. data/spec/unit/knife/role_env_run_list_clear_spec.rb +94 -94
  1554. data/spec/unit/knife/role_env_run_list_remove_spec.rb +102 -102
  1555. data/spec/unit/knife/role_env_run_list_replace_spec.rb +105 -105
  1556. data/spec/unit/knife/role_env_run_list_set_spec.rb +99 -99
  1557. data/spec/unit/knife/role_from_file_spec.rb +69 -69
  1558. data/spec/unit/knife/role_list_spec.rb +54 -54
  1559. data/spec/unit/knife/role_run_list_add_spec.rb +179 -179
  1560. data/spec/unit/knife/role_run_list_clear_spec.rb +84 -84
  1561. data/spec/unit/knife/role_run_list_remove_spec.rb +92 -92
  1562. data/spec/unit/knife/role_run_list_replace_spec.rb +98 -98
  1563. data/spec/unit/knife/role_run_list_set_spec.rb +89 -89
  1564. data/spec/unit/knife/role_show_spec.rb +59 -59
  1565. data/spec/unit/knife/ssh_spec.rb +428 -410
  1566. data/spec/unit/knife/ssl_check_spec.rb +240 -240
  1567. data/spec/unit/knife/ssl_fetch_spec.rb +184 -184
  1568. data/spec/unit/knife/status_spec.rb +108 -108
  1569. data/spec/unit/knife/tag_create_spec.rb +23 -23
  1570. data/spec/unit/knife/tag_delete_spec.rb +25 -25
  1571. data/spec/unit/knife/tag_list_spec.rb +23 -23
  1572. data/spec/unit/knife/user_create_spec.rb +214 -214
  1573. data/spec/unit/knife/user_delete_spec.rb +65 -65
  1574. data/spec/unit/knife/user_edit_spec.rb +66 -66
  1575. data/spec/unit/knife/user_list_spec.rb +36 -36
  1576. data/spec/unit/knife/user_reregister_spec.rb +74 -74
  1577. data/spec/unit/knife/user_show_spec.rb +65 -65
  1578. data/spec/unit/knife_spec.rb +529 -529
  1579. data/spec/unit/lib_backcompat_spec.rb +34 -34
  1580. data/spec/unit/log/syslog_spec.rb +53 -53
  1581. data/spec/unit/log/winevt_spec.rb +55 -55
  1582. data/spec/unit/log_spec.rb +24 -24
  1583. data/spec/unit/lwrp_spec.rb +778 -720
  1584. data/spec/unit/mash_spec.rb +51 -51
  1585. data/spec/unit/mixin/api_version_request_handling_spec.rb +126 -126
  1586. data/spec/unit/mixin/checksum_spec.rb +40 -40
  1587. data/spec/unit/mixin/command_spec.rb +104 -104
  1588. data/spec/unit/mixin/convert_to_class_name_spec.rb +54 -54
  1589. data/spec/unit/mixin/deep_merge_spec.rb +342 -342
  1590. data/spec/unit/mixin/deprecation_spec.rb +57 -57
  1591. data/spec/unit/mixin/enforce_ownership_and_permissions_spec.rb +96 -96
  1592. data/spec/unit/mixin/homebrew_user_spec.rb +100 -100
  1593. data/spec/unit/mixin/lazy_module_include.rb +71 -0
  1594. data/spec/unit/mixin/params_validate_spec.rb +409 -409
  1595. data/spec/unit/mixin/path_sanity_spec.rb +92 -92
  1596. data/spec/unit/mixin/powershell_out_spec.rb +70 -70
  1597. data/spec/unit/mixin/powershell_type_coercions_spec.rb +83 -83
  1598. data/spec/unit/mixin/properties_spec.rb +97 -97
  1599. data/spec/unit/mixin/proxified_socket_spec.rb +97 -94
  1600. data/spec/unit/mixin/securable_spec.rb +314 -314
  1601. data/spec/unit/mixin/shell_out_spec.rb +299 -299
  1602. data/spec/unit/mixin/subclass_directive_spec.rb +45 -45
  1603. data/spec/unit/mixin/template_spec.rb +276 -276
  1604. data/spec/unit/mixin/unformatter_spec.rb +61 -61
  1605. data/spec/unit/mixin/uris_spec.rb +57 -57
  1606. data/spec/unit/mixin/windows_architecture_helper_spec.rb +85 -85
  1607. data/spec/unit/mixin/xml_escape_spec.rb +54 -54
  1608. data/spec/unit/monkey_patches/uri_spec.rb +34 -34
  1609. data/spec/unit/monologger_spec.rb +45 -45
  1610. data/spec/unit/node/attribute_spec.rb +1179 -1179
  1611. data/spec/unit/node/immutable_collections_spec.rb +197 -197
  1612. data/spec/unit/node_map_spec.rb +170 -170
  1613. data/spec/unit/node_spec.rb +1565 -1565
  1614. data/spec/unit/org_spec.rb +196 -196
  1615. data/spec/unit/platform/query_helpers_spec.rb +220 -220
  1616. data/spec/unit/platform_spec.rb +241 -241
  1617. data/spec/unit/policy_builder/dynamic_spec.rb +273 -273
  1618. data/spec/unit/policy_builder/expand_node_object_spec.rb +336 -336
  1619. data/spec/unit/policy_builder/policyfile_spec.rb +745 -745
  1620. data/spec/unit/policy_builder_spec.rb +26 -26
  1621. data/spec/unit/property/state_spec.rb +508 -508
  1622. data/spec/unit/property/validation_spec.rb +704 -704
  1623. data/spec/unit/property_spec.rb +1227 -1227
  1624. data/spec/unit/provider/apt_repository_spec.rb +178 -0
  1625. data/spec/unit/provider/apt_update_spec.rb +113 -113
  1626. data/spec/unit/provider/breakpoint_spec.rb +53 -53
  1627. data/spec/unit/provider/cookbook_file/content_spec.rb +39 -39
  1628. data/spec/unit/provider/cookbook_file_spec.rb +58 -58
  1629. data/spec/unit/provider/cron/unix_spec.rb +139 -139
  1630. data/spec/unit/provider/cron_spec.rb +1010 -1010
  1631. data/spec/unit/provider/deploy/revision_spec.rb +110 -110
  1632. data/spec/unit/provider/deploy/timestamped_spec.rb +40 -40
  1633. data/spec/unit/provider/deploy_spec.rb +641 -641
  1634. data/spec/unit/provider/directory_spec.rb +287 -287
  1635. data/spec/unit/provider/dsc_resource_spec.rb +167 -167
  1636. data/spec/unit/provider/dsc_script_spec.rb +173 -173
  1637. data/spec/unit/provider/env/windows_spec.rb +103 -103
  1638. data/spec/unit/provider/env_spec.rb +310 -310
  1639. data/spec/unit/provider/erl_call_spec.rb +85 -85
  1640. data/spec/unit/provider/execute_spec.rb +243 -243
  1641. data/spec/unit/provider/file/content_spec.rb +114 -114
  1642. data/spec/unit/provider/file_spec.rb +56 -56
  1643. data/spec/unit/provider/git_spec.rb +668 -668
  1644. data/spec/unit/provider/group/dscl_spec.rb +331 -331
  1645. data/spec/unit/provider/group/gpasswd_spec.rb +116 -116
  1646. data/spec/unit/provider/group/groupadd_spec.rb +174 -174
  1647. data/spec/unit/provider/group/groupmod_spec.rb +133 -133
  1648. data/spec/unit/provider/group/pw_spec.rb +138 -138
  1649. data/spec/unit/provider/group/usermod_spec.rb +115 -115
  1650. data/spec/unit/provider/group/windows_spec.rb +101 -101
  1651. data/spec/unit/provider/group_spec.rb +286 -286
  1652. data/spec/unit/provider/http_request_spec.rb +159 -159
  1653. data/spec/unit/provider/ifconfig/aix_spec.rb +180 -180
  1654. data/spec/unit/provider/ifconfig/debian_spec.rb +344 -344
  1655. data/spec/unit/provider/ifconfig/redhat_spec.rb +73 -73
  1656. data/spec/unit/provider/ifconfig_spec.rb +200 -200
  1657. data/spec/unit/provider/launchd_spec.rb +189 -189
  1658. data/spec/unit/provider/link_spec.rb +252 -252
  1659. data/spec/unit/provider/log_spec.rb +75 -75
  1660. data/spec/unit/provider/mdadm_spec.rb +131 -131
  1661. data/spec/unit/provider/mount/aix_spec.rb +237 -238
  1662. data/spec/unit/provider/mount/mount_spec.rb +474 -480
  1663. data/spec/unit/provider/mount/solaris_spec.rb +822 -822
  1664. data/spec/unit/provider/mount/windows_spec.rb +149 -151
  1665. data/spec/unit/provider/mount_spec.rb +184 -203
  1666. data/spec/unit/provider/ohai_spec.rb +84 -84
  1667. data/spec/unit/provider/osx_profile_spec.rb +249 -249
  1668. data/spec/unit/provider/package/aix_spec.rb +172 -172
  1669. data/spec/unit/provider/package/apt_spec.rb +386 -386
  1670. data/spec/unit/provider/package/chocolatey_spec.rb +501 -501
  1671. data/spec/unit/provider/package/dpkg_spec.rb +287 -287
  1672. data/spec/unit/provider/package/easy_install_spec.rb +108 -108
  1673. data/spec/unit/provider/package/freebsd/pkg_spec.rb +274 -274
  1674. data/spec/unit/provider/package/freebsd/pkgng_spec.rb +148 -148
  1675. data/spec/unit/provider/package/freebsd/port_spec.rb +163 -163
  1676. data/spec/unit/provider/package/homebrew_spec.rb +292 -292
  1677. data/spec/unit/provider/package/ips_spec.rb +227 -227
  1678. data/spec/unit/provider/package/macports_spec.rb +203 -203
  1679. data/spec/unit/provider/package/openbsd_spec.rb +132 -132
  1680. data/spec/unit/provider/package/pacman_spec.rb +194 -194
  1681. data/spec/unit/provider/package/paludis_spec.rb +134 -134
  1682. data/spec/unit/provider/package/portage_spec.rb +310 -310
  1683. data/spec/unit/provider/package/rpm_spec.rb +429 -429
  1684. data/spec/unit/provider/package/rubygems_spec.rb +782 -782
  1685. data/spec/unit/provider/package/smartos_spec.rb +110 -110
  1686. data/spec/unit/provider/package/solaris_spec.rb +167 -167
  1687. data/spec/unit/provider/package/windows/exe_spec.rb +187 -187
  1688. data/spec/unit/provider/package/windows/msi_spec.rb +159 -159
  1689. data/spec/unit/provider/package/windows_spec.rb +397 -397
  1690. data/spec/unit/provider/package/yum_spec.rb +2267 -2267
  1691. data/spec/unit/provider/package/zypper_spec.rb +268 -268
  1692. data/spec/unit/provider/package_spec.rb +870 -870
  1693. data/spec/unit/provider/powershell_script_spec.rb +106 -106
  1694. data/spec/unit/provider/registry_key_spec.rb +295 -295
  1695. data/spec/unit/provider/remote_directory_spec.rb +221 -221
  1696. data/spec/unit/provider/remote_file/cache_control_data_spec.rb +245 -245
  1697. data/spec/unit/provider/remote_file/content_spec.rb +252 -252
  1698. data/spec/unit/provider/remote_file/fetcher_spec.rb +94 -94
  1699. data/spec/unit/provider/remote_file/ftp_spec.rb +217 -219
  1700. data/spec/unit/provider/remote_file/http_spec.rb +322 -301
  1701. data/spec/unit/provider/remote_file/local_file_spec.rb +103 -103
  1702. data/spec/unit/provider/remote_file/network_file_spec.rb +45 -45
  1703. data/spec/unit/provider/remote_file/sftp_spec.rb +150 -0
  1704. data/spec/unit/provider/remote_file_spec.rb +61 -61
  1705. data/spec/unit/provider/route_spec.rb +242 -242
  1706. data/spec/unit/provider/ruby_block_spec.rb +45 -45
  1707. data/spec/unit/provider/script_spec.rb +114 -114
  1708. data/spec/unit/provider/service/aix_service_spec.rb +195 -195
  1709. data/spec/unit/provider/service/aixinit_service_spec.rb +272 -272
  1710. data/spec/unit/provider/service/arch_service_spec.rb +324 -324
  1711. data/spec/unit/provider/service/debian_service_spec.rb +375 -375
  1712. data/spec/unit/provider/service/freebsd_service_spec.rb +613 -613
  1713. data/spec/unit/provider/service/gentoo_service_spec.rb +144 -144
  1714. data/spec/unit/provider/service/init_service_spec.rb +235 -235
  1715. data/spec/unit/provider/service/insserv_service_spec.rb +75 -75
  1716. data/spec/unit/provider/service/invokercd_service_spec.rb +211 -211
  1717. data/spec/unit/provider/service/macosx_spec.rb +335 -335
  1718. data/spec/unit/provider/service/openbsd_service_spec.rb +545 -545
  1719. data/spec/unit/provider/service/redhat_spec.rb +250 -236
  1720. data/spec/unit/provider/service/simple_service_spec.rb +169 -169
  1721. data/spec/unit/provider/service/solaris_smf_service_spec.rb +255 -255
  1722. data/spec/unit/provider/service/systemd_service_spec.rb +370 -344
  1723. data/spec/unit/provider/service/upstart_service_spec.rb +342 -342
  1724. data/spec/unit/provider/service/windows_spec.rb +463 -463
  1725. data/spec/unit/provider/service_spec.rb +168 -168
  1726. data/spec/unit/provider/subversion_spec.rb +352 -298
  1727. data/spec/unit/provider/template/content_spec.rb +169 -169
  1728. data/spec/unit/provider/template_spec.rb +89 -89
  1729. data/spec/unit/provider/user/dscl_spec.rb +901 -901
  1730. data/spec/unit/provider/user/pw_spec.rb +252 -252
  1731. data/spec/unit/provider/user/solaris_spec.rb +139 -139
  1732. data/spec/unit/provider/user/useradd_spec.rb +51 -51
  1733. data/spec/unit/provider/user/windows_spec.rb +185 -185
  1734. data/spec/unit/provider/user_spec.rb +474 -474
  1735. data/spec/unit/provider/whyrun_safe_ruby_block_spec.rb +46 -46
  1736. data/spec/unit/provider_resolver_spec.rb +893 -893
  1737. data/spec/unit/provider_spec.rb +198 -198
  1738. data/spec/unit/pure_application_spec.rb +32 -32
  1739. data/spec/unit/recipe_spec.rb +699 -699
  1740. data/spec/unit/resource/apt_package_spec.rb +38 -38
  1741. data/spec/unit/resource/apt_repository_spec.rb +34 -0
  1742. data/spec/unit/resource/apt_update_spec.rb +38 -38
  1743. data/spec/unit/resource/bash_spec.rb +40 -40
  1744. data/spec/unit/resource/batch_spec.rb +49 -49
  1745. data/spec/unit/resource/breakpoint_spec.rb +47 -47
  1746. data/spec/unit/resource/chef_gem_spec.rb +157 -157
  1747. data/spec/unit/resource/chocolatey_package_spec.rb +67 -67
  1748. data/spec/unit/resource/conditional_action_not_nothing_spec.rb +45 -45
  1749. data/spec/unit/resource/conditional_spec.rb +208 -208
  1750. data/spec/unit/resource/cookbook_file_spec.rb +88 -88
  1751. data/spec/unit/resource/cron_spec.rb +186 -186
  1752. data/spec/unit/resource/csh_spec.rb +40 -40
  1753. data/spec/unit/resource/deploy_revision_spec.rb +42 -42
  1754. data/spec/unit/resource/deploy_spec.rb +283 -283
  1755. data/spec/unit/resource/directory_spec.rb +82 -82
  1756. data/spec/unit/resource/dpkg_package_spec.rb +32 -32
  1757. data/spec/unit/resource/dsc_resource_spec.rb +96 -96
  1758. data/spec/unit/resource/dsc_script_spec.rb +134 -134
  1759. data/spec/unit/resource/easy_install_package_spec.rb +39 -39
  1760. data/spec/unit/resource/env_spec.rb +85 -85
  1761. data/spec/unit/resource/erl_call_spec.rb +81 -81
  1762. data/spec/unit/resource/execute_spec.rb +35 -35
  1763. data/spec/unit/resource/file/verification_spec.rb +139 -139
  1764. data/spec/unit/resource/file_spec.rb +130 -130
  1765. data/spec/unit/resource/freebsd_package_spec.rb +87 -87
  1766. data/spec/unit/resource/gem_package_spec.rb +42 -42
  1767. data/spec/unit/resource/git_spec.rb +50 -50
  1768. data/spec/unit/resource/group_spec.rb +162 -162
  1769. data/spec/unit/resource/homebrew_package_spec.rb +50 -50
  1770. data/spec/unit/resource/http_request_spec.rb +59 -59
  1771. data/spec/unit/resource/ifconfig_spec.rb +109 -109
  1772. data/spec/unit/resource/ips_package_spec.rb +40 -40
  1773. data/spec/unit/resource/ksh_spec.rb +40 -40
  1774. data/spec/unit/resource/launchd_spec.rb +31 -31
  1775. data/spec/unit/resource/link_spec.rb +134 -134
  1776. data/spec/unit/resource/log_spec.rb +73 -73
  1777. data/spec/unit/resource/macports_package_spec.rb +32 -32
  1778. data/spec/unit/resource/mdadm_spec.rb +102 -102
  1779. data/spec/unit/resource/mount_spec.rb +214 -214
  1780. data/spec/unit/resource/ohai_spec.rb +61 -61
  1781. data/spec/unit/resource/openbsd_package_spec.rb +48 -48
  1782. data/spec/unit/resource/osx_profile_spec.rb +61 -61
  1783. data/spec/unit/resource/package_spec.rb +93 -93
  1784. data/spec/unit/resource/pacman_package_spec.rb +32 -32
  1785. data/spec/unit/resource/perl_spec.rb +40 -40
  1786. data/spec/unit/resource/portage_package_spec.rb +38 -38
  1787. data/spec/unit/resource/powershell_script_spec.rb +136 -136
  1788. data/spec/unit/resource/python_spec.rb +40 -40
  1789. data/spec/unit/resource/registry_key_spec.rb +199 -199
  1790. data/spec/unit/resource/remote_directory_spec.rb +97 -97
  1791. data/spec/unit/resource/remote_file_spec.rb +207 -207
  1792. data/spec/unit/resource/resource_notification_spec.rb +169 -169
  1793. data/spec/unit/resource/route_spec.rb +107 -107
  1794. data/spec/unit/resource/rpm_package_spec.rb +46 -46
  1795. data/spec/unit/resource/ruby_block_spec.rb +61 -61
  1796. data/spec/unit/resource/ruby_spec.rb +40 -40
  1797. data/spec/unit/resource/scm_spec.rb +193 -193
  1798. data/spec/unit/resource/script_spec.rb +44 -44
  1799. data/spec/unit/resource/service_spec.rb +179 -179
  1800. data/spec/unit/resource/smartos_package_spec.rb +33 -33
  1801. data/spec/unit/resource/solaris_package_spec.rb +42 -42
  1802. data/spec/unit/resource/subversion_spec.rb +71 -71
  1803. data/spec/unit/resource/template_spec.rb +210 -210
  1804. data/spec/unit/resource/timestamped_deploy_spec.rb +32 -32
  1805. data/spec/unit/resource/user_spec.rb +133 -133
  1806. data/spec/unit/resource/windows_package_spec.rb +95 -95
  1807. data/spec/unit/resource/windows_service_spec.rb +49 -49
  1808. data/spec/unit/resource/yum_package_spec.rb +89 -89
  1809. data/spec/unit/resource_builder_spec.rb +1 -1
  1810. data/spec/unit/resource_collection/resource_list_spec.rb +137 -137
  1811. data/spec/unit/resource_collection/resource_set_spec.rb +199 -199
  1812. data/spec/unit/resource_collection/stepable_iterator_spec.rb +144 -144
  1813. data/spec/unit/resource_collection_spec.rb +369 -299
  1814. data/spec/unit/resource_definition_spec.rb +117 -117
  1815. data/spec/unit/resource_reporter_spec.rb +758 -758
  1816. data/spec/unit/resource_resolver_spec.rb +52 -52
  1817. data/spec/unit/resource_spec.rb +1101 -1101
  1818. data/spec/unit/rest/auth_credentials_spec.rb +292 -296
  1819. data/spec/unit/rest_spec.rb +753 -753
  1820. data/spec/unit/role_spec.rb +358 -358
  1821. data/spec/unit/run_context/child_run_context_spec.rb +133 -133
  1822. data/spec/unit/run_context/cookbook_compiler_spec.rb +184 -184
  1823. data/spec/unit/run_context_spec.rb +241 -241
  1824. data/spec/unit/run_list/run_list_expansion_spec.rb +144 -144
  1825. data/spec/unit/run_list/run_list_item_spec.rb +117 -117
  1826. data/spec/unit/run_list/versioned_recipe_list_spec.rb +194 -194
  1827. data/spec/unit/run_list_spec.rb +312 -312
  1828. data/spec/unit/run_lock_spec.rb +140 -140
  1829. data/spec/unit/run_status_spec.rb +144 -144
  1830. data/spec/unit/runner_spec.rb +411 -411
  1831. data/spec/unit/scan_access_control_spec.rb +183 -183
  1832. data/spec/unit/search/query_spec.rb +289 -289
  1833. data/spec/unit/shell/model_wrapper_spec.rb +96 -96
  1834. data/spec/unit/shell/shell_ext_spec.rb +153 -153
  1835. data/spec/unit/shell/shell_session_spec.rb +195 -195
  1836. data/spec/unit/shell_out_spec.rb +18 -18
  1837. data/spec/unit/shell_spec.rb +162 -162
  1838. data/spec/unit/user_spec.rb +275 -275
  1839. data/spec/unit/user_v1_spec.rb +583 -583
  1840. data/spec/unit/util/backup_spec.rb +141 -141
  1841. data/spec/unit/util/diff_spec.rb +576 -576
  1842. data/spec/unit/util/dsc/configuration_generator_spec.rb +193 -193
  1843. data/spec/unit/util/dsc/lcm_output_parser_spec.rb +164 -164
  1844. data/spec/unit/util/dsc/local_configuration_manager_spec.rb +138 -138
  1845. data/spec/unit/util/dsc/resource_store.rb +76 -76
  1846. data/spec/unit/util/editor_spec.rb +152 -152
  1847. data/spec/unit/util/file_edit_spec.rb +224 -224
  1848. data/spec/unit/util/powershell/cmdlet_spec.rb +106 -106
  1849. data/spec/unit/util/powershell/ps_credential_spec.rb +44 -44
  1850. data/spec/unit/util/selinux_spec.rb +171 -171
  1851. data/spec/unit/util/threaded_job_queue_spec.rb +51 -51
  1852. data/spec/unit/version/platform_spec.rb +60 -60
  1853. data/spec/unit/version_class_spec.rb +171 -171
  1854. data/spec/unit/version_constraint/platform_spec.rb +45 -45
  1855. data/spec/unit/version_constraint_spec.rb +179 -179
  1856. data/spec/unit/win32/registry_spec.rb +394 -394
  1857. data/spec/unit/windows_service_spec.rb +116 -116
  1858. data/tasks/cbgb.rb +84 -84
  1859. data/tasks/external_tests.rb +64 -64
  1860. data/tasks/maintainers.rb +210 -210
  1861. data/tasks/rspec.rb +89 -89
  1862. metadata +55 -464
@@ -1,665 +1,665 @@
1
- #
2
- # Author:: John Keiser (<jkeiser@chef.io>)
3
- # Copyright:: Copyright 2011-2016, 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 "chef/win32/api/security"
20
- require "chef/win32/error"
21
- require "chef/win32/memory"
22
- require "chef/win32/process"
23
- require "chef/win32/unicode"
24
- require "chef/win32/security/token"
25
- require "chef/mixin/wide_string"
26
-
27
- class Chef
28
- module ReservedNames::Win32
29
- class Security
30
- include Chef::ReservedNames::Win32::API::Error
31
- extend Chef::ReservedNames::Win32::API::Error
32
- include Chef::ReservedNames::Win32::API::Security
33
- extend Chef::ReservedNames::Win32::API::Security
34
- extend Chef::ReservedNames::Win32::API::Macros
35
- include Chef::Mixin::WideString
36
- extend Chef::Mixin::WideString
37
-
38
- def self.access_check(security_descriptor, token, desired_access, generic_mapping)
39
- token_handle = token.handle.handle
40
- security_descriptor_ptr = security_descriptor.pointer
41
-
42
- rights_ptr = FFI::MemoryPointer.new(:ulong)
43
- rights_ptr.write_ulong(desired_access)
44
-
45
- # This function takes care of calling MapGenericMask, so you don't have to
46
- MapGenericMask(rights_ptr, generic_mapping)
47
-
48
- result_ptr = FFI::MemoryPointer.new(:ulong)
49
-
50
- # Because optional actually means required
51
- privileges = PRIVILEGE_SET.new
52
- privileges[:PrivilegeCount] = 0
53
- privileges_length_ptr = FFI::MemoryPointer.new(:ulong)
54
- privileges_length_ptr.write_ulong(privileges.size)
55
-
56
- granted_access_ptr = FFI::MemoryPointer.new(:ulong)
57
-
58
- unless AccessCheck(security_descriptor_ptr, token_handle, rights_ptr.read_ulong,
59
- generic_mapping, privileges, privileges_length_ptr, granted_access_ptr,
60
- result_ptr)
61
- Chef::ReservedNames::Win32::Error.raise!
62
- end
63
- result_ptr.read_ulong == 1
64
- end
65
-
66
- def self.add_ace(acl, ace, insert_position = MAXDWORD, revision = ACL_REVISION)
67
- acl = acl.pointer if acl.respond_to?(:pointer)
68
- ace = ace.pointer if ace.respond_to?(:pointer)
69
- ace_size = ACE_HEADER.new(ace)[:AceSize]
70
- unless AddAce(acl, revision, insert_position, ace, ace_size)
71
- Chef::ReservedNames::Win32::Error.raise!
72
- end
73
- end
74
-
75
- def self.add_access_allowed_ace(acl, sid, access_mask, revision = ACL_REVISION)
76
- acl = acl.pointer if acl.respond_to?(:pointer)
77
- sid = sid.pointer if sid.respond_to?(:pointer)
78
- unless AddAccessAllowedAce(acl, revision, access_mask, sid)
79
- Chef::ReservedNames::Win32::Error.raise!
80
- end
81
- end
82
-
83
- def self.add_access_allowed_ace_ex(acl, sid, access_mask, flags = 0, revision = ACL_REVISION)
84
- acl = acl.pointer if acl.respond_to?(:pointer)
85
- sid = sid.pointer if sid.respond_to?(:pointer)
86
- unless AddAccessAllowedAceEx(acl, revision, flags, access_mask, sid)
87
- Chef::ReservedNames::Win32::Error.raise!
88
- end
89
- end
90
-
91
- def self.add_access_denied_ace(acl, sid, access_mask, revision = ACL_REVISION)
92
- acl = acl.pointer if acl.respond_to?(:pointer)
93
- sid = sid.pointer if sid.respond_to?(:pointer)
94
- unless AddAccessDeniedAce(acl, revision, access_mask, sid)
95
- Chef::ReservedNames::Win32::Error.raise!
96
- end
97
- end
98
-
99
- def self.add_access_denied_ace_ex(acl, sid, access_mask, flags = 0, revision = ACL_REVISION)
100
- acl = acl.pointer if acl.respond_to?(:pointer)
101
- sid = sid.pointer if sid.respond_to?(:pointer)
102
- unless AddAccessDeniedAceEx(acl, revision, flags, access_mask, sid)
103
- Chef::ReservedNames::Win32::Error.raise!
104
- end
105
- end
106
-
107
- def self.add_account_right(name, privilege)
108
- privilege_pointer = FFI::MemoryPointer.new LSA_UNICODE_STRING, 1
109
- privilege_lsa_string = LSA_UNICODE_STRING.new(privilege_pointer)
110
- privilege_lsa_string[:Buffer] = FFI::MemoryPointer.from_string(privilege.to_wstring)
111
- privilege_lsa_string[:Length] = privilege.length * 2
112
- privilege_lsa_string[:MaximumLength] = (privilege.length + 1) * 2
113
-
114
- with_lsa_policy(name) do |policy_handle, sid|
115
- result = LsaAddAccountRights(policy_handle.read_pointer, sid, privilege_pointer, 1)
116
- win32_error = LsaNtStatusToWinError(result)
117
- if win32_error != 0
118
- Chef::ReservedNames::Win32::Error.raise!(nil, win32_error)
119
- end
120
- end
121
- end
122
-
123
- def self.adjust_token_privileges(token, privileges)
124
- token = token.handle if token.respond_to?(:handle)
125
- old_privileges_size = FFI::Buffer.new(:long).write_long(privileges.size_with_privileges)
126
- old_privileges = TOKEN_PRIVILEGES.new(FFI::Buffer.new(old_privileges_size.read_long))
127
- unless AdjustTokenPrivileges(token.handle, false, privileges, privileges.size_with_privileges, old_privileges, old_privileges_size)
128
- Chef::ReservedNames::Win32::Error.raise!
129
- end
130
-
131
- old_privileges
132
- end
133
-
134
- def self.convert_sid_to_string_sid(sid)
135
- sid = sid.pointer if sid.respond_to?(:pointer)
136
- result = FFI::MemoryPointer.new :pointer
137
- # TODO: use the W version
138
- unless ConvertSidToStringSidA(sid, result)
139
- Chef::ReservedNames::Win32::Error.raise!
140
- end
141
-
142
- result_string = result.read_pointer.read_string
143
-
144
- Chef::ReservedNames::Win32::Memory.local_free(result.read_pointer)
145
-
146
- result_string
147
- end
148
-
149
- def self.convert_string_sid_to_sid(string_sid)
150
- result = FFI::MemoryPointer.new :pointer
151
- unless ConvertStringSidToSidW(string_sid.to_wstring, result)
152
- Chef::ReservedNames::Win32::Error.raise!
153
- end
154
-
155
- result_pointer = result.read_pointer
156
- sid = SID.new(result_pointer)
157
-
158
- # The result pointer must be freed with local_free
159
- ObjectSpace.define_finalizer(sid, Memory.local_free_finalizer(result_pointer))
160
-
161
- sid
162
- end
163
-
164
- def self.delete_ace(acl, index)
165
- acl = acl.pointer if acl.respond_to?(:pointer)
166
- unless DeleteAce(acl, index)
167
- Chef::ReservedNames::Win32::Error.raise!
168
- end
169
- end
170
-
171
- def self.equal_sid(sid1, sid2)
172
- sid1 = sid1.pointer if sid1.respond_to?(:pointer)
173
- sid2 = sid2.pointer if sid2.respond_to?(:pointer)
174
- EqualSid(sid1, sid2)
175
- end
176
-
177
- def self.free_sid(sid)
178
- sid = sid.pointer if sid.respond_to?(:pointer)
179
- unless FreeSid(sid).null?
180
- Chef::ReservedNames::Win32::Error.raise!
181
- end
182
- end
183
-
184
- def self.get_account_right(name)
185
- privileges = []
186
- privilege_pointer = FFI::MemoryPointer.new(:pointer)
187
- privilege_length = FFI::MemoryPointer.new(:ulong)
188
-
189
- with_lsa_policy(name) do |policy_handle, sid|
190
- result = LsaEnumerateAccountRights(policy_handle.read_pointer, sid, privilege_pointer, privilege_length)
191
- win32_error = LsaNtStatusToWinError(result)
192
- return [] if win32_error == 2 # FILE_NOT_FOUND - No rights assigned
193
- if win32_error != 0
194
- Chef::ReservedNames::Win32::Error.raise!(nil, win32_error)
195
- end
196
-
197
- privilege_length.read_ulong.times do |i|
198
- privilege = LSA_UNICODE_STRING.new(privilege_pointer.read_pointer + i * LSA_UNICODE_STRING.size)
199
- privileges << privilege[:Buffer].read_wstring
200
- end
201
- LsaFreeMemory(privilege_pointer)
202
- end
203
-
204
- privileges
205
- end
206
-
207
- def self.get_ace(acl, index)
208
- acl = acl.pointer if acl.respond_to?(:pointer)
209
- ace = FFI::Buffer.new :pointer
210
- unless GetAce(acl, index, ace)
211
- Chef::ReservedNames::Win32::Error.raise!
212
- end
213
- ACE.new(ace.read_pointer, acl)
214
- end
215
-
216
- def self.get_length_sid(sid)
217
- sid = sid.pointer if sid.respond_to?(:pointer)
218
- GetLengthSid(sid)
219
- end
220
-
221
- def self.get_file_security(path, info = OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION)
222
- size_ptr = FFI::MemoryPointer.new(:ulong)
223
-
224
- success = GetFileSecurityW(path.to_wstring, info, nil, 0, size_ptr)
225
-
226
- if !success && FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
227
- Chef::ReservedNames::Win32::Error.raise!
228
- end
229
-
230
- security_descriptor_ptr = FFI::MemoryPointer.new(size_ptr.read_ulong)
231
- unless GetFileSecurityW(path.to_wstring, info, security_descriptor_ptr, size_ptr.read_ulong, size_ptr)
232
- Chef::ReservedNames::Win32::Error.raise!
233
- end
234
-
235
- SecurityDescriptor.new(security_descriptor_ptr)
236
- end
237
-
238
- def self.get_named_security_info(path, type = :SE_FILE_OBJECT, info = OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION)
239
- security_descriptor = FFI::MemoryPointer.new :pointer
240
- hr = GetNamedSecurityInfoW(path.to_wstring, type, info, nil, nil, nil, nil, security_descriptor)
241
- if hr != ERROR_SUCCESS
242
- Chef::ReservedNames::Win32::Error.raise!("get_named_security_info(#{path}, #{type}, #{info})")
243
- end
244
-
245
- result_pointer = security_descriptor.read_pointer
246
- result = SecurityDescriptor.new(result_pointer)
247
-
248
- # This memory has to be freed with LocalFree.
249
- ObjectSpace.define_finalizer(result, Memory.local_free_finalizer(result_pointer))
250
-
251
- result
252
- end
253
-
254
- def self.get_security_descriptor_control(security_descriptor)
255
- security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
256
- result = FFI::Buffer.new :ushort
257
- version = FFI::Buffer.new :uint32
258
- unless GetSecurityDescriptorControl(security_descriptor, result, version)
259
- Chef::ReservedNames::Win32::Error.raise!
260
- end
261
- [ result.read_ushort, version.read_uint32 ]
262
- end
263
-
264
- def self.get_security_descriptor_dacl(security_descriptor)
265
- security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
266
- present = FFI::Buffer.new :bool
267
- defaulted = FFI::Buffer.new :bool
268
- acl = FFI::Buffer.new :pointer
269
- unless GetSecurityDescriptorDacl(security_descriptor, present, acl, defaulted)
270
- Chef::ReservedNames::Win32::Error.raise!
271
- end
272
- acl = acl.read_pointer
273
- [ present.read_char != 0, acl.null? ? nil : ACL.new(acl, security_descriptor), defaulted.read_char != 0 ]
274
- end
275
-
276
- def self.get_security_descriptor_group(security_descriptor)
277
- security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
278
- result = FFI::Buffer.new :pointer
279
- defaulted = FFI::Buffer.new :long
280
- unless GetSecurityDescriptorGroup(security_descriptor, result, defaulted)
281
- Chef::ReservedNames::Win32::Error.raise!
282
- end
283
-
284
- sid = SID.new(result.read_pointer, security_descriptor)
285
- defaulted = defaulted.read_char != 0
286
- [ sid, defaulted ]
287
- end
288
-
289
- def self.get_security_descriptor_owner(security_descriptor)
290
- security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
291
- result = FFI::Buffer.new :pointer
292
- defaulted = FFI::Buffer.new :long
293
- unless GetSecurityDescriptorOwner(security_descriptor, result, defaulted)
294
- Chef::ReservedNames::Win32::Error.raise!
295
- end
296
-
297
- sid = SID.new(result.read_pointer, security_descriptor)
298
- defaulted = defaulted.read_char != 0
299
- [ sid, defaulted ]
300
- end
301
-
302
- def self.get_security_descriptor_sacl(security_descriptor)
303
- security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
304
- present = FFI::Buffer.new :bool
305
- defaulted = FFI::Buffer.new :bool
306
- acl = FFI::Buffer.new :pointer
307
- unless GetSecurityDescriptorSacl(security_descriptor, present, acl, defaulted)
308
- Chef::ReservedNames::Win32::Error.raise!
309
- end
310
- acl = acl.read_pointer
311
- [ present.read_char != 0, acl.null? ? nil : ACL.new(acl, security_descriptor), defaulted.read_char != 0 ]
312
- end
313
-
314
- def self.get_token_information_owner(token)
315
- owner_result_size = FFI::MemoryPointer.new(:ulong)
316
- if GetTokenInformation(token.handle.handle, :TokenOwner, nil, 0, owner_result_size)
317
- raise "Expected ERROR_INSUFFICIENT_BUFFER from GetTokenInformation, and got no error!"
318
- elsif FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
319
- Chef::ReservedNames::Win32::Error.raise!
320
- end
321
- owner_result_storage = FFI::MemoryPointer.new owner_result_size.read_ulong
322
- unless GetTokenInformation(token.handle.handle, :TokenOwner, owner_result_storage, owner_result_size.read_ulong, owner_result_size)
323
- Chef::ReservedNames::Win32::Error.raise!
324
- end
325
- owner_result = TOKEN_OWNER.new owner_result_storage
326
- SID.new(owner_result[:Owner], owner_result_storage)
327
- end
328
-
329
- def self.get_token_information_primary_group(token)
330
- group_result_size = FFI::MemoryPointer.new(:ulong)
331
- if GetTokenInformation(token.handle.handle, :TokenPrimaryGroup, nil, 0, group_result_size)
332
- raise "Expected ERROR_INSUFFICIENT_BUFFER from GetTokenInformation, and got no error!"
333
- elsif FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
334
- Chef::ReservedNames::Win32::Error.raise!
335
- end
336
- group_result_storage = FFI::MemoryPointer.new group_result_size.read_ulong
337
- unless GetTokenInformation(token.handle.handle, :TokenPrimaryGroup, group_result_storage, group_result_size.read_ulong, group_result_size)
338
- Chef::ReservedNames::Win32::Error.raise!
339
- end
340
- group_result = TOKEN_PRIMARY_GROUP.new group_result_storage
341
- SID.new(group_result[:PrimaryGroup], group_result_storage)
342
- end
343
-
344
- def self.initialize_acl(acl_size)
345
- acl = FFI::MemoryPointer.new acl_size
346
- unless InitializeAcl(acl, acl_size, ACL_REVISION)
347
- Chef::ReservedNames::Win32::Error.raise!
348
- end
349
- ACL.new(acl)
350
- end
351
-
352
- def self.initialize_security_descriptor(revision = SECURITY_DESCRIPTOR_REVISION)
353
- security_descriptor = FFI::MemoryPointer.new SECURITY_DESCRIPTOR_MIN_LENGTH
354
- unless InitializeSecurityDescriptor(security_descriptor, revision)
355
- Chef::ReservedNames::Win32::Error.raise!
356
- end
357
- SecurityDescriptor.new(security_descriptor)
358
- end
359
-
360
- def self.is_valid_acl(acl)
361
- acl = acl.pointer if acl.respond_to?(:pointer)
362
- IsValidAcl(acl) != 0
363
- end
364
-
365
- def self.is_valid_security_descriptor(security_descriptor)
366
- security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
367
- IsValidSecurityDescriptor(security_descriptor) != 0
368
- end
369
-
370
- def self.is_valid_sid(sid)
371
- sid = sid.pointer if sid.respond_to?(:pointer)
372
- IsValidSid(sid) != 0
373
- end
374
-
375
- def self.lookup_account_name(name, system_name = nil)
376
- # Figure out how big the buffers need to be
377
- sid_size = FFI::Buffer.new(:long).write_long(0)
378
- referenced_domain_name_size = FFI::Buffer.new(:long).write_long(0)
379
- system_name = system_name.to_wstring if system_name
380
- if LookupAccountNameW(system_name, name.to_wstring, nil, sid_size, nil, referenced_domain_name_size, nil)
381
- raise "Expected ERROR_INSUFFICIENT_BUFFER from LookupAccountName, and got no error!"
382
- elsif FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
383
- Chef::ReservedNames::Win32::Error.raise!
384
- end
385
-
386
- sid = FFI::MemoryPointer.new :char, sid_size.read_long
387
- referenced_domain_name = FFI::MemoryPointer.new :char, (referenced_domain_name_size.read_long * 2)
388
- use = FFI::Buffer.new(:long).write_long(0)
389
- unless LookupAccountNameW(system_name, name.to_wstring, sid, sid_size, referenced_domain_name, referenced_domain_name_size, use)
390
- Chef::ReservedNames::Win32::Error.raise!
391
- end
392
-
393
- [ referenced_domain_name.read_wstring(referenced_domain_name_size.read_long), SID.new(sid), use.read_long ]
394
- end
395
-
396
- def self.lookup_account_sid(sid, system_name = nil)
397
- sid = sid.pointer if sid.respond_to?(:pointer)
398
- # Figure out how big the buffer needs to be
399
- name_size = FFI::Buffer.new(:long).write_long(0)
400
- referenced_domain_name_size = FFI::Buffer.new(:long).write_long(0)
401
- system_name = system_name.to_wstring if system_name
402
- if LookupAccountSidW(system_name, sid, nil, name_size, nil, referenced_domain_name_size, nil)
403
- raise "Expected ERROR_INSUFFICIENT_BUFFER from LookupAccountSid, and got no error!"
404
- elsif FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
405
- Chef::ReservedNames::Win32::Error.raise!
406
- end
407
-
408
- name = FFI::MemoryPointer.new :char, (name_size.read_long * 2)
409
- referenced_domain_name = FFI::MemoryPointer.new :char, (referenced_domain_name_size.read_long * 2)
410
- use = FFI::Buffer.new(:long).write_long(0)
411
- unless LookupAccountSidW(system_name, sid, name, name_size, referenced_domain_name, referenced_domain_name_size, use)
412
- Chef::ReservedNames::Win32::Error.raise!
413
- end
414
-
415
- [ referenced_domain_name.read_wstring(referenced_domain_name_size.read_long), name.read_wstring(name_size.read_long), use.read_long ]
416
- end
417
-
418
- def self.lookup_privilege_name(system_name, luid)
419
- system_name = system_name.to_wstring if system_name
420
- name_size = FFI::Buffer.new(:long).write_long(0)
421
- if LookupPrivilegeNameW(system_name, luid, nil, name_size)
422
- raise "Expected ERROR_INSUFFICIENT_BUFFER from LookupPrivilegeName, and got no error!"
423
- elsif FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
424
- Chef::ReservedNames::Win32::Error.raise!
425
- end
426
-
427
- name = FFI::MemoryPointer.new :char, (name_size.read_long * 2)
428
- unless LookupPrivilegeNameW(system_name, luid, name, name_size)
429
- Chef::ReservedNames::Win32::Error.raise!
430
- end
431
-
432
- name.read_wstring(name_size.read_long)
433
- end
434
-
435
- def self.lookup_privilege_display_name(system_name, name)
436
- system_name = system_name.to_wstring if system_name
437
- display_name_size = FFI::Buffer.new(:long).write_long(0)
438
- language_id = FFI::Buffer.new(:long)
439
- if LookupPrivilegeDisplayNameW(system_name, name.to_wstring, nil, display_name_size, language_id)
440
- raise "Expected ERROR_INSUFFICIENT_BUFFER from LookupPrivilegeDisplayName, and got no error!"
441
- elsif FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
442
- Chef::ReservedNames::Win32::Error.raise!
443
- end
444
-
445
- display_name = FFI::MemoryPointer.new :char, (display_name_size.read_long * 2)
446
- unless LookupPrivilegeDisplayNameW(system_name, name.to_wstring, display_name, display_name_size, language_id)
447
- Chef::ReservedNames::Win32::Error.raise!
448
- end
449
-
450
- [ display_name.read_wstring(display_name_size.read_long), language_id.read_long ]
451
- end
452
-
453
- def self.lookup_privilege_value(system_name, name)
454
- luid = FFI::Buffer.new(:uint64).write_uint64(0)
455
- system_name = system_name.to_wstring if system_name
456
- unless LookupPrivilegeValueW(system_name, name.to_wstring, luid)
457
- Win32::Error.raise!
458
- end
459
- luid.read_uint64
460
- end
461
-
462
- def self.make_absolute_sd(security_descriptor)
463
- security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
464
-
465
- # Figure out buffer sizes
466
- absolute_sd_size = FFI::Buffer.new(:long).write_long(0)
467
- dacl_size = FFI::Buffer.new(:long).write_long(0)
468
- sacl_size = FFI::Buffer.new(:long).write_long(0)
469
- owner_size = FFI::Buffer.new(:long).write_long(0)
470
- group_size = FFI::Buffer.new(:long).write_long(0)
471
- if MakeAbsoluteSD(security_descriptor, nil, absolute_sd_size, nil, dacl_size, nil, sacl_size, nil, owner_size, nil, group_size)
472
- raise "Expected ERROR_INSUFFICIENT_BUFFER from MakeAbsoluteSD, and got no error!"
473
- elsif FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
474
- Chef::ReservedNames::Win32::Error.raise!
475
- end
476
-
477
- absolute_sd = FFI::MemoryPointer.new absolute_sd_size.read_long
478
- owner = FFI::MemoryPointer.new owner_size.read_long
479
- group = FFI::MemoryPointer.new group_size.read_long
480
- dacl = FFI::MemoryPointer.new dacl_size.read_long
481
- sacl = FFI::MemoryPointer.new sacl_size.read_long
482
- unless MakeAbsoluteSD(security_descriptor, absolute_sd, absolute_sd_size, dacl, dacl_size, sacl, sacl_size, owner, owner_size, group, group_size)
483
- Chef::ReservedNames::Win32::Error.raise!
484
- end
485
-
486
- [ SecurityDescriptor.new(absolute_sd), SID.new(owner), SID.new(group), ACL.new(dacl), ACL.new(sacl) ]
487
- end
488
-
489
- def self.open_current_process_token(desired_access = TOKEN_READ)
490
- open_process_token(Chef::ReservedNames::Win32::Process.get_current_process, desired_access)
491
- end
492
-
493
- def self.open_process_token(process, desired_access)
494
- process = process.handle if process.respond_to?(:handle)
495
- process = process.handle if process.respond_to?(:handle)
496
- token = FFI::Buffer.new(:ulong)
497
- unless OpenProcessToken(process, desired_access, token)
498
- Chef::ReservedNames::Win32::Error.raise!
499
- end
500
- Token.new(Handle.new(token.read_ulong))
501
- end
502
-
503
- def self.query_security_access_mask(security_information)
504
- result = FFI::Buffer.new(:long)
505
- QuerySecurityAccessMask(security_information, result)
506
- result.read_long
507
- end
508
-
509
- def self.set_file_security(path, security_information, security_descriptor)
510
- security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
511
- unless SetFileSecurityW(path.to_wstring, security_information, security_descriptor)
512
- Chef::ReservedNames::Win32::Error.raise!
513
- end
514
- end
515
-
516
- def self.set_named_security_info(path, type, args)
517
- owner = args[:owner]
518
- group = args[:group]
519
- dacl = args[:dacl]
520
- sacl = args[:sacl]
521
- owner = owner.pointer if owner && owner.respond_to?(:pointer)
522
- group = group.pointer if group && group.respond_to?(:pointer)
523
- dacl = dacl.pointer if dacl && dacl.respond_to?(:pointer)
524
- sacl = sacl.pointer if sacl && sacl.respond_to?(:pointer)
525
-
526
- # Determine the security_information flags
527
- security_information = 0
528
- security_information |= OWNER_SECURITY_INFORMATION if args.has_key?(:owner)
529
- security_information |= GROUP_SECURITY_INFORMATION if args.has_key?(:group)
530
- security_information |= DACL_SECURITY_INFORMATION if args.has_key?(:dacl)
531
- security_information |= SACL_SECURITY_INFORMATION if args.has_key?(:sacl)
532
- if args.has_key?(:dacl_inherits)
533
- security_information |= (args[:dacl_inherits] ? UNPROTECTED_DACL_SECURITY_INFORMATION : PROTECTED_DACL_SECURITY_INFORMATION)
534
- end
535
- if args.has_key?(:sacl_inherits)
536
- security_information |= (args[:sacl_inherits] ? UNPROTECTED_SACL_SECURITY_INFORMATION : PROTECTED_SACL_SECURITY_INFORMATION)
537
- end
538
-
539
- hr = SetNamedSecurityInfoW(path.to_wstring, type, security_information, owner, group, dacl, sacl)
540
- if hr != ERROR_SUCCESS
541
- Chef::ReservedNames::Win32::Error.raise!
542
- end
543
- end
544
-
545
- def self.set_security_access_mask(security_information)
546
- result = FFI::Buffer.new(:long)
547
- SetSecurityAccessMask(security_information, result)
548
- result.read_long
549
- end
550
-
551
- def set_security_descriptor_dacl(security_descriptor, acl, defaulted = false, present = nil)
552
- security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
553
- acl = acl.pointer if acl.respond_to?(:pointer)
554
- present = !security_descriptor.null? if present == nil
555
-
556
- unless SetSecurityDescriptorDacl(security_descriptor, present, acl, defaulted)
557
- Chef::ReservedNames::Win32::Error.raise!
558
- end
559
- end
560
-
561
- def self.set_security_descriptor_group(security_descriptor, sid, defaulted = false)
562
- security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
563
- sid = sid.pointer if sid.respond_to?(:pointer)
564
-
565
- unless SetSecurityDescriptorGroup(security_descriptor, sid, defaulted)
566
- Chef::ReservedNames::Win32::Error.raise!
567
- end
568
- end
569
-
570
- def self.set_security_descriptor_owner(security_descriptor, sid, defaulted = false)
571
- security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
572
- sid = sid.pointer if sid.respond_to?(:pointer)
573
-
574
- unless SetSecurityDescriptorOwner(security_descriptor, sid, defaulted)
575
- Chef::ReservedNames::Win32::Error.raise!
576
- end
577
- end
578
-
579
- def self.set_security_descriptor_sacl(security_descriptor, acl, defaulted = false, present = nil)
580
- security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
581
- acl = acl.pointer if acl.respond_to?(:pointer)
582
- present = !security_descriptor.null? if present == nil
583
-
584
- unless SetSecurityDescriptorSacl(security_descriptor, present, acl, defaulted)
585
- Chef::ReservedNames::Win32::Error.raise!
586
- end
587
- end
588
-
589
- def self.with_lsa_policy(username)
590
- sid = lookup_account_name(username)[1]
591
-
592
- access = 0
593
- access |= POLICY_CREATE_ACCOUNT
594
- access |= POLICY_LOOKUP_NAMES
595
-
596
- policy_handle = FFI::MemoryPointer.new(:pointer)
597
- result = LsaOpenPolicy(nil, LSA_OBJECT_ATTRIBUTES.new, access, policy_handle)
598
- win32_error = LsaNtStatusToWinError(result)
599
- if win32_error != 0
600
- Chef::ReservedNames::Win32::Error.raise!(nil, win32_error)
601
- end
602
-
603
- begin
604
- yield policy_handle, sid.pointer
605
- ensure
606
- win32_error = LsaNtStatusToWinError(LsaClose(policy_handle.read_pointer))
607
- if win32_error != 0
608
- Chef::ReservedNames::Win32::Error.raise!(nil, win32_error)
609
- end
610
- end
611
- end
612
-
613
- def self.with_privileges(*privilege_names)
614
- # Set privileges
615
- token = open_current_process_token(TOKEN_READ | TOKEN_ADJUST_PRIVILEGES)
616
- old_privileges = token.enable_privileges(*privilege_names)
617
-
618
- # Let the caller do their privileged stuff
619
- begin
620
- yield
621
- ensure
622
- # Set privileges back to what they were before
623
- token.adjust_privileges(old_privileges)
624
- end
625
- end
626
-
627
- # Checks if the caller has the admin privileges in their
628
- # security token
629
- def self.has_admin_privileges?
630
- if Chef::Platform.windows_server_2003?
631
- # Admin privileges do not exist on Windows Server 2003
632
-
633
- true
634
- else
635
- process_token = open_current_process_token(TOKEN_READ)
636
- elevation_result = FFI::Buffer.new(:ulong)
637
- elevation_result_size = FFI::MemoryPointer.new(:uint32)
638
- success = GetTokenInformation(process_token.handle.handle, :TokenElevation, elevation_result, 4, elevation_result_size)
639
-
640
- # Assume process is not elevated if the call fails.
641
- # Process is elevated if the result is different than 0.
642
- success && (elevation_result.read_ulong != 0)
643
- end
644
- end
645
-
646
- def self.logon_user(username, domain, password, logon_type, logon_provider)
647
- username = wstring(username)
648
- domain = wstring(domain)
649
- password = wstring(password)
650
-
651
- token = FFI::Buffer.new(:pointer)
652
- unless LogonUserW(username, domain, password, logon_type, logon_provider, token)
653
- Chef::ReservedNames::Win32::Error.raise!
654
- end
655
- Token.new(Handle.new(token.read_pointer))
656
- end
657
- end
658
- end
659
- end
660
-
661
- require "chef/win32/security/ace"
662
- require "chef/win32/security/acl"
663
- require "chef/win32/security/securable_object"
664
- require "chef/win32/security/security_descriptor"
665
- require "chef/win32/security/sid"
1
+ #
2
+ # Author:: John Keiser (<jkeiser@chef.io>)
3
+ # Copyright:: Copyright 2011-2016, 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 "chef/win32/api/security"
20
+ require "chef/win32/error"
21
+ require "chef/win32/memory"
22
+ require "chef/win32/process"
23
+ require "chef/win32/unicode"
24
+ require "chef/win32/security/token"
25
+ require "chef/mixin/wide_string"
26
+
27
+ class Chef
28
+ module ReservedNames::Win32
29
+ class Security
30
+ include Chef::ReservedNames::Win32::API::Error
31
+ extend Chef::ReservedNames::Win32::API::Error
32
+ include Chef::ReservedNames::Win32::API::Security
33
+ extend Chef::ReservedNames::Win32::API::Security
34
+ extend Chef::ReservedNames::Win32::API::Macros
35
+ include Chef::Mixin::WideString
36
+ extend Chef::Mixin::WideString
37
+
38
+ def self.access_check(security_descriptor, token, desired_access, generic_mapping)
39
+ token_handle = token.handle.handle
40
+ security_descriptor_ptr = security_descriptor.pointer
41
+
42
+ rights_ptr = FFI::MemoryPointer.new(:ulong)
43
+ rights_ptr.write_ulong(desired_access)
44
+
45
+ # This function takes care of calling MapGenericMask, so you don't have to
46
+ MapGenericMask(rights_ptr, generic_mapping)
47
+
48
+ result_ptr = FFI::MemoryPointer.new(:ulong)
49
+
50
+ # Because optional actually means required
51
+ privileges = PRIVILEGE_SET.new
52
+ privileges[:PrivilegeCount] = 0
53
+ privileges_length_ptr = FFI::MemoryPointer.new(:ulong)
54
+ privileges_length_ptr.write_ulong(privileges.size)
55
+
56
+ granted_access_ptr = FFI::MemoryPointer.new(:ulong)
57
+
58
+ unless AccessCheck(security_descriptor_ptr, token_handle, rights_ptr.read_ulong,
59
+ generic_mapping, privileges, privileges_length_ptr, granted_access_ptr,
60
+ result_ptr)
61
+ Chef::ReservedNames::Win32::Error.raise!
62
+ end
63
+ result_ptr.read_ulong == 1
64
+ end
65
+
66
+ def self.add_ace(acl, ace, insert_position = MAXDWORD, revision = ACL_REVISION)
67
+ acl = acl.pointer if acl.respond_to?(:pointer)
68
+ ace = ace.pointer if ace.respond_to?(:pointer)
69
+ ace_size = ACE_HEADER.new(ace)[:AceSize]
70
+ unless AddAce(acl, revision, insert_position, ace, ace_size)
71
+ Chef::ReservedNames::Win32::Error.raise!
72
+ end
73
+ end
74
+
75
+ def self.add_access_allowed_ace(acl, sid, access_mask, revision = ACL_REVISION)
76
+ acl = acl.pointer if acl.respond_to?(:pointer)
77
+ sid = sid.pointer if sid.respond_to?(:pointer)
78
+ unless AddAccessAllowedAce(acl, revision, access_mask, sid)
79
+ Chef::ReservedNames::Win32::Error.raise!
80
+ end
81
+ end
82
+
83
+ def self.add_access_allowed_ace_ex(acl, sid, access_mask, flags = 0, revision = ACL_REVISION)
84
+ acl = acl.pointer if acl.respond_to?(:pointer)
85
+ sid = sid.pointer if sid.respond_to?(:pointer)
86
+ unless AddAccessAllowedAceEx(acl, revision, flags, access_mask, sid)
87
+ Chef::ReservedNames::Win32::Error.raise!
88
+ end
89
+ end
90
+
91
+ def self.add_access_denied_ace(acl, sid, access_mask, revision = ACL_REVISION)
92
+ acl = acl.pointer if acl.respond_to?(:pointer)
93
+ sid = sid.pointer if sid.respond_to?(:pointer)
94
+ unless AddAccessDeniedAce(acl, revision, access_mask, sid)
95
+ Chef::ReservedNames::Win32::Error.raise!
96
+ end
97
+ end
98
+
99
+ def self.add_access_denied_ace_ex(acl, sid, access_mask, flags = 0, revision = ACL_REVISION)
100
+ acl = acl.pointer if acl.respond_to?(:pointer)
101
+ sid = sid.pointer if sid.respond_to?(:pointer)
102
+ unless AddAccessDeniedAceEx(acl, revision, flags, access_mask, sid)
103
+ Chef::ReservedNames::Win32::Error.raise!
104
+ end
105
+ end
106
+
107
+ def self.add_account_right(name, privilege)
108
+ privilege_pointer = FFI::MemoryPointer.new LSA_UNICODE_STRING, 1
109
+ privilege_lsa_string = LSA_UNICODE_STRING.new(privilege_pointer)
110
+ privilege_lsa_string[:Buffer] = FFI::MemoryPointer.from_string(privilege.to_wstring)
111
+ privilege_lsa_string[:Length] = privilege.length * 2
112
+ privilege_lsa_string[:MaximumLength] = (privilege.length + 1) * 2
113
+
114
+ with_lsa_policy(name) do |policy_handle, sid|
115
+ result = LsaAddAccountRights(policy_handle.read_pointer, sid, privilege_pointer, 1)
116
+ win32_error = LsaNtStatusToWinError(result)
117
+ if win32_error != 0
118
+ Chef::ReservedNames::Win32::Error.raise!(nil, win32_error)
119
+ end
120
+ end
121
+ end
122
+
123
+ def self.adjust_token_privileges(token, privileges)
124
+ token = token.handle if token.respond_to?(:handle)
125
+ old_privileges_size = FFI::Buffer.new(:long).write_long(privileges.size_with_privileges)
126
+ old_privileges = TOKEN_PRIVILEGES.new(FFI::Buffer.new(old_privileges_size.read_long))
127
+ unless AdjustTokenPrivileges(token.handle, false, privileges, privileges.size_with_privileges, old_privileges, old_privileges_size)
128
+ Chef::ReservedNames::Win32::Error.raise!
129
+ end
130
+
131
+ old_privileges
132
+ end
133
+
134
+ def self.convert_sid_to_string_sid(sid)
135
+ sid = sid.pointer if sid.respond_to?(:pointer)
136
+ result = FFI::MemoryPointer.new :pointer
137
+ # TODO: use the W version
138
+ unless ConvertSidToStringSidA(sid, result)
139
+ Chef::ReservedNames::Win32::Error.raise!
140
+ end
141
+
142
+ result_string = result.read_pointer.read_string
143
+
144
+ Chef::ReservedNames::Win32::Memory.local_free(result.read_pointer)
145
+
146
+ result_string
147
+ end
148
+
149
+ def self.convert_string_sid_to_sid(string_sid)
150
+ result = FFI::MemoryPointer.new :pointer
151
+ unless ConvertStringSidToSidW(string_sid.to_wstring, result)
152
+ Chef::ReservedNames::Win32::Error.raise!
153
+ end
154
+
155
+ result_pointer = result.read_pointer
156
+ sid = SID.new(result_pointer)
157
+
158
+ # The result pointer must be freed with local_free
159
+ ObjectSpace.define_finalizer(sid, Memory.local_free_finalizer(result_pointer))
160
+
161
+ sid
162
+ end
163
+
164
+ def self.delete_ace(acl, index)
165
+ acl = acl.pointer if acl.respond_to?(:pointer)
166
+ unless DeleteAce(acl, index)
167
+ Chef::ReservedNames::Win32::Error.raise!
168
+ end
169
+ end
170
+
171
+ def self.equal_sid(sid1, sid2)
172
+ sid1 = sid1.pointer if sid1.respond_to?(:pointer)
173
+ sid2 = sid2.pointer if sid2.respond_to?(:pointer)
174
+ EqualSid(sid1, sid2)
175
+ end
176
+
177
+ def self.free_sid(sid)
178
+ sid = sid.pointer if sid.respond_to?(:pointer)
179
+ unless FreeSid(sid).null?
180
+ Chef::ReservedNames::Win32::Error.raise!
181
+ end
182
+ end
183
+
184
+ def self.get_account_right(name)
185
+ privileges = []
186
+ privilege_pointer = FFI::MemoryPointer.new(:pointer)
187
+ privilege_length = FFI::MemoryPointer.new(:ulong)
188
+
189
+ with_lsa_policy(name) do |policy_handle, sid|
190
+ result = LsaEnumerateAccountRights(policy_handle.read_pointer, sid, privilege_pointer, privilege_length)
191
+ win32_error = LsaNtStatusToWinError(result)
192
+ return [] if win32_error == 2 # FILE_NOT_FOUND - No rights assigned
193
+ if win32_error != 0
194
+ Chef::ReservedNames::Win32::Error.raise!(nil, win32_error)
195
+ end
196
+
197
+ privilege_length.read_ulong.times do |i|
198
+ privilege = LSA_UNICODE_STRING.new(privilege_pointer.read_pointer + i * LSA_UNICODE_STRING.size)
199
+ privileges << privilege[:Buffer].read_wstring
200
+ end
201
+ LsaFreeMemory(privilege_pointer)
202
+ end
203
+
204
+ privileges
205
+ end
206
+
207
+ def self.get_ace(acl, index)
208
+ acl = acl.pointer if acl.respond_to?(:pointer)
209
+ ace = FFI::Buffer.new :pointer
210
+ unless GetAce(acl, index, ace)
211
+ Chef::ReservedNames::Win32::Error.raise!
212
+ end
213
+ ACE.new(ace.read_pointer, acl)
214
+ end
215
+
216
+ def self.get_length_sid(sid)
217
+ sid = sid.pointer if sid.respond_to?(:pointer)
218
+ GetLengthSid(sid)
219
+ end
220
+
221
+ def self.get_file_security(path, info = OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION)
222
+ size_ptr = FFI::MemoryPointer.new(:ulong)
223
+
224
+ success = GetFileSecurityW(path.to_wstring, info, nil, 0, size_ptr)
225
+
226
+ if !success && FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
227
+ Chef::ReservedNames::Win32::Error.raise!
228
+ end
229
+
230
+ security_descriptor_ptr = FFI::MemoryPointer.new(size_ptr.read_ulong)
231
+ unless GetFileSecurityW(path.to_wstring, info, security_descriptor_ptr, size_ptr.read_ulong, size_ptr)
232
+ Chef::ReservedNames::Win32::Error.raise!
233
+ end
234
+
235
+ SecurityDescriptor.new(security_descriptor_ptr)
236
+ end
237
+
238
+ def self.get_named_security_info(path, type = :SE_FILE_OBJECT, info = OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION)
239
+ security_descriptor = FFI::MemoryPointer.new :pointer
240
+ hr = GetNamedSecurityInfoW(path.to_wstring, type, info, nil, nil, nil, nil, security_descriptor)
241
+ if hr != ERROR_SUCCESS
242
+ Chef::ReservedNames::Win32::Error.raise!("get_named_security_info(#{path}, #{type}, #{info})")
243
+ end
244
+
245
+ result_pointer = security_descriptor.read_pointer
246
+ result = SecurityDescriptor.new(result_pointer)
247
+
248
+ # This memory has to be freed with LocalFree.
249
+ ObjectSpace.define_finalizer(result, Memory.local_free_finalizer(result_pointer))
250
+
251
+ result
252
+ end
253
+
254
+ def self.get_security_descriptor_control(security_descriptor)
255
+ security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
256
+ result = FFI::Buffer.new :ushort
257
+ version = FFI::Buffer.new :uint32
258
+ unless GetSecurityDescriptorControl(security_descriptor, result, version)
259
+ Chef::ReservedNames::Win32::Error.raise!
260
+ end
261
+ [ result.read_ushort, version.read_uint32 ]
262
+ end
263
+
264
+ def self.get_security_descriptor_dacl(security_descriptor)
265
+ security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
266
+ present = FFI::Buffer.new :bool
267
+ defaulted = FFI::Buffer.new :bool
268
+ acl = FFI::Buffer.new :pointer
269
+ unless GetSecurityDescriptorDacl(security_descriptor, present, acl, defaulted)
270
+ Chef::ReservedNames::Win32::Error.raise!
271
+ end
272
+ acl = acl.read_pointer
273
+ [ present.read_char != 0, acl.null? ? nil : ACL.new(acl, security_descriptor), defaulted.read_char != 0 ]
274
+ end
275
+
276
+ def self.get_security_descriptor_group(security_descriptor)
277
+ security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
278
+ result = FFI::Buffer.new :pointer
279
+ defaulted = FFI::Buffer.new :long
280
+ unless GetSecurityDescriptorGroup(security_descriptor, result, defaulted)
281
+ Chef::ReservedNames::Win32::Error.raise!
282
+ end
283
+
284
+ sid = SID.new(result.read_pointer, security_descriptor)
285
+ defaulted = defaulted.read_char != 0
286
+ [ sid, defaulted ]
287
+ end
288
+
289
+ def self.get_security_descriptor_owner(security_descriptor)
290
+ security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
291
+ result = FFI::Buffer.new :pointer
292
+ defaulted = FFI::Buffer.new :long
293
+ unless GetSecurityDescriptorOwner(security_descriptor, result, defaulted)
294
+ Chef::ReservedNames::Win32::Error.raise!
295
+ end
296
+
297
+ sid = SID.new(result.read_pointer, security_descriptor)
298
+ defaulted = defaulted.read_char != 0
299
+ [ sid, defaulted ]
300
+ end
301
+
302
+ def self.get_security_descriptor_sacl(security_descriptor)
303
+ security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
304
+ present = FFI::Buffer.new :bool
305
+ defaulted = FFI::Buffer.new :bool
306
+ acl = FFI::Buffer.new :pointer
307
+ unless GetSecurityDescriptorSacl(security_descriptor, present, acl, defaulted)
308
+ Chef::ReservedNames::Win32::Error.raise!
309
+ end
310
+ acl = acl.read_pointer
311
+ [ present.read_char != 0, acl.null? ? nil : ACL.new(acl, security_descriptor), defaulted.read_char != 0 ]
312
+ end
313
+
314
+ def self.get_token_information_owner(token)
315
+ owner_result_size = FFI::MemoryPointer.new(:ulong)
316
+ if GetTokenInformation(token.handle.handle, :TokenOwner, nil, 0, owner_result_size)
317
+ raise "Expected ERROR_INSUFFICIENT_BUFFER from GetTokenInformation, and got no error!"
318
+ elsif FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
319
+ Chef::ReservedNames::Win32::Error.raise!
320
+ end
321
+ owner_result_storage = FFI::MemoryPointer.new owner_result_size.read_ulong
322
+ unless GetTokenInformation(token.handle.handle, :TokenOwner, owner_result_storage, owner_result_size.read_ulong, owner_result_size)
323
+ Chef::ReservedNames::Win32::Error.raise!
324
+ end
325
+ owner_result = TOKEN_OWNER.new owner_result_storage
326
+ SID.new(owner_result[:Owner], owner_result_storage)
327
+ end
328
+
329
+ def self.get_token_information_primary_group(token)
330
+ group_result_size = FFI::MemoryPointer.new(:ulong)
331
+ if GetTokenInformation(token.handle.handle, :TokenPrimaryGroup, nil, 0, group_result_size)
332
+ raise "Expected ERROR_INSUFFICIENT_BUFFER from GetTokenInformation, and got no error!"
333
+ elsif FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
334
+ Chef::ReservedNames::Win32::Error.raise!
335
+ end
336
+ group_result_storage = FFI::MemoryPointer.new group_result_size.read_ulong
337
+ unless GetTokenInformation(token.handle.handle, :TokenPrimaryGroup, group_result_storage, group_result_size.read_ulong, group_result_size)
338
+ Chef::ReservedNames::Win32::Error.raise!
339
+ end
340
+ group_result = TOKEN_PRIMARY_GROUP.new group_result_storage
341
+ SID.new(group_result[:PrimaryGroup], group_result_storage)
342
+ end
343
+
344
+ def self.initialize_acl(acl_size)
345
+ acl = FFI::MemoryPointer.new acl_size
346
+ unless InitializeAcl(acl, acl_size, ACL_REVISION)
347
+ Chef::ReservedNames::Win32::Error.raise!
348
+ end
349
+ ACL.new(acl)
350
+ end
351
+
352
+ def self.initialize_security_descriptor(revision = SECURITY_DESCRIPTOR_REVISION)
353
+ security_descriptor = FFI::MemoryPointer.new SECURITY_DESCRIPTOR_MIN_LENGTH
354
+ unless InitializeSecurityDescriptor(security_descriptor, revision)
355
+ Chef::ReservedNames::Win32::Error.raise!
356
+ end
357
+ SecurityDescriptor.new(security_descriptor)
358
+ end
359
+
360
+ def self.is_valid_acl(acl)
361
+ acl = acl.pointer if acl.respond_to?(:pointer)
362
+ IsValidAcl(acl) != 0
363
+ end
364
+
365
+ def self.is_valid_security_descriptor(security_descriptor)
366
+ security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
367
+ IsValidSecurityDescriptor(security_descriptor) != 0
368
+ end
369
+
370
+ def self.is_valid_sid(sid)
371
+ sid = sid.pointer if sid.respond_to?(:pointer)
372
+ IsValidSid(sid) != 0
373
+ end
374
+
375
+ def self.lookup_account_name(name, system_name = nil)
376
+ # Figure out how big the buffers need to be
377
+ sid_size = FFI::Buffer.new(:long).write_long(0)
378
+ referenced_domain_name_size = FFI::Buffer.new(:long).write_long(0)
379
+ system_name = system_name.to_wstring if system_name
380
+ if LookupAccountNameW(system_name, name.to_wstring, nil, sid_size, nil, referenced_domain_name_size, nil)
381
+ raise "Expected ERROR_INSUFFICIENT_BUFFER from LookupAccountName, and got no error!"
382
+ elsif FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
383
+ Chef::ReservedNames::Win32::Error.raise!
384
+ end
385
+
386
+ sid = FFI::MemoryPointer.new :char, sid_size.read_long
387
+ referenced_domain_name = FFI::MemoryPointer.new :char, (referenced_domain_name_size.read_long * 2)
388
+ use = FFI::Buffer.new(:long).write_long(0)
389
+ unless LookupAccountNameW(system_name, name.to_wstring, sid, sid_size, referenced_domain_name, referenced_domain_name_size, use)
390
+ Chef::ReservedNames::Win32::Error.raise!
391
+ end
392
+
393
+ [ referenced_domain_name.read_wstring(referenced_domain_name_size.read_long), SID.new(sid), use.read_long ]
394
+ end
395
+
396
+ def self.lookup_account_sid(sid, system_name = nil)
397
+ sid = sid.pointer if sid.respond_to?(:pointer)
398
+ # Figure out how big the buffer needs to be
399
+ name_size = FFI::Buffer.new(:long).write_long(0)
400
+ referenced_domain_name_size = FFI::Buffer.new(:long).write_long(0)
401
+ system_name = system_name.to_wstring if system_name
402
+ if LookupAccountSidW(system_name, sid, nil, name_size, nil, referenced_domain_name_size, nil)
403
+ raise "Expected ERROR_INSUFFICIENT_BUFFER from LookupAccountSid, and got no error!"
404
+ elsif FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
405
+ Chef::ReservedNames::Win32::Error.raise!
406
+ end
407
+
408
+ name = FFI::MemoryPointer.new :char, (name_size.read_long * 2)
409
+ referenced_domain_name = FFI::MemoryPointer.new :char, (referenced_domain_name_size.read_long * 2)
410
+ use = FFI::Buffer.new(:long).write_long(0)
411
+ unless LookupAccountSidW(system_name, sid, name, name_size, referenced_domain_name, referenced_domain_name_size, use)
412
+ Chef::ReservedNames::Win32::Error.raise!
413
+ end
414
+
415
+ [ referenced_domain_name.read_wstring(referenced_domain_name_size.read_long), name.read_wstring(name_size.read_long), use.read_long ]
416
+ end
417
+
418
+ def self.lookup_privilege_name(system_name, luid)
419
+ system_name = system_name.to_wstring if system_name
420
+ name_size = FFI::Buffer.new(:long).write_long(0)
421
+ if LookupPrivilegeNameW(system_name, luid, nil, name_size)
422
+ raise "Expected ERROR_INSUFFICIENT_BUFFER from LookupPrivilegeName, and got no error!"
423
+ elsif FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
424
+ Chef::ReservedNames::Win32::Error.raise!
425
+ end
426
+
427
+ name = FFI::MemoryPointer.new :char, (name_size.read_long * 2)
428
+ unless LookupPrivilegeNameW(system_name, luid, name, name_size)
429
+ Chef::ReservedNames::Win32::Error.raise!
430
+ end
431
+
432
+ name.read_wstring(name_size.read_long)
433
+ end
434
+
435
+ def self.lookup_privilege_display_name(system_name, name)
436
+ system_name = system_name.to_wstring if system_name
437
+ display_name_size = FFI::Buffer.new(:long).write_long(0)
438
+ language_id = FFI::Buffer.new(:long)
439
+ if LookupPrivilegeDisplayNameW(system_name, name.to_wstring, nil, display_name_size, language_id)
440
+ raise "Expected ERROR_INSUFFICIENT_BUFFER from LookupPrivilegeDisplayName, and got no error!"
441
+ elsif FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
442
+ Chef::ReservedNames::Win32::Error.raise!
443
+ end
444
+
445
+ display_name = FFI::MemoryPointer.new :char, (display_name_size.read_long * 2)
446
+ unless LookupPrivilegeDisplayNameW(system_name, name.to_wstring, display_name, display_name_size, language_id)
447
+ Chef::ReservedNames::Win32::Error.raise!
448
+ end
449
+
450
+ [ display_name.read_wstring(display_name_size.read_long), language_id.read_long ]
451
+ end
452
+
453
+ def self.lookup_privilege_value(system_name, name)
454
+ luid = FFI::Buffer.new(:uint64).write_uint64(0)
455
+ system_name = system_name.to_wstring if system_name
456
+ unless LookupPrivilegeValueW(system_name, name.to_wstring, luid)
457
+ Win32::Error.raise!
458
+ end
459
+ luid.read_uint64
460
+ end
461
+
462
+ def self.make_absolute_sd(security_descriptor)
463
+ security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
464
+
465
+ # Figure out buffer sizes
466
+ absolute_sd_size = FFI::Buffer.new(:long).write_long(0)
467
+ dacl_size = FFI::Buffer.new(:long).write_long(0)
468
+ sacl_size = FFI::Buffer.new(:long).write_long(0)
469
+ owner_size = FFI::Buffer.new(:long).write_long(0)
470
+ group_size = FFI::Buffer.new(:long).write_long(0)
471
+ if MakeAbsoluteSD(security_descriptor, nil, absolute_sd_size, nil, dacl_size, nil, sacl_size, nil, owner_size, nil, group_size)
472
+ raise "Expected ERROR_INSUFFICIENT_BUFFER from MakeAbsoluteSD, and got no error!"
473
+ elsif FFI::LastError.error != ERROR_INSUFFICIENT_BUFFER
474
+ Chef::ReservedNames::Win32::Error.raise!
475
+ end
476
+
477
+ absolute_sd = FFI::MemoryPointer.new absolute_sd_size.read_long
478
+ owner = FFI::MemoryPointer.new owner_size.read_long
479
+ group = FFI::MemoryPointer.new group_size.read_long
480
+ dacl = FFI::MemoryPointer.new dacl_size.read_long
481
+ sacl = FFI::MemoryPointer.new sacl_size.read_long
482
+ unless MakeAbsoluteSD(security_descriptor, absolute_sd, absolute_sd_size, dacl, dacl_size, sacl, sacl_size, owner, owner_size, group, group_size)
483
+ Chef::ReservedNames::Win32::Error.raise!
484
+ end
485
+
486
+ [ SecurityDescriptor.new(absolute_sd), SID.new(owner), SID.new(group), ACL.new(dacl), ACL.new(sacl) ]
487
+ end
488
+
489
+ def self.open_current_process_token(desired_access = TOKEN_READ)
490
+ open_process_token(Chef::ReservedNames::Win32::Process.get_current_process, desired_access)
491
+ end
492
+
493
+ def self.open_process_token(process, desired_access)
494
+ process = process.handle if process.respond_to?(:handle)
495
+ process = process.handle if process.respond_to?(:handle)
496
+ token = FFI::Buffer.new(:ulong)
497
+ unless OpenProcessToken(process, desired_access, token)
498
+ Chef::ReservedNames::Win32::Error.raise!
499
+ end
500
+ Token.new(Handle.new(token.read_ulong))
501
+ end
502
+
503
+ def self.query_security_access_mask(security_information)
504
+ result = FFI::Buffer.new(:long)
505
+ QuerySecurityAccessMask(security_information, result)
506
+ result.read_long
507
+ end
508
+
509
+ def self.set_file_security(path, security_information, security_descriptor)
510
+ security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
511
+ unless SetFileSecurityW(path.to_wstring, security_information, security_descriptor)
512
+ Chef::ReservedNames::Win32::Error.raise!
513
+ end
514
+ end
515
+
516
+ def self.set_named_security_info(path, type, args)
517
+ owner = args[:owner]
518
+ group = args[:group]
519
+ dacl = args[:dacl]
520
+ sacl = args[:sacl]
521
+ owner = owner.pointer if owner && owner.respond_to?(:pointer)
522
+ group = group.pointer if group && group.respond_to?(:pointer)
523
+ dacl = dacl.pointer if dacl && dacl.respond_to?(:pointer)
524
+ sacl = sacl.pointer if sacl && sacl.respond_to?(:pointer)
525
+
526
+ # Determine the security_information flags
527
+ security_information = 0
528
+ security_information |= OWNER_SECURITY_INFORMATION if args.has_key?(:owner)
529
+ security_information |= GROUP_SECURITY_INFORMATION if args.has_key?(:group)
530
+ security_information |= DACL_SECURITY_INFORMATION if args.has_key?(:dacl)
531
+ security_information |= SACL_SECURITY_INFORMATION if args.has_key?(:sacl)
532
+ if args.has_key?(:dacl_inherits)
533
+ security_information |= (args[:dacl_inherits] ? UNPROTECTED_DACL_SECURITY_INFORMATION : PROTECTED_DACL_SECURITY_INFORMATION)
534
+ end
535
+ if args.has_key?(:sacl_inherits)
536
+ security_information |= (args[:sacl_inherits] ? UNPROTECTED_SACL_SECURITY_INFORMATION : PROTECTED_SACL_SECURITY_INFORMATION)
537
+ end
538
+
539
+ hr = SetNamedSecurityInfoW(path.to_wstring, type, security_information, owner, group, dacl, sacl)
540
+ if hr != ERROR_SUCCESS
541
+ Chef::ReservedNames::Win32::Error.raise!
542
+ end
543
+ end
544
+
545
+ def self.set_security_access_mask(security_information)
546
+ result = FFI::Buffer.new(:long)
547
+ SetSecurityAccessMask(security_information, result)
548
+ result.read_long
549
+ end
550
+
551
+ def set_security_descriptor_dacl(security_descriptor, acl, defaulted = false, present = nil)
552
+ security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
553
+ acl = acl.pointer if acl.respond_to?(:pointer)
554
+ present = !security_descriptor.null? if present == nil
555
+
556
+ unless SetSecurityDescriptorDacl(security_descriptor, present, acl, defaulted)
557
+ Chef::ReservedNames::Win32::Error.raise!
558
+ end
559
+ end
560
+
561
+ def self.set_security_descriptor_group(security_descriptor, sid, defaulted = false)
562
+ security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
563
+ sid = sid.pointer if sid.respond_to?(:pointer)
564
+
565
+ unless SetSecurityDescriptorGroup(security_descriptor, sid, defaulted)
566
+ Chef::ReservedNames::Win32::Error.raise!
567
+ end
568
+ end
569
+
570
+ def self.set_security_descriptor_owner(security_descriptor, sid, defaulted = false)
571
+ security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
572
+ sid = sid.pointer if sid.respond_to?(:pointer)
573
+
574
+ unless SetSecurityDescriptorOwner(security_descriptor, sid, defaulted)
575
+ Chef::ReservedNames::Win32::Error.raise!
576
+ end
577
+ end
578
+
579
+ def self.set_security_descriptor_sacl(security_descriptor, acl, defaulted = false, present = nil)
580
+ security_descriptor = security_descriptor.pointer if security_descriptor.respond_to?(:pointer)
581
+ acl = acl.pointer if acl.respond_to?(:pointer)
582
+ present = !security_descriptor.null? if present == nil
583
+
584
+ unless SetSecurityDescriptorSacl(security_descriptor, present, acl, defaulted)
585
+ Chef::ReservedNames::Win32::Error.raise!
586
+ end
587
+ end
588
+
589
+ def self.with_lsa_policy(username)
590
+ sid = lookup_account_name(username)[1]
591
+
592
+ access = 0
593
+ access |= POLICY_CREATE_ACCOUNT
594
+ access |= POLICY_LOOKUP_NAMES
595
+
596
+ policy_handle = FFI::MemoryPointer.new(:pointer)
597
+ result = LsaOpenPolicy(nil, LSA_OBJECT_ATTRIBUTES.new, access, policy_handle)
598
+ win32_error = LsaNtStatusToWinError(result)
599
+ if win32_error != 0
600
+ Chef::ReservedNames::Win32::Error.raise!(nil, win32_error)
601
+ end
602
+
603
+ begin
604
+ yield policy_handle, sid.pointer
605
+ ensure
606
+ win32_error = LsaNtStatusToWinError(LsaClose(policy_handle.read_pointer))
607
+ if win32_error != 0
608
+ Chef::ReservedNames::Win32::Error.raise!(nil, win32_error)
609
+ end
610
+ end
611
+ end
612
+
613
+ def self.with_privileges(*privilege_names)
614
+ # Set privileges
615
+ token = open_current_process_token(TOKEN_READ | TOKEN_ADJUST_PRIVILEGES)
616
+ old_privileges = token.enable_privileges(*privilege_names)
617
+
618
+ # Let the caller do their privileged stuff
619
+ begin
620
+ yield
621
+ ensure
622
+ # Set privileges back to what they were before
623
+ token.adjust_privileges(old_privileges)
624
+ end
625
+ end
626
+
627
+ # Checks if the caller has the admin privileges in their
628
+ # security token
629
+ def self.has_admin_privileges?
630
+ if Chef::Platform.windows_server_2003?
631
+ # Admin privileges do not exist on Windows Server 2003
632
+
633
+ true
634
+ else
635
+ process_token = open_current_process_token(TOKEN_READ)
636
+ elevation_result = FFI::Buffer.new(:ulong)
637
+ elevation_result_size = FFI::MemoryPointer.new(:uint32)
638
+ success = GetTokenInformation(process_token.handle.handle, :TokenElevation, elevation_result, 4, elevation_result_size)
639
+
640
+ # Assume process is not elevated if the call fails.
641
+ # Process is elevated if the result is different than 0.
642
+ success && (elevation_result.read_ulong != 0)
643
+ end
644
+ end
645
+
646
+ def self.logon_user(username, domain, password, logon_type, logon_provider)
647
+ username = wstring(username)
648
+ domain = wstring(domain)
649
+ password = wstring(password)
650
+
651
+ token = FFI::Buffer.new(:pointer)
652
+ unless LogonUserW(username, domain, password, logon_type, logon_provider, token)
653
+ Chef::ReservedNames::Win32::Error.raise!
654
+ end
655
+ Token.new(Handle.new(token.read_pointer))
656
+ end
657
+ end
658
+ end
659
+ end
660
+
661
+ require "chef/win32/security/ace"
662
+ require "chef/win32/security/acl"
663
+ require "chef/win32/security/securable_object"
664
+ require "chef/win32/security/security_descriptor"
665
+ require "chef/win32/security/sid"