TrueCar-chef 0.10.0.beta.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (372) hide show
  1. data/LICENSE +201 -0
  2. data/README.rdoc +171 -0
  3. data/bin/chef-client +26 -0
  4. data/bin/chef-solo +25 -0
  5. data/bin/knife +26 -0
  6. data/bin/shef +34 -0
  7. data/distro/README +2 -0
  8. data/distro/arch/etc/conf.d/chef-client.conf +5 -0
  9. data/distro/arch/etc/conf.d/chef-server-webui.conf +10 -0
  10. data/distro/arch/etc/conf.d/chef-server.conf +10 -0
  11. data/distro/arch/etc/conf.d/chef-solr-indexer.conf +8 -0
  12. data/distro/arch/etc/conf.d/chef-solr.conf +8 -0
  13. data/distro/arch/etc/rc.d/chef-client +76 -0
  14. data/distro/arch/etc/rc.d/chef-server +78 -0
  15. data/distro/arch/etc/rc.d/chef-server-webui +78 -0
  16. data/distro/arch/etc/rc.d/chef-solr +78 -0
  17. data/distro/arch/etc/rc.d/chef-solr-indexer +78 -0
  18. data/distro/common/man/man1/chef-indexer.1 +42 -0
  19. data/distro/common/man/man1/chef-server-webui.1 +106 -0
  20. data/distro/common/man/man1/chef-server.1 +107 -0
  21. data/distro/common/man/man1/chef-solr-indexer.1 +55 -0
  22. data/distro/common/man/man1/chef-solr.1 +55 -0
  23. data/distro/common/man/man8/chef-client.8 +63 -0
  24. data/distro/common/man/man8/chef-solo.8 +57 -0
  25. data/distro/common/man/man8/chef-solr-rebuild.8 +37 -0
  26. data/distro/common/man/man8/knife.8 +1349 -0
  27. data/distro/common/man/man8/shef.8 +45 -0
  28. data/distro/common/markdown/README +3 -0
  29. data/distro/common/markdown/knife.mkd +865 -0
  30. data/distro/debian/etc/default/chef-client +4 -0
  31. data/distro/debian/etc/default/chef-server +9 -0
  32. data/distro/debian/etc/default/chef-server-webui +9 -0
  33. data/distro/debian/etc/default/chef-solr +8 -0
  34. data/distro/debian/etc/default/chef-solr-indexer +7 -0
  35. data/distro/debian/etc/init.d/chef-client +175 -0
  36. data/distro/debian/etc/init.d/chef-server +122 -0
  37. data/distro/debian/etc/init.d/chef-server-webui +123 -0
  38. data/distro/debian/etc/init.d/chef-solr +176 -0
  39. data/distro/debian/etc/init.d/chef-solr-indexer +176 -0
  40. data/distro/debian/etc/init/chef-client.conf +17 -0
  41. data/distro/debian/etc/init/chef-server-webui.conf +17 -0
  42. data/distro/debian/etc/init/chef-server.conf +17 -0
  43. data/distro/debian/etc/init/chef-solr-indexer.conf +17 -0
  44. data/distro/debian/etc/init/chef-solr.conf +17 -0
  45. data/distro/redhat/etc/init.d/chef-client +106 -0
  46. data/distro/redhat/etc/init.d/chef-server +112 -0
  47. data/distro/redhat/etc/init.d/chef-server-webui +112 -0
  48. data/distro/redhat/etc/init.d/chef-solr +104 -0
  49. data/distro/redhat/etc/init.d/chef-solr-indexer +104 -0
  50. data/distro/redhat/etc/logrotate.d/chef-client +8 -0
  51. data/distro/redhat/etc/logrotate.d/chef-server +8 -0
  52. data/distro/redhat/etc/logrotate.d/chef-server-webui +8 -0
  53. data/distro/redhat/etc/logrotate.d/chef-solr +8 -0
  54. data/distro/redhat/etc/logrotate.d/chef-solr-indexer +8 -0
  55. data/distro/redhat/etc/sysconfig/chef-client +15 -0
  56. data/distro/redhat/etc/sysconfig/chef-server +14 -0
  57. data/distro/redhat/etc/sysconfig/chef-server-webui +14 -0
  58. data/distro/redhat/etc/sysconfig/chef-solr +8 -0
  59. data/distro/redhat/etc/sysconfig/chef-solr-indexer +7 -0
  60. data/lib/chef.rb +40 -0
  61. data/lib/chef/api_client.rb +264 -0
  62. data/lib/chef/application.rb +137 -0
  63. data/lib/chef/application/agent.rb +18 -0
  64. data/lib/chef/application/client.rb +242 -0
  65. data/lib/chef/application/knife.rb +169 -0
  66. data/lib/chef/application/solo.rb +217 -0
  67. data/lib/chef/applications.rb +4 -0
  68. data/lib/chef/certificate.rb +194 -0
  69. data/lib/chef/checksum.rb +182 -0
  70. data/lib/chef/checksum_cache.rb +189 -0
  71. data/lib/chef/client.rb +362 -0
  72. data/lib/chef/config.rb +244 -0
  73. data/lib/chef/cookbook/chefignore.rb +66 -0
  74. data/lib/chef/cookbook/cookbook_collection.rb +45 -0
  75. data/lib/chef/cookbook/cookbook_version_loader.rb +151 -0
  76. data/lib/chef/cookbook/file_system_file_vendor.rb +56 -0
  77. data/lib/chef/cookbook/file_vendor.rb +48 -0
  78. data/lib/chef/cookbook/metadata.rb +592 -0
  79. data/lib/chef/cookbook/remote_file_vendor.rb +87 -0
  80. data/lib/chef/cookbook/syntax_check.rb +136 -0
  81. data/lib/chef/cookbook_loader.rb +103 -0
  82. data/lib/chef/cookbook_site_streaming_uploader.rb +244 -0
  83. data/lib/chef/cookbook_uploader.rb +125 -0
  84. data/lib/chef/cookbook_version.rb +979 -0
  85. data/lib/chef/cookbook_version_selector.rb +163 -0
  86. data/lib/chef/couchdb.rb +247 -0
  87. data/lib/chef/daemon.rb +172 -0
  88. data/lib/chef/data_bag.rb +223 -0
  89. data/lib/chef/data_bag_item.rb +267 -0
  90. data/lib/chef/encrypted_data_bag_item.rb +126 -0
  91. data/lib/chef/environment.rb +386 -0
  92. data/lib/chef/exceptions.rb +153 -0
  93. data/lib/chef/file_access_control.rb +140 -0
  94. data/lib/chef/file_cache.rb +218 -0
  95. data/lib/chef/handler.rb +206 -0
  96. data/lib/chef/handler/json_file.rb +58 -0
  97. data/lib/chef/index_queue.rb +29 -0
  98. data/lib/chef/index_queue/amqp_client.rb +116 -0
  99. data/lib/chef/index_queue/consumer.rb +76 -0
  100. data/lib/chef/index_queue/indexable.rb +109 -0
  101. data/lib/chef/json_compat.rb +52 -0
  102. data/lib/chef/knife.rb +424 -0
  103. data/lib/chef/knife/bootstrap.rb +185 -0
  104. data/lib/chef/knife/bootstrap/archlinux-gems.erb +47 -0
  105. data/lib/chef/knife/bootstrap/centos5-gems.erb +41 -0
  106. data/lib/chef/knife/bootstrap/client-install.vbs +80 -0
  107. data/lib/chef/knife/bootstrap/fedora13-gems.erb +38 -0
  108. data/lib/chef/knife/bootstrap/ubuntu10.04-apt.erb +32 -0
  109. data/lib/chef/knife/bootstrap/ubuntu10.04-gems.erb +46 -0
  110. data/lib/chef/knife/bootstrap/windows-gems.erb +34 -0
  111. data/lib/chef/knife/client_bulk_delete.rb +43 -0
  112. data/lib/chef/knife/client_create.rb +73 -0
  113. data/lib/chef/knife/client_delete.rb +48 -0
  114. data/lib/chef/knife/client_edit.rb +48 -0
  115. data/lib/chef/knife/client_list.rb +43 -0
  116. data/lib/chef/knife/client_reregister.rb +59 -0
  117. data/lib/chef/knife/client_show.rb +53 -0
  118. data/lib/chef/knife/configure.rb +136 -0
  119. data/lib/chef/knife/configure_client.rb +52 -0
  120. data/lib/chef/knife/cookbook_bulk_delete.rb +61 -0
  121. data/lib/chef/knife/cookbook_create.rb +274 -0
  122. data/lib/chef/knife/cookbook_delete.rb +149 -0
  123. data/lib/chef/knife/cookbook_download.rb +134 -0
  124. data/lib/chef/knife/cookbook_list.rb +50 -0
  125. data/lib/chef/knife/cookbook_metadata.rb +102 -0
  126. data/lib/chef/knife/cookbook_metadata_from_file.rb +44 -0
  127. data/lib/chef/knife/cookbook_show.rb +101 -0
  128. data/lib/chef/knife/cookbook_site_download.rb +58 -0
  129. data/lib/chef/knife/cookbook_site_list.rb +56 -0
  130. data/lib/chef/knife/cookbook_site_search.rb +51 -0
  131. data/lib/chef/knife/cookbook_site_share.rb +114 -0
  132. data/lib/chef/knife/cookbook_site_show.rb +57 -0
  133. data/lib/chef/knife/cookbook_site_unshare.rb +56 -0
  134. data/lib/chef/knife/cookbook_site_vendor.rb +145 -0
  135. data/lib/chef/knife/cookbook_test.rb +82 -0
  136. data/lib/chef/knife/cookbook_upload.rb +146 -0
  137. data/lib/chef/knife/data_bag_create.rb +94 -0
  138. data/lib/chef/knife/data_bag_delete.rb +51 -0
  139. data/lib/chef/knife/data_bag_edit.rb +94 -0
  140. data/lib/chef/knife/data_bag_from_file.rb +85 -0
  141. data/lib/chef/knife/data_bag_list.rb +46 -0
  142. data/lib/chef/knife/data_bag_show.rb +81 -0
  143. data/lib/chef/knife/environment_create.rb +53 -0
  144. data/lib/chef/knife/environment_delete.rb +45 -0
  145. data/lib/chef/knife/environment_edit.rb +45 -0
  146. data/lib/chef/knife/environment_from_file.rb +39 -0
  147. data/lib/chef/knife/environment_list.rb +42 -0
  148. data/lib/chef/knife/environment_show.rb +46 -0
  149. data/lib/chef/knife/exec.rb +51 -0
  150. data/lib/chef/knife/index_rebuild.rb +50 -0
  151. data/lib/chef/knife/node_bulk_delete.rb +46 -0
  152. data/lib/chef/knife/node_create.rb +50 -0
  153. data/lib/chef/knife/node_delete.rb +47 -0
  154. data/lib/chef/knife/node_edit.rb +163 -0
  155. data/lib/chef/knife/node_from_file.rb +45 -0
  156. data/lib/chef/knife/node_list.rb +46 -0
  157. data/lib/chef/knife/node_run_list_add.rb +67 -0
  158. data/lib/chef/knife/node_run_list_remove.rb +48 -0
  159. data/lib/chef/knife/node_show.rb +62 -0
  160. data/lib/chef/knife/recipe_list.rb +33 -0
  161. data/lib/chef/knife/role_bulk_delete.rb +47 -0
  162. data/lib/chef/knife/role_create.rb +55 -0
  163. data/lib/chef/knife/role_delete.rb +47 -0
  164. data/lib/chef/knife/role_edit.rb +48 -0
  165. data/lib/chef/knife/role_from_file.rb +49 -0
  166. data/lib/chef/knife/role_list.rb +43 -0
  167. data/lib/chef/knife/role_show.rb +54 -0
  168. data/lib/chef/knife/search.rb +123 -0
  169. data/lib/chef/knife/ssh.rb +318 -0
  170. data/lib/chef/knife/status.rb +90 -0
  171. data/lib/chef/knife/subcommand_loader.rb +101 -0
  172. data/lib/chef/knife/tag_create.rb +31 -0
  173. data/lib/chef/knife/tag_delete.rb +31 -0
  174. data/lib/chef/knife/tag_list.rb +29 -0
  175. data/lib/chef/knife/ui.rb +227 -0
  176. data/lib/chef/knife/windows_bootstrap.rb +157 -0
  177. data/lib/chef/log.rb +39 -0
  178. data/lib/chef/mash.rb +211 -0
  179. data/lib/chef/mixin/check_helper.rb +31 -0
  180. data/lib/chef/mixin/checksum.rb +32 -0
  181. data/lib/chef/mixin/command.rb +221 -0
  182. data/lib/chef/mixin/command/unix.rb +215 -0
  183. data/lib/chef/mixin/command/windows.rb +76 -0
  184. data/lib/chef/mixin/convert_to_class_name.rb +63 -0
  185. data/lib/chef/mixin/create_path.rb +56 -0
  186. data/lib/chef/mixin/deep_merge.rb +225 -0
  187. data/lib/chef/mixin/deprecation.rb +65 -0
  188. data/lib/chef/mixin/from_file.rb +50 -0
  189. data/lib/chef/mixin/language.rb +165 -0
  190. data/lib/chef/mixin/language_include_attribute.rb +61 -0
  191. data/lib/chef/mixin/language_include_recipe.rb +52 -0
  192. data/lib/chef/mixin/params_validate.rb +225 -0
  193. data/lib/chef/mixin/recipe_definition_dsl_core.rb +81 -0
  194. data/lib/chef/mixin/shell_out.rb +40 -0
  195. data/lib/chef/mixin/template.rb +95 -0
  196. data/lib/chef/mixin/xml_escape.rb +140 -0
  197. data/lib/chef/mixins.rb +15 -0
  198. data/lib/chef/monkey_patches/dir.rb +36 -0
  199. data/lib/chef/monkey_patches/numeric.rb +7 -0
  200. data/lib/chef/monkey_patches/regexp.rb +34 -0
  201. data/lib/chef/monkey_patches/string.rb +28 -0
  202. data/lib/chef/monkey_patches/tempfile.rb +64 -0
  203. data/lib/chef/nil_argument.rb +3 -0
  204. data/lib/chef/node.rb +661 -0
  205. data/lib/chef/node/attribute.rb +487 -0
  206. data/lib/chef/openid_registration.rb +187 -0
  207. data/lib/chef/platform.rb +409 -0
  208. data/lib/chef/provider.rb +124 -0
  209. data/lib/chef/provider/breakpoint.rb +36 -0
  210. data/lib/chef/provider/cookbook_file.rb +101 -0
  211. data/lib/chef/provider/cron.rb +186 -0
  212. data/lib/chef/provider/cron/solaris.rb +195 -0
  213. data/lib/chef/provider/deploy.rb +320 -0
  214. data/lib/chef/provider/deploy/revision.rb +80 -0
  215. data/lib/chef/provider/deploy/timestamped.rb +33 -0
  216. data/lib/chef/provider/directory.rb +72 -0
  217. data/lib/chef/provider/env.rb +152 -0
  218. data/lib/chef/provider/env/windows.rb +75 -0
  219. data/lib/chef/provider/erl_call.rb +100 -0
  220. data/lib/chef/provider/execute.rb +60 -0
  221. data/lib/chef/provider/file.rb +222 -0
  222. data/lib/chef/provider/git.rb +221 -0
  223. data/lib/chef/provider/group.rb +133 -0
  224. data/lib/chef/provider/group/aix.rb +70 -0
  225. data/lib/chef/provider/group/dscl.rb +121 -0
  226. data/lib/chef/provider/group/gpasswd.rb +53 -0
  227. data/lib/chef/provider/group/groupadd.rb +81 -0
  228. data/lib/chef/provider/group/pw.rb +84 -0
  229. data/lib/chef/provider/group/usermod.rb +57 -0
  230. data/lib/chef/provider/group/windows.rb +79 -0
  231. data/lib/chef/provider/http_request.rb +122 -0
  232. data/lib/chef/provider/ifconfig.rb +132 -0
  233. data/lib/chef/provider/link.rb +161 -0
  234. data/lib/chef/provider/log.rb +54 -0
  235. data/lib/chef/provider/mdadm.rb +91 -0
  236. data/lib/chef/provider/mount.rb +117 -0
  237. data/lib/chef/provider/mount/mount.rb +232 -0
  238. data/lib/chef/provider/mount/windows.rb +80 -0
  239. data/lib/chef/provider/ohai.rb +41 -0
  240. data/lib/chef/provider/package.rb +160 -0
  241. data/lib/chef/provider/package/apt.rb +110 -0
  242. data/lib/chef/provider/package/dpkg.rb +112 -0
  243. data/lib/chef/provider/package/easy_install.rb +136 -0
  244. data/lib/chef/provider/package/freebsd.rb +123 -0
  245. data/lib/chef/provider/package/macports.rb +105 -0
  246. data/lib/chef/provider/package/pacman.rb +101 -0
  247. data/lib/chef/provider/package/portage.rb +135 -0
  248. data/lib/chef/provider/package/rpm.rb +101 -0
  249. data/lib/chef/provider/package/rubygems.rb +462 -0
  250. data/lib/chef/provider/package/solaris.rb +127 -0
  251. data/lib/chef/provider/package/yum-dump.py +128 -0
  252. data/lib/chef/provider/package/yum.rb +261 -0
  253. data/lib/chef/provider/package/zypper.rb +133 -0
  254. data/lib/chef/provider/remote_directory.rb +138 -0
  255. data/lib/chef/provider/remote_file.rb +119 -0
  256. data/lib/chef/provider/route.rb +195 -0
  257. data/lib/chef/provider/ruby_block.rb +33 -0
  258. data/lib/chef/provider/script.rb +55 -0
  259. data/lib/chef/provider/service.rb +128 -0
  260. data/lib/chef/provider/service/arch.rb +109 -0
  261. data/lib/chef/provider/service/debian.rb +130 -0
  262. data/lib/chef/provider/service/freebsd.rb +156 -0
  263. data/lib/chef/provider/service/gentoo.rb +54 -0
  264. data/lib/chef/provider/service/init.rb +71 -0
  265. data/lib/chef/provider/service/insserv.rb +52 -0
  266. data/lib/chef/provider/service/redhat.rb +60 -0
  267. data/lib/chef/provider/service/simple.rb +118 -0
  268. data/lib/chef/provider/service/solaris.rb +85 -0
  269. data/lib/chef/provider/service/upstart.rb +192 -0
  270. data/lib/chef/provider/service/windows.rb +146 -0
  271. data/lib/chef/provider/subversion.rb +194 -0
  272. data/lib/chef/provider/template.rb +105 -0
  273. data/lib/chef/provider/user.rb +187 -0
  274. data/lib/chef/provider/user/dscl.rb +280 -0
  275. data/lib/chef/provider/user/pw.rb +113 -0
  276. data/lib/chef/provider/user/useradd.rb +137 -0
  277. data/lib/chef/provider/user/windows.rb +124 -0
  278. data/lib/chef/providers.rb +93 -0
  279. data/lib/chef/recipe.rb +128 -0
  280. data/lib/chef/resource.rb +530 -0
  281. data/lib/chef/resource/apt_package.rb +34 -0
  282. data/lib/chef/resource/bash.rb +33 -0
  283. data/lib/chef/resource/breakpoint.rb +35 -0
  284. data/lib/chef/resource/cookbook_file.rb +45 -0
  285. data/lib/chef/resource/cron.rb +188 -0
  286. data/lib/chef/resource/csh.rb +33 -0
  287. data/lib/chef/resource/deploy.rb +371 -0
  288. data/lib/chef/resource/deploy_revision.rb +35 -0
  289. data/lib/chef/resource/directory.rb +76 -0
  290. data/lib/chef/resource/dpkg_package.rb +34 -0
  291. data/lib/chef/resource/easy_install_package.rb +57 -0
  292. data/lib/chef/resource/env.rb +58 -0
  293. data/lib/chef/resource/erl_call.rb +83 -0
  294. data/lib/chef/resource/execute.rb +127 -0
  295. data/lib/chef/resource/file.rb +99 -0
  296. data/lib/chef/resource/freebsd_package.rb +35 -0
  297. data/lib/chef/resource/gem_package.rb +53 -0
  298. data/lib/chef/resource/git.rb +37 -0
  299. data/lib/chef/resource/group.rb +70 -0
  300. data/lib/chef/resource/http_request.rb +61 -0
  301. data/lib/chef/resource/ifconfig.rb +134 -0
  302. data/lib/chef/resource/link.rb +78 -0
  303. data/lib/chef/resource/log.rb +62 -0
  304. data/lib/chef/resource/macports_package.rb +29 -0
  305. data/lib/chef/resource/mdadm.rb +82 -0
  306. data/lib/chef/resource/mount.rb +135 -0
  307. data/lib/chef/resource/ohai.rb +40 -0
  308. data/lib/chef/resource/package.rb +80 -0
  309. data/lib/chef/resource/pacman_package.rb +33 -0
  310. data/lib/chef/resource/perl.rb +33 -0
  311. data/lib/chef/resource/portage_package.rb +33 -0
  312. data/lib/chef/resource/python.rb +33 -0
  313. data/lib/chef/resource/remote_directory.rb +109 -0
  314. data/lib/chef/resource/remote_file.rb +83 -0
  315. data/lib/chef/resource/route.rb +135 -0
  316. data/lib/chef/resource/rpm_package.rb +34 -0
  317. data/lib/chef/resource/ruby.rb +33 -0
  318. data/lib/chef/resource/ruby_block.rb +40 -0
  319. data/lib/chef/resource/scm.rb +147 -0
  320. data/lib/chef/resource/script.rb +60 -0
  321. data/lib/chef/resource/service.rb +160 -0
  322. data/lib/chef/resource/solaris_package.rb +36 -0
  323. data/lib/chef/resource/subversion.rb +36 -0
  324. data/lib/chef/resource/template.rb +69 -0
  325. data/lib/chef/resource/timestamped_deploy.rb +31 -0
  326. data/lib/chef/resource/user.rb +130 -0
  327. data/lib/chef/resource/yum_package.rb +43 -0
  328. data/lib/chef/resource_collection.rb +217 -0
  329. data/lib/chef/resource_collection/stepable_iterator.rb +124 -0
  330. data/lib/chef/resource_definition.rb +67 -0
  331. data/lib/chef/resource_definition_list.rb +38 -0
  332. data/lib/chef/resources.rb +64 -0
  333. data/lib/chef/rest.rb +386 -0
  334. data/lib/chef/rest/auth_credentials.rb +71 -0
  335. data/lib/chef/rest/cookie_jar.rb +31 -0
  336. data/lib/chef/rest/rest_request.rb +188 -0
  337. data/lib/chef/role.rb +341 -0
  338. data/lib/chef/run_context.rb +126 -0
  339. data/lib/chef/run_list.rb +165 -0
  340. data/lib/chef/run_list/run_list_expansion.rb +193 -0
  341. data/lib/chef/run_list/run_list_item.rb +92 -0
  342. data/lib/chef/run_list/versioned_recipe_list.rb +68 -0
  343. data/lib/chef/run_status.rb +121 -0
  344. data/lib/chef/runner.rb +99 -0
  345. data/lib/chef/sandbox.rb +153 -0
  346. data/lib/chef/search/query.rb +65 -0
  347. data/lib/chef/shef.rb +326 -0
  348. data/lib/chef/shef/ext.rb +569 -0
  349. data/lib/chef/shef/model_wrapper.rb +120 -0
  350. data/lib/chef/shef/shef_rest.rb +28 -0
  351. data/lib/chef/shef/shef_session.rb +284 -0
  352. data/lib/chef/shell_out.rb +238 -0
  353. data/lib/chef/shell_out/unix.rb +223 -0
  354. data/lib/chef/shell_out/windows.rb +98 -0
  355. data/lib/chef/solr_query.rb +187 -0
  356. data/lib/chef/solr_query/lucene.treetop +150 -0
  357. data/lib/chef/solr_query/lucene_nodes.rb +285 -0
  358. data/lib/chef/solr_query/query_transform.rb +65 -0
  359. data/lib/chef/solr_query/solr_http_request.rb +118 -0
  360. data/lib/chef/streaming_cookbook_uploader.rb +201 -0
  361. data/lib/chef/tasks/chef_repo.rake +256 -0
  362. data/lib/chef/util/file_edit.rb +122 -0
  363. data/lib/chef/util/windows.rb +56 -0
  364. data/lib/chef/util/windows/net_group.rb +101 -0
  365. data/lib/chef/util/windows/net_use.rb +121 -0
  366. data/lib/chef/util/windows/net_user.rb +198 -0
  367. data/lib/chef/util/windows/volume.rb +59 -0
  368. data/lib/chef/version.rb +23 -0
  369. data/lib/chef/version_class.rb +70 -0
  370. data/lib/chef/version_constraint.rb +116 -0
  371. data/lib/chef/webui_user.rb +231 -0
  372. metadata +600 -0
@@ -0,0 +1,105 @@
1
+ #--
2
+ # Author:: Adam Jacob (<adam@opscode.com>)
3
+ # Author:: Daniel DeLeo (<dan@opscode.com>)
4
+ # Copyright:: Copyright (c) 2008, 2010 Opscode, Inc.
5
+ # License:: Apache License, Version 2.0
6
+ #
7
+ # Licensed under the Apache License, Version 2.0 (the "License");
8
+ # you may not use this file except in compliance with the License.
9
+ # You may obtain a copy of the License at
10
+ #
11
+ # http://www.apache.org/licenses/LICENSE-2.0
12
+ #
13
+ # Unless required by applicable law or agreed to in writing, software
14
+ # distributed under the License is distributed on an "AS IS" BASIS,
15
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
+ # See the License for the specific language governing permissions and
17
+ # limitations under the License.
18
+ #
19
+
20
+ require 'chef/provider/file'
21
+ require 'chef/mixin/template'
22
+ require 'chef/mixin/checksum'
23
+ require 'chef/file_access_control'
24
+
25
+ class Chef
26
+ class Provider
27
+
28
+ class Template < Chef::Provider::File
29
+
30
+ include Chef::Mixin::Checksum
31
+ include Chef::Mixin::Template
32
+
33
+ def load_current_resource
34
+ super
35
+ @current_resource.checksum(checksum(@current_resource.path)) if ::File.exist?(@current_resource.path)
36
+ end
37
+
38
+ def action_create
39
+ render_with_context(template_location) do |rendered_template|
40
+ rendered(rendered_template)
41
+ if ::File.exist?(@new_resource.path) && content_matches?
42
+ Chef::Log.debug("#{@new_resource} content has not changed.")
43
+ set_all_access_controls(@new_resource.path)
44
+ else
45
+ Chef::Log.info("Writing updated content for #{@new_resource} to #{@new_resource.path}")
46
+ backup
47
+ set_all_access_controls(rendered_template.path)
48
+ FileUtils.mv(rendered_template.path, @new_resource.path)
49
+ @new_resource.updated_by_last_action(true)
50
+ end
51
+ end
52
+ end
53
+
54
+ def action_create_if_missing
55
+ if ::File.exists?(@new_resource.path)
56
+ Chef::Log.debug("Template #{@new_resource} exists, taking no action.")
57
+ else
58
+ action_create
59
+ end
60
+ end
61
+
62
+ def template_location
63
+ Chef::Log.debug("looking for template #{@new_resource.source} in cookbook #{cookbook_name.inspect}")
64
+ @template_file_cache_location ||= begin
65
+ if @new_resource.local
66
+ @new_resource.source
67
+ else
68
+ cookbook = run_context.cookbook_collection[resource_cookbook]
69
+ cookbook.preferred_filename_on_disk_location(node, :templates, @new_resource.source)
70
+ end
71
+ end
72
+ end
73
+
74
+ def resource_cookbook
75
+ @new_resource.cookbook || @new_resource.cookbook_name
76
+ end
77
+
78
+ def rendered(rendered_template)
79
+ @new_resource.checksum(checksum(rendered_template.path))
80
+ Chef::Log.debug("Current content's checksum: #{@current_resource.checksum}")
81
+ Chef::Log.debug("Rendered content's checksum: #{@new_resource.checksum}")
82
+ end
83
+
84
+ def content_matches?
85
+ @current_resource.checksum == @new_resource.checksum
86
+ end
87
+
88
+ def set_all_access_controls(file)
89
+ access_controls = Chef::FileAccessControl.new(@new_resource, file)
90
+ access_controls.set_all
91
+ @new_resource.updated_by_last_action(access_controls.modified?)
92
+ end
93
+
94
+ private
95
+
96
+ def render_with_context(template_location, &block)
97
+ context = {}
98
+ context.merge!(@new_resource.variables)
99
+ context[:node] = node
100
+ render_template(IO.read(template_location), context, &block)
101
+ end
102
+
103
+ end
104
+ end
105
+ end
@@ -0,0 +1,187 @@
1
+ #
2
+ # Author:: Adam Jacob (<adam@opscode.com>)
3
+ # Copyright:: Copyright (c) 2008 Opscode, 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/provider'
20
+ require 'chef/mixin/command'
21
+ require 'chef/resource/user'
22
+ require 'etc'
23
+
24
+ class Chef
25
+ class Provider
26
+ class User < Chef::Provider
27
+
28
+ include Chef::Mixin::Command
29
+
30
+ attr_accessor :user_exists, :locked
31
+
32
+ def initialize(new_resource, run_context)
33
+ super
34
+ @user_exists = true
35
+ @locked = nil
36
+ end
37
+
38
+ def convert_group_name
39
+ if @new_resource.gid.is_a? String
40
+ @new_resource.gid(Etc.getgrnam(@new_resource.gid).gid)
41
+ end
42
+ rescue ArgumentError => e
43
+ raise Chef::Exceptions::User, "Couldn't lookup integer GID for group name #{@new_resource.gid}"
44
+ end
45
+
46
+ def load_current_resource
47
+ @current_resource = Chef::Resource::User.new(@new_resource.name)
48
+ @current_resource.username(@new_resource.username)
49
+
50
+ begin
51
+ user_info = Etc.getpwnam(@new_resource.username)
52
+ rescue ArgumentError => e
53
+ @user_exists = false
54
+ Chef::Log.debug("User #{@new_resource.username} does not exist")
55
+ user_info = nil
56
+ end
57
+
58
+ if user_info
59
+ @current_resource.uid(user_info.uid)
60
+ @current_resource.gid(user_info.gid)
61
+ @current_resource.comment(user_info.gecos)
62
+ @current_resource.home(user_info.dir)
63
+ @current_resource.shell(user_info.shell)
64
+ @current_resource.password(user_info.passwd)
65
+
66
+ if @new_resource.password && @current_resource.password == 'x'
67
+ begin
68
+ require 'shadow'
69
+ rescue LoadError
70
+ Chef::Log.error("You must have ruby-shadow installed for password support!")
71
+ raise Chef::Exceptions::MissingLibrary, "You must have ruby-shadow installed for password support!"
72
+ else
73
+ shadow_info = Shadow::Passwd.getspnam(@new_resource.username)
74
+ @current_resource.password(shadow_info.sp_pwdp)
75
+ end
76
+ end
77
+
78
+ if @new_resource.gid
79
+ convert_group_name
80
+ end
81
+ end
82
+
83
+ @current_resource
84
+ end
85
+
86
+ # Check to see if the user needs any changes
87
+ #
88
+ # === Returns
89
+ # <true>:: If a change is required
90
+ # <false>:: If the users are identical
91
+ def compare_user
92
+ [ :uid, :gid, :comment, :home, :shell, :password ].any? do |user_attrib|
93
+ !@new_resource.send(user_attrib).nil? && @new_resource.send(user_attrib) != @current_resource.send(user_attrib)
94
+ end
95
+ end
96
+
97
+ def action_create
98
+ if !@user_exists
99
+ create_user
100
+ Chef::Log.info("Created #{@new_resource}")
101
+ @new_resource.updated_by_last_action(true)
102
+ elsif compare_user
103
+ manage_user
104
+ Chef::Log.info("Altered #{@new_resource}")
105
+ @new_resource.updated_by_last_action(true)
106
+ end
107
+ end
108
+
109
+ def action_remove
110
+ if @user_exists
111
+ remove_user
112
+ @new_resource.updated_by_last_action(true)
113
+ Chef::Log.info("Removed #{@new_resource}")
114
+ end
115
+ end
116
+
117
+ def remove_user
118
+ raise NotImplementedError
119
+ end
120
+
121
+ def action_manage
122
+ if @user_exists && compare_user
123
+ manage_user
124
+ @new_resource.updated_by_last_action(true)
125
+ Chef::Log.info("Managed #{@new_resource}")
126
+ end
127
+ end
128
+
129
+ def manage_user
130
+ raise NotImplementedError
131
+ end
132
+
133
+ def action_modify
134
+ if @user_exists
135
+ if compare_user
136
+ manage_user
137
+ @new_resource.updated_by_last_action(true)
138
+ Chef::Log.info("Modified #{@new_resource}")
139
+ end
140
+ else
141
+ raise Chef::Exceptions::User, "Cannot modify #{@new_resource} - user does not exist!"
142
+ end
143
+ end
144
+
145
+ def action_lock
146
+ if @user_exists
147
+ if check_lock() == false
148
+ lock_user
149
+ @new_resource.updated_by_last_action(true)
150
+ Chef::Log.info("Locked #{@new_resource}")
151
+ else
152
+ Chef::Log.debug("No need to lock #{@new_resource}")
153
+ end
154
+ else
155
+ raise Chef::Exceptions::User, "Cannot lock #{@new_resource} - user does not exist!"
156
+ end
157
+ end
158
+
159
+ def check_lock
160
+ raise NotImplementedError
161
+ end
162
+
163
+ def lock_user
164
+ raise NotImplementedError
165
+ end
166
+
167
+ def action_unlock
168
+ if @user_exists
169
+ if check_lock() == true
170
+ unlock_user
171
+ @new_resource.updated_by_last_action(true)
172
+ Chef::Log.info("Unlocked #{@new_resource}")
173
+ else
174
+ Chef::Log.debug("No need to unlock #{@new_resource}")
175
+ end
176
+ else
177
+ raise Chef::Exceptions::User, "Cannot unlock #{@new_resource} - user does not exist!"
178
+ end
179
+ end
180
+
181
+ def unlock_user
182
+ raise NotImplementedError
183
+ end
184
+
185
+ end
186
+ end
187
+ end
@@ -0,0 +1,280 @@
1
+ #
2
+ # Author:: Dreamcat4 (<dreamcat4@gmail.com>)
3
+ # Copyright:: Copyright (c) 2009 OpsCode, 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/mixin/shell_out'
20
+ require 'chef/provider/user'
21
+ require 'openssl'
22
+
23
+ class Chef
24
+ class Provider
25
+ class User
26
+ class Dscl < Chef::Provider::User
27
+ include Chef::Mixin::ShellOut
28
+
29
+ NFS_HOME_DIRECTORY = %r{^NFSHomeDirectory: (.*)$}
30
+ AUTHENTICATION_AUTHORITY = %r{^AuthenticationAuthority: (.*)$}
31
+
32
+ def dscl(*args)
33
+ shell_out("dscl . -#{args.join(' ')}")
34
+ end
35
+
36
+ def safe_dscl(*args)
37
+ result = dscl(*args)
38
+ return "" if ( args.first =~ /^delete/ ) && ( result.exitstatus != 0 )
39
+ raise(Chef::Exceptions::DsclCommandFailed,"dscl error: #{result.inspect}") unless result.exitstatus == 0
40
+ raise(Chef::Exceptions::DsclCommandFailed,"dscl error: #{result.inspect}") if result.stdout =~ /No such key: /
41
+ return result.stdout
42
+ end
43
+
44
+ # This is handled in providers/group.rb by Etc.getgrnam()
45
+ # def user_exists?(user)
46
+ # users = safe_dscl("list /Users")
47
+ # !! ( users =~ Regexp.new("\n#{user}\n") )
48
+ # end
49
+
50
+ # get a free UID greater than 200
51
+ def get_free_uid(search_limit=1000)
52
+ uid = nil; next_uid_guess = 200
53
+ users_uids = safe_dscl("list /Users uid")
54
+ while(next_uid_guess < search_limit + 200)
55
+ if users_uids =~ Regexp.new("#{Regexp.escape(next_uid_guess.to_s)}\n")
56
+ next_uid_guess += 1
57
+ else
58
+ uid = next_uid_guess
59
+ break
60
+ end
61
+ end
62
+ return uid || raise("uid not found. Exhausted. Searched #{search_limit} times")
63
+ end
64
+
65
+ def uid_used?(uid)
66
+ return false unless uid
67
+ users_uids = safe_dscl("list /Users uid")
68
+ !! ( users_uids =~ Regexp.new("#{Regexp.escape(uid.to_s)}\n") )
69
+ end
70
+
71
+ def set_uid
72
+ @new_resource.uid(get_free_uid) if (@new_resource.uid.nil? || @new_resource.uid == '')
73
+ if uid_used?(@new_resource.uid)
74
+ raise(Chef::Exceptions::RequestedUIDUnavailable, "uid #{@new_resource.uid} is already in use")
75
+ end
76
+ safe_dscl("create /Users/#{@new_resource.username} UniqueID #{@new_resource.uid}")
77
+ end
78
+
79
+ def modify_home
80
+ return safe_dscl("delete /Users/#{@new_resource.username} NFSHomeDirectory") if (@new_resource.home.nil? || @new_resource.home.empty?)
81
+ if @new_resource.supports[:manage_home]
82
+ validate_home_dir_specification!
83
+
84
+ if (@current_resource.home == @new_resource.home) && !new_home_exists?
85
+ ditto_home
86
+ elsif !current_home_exists? && !new_home_exists?
87
+ ditto_home
88
+ elsif current_home_exists?
89
+ move_home
90
+ end
91
+ end
92
+ safe_dscl("create /Users/#{@new_resource.username} NFSHomeDirectory '#{@new_resource.home}'")
93
+ end
94
+
95
+ def osx_shadow_hash?(string)
96
+ return !! ( string =~ /^[[:xdigit:]]{1240}$/ )
97
+ end
98
+
99
+ def osx_salted_sha1?(string)
100
+ return !! ( string =~ /^[[:xdigit:]]{48}$/ )
101
+ end
102
+
103
+ def guid
104
+ safe_dscl("read /Users/#{@new_resource.username} GeneratedUID").gsub(/GeneratedUID: /,"").strip
105
+ end
106
+
107
+ def shadow_hash_set?
108
+ user_data = safe_dscl("read /Users/#{@new_resource.username}")
109
+ if user_data =~ /AuthenticationAuthority: / && user_data =~ /ShadowHash/
110
+ true
111
+ else
112
+ false
113
+ end
114
+ end
115
+
116
+ def modify_password
117
+ if @new_resource.password
118
+ shadow_hash = nil
119
+
120
+ Chef::Log.debug("#{new_resource}: updating password")
121
+ if osx_shadow_hash?(@new_resource.password)
122
+ shadow_hash = @new_resource.password.upcase
123
+ else
124
+ if osx_salted_sha1?(@new_resource.password)
125
+ salted_sha1 = @new_resource.password.upcase
126
+ else
127
+ hex_salt = ""
128
+ OpenSSL::Random.random_bytes(10).each_byte { |b| hex_salt << b.to_i.to_s(16) }
129
+ hex_salt = hex_salt.slice(0...8)
130
+ salt = [hex_salt].pack("H*")
131
+ sha1 = ::OpenSSL::Digest::SHA1.hexdigest(salt+@new_resource.password)
132
+ salted_sha1 = (hex_salt+sha1).upcase
133
+ end
134
+ shadow_hash = String.new("00000000"*155)
135
+ shadow_hash[168] = salted_sha1
136
+ end
137
+
138
+ ::File.open("/var/db/shadow/hash/#{guid}",'w',0600) do |output|
139
+ output.puts shadow_hash
140
+ end
141
+
142
+ unless shadow_hash_set?
143
+ safe_dscl("append /Users/#{@new_resource.username} AuthenticationAuthority ';ShadowHash;'")
144
+ end
145
+ end
146
+ end
147
+
148
+ def load_current_resource
149
+ super
150
+ raise Chef::Exceptions::User, "Could not find binary /usr/bin/dscl for #{@new_resource}" unless ::File.exists?("/usr/bin/dscl")
151
+ end
152
+
153
+ def create_user
154
+ dscl_create_user
155
+ dscl_create_comment
156
+ set_uid
157
+ dscl_set_gid
158
+ modify_home
159
+ dscl_set_shell
160
+ modify_password
161
+ end
162
+
163
+ def manage_user
164
+ dscl_create_user if diverged?(:username)
165
+ dscl_create_comment if diverged?(:comment)
166
+ set_uid if diverged?(:uid)
167
+ dscl_set_gid if diverged?(:uid)
168
+ modify_home if diverged?(:home)
169
+ dscl_set_shell if diverged?(:shell)
170
+ modify_password if diverged?(:password)
171
+ end
172
+
173
+ def dscl_create_user
174
+ safe_dscl("create /Users/#{@new_resource.username}")
175
+ end
176
+
177
+ def dscl_create_comment
178
+ safe_dscl("create /Users/#{@new_resource.username} RealName '#{@new_resource.comment}'")
179
+ end
180
+
181
+ def dscl_set_gid
182
+ safe_dscl("create /Users/#{@new_resource.username} PrimaryGroupID '#{@new_resource.gid}'")
183
+ end
184
+
185
+ def dscl_set_shell
186
+ if @new_resource.password || ::File.exists?("#{@new_resource.shell}")
187
+ safe_dscl("create /Users/#{@new_resource.username} UserShell '#{@new_resource.shell}'")
188
+ else
189
+ safe_dscl("create /Users/#{@new_resource.username} UserShell '/usr/bin/false'")
190
+ end
191
+ end
192
+
193
+ def remove_user
194
+ if @new_resource.supports[:manage_home]
195
+ user_info = safe_dscl("read /Users/#{@new_resource.username}")
196
+ if nfs_home_match = user_info.match(NFS_HOME_DIRECTORY)
197
+ #nfs_home = safe_dscl("read /Users/#{@new_resource.username} NFSHomeDirectory")
198
+ #nfs_home.gsub!(/NFSHomeDirectory: /,"").gsub!(/\n$/,"")
199
+ nfs_home = nfs_home_match[1]
200
+ FileUtils.rm_rf(nfs_home)
201
+ end
202
+ end
203
+ # remove the user from its groups
204
+ groups = []
205
+ Etc.group do |group|
206
+ groups << group.name if group.mem.include?(@new_resource.username)
207
+ end
208
+ groups.each do |group_name|
209
+ safe_dscl("delete /Groups/#{group_name} GroupMembership '#{@new_resource.username}'")
210
+ end
211
+ # remove user account
212
+ safe_dscl("delete /Users/#{@new_resource.username}")
213
+ end
214
+
215
+ def locked?
216
+ user_info = safe_dscl("read /Users/#{@new_resource.username}")
217
+ if auth_authority_md = AUTHENTICATION_AUTHORITY.match(user_info)
218
+ !!(auth_authority_md[1] =~ /DisabledUser/ )
219
+ else
220
+ false
221
+ end
222
+ end
223
+
224
+ def check_lock
225
+ return @locked = locked?
226
+ end
227
+
228
+ def lock_user
229
+ safe_dscl("append /Users/#{@new_resource.username} AuthenticationAuthority ';DisabledUser;'")
230
+ end
231
+
232
+ def unlock_user
233
+ auth_info = safe_dscl("read /Users/#{@new_resource.username} AuthenticationAuthority")
234
+ auth_string = auth_info.gsub(/AuthenticationAuthority: /,"").gsub(/;DisabledUser;/,"").strip#.gsub!(/[; ]*$/,"")
235
+ safe_dscl("create /Users/#{@new_resource.username} AuthenticationAuthority '#{auth_string}'")
236
+ end
237
+
238
+ def validate_home_dir_specification!
239
+ unless @new_resource.home =~ /^\//
240
+ raise(Chef::Exceptions::InvalidHomeDirectory,"invalid path spec for User: '#{@new_resource.username}', home directory: '#{@new_resource.home}'")
241
+ end
242
+ end
243
+
244
+ def current_home_exists?
245
+ ::File.exist?("#{@current_resource.home}")
246
+ end
247
+
248
+ def new_home_exists?
249
+ ::File.exist?("#{@new_resource.home}")
250
+ end
251
+
252
+ def ditto_home
253
+ skel = "/System/Library/User Template/English.lproj"
254
+ raise(Chef::Exceptions::User,"can't find skel at: #{skel}") unless ::File.exists?(skel)
255
+ shell_out! "ditto '#{skel}' '#{@new_resource.home}'"
256
+ ::FileUtils.chown_R(@new_resource.username,@new_resource.gid.to_s,@new_resource.home)
257
+ end
258
+
259
+ def move_home
260
+ Chef::Log.debug("moving #{self} home from #{@current_resource.home} to #{@new_resource.home}")
261
+
262
+ src = @current_resource.home
263
+ FileUtils.mkdir_p(@new_resource.home)
264
+ files = ::Dir.glob("#{src}/*", ::File::FNM_DOTMATCH) - ["#{src}/.","#{src}/.."]
265
+ ::FileUtils.mv(files,@new_resource.home, :force => true)
266
+ ::FileUtils.rmdir(src)
267
+ ::FileUtils.chown_R(@new_resource.username,@new_resource.gid.to_s,@new_resource.home)
268
+ end
269
+
270
+ def diverged?(parameter)
271
+ parameter_updated?(parameter) && (not @new_resource.send(parameter).nil?)
272
+ end
273
+
274
+ def parameter_updated?(parameter)
275
+ not (@new_resource.send(parameter) == @current_resource.send(parameter))
276
+ end
277
+ end
278
+ end
279
+ end
280
+ end