fairchild-poolparty 1.1.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (519) hide show
  1. data/History.txt +35 -0
  2. data/License.txt +20 -0
  3. data/PostInstall.txt +19 -0
  4. data/README.txt +77 -0
  5. data/Rakefile +45 -0
  6. data/VERSION.yml +4 -0
  7. data/bin/cloud +32 -0
  8. data/bin/cloud-bootstrap +21 -0
  9. data/bin/cloud-configure +28 -0
  10. data/bin/cloud-console +12 -0
  11. data/bin/cloud-contract +17 -0
  12. data/bin/cloud-expand +19 -0
  13. data/bin/cloud-handle-load +27 -0
  14. data/bin/cloud-list +23 -0
  15. data/bin/cloud-osxcopy +17 -0
  16. data/bin/cloud-provision +30 -0
  17. data/bin/cloud-rsync +28 -0
  18. data/bin/cloud-run +18 -0
  19. data/bin/cloud-setup-dev +25 -0
  20. data/bin/cloud-show +27 -0
  21. data/bin/cloud-spec +41 -0
  22. data/bin/cloud-ssh +23 -0
  23. data/bin/cloud-start +28 -0
  24. data/bin/cloud-stats +17 -0
  25. data/bin/cloud-terminate +20 -0
  26. data/bin/ec2-list-active +24 -0
  27. data/bin/messenger-get-current-nodes +14 -0
  28. data/bin/pool +31 -0
  29. data/bin/pool-describe +8 -0
  30. data/bin/pool-generate +18 -0
  31. data/bin/pool-init +28 -0
  32. data/bin/pool-list +30 -0
  33. data/bin/pool-start +26 -0
  34. data/bin/server-become-master +24 -0
  35. data/bin/server-build-messenger +28 -0
  36. data/bin/server-butterfly +25 -0
  37. data/bin/server-clean-cert-for +15 -0
  38. data/bin/server-cloud-elections +26 -0
  39. data/bin/server-ensure-provisioning +38 -0
  40. data/bin/server-fire-cmd +14 -0
  41. data/bin/server-get-load +15 -0
  42. data/bin/server-list-active +26 -0
  43. data/bin/server-list-instances +15 -0
  44. data/bin/server-manage-election +67 -0
  45. data/bin/server-monitor.ru +25 -0
  46. data/bin/server-provision +32 -0
  47. data/bin/server-query-agent +15 -0
  48. data/bin/server-rerun +23 -0
  49. data/bin/server-send-command +18 -0
  50. data/bin/server-show-stats +17 -0
  51. data/bin/server-start-agent +15 -0
  52. data/bin/server-start-client +29 -0
  53. data/bin/server-start-master +26 -0
  54. data/bin/server-start-node +32 -0
  55. data/bin/server-stop-client +3 -0
  56. data/bin/server-stop-master +3 -0
  57. data/bin/server-stop-node +3 -0
  58. data/bin/server-update-hosts +49 -0
  59. data/bin/server-write-new-nodes +26 -0
  60. data/config/jeweler.rb +43 -0
  61. data/config/requirements.rb +7 -0
  62. data/examples/basic.rb +23 -0
  63. data/examples/deploy.rb +5 -0
  64. data/examples/fairchild.rb +32 -0
  65. data/examples/fairchild_chef.rb +19 -0
  66. data/examples/paparazzi.conf.erb +21 -0
  67. data/examples/plugin_without_plugin_directory.rb +12 -0
  68. data/examples/poolparty.rb +12 -0
  69. data/generators/poolspec/USAGE +5 -0
  70. data/generators/poolspec/poolspec_generator.rb +58 -0
  71. data/generators/poolspec/templates/pool_spec_template.erb +9 -0
  72. data/lib/erlang/messenger/Emakefile +1 -0
  73. data/lib/erlang/messenger/Makefile +15 -0
  74. data/lib/erlang/messenger/README +5 -0
  75. data/lib/erlang/messenger/Rakefile +72 -0
  76. data/lib/erlang/messenger/control +11 -0
  77. data/lib/erlang/messenger/ebin/client.app +19 -0
  78. data/lib/erlang/messenger/ebin/master.app +19 -0
  79. data/lib/erlang/messenger/ebin/node.app +19 -0
  80. data/lib/erlang/messenger/ebin/packager.app +19 -0
  81. data/lib/erlang/messenger/ebin/pm_client_rel-0.1.rel +1 -0
  82. data/lib/erlang/messenger/ebin/pm_master_rel-0.1.rel +1 -0
  83. data/lib/erlang/messenger/ebin/pm_node_rel-0.1.rel +1 -0
  84. data/lib/erlang/messenger/include/defines.hrl +27 -0
  85. data/lib/erlang/messenger/lib/eunit/AUTHORS +2 -0
  86. data/lib/erlang/messenger/lib/eunit/CHANGELOG +14 -0
  87. data/lib/erlang/messenger/lib/eunit/COPYING +504 -0
  88. data/lib/erlang/messenger/lib/eunit/Makefile +28 -0
  89. data/lib/erlang/messenger/lib/eunit/NOTES +276 -0
  90. data/lib/erlang/messenger/lib/eunit/README +3 -0
  91. data/lib/erlang/messenger/lib/eunit/doc/edoc-info +3 -0
  92. data/lib/erlang/messenger/lib/eunit/doc/erlang.png +0 -0
  93. data/lib/erlang/messenger/lib/eunit/doc/eunit.html +172 -0
  94. data/lib/erlang/messenger/lib/eunit/doc/index.html +17 -0
  95. data/lib/erlang/messenger/lib/eunit/doc/modules-frame.html +12 -0
  96. data/lib/erlang/messenger/lib/eunit/doc/overview-summary.html +984 -0
  97. data/lib/erlang/messenger/lib/eunit/doc/overview.edoc +980 -0
  98. data/lib/erlang/messenger/lib/eunit/doc/packages-frame.html +11 -0
  99. data/lib/erlang/messenger/lib/eunit/doc/stylesheet.css +55 -0
  100. data/lib/erlang/messenger/lib/eunit/ebin/autoload.beam +0 -0
  101. data/lib/erlang/messenger/lib/eunit/ebin/code_monitor.beam +0 -0
  102. data/lib/erlang/messenger/lib/eunit/ebin/eunit.app +21 -0
  103. data/lib/erlang/messenger/lib/eunit/ebin/eunit.appup +1 -0
  104. data/lib/erlang/messenger/lib/eunit/ebin/eunit.beam +0 -0
  105. data/lib/erlang/messenger/lib/eunit/ebin/eunit_autoexport.beam +0 -0
  106. data/lib/erlang/messenger/lib/eunit/ebin/eunit_data.beam +0 -0
  107. data/lib/erlang/messenger/lib/eunit/ebin/eunit_lib.beam +0 -0
  108. data/lib/erlang/messenger/lib/eunit/ebin/eunit_proc.beam +0 -0
  109. data/lib/erlang/messenger/lib/eunit/ebin/eunit_serial.beam +0 -0
  110. data/lib/erlang/messenger/lib/eunit/ebin/eunit_server.beam +0 -0
  111. data/lib/erlang/messenger/lib/eunit/ebin/eunit_striptests.beam +0 -0
  112. data/lib/erlang/messenger/lib/eunit/ebin/eunit_test.beam +0 -0
  113. data/lib/erlang/messenger/lib/eunit/ebin/eunit_tests.beam +0 -0
  114. data/lib/erlang/messenger/lib/eunit/ebin/eunit_tty.beam +0 -0
  115. data/lib/erlang/messenger/lib/eunit/ebin/file_monitor.beam +0 -0
  116. data/lib/erlang/messenger/lib/eunit/examples/eunit_examples.erl +339 -0
  117. data/lib/erlang/messenger/lib/eunit/examples/fib.erl +19 -0
  118. data/lib/erlang/messenger/lib/eunit/examples/tests.txt +1 -0
  119. data/lib/erlang/messenger/lib/eunit/include/eunit.hrl +313 -0
  120. data/lib/erlang/messenger/lib/eunit/src/Makefile +46 -0
  121. data/lib/erlang/messenger/lib/eunit/src/autoload.erl +388 -0
  122. data/lib/erlang/messenger/lib/eunit/src/code_monitor.erl +243 -0
  123. data/lib/erlang/messenger/lib/eunit/src/eunit.app.src +21 -0
  124. data/lib/erlang/messenger/lib/eunit/src/eunit.appup.src +1 -0
  125. data/lib/erlang/messenger/lib/eunit/src/eunit.erl +196 -0
  126. data/lib/erlang/messenger/lib/eunit/src/eunit_autoexport.erl +102 -0
  127. data/lib/erlang/messenger/lib/eunit/src/eunit_data.erl +798 -0
  128. data/lib/erlang/messenger/lib/eunit/src/eunit_internal.hrl +48 -0
  129. data/lib/erlang/messenger/lib/eunit/src/eunit_lib.erl +682 -0
  130. data/lib/erlang/messenger/lib/eunit/src/eunit_proc.erl +552 -0
  131. data/lib/erlang/messenger/lib/eunit/src/eunit_serial.erl +157 -0
  132. data/lib/erlang/messenger/lib/eunit/src/eunit_server.erl +340 -0
  133. data/lib/erlang/messenger/lib/eunit/src/eunit_striptests.erl +64 -0
  134. data/lib/erlang/messenger/lib/eunit/src/eunit_test.erl +334 -0
  135. data/lib/erlang/messenger/lib/eunit/src/eunit_tests.erl +45 -0
  136. data/lib/erlang/messenger/lib/eunit/src/eunit_tty.erl +272 -0
  137. data/lib/erlang/messenger/lib/eunit/src/file_monitor.erl +409 -0
  138. data/lib/erlang/messenger/lib/eunit/sys.config +9 -0
  139. data/lib/erlang/messenger/lib/eunit/vsn.mk +1 -0
  140. data/lib/erlang/messenger/pm_client_rel-0.1.boot +0 -0
  141. data/lib/erlang/messenger/pm_client_rel-0.1.script +238 -0
  142. data/lib/erlang/messenger/pm_master_rel-0.1.boot +0 -0
  143. data/lib/erlang/messenger/pm_master_rel-0.1.script +239 -0
  144. data/lib/erlang/messenger/pm_node_rel-0.1.boot +0 -0
  145. data/lib/erlang/messenger/pm_node_rel-0.1.script +237 -0
  146. data/lib/erlang/messenger/src/client_app.erl +39 -0
  147. data/lib/erlang/messenger/src/client_server.erl +60 -0
  148. data/lib/erlang/messenger/src/master_app.erl +39 -0
  149. data/lib/erlang/messenger/src/node_app.erl +39 -0
  150. data/lib/erlang/messenger/src/pm_client.erl +49 -0
  151. data/lib/erlang/messenger/src/pm_client_supervisor.erl +38 -0
  152. data/lib/erlang/messenger/src/pm_cluster.erl +61 -0
  153. data/lib/erlang/messenger/src/pm_event_manager.erl +27 -0
  154. data/lib/erlang/messenger/src/pm_master.erl +215 -0
  155. data/lib/erlang/messenger/src/pm_master_event_handler.erl +72 -0
  156. data/lib/erlang/messenger/src/pm_master_supervisor.erl +39 -0
  157. data/lib/erlang/messenger/src/pm_node.erl +200 -0
  158. data/lib/erlang/messenger/src/pm_node_supervisor.erl +38 -0
  159. data/lib/erlang/messenger/src/pm_packager.erl +76 -0
  160. data/lib/erlang/messenger/src/pm_spawner.erl +213 -0
  161. data/lib/erlang/messenger/src/pm_strings.erl +11 -0
  162. data/lib/erlang/messenger/src/utils.erl +72 -0
  163. data/lib/erlang/messenger/useful_snippets +17 -0
  164. data/lib/poolparty/aska/aska.rb +152 -0
  165. data/lib/poolparty/base_packages/bind.rb +11 -0
  166. data/lib/poolparty/base_packages/haproxy.rb +46 -0
  167. data/lib/poolparty/base_packages/heartbeat.rb +58 -0
  168. data/lib/poolparty/base_packages/poolparty.rb +14 -0
  169. data/lib/poolparty/base_packages/ruby.rb +42 -0
  170. data/lib/poolparty/base_packages/runit.rb +21 -0
  171. data/lib/poolparty/capistrano/cloud_tasks.rb +10 -0
  172. data/lib/poolparty/capistrano.rb +54 -0
  173. data/lib/poolparty/config/postlaunchmessage.txt +5 -0
  174. data/lib/poolparty/core/array.rb +36 -0
  175. data/lib/poolparty/core/class.rb +26 -0
  176. data/lib/poolparty/core/exception.rb +10 -0
  177. data/lib/poolparty/core/float.rb +13 -0
  178. data/lib/poolparty/core/hash.rb +71 -0
  179. data/lib/poolparty/core/kernel.rb +66 -0
  180. data/lib/poolparty/core/metaid.rb +15 -0
  181. data/lib/poolparty/core/module.rb +40 -0
  182. data/lib/poolparty/core/my_open_struct.rb +18 -0
  183. data/lib/poolparty/core/object.rb +93 -0
  184. data/lib/poolparty/core/ordered_hash.rb +99 -0
  185. data/lib/poolparty/core/proc.rb +7 -0
  186. data/lib/poolparty/core/string.rb +140 -0
  187. data/lib/poolparty/core/symbol.rb +17 -0
  188. data/lib/poolparty/core/time.rb +56 -0
  189. data/lib/poolparty/dependencies.rb +49 -0
  190. data/lib/poolparty/dependency_resolver/chef_resolver.rb +221 -0
  191. data/lib/poolparty/dependency_resolver/dependency_resolver.rb +42 -0
  192. data/lib/poolparty/dependency_resolver/dependency_resolver_cloud_extensions.rb +28 -0
  193. data/lib/poolparty/dependency_resolver/puppet.rb +75 -0
  194. data/lib/poolparty/dependency_resolver/puppet_resolver.rb +173 -0
  195. data/lib/poolparty/exceptions/CloudNotFoundException.rb +7 -0
  196. data/lib/poolparty/exceptions/LoadRulesException.rb +7 -0
  197. data/lib/poolparty/exceptions/MasterException.rb +10 -0
  198. data/lib/poolparty/exceptions/ProvisionerException.rb +5 -0
  199. data/lib/poolparty/exceptions/RemoteException.rb +12 -0
  200. data/lib/poolparty/exceptions/ResourceException.rb +7 -0
  201. data/lib/poolparty/exceptions/RuntimeException.rb +7 -0
  202. data/lib/poolparty/exceptions/SpecException.rb +7 -0
  203. data/lib/poolparty/exceptions/TemplateNotFound.rb +7 -0
  204. data/lib/poolparty/exceptions/UnacceptableCommand.rb +5 -0
  205. data/lib/poolparty/exceptions/dependency_resolver_exception.rb +5 -0
  206. data/lib/poolparty/exceptions/package_exception.rb +7 -0
  207. data/lib/poolparty/extra/deployments.rb +31 -0
  208. data/lib/poolparty/helpers/binary.rb +67 -0
  209. data/lib/poolparty/helpers/console.rb +48 -0
  210. data/lib/poolparty/helpers/display.rb +30 -0
  211. data/lib/poolparty/helpers/hash_printer.rb +44 -0
  212. data/lib/poolparty/helpers/loading.rb +4 -0
  213. data/lib/poolparty/helpers/nice_printer.rb +36 -0
  214. data/lib/poolparty/helpers/optioner.rb +149 -0
  215. data/lib/poolparty/helpers/ruberl.rb +33 -0
  216. data/lib/poolparty/lite.rb +20 -0
  217. data/lib/poolparty/modules/cloud_dsl.rb +20 -0
  218. data/lib/poolparty/modules/cloud_resourcer.rb +122 -0
  219. data/lib/poolparty/modules/daemonizable.rb +141 -0
  220. data/lib/poolparty/modules/definable_resource.rb +57 -0
  221. data/lib/poolparty/modules/file_writer.rb +95 -0
  222. data/lib/poolparty/modules/output.rb +13 -0
  223. data/lib/poolparty/modules/pretty_printer.rb +40 -0
  224. data/lib/poolparty/modules/resourcing_dsl.rb +74 -0
  225. data/lib/poolparty/modules/s3_string.rb +32 -0
  226. data/lib/poolparty/modules/safe_instance.rb +31 -0
  227. data/lib/poolparty/modules/thread_pool.rb +106 -0
  228. data/lib/poolparty/monitors/base_monitor.rb +81 -0
  229. data/lib/poolparty/monitors/monitor_rack.rb +132 -0
  230. data/lib/poolparty/monitors/monitors/load_monitor.rb +15 -0
  231. data/lib/poolparty/monitors/monitors/memory_monitor.rb +50 -0
  232. data/lib/poolparty/monitors/monitors/server_monitor.rb +7 -0
  233. data/lib/poolparty/monitors/monitors/web_monitor.rb +18 -0
  234. data/lib/poolparty/monitors/neighborhood_monitor.rb +25 -0
  235. data/lib/poolparty/monitors/stats_monitor.rb +182 -0
  236. data/lib/poolparty/monitors.rb +6 -0
  237. data/lib/poolparty/net/init.rb +11 -0
  238. data/lib/poolparty/net/messenger.rb +55 -0
  239. data/lib/poolparty/net/remote_bases.rb +21 -0
  240. data/lib/poolparty/net/remote_instance.rb +109 -0
  241. data/lib/poolparty/net/remoter/cloud_control.rb +251 -0
  242. data/lib/poolparty/net/remoter/connections.rb +180 -0
  243. data/lib/poolparty/net/remoter/interactive.rb +121 -0
  244. data/lib/poolparty/net/remoter/lists.rb +12 -0
  245. data/lib/poolparty/net/remoter_base.rb +97 -0
  246. data/lib/poolparty/net/remoter_bases/ec2/ec2.rb +235 -0
  247. data/lib/poolparty/net/remoter_bases/ec2/ec2_remote_instance.rb +53 -0
  248. data/lib/poolparty/net/remoter_bases/ec2/ec2_response_object.rb +64 -0
  249. data/lib/poolparty/plugins/chef.rb +168 -0
  250. data/lib/poolparty/plugins/deploydirectory.rb +47 -0
  251. data/lib/poolparty/plugins/git.rb +66 -0
  252. data/lib/poolparty/plugins/line_in_file.rb +13 -0
  253. data/lib/poolparty/plugins/rsyncmirror.rb +28 -0
  254. data/lib/poolparty/plugins/runit.rb +96 -0
  255. data/lib/poolparty/plugins/svn.rb +48 -0
  256. data/lib/poolparty/poolparty/cloud.rb +216 -0
  257. data/lib/poolparty/poolparty/custom_resource.rb +45 -0
  258. data/lib/poolparty/poolparty/default.rb +167 -0
  259. data/lib/poolparty/poolparty/key.rb +75 -0
  260. data/lib/poolparty/poolparty/loggable.rb +28 -0
  261. data/lib/poolparty/poolparty/neighborhoods.rb +69 -0
  262. data/lib/poolparty/poolparty/plugin.rb +69 -0
  263. data/lib/poolparty/poolparty/plugin_model.rb +45 -0
  264. data/lib/poolparty/poolparty/pool.rb +76 -0
  265. data/lib/poolparty/poolparty/poolparty_base_class.rb +181 -0
  266. data/lib/poolparty/poolparty/resource.rb +205 -0
  267. data/lib/poolparty/poolparty/script.rb +58 -0
  268. data/lib/poolparty/poolparty/service.rb +34 -0
  269. data/lib/poolparty/poolparty/template.rb +27 -0
  270. data/lib/poolparty/provision/boot_strapper.rb +141 -0
  271. data/lib/poolparty/provision/configurations/chef.rb +22 -0
  272. data/lib/poolparty/provision/configurations/puppet.rb +28 -0
  273. data/lib/poolparty/provision/dr_configure.rb +85 -0
  274. data/lib/poolparty/resources/cron.rb +14 -0
  275. data/lib/poolparty/resources/custom_service.rb +30 -0
  276. data/lib/poolparty/resources/directory.rb +13 -0
  277. data/lib/poolparty/resources/exec.rb +25 -0
  278. data/lib/poolparty/resources/file.rb +29 -0
  279. data/lib/poolparty/resources/host.rb +16 -0
  280. data/lib/poolparty/resources/mount.rb +21 -0
  281. data/lib/poolparty/resources/package.rb +12 -0
  282. data/lib/poolparty/resources/remote_file.rb +20 -0
  283. data/lib/poolparty/resources/service.rb +20 -0
  284. data/lib/poolparty/resources/sshkey.rb +27 -0
  285. data/lib/poolparty/resources/symlink.rb +21 -0
  286. data/lib/poolparty/resources/user.rb +13 -0
  287. data/lib/poolparty/resources/variable.rb +9 -0
  288. data/lib/poolparty/schema.rb +64 -0
  289. data/lib/poolparty/services/conditional.rb +46 -0
  290. data/lib/poolparty/services/gem_package.rb +52 -0
  291. data/lib/poolparty/spec/core/string.rb +18 -0
  292. data/lib/poolparty/spec/matchers/a_spec_extensions_base.rb +26 -0
  293. data/lib/poolparty/spec/matchers/have_cron.rb +28 -0
  294. data/lib/poolparty/spec/matchers/have_deploydirectory.rb +15 -0
  295. data/lib/poolparty/spec/matchers/have_directory.rb +31 -0
  296. data/lib/poolparty/spec/matchers/have_exec.rb +28 -0
  297. data/lib/poolparty/spec/matchers/have_file.rb +28 -0
  298. data/lib/poolparty/spec/matchers/have_gempackage.rb +28 -0
  299. data/lib/poolparty/spec/matchers/have_git.rb +28 -0
  300. data/lib/poolparty/spec/matchers/have_host.rb +28 -0
  301. data/lib/poolparty/spec/matchers/have_mount.rb +28 -0
  302. data/lib/poolparty/spec/matchers/have_package.rb +28 -0
  303. data/lib/poolparty/spec/matchers/have_remotefile.rb +28 -0
  304. data/lib/poolparty/spec/matchers/have_rsyncmirror.rb +28 -0
  305. data/lib/poolparty/spec/matchers/have_service.rb +28 -0
  306. data/lib/poolparty/spec/matchers/have_sshkey.rb +28 -0
  307. data/lib/poolparty/spec/matchers/have_symlink.rb +28 -0
  308. data/lib/poolparty/spec/matchers/have_variable.rb +32 -0
  309. data/lib/poolparty/spec/spec/dynamic_matchers.rb +63 -0
  310. data/lib/poolparty/spec/spec/ensure_matchers_exist.rb +7 -0
  311. data/lib/poolparty/spec/templates/have_base.rb +28 -0
  312. data/lib/poolparty/spec.rb +31 -0
  313. data/lib/poolparty/templates/authkeys +2 -0
  314. data/lib/poolparty/templates/cib.xml +54 -0
  315. data/lib/poolparty/templates/erlang_cookie_maker +6 -0
  316. data/lib/poolparty/templates/gem +27 -0
  317. data/lib/poolparty/templates/gemrc +11 -0
  318. data/lib/poolparty/templates/ha.cf +17 -0
  319. data/lib/poolparty/templates/haproxy.conf +36 -0
  320. data/lib/poolparty/templates/haresources +3 -0
  321. data/lib/poolparty/templates/logd.cf +42 -0
  322. data/lib/poolparty/templates/messenger/client/log-run.erb +2 -0
  323. data/lib/poolparty/templates/messenger/client/run.erb +4 -0
  324. data/lib/poolparty/templates/messenger/master/log-run.erb +2 -0
  325. data/lib/poolparty/templates/messenger/master/run.erb +4 -0
  326. data/lib/poolparty/templates/messenger/node/log-run.erb +2 -0
  327. data/lib/poolparty/templates/messenger/node/run.erb +4 -0
  328. data/lib/poolparty/templates/monitor.ru +16 -0
  329. data/lib/poolparty/templates/namespaceauth.conf +19 -0
  330. data/lib/poolparty/templates/poolparty.monitor +14 -0
  331. data/lib/poolparty/templates/puppet/add_puppet_to_hosts +6 -0
  332. data/lib/poolparty/templates/puppet/puppet.conf +2 -0
  333. data/lib/poolparty/templates/puppet/puppetrunner +14 -0
  334. data/lib/poolparty/templates/puppet/site.pp +4 -0
  335. data/lib/poolparty/templates/puppetrunner +14 -0
  336. data/lib/poolparty/templates/yaws.conf +19 -0
  337. data/lib/poolparty/version.rb +15 -0
  338. data/lib/poolparty.rb +148 -0
  339. data/lib/poolpartycl.rb +7 -0
  340. data/script/destroy +14 -0
  341. data/script/generate +14 -0
  342. data/spec/bin/bin_spec_helper.rb +7 -0
  343. data/spec/bin/fixtures/bin_cloud_for_test.rb +19 -0
  344. data/spec/bin/server-list-active_spec.rb +22 -0
  345. data/spec/poolparty/aska/aska_spec.rb +117 -0
  346. data/spec/poolparty/base_packages/haproxy_spec.rb +7 -0
  347. data/spec/poolparty/base_packages/heartbeat_spec.rb +7 -0
  348. data/spec/poolparty/bin/console_spec.rb +83 -0
  349. data/spec/poolparty/core/array_spec.rb +46 -0
  350. data/spec/poolparty/core/float.rb +13 -0
  351. data/spec/poolparty/core/hash_spec.rb +83 -0
  352. data/spec/poolparty/core/kernel_spec.rb +24 -0
  353. data/spec/poolparty/core/module_spec.rb +15 -0
  354. data/spec/poolparty/core/object_spec.rb +68 -0
  355. data/spec/poolparty/core/ordered_hash_spec.rb +48 -0
  356. data/spec/poolparty/core/string_spec.rb +145 -0
  357. data/spec/poolparty/core/time_spec.rb +49 -0
  358. data/spec/poolparty/dependencies_spec.rb +11 -0
  359. data/spec/poolparty/dependency_resolver/chef_resolver_spec.rb +119 -0
  360. data/spec/poolparty/dependency_resolver/dependency_resolver_cloud_extensions_spec.rb +128 -0
  361. data/spec/poolparty/dependency_resolver/dependency_resolver_spec.rb +16 -0
  362. data/spec/poolparty/dependency_resolver/puppet_resolver_spec.rb +124 -0
  363. data/spec/poolparty/extra/deployments_spec.rb +68 -0
  364. data/spec/poolparty/fixtures/clouds.json +128 -0
  365. data/spec/poolparty/fixtures/test_template.erb +1 -0
  366. data/spec/poolparty/helpers/binary_spec.rb +26 -0
  367. data/spec/poolparty/helpers/display_spec.rb +13 -0
  368. data/spec/poolparty/helpers/hash_printer_spec.rb +34 -0
  369. data/spec/poolparty/helpers/optioner_spec.rb +50 -0
  370. data/spec/poolparty/id_rsa +27 -0
  371. data/spec/poolparty/modules/cloud_resourcer_spec.rb +67 -0
  372. data/spec/poolparty/modules/definable_resource.rb +9 -0
  373. data/spec/poolparty/modules/file_writer_spec.rb +64 -0
  374. data/spec/poolparty/modules/s3_string_spec.rb +15 -0
  375. data/spec/poolparty/monitors/base_monitor_spec.rb +112 -0
  376. data/spec/poolparty/monitors/monitors/cpu_monitor_spec.rb +18 -0
  377. data/spec/poolparty/monitors/monitors/memory_monitor_spec.rb +48 -0
  378. data/spec/poolparty/net/messenger_spec.rb +16 -0
  379. data/spec/poolparty/net/remote_instance_spec.rb +17 -0
  380. data/spec/poolparty/net/remote_spec.rb +286 -0
  381. data/spec/poolparty/net/remoter_base_spec.rb +35 -0
  382. data/spec/poolparty/net/remoter_bases/ec2_mocks_and_stubs.rb +24 -0
  383. data/spec/poolparty/net/remoter_bases/ec2_remote_instance_spec.rb +125 -0
  384. data/spec/poolparty/net/remoter_bases/ec2_spec.rb +119 -0
  385. data/spec/poolparty/net/remoter_spec.rb +130 -0
  386. data/spec/poolparty/plugins/chef_spec.rb +7 -0
  387. data/spec/poolparty/plugins/deploydirectory_spec.rb +51 -0
  388. data/spec/poolparty/plugins/git_spec.rb +40 -0
  389. data/spec/poolparty/plugins/line_spec.rb +22 -0
  390. data/spec/poolparty/plugins/svn_spec.rb +16 -0
  391. data/spec/poolparty/poolparty/cloud_spec.rb +345 -0
  392. data/spec/poolparty/poolparty/configurers/files/ruby_basic.rb +16 -0
  393. data/spec/poolparty/poolparty/configurers/files/ruby_plugins.rb +16 -0
  394. data/spec/poolparty/poolparty/configurers/ruby_spec.rb +42 -0
  395. data/spec/poolparty/poolparty/custom_resource_spec.rb +79 -0
  396. data/spec/poolparty/poolparty/default_spec.rb +139 -0
  397. data/spec/poolparty/poolparty/example_spec.rb +60 -0
  398. data/spec/poolparty/poolparty/key_spec.rb +42 -0
  399. data/spec/poolparty/poolparty/neighborhoods_spec.rb +66 -0
  400. data/spec/poolparty/poolparty/plugin_model_spec.rb +54 -0
  401. data/spec/poolparty/poolparty/plugin_spec.rb +41 -0
  402. data/spec/poolparty/poolparty/pool_spec.rb +100 -0
  403. data/spec/poolparty/poolparty/resource_spec.rb +209 -0
  404. data/spec/poolparty/poolparty/script_spec.rb +49 -0
  405. data/spec/poolparty/poolparty/service_spec.rb +5 -0
  406. data/spec/poolparty/poolparty/template_spec.rb +26 -0
  407. data/spec/poolparty/poolparty/test_plugins/sshkey_test +2 -0
  408. data/spec/poolparty/poolparty/test_plugins/virtual_host_template.erb +0 -0
  409. data/spec/poolparty/poolparty/test_plugins/webserver.rb +30 -0
  410. data/spec/poolparty/poolparty_base_class_spec.rb +80 -0
  411. data/spec/poolparty/poolparty_spec.rb +36 -0
  412. data/spec/poolparty/resources/cron_spec.rb +44 -0
  413. data/spec/poolparty/resources/directory_spec.rb +40 -0
  414. data/spec/poolparty/resources/exec_spec.rb +37 -0
  415. data/spec/poolparty/resources/file_spec.rb +63 -0
  416. data/spec/poolparty/resources/gem_spec.rb +7 -0
  417. data/spec/poolparty/resources/host_spec.rb +35 -0
  418. data/spec/poolparty/resources/package_spec.rb +29 -0
  419. data/spec/poolparty/resources/service_spec.rb +29 -0
  420. data/spec/poolparty/resources/sshkey_spec.rb +40 -0
  421. data/spec/poolparty/resources/symlink_spec.rb +29 -0
  422. data/spec/poolparty/resources/user_spec.rb +48 -0
  423. data/spec/poolparty/resources/variable_spec.rb +26 -0
  424. data/spec/poolparty/schema_spec.rb +53 -0
  425. data/spec/poolparty/services/conditional_spec.rb +52 -0
  426. data/spec/poolparty/spec/core/string_spec.rb +57 -0
  427. data/spec/poolparty/spec_helper.rb +263 -0
  428. data/spec/poolparty/test_spec_helper.rb +13 -0
  429. data/tasks/cloud.rake +3 -0
  430. data/tasks/development.rake +82 -0
  431. data/tasks/ec2.rake +13 -0
  432. data/tasks/environment.rake +7 -0
  433. data/tasks/instance.rake +2 -0
  434. data/tasks/poolparty.rake +54 -0
  435. data/tasks/server.rake +44 -0
  436. data/tasks/spec.rake +16 -0
  437. data/test/fixtures/test_template.erb +1 -0
  438. data/test/poolparty/core/hash_test.rb +23 -0
  439. data/test/poolparty/poolparty/template_test.rb +31 -0
  440. data/test/poolparty/provision/boot_strapper_test.rb +6 -0
  441. data/test/poolparty/provision/dr_configure_test.rb +6 -0
  442. data/test/test_generator_helper.rb +29 -0
  443. data/test/test_helper.rb +5 -0
  444. data/test/test_pool_spec_generator.rb +47 -0
  445. data/test/test_poolparty.rb +11 -0
  446. data/vendor/gems/butterfly/History.txt +4 -0
  447. data/vendor/gems/butterfly/PostInstall.txt +2 -0
  448. data/vendor/gems/butterfly/README.rdoc +48 -0
  449. data/vendor/gems/butterfly/Rakefile +62 -0
  450. data/vendor/gems/butterfly/VERSION.yml +4 -0
  451. data/vendor/gems/butterfly/bin/flutter +4 -0
  452. data/vendor/gems/butterfly/butterfly.gemspec +37 -0
  453. data/vendor/gems/butterfly/examples/config.ru +15 -0
  454. data/vendor/gems/butterfly/examples/my_app.rb +12 -0
  455. data/vendor/gems/butterfly/lib/butterfly.rb +14 -0
  456. data/vendor/gems/butterfly/lib/handler.rb +48 -0
  457. data/vendor/gems/butterfly/lib/request.rb +29 -0
  458. data/vendor/gems/butterfly/lib/response.rb +49 -0
  459. data/vendor/gems/butterfly/script/console +10 -0
  460. data/vendor/gems/butterfly/script/destroy +14 -0
  461. data/vendor/gems/butterfly/script/generate +14 -0
  462. data/vendor/gems/butterfly/test/test_adapter_base.rb +23 -0
  463. data/vendor/gems/butterfly/test/test_butterfly_request.rb +46 -0
  464. data/vendor/gems/butterfly/test/test_butterfly_response.rb +43 -0
  465. data/vendor/gems/butterfly/test/test_butterfly_server.rb +16 -0
  466. data/vendor/gems/butterfly/test/test_default.rb +12 -0
  467. data/vendor/gems/butterfly/test/test_helper.rb +6 -0
  468. data/vendor/gems/dslify/History.txt +4 -0
  469. data/vendor/gems/dslify/Manifest.txt +25 -0
  470. data/vendor/gems/dslify/PostInstall.txt +5 -0
  471. data/vendor/gems/dslify/README.txt +60 -0
  472. data/vendor/gems/dslify/Rakefile +56 -0
  473. data/vendor/gems/dslify/config/hoe.rb +73 -0
  474. data/vendor/gems/dslify/config/requirements.rb +15 -0
  475. data/vendor/gems/dslify/dslify.gemspec +40 -0
  476. data/vendor/gems/dslify/lib/dslify/dslify.rb +69 -0
  477. data/vendor/gems/dslify/lib/dslify/version.rb +10 -0
  478. data/vendor/gems/dslify/lib/dslify.rb +7 -0
  479. data/vendor/gems/dslify/script/console +10 -0
  480. data/vendor/gems/dslify/script/destroy +14 -0
  481. data/vendor/gems/dslify/script/generate +14 -0
  482. data/vendor/gems/dslify/script/txt2html +82 -0
  483. data/vendor/gems/dslify/setup.rb +1585 -0
  484. data/vendor/gems/dslify/tasks/deployment.rake +34 -0
  485. data/vendor/gems/dslify/tasks/environment.rake +7 -0
  486. data/vendor/gems/dslify/tasks/website.rake +17 -0
  487. data/vendor/gems/dslify/test/test_dslify.rb +114 -0
  488. data/vendor/gems/dslify/website/index.html +86 -0
  489. data/vendor/gems/dslify/website/index.txt +83 -0
  490. data/vendor/gems/dslify/website/javascripts/rounded_corners_lite.inc.js +285 -0
  491. data/vendor/gems/dslify/website/stylesheets/screen.css +138 -0
  492. data/vendor/gems/dslify/website/template.html.erb +48 -0
  493. data/vendor/gems/parenting/History.txt +4 -0
  494. data/vendor/gems/parenting/Manifest.txt +13 -0
  495. data/vendor/gems/parenting/PostInstall.txt +2 -0
  496. data/vendor/gems/parenting/README.rdoc +47 -0
  497. data/vendor/gems/parenting/Rakefile +28 -0
  498. data/vendor/gems/parenting/lib/parenting/base.rb +65 -0
  499. data/vendor/gems/parenting/lib/parenting.rb +10 -0
  500. data/vendor/gems/parenting/parenting.gemspec +39 -0
  501. data/vendor/gems/parenting/script/console +10 -0
  502. data/vendor/gems/parenting/script/destroy +14 -0
  503. data/vendor/gems/parenting/script/generate +14 -0
  504. data/vendor/gems/parenting/test/file_to_eval.rb +9 -0
  505. data/vendor/gems/parenting/test/test_helper.rb +5 -0
  506. data/vendor/gems/parenting/test/test_parenting.rb +89 -0
  507. data/vendor/gems/suitcase/LICENSE +20 -0
  508. data/vendor/gems/suitcase/README.rdoc +31 -0
  509. data/vendor/gems/suitcase/Rakefile +57 -0
  510. data/vendor/gems/suitcase/VERSION.yml +4 -0
  511. data/vendor/gems/suitcase/lib/suitcase/unzipper.rb +15 -0
  512. data/vendor/gems/suitcase/lib/suitcase/zipper.rb +103 -0
  513. data/vendor/gems/suitcase/lib/suitcase.rb +5 -0
  514. data/vendor/gems/suitcase/suitcase.gemspec +52 -0
  515. data/vendor/gems/suitcase/test/suitcase_test.rb +89 -0
  516. data/vendor/gems/suitcase/test/test_dir/box.rb +1 -0
  517. data/vendor/gems/suitcase/test/test_dir/test.txt +1 -0
  518. data/vendor/gems/suitcase/test/test_helper.rb +12 -0
  519. metadata +810 -0
@@ -0,0 +1,235 @@
1
+ =begin rdoc
2
+ EC2 Remoter Base
3
+
4
+ This serves as the basis for running PoolParty on Amazon's ec2 cloud
5
+ cluster.
6
+ =end
7
+ require "date"
8
+ require "#{::File.dirname(__FILE__)}/ec2_response_object"
9
+
10
+ begin
11
+ require 'EC2'
12
+ rescue LoadError
13
+ puts <<-EOM
14
+ Error: In order to use ec2, you need to install the amazon-ec2 gem
15
+
16
+ Ec2 is the default remoter base for PoolParty. If you intend on using
17
+ a different remoter base, specify it with:
18
+
19
+ using :remoter_name
20
+
21
+ in your config file, otherwise, to continue install grempe-amazon-ec2 with
22
+
23
+ sudo gem install grempe-amazon-ec2 --source http://gems.github.com
24
+ EOM
25
+ end
26
+
27
+ class String
28
+ def convert_from_ec2_to_ip
29
+ self.gsub(/.compute-1.amazonaws.com*/, '').gsub(/ec2-/, '').gsub(/-/, '.')
30
+ end
31
+ def parse_datetime
32
+ DateTime.parse( self.chomp ) rescue self
33
+ end
34
+ end
35
+
36
+ module PoolParty
37
+ module Remote
38
+ class Ec2 < Remote::RemoterBase
39
+
40
+ def self.launch_new_instance!(o = options)
41
+ raise "You must pass a keypair to launch an instance, or else you wont be able to login. options = #{o.inspect}" if !o[:keypair]
42
+ instance = ec2(o).run_instances(
43
+ :image_id => o[:ami],
44
+ :user_data => o[:user_data],
45
+ :minCount => 1,
46
+ :maxCount => o[:num],
47
+ :key_name => o[:keypair],
48
+ :availability_zone => o[:availabilty_zone],
49
+ :instance_type => o[:size],
50
+ :group_id => o[:security_group])
51
+
52
+ begin
53
+ h = EC2ResponseObject.get_hash_from_response(instance.instancesSet.item.first)
54
+ #h = instance.instancesSet.item.first
55
+ rescue Exception => e
56
+ h = EC2ResponseObject.get_hash_from_response(instance) rescue instance
57
+ # h = instance
58
+ end
59
+ h
60
+ end
61
+ # Terminate an instance by id
62
+ def self.terminate_instance!(o={}) #NOTE: maybe we should not allow this command wihtout an instance_idˇ
63
+ ec2(o).terminate_instances(:instance_id => o[:instance_id])
64
+ end
65
+ # Describe an instance's status
66
+ def self.describe_instance(o={})
67
+ return describe_instances.first if o[:instance_id].nil?
68
+ describe_instances.detect {|a| a[:name] == o[:instance_id] || a[:ip] == o[:instance_id] || a[:instance_id] == o[:instance_id] }
69
+ end
70
+ def self.describe_instances(o={})
71
+ id = 0
72
+ get_instances_description(o).each_with_index do |h,i|
73
+ if h[:status] == "running"
74
+ inst_name = id == 0 ? "master" : "node#{id}"
75
+ id += 1
76
+ else
77
+ inst_name = "#{h[:status]}_node#{i}"
78
+ end
79
+ h.merge!({
80
+ :name => inst_name,
81
+ :hostname => h[:ip],
82
+ :ip => h[:ip].convert_from_ec2_to_ip,
83
+ :index => i, #TODO MF get the instance id from the aws result instead
84
+ :launching_time => (h[:launching_time])
85
+ })
86
+ end.sort {|a,b| a[:index] <=> b[:index] }
87
+ end
88
+
89
+ def self.ec2(o={})
90
+ @ec2 ||= EC2::Base.new( :access_key_id => o[:access_key],
91
+ :secret_access_key => o[:secret_access_key]
92
+ )
93
+ end
94
+ # Get the ec2 description for the response in a hash format
95
+ def self.get_instances_description(o={})
96
+ EC2ResponseObject.get_descriptions(ec2(o).describe_instances)
97
+ end
98
+ def get_descriptions(o={})
99
+ self.class.get_descriptions(o)
100
+ end
101
+
102
+ # Class method helpers
103
+ def self.aws_keys
104
+ unless @access_key && @secret_access_key
105
+ aws_keys = {}
106
+ aws_keys = YAML::load( File.open('/etc/poolparty/aws_keys.yml') ) rescue 'No aws_keys.yml file. Will try to use enviornment variables'
107
+ @access_key ||= aws_keys[:access_key] || ENV['AMAZON_ACCESS_KEY_ID'] || ENV['AWS_ACCESS_KEY']
108
+ @secret_access_key ||= aws_keys[:secret_access_key] || ENV['AMAZON_SECRET_ACCESS_KEY'] || ENV['AWS_SECRET_ACCESS_KEY']
109
+ end
110
+ [@access_key, @secret_access_key]
111
+ end
112
+
113
+ def after_launch_master(inst=nil)
114
+ instance = master
115
+ vputs "Running tasks after launching the master"
116
+ begin
117
+ # when_no_pending_instances do
118
+ if instance
119
+ attach_volume(instance)
120
+ # Let's associate the address LAST so that we can still connect to the instance
121
+ # for the other tasks here
122
+ associate_address(instance)
123
+ reset_remoter_base!
124
+ end
125
+ # end
126
+ rescue Exception => e
127
+ vputs "Error in after_launch_master: #{e}"
128
+ end
129
+ reset_remoter_base!
130
+ when_all_assigned_ips {wait "5.seconds"}
131
+ end
132
+
133
+ # Attach a volume to the instance
134
+ # DEPRECATE this relies on master. master will be removed in next major release. This method will be in ec2_remote_instance instead, or require an instance id
135
+ def attach_volume(instance=nil)
136
+ if ebs_volume_id
137
+ vputs "Attaching volume #{ebs_volume_id} to the master at #{ebs_volume_device}"
138
+ instance = master
139
+ ec2.attach_volume(:volume_id => ebs_volume_id, :instance_id => instance.instance_id, :device => ebs_volume_device) if ebs_volume_id && ebs_volume_mount_point
140
+ end
141
+ end
142
+ # Associate an address with the instance using ec2
143
+ # DEPRECATE relies on master
144
+ def associate_address(instance=nil)
145
+ if set_master_ip_to
146
+ dputs "Associating master with #{set_master_ip_to}"
147
+ instance = master
148
+ ec2.associate_address(:instance_id => instance.instance_id, :public_ip => set_master_ip_to) if set_master_ip_to
149
+ end
150
+ end
151
+
152
+ # Help create a keypair for the cloud
153
+ # This is a helper to create the keypair and add them to the cloud for you
154
+ def create_keypair
155
+ return false unless keypair
156
+ unless ::File.exists?( new_keypair_path )
157
+ FileUtils.mkdir_p ::File.dirname( new_keypair_path )
158
+ vputs "Creating keypair: #{keypair} in #{new_keypair_path}"
159
+ Kernel.system "ec2-add-keypair #{keypair} > #{new_keypair_path} && chmod 600 #{new_keypair_path}"
160
+ end
161
+ end
162
+
163
+ # wrapper for remote base to perform a snapshot backup for the ebs volume
164
+ def create_snapshot
165
+ return nil if ebs_volume_id.nil?
166
+ ec2.create_snapshot(:volume_id => ebs_volume_id)
167
+ end
168
+
169
+ # EC2 connections
170
+ def ec2(o={})
171
+ @ec2 ||= self.class.ec2(o)
172
+ end
173
+
174
+ # These are tasks that run before the configuration runs
175
+ def before_configuration_tasks
176
+ if set_master_ip_to && master.ip && master.ip.to_s != set_master_ip_to.to_s
177
+ associate_address(master)
178
+ reset_remoter_base!
179
+
180
+ when_no_pending_instances do
181
+ when_all_assigned_ips do
182
+ vputs "Associated master with #{set_master_ip_to}"
183
+ end
184
+ end
185
+ end
186
+
187
+ end
188
+ def has_cert_and_key?
189
+ pub_key && private_key
190
+ end
191
+ # The keys are used only for puppet certificates
192
+ # and are only used for EC2.
193
+ # Public key
194
+ def pub_key
195
+ @pub_key ||= ENV["EC2_CERT"] ? ENV["EC2_CERT"] : nil
196
+ end
197
+ # Private key
198
+ def private_key
199
+ @private_key ||= ENV["EC2_PRIVATE_KEY"] ? ENV["EC2_PRIVATE_KEY"] : nil
200
+ end
201
+
202
+ def custom_minimum_runnable_options
203
+ [:ami, :availabilty_zone, :security_group]
204
+ end
205
+
206
+ # Hook
207
+ #TODO#: Change this so they match with the cap tasks
208
+ def custom_install_tasks_for(o)
209
+ [
210
+ # "if [ -z $(grep -v '#' /etc/hosts | grep '#{o.name}') ]; then echo \"$(curl http://169.254.169.254/latest/meta-data/public-ipv4) #{o.name}\" >> /etc/hosts; fi",
211
+ "if [ -z \"$(grep -v '#' /etc/hosts | grep '#{o.name}')\" ]; then echo '127.0.0.1 #{o.name}' >> /etc/hosts; fi",
212
+ "hostname #{o.name}",
213
+ "echo #{o.name} > /etc/hostname"
214
+ ]
215
+ end
216
+
217
+ def after_install_tasks_for(o)
218
+ [
219
+ # "cd /var/poolparty && wget http://rubyforge.org/frs/download.php/43666/amazon-ec2-0.3.1.gem -O amazon-ec2.gem 2>&1",
220
+ # "/usr/bin/gem install --no-ri --no-rdoc amazon-ec2.gem 2>&1"
221
+ ]
222
+ end
223
+
224
+ def custom_configure_tasks_for(o)
225
+ [
226
+ ]
227
+ end
228
+
229
+ def reset_base!
230
+ @describe_instances = @cached_descriptions = nil
231
+ end
232
+ end
233
+
234
+ end
235
+ end
@@ -0,0 +1,53 @@
1
+ module PoolParty
2
+ module Remote
3
+ class Ec2RemoteInstance < RemoteInstance
4
+ include Dslify
5
+
6
+ attr_reader :my_cloud, :uniquely_identifiable_by, :found_at
7
+
8
+
9
+ # A new instance will be created from the passed in hash.
10
+ # This hash of passed in values will be converted to methods on this instance.
11
+ # The parent clouds describe_instances list will be searched for the first one matching any of this instance's provided unique identifiers.
12
+ # If an instance is found, this instance's properties will be set to the properties provided
13
+ # If the found instance has properties of the same key as the provided options, the found instance's values will override the passed in options
14
+ def initialize(opts={}, prnt=Ec2.new)
15
+ @uniquely_identifiable_by = [:ip, :name, :dns_name, :instance_id]
16
+ @original_options = opts
17
+ @my_cloud = prnt
18
+ super(opts, prnt)
19
+ find_myself(@uniquely_identifiable_by && opts.keys) if prnt.respond_to?(:describe_instances)
20
+ end
21
+
22
+ # Search the clouds describe_instances list for the first match on one of this nodes unique identifiers
23
+ def find_myself(unique_identifiers = @original_options.keys)
24
+ description_hash = @my_cloud.describe_instances.detect do|node|
25
+ unique_identifiers.detect{|identifier_key| node[identifier_key] == options[identifier_key]
26
+ }
27
+ end
28
+ return nil if description_hash.blank?
29
+ @found_at = Time.now
30
+ self.set_vars_from_options(description_hash)
31
+ self
32
+ end
33
+
34
+ # Is this instance running?
35
+ def running?
36
+ !(status =~ /running/).nil?
37
+ end
38
+ # Is this instance pending?
39
+ def pending?
40
+ !(status =~ /pending/).nil?
41
+ end
42
+ # Is this instance terminating?
43
+ def terminating?
44
+ !(status =~ /shutting/).nil?
45
+ end
46
+ # Has this instance been terminated?
47
+ def terminated?
48
+ !(status =~ /terminated/).nil?
49
+ end
50
+
51
+ end
52
+ end
53
+ end
@@ -0,0 +1,64 @@
1
+ # Convenience class to convert standard amazon-ec2 responses from their camel cased style to a hash using underscore style.
2
+ # For example: instanceId to instance_id
3
+ class EC2ResponseObject
4
+ def self.get_descriptions(resp)
5
+ rs = get_instance_from_response(resp)
6
+ group = get_group_from_response(resp)
7
+
8
+ # puts rs.methods.sort - rs.ancestors.methods
9
+ out = begin
10
+ if rs.respond_to?(:instancesSet)
11
+ [EC2ResponseObject.get_hash_from_response(rs.instancesSet.item, group)]
12
+ else
13
+ rs.collect {|r|
14
+ if r.instancesSet.item.class == Array
15
+ r.instancesSet.item.map {|t| EC2ResponseObject.get_hash_from_response(t, group)}
16
+ else
17
+ [EC2ResponseObject.get_hash_from_response(r.instancesSet.item, group)]
18
+ end
19
+ }.flatten.reject {|a| a.nil? }
20
+ end
21
+ rescue Exception => e
22
+ # Really weird bug with amazon's ec2 gem
23
+ rs.collect {|r| EC2ResponseObject.get_hash_from_response(r)}.reject {|a| a.nil? } rescue []
24
+ end
25
+
26
+ out
27
+ end
28
+ def self.get_instance_from_response(resp)
29
+ begin
30
+ rs = resp.reservationSet.item unless resp.reservationSet.nil?
31
+ rs ||= resp.DescribeInstancesResponse.reservationSet.item
32
+ rs ||= rs.respond_to?(:instancesSet) ? rs.instancesSet : rs
33
+ rs.reject! {|a| a.nil? || a.empty? }
34
+ rescue Exception => e
35
+ resp
36
+ end
37
+ rs
38
+ end
39
+ def self.get_group_from_response(resp)
40
+ begin
41
+ resp = resp.reservationSet.item.first if resp.reservationSet.item.is_a?(Array)
42
+ group = resp.reservationSet.item.groupSet.item.groupId unless resp.reservationSet.nil?
43
+ group ||= resp.groupSet.item[0].groupId rescue nil
44
+ group ||= resp.DescribeInstancesResponse.reservationSet.item.groupSet.item.groupId
45
+ #rs ||= rs.respond_to?(:instancesSet) ? rs.instancesSet : rs
46
+ #rs.reject! {|a| a.nil? || a.empty? }
47
+ rescue Exception => e
48
+ resp
49
+ end
50
+ group
51
+ end
52
+ def self.get_hash_from_response(resp, group = 'default')
53
+ {
54
+ :instance_id => resp.instanceId,
55
+ :name => resp.instanceId,
56
+ :ip => resp.dnsName || "not-assigned",
57
+ :status => resp.instanceState.name,
58
+ :launching_time => resp.launchTime.parse_datetime,
59
+ :internal_ip => resp.privateDnsName,
60
+ :keypair => resp.keyName,
61
+ :security_group => group
62
+ }
63
+ end
64
+ end
@@ -0,0 +1,168 @@
1
+ require "tempfile"
2
+ module PoolParty
3
+ class ChefRecipe
4
+ include Dslify
5
+ end
6
+ class Chef
7
+
8
+ plugin :chef do
9
+ def before_load(o, &block)
10
+ bootstrap_gems "chef", "ohai"
11
+ bootstrap_commands [
12
+ "mkdir -p /etc/chef/cookbooks /etc/chef/cache"
13
+ ]
14
+ end
15
+
16
+ def loaded o={}, &block
17
+ end
18
+
19
+ def recipe_files
20
+ @recipe_files ||= []
21
+ end
22
+
23
+ def basedir
24
+ @basedir ||= "#{Default.tmp_path}/dr_configure/chef/recipes/main"
25
+ end
26
+
27
+ def recipe file=nil, o={}, &block
28
+ if file
29
+ ::FileUtils.mkdir_p "#{basedir}/recipes" unless ::File.directory? basedir
30
+
31
+ unless ::File.file?(file)
32
+ tfile = Tempfile.new("main-poolparty-recipe")
33
+ tfile << file # copy the string into the temp file
34
+ file = tfile.path
35
+ end
36
+
37
+ ::File.cp file, "#{basedir}/recipes/default.rb"
38
+
39
+ templates o[:templates] if o[:templates]
40
+
41
+ recipe_files << basedir
42
+ # TODO: Enable neat syntax from within poolparty
43
+ else
44
+ raise <<-EOR
45
+ PoolParty currently only supports passing recipes as files. Please specify a file in your chef block and try again"
46
+ EOR
47
+ end
48
+ end
49
+
50
+ def templates templates=[]
51
+ if templates
52
+ ::FileUtils.mkdir_p "#{basedir}/templates/default/"
53
+ templates.each do |f|
54
+ if ::File.file?(f)
55
+ ::File.cp f, "#{basedir}/templates/default/#{::File.basename(f)}"
56
+ elsif ::File.directory?(f)
57
+ Dir["#{f}/*"].each {|f| ::File.cp f, "#{basedir}/templates/default/#{::File.basename(f)}" }
58
+ else
59
+ tfile = Tempfile.new("main-poolparty-recipe")
60
+ tfile << f # copy the string into the temp file
61
+ ::File.cp tfile.path, "#{basedir}/templates/default/#{::File.basename(f)}"
62
+ end
63
+ end
64
+ end
65
+ end
66
+
67
+ def json file=nil, &block
68
+ if @json_file
69
+ @json_file
70
+ else
71
+ if file
72
+ if ::File.file? file
73
+ ::File.cp file, "#{Default.tmp_path}/dr_configure/dna.json"
74
+ elsif file.is_a?(String)
75
+ ::File.open("#{Default.tmp_path}/dr_configure/dna.json", "w+"){|tf| tf << file } # is really a string
76
+ else
77
+ raise <<-EOM
78
+ Your json must either point to a file that exists or a string. Please check your configuration and try again
79
+ EOM
80
+ end
81
+ @json_file = "#{Default.tmp_path}/dr_configure/dna.json"
82
+ else
83
+ unless @recipe
84
+ @recipe = ChefRecipe.new
85
+ @recipe.instance_eval &block if block
86
+ @recipe.recipes(recipe_files.empty? ? ["poolparty"] : ["poolparty", "main"])
87
+ ::File.open("#{Default.tmp_path}/dr_configure/dna.json", "w+") {|f| f << @recipe.options.to_json }
88
+ @json_file = "#{Default.tmp_path}/dr_configure/dna.json"
89
+ end
90
+ end
91
+ end
92
+ end
93
+
94
+ def include_recipes *recps
95
+ unless recps.empty?
96
+ recps.each do |rcp|
97
+ Dir[::File.expand_path(rcp)].each do |f|
98
+ added_recipes << f
99
+ end
100
+ end
101
+ end
102
+ end
103
+
104
+ def config file=""
105
+ if @config_file
106
+ @config_file
107
+ else
108
+ if ::File.file? file
109
+ @config_file = file
110
+ else
111
+ conf_string = if file.empty?
112
+ # default config
113
+ <<-EOE
114
+ cookbook_path "/etc/chef/cookbooks"
115
+ node_path "/etc/chef/nodes"
116
+ log_level :info
117
+ file_store_path "/etc/chef"
118
+ file_cache_path "/etc/chef"
119
+ EOE
120
+ else
121
+ open(file).read
122
+ end
123
+ ::File.open("#{Default.tmp_path}/dr_configure/chef_config.rb", "w+") do |tf|
124
+ tf << conf_string
125
+ end
126
+ @config_file = "#{Default.tmp_path}/dr_configure/chef_config.rb"
127
+ end
128
+ end
129
+ end
130
+
131
+ def added_recipes
132
+ @added_recipes ||= []
133
+ end
134
+
135
+ def after_create
136
+ before_configure
137
+ end
138
+
139
+ def before_configure
140
+ config
141
+ json
142
+
143
+ if ::File.directory?("/etc/chef")
144
+ ::Suitcase::Zipper.add("/etc/chef/cookbooks/*", "chef/recipes")
145
+ ::Suitcase::Zipper.add("/etc/chef/dna.json", "chef/json")
146
+ ::Suitcase::Zipper.add("/etc/chef/solo.rb", "chef/")
147
+ end
148
+
149
+ ::Suitcase::Zipper.add(@config_file, "chef")
150
+ added_recipes.each do |rcp|
151
+ # ::FileUtils.cp_r rcp, "/tmp/poolparty/dr_configure/recipes/"
152
+ ::Suitcase::Zipper.add(rcp, "chef/recipes")
153
+ end
154
+
155
+ ::Suitcase::Zipper.add(@json_file, "chef/json")
156
+ configure_commands ["cp -f /var/poolparty/dr_configure/chef/json/dna.json /etc/chef/dna.json"]
157
+
158
+ recipe_files.each do |rf|
159
+ ::FileUtils.mkdir_p "/tmp/poolparty/dr_configure/recipes/#{::File.basename(rf)}"
160
+ ::FileUtils.cp_r rf, "/tmp/poolparty/dr_configure/recipes/#{::File.basename(rf)}"
161
+ # ::Suitcase::Zipper.add(rf, "chef/recipes")
162
+ end
163
+ end
164
+
165
+ end
166
+
167
+ end
168
+ end
@@ -0,0 +1,47 @@
1
+ =begin rdoc
2
+ DeployDirectory
3
+
4
+ Deploy directory will tar.gz a local directory and sync it up to
5
+ the master instance of the cloud. This enables you to send a directory
6
+ up to the cloud and let the master host it for the remote slaves
7
+ =end
8
+ module PoolParty
9
+ class Deploydirectory
10
+
11
+ virtual_resource(:deploy_directory) do
12
+
13
+ def loaded(opts={}, &block)
14
+ # raise(Exception.new("You must include a directory for the git repos set by :at")) if at?.nil?
15
+ # opts.has_key?(:at) ? at(opts.delete(:at)) : raise(Exception.new("You must include a directory for the git repos set by :at"))
16
+
17
+ package_deploy_directory
18
+ add_unpack_directory
19
+ end
20
+
21
+ def package_deploy_directory
22
+ ::Suitcase::Zipper.add(sync_dir, "user_directory/")
23
+ end
24
+
25
+ def add_unpack_directory
26
+ has_directory("#{::File.dirname(basedir)}")
27
+
28
+ has_exec("unpack-#{::File.basename(basedir)}-deploy-directory") do
29
+ requires get_directory("#{::File.dirname(basedir)}")
30
+ cwd basedir
31
+ onlyif "test -f #{basedir}/#{sync_dir}"
32
+ command "cd #{cwd}; cp -R /var/poolparty/dr_configure/user_directory/#{sync_dir}; rm -rf /var/poolparty/dr_configure/#{name}"
33
+ end
34
+ end
35
+
36
+ def from(dir)
37
+ sync_dir dir
38
+ end
39
+
40
+ def to(dir)
41
+ basedir dir
42
+ end
43
+
44
+ end
45
+
46
+ end
47
+ end
@@ -0,0 +1,66 @@
1
+ module PoolParty
2
+ class GitResource
3
+
4
+ virtual_resource(:git) do
5
+ def loaded(*args)
6
+ has_package(:name => "git-core")
7
+ end
8
+ end
9
+
10
+ virtual_resource(:git_repos) do
11
+
12
+ def loaded(opts={}, &block)
13
+ raise(Exception.new("You must include a directory for the git repos set by :at")) if at?.nil?
14
+ # opts.has_key?(:at) ? at(opts.delete(:at)) : raise(Exception.new("You must include a directory for the git repos set by :at"))
15
+ # opts.has_key?(:source) ? git_repos(opts.delete(:source) || opts[:name]) : raise(Exception.new("You must include the git source set by :source"))
16
+ has_package("git-core")
17
+ has_git_repository
18
+ end
19
+
20
+ def has_git_repository
21
+
22
+ has_directory(::File.dirname(working_dir))
23
+ has_directory(:name => "#{working_dir}", :requires => get_directory("#{::File.dirname(working_dir)}"))
24
+
25
+ has_exec(:name => "git-#{name}", :requires => [get_directory("#{working_dir}"), get_package("git-core")] ) do
26
+ # Cloud, GitRepos, Exec
27
+ command parent.requires_user? ? "git clone #{requires_user}@#{source} #{working_dir}" : "cd #{working_dir} && git clone #{source}"
28
+ cwd "#{working_dir if working_dir}"
29
+ creates creates_dir
30
+ end
31
+ has_exec(:name => "update-#{name}", :cwd => ::File.dirname( creates_dir )) do
32
+ command "git pull"
33
+ end
34
+ if owner?
35
+ has_exec(:name => "chown-#{name}", :cwd => ::File.dirname( creates_dir )) do
36
+ command "chown #{owner} * -R"
37
+ end
38
+ end
39
+ end
40
+
41
+ def git_repos(src)
42
+ source src
43
+ end
44
+
45
+ def at(dir)
46
+ working_dir dir
47
+ end
48
+
49
+ def to(dir)
50
+ at(dir)
51
+ end
52
+
53
+ def creates_dir
54
+ "#{::File.join( working_dir, ::File.basename(source, ::File.extname(source)) )}/.git"
55
+ end
56
+
57
+ # Since git is not a native type, we have to say which core resource
58
+ # it is using to be able to require it
59
+ def class_type_name
60
+ "exec"
61
+ end
62
+
63
+ end
64
+
65
+ end
66
+ end
@@ -0,0 +1,13 @@
1
+ module PoolParty
2
+ class LineInFile
3
+
4
+ virtual_resource(:line_in_file) do
5
+ def loaded(opts={}, &block)
6
+ has_exec "line_in_#{file}" do
7
+ command "grep -q \'#{line.safe_quote}\' #{file} || echo \'#{line.safe_quote}\' >> #{file}"
8
+ end
9
+ end
10
+ end
11
+
12
+ end
13
+ end
@@ -0,0 +1,28 @@
1
+ module PoolParty
2
+ class Rsyncmirror
3
+
4
+ virtual_resource(:rsyncmirror) do
5
+
6
+ def loaded(opts={})
7
+ execute_on_node do
8
+ @dir = dir || name
9
+ has_exec(opts.merge({:command => "#{cloud.remote_rsync_command} --no-implied-dirs --delete-excluded #{Default.user}@master:#{@dir}/ #{@dir}/".safe_quote, :name => "rsync-#{name}"}))
10
+ end
11
+ end
12
+
13
+ # Since git is not a native type, we have to say which core resource
14
+ # it is using to be able to require it
15
+ def class_type_name
16
+ "exec"
17
+ end
18
+
19
+ # Because we are requiring an exec, instead of a built-in package of the git, we have to overload
20
+ # the to_s method and prepend it with the same name as above
21
+ def key
22
+ "rsync-#{name}"
23
+ end
24
+
25
+ end
26
+
27
+ end
28
+ end