takomo 8.0.3 → 9.0.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli-io/formatters.d.ts +3 -1
- package/dist/cli-io/formatters.js +13 -1
- package/dist/cli-io/formatters.js.map +1 -1
- package/dist/cli-io/stacks/common.d.ts +4 -0
- package/dist/cli-io/stacks/common.js +17 -0
- package/dist/cli-io/stacks/common.js.map +1 -1
- package/dist/cli-io/stacks/deploy-stacks/deploy-stacks-io.d.ts +8 -1
- package/dist/cli-io/stacks/deploy-stacks/deploy-stacks-io.js +90 -25
- package/dist/cli-io/stacks/deploy-stacks/deploy-stacks-io.js.map +1 -1
- package/dist/cli-io/stacks/deploy-stacks/emit-stack-templates-io.js +8 -1
- package/dist/cli-io/stacks/deploy-stacks/emit-stack-templates-io.js.map +1 -1
- package/dist/cli-io/stacks/deploy-stacks/parameters.d.ts +3 -0
- package/dist/cli-io/stacks/deploy-stacks/parameters.js +72 -0
- package/dist/cli-io/stacks/deploy-stacks/parameters.js.map +1 -1
- package/dist/cli-io/stacks/deploy-stacks/resources.d.ts +2 -0
- package/dist/cli-io/stacks/deploy-stacks/resources.js +20 -0
- package/dist/cli-io/stacks/deploy-stacks/resources.js.map +1 -1
- package/dist/cli-io/stacks/deploy-stacks/stack-policy.d.ts +2 -2
- package/dist/cli-io/stacks/deploy-stacks/stack-policy.js.map +1 -1
- package/dist/cli-io/stacks/deploy-stacks/tags.d.ts +3 -0
- package/dist/cli-io/stacks/deploy-stacks/tags.js +68 -0
- package/dist/cli-io/stacks/deploy-stacks/tags.js.map +1 -1
- package/dist/cli-io/stacks/deploy-stacks/termination-protection.d.ts +2 -2
- package/dist/cli-io/stacks/deploy-stacks/termination-protection.js.map +1 -1
- package/dist/cli-io/stacks/detect-drift-io.js +2 -2
- package/dist/cli-io/stacks/detect-drift-io.js.map +1 -1
- package/dist/cli-io/stacks/list-stacks-io.js +3 -2
- package/dist/cli-io/stacks/list-stacks-io.js.map +1 -1
- package/dist/cli-io/stacks/undeploy-stacks-io.js +41 -19
- package/dist/cli-io/stacks/undeploy-stacks-io.js.map +1 -1
- package/dist/command/command-model.d.ts +2 -1
- package/dist/command/command-model.js.map +1 -1
- package/dist/command/stacks/common/custom-states.d.ts +33 -0
- package/dist/command/stacks/common/custom-states.js +2 -0
- package/dist/command/stacks/common/custom-states.js.map +1 -0
- package/dist/command/stacks/common/load-current-cf-stacks.d.ts +17 -5
- package/dist/command/stacks/common/load-current-cf-stacks.js +73 -13
- package/dist/command/stacks/common/load-current-cf-stacks.js.map +1 -1
- package/dist/command/stacks/deploy/command.js +1 -1
- package/dist/command/stacks/deploy/command.js.map +1 -1
- package/dist/command/stacks/deploy/custom-stack/states.d.ts +42 -0
- package/dist/command/stacks/deploy/custom-stack/states.js.map +1 -0
- package/dist/command/stacks/deploy/custom-stack/steps/create-or-update-stack.d.ts +3 -0
- package/dist/command/stacks/deploy/custom-stack/steps/create-or-update-stack.js +11 -0
- package/dist/command/stacks/deploy/custom-stack/steps/create-or-update-stack.js.map +1 -0
- package/dist/command/stacks/deploy/custom-stack/steps/create-stack.d.ts +3 -0
- package/dist/command/stacks/deploy/custom-stack/steps/create-stack.js +41 -0
- package/dist/command/stacks/deploy/custom-stack/steps/create-stack.js.map +1 -0
- package/dist/command/stacks/deploy/custom-stack/steps/get-changes.d.ts +8 -0
- package/dist/command/stacks/deploy/custom-stack/steps/get-changes.js +58 -0
- package/dist/command/stacks/deploy/custom-stack/steps/get-changes.js.map +1 -0
- package/dist/command/stacks/deploy/custom-stack/steps/prepare-parameters.d.ts +3 -0
- package/dist/command/stacks/deploy/custom-stack/steps/prepare-parameters.js +44 -0
- package/dist/command/stacks/deploy/custom-stack/steps/prepare-parameters.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → custom-stack/steps}/prepare-tags.d.ts +1 -1
- package/dist/command/stacks/deploy/custom-stack/steps/prepare-tags.js +27 -0
- package/dist/command/stacks/deploy/custom-stack/steps/prepare-tags.js.map +1 -0
- package/dist/command/stacks/deploy/custom-stack/steps/review-deployment.d.ts +3 -0
- package/dist/command/stacks/deploy/custom-stack/steps/review-deployment.js +15 -0
- package/dist/command/stacks/deploy/custom-stack/steps/review-deployment.js.map +1 -0
- package/dist/command/stacks/deploy/custom-stack/steps/update-stack.d.ts +3 -0
- package/dist/command/stacks/deploy/custom-stack/steps/update-stack.js +42 -0
- package/dist/command/stacks/deploy/custom-stack/steps/update-stack.js.map +1 -0
- package/dist/command/stacks/deploy/custom-stack/steps/wait-dependencies-to-complete.d.ts +3 -0
- package/dist/command/stacks/deploy/custom-stack/steps/wait-dependencies-to-complete.js +26 -0
- package/dist/command/stacks/deploy/custom-stack/steps/wait-dependencies-to-complete.js.map +1 -0
- package/dist/command/stacks/deploy/custom-stack/transitions.d.ts +13 -0
- package/dist/command/stacks/deploy/custom-stack/transitions.js +21 -0
- package/dist/command/stacks/deploy/custom-stack/transitions.js.map +1 -0
- package/dist/command/stacks/deploy/deploy-stack.d.ts +3 -4
- package/dist/command/stacks/deploy/deploy-stack.js +73 -34
- package/dist/command/stacks/deploy/deploy-stack.js.map +1 -1
- package/dist/command/stacks/deploy/execute-deploy-context.js +4 -4
- package/dist/command/stacks/deploy/execute-deploy-context.js.map +1 -1
- package/dist/command/stacks/deploy/model.d.ts +7 -2
- package/dist/command/stacks/deploy/plan.d.ts +18 -4
- package/dist/command/stacks/deploy/plan.js +28 -10
- package/dist/command/stacks/deploy/plan.js.map +1 -1
- package/dist/command/stacks/deploy/{states.d.ts → standard-stack/states.d.ts} +17 -15
- package/dist/command/stacks/deploy/standard-stack/states.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/continue-update-rollback.d.ts +1 -1
- package/dist/command/stacks/deploy/standard-stack/steps/continue-update-rollback.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/emit-stack-template.d.ts +1 -1
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/emit-stack-template.js +2 -2
- package/dist/command/stacks/deploy/standard-stack/steps/emit-stack-template.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/enrich-current-stack.d.ts +1 -1
- package/dist/command/stacks/deploy/standard-stack/steps/enrich-current-stack.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/execute-after-deploy-hooks.d.ts +1 -1
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/execute-after-deploy-hooks.js +2 -2
- package/dist/command/stacks/deploy/standard-stack/steps/execute-after-deploy-hooks.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/execute-before-deploy-hooks.d.ts +1 -1
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/execute-before-deploy-hooks.js +2 -2
- package/dist/command/stacks/deploy/standard-stack/steps/execute-before-deploy-hooks.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/initiate-change-set-create.d.ts +3 -3
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/initiate-change-set-create.js +2 -2
- package/dist/command/stacks/deploy/standard-stack/steps/initiate-change-set-create.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/initiate-failed-stack-delete.d.ts +1 -1
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/initiate-failed-stack-delete.js +1 -1
- package/dist/command/stacks/deploy/standard-stack/steps/initiate-failed-stack-delete.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/initiate-stack-create-or-update.d.ts +1 -1
- package/dist/command/stacks/deploy/standard-stack/steps/initiate-stack-create-or-update.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/initiate-stack-create.d.ts +1 -1
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/initiate-stack-create.js +2 -2
- package/dist/command/stacks/deploy/standard-stack/steps/initiate-stack-create.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/initiate-stack-update.d.ts +1 -1
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/initiate-stack-update.js +3 -3
- package/dist/command/stacks/deploy/standard-stack/steps/initiate-stack-update.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/prepare-parameters.d.ts +1 -1
- package/dist/command/stacks/deploy/standard-stack/steps/prepare-parameters.js.map +1 -0
- package/dist/command/stacks/deploy/standard-stack/steps/prepare-tags.d.ts +3 -0
- package/dist/command/stacks/deploy/standard-stack/steps/prepare-tags.js.map +1 -0
- package/dist/command/stacks/deploy/standard-stack/steps/prepare-template.d.ts +7 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/prepare-template.js +1 -1
- package/dist/command/stacks/deploy/standard-stack/steps/prepare-template.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/review-change-set.d.ts +1 -1
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/review-change-set.js +1 -1
- package/dist/command/stacks/deploy/standard-stack/steps/review-change-set.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/summarize-template.d.ts +1 -1
- package/dist/command/stacks/deploy/standard-stack/steps/summarize-template.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/update-termination-protection.d.ts +1 -1
- package/dist/command/stacks/deploy/standard-stack/steps/update-termination-protection.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/upload-template.d.ts +1 -1
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/upload-template.js +1 -1
- package/dist/command/stacks/deploy/standard-stack/steps/upload-template.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/validate-parameters.d.ts +3 -3
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/validate-parameters.js +3 -3
- package/dist/command/stacks/deploy/standard-stack/steps/validate-parameters.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/validate-template.d.ts +1 -1
- package/dist/command/stacks/deploy/standard-stack/steps/validate-template.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/wait-change-set-to-be-ready.d.ts +1 -1
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/wait-change-set-to-be-ready.js +5 -5
- package/dist/command/stacks/deploy/standard-stack/steps/wait-change-set-to-be-ready.js.map +1 -0
- package/dist/command/stacks/deploy/standard-stack/steps/wait-dependencies-to-complete.d.ts +3 -0
- package/dist/command/stacks/deploy/standard-stack/steps/wait-dependencies-to-complete.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/wait-failed-stack-delete-to-complete.d.ts +1 -1
- package/dist/command/stacks/deploy/standard-stack/steps/wait-failed-stack-delete-to-complete.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/wait-stack-create-or-update-to-complete.d.ts +1 -1
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/wait-stack-create-or-update-to-complete.js +1 -1
- package/dist/command/stacks/deploy/standard-stack/steps/wait-stack-create-or-update-to-complete.js.map +1 -0
- package/dist/command/stacks/deploy/{steps → standard-stack/steps}/wait-stack-rollback-to-complete.d.ts +1 -1
- package/dist/command/stacks/deploy/standard-stack/steps/wait-stack-rollback-to-complete.js.map +1 -0
- package/dist/command/stacks/deploy/{transitions.d.ts → standard-stack/transitions.d.ts} +4 -4
- package/dist/command/stacks/deploy/{transitions.js → standard-stack/transitions.js} +2 -2
- package/dist/command/stacks/deploy/standard-stack/transitions.js.map +1 -0
- package/dist/command/stacks/deploy/validate.js +3 -1
- package/dist/command/stacks/deploy/validate.js.map +1 -1
- package/dist/command/stacks/drift/detect-drift.js +10 -5
- package/dist/command/stacks/drift/detect-drift.js.map +1 -1
- package/dist/command/stacks/inspect/configuration/command.js.map +1 -1
- package/dist/command/stacks/list/list-stacks.js +27 -9
- package/dist/command/stacks/list/list-stacks.js.map +1 -1
- package/dist/command/stacks/list/model.d.ts +1 -0
- package/dist/command/stacks/undeploy/command.js +3 -3
- package/dist/command/stacks/undeploy/command.js.map +1 -1
- package/dist/command/stacks/undeploy/custom-stack/states.d.ts +27 -0
- package/dist/command/stacks/undeploy/custom-stack/states.js +2 -0
- package/dist/command/stacks/undeploy/custom-stack/states.js.map +1 -0
- package/dist/command/stacks/undeploy/custom-stack/steps/delete-stack.d.ts +3 -0
- package/dist/command/stacks/undeploy/custom-stack/steps/delete-stack.js +38 -0
- package/dist/command/stacks/undeploy/custom-stack/steps/delete-stack.js.map +1 -0
- package/dist/command/stacks/undeploy/custom-stack/steps/wait-dependents-to-complete.d.ts +3 -0
- package/dist/command/stacks/undeploy/custom-stack/steps/wait-dependents-to-complete.js +26 -0
- package/dist/command/stacks/undeploy/custom-stack/steps/wait-dependents-to-complete.js.map +1 -0
- package/dist/command/stacks/undeploy/custom-stack/transitions.d.ts +7 -0
- package/dist/command/stacks/undeploy/custom-stack/transitions.js +9 -0
- package/dist/command/stacks/undeploy/custom-stack/transitions.js.map +1 -0
- package/dist/command/stacks/undeploy/delete.js +41 -17
- package/dist/command/stacks/undeploy/delete.js.map +1 -1
- package/dist/command/stacks/undeploy/plan.d.ts +19 -5
- package/dist/command/stacks/undeploy/plan.js +39 -11
- package/dist/command/stacks/undeploy/plan.js.map +1 -1
- package/dist/command/stacks/undeploy/standard-stack/states.d.ts +32 -0
- package/dist/command/stacks/undeploy/standard-stack/states.js +2 -0
- package/dist/command/stacks/undeploy/standard-stack/states.js.map +1 -0
- package/dist/command/stacks/undeploy/{steps → standard-stack/steps}/execute-after-undeploy-hooks.d.ts +1 -1
- package/dist/command/stacks/undeploy/{steps → standard-stack/steps}/execute-after-undeploy-hooks.js +1 -1
- package/dist/command/stacks/undeploy/standard-stack/steps/execute-after-undeploy-hooks.js.map +1 -0
- package/dist/command/stacks/undeploy/{steps → standard-stack/steps}/execute-before-undeploy-hooks.d.ts +1 -1
- package/dist/command/stacks/undeploy/{steps → standard-stack/steps}/execute-before-undeploy-hooks.js +1 -1
- package/dist/command/stacks/undeploy/standard-stack/steps/execute-before-undeploy-hooks.js.map +1 -0
- package/dist/command/stacks/undeploy/{steps → standard-stack/steps}/initiate-stack-delete.d.ts +1 -1
- package/dist/command/stacks/undeploy/{steps → standard-stack/steps}/initiate-stack-delete.js +1 -1
- package/dist/command/stacks/undeploy/standard-stack/steps/initiate-stack-delete.js.map +1 -0
- package/dist/command/stacks/undeploy/standard-stack/steps/wait-dependents-to-complete.d.ts +3 -0
- package/dist/command/stacks/undeploy/standard-stack/steps/wait-dependents-to-complete.js.map +1 -0
- package/dist/command/stacks/undeploy/{steps → standard-stack/steps}/wait-stack-delete-to-complete.d.ts +1 -1
- package/dist/command/stacks/undeploy/standard-stack/steps/wait-stack-delete-to-complete.js.map +1 -0
- package/dist/command/stacks/undeploy/{transitions.d.ts → standard-stack/transitions.d.ts} +4 -4
- package/dist/command/stacks/undeploy/{transitions.js → standard-stack/transitions.js} +2 -2
- package/dist/command/stacks/undeploy/standard-stack/transitions.js.map +1 -0
- package/dist/command/stacks/undeploy/validate.js +11 -6
- package/dist/command/stacks/undeploy/validate.js.map +1 -1
- package/dist/config/custom-stack-config.d.ts +8 -0
- package/dist/config/custom-stack-config.js +6 -0
- package/dist/config/custom-stack-config.js.map +1 -0
- package/dist/config/stack-config.d.ts +9 -11
- package/dist/config/standard-stack-config.d.ts +15 -0
- package/dist/config/standard-stack-config.js +3 -0
- package/dist/config/standard-stack-config.js.map +1 -0
- package/dist/context/stacks-context.d.ts +3 -1
- package/dist/custom-stacks/cmd-custom-stack-handler.d.ts +24 -0
- package/dist/custom-stacks/cmd-custom-stack-handler.js +274 -0
- package/dist/custom-stacks/cmd-custom-stack-handler.js.map +1 -0
- package/dist/custom-stacks/custom-stack-handler-registry.d.ts +13 -0
- package/dist/custom-stacks/custom-stack-handler-registry.js +32 -0
- package/dist/custom-stacks/custom-stack-handler-registry.js.map +1 -0
- package/dist/custom-stacks/custom-stack-handler.d.ts +401 -0
- package/dist/custom-stacks/custom-stack-handler.js +2 -0
- package/dist/custom-stacks/custom-stack-handler.js.map +1 -0
- package/dist/extensions/config-customizer.d.ts +5 -0
- package/dist/hooks/execute.d.ts +2 -2
- package/dist/hooks/execute.js +1 -0
- package/dist/hooks/execute.js.map +1 -1
- package/dist/hooks/hook.d.ts +2 -2
- package/dist/index.d.ts +5 -1
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/dist/parser/stacks/build-custom-stack-config.d.ts +5 -0
- package/dist/parser/stacks/build-custom-stack-config.js +51 -0
- package/dist/parser/stacks/build-custom-stack-config.js.map +1 -0
- package/dist/parser/stacks/build-standard-stack-config.d.ts +6 -0
- package/dist/parser/stacks/{build-stack-config.js → build-standard-stack-config.js} +5 -4
- package/dist/parser/stacks/build-standard-stack-config.js.map +1 -0
- package/dist/parser/stacks/parse-custom-stack-type.d.ts +2 -0
- package/dist/parser/stacks/parse-custom-stack-type.js +10 -0
- package/dist/parser/stacks/parse-custom-stack-type.js.map +1 -0
- package/dist/resolvers/stack-output-resolver.js +4 -0
- package/dist/resolvers/stack-output-resolver.js.map +1 -1
- package/dist/schema/custom-stack-config-schema.d.ts +7 -0
- package/dist/schema/custom-stack-config-schema.js +34 -0
- package/dist/schema/custom-stack-config-schema.js.map +1 -0
- package/dist/schema/stacks-schema.d.ts +1 -0
- package/dist/schema/stacks-schema.js +2 -0
- package/dist/schema/stacks-schema.js.map +1 -1
- package/dist/schema/{stack-config-schema.d.ts → standard-stack-config-schema.d.ts} +2 -2
- package/dist/schema/{stack-config-schema.js → standard-stack-config-schema.js} +4 -3
- package/dist/schema/standard-stack-config-schema.js.map +1 -0
- package/dist/stacks/custom-stack.d.ts +26 -0
- package/dist/stacks/custom-stack.js +38 -0
- package/dist/stacks/custom-stack.js.map +1 -0
- package/dist/stacks/stack.d.ts +13 -41
- package/dist/stacks/stack.js +11 -38
- package/dist/stacks/stack.js.map +1 -1
- package/dist/stacks/standard-stack.d.ts +54 -0
- package/dist/stacks/standard-stack.js +42 -0
- package/dist/stacks/standard-stack.js.map +1 -0
- package/dist/takomo-config-repository-fs/deployment-targets/config-repository.js +5 -1
- package/dist/takomo-config-repository-fs/deployment-targets/config-repository.js.map +1 -1
- package/dist/takomo-config-repository-fs/stacks/config-repository.js +4 -1
- package/dist/takomo-config-repository-fs/stacks/config-repository.js.map +1 -1
- package/dist/takomo-config-repository-fs/stacks/parser.d.ts +4 -3
- package/dist/takomo-config-repository-fs/stacks/parser.js +35 -7
- package/dist/takomo-config-repository-fs/stacks/parser.js.map +1 -1
- package/dist/takomo-stacks-context/config/build-custom-stack.d.ts +15 -0
- package/dist/takomo-stacks-context/config/build-custom-stack.js +104 -0
- package/dist/takomo-stacks-context/config/build-custom-stack.js.map +1 -0
- package/dist/takomo-stacks-context/config/build-stack.d.ts +12 -12
- package/dist/takomo-stacks-context/config/build-stack.js +18 -139
- package/dist/takomo-stacks-context/config/build-stack.js.map +1 -1
- package/dist/takomo-stacks-context/config/build-stacks-context.js +8 -2
- package/dist/takomo-stacks-context/config/build-stacks-context.js.map +1 -1
- package/dist/takomo-stacks-context/config/build-standard-stack.d.ts +27 -0
- package/dist/takomo-stacks-context/config/build-standard-stack.js +144 -0
- package/dist/takomo-stacks-context/config/build-standard-stack.js.map +1 -0
- package/dist/takomo-stacks-context/config/config-tree.d.ts +3 -2
- package/dist/takomo-stacks-context/config/create-root-stack-group.js.map +1 -1
- package/dist/takomo-stacks-context/config/process-config-tree.d.ts +2 -1
- package/dist/takomo-stacks-context/config/process-config-tree.js +6 -6
- package/dist/takomo-stacks-context/config/process-config-tree.js.map +1 -1
- package/dist/takomo-stacks-context/dependencies.js +2 -2
- package/dist/takomo-stacks-context/dependencies.js.map +1 -1
- package/dist/takomo-stacks-context/model.d.ts +7 -5
- package/dist/takomo-stacks-context/model.js +2 -0
- package/dist/takomo-stacks-context/model.js.map +1 -1
- package/dist/takomo-stacks-model/util.d.ts +0 -4
- package/dist/takomo-stacks-model/util.js +0 -4
- package/dist/takomo-stacks-model/util.js.map +1 -1
- package/dist/utils/collections.d.ts +1 -0
- package/dist/utils/collections.js +4 -0
- package/dist/utils/collections.js.map +1 -1
- package/dist/utils/exhaustive-check.d.ts +1 -0
- package/dist/utils/exhaustive-check.js +4 -0
- package/dist/utils/exhaustive-check.js.map +1 -0
- package/package.json +3 -2
- package/dist/command/stacks/deploy/states.js.map +0 -1
- package/dist/command/stacks/deploy/steps/continue-update-rollback.js.map +0 -1
- package/dist/command/stacks/deploy/steps/emit-stack-template.js.map +0 -1
- package/dist/command/stacks/deploy/steps/enrich-current-stack.js.map +0 -1
- package/dist/command/stacks/deploy/steps/execute-after-deploy-hooks.js.map +0 -1
- package/dist/command/stacks/deploy/steps/execute-before-deploy-hooks.js.map +0 -1
- package/dist/command/stacks/deploy/steps/initiate-change-set-create.js.map +0 -1
- package/dist/command/stacks/deploy/steps/initiate-failed-stack-delete.js.map +0 -1
- package/dist/command/stacks/deploy/steps/initiate-stack-create-or-update.js.map +0 -1
- package/dist/command/stacks/deploy/steps/initiate-stack-create.js.map +0 -1
- package/dist/command/stacks/deploy/steps/initiate-stack-update.js.map +0 -1
- package/dist/command/stacks/deploy/steps/prepare-parameters.js.map +0 -1
- package/dist/command/stacks/deploy/steps/prepare-tags.js.map +0 -1
- package/dist/command/stacks/deploy/steps/prepare-template.d.ts +0 -7
- package/dist/command/stacks/deploy/steps/prepare-template.js.map +0 -1
- package/dist/command/stacks/deploy/steps/review-change-set.js.map +0 -1
- package/dist/command/stacks/deploy/steps/summarize-template.js.map +0 -1
- package/dist/command/stacks/deploy/steps/update-termination-protection.js.map +0 -1
- package/dist/command/stacks/deploy/steps/upload-template.js.map +0 -1
- package/dist/command/stacks/deploy/steps/validate-parameters.js.map +0 -1
- package/dist/command/stacks/deploy/steps/validate-template.js.map +0 -1
- package/dist/command/stacks/deploy/steps/wait-change-set-to-be-ready.js.map +0 -1
- package/dist/command/stacks/deploy/steps/wait-dependencies-to-complete.d.ts +0 -3
- package/dist/command/stacks/deploy/steps/wait-dependencies-to-complete.js.map +0 -1
- package/dist/command/stacks/deploy/steps/wait-failed-stack-delete-to-complete.js.map +0 -1
- package/dist/command/stacks/deploy/steps/wait-stack-create-or-update-to-complete.js.map +0 -1
- package/dist/command/stacks/deploy/steps/wait-stack-rollback-to-complete.js.map +0 -1
- package/dist/command/stacks/deploy/transitions.js.map +0 -1
- package/dist/command/stacks/undeploy/states.d.ts +0 -30
- package/dist/command/stacks/undeploy/states.js.map +0 -1
- package/dist/command/stacks/undeploy/steps/execute-after-undeploy-hooks.js.map +0 -1
- package/dist/command/stacks/undeploy/steps/execute-before-undeploy-hooks.js.map +0 -1
- package/dist/command/stacks/undeploy/steps/initiate-stack-delete.js.map +0 -1
- package/dist/command/stacks/undeploy/steps/wait-dependents-to-complete.d.ts +0 -3
- package/dist/command/stacks/undeploy/steps/wait-dependents-to-complete.js.map +0 -1
- package/dist/command/stacks/undeploy/steps/wait-stack-delete-to-complete.js.map +0 -1
- package/dist/command/stacks/undeploy/transitions.js.map +0 -1
- package/dist/parser/stacks/build-stack-config.d.ts +0 -6
- package/dist/parser/stacks/build-stack-config.js.map +0 -1
- package/dist/schema/stack-config-schema.js.map +0 -1
- /package/dist/command/stacks/deploy/{states.js → custom-stack/states.js} +0 -0
- /package/dist/command/stacks/{undeploy → deploy/standard-stack}/states.js +0 -0
- /package/dist/command/stacks/deploy/{steps → standard-stack/steps}/continue-update-rollback.js +0 -0
- /package/dist/command/stacks/deploy/{steps → standard-stack/steps}/enrich-current-stack.js +0 -0
- /package/dist/command/stacks/deploy/{steps → standard-stack/steps}/initiate-stack-create-or-update.js +0 -0
- /package/dist/command/stacks/deploy/{steps → standard-stack/steps}/prepare-parameters.js +0 -0
- /package/dist/command/stacks/deploy/{steps → standard-stack/steps}/prepare-tags.js +0 -0
- /package/dist/command/stacks/deploy/{steps → standard-stack/steps}/summarize-template.js +0 -0
- /package/dist/command/stacks/deploy/{steps → standard-stack/steps}/update-termination-protection.js +0 -0
- /package/dist/command/stacks/deploy/{steps → standard-stack/steps}/validate-template.js +0 -0
- /package/dist/command/stacks/deploy/{steps → standard-stack/steps}/wait-dependencies-to-complete.js +0 -0
- /package/dist/command/stacks/deploy/{steps → standard-stack/steps}/wait-failed-stack-delete-to-complete.js +0 -0
- /package/dist/command/stacks/deploy/{steps → standard-stack/steps}/wait-stack-rollback-to-complete.js +0 -0
- /package/dist/command/stacks/undeploy/{steps → standard-stack/steps}/wait-dependents-to-complete.js +0 -0
- /package/dist/command/stacks/undeploy/{steps → standard-stack/steps}/wait-stack-delete-to-complete.js +0 -0
|
@@ -0,0 +1,274 @@
|
|
|
1
|
+
import * as R from "ramda";
|
|
2
|
+
import { prepareAwsEnvVariables } from "../aws/util.js";
|
|
3
|
+
import { executeShellCommand } from "../utils/exec.js";
|
|
4
|
+
import { expandFilePath } from "../utils/files.js";
|
|
5
|
+
import joi from "joi";
|
|
6
|
+
import { TakomoError } from "../utils/errors.js";
|
|
7
|
+
const commandStringSchema = joi.string().required();
|
|
8
|
+
const commandConfigSchema = joi
|
|
9
|
+
.object({
|
|
10
|
+
command: commandStringSchema,
|
|
11
|
+
exposeStackCredentials: joi.boolean(),
|
|
12
|
+
exposeStackRegion: joi.boolean(),
|
|
13
|
+
cwd: joi.string(),
|
|
14
|
+
capture: joi.string().valid("all", "last-line"),
|
|
15
|
+
})
|
|
16
|
+
.required();
|
|
17
|
+
const commandSchema = [commandConfigSchema, commandStringSchema];
|
|
18
|
+
const schema = joi.object({
|
|
19
|
+
getCurrentStateCommand: commandSchema,
|
|
20
|
+
createCommand: commandSchema,
|
|
21
|
+
updateCommand: commandSchema,
|
|
22
|
+
deleteCommand: commandSchema,
|
|
23
|
+
getChangesCommand: commandSchema,
|
|
24
|
+
exposeStackCredentials: joi.boolean(),
|
|
25
|
+
exposeStackRegion: joi.boolean(),
|
|
26
|
+
cwd: joi.string(),
|
|
27
|
+
capture: joi.string().valid("all", "last-line"),
|
|
28
|
+
});
|
|
29
|
+
const captureValue = (capture, output) => {
|
|
30
|
+
switch (capture) {
|
|
31
|
+
case "all":
|
|
32
|
+
return output;
|
|
33
|
+
case "last-line":
|
|
34
|
+
return R.last(output.split("\n")) ?? "";
|
|
35
|
+
default:
|
|
36
|
+
throw new Error(`Unknown value for capture: ${capture}`);
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
const toCommandConfig = (config) => {
|
|
40
|
+
if (typeof config === "string") {
|
|
41
|
+
return { command: config };
|
|
42
|
+
}
|
|
43
|
+
return config;
|
|
44
|
+
};
|
|
45
|
+
const executeCommand = async ({ config, handlerConfig, stack, ctx, logger, tags = {}, parameters = {}, }) => {
|
|
46
|
+
const { command, exposeStackCredentials = handlerConfig.exposeStackCredentials, exposeStackRegion = handlerConfig.exposeStackRegion, cwd = handlerConfig.cwd, capture = handlerConfig.capture ?? "all", } = config;
|
|
47
|
+
const credentials = exposeStackCredentials === true
|
|
48
|
+
? await stack.credentialManager.getCredentials()
|
|
49
|
+
: undefined;
|
|
50
|
+
const region = exposeStackRegion === true ? stack.region : undefined;
|
|
51
|
+
const additionalVariables = {};
|
|
52
|
+
if (tags) {
|
|
53
|
+
Object.entries(tags).forEach(([key, value]) => {
|
|
54
|
+
const envVarName = `TKM_TAG_${key
|
|
55
|
+
.toUpperCase()
|
|
56
|
+
.replace(/[^A-Z0-9_]/g, "_")}`;
|
|
57
|
+
additionalVariables[envVarName] = value;
|
|
58
|
+
});
|
|
59
|
+
additionalVariables["TKM_TAGS_JSON"] = JSON.stringify(tags);
|
|
60
|
+
}
|
|
61
|
+
if (parameters) {
|
|
62
|
+
Object.entries(parameters).forEach(([key, value]) => {
|
|
63
|
+
const envVarName = `TKM_PARAM_${key
|
|
64
|
+
.toUpperCase()
|
|
65
|
+
.replace(/[^A-Z0-9_]/g, "_")}`;
|
|
66
|
+
additionalVariables[envVarName] = value;
|
|
67
|
+
});
|
|
68
|
+
additionalVariables["TKM_PARAMETERS_JSON"] = JSON.stringify(parameters);
|
|
69
|
+
}
|
|
70
|
+
const env = prepareAwsEnvVariables({
|
|
71
|
+
env: process.env,
|
|
72
|
+
credentials,
|
|
73
|
+
region,
|
|
74
|
+
additionalVariables,
|
|
75
|
+
});
|
|
76
|
+
const { stdout, success, error } = await executeShellCommand({
|
|
77
|
+
command,
|
|
78
|
+
env,
|
|
79
|
+
cwd: cwd ? expandFilePath(ctx.projectDir, cwd) : ctx.projectDir,
|
|
80
|
+
stdoutListener: (data) => logger.debug(data),
|
|
81
|
+
stderrListener: (data) => logger.error(data),
|
|
82
|
+
});
|
|
83
|
+
if (!success) {
|
|
84
|
+
throw error;
|
|
85
|
+
}
|
|
86
|
+
const output = captureValue(capture, (stdout ?? "").trim());
|
|
87
|
+
logger.debug(`Command output: ${output}`);
|
|
88
|
+
return output;
|
|
89
|
+
};
|
|
90
|
+
export const createCmdCustomStackHandler = () => {
|
|
91
|
+
return {
|
|
92
|
+
type: "cmd",
|
|
93
|
+
parseConfig: async (props) => {
|
|
94
|
+
const { config, stackPath } = props;
|
|
95
|
+
const { error } = schema.validate(config, {
|
|
96
|
+
abortEarly: false,
|
|
97
|
+
convert: false,
|
|
98
|
+
});
|
|
99
|
+
if (error) {
|
|
100
|
+
const details = error.details.map((d) => ` - ${d.message}`).join("\n");
|
|
101
|
+
return {
|
|
102
|
+
success: false,
|
|
103
|
+
message: `Invalid custom stack configuration`,
|
|
104
|
+
error: new TakomoError(`Validation errors in custom configuration of custom stack ${stackPath}:\n\n${details}`),
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
return {
|
|
108
|
+
success: true,
|
|
109
|
+
config: config,
|
|
110
|
+
};
|
|
111
|
+
},
|
|
112
|
+
getCurrentState: async (props) => {
|
|
113
|
+
try {
|
|
114
|
+
const output = await executeCommand({
|
|
115
|
+
...props,
|
|
116
|
+
config: toCommandConfig(props.config.getCurrentStateCommand),
|
|
117
|
+
handlerConfig: props.config,
|
|
118
|
+
});
|
|
119
|
+
try {
|
|
120
|
+
return {
|
|
121
|
+
success: true,
|
|
122
|
+
state: JSON.parse(output),
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
catch (e) {
|
|
126
|
+
const error = e;
|
|
127
|
+
props.logger.error(`Get current state succeeded but parsing result failed for custom stack ${props.stack.path}`, error);
|
|
128
|
+
return {
|
|
129
|
+
success: false,
|
|
130
|
+
message: "Parsing get current state result failed",
|
|
131
|
+
error,
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
catch (e) {
|
|
136
|
+
const error = e;
|
|
137
|
+
props.logger.error(`Getting current state failed for custom stack ${props.stack.path}`, error);
|
|
138
|
+
return {
|
|
139
|
+
success: false,
|
|
140
|
+
message: "Unhandled error",
|
|
141
|
+
error,
|
|
142
|
+
};
|
|
143
|
+
}
|
|
144
|
+
},
|
|
145
|
+
getChanges: async (props) => {
|
|
146
|
+
try {
|
|
147
|
+
const output = await executeCommand({
|
|
148
|
+
...props,
|
|
149
|
+
config: toCommandConfig(props.config.getChangesCommand),
|
|
150
|
+
handlerConfig: props.config,
|
|
151
|
+
});
|
|
152
|
+
if (output.trim() === "") {
|
|
153
|
+
return {
|
|
154
|
+
success: true,
|
|
155
|
+
changes: [],
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
try {
|
|
159
|
+
return {
|
|
160
|
+
success: true,
|
|
161
|
+
changes: JSON.parse(output),
|
|
162
|
+
};
|
|
163
|
+
}
|
|
164
|
+
catch (e) {
|
|
165
|
+
const error = e;
|
|
166
|
+
props.logger.error(`Get current state succeeded but parsing result failed for custom stack ${props.stack.path}`, error);
|
|
167
|
+
return {
|
|
168
|
+
success: false,
|
|
169
|
+
message: "Parsing get current state result failed",
|
|
170
|
+
error,
|
|
171
|
+
};
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
catch (e) {
|
|
175
|
+
const error = e;
|
|
176
|
+
props.logger.error(`Getting current state failed for custom stack ${props.stack.path}`, error);
|
|
177
|
+
return {
|
|
178
|
+
success: false,
|
|
179
|
+
message: "Unhandled error",
|
|
180
|
+
error,
|
|
181
|
+
};
|
|
182
|
+
}
|
|
183
|
+
},
|
|
184
|
+
create: async (props) => {
|
|
185
|
+
try {
|
|
186
|
+
const output = await executeCommand({
|
|
187
|
+
...props,
|
|
188
|
+
config: toCommandConfig(props.config.createCommand),
|
|
189
|
+
handlerConfig: props.config,
|
|
190
|
+
});
|
|
191
|
+
try {
|
|
192
|
+
return {
|
|
193
|
+
success: true,
|
|
194
|
+
state: JSON.parse(output),
|
|
195
|
+
};
|
|
196
|
+
}
|
|
197
|
+
catch (e) {
|
|
198
|
+
const error = e;
|
|
199
|
+
props.logger.error(`Create succeeded but parsing result failed for custom stack ${props.stack.path}`, error);
|
|
200
|
+
return {
|
|
201
|
+
success: false,
|
|
202
|
+
message: "Parsing create result failed",
|
|
203
|
+
error,
|
|
204
|
+
};
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
catch (e) {
|
|
208
|
+
const error = e;
|
|
209
|
+
props.logger.error(`Creating stack failed for custom stack ${props.stack.path}`, error);
|
|
210
|
+
return {
|
|
211
|
+
success: false,
|
|
212
|
+
message: "Unhandled error",
|
|
213
|
+
error,
|
|
214
|
+
};
|
|
215
|
+
}
|
|
216
|
+
},
|
|
217
|
+
update: async (props) => {
|
|
218
|
+
try {
|
|
219
|
+
const output = await executeCommand({
|
|
220
|
+
...props,
|
|
221
|
+
config: toCommandConfig(props.config.updateCommand),
|
|
222
|
+
handlerConfig: props.config,
|
|
223
|
+
});
|
|
224
|
+
try {
|
|
225
|
+
return {
|
|
226
|
+
success: true,
|
|
227
|
+
state: JSON.parse(output),
|
|
228
|
+
};
|
|
229
|
+
}
|
|
230
|
+
catch (e) {
|
|
231
|
+
const error = e;
|
|
232
|
+
props.logger.error(`Update succeeded but parsing result failed for custom stack ${props.stack.path}`, error);
|
|
233
|
+
return {
|
|
234
|
+
success: false,
|
|
235
|
+
message: "Parsing update result failed",
|
|
236
|
+
error,
|
|
237
|
+
};
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
catch (e) {
|
|
241
|
+
const error = e;
|
|
242
|
+
props.logger.error(`Updating stack failed for custom stack ${props.stack.path}`, error);
|
|
243
|
+
return {
|
|
244
|
+
success: false,
|
|
245
|
+
message: "Unhandled error",
|
|
246
|
+
error,
|
|
247
|
+
};
|
|
248
|
+
}
|
|
249
|
+
},
|
|
250
|
+
delete: async (props) => {
|
|
251
|
+
try {
|
|
252
|
+
await executeCommand({
|
|
253
|
+
...props,
|
|
254
|
+
config: toCommandConfig(props.config.deleteCommand),
|
|
255
|
+
handlerConfig: props.config,
|
|
256
|
+
});
|
|
257
|
+
// TODO: Validate state?
|
|
258
|
+
return {
|
|
259
|
+
success: true,
|
|
260
|
+
};
|
|
261
|
+
}
|
|
262
|
+
catch (e) {
|
|
263
|
+
const error = e;
|
|
264
|
+
props.logger.error(`Getting current state failed for stack ${props.stack.path}`, error);
|
|
265
|
+
return {
|
|
266
|
+
success: false,
|
|
267
|
+
message: "Unhandled error",
|
|
268
|
+
error,
|
|
269
|
+
};
|
|
270
|
+
}
|
|
271
|
+
},
|
|
272
|
+
};
|
|
273
|
+
};
|
|
274
|
+
//# sourceMappingURL=cmd-custom-stack-handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cmd-custom-stack-handler.js","sourceRoot":"","sources":["../../src/custom-stacks/cmd-custom-stack-handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { TkmLogger } from "../utils/logging.js";
|
|
2
|
+
import { CustomStackHandler } from "./custom-stack-handler.js";
|
|
3
|
+
import { CustomStackType } from "../stacks/stack.js";
|
|
4
|
+
export interface CustomStackHandlerRegistry {
|
|
5
|
+
readonly getHandler: (type: CustomStackType) => CustomStackHandler<any, any>;
|
|
6
|
+
readonly registerHandler: (provider: CustomStackHandler<any, any>) => Promise<void>;
|
|
7
|
+
}
|
|
8
|
+
interface CreateCustomStackHandlerRegistryProps {
|
|
9
|
+
readonly logger: TkmLogger;
|
|
10
|
+
}
|
|
11
|
+
export declare const createCustomStackHandlerRegistry: ({ logger, }: CreateCustomStackHandlerRegistryProps) => CustomStackHandlerRegistry;
|
|
12
|
+
export declare const coreCustomStackHandlerProviders: () => ReadonlyArray<CustomStackHandler<any, any>>;
|
|
13
|
+
export {};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { createCmdCustomStackHandler } from "./cmd-custom-stack-handler.js";
|
|
2
|
+
// Reserved types that cannot be used by custom stack handlers
|
|
3
|
+
const reservedTypes = ["standard", "custom"];
|
|
4
|
+
export const createCustomStackHandlerRegistry = ({ logger, }) => {
|
|
5
|
+
const handlers = new Map();
|
|
6
|
+
const registerHandler = async (handler) => {
|
|
7
|
+
reservedTypes.forEach((type) => {
|
|
8
|
+
if (handler.type === type) {
|
|
9
|
+
throw new Error(`Cannot register custom stack handler with reserved type '${type}'`);
|
|
10
|
+
}
|
|
11
|
+
});
|
|
12
|
+
const existingHandler = handlers.get(handler.type);
|
|
13
|
+
if (existingHandler) {
|
|
14
|
+
throw new Error(`Custom stack handler already registered for with type '${handler.type}'`);
|
|
15
|
+
}
|
|
16
|
+
logger.debug(`Registered custom stack handler with type '${handler.type}'`);
|
|
17
|
+
handlers.set(handler.type, handler);
|
|
18
|
+
};
|
|
19
|
+
const getHandler = (type) => {
|
|
20
|
+
const handler = handlers.get(type);
|
|
21
|
+
if (!handler) {
|
|
22
|
+
throw new Error(`Custom stack handler not found with type '${type}'`);
|
|
23
|
+
}
|
|
24
|
+
return handler;
|
|
25
|
+
};
|
|
26
|
+
return {
|
|
27
|
+
registerHandler,
|
|
28
|
+
getHandler,
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
export const coreCustomStackHandlerProviders = () => [createCmdCustomStackHandler()];
|
|
32
|
+
//# sourceMappingURL=custom-stack-handler-registry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"custom-stack-handler-registry.js","sourceRoot":"","sources":["../../src/custom-stacks/custom-stack-handler-registry.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,2BAA2B,EAAE,MAAM,+BAA+B,CAAA;AAe3E,8DAA8D;AAC9D,MAAM,aAAa,GAAmC,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;AAE5E,MAAM,CAAC,MAAM,gCAAgC,GAAG,CAAC,EAC/C,MAAM,GACgC,EAA8B,EAAE;IACtE,MAAM,QAAQ,GAAG,IAAI,GAAG,EAGrB,CAAA;IAEH,MAAM,eAAe,GAAG,KAAK,EAC3B,OAAsD,EACvC,EAAE;QACjB,aAAa,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC7B,IAAI,OAAO,CAAC,IAAI,KAAK,IAAI,EAAE,CAAC;gBAC1B,MAAM,IAAI,KAAK,CACb,4DAA4D,IAAI,GAAG,CACpE,CAAA;YACH,CAAC;QACH,CAAC,CAAC,CAAA;QAEF,MAAM,eAAe,GAAG,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;QAClD,IAAI,eAAe,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CACb,0DAA0D,OAAO,CAAC,IAAI,GAAG,CAC1E,CAAA;QACH,CAAC;QAED,MAAM,CAAC,KAAK,CAAC,8CAA8C,OAAO,CAAC,IAAI,GAAG,CAAC,CAAA;QAE3E,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;IACrC,CAAC,CAAA;IAED,MAAM,UAAU,GAAG,CACjB,IAAqB,EAC0B,EAAE;QACjD,MAAM,OAAO,GAAG,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;QAClC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,6CAA6C,IAAI,GAAG,CAAC,CAAA;QACvE,CAAC;QAED,OAAO,OAAO,CAAA;IAChB,CAAC,CAAA;IAED,OAAO;QACL,eAAe;QACf,UAAU;KACX,CAAA;AACH,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,+BAA+B,GAAG,GAE7C,EAAE,CAAC,CAAC,2BAA2B,EAAE,CAAC,CAAA"}
|