lono 7.5.2 → 8.0.0.pre.rc1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (458) hide show
  1. checksums.yaml +4 -4
  2. data/.cody/README.md +5 -15
  3. data/.cody/acceptance/bin/build.sh +52 -0
  4. data/.cody/acceptance/buildspec.yml +10 -0
  5. data/.cody/acceptance/project.rb +6 -0
  6. data/.cody/{role.rb → acceptance/role.rb} +0 -0
  7. data/.cody/shared/script/install/lono.sh +40 -0
  8. data/.cody/shared/script/install.sh +5 -0
  9. data/CHANGELOG.md +21 -4
  10. data/CONTRIBUTING.md +2 -2
  11. data/Gemfile +5 -1
  12. data/LICENSE.txt +201 -1
  13. data/README.md +4 -4
  14. data/lib/lono/api/client.rb +3 -2
  15. data/lib/lono/app/inits.rb +13 -0
  16. data/lib/lono/app.rb +71 -0
  17. data/lib/lono/app_file/base.rb +1 -1
  18. data/lib/lono/app_file/build/lambda_layer/ruby_packager.rb +9 -9
  19. data/lib/lono/app_file/build/lambda_layer.rb +3 -3
  20. data/lib/lono/app_file/build.rb +9 -14
  21. data/lib/lono/app_file/registry/item.rb +4 -4
  22. data/lib/lono/app_file/upload.rb +1 -1
  23. data/lib/lono/autoloader.rb +2 -2
  24. data/lib/lono/aws_services/helper.rb +43 -6
  25. data/lib/lono/aws_services.rb +37 -6
  26. data/lib/lono/blueprint.rb +18 -9
  27. data/lib/lono/booter.rb +28 -0
  28. data/lib/lono/{template → builder}/context/helpers.rb +1 -1
  29. data/lib/lono/{template → builder}/context/loader/load_files.rb +5 -6
  30. data/lib/lono/builder/context/loader.rb +35 -0
  31. data/lib/lono/builder/context/params.rb +7 -0
  32. data/lib/lono/{template → builder}/context/ssm_fetcher.rb +1 -1
  33. data/lib/lono/{template → builder}/context.rb +5 -9
  34. data/lib/lono/{param/generator.rb → builder/param.rb} +21 -22
  35. data/lib/lono/builder/template/aws_service.rb +15 -0
  36. data/lib/lono/builder/template/bashify.rb +43 -0
  37. data/lib/lono/{template → builder/template}/configset_injector.rb +4 -4
  38. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/fn.rb +2 -2
  39. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/helpers/core_helper.rb +1 -1
  40. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/helpers/ec2_helper.rb +1 -1
  41. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/helpers/file_helper.rb +8 -12
  42. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/helpers/s3_helper.rb +2 -2
  43. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/helpers/stack_helper.rb +11 -8
  44. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/helpers/tags_helper.rb +1 -1
  45. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/helpers.rb +2 -2
  46. data/lib/lono/builder/template/dsl/evaluator/section/base.rb +23 -0
  47. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/condition.rb +1 -1
  48. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/mapping.rb +1 -1
  49. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/methods.rb +7 -7
  50. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/output.rb +1 -1
  51. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/parameter.rb +1 -1
  52. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/resource/property_mover.rb +1 -1
  53. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/resource.rb +1 -1
  54. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/section.rb +1 -1
  55. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/squeezer.rb +1 -1
  56. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/stringify.rb +1 -1
  57. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/syntax/extend_with.rb +1 -1
  58. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/syntax/parameter_group.rb +1 -1
  59. data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/syntax.rb +3 -3
  60. data/lib/lono/builder/template/dsl/evaluator.rb +45 -0
  61. data/lib/lono/{template/strategy → builder/template}/dsl/finalizer/parameter_groups.rb +2 -2
  62. data/lib/lono/{template/strategy → builder/template}/dsl/finalizer.rb +1 -1
  63. data/lib/lono/builder/template/dsl.rb +14 -0
  64. data/lib/lono/{template → builder/template}/evaluate.rb +18 -6
  65. data/lib/lono/builder/template/helpers.rb +149 -0
  66. data/lib/lono/{output/template.rb → builder/template/output.rb} +14 -7
  67. data/lib/lono/{template → builder/template}/post_processor.rb +4 -4
  68. data/lib/lono/{template → builder/template}/upload.rb +3 -5
  69. data/lib/lono/builder/template.rb +55 -0
  70. data/lib/lono/bundler/cli/base.rb +10 -0
  71. data/lib/lono/bundler/cli/bundle.rb +44 -0
  72. data/lib/lono/bundler/cli/clean.rb +27 -0
  73. data/lib/lono/bundler/cli/help/bundle.md +3 -0
  74. data/lib/lono/bundler/cli/help.rb +11 -0
  75. data/lib/lono/bundler/cli.rb +7 -0
  76. data/lib/lono/bundler/component/concerns/local_concern.rb +10 -0
  77. data/lib/lono/bundler/component/concerns/notation_concern.rb +59 -0
  78. data/lib/lono/bundler/component/concerns/path_concern.rb +68 -0
  79. data/lib/lono/bundler/component/concerns/stack_concern.rb +60 -0
  80. data/lib/lono/bundler/component/fetcher/base.rb +27 -0
  81. data/lib/lono/bundler/component/fetcher/gcs.rb +69 -0
  82. data/lib/lono/bundler/component/fetcher/git.rb +69 -0
  83. data/lib/lono/bundler/component/fetcher/local.rb +15 -0
  84. data/lib/lono/bundler/component/fetcher/s3.rb +66 -0
  85. data/lib/lono/bundler/component/fetcher.rb +18 -0
  86. data/lib/lono/bundler/component/http/concern.rb +45 -0
  87. data/lib/lono/bundler/component/http/source.rb +19 -0
  88. data/lib/lono/bundler/component/org_repo.rb +65 -0
  89. data/lib/lono/bundler/component/props/extension.rb +19 -0
  90. data/lib/lono/bundler/component/props/typer.rb +41 -0
  91. data/lib/lono/bundler/component/props.rb +122 -0
  92. data/lib/lono/bundler/component/registry.rb +136 -0
  93. data/lib/lono/bundler/component.rb +52 -0
  94. data/lib/lono/bundler/config.rb +18 -0
  95. data/lib/lono/bundler/dsl/syntax.rb +46 -0
  96. data/lib/lono/bundler/dsl.rb +21 -0
  97. data/lib/lono/bundler/exporter/base.rb +6 -0
  98. data/lib/lono/bundler/exporter/copy.rb +22 -0
  99. data/lib/lono/bundler/exporter.rb +50 -0
  100. data/lib/lono/bundler/extract/tar.rb +34 -0
  101. data/lib/lono/bundler/extract/zip.rb +16 -0
  102. data/lib/lono/bundler/info.rb +39 -0
  103. data/lib/lono/bundler/list.rb +26 -0
  104. data/lib/lono/bundler/lockfile/version_comparer.rb +56 -0
  105. data/lib/lono/bundler/lockfile/yamler.rb +36 -0
  106. data/lib/lono/bundler/lockfile.rb +66 -0
  107. data/lib/lono/bundler/lonofile.rb +32 -0
  108. data/lib/lono/bundler/runner.rb +27 -0
  109. data/lib/lono/bundler/syncer.rb +70 -0
  110. data/lib/lono/bundler/util/git.rb +37 -0
  111. data/lib/lono/bundler/util/logging.rb +7 -0
  112. data/lib/lono/bundler/util/sure.rb +5 -0
  113. data/lib/lono/{bundle.rb → bundler.rb} +38 -4
  114. data/lib/lono/cfn/base.rb +9 -195
  115. data/lib/lono/cfn/cancel.rb +9 -26
  116. data/lib/lono/cfn/concerns/build.rb +10 -0
  117. data/lib/lono/cfn/concerns/template_output.rb +10 -0
  118. data/lib/lono/cfn/concerns.rb +43 -0
  119. data/lib/lono/cfn/delete.rb +8 -32
  120. data/lib/lono/cfn/deploy/base.rb +4 -0
  121. data/lib/lono/cfn/deploy/iam.rb +49 -0
  122. data/lib/lono/cfn/deploy/notification.rb +8 -0
  123. data/lib/lono/cfn/deploy/operable.rb +18 -0
  124. data/lib/lono/cfn/deploy/opts.rb +49 -0
  125. data/lib/lono/cfn/deploy/rollback.rb +46 -0
  126. data/lib/lono/cfn/deploy/tags.rb +18 -0
  127. data/lib/lono/cfn/deploy.rb +71 -5
  128. data/lib/lono/cfn/download.rb +5 -7
  129. data/lib/lono/cfn/output.rb +49 -0
  130. data/lib/lono/cfn/plan/base.rb +19 -0
  131. data/lib/lono/cfn/plan/changeset/base.rb +19 -0
  132. data/lib/lono/cfn/plan/changeset/notifications.rb +24 -0
  133. data/lib/lono/cfn/plan/changeset/outputs.rb +25 -0
  134. data/lib/lono/cfn/plan/changeset/resources.rb +48 -0
  135. data/lib/lono/cfn/plan/changeset/tags.rb +16 -0
  136. data/lib/lono/cfn/plan/changeset.rb +136 -0
  137. data/lib/lono/cfn/plan/concerns.rb +10 -0
  138. data/lib/lono/cfn/plan/delete.rb +16 -0
  139. data/lib/lono/cfn/plan/diff/base.rb +10 -0
  140. data/lib/lono/cfn/plan/diff/data.rb +52 -0
  141. data/lib/lono/cfn/plan/diff/file.rb +56 -0
  142. data/lib/lono/cfn/plan/new.rb +26 -0
  143. data/lib/lono/cfn/{preview → plan}/param.rb +26 -34
  144. data/lib/lono/cfn/plan/summary.rb +16 -0
  145. data/lib/lono/cfn/plan/template.rb +28 -0
  146. data/lib/lono/cfn/plan.rb +33 -0
  147. data/lib/lono/cfn/show.rb +30 -0
  148. data/lib/lono/cfn/status.rb +1 -1
  149. data/lib/lono/cli/abstract.rb +17 -0
  150. data/lib/lono/cli/base.rb +9 -0
  151. data/lib/lono/cli/build.rb +101 -0
  152. data/lib/lono/cli/bundle.rb +21 -0
  153. data/lib/lono/cli/cfn/opts.rb +59 -0
  154. data/lib/lono/cli/cfn.rb +19 -0
  155. data/lib/lono/cli/clean.rb +22 -0
  156. data/lib/lono/{code.rb → cli/code.rb} +2 -2
  157. data/lib/lono/{completion.rb → cli/completion.rb} +2 -2
  158. data/lib/lono/{help → cli/help}/blueprint/new.md +4 -4
  159. data/lib/lono/{help/generate.md → cli/help/build.md} +6 -6
  160. data/lib/lono/{help → cli/help}/cfn/cancel.md +0 -0
  161. data/lib/lono/cli/help/cfn/download.md +3 -0
  162. data/lib/lono/{help → cli/help}/cfn/preview.md +9 -8
  163. data/lib/lono/{help → cli/help}/cfn/status.md +0 -0
  164. data/lib/lono/cli/help/cfn.md +4 -0
  165. data/lib/lono/{help → cli/help}/code/convert.md +0 -0
  166. data/lib/lono/{help → cli/help}/code/import.md +2 -2
  167. data/lib/lono/{help → cli/help}/completion.md +3 -3
  168. data/lib/lono/{help → cli/help}/completion_script.md +0 -0
  169. data/lib/lono/{help → cli/help}/configsets.md +0 -0
  170. data/lib/lono/cli/help/down.md +13 -0
  171. data/lib/lono/cli/help/new/project.md +34 -0
  172. data/lib/lono/{help → cli/help}/param/generate.md +0 -0
  173. data/lib/lono/cli/help/param.md +6 -0
  174. data/lib/lono/{help → cli/help}/pro/blueprints.md +0 -0
  175. data/lib/lono/{help → cli/help}/pro/configsets.md +0 -0
  176. data/lib/lono/{help → cli/help}/script/build.md +0 -0
  177. data/lib/lono/{help → cli/help}/script/upload.md +0 -0
  178. data/lib/lono/{help → cli/help}/seed.md +2 -2
  179. data/lib/lono/cli/help/summary.md +33 -0
  180. data/lib/lono/{help → cli/help}/template/bashify.md +0 -0
  181. data/lib/lono/cli/help/template/generate.md +7 -0
  182. data/lib/lono/{help → cli/help}/template.md +0 -0
  183. data/lib/lono/cli/help/up.md +30 -0
  184. data/lib/lono/{help → cli/help}/user_data.md +3 -3
  185. data/lib/lono/cli/help.rb +56 -0
  186. data/lib/lono/cli/list.rb +28 -0
  187. data/lib/lono/cli/new/blueprint.rb +33 -0
  188. data/lib/lono/cli/new/concerns.rb +16 -0
  189. data/lib/lono/{configset/new.rb → cli/new/configset.rb} +2 -9
  190. data/lib/lono/{extension/new.rb → cli/new/extension.rb} +2 -10
  191. data/lib/lono/cli/new/helper.rb +32 -0
  192. data/lib/lono/cli/new/project.rb +77 -0
  193. data/lib/lono/cli/new/sequence.rb +51 -0
  194. data/lib/lono/cli/new/shim.rb +59 -0
  195. data/lib/lono/cli/new/test/blueprint.rb +23 -0
  196. data/lib/lono/cli/new/test/sequence.rb +10 -0
  197. data/lib/lono/cli/new/test.rb +8 -0
  198. data/lib/lono/cli/new.rb +31 -0
  199. data/lib/lono/{opts.rb → cli/opts.rb} +9 -12
  200. data/lib/lono/{s3.rb → cli/s3.rb} +9 -7
  201. data/lib/lono/cli/script/base.rb +5 -0
  202. data/lib/lono/cli/script/build.rb +72 -0
  203. data/lib/lono/cli/script/upload.rb +49 -0
  204. data/lib/lono/{script.rb → cli/script.rb} +2 -2
  205. data/lib/lono/cli/seed.rb +9 -0
  206. data/lib/lono/cli/test.rb +35 -0
  207. data/lib/lono/cli.rb +80 -109
  208. data/lib/lono/command.rb +27 -0
  209. data/lib/lono/configset/{generator.rb → builder.rb} +9 -7
  210. data/lib/lono/configset/combiner.rb +8 -6
  211. data/lib/lono/configset/evaluate_file.rb +1 -1
  212. data/lib/lono/configset/meta.rb +1 -1
  213. data/lib/lono/configset/s3_file/build.rb +5 -4
  214. data/lib/lono/configset/s3_file/item.rb +1 -1
  215. data/lib/lono/configset/s3_file/upload.rb +2 -2
  216. data/lib/lono/configset/strategy/base.rb +6 -6
  217. data/lib/lono/configset/strategy/helpers/dsl/core.rb +1 -1
  218. data/lib/lono/core.rb +25 -54
  219. data/lib/lono/extensions/dsl.rb +2 -5
  220. data/lib/lono/extensions/loader.rb +1 -12
  221. data/lib/lono/extensions.rb +2 -2
  222. data/lib/lono/importer/base.rb +5 -5
  223. data/lib/lono/importer/download.rb +7 -7
  224. data/lib/lono/importer/dsl.rb +3 -3
  225. data/lib/lono/importer/service/coder.rb +10 -10
  226. data/lib/lono/importer.rb +1 -10
  227. data/lib/lono/inspector/base.rb +7 -7
  228. data/lib/lono/inspector/summary.rb +19 -17
  229. data/lib/lono/layering/layer.rb +126 -0
  230. data/lib/lono/layering.rb +13 -55
  231. data/lib/lono/logger/formatter.rb +13 -0
  232. data/lib/lono/logger.rb +33 -0
  233. data/lib/lono/lookup.rb +12 -0
  234. data/lib/lono/names.rb +50 -0
  235. data/lib/lono/plugin/meta.rb +30 -0
  236. data/lib/lono/plugin/tester.rb +13 -0
  237. data/lib/lono/plugin.rb +10 -0
  238. data/lib/lono/s3/aws_setup.rb +4 -3
  239. data/lib/lono/s3/bucket.rb +19 -19
  240. data/lib/lono/s3/uploader.rb +10 -12
  241. data/lib/lono/script/base.rb +3 -3
  242. data/lib/lono/script/build.rb +11 -12
  243. data/lib/lono/script/upload.rb +7 -7
  244. data/lib/lono/{seed → seeder}/service_role.rb +1 -1
  245. data/lib/lono/{seed/base.rb → seeder.rb} +21 -36
  246. data/lib/lono/user_data.rb +8 -13
  247. data/lib/lono/utils/context.rb +15 -0
  248. data/lib/lono/utils/item/zip.rb +5 -5
  249. data/lib/lono/utils/logging.rb +7 -0
  250. data/lib/lono/utils/{pretty_time.rb → pretty.rb} +6 -2
  251. data/lib/lono/utils/quit.rb +7 -0
  252. data/lib/lono/utils/rsync.rb +4 -2
  253. data/lib/lono/utils/sure.rb +4 -4
  254. data/lib/lono/version.rb +1 -1
  255. data/lib/lono.rb +7 -12
  256. data/lib/templates/blueprint/template.rb +2 -0
  257. data/lib/templates/configset/{lib/configset.rb → configset.rb} +0 -0
  258. data/lib/templates/examples/blueprint/template.rb +9 -0
  259. data/lib/templates/helper/%underscore_name%_helper.rb.tt +6 -0
  260. data/lib/templates/{skeleton → project}/.gitignore +1 -2
  261. data/lib/templates/project/Gemfile.tt +11 -0
  262. data/lib/templates/project/README.md +9 -0
  263. data/lib/templates/project/config/app.rb +3 -0
  264. data/lib/templates/shim/lono +7 -0
  265. data/lono.gemspec +51 -44
  266. metadata +246 -269
  267. data/.circleci/README.md +0 -3
  268. data/.circleci/config.yml +0 -58
  269. data/.cody/acceptance.sh +0 -49
  270. data/.cody/buildspec.yml +0 -9
  271. data/.cody/demo.rb +0 -38
  272. data/.cody/project.rb +0 -6
  273. data/.gitmodules +0 -3
  274. data/lib/lono/abstract_base.rb +0 -25
  275. data/lib/lono/aws_services/stack.rb +0 -41
  276. data/lib/lono/aws_services/stack_set.rb +0 -41
  277. data/lib/lono/blueprint/configset/loader.rb +0 -7
  278. data/lib/lono/blueprint/helper.rb +0 -24
  279. data/lib/lono/blueprint/meta.rb +0 -30
  280. data/lib/lono/blueprint/new.rb +0 -127
  281. data/lib/lono/blueprint/root.rb +0 -25
  282. data/lib/lono/cfn/create.rb +0 -41
  283. data/lib/lono/cfn/opts.rb +0 -88
  284. data/lib/lono/cfn/preview/changeset.rb +0 -168
  285. data/lib/lono/cfn/preview/codediff.rb +0 -41
  286. data/lib/lono/cfn/preview/diff_viewer.rb +0 -23
  287. data/lib/lono/cfn/rollback.rb +0 -26
  288. data/lib/lono/cfn/update.rb +0 -71
  289. data/lib/lono/cfn.rb +0 -75
  290. data/lib/lono/clean.rb +0 -14
  291. data/lib/lono/configset/list.rb +0 -67
  292. data/lib/lono/configset/preparer.rb +0 -44
  293. data/lib/lono/configset/register/base.rb +0 -122
  294. data/lib/lono/configset/register/blueprint.rb +0 -16
  295. data/lib/lono/configset/register/dsl.rb +0 -14
  296. data/lib/lono/configset/register/project.rb +0 -13
  297. data/lib/lono/configset/resolver.rb +0 -47
  298. data/lib/lono/configset.rb +0 -16
  299. data/lib/lono/conventions.rb +0 -23
  300. data/lib/lono/core/config.rb +0 -22
  301. data/lib/lono/default/settings.yml +0 -21
  302. data/lib/lono/ext/bundler.rb +0 -7
  303. data/lib/lono/extension/helper.rb +0 -13
  304. data/lib/lono/extension/list.rb +0 -40
  305. data/lib/lono/extension.rb +0 -9
  306. data/lib/lono/extensions/preparer.rb +0 -26
  307. data/lib/lono/extensions/register.rb +0 -15
  308. data/lib/lono/file_uploader.rb +0 -21
  309. data/lib/lono/finder/base.rb +0 -152
  310. data/lib/lono/finder/blueprint/configset.rb +0 -17
  311. data/lib/lono/finder/blueprint.rb +0 -11
  312. data/lib/lono/finder/configset.rb +0 -11
  313. data/lib/lono/finder/extension.rb +0 -11
  314. data/lib/lono/generate.rb +0 -111
  315. data/lib/lono/help/cfn/create.md +0 -26
  316. data/lib/lono/help/cfn/delete.md +0 -13
  317. data/lib/lono/help/cfn/deploy.md +0 -21
  318. data/lib/lono/help/cfn/download.md +0 -3
  319. data/lib/lono/help/cfn/update.md +0 -49
  320. data/lib/lono/help/cfn.md +0 -7
  321. data/lib/lono/help/new.md +0 -57
  322. data/lib/lono/help/param.md +0 -6
  323. data/lib/lono/help/set_instances/delete.md +0 -21
  324. data/lib/lono/help/set_instances/deploy.md +0 -31
  325. data/lib/lono/help/set_instances/list.md +0 -14
  326. data/lib/lono/help/set_instances/status.md +0 -15
  327. data/lib/lono/help/set_instances/sync.md +0 -92
  328. data/lib/lono/help/sets/delete.md +0 -8
  329. data/lib/lono/help/sets/deploy.md +0 -76
  330. data/lib/lono/help/sets/status.md +0 -23
  331. data/lib/lono/help/summary.md +0 -33
  332. data/lib/lono/help/template/generate.md +0 -7
  333. data/lib/lono/help/upgrade.md +0 -1
  334. data/lib/lono/help/xgraph.md +0 -16
  335. data/lib/lono/help.rb +0 -15
  336. data/lib/lono/importer/erb.rb +0 -31
  337. data/lib/lono/inspector/graph.rb +0 -125
  338. data/lib/lono/jade/circular.rb +0 -26
  339. data/lib/lono/jade/materializer/final.rb +0 -10
  340. data/lib/lono/jade/materializer/gems_builder.rb +0 -81
  341. data/lib/lono/jade/materializer/source.rb +0 -54
  342. data/lib/lono/jade/materializer.rb +0 -15
  343. data/lib/lono/jade/registry.rb +0 -64
  344. data/lib/lono/jade.rb +0 -110
  345. data/lib/lono/jadespec.rb +0 -68
  346. data/lib/lono/new/helper.rb +0 -15
  347. data/lib/lono/new.rb +0 -95
  348. data/lib/lono/param.rb +0 -14
  349. data/lib/lono/pro/base.rb +0 -16
  350. data/lib/lono/pro/repo.rb +0 -28
  351. data/lib/lono/pro.rb +0 -15
  352. data/lib/lono/project_checker.rb +0 -35
  353. data/lib/lono/registration/base.rb +0 -37
  354. data/lib/lono/registration/check.rb +0 -15
  355. data/lib/lono/registration/temp.rb +0 -53
  356. data/lib/lono/registration/user.rb +0 -60
  357. data/lib/lono/seed.rb +0 -39
  358. data/lib/lono/sequence.rb +0 -35
  359. data/lib/lono/set_instances/base.rb +0 -30
  360. data/lib/lono/set_instances/changeable.rb +0 -53
  361. data/lib/lono/set_instances/create.rb +0 -7
  362. data/lib/lono/set_instances/delete.rb +0 -47
  363. data/lib/lono/set_instances/deploy.rb +0 -52
  364. data/lib/lono/set_instances/list.rb +0 -13
  365. data/lib/lono/set_instances/opts.rb +0 -37
  366. data/lib/lono/set_instances/status.rb +0 -12
  367. data/lib/lono/set_instances/sync.rb +0 -181
  368. data/lib/lono/set_instances/update.rb +0 -15
  369. data/lib/lono/set_instances.rb +0 -54
  370. data/lib/lono/sets/base.rb +0 -50
  371. data/lib/lono/sets/create.rb +0 -27
  372. data/lib/lono/sets/delete.rb +0 -43
  373. data/lib/lono/sets/deploy.rb +0 -11
  374. data/lib/lono/sets/list.rb +0 -35
  375. data/lib/lono/sets/opts.rb +0 -18
  376. data/lib/lono/sets/preview/codediff.rb +0 -35
  377. data/lib/lono/sets/preview/param.rb +0 -32
  378. data/lib/lono/sets/status/instance/base.rb +0 -120
  379. data/lib/lono/sets/status/instance/completed.rb +0 -35
  380. data/lib/lono/sets/status/instance/deleted.rb +0 -32
  381. data/lib/lono/sets/status/instance/show.rb +0 -7
  382. data/lib/lono/sets/status/instance.rb +0 -20
  383. data/lib/lono/sets/status/instances.rb +0 -136
  384. data/lib/lono/sets/status.rb +0 -128
  385. data/lib/lono/sets/summarize.rb +0 -22
  386. data/lib/lono/sets/time_spent.rb +0 -11
  387. data/lib/lono/sets/update.rb +0 -74
  388. data/lib/lono/sets/waiter.rb +0 -23
  389. data/lib/lono/sets.rb +0 -34
  390. data/lib/lono/setting.rb +0 -75
  391. data/lib/lono/template/aws_service.rb +0 -20
  392. data/lib/lono/template/bashify.rb +0 -39
  393. data/lib/lono/template/context/loader.rb +0 -52
  394. data/lib/lono/template/generator.rb +0 -23
  395. data/lib/lono/template/helper.rb +0 -152
  396. data/lib/lono/template/strategy/base.rb +0 -4
  397. data/lib/lono/template/strategy/common/helpers.rb +0 -44
  398. data/lib/lono/template/strategy/dsl/builder/section/base.rb +0 -30
  399. data/lib/lono/template/strategy/dsl/builder.rb +0 -59
  400. data/lib/lono/template/strategy/dsl.rb +0 -14
  401. data/lib/lono/template/strategy/erb.rb +0 -82
  402. data/lib/lono/template/strategy/source.rb +0 -8
  403. data/lib/lono/template/template.rb +0 -54
  404. data/lib/lono/template/util.rb +0 -8
  405. data/lib/lono/template.rb +0 -24
  406. data/lib/lono/upgrade.rb +0 -20
  407. data/lib/lono/utils/generators/tree.rb +0 -18
  408. data/lib/templates/blueprint/%blueprint_name%.gemspec.tt +0 -45
  409. data/lib/templates/blueprint/.gitignore +0 -11
  410. data/lib/templates/blueprint/CHANGELOG.md +0 -7
  411. data/lib/templates/blueprint/Gemfile +0 -4
  412. data/lib/templates/blueprint/README.md.tt +0 -33
  413. data/lib/templates/blueprint/Rakefile.tt +0 -9
  414. data/lib/templates/blueprint/seed/configs.rb +0 -28
  415. data/lib/templates/blueprint_types/dsl/app/templates/%blueprint_name%.rb +0 -36
  416. data/lib/templates/blueprint_types/dsl/app/user_data/bootstrap.sh +0 -2
  417. data/lib/templates/blueprint_types/erb/app/definitions/base.rb.tt +0 -1
  418. data/lib/templates/blueprint_types/erb/app/templates/%blueprint_name%.yml +0 -67
  419. data/lib/templates/configset/%configset_name%.gemspec.tt +0 -42
  420. data/lib/templates/configset/.gitignore +0 -10
  421. data/lib/templates/configset/CHANGELOG.md +0 -7
  422. data/lib/templates/configset/Gemfile +0 -4
  423. data/lib/templates/configset/README.md.tt +0 -3
  424. data/lib/templates/configset/Rakefile.tt +0 -9
  425. data/lib/templates/extension/%extension_name%.gemspec.tt +0 -46
  426. data/lib/templates/extension/.gitignore +0 -11
  427. data/lib/templates/extension/.rspec +0 -3
  428. data/lib/templates/extension/CHANGELOG.md +0 -7
  429. data/lib/templates/extension/Gemfile.tt +0 -4
  430. data/lib/templates/extension/Rakefile.tt +0 -9
  431. data/lib/templates/extension/spec/spec_helper.rb.tt +0 -29
  432. data/lib/templates/skeleton/Gemfile +0 -3
  433. data/lib/templates/skeleton/README.md +0 -58
  434. data/lib/templates/skeleton/configs/settings.yml +0 -13
  435. data/vendor/cfn-status/CHANGELOG.md +0 -14
  436. data/vendor/cfn-status/Gemfile +0 -4
  437. data/vendor/cfn-status/Gemfile.lock +0 -49
  438. data/vendor/cfn-status/LICENSE.txt +0 -21
  439. data/vendor/cfn-status/README.md +0 -58
  440. data/vendor/cfn-status/Rakefile +0 -6
  441. data/vendor/cfn-status/bin/console +0 -14
  442. data/vendor/cfn-status/bin/setup +0 -8
  443. data/vendor/cfn-status/cfn-status.gemspec +0 -30
  444. data/vendor/cfn-status/lib/cfn-status.rb +0 -1
  445. data/vendor/cfn-status/lib/cfn_status/aws_service.rb +0 -51
  446. data/vendor/cfn-status/lib/cfn_status/version.rb +0 -3
  447. data/vendor/cfn-status/lib/cfn_status.rb +0 -245
  448. data/vendor/cfn-status/spec/fixtures/cfn/pages/fresh/describe_stack_events-1.json +0 -1103
  449. data/vendor/cfn-status/spec/fixtures/cfn/pages/fresh/describe_stack_events-2.json +0 -1104
  450. data/vendor/cfn-status/spec/fixtures/cfn/pages/fresh/describe_stack_events-3.json +0 -1103
  451. data/vendor/cfn-status/spec/fixtures/cfn/pages/updating/describe_stack_events-1.json +0 -1103
  452. data/vendor/cfn-status/spec/fixtures/cfn/pages/updating/describe_stack_events-2.json +0 -1104
  453. data/vendor/cfn-status/spec/fixtures/cfn/pages/updating/describe_stack_events-3.json +0 -1103
  454. data/vendor/cfn-status/spec/fixtures/cfn/stack-events-complete.json +0 -1080
  455. data/vendor/cfn-status/spec/fixtures/cfn/stack-events-in-progress.json +0 -1080
  456. data/vendor/cfn-status/spec/fixtures/cfn/stack-events-update-rollback-complete.json +0 -1086
  457. data/vendor/cfn-status/spec/lib/cfn_status_spec.rb +0 -153
  458. data/vendor/cfn-status/spec/spec_helper.rb +0 -14
@@ -1,20 +1,16 @@
1
- module Lono::Template::Strategy::Dsl::Builder::Helpers
1
+ module Lono::Builder::Template::Dsl::Evaluator::Helpers
2
2
  module FileHelper
3
3
  extend Memoist
4
4
 
5
- def content(path)
6
- render_file(Lono.config.content_path, path)
7
- end
8
-
9
5
  def user_data(path)
10
- render_file(Lono.config.user_data_path, path)
6
+ render_file(Lono.config.paths.user_data, path)
11
7
  end
12
8
 
13
9
  def user_data_script
14
10
  unless @user_data_script
15
11
  return <<~EOL
16
- # @user_data_script variable not set. IE: @user_data_script = "configs/#{@blueprint}/user_data/boostrap.sh"
17
- # Also, make sure that "configs/#{@blueprint}/user_data/boostrap.sh" path you're using exists.
12
+ # @user_data_script variable not set. IE: @user_data_script = "config/#{@blueprint.name}/user_data/boostrap.sh"
13
+ # Also, make sure that "config/#{@blueprint.name}/user_data/boostrap.sh" path you're using exists.
18
14
  EOL
19
15
  end
20
16
 
@@ -22,7 +18,7 @@ module Lono::Template::Strategy::Dsl::Builder::Helpers
22
18
  render_path(@user_data_script)
23
19
  else
24
20
  message = "WARN: #{@user_data_script} not found"
25
- puts message.color(:yellow)
21
+ logger.info message.color(:yellow)
26
22
  "# #{message}"
27
23
  end
28
24
  end
@@ -33,9 +29,9 @@ module Lono::Template::Strategy::Dsl::Builder::Helpers
33
29
  render_path(path)
34
30
  else
35
31
  message = "WARNING: path #{path} not found"
36
- puts message.color(:yellow)
37
- puts "Called from:"
38
- puts caller[2]
32
+ logger.info message.color(:yellow)
33
+ logger.info "Called from:"
34
+ logger.info caller[2]
39
35
  message
40
36
  end
41
37
  end
@@ -1,4 +1,4 @@
1
- module Lono::Template::Strategy::Dsl::Builder::Helpers
1
+ module Lono::Builder::Template::Dsl::Evaluator::Helpers
2
2
  module S3Helper
3
3
  def s3_bucket
4
4
  Lono::S3::Bucket.name
@@ -8,7 +8,7 @@ module Lono::Template::Strategy::Dsl::Builder::Helpers
8
8
  def s3_key(name, options={})
9
9
  default = {type: "file"}
10
10
  options.reverse_merge!(default)
11
- Lono::AppFile::Registry.register(name, @blueprint, options)
11
+ Lono::AppFile::Registry.register(name, @blueprint.name, options)
12
12
  "file://app/files/#{options[:type]}/#{name}" # placeholder for post processing
13
13
  end
14
14
  alias_method :file_s3_key, :s3_key
@@ -1,10 +1,11 @@
1
- module Lono::Template::Strategy::Dsl::Builder::Helpers
1
+ module Lono::Builder::Template::Dsl::Evaluator::Helpers
2
2
  module StackHelper
3
3
  extend Memoist
4
4
  include Lono::AwsServices
5
5
 
6
6
  def stack_output(name)
7
7
  stack_name, key = name.split(".")
8
+ stack_name = stack_name(stack_name)
8
9
  resp = describe_stacks(stack_name: stack_name)
9
10
  stack = resp.stacks.first
10
11
  if stack
@@ -14,27 +15,29 @@ module Lono::Template::Strategy::Dsl::Builder::Helpers
14
15
  if o
15
16
  o.output_value
16
17
  else
17
- "NOT FOUND: output #{key} for stack #{stack_name}"
18
+ logger.info "WARN: NOT FOUND: output #{key} for stack #{stack_name}"
18
19
  end
19
20
  end
20
21
 
21
22
  def stack_resource(name)
22
23
  stack_name, logical_id = name.split(".")
24
+ stack_name = stack_name(stack_name)
23
25
  resp = describe_stack_resources(stack_name: stack_name)
24
26
  resources = resp.stack_resources
25
27
  resource = resources.find { |r| r.logical_resource_id == logical_id }
26
28
  if resource
27
29
  resource.physical_resource_id
28
30
  else
29
- "NOT FOUND: logical_id #{logical_id} for stack #{stack_name}"
31
+ logger.info "WARN: NOT FOUND: logical_id #{logical_id} for stack #{stack_name}"
30
32
  end
31
33
  end
32
34
 
33
- def lookup_output(name)
34
- result = stack_output(name)
35
- return unless ENV['LONO_DEPRECATION_SOFT']
36
- puts "DEPRECATION WARNING: lookup_output is deprecated. Please use stack_output instead".color(:yellow)
37
- result
35
+ def stack_name(blueprint)
36
+ return blueprint unless Lono.config.names.output.expand
37
+ names = Lono::Names.new(blueprint: blueprint)
38
+ # explicit expansion pattern provided by user
39
+ pattern = blueprint.include?(':') ? blueprint : Lono.config.names.output.stack
40
+ names.expansion(pattern)
38
41
  end
39
42
 
40
43
  private
@@ -1,4 +1,4 @@
1
- module Lono::Template::Strategy::Dsl::Builder::Helpers
1
+ module Lono::Builder::Template::Dsl::Evaluator::Helpers
2
2
  module TagsHelper
3
3
  def tags(hash={})
4
4
  if hash.empty?
@@ -1,5 +1,5 @@
1
1
  # Built-in helpers for the DSL form
2
- class Lono::Template::Strategy::Dsl::Builder
2
+ class Lono::Builder::Template::Dsl::Evaluator
3
3
  module Helpers
4
4
  extend Memoist
5
5
 
@@ -11,6 +11,6 @@ class Lono::Template::Strategy::Dsl::Builder
11
11
  include klass.constantize
12
12
  end
13
13
 
14
- include Lono::Template::Strategy::Common::Helpers
14
+ include Lono::Builder::Template::Helpers
15
15
  end
16
16
  end
@@ -0,0 +1,23 @@
1
+ module Lono::Builder::Template::Dsl::Evaluator::Section
2
+ class Base
3
+ include Lono::Builder::Template::Dsl::Evaluator::Fn
4
+ include Lono::Builder::Template::Dsl::Evaluator::Helpers
5
+ include Lono::Builder::Template::Dsl::Evaluator::Stringify
6
+
7
+ def initialize(blueprint, *definition)
8
+ @blueprint = blueprint
9
+ @definition = definition.flatten
10
+ end
11
+
12
+ private
13
+ def camelize(attributes)
14
+ data = stringify!(attributes)
15
+ clean(data)
16
+ end
17
+
18
+ # Remove items with nil value automatically
19
+ def clean(data)
20
+ Lono::Builder::Template::Dsl::Evaluator::Squeezer.new(data).squeeze
21
+ end
22
+ end
23
+ end
@@ -2,7 +2,7 @@
2
2
  #
3
3
  # template - uses @definition to build a CloudFormation template section
4
4
  #
5
- module Lono::Template::Strategy::Dsl::Builder::Section
5
+ module Lono::Builder::Template::Dsl::Evaluator::Section
6
6
  class Condition < Base
7
7
  def template
8
8
  camelize(standarize(@definition))
@@ -2,7 +2,7 @@
2
2
  #
3
3
  # template - uses @definition to build a CloudFormation template section
4
4
  #
5
- module Lono::Template::Strategy::Dsl::Builder::Section
5
+ module Lono::Builder::Template::Dsl::Evaluator::Section
6
6
  class Mapping < Base
7
7
  def template
8
8
  camelize(standarize(@definition))
@@ -1,5 +1,5 @@
1
1
  # Organize core section method syntax here
2
- module Lono::Template::Strategy::Dsl::Builder::Section
2
+ module Lono::Builder::Template::Dsl::Evaluator::Section
3
3
  module Methods
4
4
  def aws_template_format_version(version_date)
5
5
  @cfn["AWSTemplateFormatVersion"] = version_date
@@ -20,7 +20,7 @@ module Lono::Template::Strategy::Dsl::Builder::Section
20
20
 
21
21
  def parameter(*definition)
22
22
  @cfn["Parameters"] ||= {}
23
- param = Parameter.new(@blueprint, definition)
23
+ param = Parameter.new(@blueprint.name, definition)
24
24
  @cfn["Parameters"].merge!(param.template)
25
25
 
26
26
  # Additional decorations
@@ -33,32 +33,32 @@ module Lono::Template::Strategy::Dsl::Builder::Section
33
33
 
34
34
  def mapping(*definition)
35
35
  @cfn["Mappings"] ||= {}
36
- mapping = Mapping.new(@blueprint, definition)
36
+ mapping = Mapping.new(@blueprint.name, definition)
37
37
  @cfn["Mappings"].merge!(mapping.template)
38
38
  end
39
39
 
40
40
  def resource(*definition)
41
41
  @cfn["Resources"] ||= {}
42
- resource = Resource.new(@blueprint, definition)
42
+ resource = Resource.new(@blueprint.name, definition)
43
43
  @cfn["Resources"].merge!(resource.template)
44
44
  end
45
45
 
46
46
  def condition(*definition)
47
47
  @cfn["Conditions"] ||= {}
48
- condition = Condition.new(@blueprint, definition)
48
+ condition = Condition.new(@blueprint.name, definition)
49
49
  @cfn["Conditions"].merge!(condition.template)
50
50
  end
51
51
 
52
52
  def output(*definition)
53
53
  @cfn["Outputs"] ||= {}
54
- output = Output.new(@blueprint, definition)
54
+ output = Output.new(@blueprint.name, definition)
55
55
  @cfn["Outputs"].merge!(output.template)
56
56
  end
57
57
 
58
58
  # Generic section method in case CloudFormation adds a new future section.
59
59
  # The generic section method adds a new top-level key
60
60
  def section(key, definition)
61
- @cfn[key] = Section.new(@blueprint, definition).template
61
+ @cfn[key] = Section.new(@blueprint.name, definition).template
62
62
  end
63
63
  end
64
64
  end
@@ -2,7 +2,7 @@
2
2
  #
3
3
  # template - uses @definition to build a CloudFormation template section
4
4
  #
5
- module Lono::Template::Strategy::Dsl::Builder::Section
5
+ module Lono::Builder::Template::Dsl::Evaluator::Section
6
6
  class Output < Base
7
7
  def template
8
8
  camelize(standarize(@definition))
@@ -2,7 +2,7 @@
2
2
  #
3
3
  # template - uses @definition to build a CloudFormation template section
4
4
  #
5
- module Lono::Template::Strategy::Dsl::Builder::Section
5
+ module Lono::Builder::Template::Dsl::Evaluator::Section
6
6
  class Parameter < Base
7
7
  attr_accessor :group_label
8
8
  attr_reader :conditional, :label
@@ -1,4 +1,4 @@
1
- class Lono::Template::Strategy::Dsl::Builder::Section::Resource
1
+ class Lono::Builder::Template::Dsl::Evaluator::Section::Resource
2
2
  # Moves the property to the top-level attributes *destructively*
3
3
  class PropertyMover
4
4
  def initialize(resource, logical_id, properties)
@@ -2,7 +2,7 @@
2
2
  #
3
3
  # template - uses @definition to build a CloudFormation template section
4
4
  #
5
- module Lono::Template::Strategy::Dsl::Builder::Section
5
+ module Lono::Builder::Template::Dsl::Evaluator::Section
6
6
  class Resource < Base
7
7
  def template
8
8
  camelize(standarize(@definition))
@@ -2,7 +2,7 @@
2
2
  #
3
3
  # template - uses @definition to build a CloudFormation template section
4
4
  #
5
- module Lono::Template::Strategy::Dsl::Builder::Section
5
+ module Lono::Builder::Template::Dsl::Evaluator::Section
6
6
  class Section < Base
7
7
  def template
8
8
  hash, _ = @definition
@@ -1,4 +1,4 @@
1
- class Lono::Template::Strategy::Dsl::Builder
1
+ class Lono::Builder::Template::Dsl::Evaluator
2
2
  class Squeezer
3
3
  def initialize(data)
4
4
  @data = data
@@ -1,4 +1,4 @@
1
- class Lono::Template::Strategy::Dsl::Builder
1
+ class Lono::Builder::Template::Dsl::Evaluator
2
2
  module Stringify
3
3
  # Accounts for Arrays also. ActiveSupport only works for Hashes.
4
4
  def stringify!(data)
@@ -1,4 +1,4 @@
1
- module Lono::Template::Strategy::Dsl::Builder::Syntax
1
+ module Lono::Builder::Template::Dsl::Evaluator::Syntax
2
2
  module ExtendWith
3
3
  def extend_with(extension)
4
4
  # Do nothing during the main DSL evaluation. The extend_with logical actual runs during during the
@@ -1,4 +1,4 @@
1
- module Lono::Template::Strategy::Dsl::Builder::Syntax
1
+ module Lono::Builder::Template::Dsl::Evaluator::Syntax
2
2
  module ParameterGroup
3
3
  def parameter_group(label)
4
4
  @group_label = label
@@ -1,8 +1,8 @@
1
- # Encapsulates syntax methods so they can be included in both the Builder and Context scope
2
- class Lono::Template::Strategy::Dsl::Builder
1
+ # Encapsulates syntax methods so they can be included in both the Evaluator and Context scope
2
+ class Lono::Builder::Template::Dsl::Evaluator
3
3
  module Syntax
4
4
  include Fn
5
- include Lono::Template::Evaluate
5
+ include Lono::Builder::Template::Evaluate
6
6
  include Section::Methods
7
7
  include ParameterGroup
8
8
  include ExtendWith
@@ -0,0 +1,45 @@
1
+ class Lono::Builder::Template::Dsl
2
+ class Evaluator
3
+ include Lono::Extensions::Loader
4
+ include Lono::Utils::Context
5
+ include Lono::Builder::Context::Loader
6
+
7
+ include Syntax
8
+ extend Memoist
9
+
10
+ def initialize(options={})
11
+ @options = options
12
+ @blueprint = Lono::Blueprint.new(options)
13
+ @template_path = "#{@blueprint.root}/template.rb"
14
+ @parameters = [] # registry
15
+ @cfn = {}
16
+ end
17
+
18
+ def build
19
+ # TODO: load_all_extension_helpers # after Extensions::Preparer#run
20
+ load_variables unless seed? # both blueprint and project variables
21
+ load_blueprint_helpers
22
+ evaluate_template_paths(@template_path) # modifies @cfn
23
+ finalize
24
+ to_yaml
25
+ @cfn
26
+ end
27
+
28
+ def finalize
29
+ o = @options.merge(parameters: @parameters)
30
+ @cfn = Finalizer.new(@cfn, o).run
31
+ end
32
+
33
+ def to_yaml
34
+ # https://stackoverflow.com/questions/24508364/how-to-emit-yaml-in-ruby-expanding-aliases
35
+ # Trick to prevent YAML from emitting aliases
36
+ @cfn = YAML.load(@cfn.to_json)
37
+ end
38
+
39
+ # Dont want any existing files to prevent building the blueprint.
40
+ # This means that parameters cannot be based on vars. It's a trade-off.
41
+ def seed?
42
+ ARGV[0] == "seed"
43
+ end
44
+ end
45
+ end
@@ -1,7 +1,7 @@
1
- class Lono::Template::Strategy::Dsl::Finalizer
1
+ class Lono::Builder::Template::Dsl::Finalizer
2
2
  class ParameterGroups
3
3
  extend Memoist
4
- include Lono::Template::Strategy::Dsl::Builder::Stringify
4
+ include Lono::Builder::Template::Dsl::Evaluator::Stringify
5
5
 
6
6
  def initialize(cfn, parameters)
7
7
  @cfn, @parameters = cfn, parameters
@@ -1,4 +1,4 @@
1
- class Lono::Template::Strategy::Dsl
1
+ class Lono::Builder::Template::Dsl
2
2
  class Finalizer
3
3
  def initialize(cfn, options={})
4
4
  @cfn, @options = cfn, options
@@ -0,0 +1,14 @@
1
+ class Lono::Builder::Template
2
+ class Dsl < Lono::CLI::Base
3
+ attr_reader :results
4
+ def run
5
+ logger.info "Building template" unless @options[:quiet]
6
+ build_template
7
+ end
8
+
9
+ def build_template
10
+ evaluator = Evaluator.new(@options)
11
+ evaluator.build
12
+ end
13
+ end
14
+ end
@@ -1,13 +1,25 @@
1
- class Lono::Template
1
+ class Lono::Builder::Template
2
2
  module Evaluate
3
+ include Lono::Utils::Logging
4
+
5
+ # Example path: /full/path/to/project/app/blueprints/demo/template.rb
6
+ def evaluate_template_paths(path)
7
+ ext = File.extname(path)
8
+ folder = path.sub(ext, '')
9
+ expr = "#{folder}/**/*.rb"
10
+ evaluate_template_path(path) # process top-level template.rb first
11
+ Dir.glob(expr).each do |path|
12
+ evaluate_template_path(path)
13
+ end
14
+ end
15
+
3
16
  def evaluate_template_path(path)
4
17
  return unless File.exist?(path)
5
-
6
18
  begin
7
19
  instance_eval(File.read(path), path)
8
20
  rescue Exception => e
9
21
  template_evaluation_error(e)
10
- puts "\nFull error:"
22
+ logger.error "\nFull error:"
11
23
  raise
12
24
  end
13
25
  end
@@ -18,9 +30,9 @@ class Lono::Template
18
30
  error_info = lines.first
19
31
  path, line_no, _ = error_info.split(':')
20
32
  line_no = line_no.to_i
21
- puts "Error evaluating #{path}:".color(:red)
22
- puts e.message
23
- puts "Here's the line in #{path} with the error:\n\n"
33
+ logger.error "Error evaluating #{path}:".color(:red)
34
+ logger.error e.message
35
+ logger.error "Here's the line in #{path} with the error:\n\n"
24
36
 
25
37
  contents = IO.read(path)
26
38
  content_lines = contents.split("\n")
@@ -0,0 +1,149 @@
1
+ require "aws-sdk-core"
2
+
3
+ class Lono::Builder::Template
4
+ module Helpers
5
+ def template_s3_path(template_name)
6
+ # hi-jacking Uploader for https_url
7
+ template_path = "output/#{@blueprint.name}/templates/#{template_name}.yml"
8
+ Lono::S3::Uploader.new(template_path).s3_https_url
9
+ end
10
+
11
+ def template_params(param_name)
12
+ o = {
13
+ allow_not_exists: true
14
+ }.merge(@options)
15
+ o["param"] = param_name
16
+ generator = Lono::CLI::Param::Generator.new(o)
17
+ # do not generate because lono cfn calling logic already generated it we only need the values
18
+ parameters = generator.parameters # Returns Array in underscore keys format
19
+ # convert Array to simplified hash structure
20
+ parameters.inject({}) do |h, param|
21
+ h.merge(param[:parameter_key] => param[:parameter_value])
22
+ end
23
+ end
24
+
25
+ # Adjust the partial path so that it will use app/user_data
26
+ def user_data(path,vars={}, options={})
27
+ options.merge!(user_data: true)
28
+ partial(path,vars, options)
29
+ end
30
+
31
+ def current_region
32
+ region = Aws.config[:region]
33
+ region ||= ENV['AWS_REGION']
34
+ return region if region
35
+
36
+ default_region = 'us-east-1' # fallback if default not found in ~/.aws/config
37
+ if ENV['AWS_PROFILE']
38
+ path = "#{ENV['HOME']}/.aws/config"
39
+ if File.exist?(path)
40
+ lines = IO.readlines(path)
41
+ capture_default, capture_current = false, false
42
+ lines.each do | line|
43
+ if line.include?('[default]')
44
+ capture_default = true # next line
45
+ next
46
+ end
47
+ if capture_default && line.match(/region = /)
48
+ # over default from above
49
+ default_region = line.split(' = ').last.strip
50
+ capture_default = false
51
+ end
52
+
53
+ md = line.match(/\[profile (.*)\]/)
54
+ if md && md[1] == ENV['AWS_PROFILE']
55
+ capture_current = true
56
+ next
57
+ end
58
+ if capture_current && line.match(/region = /)
59
+ region = line.split(' = ').last.strip
60
+ capture_current = false
61
+ end
62
+ end
63
+ end
64
+
65
+ region ||= default_region
66
+ return region if region
67
+ end
68
+
69
+ 'us-east-1' # default
70
+ end
71
+
72
+ private
73
+ def render_path(path)
74
+ RenderMePretty.result(path, context: self)
75
+ end
76
+
77
+ def user_data_path_for(path)
78
+ "#{Lono.config.paths.user_data}/#{path}"
79
+ end
80
+
81
+ def auto_add_format(path)
82
+ # Return immediately if user provided explicit extension
83
+ extension = File.extname(path) # current extension
84
+ return path if !extension.empty?
85
+
86
+ # Else let's auto detect
87
+ paths = Dir.glob("#{path}.*")
88
+
89
+ if paths.size == 1 # non-ambiguous match
90
+ return paths.first
91
+ end
92
+
93
+ if paths.size > 1 # ambiguous match
94
+ logger.info "ERROR: Multiple possible partials found:".color(:red)
95
+ paths.each do |path|
96
+ logger.info " #{path}"
97
+ end
98
+ logger.info "Please specify an extension in the name to remove the ambiguity.".color(:green)
99
+ exit 1
100
+ end
101
+
102
+ # Account for case when user wants to include a file with no extension at all
103
+ return path if File.exist?(path) && !File.directory?(path)
104
+
105
+ path # original path if this point is reached
106
+ end
107
+
108
+ # Bash code that is meant to included in user-data
109
+ def extract_scripts(options={})
110
+ settings = Lono.config.extract_scripts
111
+ options = settings.merge(options)
112
+ # defaults also here in case they are removed from settings
113
+ to = options[:to] || "/opt"
114
+ user = options[:as] || "ec2-user"
115
+
116
+ if Dir.glob("#{Lono.config.paths.scripts}/*").empty?
117
+ logger.info "WARN: you are using the extract_scripts helper method but you do not have any scripts.".color(:yellow)
118
+ calling_line = caller[0].split(':')[0..1].join(':')
119
+ logger.info "Called from: #{calling_line}"
120
+ return ""
121
+ end
122
+
123
+ <<~BASH_CODE
124
+ # Generated from the lono extract_scripts helper.
125
+ # Downloads scripts from s3, extract them, and setup.
126
+ mkdir -p #{to}
127
+ aws s3 cp #{scripts_s3_path} #{to}/
128
+ (
129
+ cd #{to}
130
+ tar zxf #{to}/#{scripts_name}
131
+ chown -R #{user}:#{user} #{to}/scripts
132
+ )
133
+ BASH_CODE
134
+ end
135
+
136
+ def scripts_name
137
+ File.basename(scripts_s3_path)
138
+ end
139
+
140
+ def scripts_s3_path
141
+ upload = Lono::Script::Upload.new(@options)
142
+ upload.s3_dest
143
+ end
144
+
145
+ def setting
146
+ @setting ||= Lono::Setting.new
147
+ end
148
+ end
149
+ end
@@ -1,9 +1,9 @@
1
- module Lono::Output
2
- class Template
1
+ class Lono::Builder::Template
2
+ class Output
3
3
  extend Memoist
4
4
 
5
- def initialize(blueprint, template)
6
- @blueprint, @template = blueprint, template
5
+ def initialize(blueprint)
6
+ @blueprint = blueprint
7
7
  end
8
8
 
9
9
  def required_parameters
@@ -34,8 +34,16 @@ module Lono::Output
34
34
  end
35
35
  end
36
36
 
37
+ def outputs
38
+ data["Outputs"] || {}
39
+ end
40
+
41
+ def resources
42
+ data["Resources"] || {}
43
+ end
44
+
37
45
  def data
38
- template_path = "#{Lono.config.output_path}/#{@blueprint}/templates/#{@template}.yml"
46
+ template_path = "#{Lono.root}/output/#{@blueprint.name}/template.yml"
39
47
  check_template_exists!(template_path)
40
48
  YAML.load(IO.read(template_path))
41
49
  end
@@ -55,8 +63,7 @@ module Lono::Output
55
63
  # does not exist.
56
64
  def check_template_exists!(template_path)
57
65
  return if File.exist?(template_path)
58
- puts "The template #{template_path} does not exist. Are you sure you use the right template name? The template name does not require the extension.".color(:red)
59
- exit 1
66
+ raise "The template #{template_path} does not exist. Are you sure you use the right template name? The template name does not require the extension.".color(:red)
60
67
  end
61
68
  end
62
69
  end
@@ -1,5 +1,5 @@
1
- class Lono::Template
2
- class PostProcessor < Lono::AbstractBase
1
+ class Lono::Builder::Template
2
+ class PostProcessor < Lono::CLI::Base
3
3
  def run
4
4
  replacements.each do |placeholder, replacement|
5
5
  update_template!(template)
@@ -20,7 +20,7 @@ class Lono::Template
20
20
  elsif item.directory? || item.file?
21
21
  placeholder = "file://app/files/file/#{item.name}"
22
22
  else
23
- puts "WARN: PostProcessor replacements Cannot find file: #{item.output_path}"
23
+ logger.info "WARN: PostProcessor replacements Cannot find file: #{item.output_path}"
24
24
  next
25
25
  end
26
26
  map[placeholder] = item.s3_path
@@ -61,7 +61,7 @@ class Lono::Template
61
61
  memoize :template
62
62
 
63
63
  def template_path
64
- "#{Lono.config.output_path}/#{@blueprint}/templates/#{@template}.yml"
64
+ "#{Lono.root}/output/#{@blueprint.name}/templates/#{@template}.yml"
65
65
  end
66
66
  end
67
67
  end