tylerrick-chef 0.10.8

Sign up to get free protection for your applications and to get access to all the features.
Files changed (450) 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-expander.conf +8 -0
  10. data/distro/arch/etc/conf.d/chef-server-webui.conf +10 -0
  11. data/distro/arch/etc/conf.d/chef-server.conf +10 -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-expander +78 -0
  15. data/distro/arch/etc/rc.d/chef-server +78 -0
  16. data/distro/arch/etc/rc.d/chef-server-webui +78 -0
  17. data/distro/arch/etc/rc.d/chef-solr +78 -0
  18. data/distro/common/html/chef-client.8.html +146 -0
  19. data/distro/common/html/chef-expander.8.html +164 -0
  20. data/distro/common/html/chef-expanderctl.8.html +146 -0
  21. data/distro/common/html/chef-server-webui.8.html +185 -0
  22. data/distro/common/html/chef-server.8.html +182 -0
  23. data/distro/common/html/chef-solo.8.html +191 -0
  24. data/distro/common/html/chef-solr.8.html +165 -0
  25. data/distro/common/html/knife-bootstrap.1.html +243 -0
  26. data/distro/common/html/knife-client.1.html +219 -0
  27. data/distro/common/html/knife-configure.1.html +170 -0
  28. data/distro/common/html/knife-cookbook-site.1.html +241 -0
  29. data/distro/common/html/knife-cookbook.1.html +384 -0
  30. data/distro/common/html/knife-data-bag.1.html +234 -0
  31. data/distro/common/html/knife-environment.1.html +267 -0
  32. data/distro/common/html/knife-exec.1.html +134 -0
  33. data/distro/common/html/knife-index.1.html +125 -0
  34. data/distro/common/html/knife-node.1.html +250 -0
  35. data/distro/common/html/knife-recipe.1.html +92 -0
  36. data/distro/common/html/knife-role.1.html +200 -0
  37. data/distro/common/html/knife-search.1.html +288 -0
  38. data/distro/common/html/knife-ssh.1.html +157 -0
  39. data/distro/common/html/knife-status.1.html +128 -0
  40. data/distro/common/html/knife-tag.1.html +137 -0
  41. data/distro/common/html/knife.1.html +321 -0
  42. data/distro/common/html/shef.1.html +283 -0
  43. data/distro/common/man/man1/knife-bootstrap.1 +197 -0
  44. data/distro/common/man/man1/knife-client.1 +99 -0
  45. data/distro/common/man/man1/knife-configure.1 +88 -0
  46. data/distro/common/man/man1/knife-cookbook-site.1 +145 -0
  47. data/distro/common/man/man1/knife-cookbook.1 +345 -0
  48. data/distro/common/man/man1/knife-data-bag.1 +130 -0
  49. data/distro/common/man/man1/knife-environment.1 +178 -0
  50. data/distro/common/man/man1/knife-exec.1 +46 -0
  51. data/distro/common/man/man1/knife-index.1 +29 -0
  52. data/distro/common/man/man1/knife-node.1 +134 -0
  53. data/distro/common/man/man1/knife-role.1 +88 -0
  54. data/distro/common/man/man1/knife-search.1 +280 -0
  55. data/distro/common/man/man1/knife-ssh.1 +83 -0
  56. data/distro/common/man/man1/knife-status.1 +29 -0
  57. data/distro/common/man/man1/knife-tag.1 +43 -0
  58. data/distro/common/man/man1/knife.1 +292 -0
  59. data/distro/common/man/man1/shef.1 +256 -0
  60. data/distro/common/man/man8/chef-client.8 +104 -0
  61. data/distro/common/man/man8/chef-expander.8 +97 -0
  62. data/distro/common/man/man8/chef-expanderctl.8 +62 -0
  63. data/distro/common/man/man8/chef-server-webui.8 +155 -0
  64. data/distro/common/man/man8/chef-server.8 +147 -0
  65. data/distro/common/man/man8/chef-solo.8 +158 -0
  66. data/distro/common/man/man8/chef-solr.8 +122 -0
  67. data/distro/common/markdown/README +3 -0
  68. data/distro/common/markdown/man1/knife-bootstrap.mkd +142 -0
  69. data/distro/common/markdown/man1/knife-client.mkd +103 -0
  70. data/distro/common/markdown/man1/knife-configure.mkd +70 -0
  71. data/distro/common/markdown/man1/knife-cookbook-site.mkd +123 -0
  72. data/distro/common/markdown/man1/knife-cookbook.mkd +263 -0
  73. data/distro/common/markdown/man1/knife-data-bag.mkd +117 -0
  74. data/distro/common/markdown/man1/knife-environment.mkd +151 -0
  75. data/distro/common/markdown/man1/knife-exec.mkd +37 -0
  76. data/distro/common/markdown/man1/knife-index.mkd +30 -0
  77. data/distro/common/markdown/man1/knife-node.mkd +130 -0
  78. data/distro/common/markdown/man1/knife-role.mkd +85 -0
  79. data/distro/common/markdown/man1/knife-search.mkd +180 -0
  80. data/distro/common/markdown/man1/knife-ssh.mkd +72 -0
  81. data/distro/common/markdown/man1/knife-status.mkd +36 -0
  82. data/distro/common/markdown/man1/knife-tag.mkd +39 -0
  83. data/distro/common/markdown/man1/knife.mkd +220 -0
  84. data/distro/common/markdown/man1/shef.mkd +189 -0
  85. data/distro/common/markdown/man8/chef-client.mkd +75 -0
  86. data/distro/common/markdown/man8/chef-expander.mkd +82 -0
  87. data/distro/common/markdown/man8/chef-expanderctl.mkd +58 -0
  88. data/distro/common/markdown/man8/chef-server-webui.mkd +121 -0
  89. data/distro/common/markdown/man8/chef-server.mkd +121 -0
  90. data/distro/common/markdown/man8/chef-solo.mkd +107 -0
  91. data/distro/common/markdown/man8/chef-solr.mkd +89 -0
  92. data/distro/debian/etc/default/chef-client +4 -0
  93. data/distro/debian/etc/default/chef-expander +8 -0
  94. data/distro/debian/etc/default/chef-server +9 -0
  95. data/distro/debian/etc/default/chef-server-webui +9 -0
  96. data/distro/debian/etc/default/chef-solr +8 -0
  97. data/distro/debian/etc/init.d/chef-client +185 -0
  98. data/distro/debian/etc/init.d/chef-expander +176 -0
  99. data/distro/debian/etc/init.d/chef-server +122 -0
  100. data/distro/debian/etc/init.d/chef-server-webui +123 -0
  101. data/distro/debian/etc/init.d/chef-solr +176 -0
  102. data/distro/debian/etc/init/chef-client.conf +17 -0
  103. data/distro/debian/etc/init/chef-expander.conf +17 -0
  104. data/distro/debian/etc/init/chef-server-webui.conf +17 -0
  105. data/distro/debian/etc/init/chef-server.conf +17 -0
  106. data/distro/debian/etc/init/chef-solr.conf +17 -0
  107. data/distro/redhat/etc/init.d/chef-client +110 -0
  108. data/distro/redhat/etc/init.d/chef-expander +104 -0
  109. data/distro/redhat/etc/init.d/chef-server +112 -0
  110. data/distro/redhat/etc/init.d/chef-server-webui +112 -0
  111. data/distro/redhat/etc/init.d/chef-solr +104 -0
  112. data/distro/redhat/etc/logrotate.d/chef-client +8 -0
  113. data/distro/redhat/etc/logrotate.d/chef-expander +8 -0
  114. data/distro/redhat/etc/logrotate.d/chef-server +8 -0
  115. data/distro/redhat/etc/logrotate.d/chef-server-webui +8 -0
  116. data/distro/redhat/etc/logrotate.d/chef-solr +8 -0
  117. data/distro/redhat/etc/sysconfig/chef-client +15 -0
  118. data/distro/redhat/etc/sysconfig/chef-expander +7 -0
  119. data/distro/redhat/etc/sysconfig/chef-server +14 -0
  120. data/distro/redhat/etc/sysconfig/chef-server-webui +14 -0
  121. data/distro/redhat/etc/sysconfig/chef-solr +8 -0
  122. data/lib/chef.rb +41 -0
  123. data/lib/chef/api_client.rb +271 -0
  124. data/lib/chef/application.rb +152 -0
  125. data/lib/chef/application/agent.rb +18 -0
  126. data/lib/chef/application/client.rb +285 -0
  127. data/lib/chef/application/knife.rb +188 -0
  128. data/lib/chef/application/solo.rb +218 -0
  129. data/lib/chef/applications.rb +4 -0
  130. data/lib/chef/certificate.rb +194 -0
  131. data/lib/chef/checksum.rb +167 -0
  132. data/lib/chef/checksum/storage.rb +18 -0
  133. data/lib/chef/checksum/storage/filesystem.rb +56 -0
  134. data/lib/chef/checksum_cache.rb +189 -0
  135. data/lib/chef/client.rb +366 -0
  136. data/lib/chef/config.rb +248 -0
  137. data/lib/chef/cookbook/chefignore.rb +66 -0
  138. data/lib/chef/cookbook/cookbook_collection.rb +45 -0
  139. data/lib/chef/cookbook/cookbook_version_loader.rb +173 -0
  140. data/lib/chef/cookbook/file_system_file_vendor.rb +56 -0
  141. data/lib/chef/cookbook/file_vendor.rb +48 -0
  142. data/lib/chef/cookbook/metadata.rb +629 -0
  143. data/lib/chef/cookbook/remote_file_vendor.rb +88 -0
  144. data/lib/chef/cookbook/syntax_check.rb +136 -0
  145. data/lib/chef/cookbook_loader.rb +121 -0
  146. data/lib/chef/cookbook_site_streaming_uploader.rb +244 -0
  147. data/lib/chef/cookbook_uploader.rb +154 -0
  148. data/lib/chef/cookbook_version.rb +1096 -0
  149. data/lib/chef/cookbook_version_selector.rb +168 -0
  150. data/lib/chef/couchdb.rb +246 -0
  151. data/lib/chef/daemon.rb +172 -0
  152. data/lib/chef/data_bag.rb +235 -0
  153. data/lib/chef/data_bag_item.rb +273 -0
  154. data/lib/chef/encrypted_data_bag_item.rb +139 -0
  155. data/lib/chef/environment.rb +455 -0
  156. data/lib/chef/exceptions.rb +154 -0
  157. data/lib/chef/file_access_control.rb +144 -0
  158. data/lib/chef/file_cache.rb +218 -0
  159. data/lib/chef/handler.rb +227 -0
  160. data/lib/chef/handler/error_report.rb +33 -0
  161. data/lib/chef/handler/json_file.rb +58 -0
  162. data/lib/chef/index_queue.rb +29 -0
  163. data/lib/chef/index_queue/amqp_client.rb +116 -0
  164. data/lib/chef/index_queue/consumer.rb +76 -0
  165. data/lib/chef/index_queue/indexable.rb +109 -0
  166. data/lib/chef/json_compat.rb +52 -0
  167. data/lib/chef/knife.rb +520 -0
  168. data/lib/chef/knife/bootstrap.rb +207 -0
  169. data/lib/chef/knife/bootstrap/archlinux-gems.erb +60 -0
  170. data/lib/chef/knife/bootstrap/centos5-gems.erb +56 -0
  171. data/lib/chef/knife/bootstrap/fedora13-gems.erb +43 -0
  172. data/lib/chef/knife/bootstrap/ubuntu10.04-apt.erb +49 -0
  173. data/lib/chef/knife/bootstrap/ubuntu10.04-gems.erb +50 -0
  174. data/lib/chef/knife/client_bulk_delete.rb +65 -0
  175. data/lib/chef/knife/client_create.rb +79 -0
  176. data/lib/chef/knife/client_delete.rb +46 -0
  177. data/lib/chef/knife/client_edit.rb +45 -0
  178. data/lib/chef/knife/client_list.rb +42 -0
  179. data/lib/chef/knife/client_reregister.rb +58 -0
  180. data/lib/chef/knife/client_show.rb +52 -0
  181. data/lib/chef/knife/configure.rb +149 -0
  182. data/lib/chef/knife/configure_client.rb +50 -0
  183. data/lib/chef/knife/cookbook_bulk_delete.rb +72 -0
  184. data/lib/chef/knife/cookbook_create.rb +274 -0
  185. data/lib/chef/knife/cookbook_delete.rb +151 -0
  186. data/lib/chef/knife/cookbook_download.rb +137 -0
  187. data/lib/chef/knife/cookbook_list.rb +47 -0
  188. data/lib/chef/knife/cookbook_metadata.rb +107 -0
  189. data/lib/chef/knife/cookbook_metadata_from_file.rb +44 -0
  190. data/lib/chef/knife/cookbook_show.rb +102 -0
  191. data/lib/chef/knife/cookbook_site_download.rb +70 -0
  192. data/lib/chef/knife/cookbook_site_install.rb +148 -0
  193. data/lib/chef/knife/cookbook_site_list.rb +62 -0
  194. data/lib/chef/knife/cookbook_site_search.rb +51 -0
  195. data/lib/chef/knife/cookbook_site_share.rb +114 -0
  196. data/lib/chef/knife/cookbook_site_show.rb +57 -0
  197. data/lib/chef/knife/cookbook_site_unshare.rb +56 -0
  198. data/lib/chef/knife/cookbook_site_vendor.rb +46 -0
  199. data/lib/chef/knife/cookbook_test.rb +93 -0
  200. data/lib/chef/knife/cookbook_upload.rb +240 -0
  201. data/lib/chef/knife/core/bootstrap_context.rb +100 -0
  202. data/lib/chef/knife/core/cookbook_scm_repo.rb +148 -0
  203. data/lib/chef/knife/core/generic_presenter.rb +191 -0
  204. data/lib/chef/knife/core/node_editor.rb +127 -0
  205. data/lib/chef/knife/core/node_presenter.rb +136 -0
  206. data/lib/chef/knife/core/object_loader.rb +75 -0
  207. data/lib/chef/knife/core/subcommand_loader.rb +112 -0
  208. data/lib/chef/knife/core/text_formatter.rb +100 -0
  209. data/lib/chef/knife/core/ui.rb +216 -0
  210. data/lib/chef/knife/data_bag_create.rb +93 -0
  211. data/lib/chef/knife/data_bag_delete.rb +51 -0
  212. data/lib/chef/knife/data_bag_edit.rb +94 -0
  213. data/lib/chef/knife/data_bag_from_file.rb +87 -0
  214. data/lib/chef/knife/data_bag_list.rb +46 -0
  215. data/lib/chef/knife/data_bag_show.rb +81 -0
  216. data/lib/chef/knife/environment_create.rb +53 -0
  217. data/lib/chef/knife/environment_delete.rb +45 -0
  218. data/lib/chef/knife/environment_edit.rb +45 -0
  219. data/lib/chef/knife/environment_from_file.rb +50 -0
  220. data/lib/chef/knife/environment_list.rb +42 -0
  221. data/lib/chef/knife/environment_show.rb +46 -0
  222. data/lib/chef/knife/exec.rb +51 -0
  223. data/lib/chef/knife/help.rb +103 -0
  224. data/lib/chef/knife/help_topics.rb +4 -0
  225. data/lib/chef/knife/index_rebuild.rb +50 -0
  226. data/lib/chef/knife/node_bulk_delete.rb +80 -0
  227. data/lib/chef/knife/node_create.rb +50 -0
  228. data/lib/chef/knife/node_delete.rb +47 -0
  229. data/lib/chef/knife/node_edit.rb +72 -0
  230. data/lib/chef/knife/node_from_file.rb +50 -0
  231. data/lib/chef/knife/node_list.rb +46 -0
  232. data/lib/chef/knife/node_run_list_add.rb +67 -0
  233. data/lib/chef/knife/node_run_list_remove.rb +48 -0
  234. data/lib/chef/knife/node_show.rb +73 -0
  235. data/lib/chef/knife/recipe_list.rb +32 -0
  236. data/lib/chef/knife/role_bulk_delete.rb +70 -0
  237. data/lib/chef/knife/role_create.rb +55 -0
  238. data/lib/chef/knife/role_delete.rb +47 -0
  239. data/lib/chef/knife/role_edit.rb +48 -0
  240. data/lib/chef/knife/role_from_file.rb +56 -0
  241. data/lib/chef/knife/role_list.rb +43 -0
  242. data/lib/chef/knife/role_show.rb +54 -0
  243. data/lib/chef/knife/search.rb +141 -0
  244. data/lib/chef/knife/ssh.rb +367 -0
  245. data/lib/chef/knife/status.rb +104 -0
  246. data/lib/chef/knife/tag_create.rb +52 -0
  247. data/lib/chef/knife/tag_delete.rb +60 -0
  248. data/lib/chef/knife/tag_list.rb +47 -0
  249. data/lib/chef/log.rb +39 -0
  250. data/lib/chef/mash.rb +211 -0
  251. data/lib/chef/mixin/check_helper.rb +31 -0
  252. data/lib/chef/mixin/checksum.rb +32 -0
  253. data/lib/chef/mixin/command.rb +163 -0
  254. data/lib/chef/mixin/command/unix.rb +215 -0
  255. data/lib/chef/mixin/command/windows.rb +76 -0
  256. data/lib/chef/mixin/convert_to_class_name.rb +63 -0
  257. data/lib/chef/mixin/create_path.rb +57 -0
  258. data/lib/chef/mixin/deep_merge.rb +225 -0
  259. data/lib/chef/mixin/deprecation.rb +65 -0
  260. data/lib/chef/mixin/from_file.rb +50 -0
  261. data/lib/chef/mixin/get_source_from_package.rb +42 -0
  262. data/lib/chef/mixin/language.rb +163 -0
  263. data/lib/chef/mixin/language_include_attribute.rb +61 -0
  264. data/lib/chef/mixin/language_include_recipe.rb +52 -0
  265. data/lib/chef/mixin/params_validate.rb +225 -0
  266. data/lib/chef/mixin/recipe_definition_dsl_core.rb +78 -0
  267. data/lib/chef/mixin/shell_out.rb +41 -0
  268. data/lib/chef/mixin/template.rb +95 -0
  269. data/lib/chef/mixin/xml_escape.rb +140 -0
  270. data/lib/chef/mixins.rb +15 -0
  271. data/lib/chef/monkey_patches/dir.rb +36 -0
  272. data/lib/chef/monkey_patches/numeric.rb +15 -0
  273. data/lib/chef/monkey_patches/object.rb +9 -0
  274. data/lib/chef/monkey_patches/regexp.rb +34 -0
  275. data/lib/chef/monkey_patches/string.rb +49 -0
  276. data/lib/chef/monkey_patches/tempfile.rb +64 -0
  277. data/lib/chef/nil_argument.rb +3 -0
  278. data/lib/chef/node.rb +677 -0
  279. data/lib/chef/node/attribute.rb +487 -0
  280. data/lib/chef/openid_registration.rb +187 -0
  281. data/lib/chef/platform.rb +434 -0
  282. data/lib/chef/provider.rb +124 -0
  283. data/lib/chef/provider/breakpoint.rb +36 -0
  284. data/lib/chef/provider/cookbook_file.rb +100 -0
  285. data/lib/chef/provider/cron.rb +186 -0
  286. data/lib/chef/provider/cron/solaris.rb +195 -0
  287. data/lib/chef/provider/deploy.rb +418 -0
  288. data/lib/chef/provider/deploy/revision.rb +80 -0
  289. data/lib/chef/provider/deploy/timestamped.rb +33 -0
  290. data/lib/chef/provider/directory.rb +72 -0
  291. data/lib/chef/provider/env.rb +152 -0
  292. data/lib/chef/provider/env/windows.rb +75 -0
  293. data/lib/chef/provider/erl_call.rb +101 -0
  294. data/lib/chef/provider/execute.rb +65 -0
  295. data/lib/chef/provider/file.rb +226 -0
  296. data/lib/chef/provider/git.rb +243 -0
  297. data/lib/chef/provider/group.rb +133 -0
  298. data/lib/chef/provider/group/aix.rb +70 -0
  299. data/lib/chef/provider/group/dscl.rb +121 -0
  300. data/lib/chef/provider/group/gpasswd.rb +53 -0
  301. data/lib/chef/provider/group/groupadd.rb +91 -0
  302. data/lib/chef/provider/group/pw.rb +84 -0
  303. data/lib/chef/provider/group/suse.rb +53 -0
  304. data/lib/chef/provider/group/usermod.rb +57 -0
  305. data/lib/chef/provider/group/windows.rb +79 -0
  306. data/lib/chef/provider/http_request.rb +122 -0
  307. data/lib/chef/provider/ifconfig.rb +195 -0
  308. data/lib/chef/provider/link.rb +164 -0
  309. data/lib/chef/provider/log.rb +54 -0
  310. data/lib/chef/provider/mdadm.rb +91 -0
  311. data/lib/chef/provider/mount.rb +114 -0
  312. data/lib/chef/provider/mount/mount.rb +240 -0
  313. data/lib/chef/provider/mount/windows.rb +81 -0
  314. data/lib/chef/provider/ohai.rb +42 -0
  315. data/lib/chef/provider/package.rb +200 -0
  316. data/lib/chef/provider/package/apt.rb +145 -0
  317. data/lib/chef/provider/package/dpkg.rb +115 -0
  318. data/lib/chef/provider/package/easy_install.rb +136 -0
  319. data/lib/chef/provider/package/freebsd.rb +125 -0
  320. data/lib/chef/provider/package/macports.rb +105 -0
  321. data/lib/chef/provider/package/pacman.rb +101 -0
  322. data/lib/chef/provider/package/portage.rb +135 -0
  323. data/lib/chef/provider/package/rpm.rb +104 -0
  324. data/lib/chef/provider/package/rubygems.rb +465 -0
  325. data/lib/chef/provider/package/solaris.rb +130 -0
  326. data/lib/chef/provider/package/yum-dump.py +286 -0
  327. data/lib/chef/provider/package/yum.rb +1173 -0
  328. data/lib/chef/provider/package/zypper.rb +144 -0
  329. data/lib/chef/provider/remote_directory.rb +137 -0
  330. data/lib/chef/provider/remote_file.rb +118 -0
  331. data/lib/chef/provider/route.rb +193 -0
  332. data/lib/chef/provider/ruby_block.rb +34 -0
  333. data/lib/chef/provider/script.rb +55 -0
  334. data/lib/chef/provider/service.rb +122 -0
  335. data/lib/chef/provider/service/arch.rb +116 -0
  336. data/lib/chef/provider/service/debian.rb +130 -0
  337. data/lib/chef/provider/service/freebsd.rb +154 -0
  338. data/lib/chef/provider/service/gentoo.rb +53 -0
  339. data/lib/chef/provider/service/init.rb +71 -0
  340. data/lib/chef/provider/service/insserv.rb +52 -0
  341. data/lib/chef/provider/service/invokercd.rb +35 -0
  342. data/lib/chef/provider/service/redhat.rb +60 -0
  343. data/lib/chef/provider/service/simple.rb +120 -0
  344. data/lib/chef/provider/service/solaris.rb +85 -0
  345. data/lib/chef/provider/service/systemd.rb +102 -0
  346. data/lib/chef/provider/service/upstart.rb +198 -0
  347. data/lib/chef/provider/service/windows.rb +155 -0
  348. data/lib/chef/provider/subversion.rb +197 -0
  349. data/lib/chef/provider/template.rb +104 -0
  350. data/lib/chef/provider/user.rb +186 -0
  351. data/lib/chef/provider/user/dscl.rb +280 -0
  352. data/lib/chef/provider/user/pw.rb +113 -0
  353. data/lib/chef/provider/user/useradd.rb +137 -0
  354. data/lib/chef/provider/user/windows.rb +124 -0
  355. data/lib/chef/providers.rb +95 -0
  356. data/lib/chef/recipe.rb +129 -0
  357. data/lib/chef/resource.rb +609 -0
  358. data/lib/chef/resource/apt_package.rb +34 -0
  359. data/lib/chef/resource/bash.rb +33 -0
  360. data/lib/chef/resource/breakpoint.rb +35 -0
  361. data/lib/chef/resource/conditional.rb +90 -0
  362. data/lib/chef/resource/cookbook_file.rb +45 -0
  363. data/lib/chef/resource/cron.rb +188 -0
  364. data/lib/chef/resource/csh.rb +33 -0
  365. data/lib/chef/resource/deploy.rb +389 -0
  366. data/lib/chef/resource/deploy_revision.rb +40 -0
  367. data/lib/chef/resource/directory.rb +76 -0
  368. data/lib/chef/resource/dpkg_package.rb +34 -0
  369. data/lib/chef/resource/easy_install_package.rb +57 -0
  370. data/lib/chef/resource/env.rb +58 -0
  371. data/lib/chef/resource/erl_call.rb +83 -0
  372. data/lib/chef/resource/execute.rb +127 -0
  373. data/lib/chef/resource/file.rb +99 -0
  374. data/lib/chef/resource/freebsd_package.rb +35 -0
  375. data/lib/chef/resource/gem_package.rb +53 -0
  376. data/lib/chef/resource/git.rb +46 -0
  377. data/lib/chef/resource/group.rb +78 -0
  378. data/lib/chef/resource/http_request.rb +61 -0
  379. data/lib/chef/resource/ifconfig.rb +144 -0
  380. data/lib/chef/resource/link.rb +78 -0
  381. data/lib/chef/resource/log.rb +62 -0
  382. data/lib/chef/resource/macports_package.rb +29 -0
  383. data/lib/chef/resource/mdadm.rb +82 -0
  384. data/lib/chef/resource/mount.rb +134 -0
  385. data/lib/chef/resource/ohai.rb +40 -0
  386. data/lib/chef/resource/package.rb +80 -0
  387. data/lib/chef/resource/pacman_package.rb +33 -0
  388. data/lib/chef/resource/perl.rb +33 -0
  389. data/lib/chef/resource/portage_package.rb +33 -0
  390. data/lib/chef/resource/python.rb +33 -0
  391. data/lib/chef/resource/remote_directory.rb +109 -0
  392. data/lib/chef/resource/remote_file.rb +83 -0
  393. data/lib/chef/resource/route.rb +135 -0
  394. data/lib/chef/resource/rpm_package.rb +34 -0
  395. data/lib/chef/resource/ruby.rb +33 -0
  396. data/lib/chef/resource/ruby_block.rb +40 -0
  397. data/lib/chef/resource/scm.rb +147 -0
  398. data/lib/chef/resource/script.rb +60 -0
  399. data/lib/chef/resource/service.rb +151 -0
  400. data/lib/chef/resource/solaris_package.rb +36 -0
  401. data/lib/chef/resource/subversion.rb +36 -0
  402. data/lib/chef/resource/template.rb +69 -0
  403. data/lib/chef/resource/timestamped_deploy.rb +31 -0
  404. data/lib/chef/resource/user.rb +130 -0
  405. data/lib/chef/resource/yum_package.rb +63 -0
  406. data/lib/chef/resource_collection.rb +217 -0
  407. data/lib/chef/resource_collection/stepable_iterator.rb +124 -0
  408. data/lib/chef/resource_definition.rb +67 -0
  409. data/lib/chef/resource_definition_list.rb +38 -0
  410. data/lib/chef/resources.rb +64 -0
  411. data/lib/chef/rest.rb +400 -0
  412. data/lib/chef/rest/auth_credentials.rb +71 -0
  413. data/lib/chef/rest/cookie_jar.rb +31 -0
  414. data/lib/chef/rest/rest_request.rb +213 -0
  415. data/lib/chef/role.rb +343 -0
  416. data/lib/chef/run_context.rb +126 -0
  417. data/lib/chef/run_list.rb +165 -0
  418. data/lib/chef/run_list/run_list_expansion.rb +193 -0
  419. data/lib/chef/run_list/run_list_item.rb +92 -0
  420. data/lib/chef/run_list/versioned_recipe_list.rb +68 -0
  421. data/lib/chef/run_status.rb +121 -0
  422. data/lib/chef/runner.rb +105 -0
  423. data/lib/chef/sandbox.rb +153 -0
  424. data/lib/chef/search/query.rb +65 -0
  425. data/lib/chef/shef.rb +327 -0
  426. data/lib/chef/shef/ext.rb +569 -0
  427. data/lib/chef/shef/model_wrapper.rb +120 -0
  428. data/lib/chef/shef/shef_rest.rb +28 -0
  429. data/lib/chef/shef/shef_session.rb +285 -0
  430. data/lib/chef/shell_out.rb +249 -0
  431. data/lib/chef/shell_out/unix.rb +223 -0
  432. data/lib/chef/shell_out/windows.rb +588 -0
  433. data/lib/chef/solr_query.rb +187 -0
  434. data/lib/chef/solr_query/lucene.treetop +150 -0
  435. data/lib/chef/solr_query/lucene_nodes.rb +285 -0
  436. data/lib/chef/solr_query/query_transform.rb +65 -0
  437. data/lib/chef/solr_query/solr_http_request.rb +132 -0
  438. data/lib/chef/streaming_cookbook_uploader.rb +201 -0
  439. data/lib/chef/tasks/chef_repo.rake +334 -0
  440. data/lib/chef/util/file_edit.rb +122 -0
  441. data/lib/chef/util/windows.rb +56 -0
  442. data/lib/chef/util/windows/net_group.rb +101 -0
  443. data/lib/chef/util/windows/net_use.rb +121 -0
  444. data/lib/chef/util/windows/net_user.rb +198 -0
  445. data/lib/chef/util/windows/volume.rb +59 -0
  446. data/lib/chef/version.rb +23 -0
  447. data/lib/chef/version_class.rb +70 -0
  448. data/lib/chef/version_constraint.rb +116 -0
  449. data/lib/chef/webui_user.rb +231 -0
  450. metadata +764 -0
@@ -0,0 +1,158 @@
1
+ .\" generated with Ronn/v0.7.3
2
+ .\" http://github.com/rtomayko/ronn/tree/0.7.3
3
+ .
4
+ .TH "CHEF\-SOLO" "8" "December 2011" "Chef 0.10.8" "Chef Manual"
5
+ .
6
+ .SH "NAME"
7
+ \fBchef\-solo\fR \- Runs chef in solo mode against a specified cookbook location\.
8
+ .
9
+ .SH "SYNOPSIS"
10
+ \fBchef\-solo\fR \fI(options)\fR
11
+ .
12
+ .TP
13
+ \fB\-c\fR, \fB\-\-config CONFIG\fR
14
+ The configuration file to use
15
+ .
16
+ .TP
17
+ \fB\-d\fR, \fB\-\-daemonize\fR
18
+ Daemonize the process
19
+ .
20
+ .TP
21
+ \fB\-g\fR, \fB\-\-group GROUP\fR
22
+ Group to set privilege to
23
+ .
24
+ .TP
25
+ \fB\-i\fR, \fB\-\-interval SECONDS\fR
26
+ Run chef\-client periodically, in seconds
27
+ .
28
+ .TP
29
+ \fB\-j\fR, \fB\-\-json\-attributes JSON_ATTRIBS\fR
30
+ Load attributes from a JSON file or URL
31
+ .
32
+ .TP
33
+ \fB\-l\fR, \fB\-\-log_level LEVEL\fR
34
+ Set the log level (debug, info, warn, error, fatal)
35
+ .
36
+ .TP
37
+ \fB\-L\fR, \fB\-\-logfile LOGLOCATION\fR
38
+ Set the log file location, defaults to STDOUT \- recommended for daemonizing
39
+ .
40
+ .TP
41
+ \fB\-N\fR, \fB\-\-node\-name NODE_NAME\fR
42
+ The node name for this client
43
+ .
44
+ .TP
45
+ \fB\-r\fR, \fB\-\-recipe\-url RECIPE_URL\fR
46
+ Pull down a remote gzipped tarball of recipes and untar it to the cookbook cache\.
47
+ .
48
+ .TP
49
+ \fB\-s\fR, \fB\-\-splay SECONDS\fR
50
+ The splay time for running at intervals, in seconds
51
+ .
52
+ .TP
53
+ \fB\-u\fR, \fB\-\-user USER\fR
54
+ User to set privilege to
55
+ .
56
+ .TP
57
+ \fB\-v\fR, \fB\-\-version\fR
58
+ Show chef version
59
+ .
60
+ .TP
61
+ \fB\-h\fR, \fB\-\-help\fR
62
+ Show this message
63
+ .
64
+ .SH "DESCRIPTION"
65
+ Chef Solo allows you to run Chef Cookbooks in the absence of a Chef Server\. To do this, the complete cookbook needs to be present on disk\.
66
+ .
67
+ .P
68
+ By default Chef Solo will look in /etc/chef/solo\.rb for its configuration\. This configuration file has two required variables: file_cache_path and cookbook_path\.
69
+ .
70
+ .P
71
+ For example:
72
+ .
73
+ .IP "" 4
74
+ .
75
+ .nf
76
+
77
+ file_cache_path "/var/chef\-solo"
78
+ cookbook_path "/var/chef\-solo/cookbooks"
79
+ .
80
+ .fi
81
+ .
82
+ .IP "" 0
83
+ .
84
+ .P
85
+ For your own systems, you can change this to reflect any directory you like, but you\'ll need to specify absolute paths and the cookbook_path directory should be a subdirectory of the file_cache_path\.
86
+ .
87
+ .P
88
+ You can also specify cookbook_path as an array, passing multiple locations to search for cookbooks\.
89
+ .
90
+ .P
91
+ For example:
92
+ .
93
+ .IP "" 4
94
+ .
95
+ .nf
96
+
97
+ file_cache_path "/var/chef\-solo"
98
+ cookbook_path ["/var/chef\-solo/cookbooks", "/var/chef\-solo/site\-cookbooks"]
99
+ .
100
+ .fi
101
+ .
102
+ .IP "" 0
103
+ .
104
+ .P
105
+ Note that earlier entries are now overridden by later ones\.
106
+ .
107
+ .P
108
+ Since chef\-solo doesn\'t have any interaction with a Chef Server, you\'ll need to specify node\-specifc attributes in a JSON file\. This can be located on the target system itself, or it can be stored on a remote server such as S3, or a web server on your network\.
109
+ .
110
+ .P
111
+ Within the JSON file, you\'ll also specify the recipes that Chef should run in the "run_list"\. An example JSON file, which sets a resolv\.conf:
112
+ .
113
+ .IP "" 4
114
+ .
115
+ .nf
116
+
117
+ {
118
+ "resolver": {
119
+ "nameservers": [ "10\.0\.0\.1" ],
120
+ "search":"int\.example\.com"
121
+ },
122
+ "run_list": [ "recipe[resolver]" ]
123
+ }
124
+ .
125
+ .fi
126
+ .
127
+ .IP "" 0
128
+ .
129
+ .P
130
+ Then you can run chef\-solo with \-j to specify the JSON file\. It will look for cookbooks in the cookbook_path configured in the configuration file, and apply attributes and use the run_list from the JSON file specified\.
131
+ .
132
+ .P
133
+ You can use \-c to specify the path to the configuration file (if you don\'t want chef\-solo to use the default)\. You can also specify \-r for a cookbook tarball\.
134
+ .
135
+ .P
136
+ For example:
137
+ .
138
+ .IP "" 4
139
+ .
140
+ .nf
141
+
142
+ chef\-solo \-c ~/solo\.rb \-j ~/node\.json \-r http://www\.example\.com/chef\-solo\.tar\.gz
143
+ .
144
+ .fi
145
+ .
146
+ .IP "" 0
147
+ .
148
+ .P
149
+ In the above case, chef\-solo would extract the tarball to your specified cookbook_path, use ~/solo\.rb as the configuration file, and apply attributes and use the run_list from ~/node\.json\.
150
+ .
151
+ .SH "SEE ALSO"
152
+ Full documentation for Chef and chef\-solo is located on the Chef wiki, http://wiki\.opscode\.com/display/chef/Home\.
153
+ .
154
+ .SH "AUTHOR"
155
+ Chef was written by Adam Jacob \fIadam@ospcode\.com\fR of Opscode (http://www\.opscode\.com), with contributions from the community\. This manual page was written by Joshua Timberman \fIjoshua@opscode\.com\fR with help2man\. Permission is granted to copy, distribute and / or modify this document under the terms of the Apache 2\.0 License\.
156
+ .
157
+ .P
158
+ On Debian systems, the complete text of the Apache 2\.0 License can be found in /usr/share/common\-licenses/Apache\-2\.0\.
@@ -0,0 +1,122 @@
1
+ .\" generated with Ronn/v0.7.3
2
+ .\" http://github.com/rtomayko/ronn/tree/0.7.3
3
+ .
4
+ .TH "CHEF\-SOLR" "8" "December 2011" "Chef 0.10.8" "Chef Manual"
5
+ .
6
+ .SH "NAME"
7
+ \fBchef\-solr\fR \- Runs as Chef\'s search server
8
+ .
9
+ .SH "SYNOPSIS"
10
+ \fBchef\-solr\fR \fI(options)\fR
11
+ .
12
+ .TP
13
+ \fB\-c\fR, \fB\-\-config CONFIG\fR
14
+ The configuration file to use
15
+ .
16
+ .TP
17
+ \fB\-d\fR, \fB\-\-daemonize\fR
18
+ Daemonize the process
19
+ .
20
+ .TP
21
+ \fB\-g\fR, \fB\-\-group GROUP\fR
22
+ Group to set privilege to
23
+ .
24
+ .TP
25
+ \fB\-l\fR, \fB\-\-log_level LEVEL\fR
26
+ Set the log level (debug, info, warn, error, fatal)
27
+ .
28
+ .TP
29
+ \fB\-L\fR, \fB\-\-logfile LOGLOCATION\fR
30
+ Set the log file location, defaults to STDOUT \- recommended for daemonizing
31
+ .
32
+ .TP
33
+ \fB\-P\fR, \fB\-\-pid PIDFILE\fR
34
+ Set the PID file location, defaults to /tmp/chef\-solr\.pid
35
+ .
36
+ .TP
37
+ \fB\-D\fR, \fB\-\-solr\-data\-dir PATH\fR
38
+ Where the Solr data lives
39
+ .
40
+ .TP
41
+ \fB\-x\fR, \fB\-\-solor\-heap\-size SIZE\fR
42
+ Set the size of the Java Heap
43
+ .
44
+ .TP
45
+ \fB\-H\fR, \fB\-\-solr\-home\-dir PATH\fR
46
+ Solr home directory
47
+ .
48
+ .TP
49
+ \fB\-j\fR, \fB\-\-java\-opts OPTS\fR
50
+ Raw options passed to Java
51
+ .
52
+ .TP
53
+ \fB\-x\fR, \fB\-\-solor\-heap\-size\fR
54
+ Set the size of the Java Heap
55
+ .
56
+ .TP
57
+ \fB\-W\fR, \fB\-\-solr\-jetty\-dir PATH\fR
58
+ Where to place the Solr Jetty instance
59
+ .
60
+ .TP
61
+ \fB\-u\fR, \fB\-\-user USER\fR
62
+ User to set privilege to
63
+ .
64
+ .TP
65
+ \fB\-v\fR, \fB\-\-version\fR
66
+ Show chef\-solr version
67
+ .
68
+ .TP
69
+ \fB\-h\fR, \fB\-\-help\fR
70
+ Show this message
71
+ .
72
+ .SH "DESCRIPTION"
73
+ Chef\-solr provides search service for Chef\. You need to have both chef\-solr and chef\-expander\-cluster running in order for search to work\.
74
+ .
75
+ .P
76
+ \fBInstallation\fR
77
+ .
78
+ .P
79
+ Make sure you backed up your data if you are upgrading from a previous version\. Run chef\-solr\-installer to upgrade your Chef Solr installation\. Answer "yes" when prompted for confirmation\. The process should look like this:
80
+ .
81
+ .IP "" 4
82
+ .
83
+ .nf
84
+
85
+ yourshell> chef\-solr\-installer
86
+ Configuration setting solr_heap_size is unknown and will be ignored
87
+
88
+ Chef Solr is already installed in /var/chef/solr
89
+ Do you want to overwrite the current install? All existing Solr data will be lost\. [y/n] y
90
+ Removing the existing Chef Solr installation
91
+ rm \-rf /var/chef/solr
92
+ rm \-rf /var/chef/solr\-jetty
93
+ rm \-rf /var/chef/solr/data
94
+ Creating Solr Home Directory
95
+ mkdir \-p /var/chef/solr
96
+ entering /var/chef/solr
97
+ tar zxvf /Users/ddeleo/opscode/chef/chef\-solr/solr/solr\-home\.tar\.gz
98
+ Creating Solr Data Directory
99
+ mkdir \-p /var/chef/solr/data
100
+ Unpacking Solr Jetty
101
+ mkdir \-p /var/chef/solr\-jetty
102
+ entering /var/chef/solr\-jetty
103
+ tar zxvf /Users/ddeleo/opscode/chef/chef\-solr/solr/solr\-jetty\.tar\.gz
104
+
105
+ Successfully installed Chef Solr\.
106
+ You can restore your search index using `knife index rebuild`
107
+ .
108
+ .fi
109
+ .
110
+ .IP "" 0
111
+ .
112
+ .SH "SEE ALSO"
113
+ \fBchef\-expander\-cluster\fR(8)
114
+ .
115
+ .P
116
+ Full documentation for Chef and chef\-server is located on the Chef wiki, http://wiki\.opscode\.com/display/chef/Home\.
117
+ .
118
+ .SH "AUTHOR"
119
+ Chef was written by Adam Jacob \fIadam@ospcode\.com\fR of Opscode (http://www\.opscode\.com), with contributions from the community\. This manual page was written by Joshua Timberman \fIjoshua@opscode\.com\fR with help2man\. Permission is granted to copy, distribute and / or modify this document under the terms of the Apache 2\.0 License\.
120
+ .
121
+ .P
122
+ On Debian systems, the complete text of the Apache 2\.0 License can be found in /usr/share/common\-licenses/Apache\-2\.0\.
@@ -0,0 +1,3 @@
1
+ This directory contains markdown documentation that is used in other places.
2
+ For example, markdown (.mkd) documents that are generated as man pages
3
+ with ronn.
@@ -0,0 +1,142 @@
1
+ knife-bootstrap(1) -- Install Chef Client on a remote host
2
+ ========================================
3
+
4
+ ## SYNOPSIS
5
+
6
+ __knife__ __bootstrap__ _(options)_
7
+
8
+ * `-i`, `--identity-file IDENTITY_FILE`:
9
+ The SSH identity file used for authentication
10
+ * `-N`, `--node-name NAME`:
11
+ The Chef node name for your new node
12
+ * `-P`, `--ssh-password PASSWORD`:
13
+ The ssh password
14
+ * `-x`, `--ssh-user USERNAME`:
15
+ The ssh username
16
+ * `-p`, `--ssh-port PORT`:
17
+ The ssh port
18
+ * `--bootstrap-version VERSION`:
19
+ The version of Chef to install
20
+ * `--bootstrap-proxy PROXY_URL`:
21
+ `The proxy server for the node being bootstrapped`
22
+ * `--prerelease`:
23
+ Install pre-release Chef gems
24
+ * `-r`, `--run-list RUN_LIST`:
25
+ Comma separated list of roles/recipes to apply
26
+ * `--template-file TEMPLATE`:
27
+ Full path to location of template to use
28
+ * `--sudo`:
29
+ Execute the bootstrap via sudo
30
+ * `-d`, `--distro DISTRO`:
31
+ Bootstrap a distro using a template
32
+ * `--no-host-key-verify`:
33
+ Disable host key verification
34
+
35
+ ## DESCRIPTION
36
+
37
+ Performs a Chef Bootstrap on the target node. The goal of the bootstrap
38
+ is to get Chef installed on the target system so it can run Chef Client
39
+ with a Chef Server. The main assumption is a baseline OS installation
40
+ exists. This sub-command is used internally by some cloud computing
41
+ plugins.
42
+
43
+ The bootstrap sub-command supports supplying a template to perform the
44
+ bootstrap steps. If the distro is not specified (via `-d` or `--distro`
45
+ option), an Ubuntu 10.04 host bootstrapped with RubyGems is assumed. The
46
+ __DISTRO__ value corresponds to the base filename of the template, in
47
+ other words `DISTRO`.erb. A template file can be specified with the
48
+ `--template-file` option in which case the __DISTRO__ is not used. The
49
+ sub-command looks in the following locations for the template to use:
50
+
51
+ * `bootstrap` directory in the installed Chef Knife library.
52
+ * `bootstrap` directory in the `$PWD/.chef`.
53
+ * `bootstrap` directory in the users `$HOME/.chef`.
54
+
55
+ The default bootstrap templates are scripts that get copied to the
56
+ target node (FQDN). The following distros are supported:
57
+
58
+ * centos5-gems
59
+ * fedora13-gems
60
+ * ubuntu10.04-gems
61
+ * ubuntu10.04-apt
62
+
63
+ The gems installations will use RubyGems 1.3.6 and Chef installed as a
64
+ gem. The apt installation will use the Opscode APT repository. The
65
+ RubyGems installation requires installing gems with native extensions,
66
+ so development related packages (ruby-dev, build-essential) are
67
+ installed. These are not installed with the apt installation, as native
68
+ extensions are already compiled in the required packages.
69
+
70
+ In addition to handling the software installation, these bootstrap
71
+ templates do the following:
72
+
73
+ - Write the validation.pem per the local knife configuration.
74
+ - Write a default config file for Chef (`/etc/chef/client.rb`) using values from the `knife.rb`.
75
+ - Create a JSON attributes file containing the specified run list and run Chef.
76
+
77
+ In the case of the RubyGems, the `client.rb` will be written from
78
+ scratch with a minimal set of values; see __EXAMPLES__. In the case of
79
+ APT Package installation, `client.rb` will have the
80
+ `validation_client_name` appended if it is not set to `chef-validator`
81
+ (default config value), and the `node_name` will be added if
82
+ `chef_node_name` option is specified.
83
+
84
+ When this is complete, the bootstrapped node will have:
85
+
86
+ - Latest Chef version installed from RubyGems or APT Packages from Opscode. This may be a later version than the local system.
87
+ - Be validated with the configured Chef Server.
88
+ - Have run Chef with its default run list if one is specfied.
89
+
90
+ Additional custom bootstrap templates can be created and stored in
91
+ `.chef/bootstrap/DISTRO.erb`, replacing __DISTRO__ with the value passed
92
+ with the `-d` or `--distro` option. See __EXAMPLES__ for more
93
+ information.
94
+
95
+ ## EXAMPLES
96
+ Setting up a custom bootstrap is fairly straightforward. Create a
97
+ `.chef/bootstrap` directory in your Chef Repository or in
98
+ `$HOME/.chef/bootstrap`. Then create the ERB template file.
99
+
100
+ mkdir ~/.chef/bootstrap
101
+ vi ~/.chef/bootstrap/debian5.0-apt.erb
102
+
103
+ For example, to create a new bootstrap template that should be used when
104
+ setting up a new Debian node. Edit the template to run the commands, set
105
+ up the validation certificate and the client configuration file, and
106
+ finally to run chef-client on completion. The bootstrap template can be
107
+ called with:
108
+
109
+ knife bootstrap mynode.example.com --template-file ~/.chef/bootstrap/debian5.0-apt.erb
110
+
111
+ Or,
112
+
113
+ knife bootstrap mynode.example.com --distro debian5.0-apt
114
+
115
+ The `--distro` parameter will automatically look in the
116
+ `~/.chef/bootstrap` directory for a file named `debian5.0-apt.erb`.
117
+
118
+ Templates provided by the Chef installation are located in
119
+ `BASEDIR/lib/chef/knife/bootstrap/*.erb`, where _BASEDIR_ is the
120
+ location where the package or Gem installed the Chef client libraries.
121
+
122
+ ## BUGS
123
+ `knife bootstrap` is not capable of bootstrapping multiple hosts in
124
+ parallel.
125
+
126
+ The bootstrap script is passed as an argument to sh(1) on the remote
127
+ system, so sensitive information contained in the script will be visible
128
+ to other users via the process list using tools such as ps(1).
129
+
130
+ ## SEE ALSO
131
+ __knife-ssh__(1)
132
+
133
+ ## AUTHOR
134
+ Chef was written by Adam Jacob <adam@opscode.com> with many contributions from the community.
135
+
136
+ ## DOCUMENTATION
137
+ This manual page was written by Joshua Timberman <joshua@opscode.com>.
138
+ Permission is granted to copy, distribute and / or modify this document under the terms of the Apache 2.0 License.
139
+
140
+
141
+ ## CHEF
142
+ Knife is distributed with Chef. <http://wiki.opscode.com/display/chef/Home>
@@ -0,0 +1,103 @@
1
+ knife-client(1) -- Manage Chef API Clients
2
+ ========================================
3
+
4
+ ## SYNOPSIS
5
+
6
+ __knife__ __client__ _sub-command_ _(options)_
7
+
8
+ ## SUB-COMMANDS
9
+ Client subcommands follow a basic create, read, update, delete (CRUD)
10
+ pattern. The Following subcommands are available:
11
+
12
+ ## BULK DELETE
13
+ __knife client bulk delete__ _regex_ _(options)_
14
+
15
+ Delete clients where the client name matches the regular expression
16
+ _regex_ on the Chef Server. The regular expression should be given as a
17
+ quoted string, and not surrounded by forward slashes.
18
+
19
+ ## CREATE
20
+ __knife client create__ _client name_ _(options)_
21
+
22
+ * `-a`, `--admin `:
23
+ Create the client as an admin
24
+ * `-f`, `--file FILE`:
25
+ Write the key to a file
26
+
27
+ Create a new client. This generates an RSA keypair. The private key will
28
+ be displayed on _STDOUT_ or written to the named file. The public half
29
+ will be stored on the Server. For _chef-client_ systems, the private key
30
+ should be copied to the system as `/etc/chef/client.pem`.
31
+
32
+ Admin clients should be created for users that will use _knife_ to
33
+ access the API as an administrator. The private key will generally be
34
+ copied to `~/.chef/client\_name.pem` and referenced in the `knife.rb`
35
+ configuration file.
36
+
37
+ ## DELETE
38
+ __knife client delete__ _client name_ _(options)_
39
+
40
+ Deletes a registered client.
41
+
42
+ ## EDIT
43
+ __client edit__ _client name_ _(options)_
44
+
45
+ Edit a registered client.
46
+
47
+ ## LIST
48
+ __client list__ _(options)_
49
+
50
+ * `-w`, `--with-uri`:
51
+ Show corresponding URIs
52
+
53
+ List all registered clients.
54
+
55
+ ## REREGISTER
56
+ __client reregister__ _client name_ _(options)_
57
+
58
+ * `-f`, `--file FILE`:
59
+ Write the key to a file
60
+
61
+ Regenerate the RSA keypair for a client. The public half will be stored
62
+ on the server and the private key displayed on _STDOUT_ or written to
63
+ the named file. This operation will invalidate the previous keypair used
64
+ by the client, preventing it from authenticating with the Chef Server.
65
+ Use care when reregistering the validator client.
66
+
67
+ ## SHOW
68
+ __client show__ _client name_ _(options)_
69
+
70
+ * `-a`, `--attribute ATTR`:
71
+ Show only one attribute
72
+
73
+ Show a client. Output format is determined by the --format option.
74
+
75
+ ## DESCRIPTION
76
+ Clients are identities used for communication with the Chef Server API,
77
+ roughly equivalent to user accounts on the Chef Server, except that
78
+ clients only communicate with the Chef Server API and are authenticated
79
+ via request signatures.
80
+
81
+ In the typical case, there will be one client object on the server for
82
+ each node, and the corresponding client and node will have identical
83
+ names.
84
+
85
+ In the Chef authorization model, there is one special client, the
86
+ "validator", which is authorized to create new non-administrative
87
+ clients but has minimal privileges otherwise. This identity is used as a
88
+ sort of "guest account" to create a client identity when initially
89
+ setting up a host for management with Chef.
90
+
91
+ ## SEE ALSO
92
+ __knife-node__(1)
93
+
94
+ ## AUTHOR
95
+ Chef was written by Adam Jacob <adam@opscode.com> with many contributions from the community.
96
+
97
+ ## DOCUMENTATION
98
+ This manual page was written by Joshua Timberman <joshua@opscode.com>.
99
+ Permission is granted to copy, distribute and / or modify this document under the terms of the Apache 2.0 License.
100
+
101
+ ## CHEF
102
+ Knife is distributed with Chef. <http://wiki.opscode.com/display/chef/Home>
103
+