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.
- checksums.yaml +4 -4
- data/.cody/README.md +5 -15
- data/.cody/acceptance/bin/build.sh +52 -0
- data/.cody/acceptance/buildspec.yml +10 -0
- data/.cody/acceptance/project.rb +6 -0
- data/.cody/{role.rb → acceptance/role.rb} +0 -0
- data/.cody/shared/script/install/lono.sh +40 -0
- data/.cody/shared/script/install.sh +5 -0
- data/CHANGELOG.md +21 -4
- data/CONTRIBUTING.md +2 -2
- data/Gemfile +5 -1
- data/LICENSE.txt +201 -1
- data/README.md +4 -4
- data/lib/lono/api/client.rb +3 -2
- data/lib/lono/app/inits.rb +13 -0
- data/lib/lono/app.rb +71 -0
- data/lib/lono/app_file/base.rb +1 -1
- data/lib/lono/app_file/build/lambda_layer/ruby_packager.rb +9 -9
- data/lib/lono/app_file/build/lambda_layer.rb +3 -3
- data/lib/lono/app_file/build.rb +9 -14
- data/lib/lono/app_file/registry/item.rb +4 -4
- data/lib/lono/app_file/upload.rb +1 -1
- data/lib/lono/autoloader.rb +2 -2
- data/lib/lono/aws_services/helper.rb +43 -6
- data/lib/lono/aws_services.rb +37 -6
- data/lib/lono/blueprint.rb +18 -9
- data/lib/lono/booter.rb +28 -0
- data/lib/lono/{template → builder}/context/helpers.rb +1 -1
- data/lib/lono/{template → builder}/context/loader/load_files.rb +5 -6
- data/lib/lono/builder/context/loader.rb +35 -0
- data/lib/lono/builder/context/params.rb +7 -0
- data/lib/lono/{template → builder}/context/ssm_fetcher.rb +1 -1
- data/lib/lono/{template → builder}/context.rb +5 -9
- data/lib/lono/{param/generator.rb → builder/param.rb} +21 -22
- data/lib/lono/builder/template/aws_service.rb +15 -0
- data/lib/lono/builder/template/bashify.rb +43 -0
- data/lib/lono/{template → builder/template}/configset_injector.rb +4 -4
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/fn.rb +2 -2
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/helpers/core_helper.rb +1 -1
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/helpers/ec2_helper.rb +1 -1
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/helpers/file_helper.rb +8 -12
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/helpers/s3_helper.rb +2 -2
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/helpers/stack_helper.rb +11 -8
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/helpers/tags_helper.rb +1 -1
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/helpers.rb +2 -2
- data/lib/lono/builder/template/dsl/evaluator/section/base.rb +23 -0
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/condition.rb +1 -1
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/mapping.rb +1 -1
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/methods.rb +7 -7
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/output.rb +1 -1
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/parameter.rb +1 -1
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/resource/property_mover.rb +1 -1
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/resource.rb +1 -1
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/section.rb +1 -1
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/squeezer.rb +1 -1
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/stringify.rb +1 -1
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/syntax/extend_with.rb +1 -1
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/syntax/parameter_group.rb +1 -1
- data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/syntax.rb +3 -3
- data/lib/lono/builder/template/dsl/evaluator.rb +45 -0
- data/lib/lono/{template/strategy → builder/template}/dsl/finalizer/parameter_groups.rb +2 -2
- data/lib/lono/{template/strategy → builder/template}/dsl/finalizer.rb +1 -1
- data/lib/lono/builder/template/dsl.rb +14 -0
- data/lib/lono/{template → builder/template}/evaluate.rb +18 -6
- data/lib/lono/builder/template/helpers.rb +149 -0
- data/lib/lono/{output/template.rb → builder/template/output.rb} +14 -7
- data/lib/lono/{template → builder/template}/post_processor.rb +4 -4
- data/lib/lono/{template → builder/template}/upload.rb +3 -5
- data/lib/lono/builder/template.rb +55 -0
- data/lib/lono/bundler/cli/base.rb +10 -0
- data/lib/lono/bundler/cli/bundle.rb +44 -0
- data/lib/lono/bundler/cli/clean.rb +27 -0
- data/lib/lono/bundler/cli/help/bundle.md +3 -0
- data/lib/lono/bundler/cli/help.rb +11 -0
- data/lib/lono/bundler/cli.rb +7 -0
- data/lib/lono/bundler/component/concerns/local_concern.rb +10 -0
- data/lib/lono/bundler/component/concerns/notation_concern.rb +59 -0
- data/lib/lono/bundler/component/concerns/path_concern.rb +68 -0
- data/lib/lono/bundler/component/concerns/stack_concern.rb +60 -0
- data/lib/lono/bundler/component/fetcher/base.rb +27 -0
- data/lib/lono/bundler/component/fetcher/gcs.rb +69 -0
- data/lib/lono/bundler/component/fetcher/git.rb +69 -0
- data/lib/lono/bundler/component/fetcher/local.rb +15 -0
- data/lib/lono/bundler/component/fetcher/s3.rb +66 -0
- data/lib/lono/bundler/component/fetcher.rb +18 -0
- data/lib/lono/bundler/component/http/concern.rb +45 -0
- data/lib/lono/bundler/component/http/source.rb +19 -0
- data/lib/lono/bundler/component/org_repo.rb +65 -0
- data/lib/lono/bundler/component/props/extension.rb +19 -0
- data/lib/lono/bundler/component/props/typer.rb +41 -0
- data/lib/lono/bundler/component/props.rb +122 -0
- data/lib/lono/bundler/component/registry.rb +136 -0
- data/lib/lono/bundler/component.rb +52 -0
- data/lib/lono/bundler/config.rb +18 -0
- data/lib/lono/bundler/dsl/syntax.rb +46 -0
- data/lib/lono/bundler/dsl.rb +21 -0
- data/lib/lono/bundler/exporter/base.rb +6 -0
- data/lib/lono/bundler/exporter/copy.rb +22 -0
- data/lib/lono/bundler/exporter.rb +50 -0
- data/lib/lono/bundler/extract/tar.rb +34 -0
- data/lib/lono/bundler/extract/zip.rb +16 -0
- data/lib/lono/bundler/info.rb +39 -0
- data/lib/lono/bundler/list.rb +26 -0
- data/lib/lono/bundler/lockfile/version_comparer.rb +56 -0
- data/lib/lono/bundler/lockfile/yamler.rb +36 -0
- data/lib/lono/bundler/lockfile.rb +66 -0
- data/lib/lono/bundler/lonofile.rb +32 -0
- data/lib/lono/bundler/runner.rb +27 -0
- data/lib/lono/bundler/syncer.rb +70 -0
- data/lib/lono/bundler/util/git.rb +37 -0
- data/lib/lono/bundler/util/logging.rb +7 -0
- data/lib/lono/bundler/util/sure.rb +5 -0
- data/lib/lono/{bundle.rb → bundler.rb} +38 -4
- data/lib/lono/cfn/base.rb +9 -195
- data/lib/lono/cfn/cancel.rb +9 -26
- data/lib/lono/cfn/concerns/build.rb +10 -0
- data/lib/lono/cfn/concerns/template_output.rb +10 -0
- data/lib/lono/cfn/concerns.rb +43 -0
- data/lib/lono/cfn/delete.rb +8 -32
- data/lib/lono/cfn/deploy/base.rb +4 -0
- data/lib/lono/cfn/deploy/iam.rb +49 -0
- data/lib/lono/cfn/deploy/notification.rb +8 -0
- data/lib/lono/cfn/deploy/operable.rb +18 -0
- data/lib/lono/cfn/deploy/opts.rb +49 -0
- data/lib/lono/cfn/deploy/rollback.rb +46 -0
- data/lib/lono/cfn/deploy/tags.rb +18 -0
- data/lib/lono/cfn/deploy.rb +71 -5
- data/lib/lono/cfn/download.rb +5 -7
- data/lib/lono/cfn/output.rb +49 -0
- data/lib/lono/cfn/plan/base.rb +19 -0
- data/lib/lono/cfn/plan/changeset/base.rb +19 -0
- data/lib/lono/cfn/plan/changeset/notifications.rb +24 -0
- data/lib/lono/cfn/plan/changeset/outputs.rb +25 -0
- data/lib/lono/cfn/plan/changeset/resources.rb +48 -0
- data/lib/lono/cfn/plan/changeset/tags.rb +16 -0
- data/lib/lono/cfn/plan/changeset.rb +136 -0
- data/lib/lono/cfn/plan/concerns.rb +10 -0
- data/lib/lono/cfn/plan/delete.rb +16 -0
- data/lib/lono/cfn/plan/diff/base.rb +10 -0
- data/lib/lono/cfn/plan/diff/data.rb +52 -0
- data/lib/lono/cfn/plan/diff/file.rb +56 -0
- data/lib/lono/cfn/plan/new.rb +26 -0
- data/lib/lono/cfn/{preview → plan}/param.rb +26 -34
- data/lib/lono/cfn/plan/summary.rb +16 -0
- data/lib/lono/cfn/plan/template.rb +28 -0
- data/lib/lono/cfn/plan.rb +33 -0
- data/lib/lono/cfn/show.rb +30 -0
- data/lib/lono/cfn/status.rb +1 -1
- data/lib/lono/cli/abstract.rb +17 -0
- data/lib/lono/cli/base.rb +9 -0
- data/lib/lono/cli/build.rb +101 -0
- data/lib/lono/cli/bundle.rb +21 -0
- data/lib/lono/cli/cfn/opts.rb +59 -0
- data/lib/lono/cli/cfn.rb +19 -0
- data/lib/lono/cli/clean.rb +22 -0
- data/lib/lono/{code.rb → cli/code.rb} +2 -2
- data/lib/lono/{completion.rb → cli/completion.rb} +2 -2
- data/lib/lono/{help → cli/help}/blueprint/new.md +4 -4
- data/lib/lono/{help/generate.md → cli/help/build.md} +6 -6
- data/lib/lono/{help → cli/help}/cfn/cancel.md +0 -0
- data/lib/lono/cli/help/cfn/download.md +3 -0
- data/lib/lono/{help → cli/help}/cfn/preview.md +9 -8
- data/lib/lono/{help → cli/help}/cfn/status.md +0 -0
- data/lib/lono/cli/help/cfn.md +4 -0
- data/lib/lono/{help → cli/help}/code/convert.md +0 -0
- data/lib/lono/{help → cli/help}/code/import.md +2 -2
- data/lib/lono/{help → cli/help}/completion.md +3 -3
- data/lib/lono/{help → cli/help}/completion_script.md +0 -0
- data/lib/lono/{help → cli/help}/configsets.md +0 -0
- data/lib/lono/cli/help/down.md +13 -0
- data/lib/lono/cli/help/new/project.md +34 -0
- data/lib/lono/{help → cli/help}/param/generate.md +0 -0
- data/lib/lono/cli/help/param.md +6 -0
- data/lib/lono/{help → cli/help}/pro/blueprints.md +0 -0
- data/lib/lono/{help → cli/help}/pro/configsets.md +0 -0
- data/lib/lono/{help → cli/help}/script/build.md +0 -0
- data/lib/lono/{help → cli/help}/script/upload.md +0 -0
- data/lib/lono/{help → cli/help}/seed.md +2 -2
- data/lib/lono/cli/help/summary.md +33 -0
- data/lib/lono/{help → cli/help}/template/bashify.md +0 -0
- data/lib/lono/cli/help/template/generate.md +7 -0
- data/lib/lono/{help → cli/help}/template.md +0 -0
- data/lib/lono/cli/help/up.md +30 -0
- data/lib/lono/{help → cli/help}/user_data.md +3 -3
- data/lib/lono/cli/help.rb +56 -0
- data/lib/lono/cli/list.rb +28 -0
- data/lib/lono/cli/new/blueprint.rb +33 -0
- data/lib/lono/cli/new/concerns.rb +16 -0
- data/lib/lono/{configset/new.rb → cli/new/configset.rb} +2 -9
- data/lib/lono/{extension/new.rb → cli/new/extension.rb} +2 -10
- data/lib/lono/cli/new/helper.rb +32 -0
- data/lib/lono/cli/new/project.rb +77 -0
- data/lib/lono/cli/new/sequence.rb +51 -0
- data/lib/lono/cli/new/shim.rb +59 -0
- data/lib/lono/cli/new/test/blueprint.rb +23 -0
- data/lib/lono/cli/new/test/sequence.rb +10 -0
- data/lib/lono/cli/new/test.rb +8 -0
- data/lib/lono/cli/new.rb +31 -0
- data/lib/lono/{opts.rb → cli/opts.rb} +9 -12
- data/lib/lono/{s3.rb → cli/s3.rb} +9 -7
- data/lib/lono/cli/script/base.rb +5 -0
- data/lib/lono/cli/script/build.rb +72 -0
- data/lib/lono/cli/script/upload.rb +49 -0
- data/lib/lono/{script.rb → cli/script.rb} +2 -2
- data/lib/lono/cli/seed.rb +9 -0
- data/lib/lono/cli/test.rb +35 -0
- data/lib/lono/cli.rb +80 -109
- data/lib/lono/command.rb +27 -0
- data/lib/lono/configset/{generator.rb → builder.rb} +9 -7
- data/lib/lono/configset/combiner.rb +8 -6
- data/lib/lono/configset/evaluate_file.rb +1 -1
- data/lib/lono/configset/meta.rb +1 -1
- data/lib/lono/configset/s3_file/build.rb +5 -4
- data/lib/lono/configset/s3_file/item.rb +1 -1
- data/lib/lono/configset/s3_file/upload.rb +2 -2
- data/lib/lono/configset/strategy/base.rb +6 -6
- data/lib/lono/configset/strategy/helpers/dsl/core.rb +1 -1
- data/lib/lono/core.rb +25 -54
- data/lib/lono/extensions/dsl.rb +2 -5
- data/lib/lono/extensions/loader.rb +1 -12
- data/lib/lono/extensions.rb +2 -2
- data/lib/lono/importer/base.rb +5 -5
- data/lib/lono/importer/download.rb +7 -7
- data/lib/lono/importer/dsl.rb +3 -3
- data/lib/lono/importer/service/coder.rb +10 -10
- data/lib/lono/importer.rb +1 -10
- data/lib/lono/inspector/base.rb +7 -7
- data/lib/lono/inspector/summary.rb +19 -17
- data/lib/lono/layering/layer.rb +126 -0
- data/lib/lono/layering.rb +13 -55
- data/lib/lono/logger/formatter.rb +13 -0
- data/lib/lono/logger.rb +33 -0
- data/lib/lono/lookup.rb +12 -0
- data/lib/lono/names.rb +50 -0
- data/lib/lono/plugin/meta.rb +30 -0
- data/lib/lono/plugin/tester.rb +13 -0
- data/lib/lono/plugin.rb +10 -0
- data/lib/lono/s3/aws_setup.rb +4 -3
- data/lib/lono/s3/bucket.rb +19 -19
- data/lib/lono/s3/uploader.rb +10 -12
- data/lib/lono/script/base.rb +3 -3
- data/lib/lono/script/build.rb +11 -12
- data/lib/lono/script/upload.rb +7 -7
- data/lib/lono/{seed → seeder}/service_role.rb +1 -1
- data/lib/lono/{seed/base.rb → seeder.rb} +21 -36
- data/lib/lono/user_data.rb +8 -13
- data/lib/lono/utils/context.rb +15 -0
- data/lib/lono/utils/item/zip.rb +5 -5
- data/lib/lono/utils/logging.rb +7 -0
- data/lib/lono/utils/{pretty_time.rb → pretty.rb} +6 -2
- data/lib/lono/utils/quit.rb +7 -0
- data/lib/lono/utils/rsync.rb +4 -2
- data/lib/lono/utils/sure.rb +4 -4
- data/lib/lono/version.rb +1 -1
- data/lib/lono.rb +7 -12
- data/lib/templates/blueprint/template.rb +2 -0
- data/lib/templates/configset/{lib/configset.rb → configset.rb} +0 -0
- data/lib/templates/examples/blueprint/template.rb +9 -0
- data/lib/templates/helper/%underscore_name%_helper.rb.tt +6 -0
- data/lib/templates/{skeleton → project}/.gitignore +1 -2
- data/lib/templates/project/Gemfile.tt +11 -0
- data/lib/templates/project/README.md +9 -0
- data/lib/templates/project/config/app.rb +3 -0
- data/lib/templates/shim/lono +7 -0
- data/lono.gemspec +51 -44
- metadata +246 -269
- data/.circleci/README.md +0 -3
- data/.circleci/config.yml +0 -58
- data/.cody/acceptance.sh +0 -49
- data/.cody/buildspec.yml +0 -9
- data/.cody/demo.rb +0 -38
- data/.cody/project.rb +0 -6
- data/.gitmodules +0 -3
- data/lib/lono/abstract_base.rb +0 -25
- data/lib/lono/aws_services/stack.rb +0 -41
- data/lib/lono/aws_services/stack_set.rb +0 -41
- data/lib/lono/blueprint/configset/loader.rb +0 -7
- data/lib/lono/blueprint/helper.rb +0 -24
- data/lib/lono/blueprint/meta.rb +0 -30
- data/lib/lono/blueprint/new.rb +0 -127
- data/lib/lono/blueprint/root.rb +0 -25
- data/lib/lono/cfn/create.rb +0 -41
- data/lib/lono/cfn/opts.rb +0 -88
- data/lib/lono/cfn/preview/changeset.rb +0 -168
- data/lib/lono/cfn/preview/codediff.rb +0 -41
- data/lib/lono/cfn/preview/diff_viewer.rb +0 -23
- data/lib/lono/cfn/rollback.rb +0 -26
- data/lib/lono/cfn/update.rb +0 -71
- data/lib/lono/cfn.rb +0 -75
- data/lib/lono/clean.rb +0 -14
- data/lib/lono/configset/list.rb +0 -67
- data/lib/lono/configset/preparer.rb +0 -44
- data/lib/lono/configset/register/base.rb +0 -122
- data/lib/lono/configset/register/blueprint.rb +0 -16
- data/lib/lono/configset/register/dsl.rb +0 -14
- data/lib/lono/configset/register/project.rb +0 -13
- data/lib/lono/configset/resolver.rb +0 -47
- data/lib/lono/configset.rb +0 -16
- data/lib/lono/conventions.rb +0 -23
- data/lib/lono/core/config.rb +0 -22
- data/lib/lono/default/settings.yml +0 -21
- data/lib/lono/ext/bundler.rb +0 -7
- data/lib/lono/extension/helper.rb +0 -13
- data/lib/lono/extension/list.rb +0 -40
- data/lib/lono/extension.rb +0 -9
- data/lib/lono/extensions/preparer.rb +0 -26
- data/lib/lono/extensions/register.rb +0 -15
- data/lib/lono/file_uploader.rb +0 -21
- data/lib/lono/finder/base.rb +0 -152
- data/lib/lono/finder/blueprint/configset.rb +0 -17
- data/lib/lono/finder/blueprint.rb +0 -11
- data/lib/lono/finder/configset.rb +0 -11
- data/lib/lono/finder/extension.rb +0 -11
- data/lib/lono/generate.rb +0 -111
- data/lib/lono/help/cfn/create.md +0 -26
- data/lib/lono/help/cfn/delete.md +0 -13
- data/lib/lono/help/cfn/deploy.md +0 -21
- data/lib/lono/help/cfn/download.md +0 -3
- data/lib/lono/help/cfn/update.md +0 -49
- data/lib/lono/help/cfn.md +0 -7
- data/lib/lono/help/new.md +0 -57
- data/lib/lono/help/param.md +0 -6
- data/lib/lono/help/set_instances/delete.md +0 -21
- data/lib/lono/help/set_instances/deploy.md +0 -31
- data/lib/lono/help/set_instances/list.md +0 -14
- data/lib/lono/help/set_instances/status.md +0 -15
- data/lib/lono/help/set_instances/sync.md +0 -92
- data/lib/lono/help/sets/delete.md +0 -8
- data/lib/lono/help/sets/deploy.md +0 -76
- data/lib/lono/help/sets/status.md +0 -23
- data/lib/lono/help/summary.md +0 -33
- data/lib/lono/help/template/generate.md +0 -7
- data/lib/lono/help/upgrade.md +0 -1
- data/lib/lono/help/xgraph.md +0 -16
- data/lib/lono/help.rb +0 -15
- data/lib/lono/importer/erb.rb +0 -31
- data/lib/lono/inspector/graph.rb +0 -125
- data/lib/lono/jade/circular.rb +0 -26
- data/lib/lono/jade/materializer/final.rb +0 -10
- data/lib/lono/jade/materializer/gems_builder.rb +0 -81
- data/lib/lono/jade/materializer/source.rb +0 -54
- data/lib/lono/jade/materializer.rb +0 -15
- data/lib/lono/jade/registry.rb +0 -64
- data/lib/lono/jade.rb +0 -110
- data/lib/lono/jadespec.rb +0 -68
- data/lib/lono/new/helper.rb +0 -15
- data/lib/lono/new.rb +0 -95
- data/lib/lono/param.rb +0 -14
- data/lib/lono/pro/base.rb +0 -16
- data/lib/lono/pro/repo.rb +0 -28
- data/lib/lono/pro.rb +0 -15
- data/lib/lono/project_checker.rb +0 -35
- data/lib/lono/registration/base.rb +0 -37
- data/lib/lono/registration/check.rb +0 -15
- data/lib/lono/registration/temp.rb +0 -53
- data/lib/lono/registration/user.rb +0 -60
- data/lib/lono/seed.rb +0 -39
- data/lib/lono/sequence.rb +0 -35
- data/lib/lono/set_instances/base.rb +0 -30
- data/lib/lono/set_instances/changeable.rb +0 -53
- data/lib/lono/set_instances/create.rb +0 -7
- data/lib/lono/set_instances/delete.rb +0 -47
- data/lib/lono/set_instances/deploy.rb +0 -52
- data/lib/lono/set_instances/list.rb +0 -13
- data/lib/lono/set_instances/opts.rb +0 -37
- data/lib/lono/set_instances/status.rb +0 -12
- data/lib/lono/set_instances/sync.rb +0 -181
- data/lib/lono/set_instances/update.rb +0 -15
- data/lib/lono/set_instances.rb +0 -54
- data/lib/lono/sets/base.rb +0 -50
- data/lib/lono/sets/create.rb +0 -27
- data/lib/lono/sets/delete.rb +0 -43
- data/lib/lono/sets/deploy.rb +0 -11
- data/lib/lono/sets/list.rb +0 -35
- data/lib/lono/sets/opts.rb +0 -18
- data/lib/lono/sets/preview/codediff.rb +0 -35
- data/lib/lono/sets/preview/param.rb +0 -32
- data/lib/lono/sets/status/instance/base.rb +0 -120
- data/lib/lono/sets/status/instance/completed.rb +0 -35
- data/lib/lono/sets/status/instance/deleted.rb +0 -32
- data/lib/lono/sets/status/instance/show.rb +0 -7
- data/lib/lono/sets/status/instance.rb +0 -20
- data/lib/lono/sets/status/instances.rb +0 -136
- data/lib/lono/sets/status.rb +0 -128
- data/lib/lono/sets/summarize.rb +0 -22
- data/lib/lono/sets/time_spent.rb +0 -11
- data/lib/lono/sets/update.rb +0 -74
- data/lib/lono/sets/waiter.rb +0 -23
- data/lib/lono/sets.rb +0 -34
- data/lib/lono/setting.rb +0 -75
- data/lib/lono/template/aws_service.rb +0 -20
- data/lib/lono/template/bashify.rb +0 -39
- data/lib/lono/template/context/loader.rb +0 -52
- data/lib/lono/template/generator.rb +0 -23
- data/lib/lono/template/helper.rb +0 -152
- data/lib/lono/template/strategy/base.rb +0 -4
- data/lib/lono/template/strategy/common/helpers.rb +0 -44
- data/lib/lono/template/strategy/dsl/builder/section/base.rb +0 -30
- data/lib/lono/template/strategy/dsl/builder.rb +0 -59
- data/lib/lono/template/strategy/dsl.rb +0 -14
- data/lib/lono/template/strategy/erb.rb +0 -82
- data/lib/lono/template/strategy/source.rb +0 -8
- data/lib/lono/template/template.rb +0 -54
- data/lib/lono/template/util.rb +0 -8
- data/lib/lono/template.rb +0 -24
- data/lib/lono/upgrade.rb +0 -20
- data/lib/lono/utils/generators/tree.rb +0 -18
- data/lib/templates/blueprint/%blueprint_name%.gemspec.tt +0 -45
- data/lib/templates/blueprint/.gitignore +0 -11
- data/lib/templates/blueprint/CHANGELOG.md +0 -7
- data/lib/templates/blueprint/Gemfile +0 -4
- data/lib/templates/blueprint/README.md.tt +0 -33
- data/lib/templates/blueprint/Rakefile.tt +0 -9
- data/lib/templates/blueprint/seed/configs.rb +0 -28
- data/lib/templates/blueprint_types/dsl/app/templates/%blueprint_name%.rb +0 -36
- data/lib/templates/blueprint_types/dsl/app/user_data/bootstrap.sh +0 -2
- data/lib/templates/blueprint_types/erb/app/definitions/base.rb.tt +0 -1
- data/lib/templates/blueprint_types/erb/app/templates/%blueprint_name%.yml +0 -67
- data/lib/templates/configset/%configset_name%.gemspec.tt +0 -42
- data/lib/templates/configset/.gitignore +0 -10
- data/lib/templates/configset/CHANGELOG.md +0 -7
- data/lib/templates/configset/Gemfile +0 -4
- data/lib/templates/configset/README.md.tt +0 -3
- data/lib/templates/configset/Rakefile.tt +0 -9
- data/lib/templates/extension/%extension_name%.gemspec.tt +0 -46
- data/lib/templates/extension/.gitignore +0 -11
- data/lib/templates/extension/.rspec +0 -3
- data/lib/templates/extension/CHANGELOG.md +0 -7
- data/lib/templates/extension/Gemfile.tt +0 -4
- data/lib/templates/extension/Rakefile.tt +0 -9
- data/lib/templates/extension/spec/spec_helper.rb.tt +0 -29
- data/lib/templates/skeleton/Gemfile +0 -3
- data/lib/templates/skeleton/README.md +0 -58
- data/lib/templates/skeleton/configs/settings.yml +0 -13
- data/vendor/cfn-status/CHANGELOG.md +0 -14
- data/vendor/cfn-status/Gemfile +0 -4
- data/vendor/cfn-status/Gemfile.lock +0 -49
- data/vendor/cfn-status/LICENSE.txt +0 -21
- data/vendor/cfn-status/README.md +0 -58
- data/vendor/cfn-status/Rakefile +0 -6
- data/vendor/cfn-status/bin/console +0 -14
- data/vendor/cfn-status/bin/setup +0 -8
- data/vendor/cfn-status/cfn-status.gemspec +0 -30
- data/vendor/cfn-status/lib/cfn-status.rb +0 -1
- data/vendor/cfn-status/lib/cfn_status/aws_service.rb +0 -51
- data/vendor/cfn-status/lib/cfn_status/version.rb +0 -3
- data/vendor/cfn-status/lib/cfn_status.rb +0 -245
- data/vendor/cfn-status/spec/fixtures/cfn/pages/fresh/describe_stack_events-1.json +0 -1103
- data/vendor/cfn-status/spec/fixtures/cfn/pages/fresh/describe_stack_events-2.json +0 -1104
- data/vendor/cfn-status/spec/fixtures/cfn/pages/fresh/describe_stack_events-3.json +0 -1103
- data/vendor/cfn-status/spec/fixtures/cfn/pages/updating/describe_stack_events-1.json +0 -1103
- data/vendor/cfn-status/spec/fixtures/cfn/pages/updating/describe_stack_events-2.json +0 -1104
- data/vendor/cfn-status/spec/fixtures/cfn/pages/updating/describe_stack_events-3.json +0 -1103
- data/vendor/cfn-status/spec/fixtures/cfn/stack-events-complete.json +0 -1080
- data/vendor/cfn-status/spec/fixtures/cfn/stack-events-in-progress.json +0 -1080
- data/vendor/cfn-status/spec/fixtures/cfn/stack-events-update-rollback-complete.json +0 -1086
- data/vendor/cfn-status/spec/lib/cfn_status_spec.rb +0 -153
- data/vendor/cfn-status/spec/spec_helper.rb +0 -14
@@ -1,20 +1,16 @@
|
|
1
|
-
module Lono::Template::
|
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.
|
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 = "
|
17
|
-
# Also, make sure that "
|
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
|
-
|
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
|
-
|
37
|
-
|
38
|
-
|
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
|
data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/helpers/s3_helper.rb
RENAMED
@@ -1,4 +1,4 @@
|
|
1
|
-
module Lono::Template::
|
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::
|
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
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
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,5 +1,5 @@
|
|
1
1
|
# Built-in helpers for the DSL form
|
2
|
-
class Lono::Template::
|
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::
|
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
|
data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/condition.rb
RENAMED
@@ -2,7 +2,7 @@
|
|
2
2
|
#
|
3
3
|
# template - uses @definition to build a CloudFormation template section
|
4
4
|
#
|
5
|
-
module Lono::Template::
|
5
|
+
module Lono::Builder::Template::Dsl::Evaluator::Section
|
6
6
|
class Condition < Base
|
7
7
|
def template
|
8
8
|
camelize(standarize(@definition))
|
data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/mapping.rb
RENAMED
@@ -2,7 +2,7 @@
|
|
2
2
|
#
|
3
3
|
# template - uses @definition to build a CloudFormation template section
|
4
4
|
#
|
5
|
-
module Lono::Template::
|
5
|
+
module Lono::Builder::Template::Dsl::Evaluator::Section
|
6
6
|
class Mapping < Base
|
7
7
|
def template
|
8
8
|
camelize(standarize(@definition))
|
data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/methods.rb
RENAMED
@@ -1,5 +1,5 @@
|
|
1
1
|
# Organize core section method syntax here
|
2
|
-
module Lono::Template::
|
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
|
data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/output.rb
RENAMED
@@ -2,7 +2,7 @@
|
|
2
2
|
#
|
3
3
|
# template - uses @definition to build a CloudFormation template section
|
4
4
|
#
|
5
|
-
module Lono::Template::
|
5
|
+
module Lono::Builder::Template::Dsl::Evaluator::Section
|
6
6
|
class Output < Base
|
7
7
|
def template
|
8
8
|
camelize(standarize(@definition))
|
data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/parameter.rb
RENAMED
@@ -2,7 +2,7 @@
|
|
2
2
|
#
|
3
3
|
# template - uses @definition to build a CloudFormation template section
|
4
4
|
#
|
5
|
-
module Lono::Template::
|
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
|
data/lib/lono/{template/strategy/dsl/builder → builder/template/dsl/evaluator}/section/resource.rb
RENAMED
@@ -2,7 +2,7 @@
|
|
2
2
|
#
|
3
3
|
# template - uses @definition to build a CloudFormation template section
|
4
4
|
#
|
5
|
-
module Lono::Template::
|
5
|
+
module Lono::Builder::Template::Dsl::Evaluator::Section
|
6
6
|
class Resource < Base
|
7
7
|
def template
|
8
8
|
camelize(standarize(@definition))
|
@@ -1,8 +1,8 @@
|
|
1
|
-
# Encapsulates syntax methods so they can be included in both the
|
2
|
-
class Lono::Template::
|
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::
|
1
|
+
class Lono::Builder::Template::Dsl::Finalizer
|
2
2
|
class ParameterGroups
|
3
3
|
extend Memoist
|
4
|
-
include Lono::Template::
|
4
|
+
include Lono::Builder::Template::Dsl::Evaluator::Stringify
|
5
5
|
|
6
6
|
def initialize(cfn, parameters)
|
7
7
|
@cfn, @parameters = cfn, parameters
|
@@ -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
|
-
|
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
|
-
|
22
|
-
|
23
|
-
|
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
|
-
|
2
|
-
class
|
1
|
+
class Lono::Builder::Template
|
2
|
+
class Output
|
3
3
|
extend Memoist
|
4
4
|
|
5
|
-
def initialize(blueprint
|
6
|
-
@blueprint
|
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.
|
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
|
-
|
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::
|
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
|
-
|
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.
|
64
|
+
"#{Lono.root}/output/#{@blueprint.name}/templates/#{@template}.yml"
|
65
65
|
end
|
66
66
|
end
|
67
67
|
end
|