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,96 @@
1
+ module PoolParty
2
+ class Runit
3
+ define_resource(:runitservice) do
4
+ def has_runit_service(name="runitservice", downif="", templatedir="")
5
+ path = copy_templates_from_templatedir(templatedir)
6
+ call_custom_function <<-EOC
7
+ runit_service {
8
+ "#{name}":
9
+ directory => "/etc/sv",
10
+ downif => "/bin/ps aux | grep -v grep | grep -q #{downif}",
11
+ templatedir => "#{path}";
12
+ }
13
+ EOC
14
+ end
15
+
16
+ def copy_templates_from_templatedir(dir=nil)
17
+ raise TemplateNotFound.new("template directory given") unless dir
18
+ raise TemplateNotFound.new("template directory cannot be found #{dir}") unless ::File.readable?(dir)
19
+ copy_directory_into_template_storage_directory(dir)
20
+ end
21
+
22
+ custom_function <<-EOF
23
+ define runit_service ($directory = "/etc/sv", $downif = "/bin/false", $templatedir) {
24
+
25
+ file { "$directory-$name":
26
+ path => "$directory/$name",
27
+ ensure => directory,
28
+ owner => root,
29
+ group => root,
30
+ mode => 0755,
31
+ require => Class["runit"]
32
+ }
33
+
34
+ file { "$directory/$name/log":
35
+ ensure => directory,
36
+ owner => root,
37
+ group => root,
38
+ mode => 0755,
39
+ require => File["$directory-$name"]
40
+ }
41
+
42
+ file { "$directory/$name/log/main":
43
+ ensure => directory,
44
+ owner => root,
45
+ group => root,
46
+ mode => 0755,
47
+ require => File["$directory/$name/log"]
48
+ }
49
+
50
+ file { "/etc/init.d/$name":
51
+ ensure => $lsbdistid ? {
52
+ 'CentOS' => "/usr/local/bin/sv",
53
+ default => "/usr/bin/sv",
54
+ },
55
+ require => [ File["$directory/$name/run"], File["$directory/$name/log/run"] ]
56
+ }
57
+
58
+ file { "/var/service/$name":
59
+ ensure => "$directory/$name",
60
+ require => [ File["$directory-$name"], File["$directory/$name/run"], File["$directory/$name/log/run"] ]
61
+ }
62
+
63
+ file { "$directory/$name/log/run":
64
+ content => template("$templatedir/log-run.erb"),
65
+ owner => root,
66
+ group => root,
67
+ mode => 755,
68
+ require => File["$directory/$name/log"],
69
+ notify => Service[$name]
70
+ }
71
+
72
+ file { "$directory/$name/run":
73
+ content => template("$templatedir/run.erb"),
74
+ owner => root,
75
+ group => root,
76
+ mode => 755,
77
+ require => File["$directory-$name"],
78
+ notify => Service[$name]
79
+ }
80
+
81
+ service { "$name":
82
+ hasrestart => true,
83
+ hasstatus => true,
84
+ require => File["/etc/init.d/$name"]
85
+ }
86
+
87
+ exec { "$name-down":
88
+ command => "/etc/init.d/$name down",
89
+ onlyif => $downif,
90
+ require => File["/etc/init.d/$name"]
91
+ }
92
+ }
93
+ EOF
94
+ end
95
+ end
96
+ end
@@ -0,0 +1,48 @@
1
+ module PoolParty
2
+ class Svn
3
+
4
+ define_resource(:svn) do
5
+
6
+ def has_svnpath(opts={})
7
+ call_custom_function <<-EOE
8
+ svnserve { #{opts[:name]}:
9
+ source => "#{opts[:source]}",
10
+ path => "#{opts[:path]}",
11
+ user => "#{opts[:user] || false}",
12
+ password => "#{opts[:password] || ""}"
13
+ }
14
+ EOE
15
+ end
16
+
17
+ custom_function <<-EOF
18
+ # Serve subversion-based code from a local location. The job of this
19
+ # module is to check the data out from subversion and keep it up to
20
+ # date, especially useful for providing data to your Puppet server.
21
+ define svnserve($source, $path, $user = false, $password = false) {
22
+ file { $path:
23
+ ensure => directory,
24
+ owner => root,
25
+ group => root
26
+ }
27
+ $svncmd = $user ? {
28
+ false => "/usr/bin/svn co --non-interactive $source/$name .",
29
+ default => "/usr/bin/svn co --non-interactive --username $user --password '$password' $source/$name ."
30
+ }
31
+ exec { "svnco-$name":
32
+ command => $svncmd,
33
+ cwd => $path,
34
+ require => File[$path],
35
+ creates => "$path/.svn"
36
+ }
37
+ exec { "svnupdate-$name":
38
+ command => "/usr/bin/svn update",
39
+ require => Exec["svnco-$name"],
40
+ onlyif => '/usr/bin/svn status -u --non-interactive | /bin/grep "\*"',
41
+ cwd => $path
42
+ }
43
+ }
44
+ EOF
45
+ end
46
+
47
+ end
48
+ end
@@ -0,0 +1,216 @@
1
+ require File.dirname(__FILE__) + "/plugin_model"
2
+ require File.dirname(__FILE__) + "/resource"
3
+
4
+ module PoolParty
5
+ module Cloud
6
+ def cloud(name=:app, &block)
7
+ clouds[name] ||= Cloud.new(name, &block)
8
+ end
9
+
10
+ def clouds
11
+ $clouds ||= {}
12
+ end
13
+
14
+ def with_cloud(cl, opts={}, &block)
15
+ raise CloudNotFoundException.new("Cloud not found") unless cl
16
+ cl.options.merge!(opts) if opts
17
+ cl.run_in_context &block if block
18
+ end
19
+
20
+ class Cloud < PoolParty::PoolPartyBaseClass
21
+ attr_reader :templates, :cloud_name, :remote_base
22
+
23
+ include CloudResourcer
24
+ include PoolParty::PluginModel
25
+ include PoolParty::Resources
26
+ include PoolParty::DependencyResolverCloudExtensions
27
+ include PrettyPrinter
28
+
29
+ # Net methods
30
+ include ::PoolParty::Remote
31
+ include PoolParty::CloudDsl
32
+ # include PoolParty::Monitors
33
+
34
+ def verbose
35
+ true
36
+ end
37
+
38
+ def self.immutable_methods
39
+ [:name]
40
+ end
41
+
42
+ def self.method_added sym
43
+ raise "Exception: #{sym.to_s.capitalize} method has been redefined" if immutable_methods.include?(sym) && !respond_to?(sym)
44
+ end
45
+
46
+ alias :name :cloud_name
47
+
48
+ # Call the remoter commands on the cloud if they don't exist on the cloud itself
49
+ # This gives the cloud access to the remote_base's methods
50
+ def method_missing(m, *args, &block)
51
+ remote_base.respond_to?(m) ? remote_base.send(m, *args, &block) : super
52
+ end
53
+
54
+ default_options(
55
+ :minimum_instances => 2,
56
+ :maximum_instances => 5,
57
+ :access_key => Default.access_key,
58
+ :secret_access_key => Default.secret_access_key,
59
+ :ec2_dir => ENV["EC2_HOME"],
60
+ :minimum_runtime => Default.minimum_runtime,
61
+ :user => Default.user
62
+ )
63
+
64
+ # Freeze the cloud_name so we can't modify it at all, set the plugin_directory
65
+ # call and run instance_eval on the block and then call the after_create callback
66
+ def initialize(name, &block)
67
+ @cloud_name = name
68
+ @cloud_name.freeze
69
+ plugin_directory "#{pool_specfile ? ::File.dirname(pool_specfile) : Dir.pwd}/plugins"
70
+ super
71
+
72
+ after_create
73
+ end
74
+
75
+ # Fetch the name of the cloud
76
+ def name(*args)
77
+ @cloud_name ||= @cloud_name ? @cloud_name : (args.empty? ? :default_cloud : args.first)
78
+ end
79
+
80
+ # Callback
81
+ # called after the cloud has been created, everything has run and is set at this point
82
+ # here the base requirements are added as well as an empty chef recipe is called
83
+ # Also, the after_create hook on the plugins used by the cloud are called here
84
+ def after_create
85
+ dputs "In after create"
86
+ ::FileUtils.mkdir_p("#{Default.tmp_path}/dr_configure")
87
+ run_in_context do
88
+ add_poolparty_base_requirements
89
+ chef do
90
+ end
91
+ end
92
+ plugin_store.each {|a| a.after_create }
93
+ setup_defaults
94
+ end
95
+
96
+ # setup defaults for the cloud
97
+ def setup_defaults
98
+ # this can be overridden in the spec, but ec2 is the default
99
+ using :ec2
100
+ options[:keypair] ||= keypair.basename rescue nil
101
+ options[:rules] = {:expand => expand_when, :contract => contract_when}
102
+ dependency_resolver 'chef'
103
+ end
104
+
105
+ # provide list of public ips to get into the cloud
106
+ def ips
107
+ list_of_running_instances.map {|ri| ri.ip }
108
+ end
109
+
110
+ # TODO: make this be a random ip, since we should not rely on it being the same each time
111
+ def ip
112
+ ips.first
113
+ end
114
+
115
+ # Build the new poolparty manifest
116
+ # Wrapping all of these requirements into the one
117
+ # poolparty class.
118
+ #
119
+ # TODO: Consider the benefits of moving all the manifest
120
+ # classes to separate files and keeping the containing
121
+ # references in the include
122
+ def build_and_store_new_config_file(filepath=nil, force=false)
123
+ filepath ||= ::File.join(Default.storage_directory, "poolparty.pp")
124
+ # write_properties_hash if debugging
125
+ vputs "Building new manifest configuration file (forced: #{force})"
126
+ manifest = force ? rebuild_manifest : build_manifest
127
+ ::File.open(filepath, "w") do |file|
128
+ file << manifest
129
+ end
130
+ end
131
+
132
+ # If there is a directory named monitors in the same directory
133
+ # as the pool specification file is in,
134
+ # then create a monitors directory in the storage directory
135
+ # and mirror the two. When PoolParty "boots" up, it scans
136
+ # the monitors directory for any custom monitors
137
+ # that are in known locations, these are included
138
+ def copy_custom_monitors
139
+ unless Default.custom_monitor_directories.empty?
140
+ Default.custom_monitor_directories.each do |dir|
141
+ Dir["#{dir}/*.rb"].each {|f| ::Suitcase::Zipper.add(f, "monitors")}
142
+ end
143
+ end
144
+ end
145
+
146
+ #FIXME MOVE TO DEPENDECY RESOL
147
+ # Configuration files
148
+ def build_manifest
149
+ vputs "Building manifest"
150
+ @build_manifest ||= build_from_existing_file
151
+ unless @build_manifest
152
+ props = to_properties_hash
153
+
154
+ @build_manifest = options[:dependency_resolver].send(:compile, props, self)
155
+ end
156
+ @build_manifest
157
+ end
158
+
159
+ def rebuild_manifest
160
+ @build_manifest = nil
161
+ build_manifest
162
+ end
163
+
164
+ # If the
165
+ def build_from_existing_file
166
+ ::FileTest.file?("#{Default.base_config_directory}/poolparty.pp") ? open("#{Default.base_config_directory}/poolparty.pp").read : nil
167
+ end
168
+
169
+ def write_properties_hash(filename=::File.join(Default.tmp_path, Default.properties_hash_filename) )
170
+ file_path = ::File.dirname(filename)
171
+ file_name = "#{::File.basename(filename, ::File.extname(filename))}_#{name}#{::File.extname(filename)}"
172
+ output = to_properties_hash.to_json
173
+ ::File.open("#{file_path}/#{file_name}", "w") {|f| f.write output }
174
+ true
175
+ end
176
+
177
+ # Callbacks on bootstrap and configuration
178
+ %w( before_bootstrap
179
+ after_bootstrap
180
+ before_configure
181
+ after_configure).each do |meth|
182
+ module_eval <<-EOE
183
+ def call_#{meth}_callbacks
184
+ plugin_store.each {|a| a.#{meth} }
185
+ end
186
+ EOE
187
+ end
188
+
189
+ # Add all the poolparty requirements here
190
+ # NOTE: These are written as plugins in the lib/poolparty/base_packages directory
191
+ # for examples.
192
+ # Also note that there is no block associated. This is because we have written
193
+ # all that is necessary in a method called enable
194
+ # which is called when there is no block
195
+ def add_poolparty_base_requirements
196
+ poolparty_base_haproxy
197
+ poolparty_base_heartbeat
198
+ poolparty_base_ruby
199
+ poolparty_base_packages
200
+ end
201
+
202
+ def other_clouds
203
+ arr = []
204
+ clouds.each do |name, cl|
205
+ arr << cl if name != self.name
206
+ end
207
+ arr
208
+ end
209
+
210
+ def reset!
211
+ reset_remoter_base!
212
+ @build_manifest = @describe_instances = @remote_instances_list = nil
213
+ end
214
+ end
215
+ end
216
+ end
@@ -0,0 +1,45 @@
1
+ require File.dirname(__FILE__) + "/resource"
2
+
3
+ module PoolParty
4
+ def available_custom_resources
5
+ $available_custom_resources ||= []
6
+ end
7
+
8
+ module Resources
9
+
10
+ def call_custom_function(str, opts={}, &block)
11
+ add_resource(:call_function, opts.merge({:str => str, :name => str.keyerize}), &block)
12
+ end
13
+
14
+ # Resources for function call
15
+ class CallFunction < Resource
16
+ def to_string(pre="")
17
+ returning Array.new do |arr|
18
+ arr << "#{pre}#{str}"
19
+ end.join("\n")
20
+ end
21
+ end
22
+
23
+ class CustomResource < Resource
24
+ def self.inherited(subclass)
25
+ PoolParty::Resources.available_custom_resources << subclass
26
+ super
27
+ end
28
+
29
+ def to_string(pre="")
30
+ returning Array.new do |output|
31
+ output << "#{pre} # Custom Functions\n"
32
+ output << self.class.custom_functions_to_string(pre)
33
+ end.join("\n")
34
+ end
35
+ end
36
+
37
+ # Stub methods
38
+ # TODO: Find a better solution
39
+ def custom_function(*args, &block)
40
+ end
41
+ def self.custom_function(*args, &block)
42
+ end
43
+
44
+ end
45
+ end
@@ -0,0 +1,167 @@
1
+ =begin rdoc
2
+ Base
3
+ This handles user interaction, loading the parameters, etc.
4
+ =end
5
+ require "open-uri"
6
+ require "ftools"
7
+ module PoolParty
8
+ class Default
9
+ include Dslify
10
+
11
+ # def self.options
12
+ default_options(
13
+ :testing => false,
14
+ :debugging => false,
15
+ :minimum_instances => 2,
16
+ :maximum_instances => 5,
17
+ :user => "root", # This should change here
18
+ :base_keypair_path => "#{ENV["HOME"]}/.ec2",
19
+ :base_ssh_path => "#{ENV["HOME"]}/.ssh",
20
+ :tmp_path => "/tmp/poolparty",
21
+ :poolparty_home_path => "#{ENV["HOME"]}/.poolparty",
22
+ :remote_storage_path => "/var/poolparty",
23
+ :remote_gem_path => "/var/poolparty/gems",
24
+ :fileserver_base => "puppet://master/files",
25
+ :base_config_directory => "/etc/poolparty",
26
+ :template_directory => "templates",
27
+ :template_path => "/var/lib/puppet/templates",
28
+ :module_path => "/etc/puppet/modules/poolparty",
29
+ :default_specfile_name => "clouds.rb",
30
+ :properties_hash_filename => "clouds.json",
31
+ :vendor_path => "#{::File.dirname(__FILE__)}/../../../vendor",
32
+ :port => "80",
33
+ :forwarding_port => "8080",
34
+ :monitor_port => 8081,
35
+ :proxy_mode => "http",
36
+ :messenger_client_port => 7050,
37
+ :butterfly_port => 8642,
38
+ :minimum_runtime => 3000, #50.minutes in seconds
39
+ :contract_when => "load < 0.25",
40
+ :expand_when => "load > 0.9",
41
+ # :agent_pid_file => ::File.readable?("/var/run/poolparty_agent.pid") ? "/var/run/agent.pid" : "#{Dir.pwd}/agent.pid",
42
+ # :agent_port => 8081,
43
+ # EC2 Options
44
+ :ami => "ami-7cfd1a15",
45
+ :size => 'm1.small', # must be 'm1.small', 'm1.large', 'm1.xlarge', 'c1.medium', or 'c1.xlarge' #TODO: change to instance_size
46
+ :availabilty_zone => "us-east-1a",
47
+ :security_group => ["default"],
48
+ # Options that should not be touched pretty much ever
49
+ :manifest_path => "/etc/puppet/manifests"
50
+ )
51
+
52
+ def options
53
+ default_options
54
+ end
55
+
56
+ # Class methods
57
+ class << self
58
+ def method_missing(m,*a,&block)
59
+ default_options.include?(m) ? default_options[m] : super
60
+ end
61
+ def options
62
+ default_options
63
+ end
64
+ # Get the access_key
65
+ def access_key
66
+ @access_key ||= load_access_keys_from_environment_var || load_keys_from_file[:access_key]
67
+ end
68
+ def load_access_keys_from_environment_var
69
+ [ ENV["AWS_ACCESS_KEY"], ENV["AWS_ACCESS_KEY_ID"]].reject {|a| a.nil? }.first
70
+ end
71
+ def secret_access_key
72
+ @secret_access_key ||= load_secret_access_keys_from_environment_var || load_keys_from_file[:secret_access_key]
73
+ end
74
+ def load_secret_access_keys_from_environment_var
75
+ [ ENV["AWS_SECRET_ACCESS_KEY"] ].reject {|a| a.nil? }.first
76
+ end
77
+ def read_keyfile
78
+ open(get_working_key_file_locations).read
79
+ end
80
+ def load_keys_from_file
81
+ @keys ||= get_working_key_file_locations ? YAML::load( read_keyfile ) : {}
82
+ end
83
+ # Store the keys in a yaml format to give the master access
84
+ # So that the master has access to the files
85
+ def store_keys_in_file
86
+ unless access_key.nil? || secret_access_key.nil?
87
+ write_to_file( key_file_locations.first, YAML::dump({:access_key => access_key, :secret_access_key => secret_access_key}))
88
+ end
89
+ end
90
+ def store_keys_in_file_for(obj=nil)
91
+ if obj
92
+ @access_key = obj.access_key
93
+ @secret_access_key = obj.secret_access_key
94
+ end
95
+ store_keys_in_file
96
+ end
97
+ def reset!
98
+ @keys = nil
99
+ end
100
+ # Get the instance first instance file that exists on the system from the expected places
101
+ # denoted in the local_instances_list_file_locations
102
+ def get_working_key_file_locations
103
+ key_file_locations.reject {|f| f unless ::File.file?(f) }.first
104
+ end
105
+ # Expected places for the instances.list to be located at on the machine
106
+ def key_file_locations
107
+ [
108
+ ".ppkeys",
109
+ "#{Default.base_config_directory}/.ppkeys",
110
+ "#{Default.storage_directory}/ppkeys",
111
+ "~/.ppkeys",
112
+ "ppkeys"
113
+ ]
114
+ end
115
+ def properties_hash_file
116
+ [
117
+ Default.base_config_directory,
118
+ Dir.pwd
119
+ ].collect do |dir|
120
+ full_dir = ::File.join(dir, Default.properties_hash_filename)
121
+ full_dir if ::File.file?(full_dir)
122
+ end.compact.first || "#{Default.base_config_directory}/#{Default.properties_hash_filename}"
123
+ end
124
+ def storage_directory
125
+ [
126
+ "/var/poolparty"
127
+ ].select do |dir|
128
+ dir if viable_directory?(dir)
129
+ end.first || ::File.join( "/tmp/poolparty")
130
+ end
131
+ def logger_location
132
+ [
133
+ "/var/log/poolparty"
134
+ ].select do |dir|
135
+ dir if viable_directory?(dir)
136
+ end.first
137
+ end
138
+ # Assume the logs will be at the pool.log location within the
139
+ # logger_location set above
140
+ def pool_logger_location
141
+ ::File.join(logger_location, "poolparty.log")
142
+ end
143
+ def custom_monitor_directories
144
+ [
145
+ "/var/poolparty/monitors",
146
+ "/etc/poolparty/monitors",
147
+ "#{Dir.pwd}/monitors"
148
+ ].select {|d| d if viable_directory?(d) }
149
+ end
150
+
151
+ def custom_modules_directories
152
+ [
153
+ "/var/poolparty/modules",
154
+ "/etc/poolparty/modules",
155
+ "#{Dir.pwd}/modules"
156
+ ].select {|d| d if viable_directory?(d) }
157
+ end
158
+ # Only return true if the directory we are reading is both readable
159
+ # and exists
160
+ def viable_directory?(dir)
161
+ ::File.directory?(dir) && ::File.readable?(dir)
162
+ end
163
+ end
164
+ #end of class methods
165
+
166
+ end
167
+ end
@@ -0,0 +1,75 @@
1
+ # STUB FOR NOW
2
+ # TODO
3
+ module PoolParty
4
+ class Key
5
+
6
+ attr_accessor :filepath
7
+
8
+ # Create a new key that defaults to id_rsa as the name.
9
+ def initialize(filepath=nil)
10
+ @filepath = (filepath.nil? || filepath.empty?) ? "id_rsa" : filepath
11
+ end
12
+
13
+ # If the full_filepath is nil, then the key doesn't exist
14
+ def exists?
15
+ full_filepath != nil
16
+ end
17
+
18
+ # Read the content of the key
19
+ def content
20
+ @content ||= exists? ? open(full_filepath).read : nil
21
+ end
22
+
23
+ # Returns the full_filepath of the key. If a full filepath is passed, we just return the expanded filepath
24
+ # for the keypair, otherwise query where it is against known locations
25
+ def full_filepath
26
+ @full_filepath ||= ::File.file?(::File.expand_path(filepath)) ? ::File.expand_path(filepath) : search_in_known_locations
27
+ end
28
+ alias :to_s :full_filepath
29
+
30
+ # Basename of the keypair
31
+ def basename
32
+ @basename ||= ::File.basename(full_filepath, ::File.extname(full_filepath)) rescue filepath
33
+ end
34
+
35
+ # Just the filename of the keypair
36
+ def filename
37
+ @filename ||= ::File.basename(full_filepath) rescue filepath
38
+ end
39
+
40
+ # Search for the key in default locations with the entire filepath
41
+ # if the file exists. If it doesn't exist in the default locations,
42
+ # then it returns nil and assumes we it doesn't exist
43
+ def search_in_known_locations
44
+ self.class.keypair_paths.each do |path|
45
+ full_path = ::File.join( ::File.expand_path(path), filepath)
46
+ return full_path if ::File.exists?(full_path)
47
+ end
48
+ nil
49
+ end
50
+
51
+ # Default locations to search for the key
52
+ def self.keypair_paths
53
+ [ "#{ENV["HOME"]}/.ssh",
54
+ "#{Default.poolparty_home_path}/keys",
55
+ Default.base_keypair_path,
56
+ Default.base_config_directory,
57
+ Default.base_ssh_path,
58
+ Default.remote_storage_path,
59
+ Dir.pwd
60
+ ]
61
+ end
62
+
63
+ # Support to add the enumerable each to keys
64
+ def each
65
+ yield full_filepath
66
+ end
67
+
68
+ # Turn the keypair into the a useful json string
69
+ def to_json
70
+ "{\"basename\":\"#{basename}\",
71
+ \"full_filepath\": \"/etc/poolparty/#{filename}\"}"
72
+ end
73
+
74
+ end
75
+ end
@@ -0,0 +1,28 @@
1
+ #todo: Deprecate
2
+ # =begin rdoc
3
+ # A logging class to allow us to log to locations
4
+ # =end
5
+ # class Loggable
6
+ # def initialize
7
+ # self.class.loggers << file_logger
8
+ # file_logger.level = :info
9
+ # end
10
+ # def file_logger
11
+ # @file_logger ||= Logging.logger( Default.pool_logger_location, logging_opts )
12
+ # end
13
+ # def stdout_logger
14
+ # @stdout_logger ||= Logging.logger(STDOUT, logging_opts.merge({:pattern => "%m\n"}))
15
+ # end
16
+ # def logging_opts
17
+ # {:pattern => "[%d] %-l : %m\n",
18
+ # :date_pattern => "%Y-%m-%d %H:%M:%S.%s"}
19
+ # end
20
+ # %w(info warn debug notice).each do |meth|
21
+ # define_method(meth.to_sym) do |*args|
22
+ # self.class.loggers.each {|l| l.send meth.to_sym, args}
23
+ # end
24
+ # end
25
+ # def self.loggers
26
+ # @loggers ||= []
27
+ # end
28
+ # end