fairchild-poolparty 1.1.4 → 1.1.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (333) hide show
  1. data/README.txt +0 -12
  2. data/Rakefile +17 -1
  3. data/VERSION.yml +1 -1
  4. data/bin/cloud +20 -1
  5. data/bin/cloud-bootstrap +14 -4
  6. data/bin/cloud-configure +26 -9
  7. data/bin/cloud-contract +7 -7
  8. data/bin/cloud-describe +28 -0
  9. data/bin/cloud-expand +13 -6
  10. data/bin/cloud-list +3 -5
  11. data/bin/cloud-osxcopy +1 -1
  12. data/bin/cloud-provision +1 -1
  13. data/bin/cloud-show +6 -5
  14. data/bin/cloud-ssh +1 -3
  15. data/bin/cloud-start +8 -6
  16. data/bin/cloud-terminate +9 -7
  17. data/bin/server-cloud-elections +29 -18
  18. data/bin/server-ensure-provisioning +24 -29
  19. data/bin/server-list-active +10 -5
  20. data/bin/server-monitor.ru +18 -1
  21. data/bin/server-update-hosts +3 -3
  22. data/bin/server-write-new-nodes +1 -1
  23. data/config/jeweler.rb +12 -3
  24. data/lib/poolparty/aska/aska.rb +1 -12
  25. data/lib/poolparty/base_packages/haproxy.rb +26 -18
  26. data/lib/poolparty/base_packages/poolparty.rb +1 -1
  27. data/lib/poolparty/capistrano.rb +1 -1
  28. data/lib/poolparty/core/array.rb +12 -0
  29. data/lib/poolparty/core/hash.rb +12 -5
  30. data/lib/poolparty/core/nil.rb +8 -0
  31. data/lib/poolparty/core/object.rb +15 -5
  32. data/lib/poolparty/core/string.rb +28 -2
  33. data/lib/poolparty/dependency_resolver/chef_resolver.rb +106 -79
  34. data/lib/poolparty/dependency_resolver/dependency_resolver.rb +1 -1
  35. data/lib/poolparty/dependency_resolver/dependency_resolver_cloud_extensions.rb +5 -4
  36. data/lib/poolparty/dependency_resolver/puppet_resolver.rb +44 -17
  37. data/lib/poolparty/helpers/console.rb +1 -1
  38. data/lib/poolparty/helpers/optioner.rb +9 -2
  39. data/lib/poolparty/lite.rb +12 -2
  40. data/lib/poolparty/modules/callbacks.rb +44 -0
  41. data/lib/poolparty/modules/cloud_dsl.rb +17 -11
  42. data/lib/poolparty/modules/cloud_resourcer.rb +29 -21
  43. data/lib/poolparty/modules/definable_resource.rb +1 -1
  44. data/lib/poolparty/modules/pinger.rb +28 -0
  45. data/lib/poolparty/modules/resourcing_dsl.rb +7 -3
  46. data/lib/poolparty/modules/thread_pool.rb +107 -106
  47. data/lib/poolparty/modules/user_helpers.rb +20 -0
  48. data/lib/poolparty/monitors/base_monitor.rb +32 -81
  49. data/lib/poolparty/monitors/monitor_rack.rb +60 -69
  50. data/lib/poolparty/monitors/monitors/favicon_monitor.rb +12 -0
  51. data/lib/poolparty/monitors/monitors/load_monitor.rb +9 -15
  52. data/lib/poolparty/monitors/monitors/memory_monitor.rb +48 -48
  53. data/lib/poolparty/monitors/monitors/neighborhood_monitor.rb +77 -0
  54. data/lib/poolparty/monitors/{stats_monitor.rb → monitors/stats_monitor.rb} +29 -24
  55. data/lib/poolparty/monitors/monitors/time_monitor.rb +15 -0
  56. data/lib/poolparty/net/messenger.rb +2 -0
  57. data/lib/poolparty/net/remoter/cloud_control.rb +177 -227
  58. data/lib/poolparty/net/remoter/connections.rb +10 -18
  59. data/lib/poolparty/net/remoter/interactive.rb +24 -90
  60. data/lib/poolparty/net/remoter_base.rb +98 -25
  61. data/lib/poolparty/net/remoter_bases/ec2/ec2.rb +83 -66
  62. data/lib/poolparty/net/remoter_bases/vmrun/utilities/vm_disk.rb +12 -0
  63. data/lib/poolparty/net/remoter_bases/vmrun/utilities/vmx.rb +33 -0
  64. data/lib/poolparty/net/remoter_bases/vmrun/utilities/vmx_file.rb +117 -0
  65. data/lib/poolparty/net/remoter_bases/vmrun/vmrun.rb +165 -0
  66. data/lib/poolparty/net/remoter_bases/vmrun/vmrun_instance.rb +71 -0
  67. data/lib/poolparty/{base_packages → plugins}/bind.rb +1 -1
  68. data/lib/poolparty/plugins/chef.rb +71 -71
  69. data/lib/poolparty/plugins/chef_deploy.rb +58 -0
  70. data/lib/poolparty/plugins/{deploydirectory.rb → deploy_directory.rb} +12 -3
  71. data/lib/poolparty/plugins/dynomite.rb +14 -0
  72. data/lib/poolparty/plugins/gem_package.rb +37 -0
  73. data/lib/poolparty/plugins/line_in_file.rb +1 -0
  74. data/lib/poolparty/plugins/nanite.rb +41 -0
  75. data/lib/poolparty/{base_packages → plugins}/tokyo_tyrant.rb +1 -1
  76. data/lib/poolparty/poolparty/cloud.rb +36 -35
  77. data/lib/poolparty/poolparty/default.rb +2 -11
  78. data/lib/poolparty/poolparty/key.rb +15 -12
  79. data/lib/poolparty/poolparty/neighborhoods.rb +54 -21
  80. data/lib/poolparty/poolparty/plugin.rb +6 -9
  81. data/lib/poolparty/poolparty/plugin_model.rb +5 -5
  82. data/lib/poolparty/poolparty/pool.rb +8 -4
  83. data/lib/poolparty/poolparty/poolparty_base_class.rb +20 -11
  84. data/lib/poolparty/poolparty/resource.rb +9 -5
  85. data/lib/poolparty/poolparty/service.rb +3 -1
  86. data/lib/poolparty/provision/boot_strapper.rb +47 -24
  87. data/lib/poolparty/provision/configurations/chef.rb +7 -4
  88. data/lib/poolparty/provision/dr_configure.rb +80 -25
  89. data/lib/poolparty/resources/cron.rb +8 -0
  90. data/lib/poolparty/resources/directory.rb +1 -1
  91. data/lib/poolparty/resources/file.rb +16 -0
  92. data/lib/poolparty/resources/package.rb +7 -2
  93. data/lib/poolparty/resources/service.rb +4 -3
  94. data/lib/poolparty/resources/symlink.rb +0 -8
  95. data/lib/poolparty/schema.rb +35 -20
  96. data/lib/poolparty/templates/haproxy.conf +27 -25
  97. data/lib/poolparty/templates/monitor.ru +3 -3
  98. data/lib/poolparty/verification/verifier_base.rb +17 -0
  99. data/lib/poolparty/verification/verifiers/ping.rb +17 -0
  100. data/lib/poolparty/verification/verify.rb +74 -0
  101. data/lib/poolparty.rb +8 -9
  102. data/lib/poolpartycl.rb +14 -0
  103. data/spec/bin/server-list-active_spec.rb +2 -0
  104. data/spec/poolparty/base_packages/haproxy_spec.rb +1 -1
  105. data/spec/poolparty/core/array_spec.rb +3 -1
  106. data/spec/poolparty/core/ordered_hash_spec.rb +2 -2
  107. data/spec/poolparty/dependency_resolver/chef_resolver_spec.rb +9 -15
  108. data/spec/poolparty/dependency_resolver/dependency_resolver_cloud_extensions_spec.rb +6 -6
  109. data/spec/poolparty/dependency_resolver/puppet_resolver_spec.rb +121 -124
  110. data/spec/poolparty/net/remote_spec.rb +287 -286
  111. data/spec/poolparty/net/remoter_bases/ec2_mocks_and_stubs.rb +1 -1
  112. data/spec/poolparty/net/remoter_bases/ec2_remote_instance_spec.rb +7 -8
  113. data/spec/poolparty/net/remoter_bases/ec2_spec.rb +22 -7
  114. data/spec/poolparty/net/remoter_spec.rb +48 -45
  115. data/spec/poolparty/poolparty/cloud_spec.rb +15 -22
  116. data/spec/poolparty/poolparty/key_spec.rb +4 -4
  117. data/spec/poolparty/poolparty/neighborhoods_spec.rb +1 -2
  118. data/spec/poolparty/poolparty/plugin_spec.rb +2 -2
  119. data/spec/poolparty/poolparty/resource_spec.rb +4 -5
  120. data/spec/poolparty/poolparty_base_class_spec.rb +82 -78
  121. data/spec/poolparty/resources/package_spec.rb +0 -3
  122. data/spec/poolparty/spec_helper.rb +4 -4
  123. data/tasks/development.rake +9 -0
  124. data/test/poolparty/core/array_test.rb +21 -0
  125. data/test/poolparty/core/hash_test.rb +14 -1
  126. data/test/poolparty/core/string_test.rb +29 -0
  127. data/test/poolparty/dependency_resolver/puppet_resolver_test.rb +106 -0
  128. data/test/poolparty/modules/callbacks_test.rb +40 -0
  129. data/test/poolparty/modules/cloud_dsl_test.rb +25 -0
  130. data/test/poolparty/net/remoter_bases/vmrun/vmrun_test.rb +50 -0
  131. data/test/poolparty/net/remoter_test.rb +14 -0
  132. data/test/poolparty/poolparty/neighborhood_test.rb +23 -0
  133. data/test/poolparty/poolparty/poolparty_base_class_test.rb +84 -0
  134. data/test/poolparty/verification/verify_test.rb +49 -0
  135. data/test/test_helper.rb +4 -1
  136. data/test/test_poolparty.rb +6 -5
  137. data/vendor/chef/apache2/attributes/apache.rb +1 -1
  138. data/vendor/chef/apache2/templates/default/default-site.erb +1 -1
  139. data/vendor/chef/chef-deploy/LICENSE +201 -0
  140. data/vendor/chef/chef-deploy/README.rdoc +24 -0
  141. data/vendor/chef/chef-deploy/Rakefile +57 -0
  142. data/vendor/chef/chef-deploy/TODO +4 -0
  143. data/vendor/chef/chef-deploy/lib/chef-deploy/cached_deploy.rb +230 -0
  144. data/vendor/chef/chef-deploy/lib/chef-deploy/git.rb +132 -0
  145. data/vendor/chef/chef-deploy/lib/chef-deploy/subversion.rb +98 -0
  146. data/vendor/chef/chef-deploy/lib/chef-deploy.rb +183 -0
  147. metadata +57 -252
  148. data/bin/cloud-run +0 -18
  149. data/bin/cloud-stats +0 -17
  150. data/bin/ec2-list-active +0 -24
  151. data/bin/pool +0 -31
  152. data/bin/pool-describe +0 -8
  153. data/bin/pool-generate +0 -18
  154. data/bin/pool-init +0 -28
  155. data/bin/pool-list +0 -30
  156. data/bin/pool-start +0 -26
  157. data/bin/server-list-instances +0 -15
  158. data/lib/erlang/messenger/Emakefile +0 -1
  159. data/lib/erlang/messenger/Makefile +0 -15
  160. data/lib/erlang/messenger/README +0 -5
  161. data/lib/erlang/messenger/Rakefile +0 -72
  162. data/lib/erlang/messenger/control +0 -11
  163. data/lib/erlang/messenger/ebin/client.app +0 -19
  164. data/lib/erlang/messenger/ebin/master.app +0 -19
  165. data/lib/erlang/messenger/ebin/node.app +0 -19
  166. data/lib/erlang/messenger/ebin/packager.app +0 -19
  167. data/lib/erlang/messenger/ebin/pm_client_rel-0.1.rel +0 -1
  168. data/lib/erlang/messenger/ebin/pm_master_rel-0.1.rel +0 -1
  169. data/lib/erlang/messenger/ebin/pm_node_rel-0.1.rel +0 -1
  170. data/lib/erlang/messenger/include/defines.hrl +0 -27
  171. data/lib/erlang/messenger/lib/eunit/AUTHORS +0 -2
  172. data/lib/erlang/messenger/lib/eunit/CHANGELOG +0 -14
  173. data/lib/erlang/messenger/lib/eunit/COPYING +0 -504
  174. data/lib/erlang/messenger/lib/eunit/Makefile +0 -28
  175. data/lib/erlang/messenger/lib/eunit/NOTES +0 -276
  176. data/lib/erlang/messenger/lib/eunit/README +0 -3
  177. data/lib/erlang/messenger/lib/eunit/doc/edoc-info +0 -3
  178. data/lib/erlang/messenger/lib/eunit/doc/erlang.png +0 -0
  179. data/lib/erlang/messenger/lib/eunit/doc/eunit.html +0 -172
  180. data/lib/erlang/messenger/lib/eunit/doc/index.html +0 -17
  181. data/lib/erlang/messenger/lib/eunit/doc/modules-frame.html +0 -12
  182. data/lib/erlang/messenger/lib/eunit/doc/overview-summary.html +0 -984
  183. data/lib/erlang/messenger/lib/eunit/doc/overview.edoc +0 -980
  184. data/lib/erlang/messenger/lib/eunit/doc/packages-frame.html +0 -11
  185. data/lib/erlang/messenger/lib/eunit/doc/stylesheet.css +0 -55
  186. data/lib/erlang/messenger/lib/eunit/ebin/autoload.beam +0 -0
  187. data/lib/erlang/messenger/lib/eunit/ebin/code_monitor.beam +0 -0
  188. data/lib/erlang/messenger/lib/eunit/ebin/eunit.app +0 -21
  189. data/lib/erlang/messenger/lib/eunit/ebin/eunit.appup +0 -1
  190. data/lib/erlang/messenger/lib/eunit/ebin/eunit.beam +0 -0
  191. data/lib/erlang/messenger/lib/eunit/ebin/eunit_autoexport.beam +0 -0
  192. data/lib/erlang/messenger/lib/eunit/ebin/eunit_data.beam +0 -0
  193. data/lib/erlang/messenger/lib/eunit/ebin/eunit_lib.beam +0 -0
  194. data/lib/erlang/messenger/lib/eunit/ebin/eunit_proc.beam +0 -0
  195. data/lib/erlang/messenger/lib/eunit/ebin/eunit_serial.beam +0 -0
  196. data/lib/erlang/messenger/lib/eunit/ebin/eunit_server.beam +0 -0
  197. data/lib/erlang/messenger/lib/eunit/ebin/eunit_striptests.beam +0 -0
  198. data/lib/erlang/messenger/lib/eunit/ebin/eunit_test.beam +0 -0
  199. data/lib/erlang/messenger/lib/eunit/ebin/eunit_tests.beam +0 -0
  200. data/lib/erlang/messenger/lib/eunit/ebin/eunit_tty.beam +0 -0
  201. data/lib/erlang/messenger/lib/eunit/ebin/file_monitor.beam +0 -0
  202. data/lib/erlang/messenger/lib/eunit/examples/eunit_examples.erl +0 -339
  203. data/lib/erlang/messenger/lib/eunit/examples/fib.erl +0 -19
  204. data/lib/erlang/messenger/lib/eunit/examples/tests.txt +0 -1
  205. data/lib/erlang/messenger/lib/eunit/include/eunit.hrl +0 -313
  206. data/lib/erlang/messenger/lib/eunit/src/Makefile +0 -46
  207. data/lib/erlang/messenger/lib/eunit/src/autoload.erl +0 -388
  208. data/lib/erlang/messenger/lib/eunit/src/code_monitor.erl +0 -243
  209. data/lib/erlang/messenger/lib/eunit/src/eunit.app.src +0 -21
  210. data/lib/erlang/messenger/lib/eunit/src/eunit.appup.src +0 -1
  211. data/lib/erlang/messenger/lib/eunit/src/eunit.erl +0 -196
  212. data/lib/erlang/messenger/lib/eunit/src/eunit_autoexport.erl +0 -102
  213. data/lib/erlang/messenger/lib/eunit/src/eunit_data.erl +0 -798
  214. data/lib/erlang/messenger/lib/eunit/src/eunit_internal.hrl +0 -48
  215. data/lib/erlang/messenger/lib/eunit/src/eunit_lib.erl +0 -682
  216. data/lib/erlang/messenger/lib/eunit/src/eunit_proc.erl +0 -552
  217. data/lib/erlang/messenger/lib/eunit/src/eunit_serial.erl +0 -157
  218. data/lib/erlang/messenger/lib/eunit/src/eunit_server.erl +0 -340
  219. data/lib/erlang/messenger/lib/eunit/src/eunit_striptests.erl +0 -64
  220. data/lib/erlang/messenger/lib/eunit/src/eunit_test.erl +0 -334
  221. data/lib/erlang/messenger/lib/eunit/src/eunit_tests.erl +0 -45
  222. data/lib/erlang/messenger/lib/eunit/src/eunit_tty.erl +0 -272
  223. data/lib/erlang/messenger/lib/eunit/src/file_monitor.erl +0 -409
  224. data/lib/erlang/messenger/lib/eunit/sys.config +0 -9
  225. data/lib/erlang/messenger/lib/eunit/vsn.mk +0 -1
  226. data/lib/erlang/messenger/pm_client_rel-0.1.boot +0 -0
  227. data/lib/erlang/messenger/pm_client_rel-0.1.script +0 -238
  228. data/lib/erlang/messenger/pm_master_rel-0.1.boot +0 -0
  229. data/lib/erlang/messenger/pm_master_rel-0.1.script +0 -239
  230. data/lib/erlang/messenger/pm_node_rel-0.1.boot +0 -0
  231. data/lib/erlang/messenger/pm_node_rel-0.1.script +0 -237
  232. data/lib/erlang/messenger/src/client_app.erl +0 -39
  233. data/lib/erlang/messenger/src/client_server.erl +0 -60
  234. data/lib/erlang/messenger/src/master_app.erl +0 -39
  235. data/lib/erlang/messenger/src/node_app.erl +0 -39
  236. data/lib/erlang/messenger/src/pm_client.erl +0 -49
  237. data/lib/erlang/messenger/src/pm_client_supervisor.erl +0 -38
  238. data/lib/erlang/messenger/src/pm_cluster.erl +0 -61
  239. data/lib/erlang/messenger/src/pm_event_manager.erl +0 -27
  240. data/lib/erlang/messenger/src/pm_master.erl +0 -215
  241. data/lib/erlang/messenger/src/pm_master_event_handler.erl +0 -72
  242. data/lib/erlang/messenger/src/pm_master_supervisor.erl +0 -39
  243. data/lib/erlang/messenger/src/pm_node.erl +0 -200
  244. data/lib/erlang/messenger/src/pm_node_supervisor.erl +0 -38
  245. data/lib/erlang/messenger/src/pm_packager.erl +0 -76
  246. data/lib/erlang/messenger/src/pm_spawner.erl +0 -213
  247. data/lib/erlang/messenger/src/pm_strings.erl +0 -11
  248. data/lib/erlang/messenger/src/utils.erl +0 -72
  249. data/lib/erlang/messenger/useful_snippets +0 -17
  250. data/lib/poolparty/monitors/monitors/server_monitor.rb +0 -7
  251. data/lib/poolparty/monitors/monitors/web_monitor.rb +0 -18
  252. data/lib/poolparty/monitors/neighborhood_monitor.rb +0 -24
  253. data/lib/poolparty/monitors.rb +0 -6
  254. data/lib/poolparty/net/remoter/lists.rb +0 -12
  255. data/lib/poolparty/poolparty/custom_resource.rb +0 -45
  256. data/lib/poolparty/resources/custom_service.rb +0 -30
  257. data/lib/poolparty/services/gem_package.rb +0 -52
  258. data/lib/poolparty/version.rb +0 -15
  259. data/spec/poolparty/plugins/svn_spec.rb +0 -16
  260. data/spec/poolparty/poolparty/custom_resource_spec.rb +0 -79
  261. data/vendor/gems/butterfly/History.txt +0 -4
  262. data/vendor/gems/butterfly/PostInstall.txt +0 -2
  263. data/vendor/gems/butterfly/README.rdoc +0 -48
  264. data/vendor/gems/butterfly/Rakefile +0 -62
  265. data/vendor/gems/butterfly/VERSION.yml +0 -4
  266. data/vendor/gems/butterfly/bin/flutter +0 -4
  267. data/vendor/gems/butterfly/butterfly.gemspec +0 -37
  268. data/vendor/gems/butterfly/examples/config.ru +0 -15
  269. data/vendor/gems/butterfly/examples/my_app.rb +0 -12
  270. data/vendor/gems/butterfly/lib/butterfly.rb +0 -14
  271. data/vendor/gems/butterfly/lib/handler.rb +0 -48
  272. data/vendor/gems/butterfly/lib/request.rb +0 -29
  273. data/vendor/gems/butterfly/lib/response.rb +0 -49
  274. data/vendor/gems/butterfly/script/console +0 -10
  275. data/vendor/gems/butterfly/script/destroy +0 -14
  276. data/vendor/gems/butterfly/script/generate +0 -14
  277. data/vendor/gems/butterfly/test/test_adapter_base.rb +0 -23
  278. data/vendor/gems/butterfly/test/test_butterfly_request.rb +0 -46
  279. data/vendor/gems/butterfly/test/test_butterfly_response.rb +0 -43
  280. data/vendor/gems/butterfly/test/test_butterfly_server.rb +0 -16
  281. data/vendor/gems/butterfly/test/test_default.rb +0 -12
  282. data/vendor/gems/butterfly/test/test_helper.rb +0 -6
  283. data/vendor/gems/dslify/History.txt +0 -4
  284. data/vendor/gems/dslify/Manifest.txt +0 -25
  285. data/vendor/gems/dslify/PostInstall.txt +0 -5
  286. data/vendor/gems/dslify/README.txt +0 -60
  287. data/vendor/gems/dslify/Rakefile +0 -56
  288. data/vendor/gems/dslify/config/hoe.rb +0 -73
  289. data/vendor/gems/dslify/config/requirements.rb +0 -15
  290. data/vendor/gems/dslify/dslify.gemspec +0 -40
  291. data/vendor/gems/dslify/lib/dslify/dslify.rb +0 -69
  292. data/vendor/gems/dslify/lib/dslify/version.rb +0 -10
  293. data/vendor/gems/dslify/lib/dslify.rb +0 -7
  294. data/vendor/gems/dslify/script/console +0 -10
  295. data/vendor/gems/dslify/script/destroy +0 -14
  296. data/vendor/gems/dslify/script/generate +0 -14
  297. data/vendor/gems/dslify/script/txt2html +0 -82
  298. data/vendor/gems/dslify/setup.rb +0 -1585
  299. data/vendor/gems/dslify/tasks/deployment.rake +0 -34
  300. data/vendor/gems/dslify/tasks/environment.rake +0 -7
  301. data/vendor/gems/dslify/tasks/website.rake +0 -17
  302. data/vendor/gems/dslify/test/test_dslify.rb +0 -114
  303. data/vendor/gems/dslify/website/index.html +0 -86
  304. data/vendor/gems/dslify/website/index.txt +0 -83
  305. data/vendor/gems/dslify/website/javascripts/rounded_corners_lite.inc.js +0 -285
  306. data/vendor/gems/dslify/website/stylesheets/screen.css +0 -138
  307. data/vendor/gems/dslify/website/template.html.erb +0 -48
  308. data/vendor/gems/parenting/History.txt +0 -4
  309. data/vendor/gems/parenting/Manifest.txt +0 -13
  310. data/vendor/gems/parenting/PostInstall.txt +0 -2
  311. data/vendor/gems/parenting/README.rdoc +0 -47
  312. data/vendor/gems/parenting/Rakefile +0 -28
  313. data/vendor/gems/parenting/lib/parenting/base.rb +0 -65
  314. data/vendor/gems/parenting/lib/parenting.rb +0 -10
  315. data/vendor/gems/parenting/parenting.gemspec +0 -39
  316. data/vendor/gems/parenting/script/console +0 -10
  317. data/vendor/gems/parenting/script/destroy +0 -14
  318. data/vendor/gems/parenting/script/generate +0 -14
  319. data/vendor/gems/parenting/test/file_to_eval.rb +0 -9
  320. data/vendor/gems/parenting/test/test_helper.rb +0 -5
  321. data/vendor/gems/parenting/test/test_parenting.rb +0 -89
  322. data/vendor/gems/suitcase/LICENSE +0 -20
  323. data/vendor/gems/suitcase/README.rdoc +0 -31
  324. data/vendor/gems/suitcase/Rakefile +0 -57
  325. data/vendor/gems/suitcase/VERSION.yml +0 -4
  326. data/vendor/gems/suitcase/lib/suitcase/unzipper.rb +0 -15
  327. data/vendor/gems/suitcase/lib/suitcase/zipper.rb +0 -119
  328. data/vendor/gems/suitcase/lib/suitcase.rb +0 -5
  329. data/vendor/gems/suitcase/suitcase.gemspec +0 -32
  330. data/vendor/gems/suitcase/test/suitcase_test.rb +0 -102
  331. data/vendor/gems/suitcase/test/test_dir/box.rb +0 -1
  332. data/vendor/gems/suitcase/test/test_dir/test.txt +0 -1
  333. data/vendor/gems/suitcase/test/test_helper.rb +0 -12
@@ -1,6 +1,6 @@
1
1
  module PoolParty
2
2
  class Base
3
- plugin :poolparty_base_tokyo_tyrant do
3
+ plugin :tokyo_tyrant do
4
4
 
5
5
  def enable
6
6
  has_package "build-essential"
@@ -4,7 +4,7 @@ require File.dirname(__FILE__) + "/resource"
4
4
  module PoolParty
5
5
  module Cloud
6
6
  # Instantiate a new cloud
7
- def cloud(name=:app, &block)
7
+ def cloud(name, &block)
8
8
  clouds[name] ||= Cloud.new(name, &block)
9
9
  end
10
10
 
@@ -25,13 +25,15 @@ module PoolParty
25
25
 
26
26
  include CloudResourcer
27
27
  include PoolParty::PluginModel
28
- include PoolParty::Resources
28
+ include PoolParty::Resources
29
+ include PoolParty::Callbacks
29
30
  include PoolParty::DependencyResolverCloudExtensions
30
31
  include PrettyPrinter
31
32
 
32
33
  # Net methods
33
34
  include ::PoolParty::Remote
34
35
  include PoolParty::CloudDsl
36
+ include PoolParty::Verification
35
37
  # include PoolParty::Monitors
36
38
 
37
39
  def verbose
@@ -45,7 +47,7 @@ module PoolParty
45
47
  # Redefining methods are not allowed
46
48
  def self.method_added sym
47
49
  raise "Exception: #{sym.to_s.capitalize} method has been redefined" if immutable_methods.include?(sym) && !respond_to?(sym)
48
- end
50
+ end
49
51
 
50
52
  alias :name :cloud_name
51
53
 
@@ -68,6 +70,10 @@ module PoolParty
68
70
  :user => Default.user
69
71
  )
70
72
 
73
+ additional_callbacks [
74
+ "after_launch_instance"
75
+ ]
76
+
71
77
  # Freeze the cloud_name so we can't modify it at all, set the plugin_directory
72
78
  # call and run instance_eval on the block and then call the after_create callback
73
79
  def initialize(name, &block)
@@ -75,8 +81,8 @@ module PoolParty
75
81
  @cloud_name.freeze
76
82
 
77
83
  plugin_directory "#{pool_specfile ? ::File.dirname(pool_specfile) : Dir.pwd}/plugins"
84
+ before_create
78
85
  super
79
-
80
86
  after_create
81
87
  end
82
88
 
@@ -85,35 +91,48 @@ module PoolParty
85
91
  @cloud_name ||= @cloud_name ? @cloud_name : (args.empty? ? :default_cloud : args.first)
86
92
  end
87
93
 
94
+ def before_create
95
+ context_stack.push self
96
+ (parent ? parent : self).add_poolparty_base_requirements
97
+ context_stack.pop
98
+ end
99
+
88
100
  # Callback
89
101
  # called after the cloud has been created, everything has run and is set at this point
90
102
  # here the base requirements are added as well as an empty chef recipe is called
91
103
  # Also, the after_create hook on the plugins used by the cloud are called here
92
104
  def after_create
93
- dputs "In after create"
94
105
  ::FileUtils.mkdir_p("#{Default.tmp_path}/dr_configure")
106
+
95
107
  run_in_context do
96
- add_poolparty_base_requirements
108
+ add_optional_enabled_services
97
109
  chef do
98
110
  end
99
111
  end
100
- plugin_store.each {|a| a.after_create }
112
+
113
+ plugin_store.each {|a| a.call_after_create_callbacks }
101
114
  setup_defaults
115
+
116
+ setup_callbacks
102
117
  end
103
118
 
104
119
  # setup defaults for the cloud
105
120
  def setup_defaults
106
121
  # this can be overridden in the spec, but ec2 is the default
107
122
  using :ec2
108
- options[:keypair] ||= keypair.basename rescue nil
109
- options[:rules] = {:expand => expand_when, :contract => contract_when}
110
- dependency_resolver 'chef'
111
- enable :haproxy unless dsl_options[:haproxy] == :disabled
123
+ options[:keypair] ||= keypair rescue nil
124
+ options[:rules] = {:expand => dsl_options[:expand_when], :contract => dsl_options[:contract_when]}
125
+ dependency_resolver 'chef'
126
+ # enable :haproxy unless dsl_options[:haproxy] == :disabled
127
+ end
128
+
129
+ def after_launch_instance(inst=nil)
130
+ remote_base.send :after_launch_instance, inst
112
131
  end
113
132
 
114
133
  # provide list of public ips to get into the cloud
115
134
  def ips
116
- list_of_running_instances.map {|ri| ri.ip }
135
+ nodes(:status => "running").map {|ri| ri.ip }
117
136
  end
118
137
 
119
138
  # TODO: make this be a random ip, since we should not rely on it being the same each time
@@ -159,9 +178,10 @@ module PoolParty
159
178
  @build_manifest ||= build_from_existing_file
160
179
  unless @build_manifest
161
180
  props = to_properties_hash
162
-
181
+
163
182
  @build_manifest = options[:dependency_resolver].send(:compile, props, self)
164
183
  end
184
+ dputs "Finished creating manifest"
165
185
  @build_manifest
166
186
  end
167
187
 
@@ -172,6 +192,7 @@ module PoolParty
172
192
  end
173
193
 
174
194
  # If the pp already exists, then let's not recreate it
195
+ # TODO: Abstract
175
196
  def build_from_existing_file
176
197
  ::FileTest.file?("#{Default.base_config_directory}/poolparty.pp") ? open("#{Default.base_config_directory}/poolparty.pp").read : nil
177
198
  end
@@ -183,18 +204,6 @@ module PoolParty
183
204
  ::File.open("#{file_path}/#{file_name}", "w") {|f| f.write output }
184
205
  true
185
206
  end
186
-
187
- # Callbacks on bootstrap and configuration
188
- %w( before_bootstrap
189
- after_bootstrap
190
- before_configure
191
- after_configure).each do |meth|
192
- module_eval <<-EOE
193
- def call_#{meth}_callbacks
194
- plugin_store.each {|a| a.#{meth} }
195
- end
196
- EOE
197
- end
198
207
 
199
208
  # Add all the poolparty requirements here
200
209
  # NOTE: These are written as plugins in the lib/poolparty/base_packages directory
@@ -203,17 +212,9 @@ module PoolParty
203
212
  # all that is necessary in a method called enable
204
213
  # which is called when there is no block
205
214
  def add_poolparty_base_requirements
206
- poolparty_base_heartbeat
215
+ # poolparty_base_heartbeat
207
216
  poolparty_base_ruby
208
- poolparty_base_packages
209
-
210
- add_optional_base_packages
211
- end
212
-
213
- # Add optional base packages included with PP
214
- def add_optional_base_packages
215
- poolparty_base_haproxy if enabled? :haproxy
216
- poolparty_base_tokyo_tyrant if enabled? :tokyo_tyrant
217
+ poolparty_base_packages
217
218
  end
218
219
 
219
220
  # TODO: Deprecate
@@ -33,20 +33,10 @@ module PoolParty
33
33
  :forwarding_port => "8080",
34
34
  :monitor_port => 8081,
35
35
  :proxy_mode => "http",
36
- :messenger_client_port => 7050,
37
36
  :butterfly_port => 8642,
38
37
  :minimum_runtime => 3000, #50.minutes in seconds
39
38
  :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"
39
+ :expand_when => "load > 0.9"
50
40
  )
51
41
 
52
42
  def options
@@ -97,6 +87,7 @@ module PoolParty
97
87
  def reset!
98
88
  @keys = nil
99
89
  end
90
+
100
91
  # Get the instance first instance file that exists on the system from the expected places
101
92
  # denoted in the local_instances_list_file_locations
102
93
  def get_working_key_file_locations
@@ -1,13 +1,14 @@
1
- # STUB FOR NOW
2
- # TODO
1
+ =begin rdoc
2
+ ssh key used to login to remote instances
3
+ =end
3
4
  module PoolParty
4
5
  class Key
5
6
 
6
7
  attr_accessor :filepath
7
8
 
8
9
  # 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
10
+ def initialize(fpath=nil)
11
+ @filepath = (fpath.nil? || fpath.empty?) ? "id_rsa" : fpath
11
12
  end
12
13
 
13
14
  # If the full_filepath is nil, then the key doesn't exist
@@ -42,20 +43,23 @@ module PoolParty
42
43
  # then it returns nil and assumes we it doesn't exist
43
44
  def search_in_known_locations
44
45
  self.class.keypair_paths.each do |path|
45
- full_path = ::File.join( ::File.expand_path(path), filepath)
46
+ full_path = ::File.join( ::File.expand_path(path), ::File.basename(filepath))
46
47
  return full_path if ::File.exists?(full_path)
47
48
  end
49
+ # raise Exception.new("We cannot continue without a keypair. Please define a keypair in your clouds.rb")
50
+ # TODO: Add raise for keypair
48
51
  nil
49
52
  end
50
53
 
51
54
  # Default locations to search for the key
52
55
  def self.keypair_paths
53
- [ "#{ENV["HOME"]}/.ssh",
56
+ [
57
+ "#{ENV["HOME"]}/.ssh",
54
58
  "#{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
+ PoolParty::Default.base_keypair_path,
60
+ PoolParty::Default.base_config_directory,
61
+ PoolParty::Default.base_ssh_path,
62
+ PoolParty::Default.remote_storage_path,
59
63
  Dir.pwd
60
64
  ]
61
65
  end
@@ -67,8 +71,7 @@ module PoolParty
67
71
 
68
72
  # Turn the keypair into the a useful json string
69
73
  def to_json
70
- "{\"basename\":\"#{basename}\",
71
- \"full_filepath\": \"/etc/poolparty/#{filename}\"}"
74
+ "{\"basename\":\"#{basename}\",\"full_filepath\": \"/etc/poolparty/#{filename}\"}"
72
75
  end
73
76
 
74
77
  end
@@ -1,26 +1,55 @@
1
+ =begin rdoc
2
+ Neighborhood
3
+
4
+ Neighborhoods describes the neighborhood that an instance is in.
5
+ Neighborhoods are instances that are "near" other instances, either by
6
+ association of instantiation or through monitor_rack.
7
+ =end
8
+ require "#{::File.dirname(__FILE__)}/../modules/pinger"
1
9
  require "#{::File.dirname(__FILE__)}/../schema"
2
10
 
3
11
  module PoolParty
4
12
  class Neighborhoods
13
+ include ::PoolParty::Pinger
5
14
  attr_reader :schema
6
15
 
7
- def initialize(json)
8
- raise Exception.new("You must pass a string or a hash to Neighborhoods") unless json
9
-
10
- case json
16
+ # Create a neighborhood from a string, array or hash given.
17
+ def initialize(data)
18
+ raise Exception.new("You must pass a string or a hash to Neighborhoods") unless data
19
+ parsed_data = case data
11
20
  when Array
12
- json = {:instances => json.map {|entry| disect(entry) }}
21
+ {:instances => data.map {|entry| disect(entry) }}
13
22
  when String
14
- json = {:instances => JSON.parse(json).map {|inst| "#{inst["name"]}\t#{inst["ip"]}"}}
23
+ {:instances => JSON.parse(data)}#.map "#{inst["instance_id"]}\t#{inst["ip"]}"}}
24
+ when Hash
25
+ data
15
26
  end
16
- @schema = PoolParty::Schema.new(json)
27
+ @schema = PoolParty::Schema.new(parsed_data)
17
28
  raise Exception.new("No instances found in the Neighborhoods schema") unless @schema.instances
18
29
  end
19
30
 
31
+ # Get the known instances from the neighborhood.json file on the server
20
32
  def instances
21
- @instances ||= @schema.instances.map {|line| disect(line) }
33
+ @instances ||= @schema.to_hash[:instances] rescue @schema.instances.collect {|line| disect(line) }
34
+ end
35
+
36
+ # Returns empty if the neighborhood has no instances
37
+ def empty?
38
+ instances.empty?
39
+ end
40
+
41
+ # Get the next node in the hash
42
+ def next_node(node_hash)
43
+ return nil if empty?
44
+ sort.wrapping_next(node_hash)
22
45
  end
23
46
 
47
+ # Sort the instances by ip string, a very basic sort
48
+ def sort
49
+ instances.sort {|a, b| a.ip <=> b.ip}
50
+ end
51
+
52
+ # Get the instances at the specific index of the neighborhood
24
53
  def [](at)
25
54
  instances[at] if at >= 0 && at < instances.size
26
55
  end
@@ -29,14 +58,13 @@ module PoolParty
29
58
  case line
30
59
  when String
31
60
  arr = line.split("\t")
32
- {:name => arr[0], :ip => arr[1]}
33
- when Hash
34
- "#{line[:name]}\t#{line[:ip]}"
61
+ {:instance_id => arr[0], :ip => arr[1]}
35
62
  else
36
63
  line
37
64
  end
38
65
  end
39
66
 
67
+ # Run through an enumeration of the instances
40
68
  def each(&block)
41
69
  instances.each &block
42
70
  end
@@ -52,17 +80,22 @@ module PoolParty
52
80
  new(json).clump(filepath)
53
81
  end
54
82
 
83
+ # Load the default neighborhood.json file
84
+ # If the neighborhood.json file exists in
85
+ # /etc/poolparty/neighborhood.json
86
+ # then load the neighborhood from the file, otherwise
87
+ # if there is a butterfly server running locally,
88
+ # query it for the current neighborhood.
89
+ # Finally, return an empty set of instances
55
90
  def self.load_default
56
- def_file = [
57
- Dir.pwd,
58
- Default.base_config_directory,
59
- Default.remote_storage_path,
60
- Default.poolparty_home_path
61
- ].select do |dir|
62
- filepath = ::File.expand_path("#{dir}/neighborhood.json")
63
- filepath if ::File.file?(filepath)
64
- end.first || nil
65
- def_file ? new( open(::File.expand_path("#{def_file}/neighborhood.json")).read ) : nil
91
+ if ::File.file?("/etc/poolparty/neighborhood.json")
92
+ new( open("/etc/poolparty/neighborhood.json").read )
93
+ elsif ping_port("127.0.0.1", Default.butterfly_port, 1)# butterfly responding?
94
+ require "open-uri"
95
+ new( open("http://127.0.0.1:8642/neighborhood").read )
96
+ else
97
+ new("[]")
98
+ end
66
99
  end
67
100
 
68
101
  end
@@ -7,6 +7,7 @@ module PoolParty
7
7
  class Plugin < PoolParty::Service
8
8
  include CloudResourcer
9
9
  include PoolParty::DependencyResolverCloudExtensions
10
+ include PoolParty::Callbacks
10
11
 
11
12
  default_options({})
12
13
 
@@ -21,6 +22,9 @@ module PoolParty
21
22
  run_in_context do
22
23
  loaded @opts, &block
23
24
  end
25
+
26
+ setup_callbacks
27
+ after_create
24
28
  end
25
29
 
26
30
  # Overwrite this method
@@ -31,14 +35,7 @@ module PoolParty
31
35
  # Callbacks available to plugins
32
36
  def after_create
33
37
  end
34
- def before_bootstrap
35
- end
36
- def after_bootstrap
37
- end
38
- def before_configure
39
- end
40
- def after_configure
41
- end
38
+
42
39
  def enable
43
40
  end
44
41
  def is_plugin?
@@ -59,7 +56,7 @@ module PoolParty
59
56
  end
60
57
 
61
58
  def self.inherited(subclass)
62
- method_name = subclass.to_s.top_level_class.gsub(/pool_party_/, '').gsub(/_class/, '').downcase.to_sym
59
+ method_name = subclass.to_s.top_level_class.gsub(/pool_party_/, '').gsub(/_class/, '').downcase.to_sym
63
60
  add_has_and_does_not_have_methods_for(method_name)
64
61
  end
65
62
 
@@ -4,7 +4,7 @@ module PoolParty
4
4
  module PluginModel
5
5
 
6
6
  def plugin(name=:plugin, cloud=nil, &block)
7
- plugins.has_key?(name) ? plugins[name] : (plugins[name] = PluginModel.new(name, &block))
7
+ plugins[name] ||= PluginModel.new(name, &block)
8
8
  end
9
9
  alias_method :register_plugin, :plugin
10
10
 
@@ -15,8 +15,8 @@ module PoolParty
15
15
  class PluginModel
16
16
  attr_accessor :klass
17
17
 
18
- def initialize(name,&block)
19
- symc = "#{name}".top_level_class.camelcase
18
+ def initialize(name,&block)
19
+ symc = "#{name}".top_level_class.camelcase
20
20
  klass = symc.class_constant(PoolParty::Plugin::Plugin, {:preserve => true}, &block)
21
21
 
22
22
  lowercase_class_name = symc.downcase
@@ -28,9 +28,9 @@ module PoolParty
28
28
  i = plugin_store.select {|i| i if i.class == #{lowercase_class_name.camelcase}Class }.first if plugin_store
29
29
  if i
30
30
  i
31
- else
31
+ else
32
32
  inst = #{lowercase_class_name.camelcase}Class.new(opts, parent, &block)
33
- this_context.plugin_store << inst if this_context
33
+ plugin_store << inst if plugin_store
34
34
  inst
35
35
  end
36
36
  end
@@ -1,7 +1,7 @@
1
1
  module PoolParty
2
2
  module Pool
3
3
 
4
- def pool(name=:app, &block)
4
+ def pool(name, &block)
5
5
  pools[name] ||= Pool.new(name, &block)
6
6
  end
7
7
 
@@ -18,14 +18,18 @@ module PoolParty
18
18
  def set_pool_specfile(filename)
19
19
  $pool_specfile = filename unless $pool_specfile
20
20
  end
21
-
21
+
22
+ def pool_specfile
23
+ $pool_specfile
24
+ end
25
+
22
26
  def reset!
23
27
  $pools = $clouds = $plugins = @describe_instances = nil
24
28
  end
25
29
 
26
30
  class Pool < PoolParty::PoolPartyBaseClass
27
31
  include PrettyPrinter
28
- include CloudResourcer # WHY?!?! TODO: investigate
32
+ include CloudResourcer # WHY?!?! TODO: check on this
29
33
  include Remote
30
34
 
31
35
  default_options Default.default_options
@@ -44,7 +48,7 @@ module PoolParty
44
48
  def self.load_from_file(filename=nil)
45
49
  # a = new ::File.basename(filename, ::File.extname(filename))
46
50
  File.open(filename, 'r') do |f|
47
- instance_eval f.read
51
+ instance_eval f.read, pool_specfile
48
52
  end
49
53
  # a
50
54
  end
@@ -12,26 +12,25 @@ module PoolParty
12
12
  include PoolParty::DependencyResolverCloudExtensions
13
13
  # attr_accessor :depth
14
14
 
15
- def initialize(opts={}, extra_opts={}, &block)
15
+ def initialize(opts={}, extra_opts={}, &block)
16
16
  add_to_parent_if_parent_exists_and_is_a_service
17
17
 
18
18
  @init_block = block
19
19
  @base_name = get_name_from_options_and_extra_options(opts, extra_opts)
20
20
 
21
- opts = (opts.is_a?(Hash) ? extra_opts.merge(opts) : extra_opts).merge(:name => @base_name)
21
+ o = (opts.is_a?(Hash) ? extra_opts.merge(opts) : extra_opts).merge(:name => @base_name)
22
22
 
23
- run_in_context(opts, &block)
23
+ run_in_context(o, &block)
24
24
  super(&block)
25
25
  end
26
26
 
27
27
  # Overloading the parent run_in_context
28
- def run_in_context(opts={}, &block)
29
- if opts
28
+ def run_in_context(o={}, &block)
29
+ if o
30
30
  context_stack.push self
31
- set_vars_from_options(opts)
31
+ set_vars_from_options(o)
32
32
  instance_eval &block if block
33
33
  context_stack.pop
34
- head
35
34
  else
36
35
  super
37
36
  end
@@ -40,7 +39,7 @@ module PoolParty
40
39
  # Add the parent's options to my own and add myself as a service if I am not a resource
41
40
  def add_to_parent_if_parent_exists_and_is_a_service
42
41
  if parent && !parent.is_a?(PoolParty::Resources::Resource)
43
- dsl_options(parent.dsl_options) if parent.is_a?(PoolParty::Pool::Pool)
42
+ dsl_options.merge!(parent.dsl_options) if parent.is_a?(PoolParty::Pool::Pool)
44
43
  parent.add_service(self) if parent.respond_to?(:add_service) && !is_a_resource?
45
44
  end
46
45
  end
@@ -95,6 +94,7 @@ module PoolParty
95
94
  end
96
95
  res.after_create
97
96
  store_in_local_resources(ty, res)
97
+ ordered_resources << res
98
98
  res
99
99
  end
100
100
  end
@@ -118,10 +118,19 @@ module PoolParty
118
118
  end
119
119
  end
120
120
 
121
+ # Store the call and use of plugins into an array
122
+ def plugin_store
123
+ @plugin_store ||= []
124
+ end
125
+
121
126
  def resource(type=:file)
122
127
  resources[type.to_sym] ||= []
123
128
  end
124
129
 
130
+ def ordered_resources
131
+ @ordered_resources ||= []
132
+ end
133
+
125
134
  def is_plugin?
126
135
  false
127
136
  end
@@ -130,7 +139,7 @@ module PoolParty
130
139
  false
131
140
  end
132
141
 
133
- def method_missing(m,*a,&block)
142
+ def method_missing(m,*a,&block)
134
143
  if this_context && this_context != self && this_context.respond_to?(m)# && !self.is_a?(PoolParty::Resources::Resource)
135
144
  this_context.send m, *a, &block
136
145
  else
@@ -162,10 +171,10 @@ module PoolParty
162
171
  method_name = "__#{typ}"
163
172
  PoolParty::PoolPartyBaseClass.module_eval <<-EOE
164
173
  def has_#{typ}(opts={}, extra={}, &block)
165
- #{method_name}(handle_option_values(opts).merge(extra.merge(:ensures => :present)), &block)
174
+ #{method_name}({:ensures => :present}.merge(handle_option_values(opts).merge(extra)), &block)
166
175
  end
167
176
  def does_not_have_#{typ}(opts={}, extra={}, &block)
168
- #{method_name}(handle_option_values(opts).merge(extra.merge(:ensures => :absent)), &block)
177
+ #{method_name}({:ensures => :absent}.merge(handle_option_values(opts).merge(extra)), &block)
169
178
  end
170
179
  EOE
171
180
  end
@@ -50,7 +50,7 @@ module PoolParty
50
50
  end
51
51
  def get_#{lowercase_class_name}(n, opts={}, &block)
52
52
  res = get_resource(:#{lowercase_class_name}, n, opts, &block)
53
- raise PackageException.new("A required #{lowercase_class_name} \#\{n\} was not found.") unless res
53
+ raise PackageException.new("Oops. Check that you specified the #{lowercase_class_name} \#\{n\}.") unless res
54
54
  res
55
55
  end
56
56
  public
@@ -75,16 +75,20 @@ module PoolParty
75
75
  # the options
76
76
  # Finally, it uses the parent's options as the lowest priority
77
77
  def initialize(opts={}, extra_opts={}, &block)
78
- super(opts, &block)
79
-
78
+ super(opts, extra_opts, &block)
79
+
80
80
  @resource_name = @base_name
81
- dsl_options[:name] = resource_name unless dsl_options.has_key?(:name)
81
+ dsl_options[:name] = resource_name unless dsl_options.has_key?(:name)
82
+
83
+ loaded(opts, &block)
84
+
85
+ after_create
82
86
  end
83
87
 
84
88
  # Stub, so you can create virtual resources
85
89
  # This is called after the resource is initialized
86
90
  # with the options given to it in the init-block
87
- def loaded(opts={})
91
+ def loaded(opts={}, &block)
88
92
  end
89
93
 
90
94
  def resource_name
@@ -18,7 +18,9 @@ module PoolParty
18
18
 
19
19
  meth = <<-EOM
20
20
  def __#{lowercase_class_name}(opts={}, &block)
21
- PoolParty::#{lowercase_class_name.camelcase}Class.new(opts, &block)
21
+ i = PoolParty::#{lowercase_class_name.camelcase}Class.new(opts, &block)
22
+ plugin_store << i if respond_to?(:plugin_store)
23
+ i
22
24
  end
23
25
  alias :#{lowercase_class_name} :__#{lowercase_class_name}
24
26
  EOM