ufo 5.0.6 → 6.0.1

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 +19 -0
  3. data/.cody/acceptance/bin/build.sh +90 -0
  4. data/.cody/acceptance/buildspec.yml +10 -0
  5. data/.cody/acceptance/project.rb +11 -0
  6. data/.cody/acceptance/role.rb +28 -0
  7. data/.cody/shared/script/install/ufo.sh +40 -0
  8. data/.cody/shared/script/install.sh +5 -0
  9. data/.github/workflows/main.yml +28 -0
  10. data/CHANGELOG.md +11 -1
  11. data/Gemfile +0 -2
  12. data/README.md +1 -32
  13. data/lib/templates/docker/Dockerfile +4 -0
  14. data/lib/templates/helper/%underscore_name%_helper.rb.tt +6 -0
  15. data/lib/templates/init/.ufo/config/web/base.rb +6 -0
  16. data/lib/templates/init/.ufo/config/web/dev.rb +6 -0
  17. data/lib/templates/init/.ufo/config/web/prod.rb +6 -0
  18. data/lib/templates/init/.ufo/config.rb.tt +39 -0
  19. data/lib/templates/init/.ufo/resources/iam_roles/execution_role.rb +23 -0
  20. data/lib/templates/init/.ufo/resources/iam_roles/task_role.rb +20 -0
  21. data/lib/templates/init/.ufo/resources/task_definitions/web.yml +29 -0
  22. data/lib/templates/init/.ufo/vars/base.rb +20 -0
  23. data/lib/templates/init/.ufo/vars/dev.rb +4 -0
  24. data/lib/templates/init/.ufo/vars/prod.rb +4 -0
  25. data/lib/ufo/aws_services.rb +118 -0
  26. data/lib/ufo/booter.rb +27 -0
  27. data/lib/ufo/cfn/base.rb +7 -0
  28. data/lib/ufo/cfn/deploy.rb +54 -0
  29. data/lib/ufo/{stack → cfn/stack}/builder/base.rb +12 -23
  30. data/lib/ufo/cfn/stack/builder/conditions.rb +25 -0
  31. data/lib/ufo/{stack → cfn/stack}/builder/outputs.rb +2 -2
  32. data/lib/ufo/cfn/stack/builder/parameters.rb +34 -0
  33. data/lib/ufo/cfn/stack/builder/resources/base.rb +4 -0
  34. data/lib/ufo/cfn/stack/builder/resources/dns.rb +47 -0
  35. data/lib/ufo/{stack/builder/resources/ecs.rb → cfn/stack/builder/resources/ecs_service.rb} +24 -10
  36. data/lib/ufo/cfn/stack/builder/resources/elb.rb +35 -0
  37. data/lib/ufo/cfn/stack/builder/resources/iam_roles/base.rb +32 -0
  38. data/lib/ufo/cfn/stack/builder/resources/iam_roles/execution_role.rb +4 -0
  39. data/lib/ufo/cfn/stack/builder/resources/iam_roles/task_role.rb +4 -0
  40. data/lib/ufo/cfn/stack/builder/resources/listener.rb +65 -0
  41. data/lib/ufo/cfn/stack/builder/resources/listener_ssl.rb +44 -0
  42. data/lib/ufo/cfn/stack/builder/resources/scaling/base.rb +5 -0
  43. data/lib/ufo/cfn/stack/builder/resources/scaling/policy.rb +27 -0
  44. data/lib/ufo/cfn/stack/builder/resources/scaling/role.rb +33 -0
  45. data/lib/ufo/cfn/stack/builder/resources/scaling/target.rb +22 -0
  46. data/lib/ufo/cfn/stack/builder/resources/security_group/base.rb +4 -0
  47. data/lib/ufo/{stack → cfn/stack}/builder/resources/security_group/ecs.rb +4 -4
  48. data/lib/ufo/{stack → cfn/stack}/builder/resources/security_group/ecs_rule.rb +2 -2
  49. data/lib/ufo/{stack → cfn/stack}/builder/resources/security_group/elb.rb +5 -6
  50. data/lib/ufo/{stack → cfn/stack}/builder/resources/target_group.rb +4 -4
  51. data/lib/ufo/{stack → cfn/stack}/builder/resources/task_definition/reconstructor.rb +4 -4
  52. data/lib/ufo/{stack → cfn/stack}/builder/resources/task_definition.rb +4 -4
  53. data/lib/ufo/cfn/stack/builder/resources.rb +24 -0
  54. data/lib/ufo/cfn/stack/builder.rb +30 -0
  55. data/lib/ufo/{stack → cfn/stack}/custom_properties.rb +21 -5
  56. data/lib/ufo/cfn/stack/params.rb +51 -0
  57. data/lib/ufo/{stack → cfn/stack}/status.rb +2 -2
  58. data/lib/ufo/cfn/stack/template.rb +8 -0
  59. data/lib/ufo/cfn/stack/vars.rb +110 -0
  60. data/lib/ufo/cfn/stack/vpc.rb +31 -0
  61. data/lib/ufo/cfn/stack.rb +175 -0
  62. data/lib/ufo/cli/base.rb +18 -0
  63. data/lib/ufo/cli/build.rb +30 -0
  64. data/lib/ufo/cli/cancel.rb +18 -0
  65. data/lib/ufo/cli/central/update.rb +80 -0
  66. data/lib/ufo/cli/central.rb +12 -0
  67. data/lib/ufo/cli/clean.rb +17 -0
  68. data/lib/ufo/cli/destroy.rb +31 -0
  69. data/lib/ufo/{docker.rb → cli/docker.rb} +18 -18
  70. data/lib/ufo/cli/exec.rb +82 -0
  71. data/lib/ufo/cli/help/central/update.md +20 -0
  72. data/lib/ufo/{help → cli/help}/completion.md +0 -0
  73. data/lib/ufo/{help → cli/help}/completion_script.md +0 -0
  74. data/lib/ufo/cli/help/destroy.md +9 -0
  75. data/lib/ufo/cli/help/docker/base.md +39 -0
  76. data/lib/ufo/{help → cli/help}/docker/build.md +9 -9
  77. data/lib/ufo/{help → cli/help}/docker/clean.md +8 -8
  78. data/lib/ufo/{help → cli/help}/docker/compile.md +0 -0
  79. data/lib/ufo/cli/help/docker/name.md +16 -0
  80. data/lib/ufo/{help → cli/help}/docker/push.md +0 -0
  81. data/lib/ufo/cli/help/docker.md +6 -0
  82. data/lib/ufo/{help → cli/help}/help.md +1 -1
  83. data/lib/ufo/cli/help/init.md +27 -0
  84. data/lib/ufo/{help → cli/help}/logs.md +5 -4
  85. data/lib/ufo/cli/help/ps.md +12 -0
  86. data/lib/ufo/cli/help/releases.md +15 -0
  87. data/lib/ufo/cli/help/rollback.md +40 -0
  88. data/lib/ufo/cli/help/scale.md +7 -0
  89. data/lib/ufo/cli/help/ship.md +41 -0
  90. data/lib/ufo/cli/help/stop.md +3 -0
  91. data/lib/ufo/cli/help.rb +62 -0
  92. data/lib/ufo/{logs.rb → cli/logs.rb} +13 -6
  93. data/lib/ufo/cli/new/concerns.rb +16 -0
  94. data/lib/ufo/cli/new/helper.rb +24 -0
  95. data/lib/ufo/cli/new/init.rb +68 -0
  96. data/lib/ufo/{sequence.rb → cli/new/sequence.rb} +26 -4
  97. data/lib/ufo/cli/new.rb +10 -0
  98. data/lib/ufo/cli/opts.rb +35 -0
  99. data/lib/ufo/cli/ps/errors.rb +116 -0
  100. data/lib/ufo/{ps → cli/ps}/task.rb +22 -29
  101. data/lib/ufo/cli/ps.rb +157 -0
  102. data/lib/ufo/{releases.rb → cli/releases.rb} +4 -4
  103. data/lib/ufo/{rollback.rb → cli/rollback.rb} +24 -12
  104. data/lib/ufo/cli/scale.rb +76 -0
  105. data/lib/ufo/cli/ship.rb +28 -0
  106. data/lib/ufo/cli/status.rb +8 -0
  107. data/lib/ufo/cli/stop.rb +49 -0
  108. data/lib/ufo/{tasks.rb → cli/tasks.rb} +2 -2
  109. data/lib/ufo/{upgrade.rb → cli/upgrade.rb} +2 -2
  110. data/lib/ufo/cli.rb +83 -172
  111. data/lib/ufo/command.rb +56 -1
  112. data/lib/ufo/concerns/autoscaling.rb +11 -0
  113. data/lib/ufo/concerns/names.rb +9 -0
  114. data/lib/ufo/concerns.rb +26 -0
  115. data/lib/ufo/config/inits.rb +13 -0
  116. data/lib/ufo/config.rb +190 -0
  117. data/lib/ufo/core.rb +32 -44
  118. data/lib/ufo/docker/builder.rb +44 -40
  119. data/lib/ufo/docker/cleaner.rb +9 -12
  120. data/lib/ufo/docker/compiler.rb +10 -4
  121. data/lib/ufo/docker/concerns.rb +7 -0
  122. data/lib/ufo/docker/dockerfile.rb +13 -9
  123. data/lib/ufo/docker/pusher.rb +13 -25
  124. data/lib/ufo/docker/state.rb +63 -0
  125. data/lib/ufo/ecr/auth.rb +8 -7
  126. data/lib/ufo/ecr/cleaner.rb +10 -14
  127. data/lib/ufo/ext/core/module.rb +31 -0
  128. data/lib/ufo/ext/core/nil_class.rb +11 -0
  129. data/lib/ufo/ext.rb +2 -0
  130. data/lib/ufo/{role → iam_role}/builder.rb +1 -1
  131. data/lib/ufo/{role → iam_role}/dsl.rb +8 -2
  132. data/lib/ufo/{role → iam_role}/registry.rb +1 -1
  133. data/lib/ufo/info.rb +22 -4
  134. data/lib/ufo/layering/layer.rb +95 -0
  135. data/lib/ufo/layering.rb +23 -0
  136. data/lib/ufo/log_group.rb +18 -10
  137. data/lib/ufo/logger/formatter.rb +13 -0
  138. data/lib/ufo/logger.rb +32 -0
  139. data/lib/ufo/names.rb +69 -0
  140. data/lib/ufo/param.rb +2 -1
  141. data/lib/ufo/task_definition/builder.rb +7 -0
  142. data/lib/ufo/task_definition/context.rb +45 -0
  143. data/lib/ufo/task_definition/erb/base.rb +18 -0
  144. data/lib/ufo/task_definition/erb/json.rb +28 -0
  145. data/lib/ufo/task_definition/erb/yaml.rb +18 -0
  146. data/lib/ufo/task_definition/erb.rb +78 -0
  147. data/lib/ufo/task_definition/helpers/aws_data_helper.rb +18 -0
  148. data/lib/ufo/task_definition/helpers/core.rb +50 -0
  149. data/lib/ufo/task_definition/helpers/ssm/fetcher.rb +39 -0
  150. data/lib/ufo/task_definition/helpers/ssm.rb +8 -0
  151. data/lib/ufo/task_definition/helpers/stack_output.rb +23 -0
  152. data/lib/ufo/{dsl/helper → task_definition/helpers}/vars.rb +40 -19
  153. data/lib/ufo/task_definition/helpers/vpc.rb +48 -0
  154. data/lib/ufo/task_definition/helpers.rb +5 -0
  155. data/lib/ufo/task_definition.rb +19 -0
  156. data/lib/ufo/upgrade/upgrade3.rb +1 -1
  157. data/lib/ufo/upgrade/upgrade4.rb +3 -3
  158. data/lib/ufo/utils/execute.rb +30 -0
  159. data/lib/ufo/utils/logging.rb +7 -0
  160. data/lib/ufo/utils/pretty.rb +18 -0
  161. data/lib/ufo/utils/squeezer.rb +1 -1
  162. data/lib/ufo/utils/sure.rb +23 -0
  163. data/lib/ufo/version.rb +1 -1
  164. data/lib/ufo/yaml/loader.rb +48 -0
  165. data/lib/ufo/yaml/validator.rb +51 -0
  166. data/lib/ufo/yaml.rb +13 -0
  167. data/lib/ufo.rb +14 -3
  168. data/spec/spec_helper.rb +4 -26
  169. data/spec/{lib → ufo}/ecr_auth_spec.rb +0 -0
  170. data/spec/{lib → ufo}/ecr_cleaner_spec.rb +0 -2
  171. data/spec/{lib/role → ufo/iam_role}/builder_spec.rb +5 -5
  172. data/spec/{lib/role → ufo/iam_role}/dsl_spec.rb +3 -3
  173. data/spec/{lib → ufo}/logs_spec.rb +2 -2
  174. data/ufo.gemspec +9 -3
  175. metadata +245 -341
  176. data/.circleci/bin/commit_docs.sh +0 -26
  177. data/.circleci/config.yml +0 -78
  178. data/.gitmodules +0 -0
  179. data/docs/.gitignore +0 -5
  180. data/docs/CNAME +0 -1
  181. data/docs/Gemfile +0 -4
  182. data/docs/LICENSE +0 -21
  183. data/docs/README.md +0 -20
  184. data/docs/_config.yml +0 -75
  185. data/docs/_docs/aws-ecs-task-execution-role.md +0 -28
  186. data/docs/_docs/conventions.md +0 -47
  187. data/docs/_docs/extras/codebuild-iam-role.md +0 -46
  188. data/docs/_docs/extras/dockerfile-erb.md +0 -60
  189. data/docs/_docs/extras/ecs-network-mode.md +0 -37
  190. data/docs/_docs/extras/load-balancer.md +0 -83
  191. data/docs/_docs/extras/minimal-deploy-iam.md +0 -79
  192. data/docs/_docs/extras/notification-arns.md +0 -21
  193. data/docs/_docs/extras/redirection-support.md +0 -27
  194. data/docs/_docs/extras/route53-support.md +0 -27
  195. data/docs/_docs/extras/security-groups.md +0 -36
  196. data/docs/_docs/extras/ssl-support.md +0 -20
  197. data/docs/_docs/faq.md +0 -100
  198. data/docs/_docs/fargate.md +0 -5
  199. data/docs/_docs/helpers.md +0 -24
  200. data/docs/_docs/iam-roles.md +0 -112
  201. data/docs/_docs/install.md +0 -25
  202. data/docs/_docs/more/auto-completion.md +0 -24
  203. data/docs/_docs/more/automated-cleanup.md +0 -14
  204. data/docs/_docs/more/customize-cloudformation.md +0 -35
  205. data/docs/_docs/more/migrations.md +0 -25
  206. data/docs/_docs/more/run-in-pieces.md +0 -30
  207. data/docs/_docs/more/single-task.md +0 -25
  208. data/docs/_docs/more/stuck-cloudformation.md +0 -29
  209. data/docs/_docs/more/why-cloudformation.md +0 -21
  210. data/docs/_docs/next-steps.md +0 -16
  211. data/docs/_docs/quick-start-ec2.md +0 -86
  212. data/docs/_docs/secrets.md +0 -135
  213. data/docs/_docs/settings/aws_profile.md +0 -36
  214. data/docs/_docs/settings/cfn.md +0 -12
  215. data/docs/_docs/settings/cluster.md +0 -66
  216. data/docs/_docs/settings/manage-security-groups.md +0 -24
  217. data/docs/_docs/settings/network.md +0 -45
  218. data/docs/_docs/settings.md +0 -55
  219. data/docs/_docs/ssl_errors.md +0 -40
  220. data/docs/_docs/structure.md +0 -41
  221. data/docs/_docs/tutorial-ufo-docker-build.md +0 -61
  222. data/docs/_docs/tutorial-ufo-init.md +0 -86
  223. data/docs/_docs/tutorial-ufo-ship.md +0 -95
  224. data/docs/_docs/tutorial-ufo-ships.md +0 -38
  225. data/docs/_docs/tutorial-ufo-tasks-build.md +0 -177
  226. data/docs/_docs/tutorial.md +0 -14
  227. data/docs/_docs/ufo-current.md +0 -49
  228. data/docs/_docs/ufo-env-extra.md +0 -22
  229. data/docs/_docs/ufo-env.md +0 -46
  230. data/docs/_docs/ufo-logs.md +0 -49
  231. data/docs/_docs/ufo-task-params.md +0 -43
  232. data/docs/_docs/ufo-tasks-register.md +0 -21
  233. data/docs/_docs/upgrading/upgrade4.5.md +0 -52
  234. data/docs/_docs/upgrading/upgrade4.md +0 -48
  235. data/docs/_docs/upgrading/upgrade5.md +0 -19
  236. data/docs/_docs/upgrading.md +0 -13
  237. data/docs/_docs/variables.md +0 -55
  238. data/docs/_includes/about.html +0 -19
  239. data/docs/_includes/banner/foot.html +0 -2
  240. data/docs/_includes/banner/head.html +0 -5
  241. data/docs/_includes/cfn-customize.md +0 -53
  242. data/docs/_includes/commands.html +0 -80
  243. data/docs/_includes/contact.html +0 -17
  244. data/docs/_includes/contact_disqus.html +0 -16
  245. data/docs/_includes/contact_static.html +0 -17
  246. data/docs/_includes/content.html +0 -26
  247. data/docs/_includes/css/bootstrap.min.css +0 -7
  248. data/docs/_includes/css/main.css +0 -501
  249. data/docs/_includes/css/quotes.css +0 -102
  250. data/docs/_includes/css/syntax.css +0 -65
  251. data/docs/_includes/css/table.css +0 -53
  252. data/docs/_includes/css/timeline.css +0 -201
  253. data/docs/_includes/css/ufo.css +0 -218
  254. data/docs/_includes/edit-on-github.html +0 -11
  255. data/docs/_includes/example.html +0 -63
  256. data/docs/_includes/footer.html +0 -44
  257. data/docs/_includes/google_analytics.html +0 -10
  258. data/docs/_includes/head.html +0 -32
  259. data/docs/_includes/header.html +0 -15
  260. data/docs/_includes/js.html +0 -32
  261. data/docs/_includes/js_disqus.html +0 -21
  262. data/docs/_includes/modals.html +0 -40
  263. data/docs/_includes/nav.html +0 -27
  264. data/docs/_includes/prev_next.md +0 -19
  265. data/docs/_includes/quotes.html +0 -19
  266. data/docs/_includes/reference.md +0 -5
  267. data/docs/_includes/repo_push_access.md +0 -11
  268. data/docs/_includes/subnav.html +0 -78
  269. data/docs/_includes/summary.html +0 -22
  270. data/docs/_includes/ufo-ship-options.md +0 -12
  271. data/docs/_includes/uses.html +0 -19
  272. data/docs/_layouts/default.html +0 -13
  273. data/docs/_layouts/style.css +0 -6
  274. data/docs/_reference/ufo-apps.md +0 -37
  275. data/docs/_reference/ufo-cancel.md +0 -24
  276. data/docs/_reference/ufo-completion.md +0 -46
  277. data/docs/_reference/ufo-completion_script.md +0 -27
  278. data/docs/_reference/ufo-current.md +0 -93
  279. data/docs/_reference/ufo-deploy.md +0 -76
  280. data/docs/_reference/ufo-destroy.md +0 -36
  281. data/docs/_reference/ufo-docker-base.md +0 -71
  282. data/docs/_reference/ufo-docker-build.md +0 -91
  283. data/docs/_reference/ufo-docker-clean.md +0 -44
  284. data/docs/_reference/ufo-docker-compile.md +0 -19
  285. data/docs/_reference/ufo-docker-help.md +0 -15
  286. data/docs/_reference/ufo-docker-name.md +0 -37
  287. data/docs/_reference/ufo-docker-push.md +0 -49
  288. data/docs/_reference/ufo-docker.md +0 -38
  289. data/docs/_reference/ufo-init.md +0 -125
  290. data/docs/_reference/ufo-logs.md +0 -40
  291. data/docs/_reference/ufo-network-help.md +0 -15
  292. data/docs/_reference/ufo-network-init.md +0 -39
  293. data/docs/_reference/ufo-network.md +0 -26
  294. data/docs/_reference/ufo-ps.md +0 -56
  295. data/docs/_reference/ufo-releases.md +0 -40
  296. data/docs/_reference/ufo-resources.md +0 -44
  297. data/docs/_reference/ufo-rollback.md +0 -61
  298. data/docs/_reference/ufo-scale.md +0 -50
  299. data/docs/_reference/ufo-ship.md +0 -129
  300. data/docs/_reference/ufo-ships.md +0 -68
  301. data/docs/_reference/ufo-status.md +0 -23
  302. data/docs/_reference/ufo-stop.md +0 -31
  303. data/docs/_reference/ufo-task.md +0 -56
  304. data/docs/_reference/ufo-tasks-build.md +0 -178
  305. data/docs/_reference/ufo-tasks-help.md +0 -15
  306. data/docs/_reference/ufo-tasks-register.md +0 -29
  307. data/docs/_reference/ufo-tasks.md +0 -35
  308. data/docs/_reference/ufo-upgrade-help.md +0 -15
  309. data/docs/_reference/ufo-upgrade-v2to3.md +0 -15
  310. data/docs/_reference/ufo-upgrade-v33to34.md +0 -15
  311. data/docs/_reference/ufo-upgrade-v3to4.md +0 -27
  312. data/docs/_reference/ufo-upgrade-v43to45.md +0 -15
  313. data/docs/_reference/ufo-upgrade.md +0 -29
  314. data/docs/_reference/ufo-version.md +0 -23
  315. data/docs/articles.md +0 -14
  316. data/docs/bin/web +0 -4
  317. data/docs/css/font-awesome/css/font-awesome.css +0 -1566
  318. data/docs/css/font-awesome/css/font-awesome.min.css +0 -4
  319. data/docs/css/font-awesome/fonts/FontAwesome.otf +0 -0
  320. data/docs/css/font-awesome/fonts/fontawesome-webfont.eot +0 -0
  321. data/docs/css/font-awesome/fonts/fontawesome-webfont.svg +0 -504
  322. data/docs/css/font-awesome/fonts/fontawesome-webfont.ttf +0 -0
  323. data/docs/css/font-awesome/fonts/fontawesome-webfont.woff +0 -0
  324. data/docs/docs.md +0 -29
  325. data/docs/img/docs/cloudformation-resources.png +0 -0
  326. data/docs/img/logos/boltops-logo-full.png +0 -0
  327. data/docs/img/logos/boltops-logo.png +0 -0
  328. data/docs/img/logos/ufo-logo-2.png +0 -0
  329. data/docs/img/logos/ufo-logo.png +0 -0
  330. data/docs/img/logos/ufo-site-header.png +0 -0
  331. data/docs/img/logos/ufo.jpg +0 -0
  332. data/docs/img/tutorials/ecs-console-task-definitions.png +0 -0
  333. data/docs/img/tutorials/ecs-console-ufo-ship.png +0 -0
  334. data/docs/img/tutorials/ecs-console-ufo-ships.png +0 -0
  335. data/docs/index.html +0 -10
  336. data/docs/js/bootstrap.js +0 -2114
  337. data/docs/js/bootstrap.min.js +0 -6
  338. data/docs/js/cbpAnimatedHeader.js +0 -44
  339. data/docs/js/cbpAnimatedHeader.min.js +0 -11
  340. data/docs/js/classie.js +0 -80
  341. data/docs/js/contact_me.js +0 -70
  342. data/docs/js/contact_me_static.js +0 -23
  343. data/docs/js/freelancer.js +0 -37
  344. data/docs/js/jqBootstrapValidation.js +0 -912
  345. data/docs/js/jquery-1.11.0.js +0 -4
  346. data/docs/js/jquery.easing.min.js +0 -44
  347. data/docs/js/nav.js +0 -53
  348. data/docs/quick-start.md +0 -133
  349. data/docs/reference.md +0 -29
  350. data/docs/style.css +0 -3
  351. data/docs/utils/ssl-doctor.rb +0 -89
  352. data/docs/utils/test-aws-api-access.rb +0 -11
  353. data/docs/utils/update-cert-chains.sh +0 -11
  354. data/lib/template/.env +0 -3
  355. data/lib/template/.secrets +0 -5
  356. data/lib/template/.ufo/iam_roles/execution_role.rb +0 -7
  357. data/lib/template/.ufo/iam_roles/task_role.rb +0 -21
  358. data/lib/template/.ufo/params.yml.tt +0 -27
  359. data/lib/template/.ufo/settings/cfn/default.yml.tt +0 -72
  360. data/lib/template/.ufo/settings/network/default.yml.tt +0 -26
  361. data/lib/template/.ufo/settings.yml.tt +0 -26
  362. data/lib/template/.ufo/task_definitions.rb.tt +0 -61
  363. data/lib/template/.ufo/templates/fargate.json.erb +0 -39
  364. data/lib/template/.ufo/templates/main.json.erb +0 -43
  365. data/lib/template/.ufo/variables/base.rb.tt +0 -19
  366. data/lib/template/.ufo/variables/development.rb +0 -8
  367. data/lib/template/.ufo/variables/production.rb +0 -7
  368. data/lib/template/Dockerfile +0 -15
  369. data/lib/template/bin/deploy.tt +0 -7
  370. data/lib/ufo/apps/cfn_map.rb +0 -70
  371. data/lib/ufo/apps/cluster.rb +0 -24
  372. data/lib/ufo/apps/service.rb +0 -56
  373. data/lib/ufo/apps.rb +0 -56
  374. data/lib/ufo/aws_service.rb +0 -36
  375. data/lib/ufo/base.rb +0 -35
  376. data/lib/ufo/cancel.rb +0 -23
  377. data/lib/ufo/current.rb +0 -104
  378. data/lib/ufo/default/settings.yml +0 -24
  379. data/lib/ufo/default/templates/main.json.erb +0 -39
  380. data/lib/ufo/destroy.rb +0 -41
  381. data/lib/ufo/docker/variables.rb +0 -26
  382. data/lib/ufo/dsl/helper.rb +0 -79
  383. data/lib/ufo/dsl/outputter.rb +0 -43
  384. data/lib/ufo/dsl/task_definition.rb +0 -108
  385. data/lib/ufo/dsl.rb +0 -96
  386. data/lib/ufo/help/apps.md +0 -12
  387. data/lib/ufo/help/balancer.md +0 -3
  388. data/lib/ufo/help/completions.md +0 -16
  389. data/lib/ufo/help/completions_script.md +0 -1
  390. data/lib/ufo/help/current.md +0 -65
  391. data/lib/ufo/help/deploy.md +0 -38
  392. data/lib/ufo/help/destroy.md +0 -9
  393. data/lib/ufo/help/docker/base.md +0 -49
  394. data/lib/ufo/help/docker/name.md +0 -16
  395. data/lib/ufo/help/docker.md +0 -6
  396. data/lib/ufo/help/init.md +0 -91
  397. data/lib/ufo/help/network/init.md +0 -13
  398. data/lib/ufo/help/ps.md +0 -27
  399. data/lib/ufo/help/releases.md +0 -16
  400. data/lib/ufo/help/resources.md +0 -20
  401. data/lib/ufo/help/rollback.md +0 -35
  402. data/lib/ufo/help/scale.md +0 -26
  403. data/lib/ufo/help/ship.md +0 -95
  404. data/lib/ufo/help/ships.md +0 -35
  405. data/lib/ufo/help/stop.md +0 -7
  406. data/lib/ufo/help/task.md +0 -27
  407. data/lib/ufo/help/tasks/build.md +0 -158
  408. data/lib/ufo/help/tasks/register.md +0 -14
  409. data/lib/ufo/help/tasks.md +0 -7
  410. data/lib/ufo/help/upgrade/v3to4.md +0 -3
  411. data/lib/ufo/help.rb +0 -9
  412. data/lib/ufo/init.rb +0 -119
  413. data/lib/ufo/network/fetch.rb +0 -48
  414. data/lib/ufo/network/helper.rb +0 -23
  415. data/lib/ufo/network/init.rb +0 -26
  416. data/lib/ufo/network.rb +0 -21
  417. data/lib/ufo/ps.rb +0 -129
  418. data/lib/ufo/scale.rb +0 -28
  419. data/lib/ufo/setting/profile.rb +0 -44
  420. data/lib/ufo/setting/security_groups.rb +0 -22
  421. data/lib/ufo/setting.rb +0 -75
  422. data/lib/ufo/settings.rb +0 -20
  423. data/lib/ufo/ship.rb +0 -103
  424. data/lib/ufo/stack/builder/conditions.rb +0 -23
  425. data/lib/ufo/stack/builder/parameters.rb +0 -45
  426. data/lib/ufo/stack/builder/resources/base.rb +0 -4
  427. data/lib/ufo/stack/builder/resources/dns.rb +0 -17
  428. data/lib/ufo/stack/builder/resources/elb.rb +0 -45
  429. data/lib/ufo/stack/builder/resources/listener.rb +0 -42
  430. data/lib/ufo/stack/builder/resources/listener_ssl.rb +0 -16
  431. data/lib/ufo/stack/builder/resources/roles/base.rb +0 -22
  432. data/lib/ufo/stack/builder/resources/roles/execution_role.rb +0 -4
  433. data/lib/ufo/stack/builder/resources/roles/task_role.rb +0 -4
  434. data/lib/ufo/stack/builder/resources/security_group/base.rb +0 -4
  435. data/lib/ufo/stack/builder/resources.rb +0 -20
  436. data/lib/ufo/stack/builder.rb +0 -26
  437. data/lib/ufo/stack/context.rb +0 -253
  438. data/lib/ufo/stack/helper.rb +0 -55
  439. data/lib/ufo/stack/template_body.rb +0 -13
  440. data/lib/ufo/stack.rb +0 -213
  441. data/lib/ufo/status.rb +0 -56
  442. data/lib/ufo/stop.rb +0 -49
  443. data/lib/ufo/task.rb +0 -225
  444. data/lib/ufo/tasks/builder.rb +0 -40
  445. data/lib/ufo/tasks/register.rb +0 -90
  446. data/lib/ufo/template_scope.rb +0 -57
  447. data/lib/ufo/util.rb +0 -69
  448. data/spec/lib/apps_spec.rb +0 -20
  449. data/spec/lib/builder_spec.rb +0 -23
  450. data/spec/lib/cli_spec.rb +0 -73
  451. data/spec/lib/completion_spec.rb +0 -18
  452. data/spec/lib/ps_spec.rb +0 -14
  453. data/spec/lib/register_spec.rb +0 -49
  454. data/spec/lib/setting_spec.rb +0 -18
  455. data/spec/lib/ship_spec.rb +0 -46
  456. data/spec/lib/stack/status_spec.rb +0 -76
  457. data/spec/lib/stop_spec.rb +0 -13
  458. data/spec/lib/task_spec.rb +0 -54
data/lib/ufo/core.rb CHANGED
@@ -4,65 +4,53 @@ require 'yaml'
4
4
  module Ufo
5
5
  module Core
6
6
  extend Memoist
7
- include Ufo::Settings
8
7
 
9
- def check_task_definition!(task_definition)
10
- task_definition_path = "#{Ufo.root}/.ufo/output/#{task_definition}.json"
11
- unless File.exist?(task_definition_path)
12
- puts "ERROR: Unable to find the task definition at #{task_definition_path}.".color(:red)
13
- puts "Are you sure you have defined it in .ufo/task_definitions.rb and it has been generated correctly in .ufo/output?".color(:red)
14
- puts "If you are calling `ufo deploy` directly, you might want to generate the task definition first with `ufo tasks build`."
15
- exit 1
16
- end
8
+ def role
9
+ ENV['UFO_ROLE'] || 'web'
17
10
  end
18
11
 
19
- def root
20
- path = ENV['UFO_ROOT'] || '.'
21
- Pathname.new(path)
12
+ def app
13
+ ENV['UFO_APP'] || config.app
22
14
  end
23
15
 
16
+ # v5: development is default
17
+ # v6: dev is default
24
18
  def env
25
- # 2-way binding
26
- ufo_env = env_from_profile || 'development'
27
- ufo_env = ENV['UFO_ENV'] if ENV['UFO_ENV'] # highest precedence
28
- ufo_env
19
+ ENV['UFO_ENV'] || 'dev'
29
20
  end
30
21
  memoize :env
31
22
 
32
- def env_extra
33
- env_extra = Current.env_extra
34
- env_extra = ENV['UFO_ENV_EXTRA'] if ENV['UFO_ENV_EXTRA'] # highest precedence
35
- return if env_extra&.empty?
36
- env_extra
23
+ def extra
24
+ extra = ENV['UFO_EXTRA'] if ENV['UFO_EXTRA'] # highest precedence
25
+ return if extra&.empty?
26
+ extra
27
+ end
28
+ memoize :extra
29
+
30
+ def root
31
+ path = ENV['UFO_ROOT'] || '.'
32
+ Pathname.new(path)
33
+ end
34
+
35
+ def log_root
36
+ "#{root}/log"
37
37
  end
38
- memoize :env_extra
39
38
 
40
- # Overrides AWS_PROFILE based on the Ufo.env if set in .ufo/settings.yml
41
- # 2-way binding.
42
- def set_aws_profile!
43
- return if ENV['TEST']
44
- return unless File.exist?("#{Ufo.root}/.ufo/settings.yml") # for rake docs
45
- return unless settings # Only load if within Ufo project and there's a settings.yml
46
- data = settings || {}
47
- if data[:aws_profile]
48
- puts "Using AWS_PROFILE=#{data[:aws_profile]} from UFO_ENV=#{Ufo.env} in config/settings.yml"
49
- ENV['AWS_PROFILE'] = data[:aws_profile]
50
- end
39
+ def configure(&block)
40
+ Config.instance.configure(&block)
51
41
  end
52
42
 
53
- def check_ufo_project!
54
- check_path = "#{Ufo.root}/.ufo/settings.yml"
55
- unless File.exist?(check_path)
56
- puts "ERROR: No settings file at #{check_path}. Are you sure you are in a project with ufo setup?".color(:red)
57
- puts "Current directory: #{Dir.pwd}"
58
- puts "If you want to set up ufo for this prjoect, please create a settings file via: ufo init"
59
- exit 1 unless ENV['TEST']
60
- end
43
+ # Generally, use the Lono.config instead of Config.instance.config since it guarantees the load_project_config call
44
+ def config
45
+ Config.instance.load_project_config
46
+ Config.instance.config
61
47
  end
48
+ memoize :config
62
49
 
63
- private
64
- def env_from_profile
65
- Ufo::Setting.new.ufo_env
50
+ # allow different logger when running up all or rspec-lono
51
+ cattr_writer :logger
52
+ def logger
53
+ @@logger ||= config.logger
66
54
  end
67
55
  end
68
56
  end
@@ -1,12 +1,11 @@
1
- require 'active_support/core_ext/module/delegation'
2
-
3
- class Ufo::Docker
1
+ module Ufo::Docker
4
2
  class Builder
5
- include Ufo::Util
3
+ extend Memoist
4
+ include Concerns
6
5
 
7
6
  delegate :push, to: :pusher
8
- def self.build(options)
9
- builder = Builder.new(options) # outside if because it need builder.full_image_name
7
+ def self.build(options={})
8
+ builder = Builder.new(options) # outside if because it need builder.docker_image
10
9
  builder.build
11
10
  pusher = Pusher.new(nil, options)
12
11
  pusher.push
@@ -21,28 +20,27 @@ class Ufo::Docker
21
20
 
22
21
  def build
23
22
  start_time = Time.now
24
- store_full_image_name
23
+ store_docker_image
25
24
 
26
- command = "docker build #{build_options}-t #{full_image_name} -f #{@dockerfile} ."
27
- say "Building docker image with:".color(:green)
28
- say " #{command}".color(:green)
25
+ logger.info "Building Docker Image"
29
26
  compile_dockerfile_erb
30
27
  check_dockerfile_exists
31
28
  update_auth_token
32
- command = "cd #{Ufo.root} && #{command}"
33
- success = execute(command, use_system: true)
29
+ command = "docker build #{build_options}-t #{docker_image} -f #{@dockerfile} ."
30
+ log = ".ufo/log/docker.log" if @options[:quiet]
31
+ success = execute(command, log: log)
34
32
  unless success
35
33
  docker_version_success = system("docker version > /dev/null 2>&1")
36
34
  unless docker_version_success
37
35
  docker_version_message = " Are you sure the docker daemon is available? Try running: docker version."
38
36
  end
39
- puts "ERROR: The docker image fail to build.#{docker_version_message}".color(:red)
37
+ logger.info "ERROR: Fail to build Docker image.#{docker_version_message}".color(:red)
40
38
  exit 1
41
39
  end
42
40
 
43
41
  took = Time.now - start_time
44
- say "Docker image #{full_image_name} built. "
45
- say "Docker build took #{pretty_time(took)}.".color(:green)
42
+ logger.info "Docker Image built: #{docker_image}"
43
+ logger.info "Took #{pretty_time(took)}"
46
44
  end
47
45
 
48
46
  def build_options
@@ -78,7 +76,7 @@ class Ufo::Docker
78
76
  end
79
77
 
80
78
  def pusher
81
- @pusher ||= Pusher.new(full_image_name, @options)
79
+ @pusher ||= Pusher.new(docker_image, @options)
82
80
  end
83
81
 
84
82
  def compile_dockerfile_erb
@@ -91,32 +89,38 @@ class Ufo::Docker
91
89
  if File.exist?(erb_path)
92
90
  compile_dockerfile_erb
93
91
  else
94
- puts "File #{erb_path.color(:green)} does not exist. Cannot compile it if it doesnt exist"
92
+ logger.info "File #{erb_path.color(:green)} does not exist. Cannot compile it if it doesnt exist"
95
93
  end
96
94
  end
97
95
 
98
96
  def check_dockerfile_exists
99
97
  unless File.exist?("#{Ufo.root}/#{@dockerfile}")
100
- puts "#{@dockerfile} does not exist. Are you sure it exists?"
98
+ logger.info "#{@dockerfile} does not exist. Are you sure it exists?"
101
99
  exit 1
102
100
  end
103
101
  end
104
102
 
105
103
  # full_image - does not include the tag
106
104
  def image_name
107
- settings[:image]
105
+ Ufo.config.docker.repo
108
106
  end
109
107
 
110
108
  # full_image - Includes the tag. Examples:
111
109
  # 123456789.dkr.ecr.us-west-2.amazonaws.com/myapp:ufo-2018-04-20T09-29-08-b7d51df
112
- # tongueroo/demo-ufo:ufo-2018-04-20T09-29-08-b7d51df
113
- def full_image_name
110
+ # org/repo:ufo-2018-04-20T09-29-08-b7d51df
111
+ def docker_image
114
112
  return generate_name if @options[:generate]
115
- return "tongueroo/demo-ufo:ufo-12345678" if ENV['TEST']
116
113
 
117
114
  unless File.exist?(docker_name_path)
118
- puts "Unable to find #{docker_name_path} which contains the last docker image name that was used as a part of `ufo docker build`. Please run `ufo docker build` first."
119
- exit 1
115
+ logger.info <<~EOL.color(:yellow)
116
+ WARN: Unable to find: #{pretty_path(docker_name_path)}
117
+ This contains the Docker image name that the build process uses.
118
+ Please first run:
119
+
120
+ ufo docker build
121
+
122
+ EOL
123
+ return "docker image not yet built"
120
124
  end
121
125
  IO.read(docker_name_path).strip
122
126
  end
@@ -125,44 +129,44 @@ class Ufo::Docker
125
129
  # and we want the image name to stay the same when the commands are run separate
126
130
  # in different processes. So we store the state in a file.
127
131
  # Only when a new docker build command gets run will the image name state be updated.
128
- def store_full_image_name
132
+ def store_docker_image
129
133
  dirname = File.dirname(docker_name_path)
130
134
  FileUtils.mkdir_p(dirname) unless File.exist?(dirname)
131
- full_image_name = generate_name
132
- IO.write(docker_name_path, full_image_name)
135
+ docker_image = generate_name
136
+ IO.write(docker_name_path, docker_image)
133
137
  end
134
138
 
135
139
  def generate_name
136
- "#{image_name}:#{@image_namespace}-#{timestamp}-#{git_sha}"
140
+ ["#{image_name}:#{@image_namespace}-#{timestamp}", git_sha].compact.join('-') # compact in case git_sha is unavailable
137
141
  end
138
142
 
139
143
  def docker_name_path
140
144
  # output gets entirely wiped by tasks builder so dotn use that folder
141
- "#{Ufo.root}/.ufo/data/docker_image_name_#{@image_namespace}.txt"
145
+ "#{Ufo.root}/.ufo/tmp/state/docker_image_name_#{@image_namespace}.txt"
142
146
  end
143
147
 
144
148
  def timestamp
145
- @timestamp ||= Time.now.strftime('%Y-%m-%dT%H-%M-%S')
149
+ Time.now.strftime('%Y-%m-%dT%H-%M-%S')
146
150
  end
151
+ memoize :timestamp
147
152
 
148
153
  def git_sha
149
- return @git_sha if @git_sha
150
- # always call this and dont use the execute method because of the noop option
151
- @git_sha = `cd #{Ufo.root} && git rev-parse --short HEAD`
152
- @git_sha.strip!
154
+ sha = if File.exist?('.git')
155
+ `git rev-parse --short HEAD`
156
+ elsif ENV['CODEBUILD_RESOLVED_SOURCE_VERSION'] # AWS codebuild
157
+ ENV['CODEBUILD_RESOLVED_SOURCE_VERSION'][0..6] # first 7 chars
158
+ end
159
+ sha.strip if sha
153
160
  end
161
+ memoize :git_sha
154
162
 
155
163
  def update_dockerfile
156
164
  updater = if File.exist?("#{Ufo.root}/Dockerfile.erb") # dont use @dockerfile on purpose
157
- Variables.new(full_image_name, @options)
165
+ State.new(docker_image, @options)
158
166
  else
159
- Dockerfile.new(full_image_name, @options)
167
+ Dockerfile.new(docker_image, @options)
160
168
  end
161
169
  updater.update
162
170
  end
163
-
164
- def say(msg)
165
- puts msg unless @options[:mute]
166
- end
167
171
  end
168
172
  end
@@ -1,26 +1,28 @@
1
- module Ufo
2
- class Docker::Cleaner
3
- include Util
1
+ module Ufo::Docker
2
+ class Cleaner
3
+ include Ufo::Utils::Execute
4
+ include Ufo::Utils::Logging
4
5
 
5
6
  def initialize(docker_image_name, options)
6
7
  # docker_image_name does not containg the tag
7
8
  # Example: 123456789.dkr.ecr.us-east-1.amazonaws.com/image
8
9
  @docker_image_name = docker_image_name
9
10
  @options = options
10
- @keep = options[:keep] || settings[:clean_keep] || 3
11
+ @keep = Ufo.config.docker.clean_keep
11
12
  @tag_prefix = options[:tag_prefix] || "ufo"
12
13
  end
13
14
 
14
15
  def cleanup
16
+ return if @keep.nil?
15
17
  return if delete_list.empty?
16
18
  command = "docker rmi #{delete_list}"
17
- say "Cleaning up docker images...".color(:green)
18
- say "=> #{"docker rmi #{delete_list}"}".color(:green)
19
+ logger.info "Cleaning docker images"
19
20
  return if @options[:noop]
20
- execute(command, use_system: false) # to use_system: false silence output
21
+ execute(command, quiet: true)
21
22
  end
22
23
 
23
24
  def delete_list
25
+ return if @keep.nil?
24
26
  return [] if ENV['TEST'] || @options[:noop]
25
27
  return @delete_list if @delete_list
26
28
 
@@ -44,10 +46,5 @@ module Ufo
44
46
  @delete_list = delete_tags.map { |t| "#{@docker_image_name}:#{t}" }.join(' ')
45
47
  end
46
48
  end
47
-
48
- def say(msg)
49
- msg = "NOOP #{msg}" if @options[:noop]
50
- puts msg unless @options[:mute]
51
- end
52
49
  end
53
50
  end
@@ -1,4 +1,4 @@
1
- class Ufo::Docker
1
+ module Ufo::Docker
2
2
  class Compiler
3
3
  def initialize(dockerfile)
4
4
  @dockerfile = dockerfile
@@ -9,13 +9,19 @@ class Ufo::Docker
9
9
  return unless File.exist?(@erb_file)
10
10
 
11
11
  puts "Compiled #{File.basename(@erb_file).color(:green)} to #{File.basename(@dockerfile).color(:green)}"
12
- path = "#{Ufo.root}/.ufo/settings/dockerfile_variables.yml"
12
+ path = "#{Ufo.root}/.ufo/state/data.yml"
13
13
  vars = YAML.load_file(path)[Ufo.env] if File.exist?(path)
14
14
  vars ||= {}
15
15
  result = RenderMePretty.result(@erb_file, vars)
16
16
  comment =<<~EOL.chop # remove the trailing newline
17
- # Note this file was generated from #{File.basename(@erb_file)} as a part of running ufo ship"
18
- # To update the FROM statement with the latest base docker image run: ufo docker base
17
+ # IMPORTANT: This file was generated from #{File.basename(@erb_file)} as a part of running:
18
+ #
19
+ # ufo ship
20
+ #
21
+ # To update the FROM statement with the latest base docker image use:
22
+ #
23
+ # ufo docker base
24
+ #
19
25
  EOL
20
26
  result = "#{comment}\n#{result}"
21
27
  IO.write(@dockerfile, result)
@@ -0,0 +1,7 @@
1
+ module Ufo::Docker
2
+ module Concerns
3
+ include Ufo::Utils::Execute
4
+ include Ufo::Utils::Logging
5
+ include Ufo::Utils::Pretty
6
+ end
7
+ end
@@ -1,7 +1,9 @@
1
- module Ufo
2
- class Docker::Dockerfile
3
- def initialize(full_image_name, options={})
4
- @full_image_name, @options = full_image_name, options
1
+ module Ufo::Docker
2
+ class Dockerfile
3
+ include Ufo::Utils::Logging
4
+
5
+ def initialize(docker_image, options={})
6
+ @docker_image, @options = docker_image, options
5
7
  end
6
8
 
7
9
  def update
@@ -21,7 +23,7 @@ module Ufo
21
23
  # replace FROM line
22
24
  new_lines = lines.map do |line|
23
25
  if line =~ /^FROM /
24
- "FROM #{@full_image_name}"
26
+ "FROM #{@docker_image}"
25
27
  else
26
28
  line
27
29
  end
@@ -31,10 +33,12 @@ module Ufo
31
33
 
32
34
  def write_new_dockerfile
33
35
  IO.write(dockerfile_path, new_dockerfile)
34
- unless @options[:mute]
35
- puts "The Dockerfile FROM statement has been updated with the latest base image:".color(:green)
36
- puts " #{@full_image_name}".color(:green)
37
- end
36
+ logger.debug <<~EOL
37
+ The Dockerfile FROM statement has been updated with the latest base image:
38
+
39
+ #{@docker_image}
40
+
41
+ EOL
38
42
  end
39
43
  end
40
44
  end
@@ -1,36 +1,29 @@
1
- require 'active_support/core_ext/module/delegation'
2
-
3
- class Ufo::Docker
1
+ module Ufo::Docker
4
2
  class Pusher
5
- include Ufo::Util
3
+ include Concerns
6
4
 
7
- delegate :full_image_name, to: :builder
5
+ delegate :docker_image, to: :builder
8
6
  attr_reader :last_image_name
9
7
  def initialize(image, options)
10
8
  @options = options
11
- # full_image_name ultimately uses @options, so @last_image_name assignment
9
+ # docker_image ultimately uses @options, so @last_image_name assignment
12
10
  # line must be defined after setting @options.
13
- @last_image_name = image || full_image_name
11
+ @last_image_name = image || docker_image
14
12
  end
15
13
 
16
14
  def push
17
15
  update_auth_token
18
16
  start_time = Time.now
19
- message = "Pushed #{last_image_name} docker image."
20
- if @options[:noop]
21
- message = "NOOP #{message}"
22
- else
23
- command = "docker push #{last_image_name}"
24
- puts "=> #{command}".color(:green)
25
- success = execute(command, use_system: true)
26
- unless success
27
- puts "ERROR: The docker image fail to push.".color(:red)
28
- exit 1
29
- end
17
+ logger.info "Pushing Docker Image"
18
+ command = "docker push #{last_image_name}"
19
+ log = ".ufo/log/docker.log" if @options[:quiet]
20
+ success = execute(command, log: log)
21
+ unless success
22
+ logger.info "ERROR: The docker image fail to push.".color(:red)
23
+ exit 1
30
24
  end
31
25
  took = Time.now - start_time
32
- message << "\nDocker push took #{pretty_time(took)}.".color(:green)
33
- puts message unless @options[:mute]
26
+ logger.info "Took #{pretty_time(took)}"
34
27
  end
35
28
 
36
29
  def builder
@@ -42,10 +35,5 @@ class Ufo::Docker
42
35
  # wont update auth token unless the image being pushed in the ECR image format
43
36
  auth.update
44
37
  end
45
-
46
- # full_image - does not include the tag
47
- def image_name
48
- settings[:image]
49
- end
50
38
  end
51
39
  end
@@ -0,0 +1,63 @@
1
+ module Ufo::Docker
2
+ class State
3
+ include Ufo::Utils::Logging
4
+ include Ufo::Utils::Pretty
5
+
6
+ def initialize(docker_image, options={})
7
+ @docker_image, @options = docker_image, options
8
+ end
9
+
10
+ def update
11
+ data = current_data
12
+ data[Ufo.env] ||= {}
13
+ data[Ufo.env]["base_image"] = @docker_image
14
+ pretty_path = state_path.sub("#{Ufo.root}/", "")
15
+ FileUtils.mkdir_p(File.dirname(state_path))
16
+ IO.write(state_path, YAML.dump(data))
17
+ logger.info "The #{pretty_path} base_image has been updated with the latest base image:".color(:green)
18
+ logger.info " #{@docker_image}".color(:green)
19
+ reminder_message
20
+ end
21
+
22
+ def current_data
23
+ File.exist?(state_path) ? YAML.load_file(state_path) : {}
24
+ end
25
+
26
+ def state_path
27
+ path = "#{Ufo.root}/.ufo/state"
28
+ if ENV['UFO_APP'] # env var activates app path
29
+ path = "#{Ufo.root}/.ufo/state/#{Ufo.app}"
30
+ end
31
+ "#{path}/data.yml"
32
+ end
33
+
34
+ def reminder_message
35
+ return unless Ufo.config.state.reminder
36
+ repo = ENV['UFO_CENTRAL_REPO']
37
+ return unless repo
38
+ logger.info "It looks like you're using a central deployer pattern".color(:yellow)
39
+ logger.info <<~EOL
40
+ Remember to commit the state file:
41
+
42
+ state file: #{pretty_path(state_path)}
43
+ repo: #{repo}
44
+
45
+ EOL
46
+
47
+ unless ENV['UFO_APP']
48
+ logger.info "WARN: It also doesnt look like UFO_ENV is set".color(:yellow)
49
+ logger.info "UFO_ENV should be set when you're using ufo in a central manner"
50
+ end
51
+
52
+ logger.info <<~EOL
53
+ You can disable these reminder messages with:
54
+
55
+ .ufo/config.rb
56
+
57
+ Ufo.configure do |config|
58
+ config.state.reminder = false
59
+ end
60
+ EOL
61
+ end
62
+ end
63
+ end
data/lib/ufo/ecr/auth.rb CHANGED
@@ -17,11 +17,12 @@ This class manipulates the ~/.docker/config.json file which is an internal docke
17
17
  =end
18
18
  module Ufo
19
19
  class Ecr::Auth
20
- include AwsService
20
+ include Ufo::AwsServices
21
+ include Ufo::Utils::Logging
21
22
 
22
- def initialize(full_image_name)
23
- @full_image_name = full_image_name
24
- @repo_domain = "#{full_image_name.split('/').first}"
23
+ def initialize(docker_image)
24
+ @docker_image = docker_image
25
+ @repo_domain = "#{docker_image.split('/').first}"
25
26
  end
26
27
 
27
28
  def update
@@ -32,16 +33,16 @@ module Ufo
32
33
  username, password = Base64.decode64(auth_token).split(':')
33
34
 
34
35
  command = "docker login -u #{username} --password-stdin #{@repo_domain}"
35
- puts "=> #{command}".color(:green)
36
+ logger.debug "=> #{command}".color(:green)
36
37
  *, status = Open3.capture3(command, stdin_data: password)
37
38
  unless status.success?
38
- puts "ERROR: The docker failed to login.".color(:red)
39
+ logger.error "ERROR: The docker failed to login.".color(:red)
39
40
  exit 1
40
41
  end
41
42
  end
42
43
 
43
44
  def ecr_image?
44
- !!(@full_image_name =~ /\.amazonaws\.com/)
45
+ !!(@docker_image =~ /\.amazonaws\.com/)
45
46
  end
46
47
 
47
48
  def fetch_auth_token
@@ -1,25 +1,23 @@
1
1
  require "json"
2
2
 
3
- # Can test:
4
- #
5
- # ufo ship app-web --cluster prod --noop
6
3
  module Ufo
7
4
  class Ecr::Cleaner
8
- include Util
9
- include AwsService
5
+ include Ufo::AwsServices
6
+ include Ufo::Utils::Execute
7
+ include Ufo::Utils::Logging
10
8
 
11
9
  def initialize(docker_image_name, options={})
12
10
  # docker_image_name does not containg the tag
13
11
  # Example: 123456789.dkr.ecr.us-east-1.amazonaws.com/image
14
12
  @docker_image_name = docker_image_name
15
13
  @options = options
16
- @keep = options[:ecr_keep] || settings[:ecr_keep]
14
+ @keep = options[:ecr_keep] || Ufo.config.docker.ecr_keep
17
15
  @tag_prefix = options[:tag_prefix] || "ufo"
18
16
  end
19
17
 
20
18
  def cleanup
21
- return false unless ecr_image?
22
19
  return false unless @keep
20
+ return false unless ecr_image?
23
21
  update_auth_token
24
22
  image_tags = fetch_image_tags
25
23
  delete_tags = image_tags[@keep..-1] # ordered by most recent images first
@@ -36,16 +34,14 @@ module Ufo
36
34
 
37
35
  def delete_images(tags)
38
36
  return if tags.nil? || tags.empty?
39
- unless @options[:mute]
40
- puts "Keeping #{@keep} most recent ECR images."
41
- puts "Deleting these ECR images:"
42
- tag_list = tags.map { |t| " #{repo_name}:#{t}" }
43
- puts tag_list
44
- end
37
+ logger.info "Keeping #{@keep} most recent ECR images."
38
+ logger.info "Deleting these ECR images:"
39
+ tag_list = tags.map { |t| " #{repo_name}:#{t}" }
40
+ logger.info tag_list
45
41
  image_ids = tags.map { |tag| {image_tag: tag} }
46
42
  ecr.batch_delete_image(
47
43
  repository_name: repo_name,
48
- image_ids: image_ids) unless @options[:noop]
44
+ image_ids: image_ids)
49
45
  end
50
46
 
51
47
  def update_auth_token
@@ -0,0 +1,31 @@
1
+ class Module
2
+ # Include all modules within the relative folder. IE: for dsl/syntax/mod/*
3
+ #
4
+ # include Common
5
+ # include Provider
6
+ # # etc
7
+ #
8
+ # Caller lines are different for OSes:
9
+ #
10
+ # windows: "C:/Ruby31-x64/lib/ruby/gems/3.1.0/gems/lono-1.1.1/lib/lono/builder.rb:34:in `build'"
11
+ # linux: "/home/ec2-user/.rvm/gems/ruby-3.0.3/gems/lono-1.1.1/lib/lono/compiler/dsl/syntax/mod.rb:4:in `<module:Mod>'"
12
+ #
13
+ def include_modules(dir)
14
+ caller_line = caller[0]
15
+ parts = caller_line.split(':')
16
+ calling_file = caller_line.match(/^[a-zA-Z]:/) ? parts[1] : parts[0]
17
+ parent_dir = File.dirname(calling_file)
18
+
19
+ full_dir = "#{parent_dir}/#{dir}"
20
+ paths = Dir.glob("#{full_dir}/**/*.rb")
21
+ if paths.empty?
22
+ raise "Empty include_modules full_dir: #{full_dir}"
23
+ end
24
+ paths.each do |path|
25
+ regexp = Regexp.new(".*/lib/")
26
+ mod = path.sub(regexp, '').sub('.rb','').camelize
27
+ c = mod.constantize
28
+ include c if c.class == Module
29
+ end
30
+ end
31
+ end
@@ -0,0 +1,11 @@
1
+ require "json"
2
+
3
+ module Ufo
4
+ refine NilClass do
5
+ def to_json
6
+ JSON.generate(self)
7
+ end
8
+ end
9
+ end
10
+
11
+ using Ufo
data/lib/ufo/ext.rb ADDED
@@ -0,0 +1,2 @@
1
+ require_relative "ext/core/module"
2
+ require_relative "ext/core/nil_class"
@@ -1,4 +1,4 @@
1
- module Ufo::Role
1
+ module Ufo::IamRole
2
2
  class Builder
3
3
  def initialize(role_type)
4
4
  @role_type = role_type