From d9c79f438f1ce56864af552aba15a6010e556efd Mon Sep 17 00:00:00 2001 From: engel80 Date: Tue, 20 Dec 2022 13:17:02 +0900 Subject: [PATCH 1/2] . --- .github/workflows/build.yml | 23 ++- package-lock.json | 60 ++++--- package.json | 7 +- ts.out/code-pipeline/bin/index.d.ts | 2 + ts.out/code-pipeline/bin/index.js | 40 +++++ .../lib/ecs-codedeploy-stack.d.ts | 17 ++ .../code-pipeline/lib/ecs-codedeploy-stack.js | 149 +++++++++++++++++ ts.out/config.d.ts | 18 +++ ts.out/config.js | 18 +++ ts.out/ecr-codecommit/bin/index.d.ts | 2 + ts.out/ecr-codecommit/bin/index.js | 40 +++++ .../lib/ecr-codecommit-stack.d.ts | 12 ++ .../lib/ecr-codecommit-stack.js | 77 +++++++++ ts.out/ecs-fargate-cluster/bin/index.d.ts | 2 + ts.out/ecs-fargate-cluster/bin/index.js | 39 +++++ .../lib/cluster-config.d.ts | 3 + .../ecs-fargate-cluster/lib/cluster-config.js | 7 + .../lib/ecs-fargate-cluster-stack.d.ts | 9 ++ .../lib/ecs-fargate-cluster-stack.js | 61 +++++++ .../bin/index.d.ts | 2 + .../ecs-fargate-service-restapi/bin/index.js | 38 +++++ .../ecs-fargate-service-restapi-stack.d.ts | 10 ++ .../lib/ecs-fargate-service-restapi-stack.js | 142 ++++++++++++++++ .../bin/index.d.ts | 2 + .../bin/index.js | 38 +++++ ...ecs-fargatespot-service-restapi-stack.d.ts | 10 ++ .../ecs-fargatespot-service-restapi-stack.js | 151 ++++++++++++++++++ ts.out/ecs-iam-role/bin/index.d.ts | 2 + ts.out/ecs-iam-role/bin/index.js | 37 +++++ .../ecs-iam-role/lib/ecs-iam-role-stack.d.ts | 13 ++ ts.out/ecs-iam-role/lib/ecs-iam-role-stack.js | 79 +++++++++ ts.out/vpc/bin/index.d.ts | 2 + ts.out/vpc/bin/index.js | 37 +++++ ts.out/vpc/lib/vpc-stack.d.ts | 5 + ts.out/vpc/lib/vpc-stack.js | 56 +++++++ 35 files changed, 1183 insertions(+), 27 deletions(-) create mode 100644 ts.out/code-pipeline/bin/index.d.ts create mode 100644 ts.out/code-pipeline/bin/index.js create mode 100644 ts.out/code-pipeline/lib/ecs-codedeploy-stack.d.ts create mode 100644 ts.out/code-pipeline/lib/ecs-codedeploy-stack.js create mode 100644 ts.out/config.d.ts create mode 100644 ts.out/config.js create mode 100644 ts.out/ecr-codecommit/bin/index.d.ts create mode 100644 ts.out/ecr-codecommit/bin/index.js create mode 100644 ts.out/ecr-codecommit/lib/ecr-codecommit-stack.d.ts create mode 100644 ts.out/ecr-codecommit/lib/ecr-codecommit-stack.js create mode 100644 ts.out/ecs-fargate-cluster/bin/index.d.ts create mode 100644 ts.out/ecs-fargate-cluster/bin/index.js create mode 100644 ts.out/ecs-fargate-cluster/lib/cluster-config.d.ts create mode 100644 ts.out/ecs-fargate-cluster/lib/cluster-config.js create mode 100644 ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.d.ts create mode 100644 ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.js create mode 100644 ts.out/ecs-fargate-service-restapi/bin/index.d.ts create mode 100644 ts.out/ecs-fargate-service-restapi/bin/index.js create mode 100644 ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.d.ts create mode 100644 ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.js create mode 100644 ts.out/ecs-fargatespot-service-restapi/bin/index.d.ts create mode 100644 ts.out/ecs-fargatespot-service-restapi/bin/index.js create mode 100644 ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.d.ts create mode 100644 ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.js create mode 100644 ts.out/ecs-iam-role/bin/index.d.ts create mode 100644 ts.out/ecs-iam-role/bin/index.js create mode 100644 ts.out/ecs-iam-role/lib/ecs-iam-role-stack.d.ts create mode 100644 ts.out/ecs-iam-role/lib/ecs-iam-role-stack.js create mode 100644 ts.out/vpc/bin/index.d.ts create mode 100644 ts.out/vpc/bin/index.js create mode 100644 ts.out/vpc/lib/vpc-stack.d.ts create mode 100644 ts.out/vpc/lib/vpc-stack.js diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 2bda9ba..784e849 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -7,7 +7,28 @@ on: pull_request: types: [opened, synchronize, reopened] jobs: - build: + cdk-build: + runs-on: ubuntu-latest + strategy: + matrix: + node: [ 18 ] + name: Node ${{ matrix.node }} sample + steps: + - uses: actions/checkout@v3 + - name: Setup node + uses: actions/setup-node@v3 + with: + node-version: ${{ matrix.node }} + - run: npm install && npm run build + + docker-build: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + - name: Build the Docker image + run: cd app && docker build . -t eks-cdk:$(date +%s) + + sonarqube: name: Build runs-on: ubuntu-latest steps: diff --git a/package-lock.json b/package-lock.json index 4d84603..c84045e 100644 --- a/package-lock.json +++ b/package-lock.json @@ -10,9 +10,10 @@ "dependencies": { "@types/js-yaml": "4.0.5", "aws-cdk-lib": "2.32.1", - "cdk-ecr-deployment": "2.5.5", + "cdk-ecr-deployment": "^2.5.6", "constructs": "^10.0.0", - "sync-request": "6.1.0" + "sync-request": "6.1.0", + "tsc": "^2.0.4" }, "bin": { "cluster": "ecs-ec2-cluster/bin/index.js" @@ -24,7 +25,7 @@ "jest": "^26.4.2", "ts-jest": "^26.2.0", "ts-node": "^9.0.0", - "typescript": "~3.9.7" + "typescript": "^4.9.4" } }, "node_modules/@ampproject/remapping": { @@ -1749,9 +1750,9 @@ "integrity": "sha512-4tYFyifaFfGacoiObjJegolkwSU4xQNGbVgUiNYVUxbQ2x2lUsFvY4hVgVzGiIe6WLOPqycWXA40l+PWsxthUw==" }, "node_modules/cdk-ecr-deployment": { - "version": "2.5.5", - "resolved": "https://registry.npmjs.org/cdk-ecr-deployment/-/cdk-ecr-deployment-2.5.5.tgz", - "integrity": "sha512-glU4fIotzz/sTDqpTqEUs3XKSlYxWBFt5sTAWgZAzIUf149i3AIhrq3OoJsH7Q7WwjFcGcLX5+BFiHvPe9l1yg==", + "version": "2.5.6", + "resolved": "https://registry.npmjs.org/cdk-ecr-deployment/-/cdk-ecr-deployment-2.5.6.tgz", + "integrity": "sha512-Vl6FksKZLC1wE/ZjHvShg4fVZqOR8x2aIUAP+M3fe1MLKQHztApi0cG4ceVYf4FLpUlYXGRjTkJR28/cWY9RnQ==", "bundleDependencies": [ "got", "hpagent" @@ -1925,7 +1926,7 @@ } }, "node_modules/cdk-ecr-deployment/node_modules/got": { - "version": "11.8.3", + "version": "11.8.5", "inBundle": true, "license": "MIT", "dependencies": { @@ -2416,9 +2417,9 @@ "dev": true }, "node_modules/decode-uri-component": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz", - "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=", + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.2.tgz", + "integrity": "sha512-FqUYQ+8o158GyGTrMFJms9qh3CqTKvAqgqsTnkLI8sKu0028orqBhxNMFkFen0zGyg6epACD32pjVk58ngIErQ==", "dev": true, "engines": { "node": ">=0.10" @@ -6438,6 +6439,14 @@ "typescript": ">=2.7" } }, + "node_modules/tsc": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/tsc/-/tsc-2.0.4.tgz", + "integrity": "sha512-fzoSieZI5KKJVBYGvwbVZs/J5za84f2lSTLPYf6AGiIf43tZ3GNrI1QzTLcjtyDDP4aLxd46RTZq1nQxe7+k5Q==", + "bin": { + "tsc": "bin/tsc" + } + }, "node_modules/type-check": { "version": "0.3.2", "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", @@ -6486,9 +6495,9 @@ } }, "node_modules/typescript": { - "version": "3.9.10", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.9.10.tgz", - "integrity": "sha512-w6fIxVE/H1PkLKcCPsFqKE7Kv7QUwhU8qQY2MueZXWx5cPZdwFupLgKK3vntcK98BtNHZtAF4LA/yl2a7k8R6Q==", + "version": "4.9.4", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.9.4.tgz", + "integrity": "sha512-Uz+dTXYzxXXbsFpM86Wh3dKCxrQqUcVMxwU54orwlJjOpO3ao8L7j5lH+dWfTwgCwIuM9GQ2kvVotzYJMXTBZg==", "dev": true, "bin": { "tsc": "bin/tsc", @@ -8208,9 +8217,9 @@ "integrity": "sha512-4tYFyifaFfGacoiObjJegolkwSU4xQNGbVgUiNYVUxbQ2x2lUsFvY4hVgVzGiIe6WLOPqycWXA40l+PWsxthUw==" }, "cdk-ecr-deployment": { - "version": "2.5.5", - "resolved": "https://registry.npmjs.org/cdk-ecr-deployment/-/cdk-ecr-deployment-2.5.5.tgz", - "integrity": "sha512-glU4fIotzz/sTDqpTqEUs3XKSlYxWBFt5sTAWgZAzIUf149i3AIhrq3OoJsH7Q7WwjFcGcLX5+BFiHvPe9l1yg==", + "version": "2.5.6", + "resolved": "https://registry.npmjs.org/cdk-ecr-deployment/-/cdk-ecr-deployment-2.5.6.tgz", + "integrity": "sha512-Vl6FksKZLC1wE/ZjHvShg4fVZqOR8x2aIUAP+M3fe1MLKQHztApi0cG4ceVYf4FLpUlYXGRjTkJR28/cWY9RnQ==", "requires": { "aws-cdk-lib": "^2.0.0", "constructs": "^10.0.5", @@ -8331,7 +8340,7 @@ } }, "got": { - "version": "11.8.3", + "version": "11.8.5", "bundled": true, "requires": { "@sindresorhus/is": "^4.0.0", @@ -8711,9 +8720,9 @@ "dev": true }, "decode-uri-component": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz", - "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=", + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.2.tgz", + "integrity": "sha512-FqUYQ+8o158GyGTrMFJms9qh3CqTKvAqgqsTnkLI8sKu0028orqBhxNMFkFen0zGyg6epACD32pjVk58ngIErQ==", "dev": true }, "deep-is": { @@ -11842,6 +11851,11 @@ "yn": "3.1.1" } }, + "tsc": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/tsc/-/tsc-2.0.4.tgz", + "integrity": "sha512-fzoSieZI5KKJVBYGvwbVZs/J5za84f2lSTLPYf6AGiIf43tZ3GNrI1QzTLcjtyDDP4aLxd46RTZq1nQxe7+k5Q==" + }, "type-check": { "version": "0.3.2", "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", @@ -11878,9 +11892,9 @@ } }, "typescript": { - "version": "3.9.10", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.9.10.tgz", - "integrity": "sha512-w6fIxVE/H1PkLKcCPsFqKE7Kv7QUwhU8qQY2MueZXWx5cPZdwFupLgKK3vntcK98BtNHZtAF4LA/yl2a7k8R6Q==", + "version": "4.9.4", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.9.4.tgz", + "integrity": "sha512-Uz+dTXYzxXXbsFpM86Wh3dKCxrQqUcVMxwU54orwlJjOpO3ao8L7j5lH+dWfTwgCwIuM9GQ2kvVotzYJMXTBZg==", "dev": true }, "union-value": { diff --git a/package.json b/package.json index 2a277b8..2449849 100644 --- a/package.json +++ b/package.json @@ -17,13 +17,14 @@ "jest": "^26.4.2", "ts-jest": "^26.2.0", "ts-node": "^9.0.0", - "typescript": "~3.9.7" + "typescript": "^4.9.4" }, "dependencies": { "@types/js-yaml": "4.0.5", "aws-cdk-lib": "2.32.1", - "cdk-ecr-deployment": "2.5.5", + "cdk-ecr-deployment": "^2.5.6", "constructs": "^10.0.0", - "sync-request": "6.1.0" + "sync-request": "6.1.0", + "tsc": "^2.0.4" } } diff --git a/ts.out/code-pipeline/bin/index.d.ts b/ts.out/code-pipeline/bin/index.d.ts new file mode 100644 index 0000000..b798801 --- /dev/null +++ b/ts.out/code-pipeline/bin/index.d.ts @@ -0,0 +1,2 @@ +#!/usr/bin/env node +export {}; diff --git a/ts.out/code-pipeline/bin/index.js b/ts.out/code-pipeline/bin/index.js new file mode 100644 index 0000000..dfbc643 --- /dev/null +++ b/ts.out/code-pipeline/bin/index.js @@ -0,0 +1,40 @@ +#!/usr/bin/env node +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const cdk = __importStar(require("aws-cdk-lib")); +const config_1 = require("../../config"); +const ecs_codedeploy_stack_1 = require("../lib/ecs-codedeploy-stack"); +const app = new cdk.App(); +const env = { + account: process.env.CDK_DEFAULT_ACCOUNT, + region: process.env.CDK_DEFAULT_REGION, +}; +const stage = app.node.tryGetContext('stage') || config_1.DEFAULT_STAGE; +const serviceName = 'fargate-restapi'; +new ecs_codedeploy_stack_1.EcsCodeDeployStack(app, `codepipeline-${serviceName}-${stage}`, { + env, + stage, + serviceName, + description: `Code Pipeline, service name: ${serviceName}-${stage}`, + terminationProtection: stage !== config_1.DEFAULT_STAGE +}); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9jb2RlLXBpcGVsaW5lL2Jpbi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQ0EsaURBQW1DO0FBQ25DLHlDQUE2QztBQUM3QyxzRUFBaUU7QUFFakUsTUFBTSxHQUFHLEdBQUcsSUFBSSxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUM7QUFDMUIsTUFBTSxHQUFHLEdBQUc7SUFDUixPQUFPLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxtQkFBbUI7SUFDeEMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCO0NBQ3pDLENBQUM7QUFDRixNQUFNLEtBQUssR0FBRyxHQUFHLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsSUFBSSxzQkFBYSxDQUFDO0FBRS9ELE1BQU0sV0FBVyxHQUFHLGlCQUFpQixDQUFDO0FBRXRDLElBQUkseUNBQWtCLENBQUMsR0FBRyxFQUFFLGdCQUFnQixXQUFXLElBQUksS0FBSyxFQUFFLEVBQUU7SUFDaEUsR0FBRztJQUNILEtBQUs7SUFDTCxXQUFXO0lBQ1gsV0FBVyxFQUFFLGdDQUFnQyxXQUFXLElBQUksS0FBSyxFQUFFO0lBQ25FLHFCQUFxQixFQUFFLEtBQUssS0FBRyxzQkFBYTtDQUMvQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIjIS91c3IvYmluL2VudiBub2RlXG5pbXBvcnQgKiBhcyBjZGsgZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0IHsgREVGQVVMVF9TVEFHRSB9IGZyb20gJy4uLy4uL2NvbmZpZyc7XG5pbXBvcnQgeyBFY3NDb2RlRGVwbG95U3RhY2sgfSBmcm9tICcuLi9saWIvZWNzLWNvZGVkZXBsb3ktc3RhY2snO1xuXG5jb25zdCBhcHAgPSBuZXcgY2RrLkFwcCgpO1xuY29uc3QgZW52ID0ge1xuICAgIGFjY291bnQ6IHByb2Nlc3MuZW52LkNES19ERUZBVUxUX0FDQ09VTlQsXG4gICAgcmVnaW9uOiBwcm9jZXNzLmVudi5DREtfREVGQVVMVF9SRUdJT04sXG59O1xuY29uc3Qgc3RhZ2UgPSBhcHAubm9kZS50cnlHZXRDb250ZXh0KCdzdGFnZScpIHx8IERFRkFVTFRfU1RBR0U7XG5cbmNvbnN0IHNlcnZpY2VOYW1lID0gJ2ZhcmdhdGUtcmVzdGFwaSc7XG5cbm5ldyBFY3NDb2RlRGVwbG95U3RhY2soYXBwLCBgY29kZXBpcGVsaW5lLSR7c2VydmljZU5hbWV9LSR7c3RhZ2V9YCwge1xuICAgIGVudixcbiAgICBzdGFnZSxcbiAgICBzZXJ2aWNlTmFtZSxcbiAgICBkZXNjcmlwdGlvbjogYENvZGUgUGlwZWxpbmUsIHNlcnZpY2UgbmFtZTogJHtzZXJ2aWNlTmFtZX0tJHtzdGFnZX1gLFxuICAgIHRlcm1pbmF0aW9uUHJvdGVjdGlvbjogc3RhZ2UhPT1ERUZBVUxUX1NUQUdFXG59KTtcbiJdfQ== \ No newline at end of file diff --git a/ts.out/code-pipeline/lib/ecs-codedeploy-stack.d.ts b/ts.out/code-pipeline/lib/ecs-codedeploy-stack.d.ts new file mode 100644 index 0000000..5aeeb21 --- /dev/null +++ b/ts.out/code-pipeline/lib/ecs-codedeploy-stack.d.ts @@ -0,0 +1,17 @@ +import { Stack, StackProps } from 'aws-cdk-lib'; +import { Construct } from 'constructs'; +export interface EcsCodeDeployStackProps extends StackProps { + stage: string; + serviceName: string; +} +/** + * SSM parameters: + * /cdk-ecs-fargate/ecr-repo-arn + * /cdk-ecs-fargate/ecr-repo-name + * /cdk-ecs-fargate/cluster-securitygroup-id + * /cdk-ecs-fargate/cluster-name + * /cdk-ecs-fargate/codecommit-arn + */ +export declare class EcsCodeDeployStack extends Stack { + constructor(scope: Construct, id: string, props: EcsCodeDeployStackProps); +} diff --git a/ts.out/code-pipeline/lib/ecs-codedeploy-stack.js b/ts.out/code-pipeline/lib/ecs-codedeploy-stack.js new file mode 100644 index 0000000..bed7e38 --- /dev/null +++ b/ts.out/code-pipeline/lib/ecs-codedeploy-stack.js @@ -0,0 +1,149 @@ +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.EcsCodeDeployStack = void 0; +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const cdk = __importStar(require("aws-cdk-lib")); +const ssm = __importStar(require("aws-cdk-lib/aws-ssm")); +const ecr = __importStar(require("aws-cdk-lib/aws-ecr")); +const ec2 = __importStar(require("aws-cdk-lib/aws-ec2")); +const ecs = __importStar(require("aws-cdk-lib/aws-ecs")); +const iam = __importStar(require("aws-cdk-lib/aws-iam")); +const codebuild = __importStar(require("aws-cdk-lib/aws-codebuild")); +const codepipeline = __importStar(require("aws-cdk-lib/aws-codepipeline")); +const codecommit = __importStar(require("aws-cdk-lib/aws-codecommit")); +const codepipeline_actions = __importStar(require("aws-cdk-lib/aws-codepipeline-actions")); +const cluster_config_1 = require("../../ecs-fargate-cluster/lib/cluster-config"); +const config_1 = require("../../config"); +/** + * SSM parameters: + * /cdk-ecs-fargate/ecr-repo-arn + * /cdk-ecs-fargate/ecr-repo-name + * /cdk-ecs-fargate/cluster-securitygroup-id + * /cdk-ecs-fargate/cluster-name + * /cdk-ecs-fargate/codecommit-arn + */ +class EcsCodeDeployStack extends aws_cdk_lib_1.Stack { + constructor(scope, id, props) { + var _a, _b; + super(scope, id, props); + const ecrRepo = ecr.Repository.fromRepositoryAttributes(this, 'ecr-repo', { + repositoryArn: cdk.Lazy.string({ produce: () => ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/ecr-repo-arn`) }), + repositoryName: ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/ecr-repo-name`) + }); + const vpcId = this.node.tryGetContext('vpcId') || ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/vpc-id`); + const vpc = ec2.Vpc.fromLookup(this, 'vpc', { vpcId }); + const clusterSgId = ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/cluster-securitygroup-id`); + const ecsSecurityGroup = ec2.SecurityGroup.fromSecurityGroupId(this, 'ecs-security-group', clusterSgId); + const cluster = ecs.Cluster.fromClusterAttributes(this, 'ecs-fargate-cluster', { + clusterName: `${cluster_config_1.CLUSTER_NAME}-${props.stage}`, + vpc, + securityGroups: [ecsSecurityGroup] + }); + const service = ecs.FargateService.fromFargateServiceAttributes(this, 'fargate-cluster', { + cluster, + serviceName: cdk.Lazy.string({ produce: () => ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/cluster-name`) }) + }); + const serviceName = props.serviceName; + const repository = codecommit.Repository.fromRepositoryArn(this, `${serviceName}-codecommit-arn`, cdk.Lazy.string({ produce: () => ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/codecommit-arn`) })); + /** + * buildImage: codebuild.LinuxBuildImage.AMAZON_LINUX_2_4, + * buildImage: codebuild.LinuxBuildImage.fromDockerRegistry('public.ecr.aws/h1a5s9h8/alpine:latest') + */ + const project = new codebuild.Project(this, `cb-project-${serviceName}`, { + projectName: `${serviceName}-build`, + source: codebuild.Source.codeCommit({ repository }), + environment: { + buildImage: codebuild.LinuxBuildImage.STANDARD_6_0, + privileged: true + }, + buildSpec: codebuild.BuildSpec.fromSourceFilename('./buildspec.yaml'), + badge: true, + environmentVariables: { + 'ACCOUNT_ID': { + value: (_a = props === null || props === void 0 ? void 0 : props.env) === null || _a === void 0 ? void 0 : _a.account + }, + 'CLUSTER_NAME': { + value: `${service.cluster.clusterName}` + }, + 'SERVICE_NAME': { + value: `${service.serviceName}` + }, + 'ECR_REPO_URI': { + value: `${ecrRepo.repositoryUri}` + } + } + }); + ecrRepo.grantPullPush(project.role); + (_b = project.role) === null || _b === void 0 ? void 0 : _b.addManagedPolicy(iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonEC2ContainerRegistryPowerUser')); + const sourceOutput = new codepipeline.Artifact(); + const buildOutput = new codepipeline.Artifact(); + /** + * aws secretsmanager create-secret --name '/github/token' --secret-string {your-token} + * or set the token with oauthToken: cdk.SecretValue.plainText(''), + */ + const sourceAction = new codepipeline_actions.GitHubSourceAction({ + actionName: 'GitHub_Source', + owner: 'engel80', + repo: 'fargate-restapi-local', + branch: 'master', + oauthToken: cdk.SecretValue.secretsManager("/github/token"), + output: sourceOutput + }); + const buildAction = new codepipeline_actions.CodeBuildAction({ + actionName: 'CodeBuild', + project, + input: sourceOutput, + outputs: [buildOutput], + }); + const manualApprovalAction = new codepipeline_actions.ManualApprovalAction({ + actionName: 'Approve', + }); + const deployAction = new codepipeline_actions.EcsDeployAction({ + actionName: 'DeployAction', + service: service, + imageFile: new codepipeline.ArtifactPath(buildOutput, `imagedefinitions.json`) + }); + new codepipeline.Pipeline(this, 'ecs-deploy-pipeline', { + pipelineName: `ecs-deploy-${service.serviceName}`, + stages: [ + { + stageName: 'Source', + actions: [sourceAction], + }, + { + stageName: 'Build', + actions: [buildAction], + }, + { + stageName: 'Approve', + actions: [manualApprovalAction], + }, + { + stageName: 'Deploy', + actions: [deployAction], + } + ] + }); + } +} +exports.EcsCodeDeployStack = EcsCodeDeployStack; +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecs-codedeploy-stack.js","sourceRoot":"","sources":["../../../code-pipeline/lib/ecs-codedeploy-stack.ts"],"names":[],"mappings":"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","sourcesContent":["import { Stack, StackProps } from 'aws-cdk-lib';\nimport * as cdk from 'aws-cdk-lib';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\n\nimport * as ecr from 'aws-cdk-lib/aws-ecr';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as codebuild from 'aws-cdk-lib/aws-codebuild';\nimport * as codepipeline from 'aws-cdk-lib/aws-codepipeline';\nimport * as codecommit from 'aws-cdk-lib/aws-codecommit';\nimport * as codepipeline_actions from 'aws-cdk-lib/aws-codepipeline-actions';\n\nimport { Construct } from 'constructs';\n\nimport { CLUSTER_NAME } from '../../ecs-fargate-cluster/lib/cluster-config';\nimport { SSM_PREFIX } from '../../config';\nimport { IBaseService } from 'aws-cdk-lib/aws-ecs';\n\nexport interface EcsCodeDeployStackProps extends StackProps {\n    stage: string;\n    serviceName: string;\n}\n/**\n * SSM parameters:\n * /cdk-ecs-fargate/ecr-repo-arn\n * /cdk-ecs-fargate/ecr-repo-name\n * /cdk-ecs-fargate/cluster-securitygroup-id\n * /cdk-ecs-fargate/cluster-name\n * /cdk-ecs-fargate/codecommit-arn\n */\nexport class EcsCodeDeployStack extends Stack {\n    constructor(scope: Construct, id: string, props: EcsCodeDeployStackProps) {\n        super(scope, id, props);\n\n        const ecrRepo = ecr.Repository.fromRepositoryAttributes(this, 'ecr-repo', {\n            repositoryArn: cdk.Lazy.string({ produce: () => ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/ecr-repo-arn`) }),\n            repositoryName: ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/ecr-repo-name`)\n        });\n\n        const vpcId = this.node.tryGetContext('vpcId') || ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/vpc-id`);\n        const vpc = ec2.Vpc.fromLookup(this, 'vpc', { vpcId });\n        const clusterSgId = ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/cluster-securitygroup-id`);\n        const ecsSecurityGroup = ec2.SecurityGroup.fromSecurityGroupId(this, 'ecs-security-group', clusterSgId);\n\n        const cluster = ecs.Cluster.fromClusterAttributes(this, 'ecs-fargate-cluster', {\n            clusterName: `${CLUSTER_NAME}-${props.stage}`,\n            vpc,\n            securityGroups: [ecsSecurityGroup]\n        });\n        const service = ecs.FargateService.fromFargateServiceAttributes(this, 'fargate-cluster', {\n            cluster,\n            serviceName: cdk.Lazy.string({ produce: () => ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/cluster-name`) })\n        }) as IBaseService;\n\n        const serviceName = props.serviceName;\n        const repository = codecommit.Repository.fromRepositoryArn(this, `${serviceName}-codecommit-arn`,\n            cdk.Lazy.string({ produce: () => ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/codecommit-arn`) }));\n\n        /**\n         * buildImage: codebuild.LinuxBuildImage.AMAZON_LINUX_2_4,\n         * buildImage: codebuild.LinuxBuildImage.fromDockerRegistry('public.ecr.aws/h1a5s9h8/alpine:latest')\n         */\n        const project = new codebuild.Project(this, `cb-project-${serviceName}`, {\n            projectName: `${serviceName}-build`,\n            source: codebuild.Source.codeCommit({ repository }),\n            environment: {\n                buildImage: codebuild.LinuxBuildImage.STANDARD_6_0,\n                privileged: true\n            },\n            buildSpec: codebuild.BuildSpec.fromSourceFilename('./buildspec.yaml'),\n            badge: true,\n            environmentVariables: {\n                'ACCOUNT_ID': {\n                    value: props?.env?.account\n                },\n                'CLUSTER_NAME': {\n                    value: `${service.cluster.clusterName}`\n                },\n                'SERVICE_NAME': {\n                    value: `${service.serviceName}`\n                },\n                'ECR_REPO_URI': {\n                    value: `${ecrRepo.repositoryUri}`\n                }\n            }\n        });\n        ecrRepo.grantPullPush(project.role!);\n        project.role?.addManagedPolicy(iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonEC2ContainerRegistryPowerUser'));\n\n        const sourceOutput = new codepipeline.Artifact();\n        const buildOutput = new codepipeline.Artifact();\n\n        /**\n         * aws secretsmanager create-secret --name '/github/token' --secret-string {your-token}\n         * or set the token with oauthToken: cdk.SecretValue.plainText('<plain-text>'),\n         */\n        const sourceAction = new codepipeline_actions.GitHubSourceAction({\n            actionName: 'GitHub_Source',\n            owner: 'engel80',\n            repo: 'fargate-restapi-local',\n            branch: 'master',\n            oauthToken: cdk.SecretValue.secretsManager(\"/github/token\"),\n            output: sourceOutput\n        });\n\n        const buildAction = new codepipeline_actions.CodeBuildAction({\n            actionName: 'CodeBuild',\n            project,\n            input: sourceOutput,\n            outputs: [buildOutput],\n        });\n        const manualApprovalAction = new codepipeline_actions.ManualApprovalAction({\n            actionName: 'Approve',\n        });\n        const deployAction = new codepipeline_actions.EcsDeployAction({\n            actionName: 'DeployAction',\n            service: service,\n            imageFile: new codepipeline.ArtifactPath(buildOutput, `imagedefinitions.json`)\n        });\n\n        new codepipeline.Pipeline(this, 'ecs-deploy-pipeline', {\n            pipelineName: `ecs-deploy-${service.serviceName}`,\n            stages: [\n                {\n                    stageName: 'Source',\n                    actions: [sourceAction],\n                },\n                {\n                    stageName: 'Build',\n                    actions: [buildAction],\n                },\n                {\n                    stageName: 'Approve',\n                    actions: [manualApprovalAction],\n                },\n                {\n                    stageName: 'Deploy',\n                    actions: [deployAction],\n                }\n            ]\n        });\n    }\n}\n"]} \ No newline at end of file diff --git a/ts.out/config.d.ts b/ts.out/config.d.ts new file mode 100644 index 0000000..316142e --- /dev/null +++ b/ts.out/config.d.ts @@ -0,0 +1,18 @@ +import * as cdk from 'aws-cdk-lib'; +/** + * /cdk-ecs-fargate/vpc-id + * + * ecs-fargate-cluster: + * /cdk-ecs-fargate/cluster-capacityprovider-name + * /cdk-ecs-fargate/cluster-securitygroup-id + * + * iam-role: + * /cdk-ecs-fargate/task-execution-role-arn + * /cdk-ecs-fargate/default-task-role-arn + * + */ +export declare const SSM_PREFIX = "/cdk-ecs-fargate"; +export declare const DEFAULT_STAGE = "dev"; +export interface StackCommonProps extends cdk.StackProps { + stage: string; +} diff --git a/ts.out/config.js b/ts.out/config.js new file mode 100644 index 0000000..75adcb3 --- /dev/null +++ b/ts.out/config.js @@ -0,0 +1,18 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.DEFAULT_STAGE = exports.SSM_PREFIX = void 0; +/** + * /cdk-ecs-fargate/vpc-id + * + * ecs-fargate-cluster: + * /cdk-ecs-fargate/cluster-capacityprovider-name + * /cdk-ecs-fargate/cluster-securitygroup-id + * + * iam-role: + * /cdk-ecs-fargate/task-execution-role-arn + * /cdk-ecs-fargate/default-task-role-arn + * + */ +exports.SSM_PREFIX = '/cdk-ecs-fargate'; +exports.DEFAULT_STAGE = 'dev'; +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBOzs7Ozs7Ozs7OztHQVdHO0FBQ1UsUUFBQSxVQUFVLEdBQUcsa0JBQWtCLENBQUM7QUFHaEMsUUFBQSxhQUFhLEdBQUcsS0FBSyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgY2RrIGZyb20gJ2F3cy1jZGstbGliJztcblxuLyoqXG4gKiAvY2RrLWVjcy1mYXJnYXRlL3ZwYy1pZFxuICogXG4gKiBlY3MtZmFyZ2F0ZS1jbHVzdGVyOlxuICogICAvY2RrLWVjcy1mYXJnYXRlL2NsdXN0ZXItY2FwYWNpdHlwcm92aWRlci1uYW1lXG4gKiAgIC9jZGstZWNzLWZhcmdhdGUvY2x1c3Rlci1zZWN1cml0eWdyb3VwLWlkXG4gKiBcbiAqIGlhbS1yb2xlOlxuICogICAvY2RrLWVjcy1mYXJnYXRlL3Rhc2stZXhlY3V0aW9uLXJvbGUtYXJuXG4gKiAgIC9jZGstZWNzLWZhcmdhdGUvZGVmYXVsdC10YXNrLXJvbGUtYXJuXG4gKiBcbiAqL1xuZXhwb3J0IGNvbnN0IFNTTV9QUkVGSVggPSAnL2Nkay1lY3MtZmFyZ2F0ZSc7XG5cblxuZXhwb3J0IGNvbnN0IERFRkFVTFRfU1RBR0UgPSAnZGV2JztcblxuZXhwb3J0IGludGVyZmFjZSBTdGFja0NvbW1vblByb3BzIGV4dGVuZHMgY2RrLlN0YWNrUHJvcHMge1xuICAgIHN0YWdlOiBzdHJpbmc7XG59Il19 \ No newline at end of file diff --git a/ts.out/ecr-codecommit/bin/index.d.ts b/ts.out/ecr-codecommit/bin/index.d.ts new file mode 100644 index 0000000..b798801 --- /dev/null +++ b/ts.out/ecr-codecommit/bin/index.d.ts @@ -0,0 +1,2 @@ +#!/usr/bin/env node +export {}; diff --git a/ts.out/ecr-codecommit/bin/index.js b/ts.out/ecr-codecommit/bin/index.js new file mode 100644 index 0000000..86d1cb0 --- /dev/null +++ b/ts.out/ecr-codecommit/bin/index.js @@ -0,0 +1,40 @@ +#!/usr/bin/env node +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const cdk = __importStar(require("aws-cdk-lib")); +const ecr_codecommit_stack_1 = require("../lib/ecr-codecommit-stack"); +const config_1 = require("../../config"); +const app = new cdk.App(); +const env = { + account: process.env.CDK_DEFAULT_ACCOUNT, + region: process.env.CDK_DEFAULT_REGION +}; +const stage = app.node.tryGetContext('stage') || config_1.DEFAULT_STAGE; +const serviceName = `fargate-restapi-${stage}`; +new ecr_codecommit_stack_1.EcrCodeCommitStack(app, `ecr-${serviceName}`, { + env, + stage, + serviceName, + description: `ECR: ${serviceName}`, + terminationProtection: stage !== config_1.DEFAULT_STAGE +}); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9lY3ItY29kZWNvbW1pdC9iaW4vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUNBLGlEQUFtQztBQUNuQyxzRUFBaUU7QUFDakUseUNBQTZDO0FBRTdDLE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO0FBQzFCLE1BQU0sR0FBRyxHQUFHO0lBQ1IsT0FBTyxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsbUJBQW1CO0lBQ3hDLE1BQU0sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQjtDQUN6QyxDQUFDO0FBQ0YsTUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLElBQUksc0JBQWEsQ0FBQztBQUMvRCxNQUFNLFdBQVcsR0FBRyxtQkFBbUIsS0FBSyxFQUFFLENBQUE7QUFFOUMsSUFBSSx5Q0FBa0IsQ0FBQyxHQUFHLEVBQUUsT0FBTyxXQUFXLEVBQUUsRUFBRTtJQUM5QyxHQUFHO0lBQ0gsS0FBSztJQUNMLFdBQVc7SUFDWCxXQUFXLEVBQUUsUUFBUSxXQUFXLEVBQUU7SUFDbEMscUJBQXFCLEVBQUUsS0FBSyxLQUFHLHNCQUFhO0NBQy9DLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIiMhL3Vzci9iaW4vZW52IG5vZGVcclxuaW1wb3J0ICogYXMgY2RrIGZyb20gJ2F3cy1jZGstbGliJztcclxuaW1wb3J0IHsgRWNyQ29kZUNvbW1pdFN0YWNrIH0gZnJvbSAnLi4vbGliL2Vjci1jb2RlY29tbWl0LXN0YWNrJztcclxuaW1wb3J0IHsgREVGQVVMVF9TVEFHRSB9IGZyb20gJy4uLy4uL2NvbmZpZyc7XHJcblxyXG5jb25zdCBhcHAgPSBuZXcgY2RrLkFwcCgpO1xyXG5jb25zdCBlbnYgPSB7XHJcbiAgICBhY2NvdW50OiBwcm9jZXNzLmVudi5DREtfREVGQVVMVF9BQ0NPVU5ULFxyXG4gICAgcmVnaW9uOiBwcm9jZXNzLmVudi5DREtfREVGQVVMVF9SRUdJT05cclxufTtcclxuY29uc3Qgc3RhZ2UgPSBhcHAubm9kZS50cnlHZXRDb250ZXh0KCdzdGFnZScpIHx8IERFRkFVTFRfU1RBR0U7XHJcbmNvbnN0IHNlcnZpY2VOYW1lID0gYGZhcmdhdGUtcmVzdGFwaS0ke3N0YWdlfWBcclxuXHJcbm5ldyBFY3JDb2RlQ29tbWl0U3RhY2soYXBwLCBgZWNyLSR7c2VydmljZU5hbWV9YCwge1xyXG4gICAgZW52LFxyXG4gICAgc3RhZ2UsXHJcbiAgICBzZXJ2aWNlTmFtZSxcclxuICAgIGRlc2NyaXB0aW9uOiBgRUNSOiAke3NlcnZpY2VOYW1lfWAsXHJcbiAgICB0ZXJtaW5hdGlvblByb3RlY3Rpb246IHN0YWdlIT09REVGQVVMVF9TVEFHRVxyXG59KTtcclxuIl19 \ No newline at end of file diff --git a/ts.out/ecr-codecommit/lib/ecr-codecommit-stack.d.ts b/ts.out/ecr-codecommit/lib/ecr-codecommit-stack.d.ts new file mode 100644 index 0000000..c120464 --- /dev/null +++ b/ts.out/ecr-codecommit/lib/ecr-codecommit-stack.d.ts @@ -0,0 +1,12 @@ +import { Construct } from 'constructs'; +import { Stack } from 'aws-cdk-lib'; +import { StackCommonProps } from '../../config'; +export interface EcrStackProps extends StackCommonProps { + serviceName: string; +} +/** + * Build 'app/Dockerfile' and push to ECR for X86 and ARM + */ +export declare class EcrCodeCommitStack extends Stack { + constructor(scope: Construct, id: string, props: EcrStackProps); +} diff --git a/ts.out/ecr-codecommit/lib/ecr-codecommit-stack.js b/ts.out/ecr-codecommit/lib/ecr-codecommit-stack.js new file mode 100644 index 0000000..4817230 --- /dev/null +++ b/ts.out/ecr-codecommit/lib/ecr-codecommit-stack.js @@ -0,0 +1,77 @@ +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.EcrCodeCommitStack = void 0; +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const path = __importStar(require("path")); +const codecommit = __importStar(require("aws-cdk-lib/aws-codecommit")); +const ssm = __importStar(require("aws-cdk-lib/aws-ssm")); +const ecr = __importStar(require("aws-cdk-lib/aws-ecr")); +const assets = __importStar(require("aws-cdk-lib/aws-ecr-assets")); +const ecrdeploy = __importStar(require("cdk-ecr-deployment")); +const config_1 = require("../../config"); +/** + * Build 'app/Dockerfile' and push to ECR for X86 and ARM + */ +class EcrCodeCommitStack extends aws_cdk_lib_1.Stack { + constructor(scope, id, props) { + super(scope, id, props); + const stage = props.stage; + const serviceName = props.serviceName; + const assetX86 = new assets.DockerImageAsset(this, 'ecr-image-x86', { + directory: path.join(__dirname, "../../", "app") + }); + const ecrRepo = new ecr.Repository(this, `${serviceName}`, { + repositoryName: `${serviceName}` + }); + new ecrdeploy.ECRDeployment(this, 'ecr-deploy-x86', { + src: new ecrdeploy.DockerImageName(assetX86.imageUri), + dest: new ecrdeploy.DockerImageName(`${ecrRepo.repositoryUriForTag('latest')}`), + }); + const assetArm = new assets.DockerImageAsset(this, 'ecr-image-arm', { + directory: path.join(__dirname, "../../", "app"), + platform: assets.Platform.LINUX_ARM64, + }); + const ecrArmRepo = new ecr.Repository(this, `${serviceName}-arm`, { + repositoryName: `${serviceName}-arm` + }); + new ecrdeploy.ECRDeployment(this, 'ecr-deploy-arm', { + src: new ecrdeploy.DockerImageName(assetArm.imageUri), + dest: new ecrdeploy.DockerImageName(`${ecrArmRepo.repositoryUriForTag('latest')}`), + }); + const codecommitRepo = new codecommit.Repository(this, `${serviceName}-codecommit`, { + repositoryName: `${serviceName}` + }); + aws_cdk_lib_1.Tags.of(codecommitRepo).add('Stage', stage); + aws_cdk_lib_1.Tags.of(ecrRepo).add('Stage', stage); + aws_cdk_lib_1.Tags.of(ecrArmRepo).add('Stage', stage); + new aws_cdk_lib_1.CfnOutput(this, 'URI', { value: ecrRepo.repositoryUri }); + new aws_cdk_lib_1.CfnOutput(this, 'URIARM', { value: ecrArmRepo.repositoryUri }); + new ssm.StringParameter(this, 'ssm-codecommit-arn', { parameterName: `${config_1.SSM_PREFIX}/codecommit-arn`, stringValue: codecommitRepo.repositoryArn }); + new ssm.StringParameter(this, 'ssm-ecr-repo-name', { parameterName: `${config_1.SSM_PREFIX}/ecr-repo-name`, stringValue: ecrRepo.repositoryName }); + new ssm.StringParameter(this, 'ssm-ecr-repo-arn', { parameterName: `${config_1.SSM_PREFIX}/ecr-repo-arn`, stringValue: ecrRepo.repositoryArn }); + new ssm.StringParameter(this, 'ssm-ecr-armrepo-name', { parameterName: `${config_1.SSM_PREFIX}/ecr-armrepo-name`, stringValue: ecrArmRepo.repositoryUri }); + new ssm.StringParameter(this, 'ssm-ecr-armrepo-arn', { parameterName: `${config_1.SSM_PREFIX}/ecr-armrepo-arn`, stringValue: ecrArmRepo.repositoryArn }); + new aws_cdk_lib_1.CfnOutput(this, 'CodeCommitRepoUrl', { value: codecommitRepo.repositoryCloneUrlHttp }); + } +} +exports.EcrCodeCommitStack = EcrCodeCommitStack; +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecr-codecommit-stack.js","sourceRoot":"","sources":["../../../ecr-codecommit/lib/ecr-codecommit-stack.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from 'constructs';\r\nimport { Stack, CfnOutput, Tags } from 'aws-cdk-lib';\r\nimport * as path from 'path';\r\nimport * as codecommit from 'aws-cdk-lib/aws-codecommit';\r\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\r\nimport * as ecr from 'aws-cdk-lib/aws-ecr';\r\nimport * as assets from 'aws-cdk-lib/aws-ecr-assets';\r\nimport * as ecrdeploy from 'cdk-ecr-deployment';\r\n\r\nimport { StackCommonProps, SSM_PREFIX } from '../../config';\r\n\r\nexport interface EcrStackProps extends StackCommonProps {\r\n    serviceName: string;\r\n}\r\n/**\r\n * Build 'app/Dockerfile' and push to ECR for X86 and ARM\r\n */\r\nexport class EcrCodeCommitStack extends Stack {\r\n    constructor(scope: Construct, id: string, props: EcrStackProps) {\r\n        super(scope, id, props);\r\n\r\n        const stage = props.stage;\r\n        const serviceName = props.serviceName;\r\n\r\n        const assetX86 = new assets.DockerImageAsset(this, 'ecr-image-x86', {\r\n            directory: path.join(__dirname, \"../../\", \"app\")\r\n        });\r\n        const ecrRepo = new ecr.Repository(this, `${serviceName}`, {\r\n            repositoryName: `${serviceName}`\r\n        });\r\n        new ecrdeploy.ECRDeployment(this, 'ecr-deploy-x86', {\r\n            src: new ecrdeploy.DockerImageName(assetX86.imageUri),\r\n            dest: new ecrdeploy.DockerImageName(`${ecrRepo.repositoryUriForTag('latest')}`),\r\n        });\r\n\r\n        const assetArm = new assets.DockerImageAsset(this, 'ecr-image-arm', {\r\n            directory: path.join(__dirname, \"../../\", \"app\"),\r\n            platform: assets.Platform.LINUX_ARM64,\r\n        });\r\n        const ecrArmRepo = new ecr.Repository(this, `${serviceName}-arm`, {\r\n            repositoryName: `${serviceName}-arm`\r\n        });\r\n        new ecrdeploy.ECRDeployment(this, 'ecr-deploy-arm', {\r\n            src: new ecrdeploy.DockerImageName(assetArm.imageUri),\r\n            dest: new ecrdeploy.DockerImageName(`${ecrArmRepo.repositoryUriForTag('latest')}`),\r\n        });\r\n\r\n        const codecommitRepo = new codecommit.Repository(this, `${serviceName}-codecommit`, {\r\n            repositoryName: `${serviceName}`\r\n        });\r\n\r\n        Tags.of(codecommitRepo).add('Stage', stage);\r\n        Tags.of(ecrRepo).add('Stage', stage);\r\n        Tags.of(ecrArmRepo).add('Stage', stage);\r\n\r\n        new CfnOutput(this, 'URI', { value: ecrRepo.repositoryUri });\r\n        new CfnOutput(this, 'URIARM', { value: ecrArmRepo.repositoryUri });\r\n\r\n        new ssm.StringParameter(this, 'ssm-codecommit-arn', { parameterName: `${SSM_PREFIX}/codecommit-arn`, stringValue: codecommitRepo.repositoryArn });\r\n\r\n        new ssm.StringParameter(this, 'ssm-ecr-repo-name', { parameterName: `${SSM_PREFIX}/ecr-repo-name`, stringValue: ecrRepo.repositoryName });\r\n        new ssm.StringParameter(this, 'ssm-ecr-repo-arn', { parameterName: `${SSM_PREFIX}/ecr-repo-arn`, stringValue: ecrRepo.repositoryArn });\r\n        new ssm.StringParameter(this, 'ssm-ecr-armrepo-name', { parameterName: `${SSM_PREFIX}/ecr-armrepo-name`, stringValue: ecrArmRepo.repositoryUri });\r\n        new ssm.StringParameter(this, 'ssm-ecr-armrepo-arn', { parameterName: `${SSM_PREFIX}/ecr-armrepo-arn`, stringValue: ecrArmRepo.repositoryArn });\r\n\r\n        new CfnOutput(this, 'CodeCommitRepoUrl', { value: codecommitRepo.repositoryCloneUrlHttp });\r\n    }\r\n}\r\n"]} \ No newline at end of file diff --git a/ts.out/ecs-fargate-cluster/bin/index.d.ts b/ts.out/ecs-fargate-cluster/bin/index.d.ts new file mode 100644 index 0000000..b798801 --- /dev/null +++ b/ts.out/ecs-fargate-cluster/bin/index.d.ts @@ -0,0 +1,2 @@ +#!/usr/bin/env node +export {}; diff --git a/ts.out/ecs-fargate-cluster/bin/index.js b/ts.out/ecs-fargate-cluster/bin/index.js new file mode 100644 index 0000000..f4eb09f --- /dev/null +++ b/ts.out/ecs-fargate-cluster/bin/index.js @@ -0,0 +1,39 @@ +#!/usr/bin/env node +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const cdk = __importStar(require("aws-cdk-lib")); +const config_1 = require("../../config"); +const cluster_config_1 = require("../lib/cluster-config"); +const ecs_fargate_cluster_stack_1 = require("../lib/ecs-fargate-cluster-stack"); +const app = new cdk.App(); +const env = { + account: process.env.CDK_DEFAULT_ACCOUNT, + region: process.env.CDK_DEFAULT_REGION, +}; +const stage = app.node.tryGetContext('stage') || config_1.DEFAULT_STAGE; +new ecs_fargate_cluster_stack_1.EcsFargateClusterStack(app, `ecs-fargate-cluster-${cluster_config_1.CLUSTER_NAME}-${stage}`, { + env, + stage, + description: `ECS Fargate cluster, cluster name: ${cluster_config_1.CLUSTER_NAME}-${stage}`, + terminationProtection: stage !== config_1.DEFAULT_STAGE +}); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9lY3MtZmFyZ2F0ZS1jbHVzdGVyL2Jpbi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQ0EsaURBQW1DO0FBRW5DLHlDQUE2QztBQUM3QywwREFBcUQ7QUFDckQsZ0ZBQTBFO0FBRTFFLE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO0FBQzFCLE1BQU0sR0FBRyxHQUFHO0lBQ1IsT0FBTyxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsbUJBQW1CO0lBQ3hDLE1BQU0sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQjtDQUN6QyxDQUFDO0FBQ0YsTUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLElBQUksc0JBQWEsQ0FBQztBQUUvRCxJQUFJLGtEQUFzQixDQUFDLEdBQUcsRUFBRSx1QkFBdUIsNkJBQVksSUFBSSxLQUFLLEVBQUUsRUFBRTtJQUM1RSxHQUFHO0lBQ0gsS0FBSztJQUNMLFdBQVcsRUFBRSxzQ0FBc0MsNkJBQVksSUFBSSxLQUFLLEVBQUU7SUFDMUUscUJBQXFCLEVBQUUsS0FBSyxLQUFHLHNCQUFhO0NBQy9DLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIiMhL3Vzci9iaW4vZW52IG5vZGVcbmltcG9ydCAqIGFzIGNkayBmcm9tICdhd3MtY2RrLWxpYic7XG5cbmltcG9ydCB7IERFRkFVTFRfU1RBR0UgfSBmcm9tICcuLi8uLi9jb25maWcnO1xuaW1wb3J0IHsgQ0xVU1RFUl9OQU1FIH0gZnJvbSAnLi4vbGliL2NsdXN0ZXItY29uZmlnJztcbmltcG9ydCB7IEVjc0ZhcmdhdGVDbHVzdGVyU3RhY2sgfSBmcm9tICcuLi9saWIvZWNzLWZhcmdhdGUtY2x1c3Rlci1zdGFjayc7XG5cbmNvbnN0IGFwcCA9IG5ldyBjZGsuQXBwKCk7XG5jb25zdCBlbnYgPSB7XG4gICAgYWNjb3VudDogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfQUNDT1VOVCxcbiAgICByZWdpb246IHByb2Nlc3MuZW52LkNES19ERUZBVUxUX1JFR0lPTixcbn07XG5jb25zdCBzdGFnZSA9IGFwcC5ub2RlLnRyeUdldENvbnRleHQoJ3N0YWdlJykgfHwgREVGQVVMVF9TVEFHRTtcblxubmV3IEVjc0ZhcmdhdGVDbHVzdGVyU3RhY2soYXBwLCBgZWNzLWZhcmdhdGUtY2x1c3Rlci0ke0NMVVNURVJfTkFNRX0tJHtzdGFnZX1gLCB7XG4gICAgZW52LFxuICAgIHN0YWdlLFxuICAgIGRlc2NyaXB0aW9uOiBgRUNTIEZhcmdhdGUgY2x1c3RlciwgY2x1c3RlciBuYW1lOiAke0NMVVNURVJfTkFNRX0tJHtzdGFnZX1gLFxuICAgIHRlcm1pbmF0aW9uUHJvdGVjdGlvbjogc3RhZ2UhPT1ERUZBVUxUX1NUQUdFXG59KTtcbiJdfQ== \ No newline at end of file diff --git a/ts.out/ecs-fargate-cluster/lib/cluster-config.d.ts b/ts.out/ecs-fargate-cluster/lib/cluster-config.d.ts new file mode 100644 index 0000000..b0ed70b --- /dev/null +++ b/ts.out/ecs-fargate-cluster/lib/cluster-config.d.ts @@ -0,0 +1,3 @@ +#!/usr/bin/env node +export declare const CLUSTER_NAME = "fargate"; +export declare const INSTANCE_TYPE = "c5.xlarge"; diff --git a/ts.out/ecs-fargate-cluster/lib/cluster-config.js b/ts.out/ecs-fargate-cluster/lib/cluster-config.js new file mode 100644 index 0000000..2400c9e --- /dev/null +++ b/ts.out/ecs-fargate-cluster/lib/cluster-config.js @@ -0,0 +1,7 @@ +#!/usr/bin/env node +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.INSTANCE_TYPE = exports.CLUSTER_NAME = void 0; +exports.CLUSTER_NAME = 'fargate'; +exports.INSTANCE_TYPE = 'c5.xlarge'; +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2x1c3Rlci1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9lY3MtZmFyZ2F0ZS1jbHVzdGVyL2xpYi9jbHVzdGVyLWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBRWEsUUFBQSxZQUFZLEdBQUcsU0FBUyxDQUFDO0FBRXpCLFFBQUEsYUFBYSxHQUFHLFdBQVcsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIiMhL3Vzci9iaW4vZW52IG5vZGVcblxuZXhwb3J0IGNvbnN0IENMVVNURVJfTkFNRSA9ICdmYXJnYXRlJztcblxuZXhwb3J0IGNvbnN0IElOU1RBTkNFX1RZUEUgPSAnYzUueGxhcmdlJztcbiJdfQ== \ No newline at end of file diff --git a/ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.d.ts b/ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.d.ts new file mode 100644 index 0000000..286570f --- /dev/null +++ b/ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.d.ts @@ -0,0 +1,9 @@ +import { Stack } from 'aws-cdk-lib'; +import { Construct } from 'constructs'; +import { StackCommonProps } from '../../config'; +/** + * Create ECS Fargate cluster and shared security group for ALB ingress + */ +export declare class EcsFargateClusterStack extends Stack { + constructor(scope: Construct, id: string, props: StackCommonProps); +} diff --git a/ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.js b/ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.js new file mode 100644 index 0000000..b1a0d53 --- /dev/null +++ b/ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.js @@ -0,0 +1,61 @@ +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.EcsFargateClusterStack = void 0; +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const ec2 = __importStar(require("aws-cdk-lib/aws-ec2")); +const ssm = __importStar(require("aws-cdk-lib/aws-ssm")); +const ecs = __importStar(require("aws-cdk-lib/aws-ecs")); +const cluster_config_1 = require("../lib/cluster-config"); +const config_1 = require("../../config"); +/** + * Create ECS Fargate cluster and shared security group for ALB ingress + */ +class EcsFargateClusterStack extends aws_cdk_lib_1.Stack { + constructor(scope, id, props) { + super(scope, id, props); + const vpcId = this.node.tryGetContext('vpcId') || ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/vpc-id`); + const vpc = ec2.Vpc.fromLookup(this, 'vpc', { vpcId }); + const clusterName = `${cluster_config_1.CLUSTER_NAME}-${props.stage}`; + const cluster = new ecs.Cluster(this, 'ecs-cluster', { + vpc, + clusterName, + containerInsights: true, + }); + const securityGroupName = `ecssg-${clusterName}`; + const ecsSecurityGroup = new ec2.SecurityGroup(this, 'ecs-security-group', { + vpc, + securityGroupName, + description: `ECS Fargate shared security group for ALB ingress, cluster: ${cluster}`, + }); + aws_cdk_lib_1.Tags.of(ecsSecurityGroup).add('Stage', props.stage); + aws_cdk_lib_1.Tags.of(ecsSecurityGroup).add('Name', securityGroupName); + new aws_cdk_lib_1.CfnOutput(this, 'Cluster', { value: cluster.clusterName }); + new aws_cdk_lib_1.CfnOutput(this, 'ECS Security Group ID', { value: ecsSecurityGroup.securityGroupId }); + // cluster-name and cluster-arn is used for deployment pipeline + new ssm.StringParameter(this, 'ssm-cluster-name', { parameterName: `${config_1.SSM_PREFIX}/cluster-name`, stringValue: cluster.clusterName }); + new ssm.StringParameter(this, 'ssm-cluster-arn', { parameterName: `${config_1.SSM_PREFIX}/cluster-arn`, stringValue: cluster.clusterArn }); + // cluster-securitygroup-id is used to add inboud from ALB to Fargate service + new ssm.StringParameter(this, 'ssm-cluster-securitygroup-id', { parameterName: `${config_1.SSM_PREFIX}/cluster-securitygroup-id`, stringValue: ecsSecurityGroup.securityGroupId }); + } +} +exports.EcsFargateClusterStack = EcsFargateClusterStack; +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNzLWZhcmdhdGUtY2x1c3Rlci1zdGFjay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2Vjcy1mYXJnYXRlLWNsdXN0ZXIvbGliL2Vjcy1mYXJnYXRlLWNsdXN0ZXItc3RhY2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDZDQUFxRDtBQUNyRCx5REFBMkM7QUFDM0MseURBQTJDO0FBQzNDLHlEQUEyQztBQUczQywwREFBcUQ7QUFDckQseUNBQTREO0FBRTVEOztHQUVHO0FBQ0gsTUFBYSxzQkFBdUIsU0FBUSxtQkFBSztJQUM3QyxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQXVCO1FBQzdELEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBRXhCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEdBQUcsQ0FBQyxlQUFlLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSxHQUFHLG1CQUFVLFNBQVMsQ0FBQyxDQUFDO1FBQ3BILE1BQU0sR0FBRyxHQUFHLEdBQUcsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO1FBRXZELE1BQU0sV0FBVyxHQUFHLEdBQUcsNkJBQVksSUFBSSxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDckQsTUFBTSxPQUFPLEdBQUcsSUFBSSxHQUFHLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxhQUFhLEVBQUU7WUFDakQsR0FBRztZQUNILFdBQVc7WUFDWCxpQkFBaUIsRUFBRSxJQUFJO1NBQzFCLENBQUMsQ0FBQztRQUVILE1BQU0saUJBQWlCLEdBQUcsU0FBUyxXQUFXLEVBQUUsQ0FBQztRQUNqRCxNQUFNLGdCQUFnQixHQUFHLElBQUksR0FBRyxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsb0JBQW9CLEVBQUU7WUFDdkUsR0FBRztZQUNILGlCQUFpQjtZQUNqQixXQUFXLEVBQUUsK0RBQStELE9BQU8sRUFBRTtTQUN4RixDQUFDLENBQUM7UUFDSCxrQkFBSSxDQUFDLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3BELGtCQUFJLENBQUMsRUFBRSxDQUFDLGdCQUFnQixDQUFDLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO1FBRXpELElBQUksdUJBQVMsQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFLEVBQUUsS0FBSyxFQUFFLE9BQU8sQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1FBQy9ELElBQUksdUJBQVMsQ0FBQyxJQUFJLEVBQUUsdUJBQXVCLEVBQUUsRUFBQyxLQUFLLEVBQUUsZ0JBQWdCLENBQUMsZUFBZSxFQUFDLENBQUMsQ0FBQztRQUV4RiwrREFBK0Q7UUFDL0QsSUFBSSxHQUFHLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSxrQkFBa0IsRUFBRSxFQUFFLGFBQWEsRUFBRSxHQUFHLG1CQUFVLGVBQWUsRUFBRSxXQUFXLEVBQUUsT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7UUFDckksSUFBSSxHQUFHLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSxpQkFBaUIsRUFBRSxFQUFFLGFBQWEsRUFBRSxHQUFHLG1CQUFVLGNBQWMsRUFBRSxXQUFXLEVBQUUsT0FBTyxDQUFDLFVBQVUsRUFBRSxDQUFDLENBQUM7UUFFbEksNkVBQTZFO1FBQzdFLElBQUksR0FBRyxDQUFDLGVBQWUsQ0FBQyxJQUFJLEVBQUUsOEJBQThCLEVBQUUsRUFBRSxhQUFhLEVBQUUsR0FBRyxtQkFBVSwyQkFBMkIsRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLENBQUMsZUFBZSxFQUFFLENBQUMsQ0FBQztJQUM5SyxDQUFDO0NBQ0o7QUFqQ0Qsd0RBaUNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3RhY2ssIENmbk91dHB1dCwgVGFncyB9IGZyb20gJ2F3cy1jZGstbGliJztcclxuaW1wb3J0ICogYXMgZWMyIGZyb20gJ2F3cy1jZGstbGliL2F3cy1lYzInO1xyXG5pbXBvcnQgKiBhcyBzc20gZnJvbSAnYXdzLWNkay1saWIvYXdzLXNzbSc7XHJcbmltcG9ydCAqIGFzIGVjcyBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWNzJztcclxuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnY29uc3RydWN0cyc7XHJcblxyXG5pbXBvcnQgeyBDTFVTVEVSX05BTUUgfSBmcm9tICcuLi9saWIvY2x1c3Rlci1jb25maWcnO1xyXG5pbXBvcnQgeyBTdGFja0NvbW1vblByb3BzLCBTU01fUFJFRklYIH0gZnJvbSAnLi4vLi4vY29uZmlnJztcclxuXHJcbi8qKlxyXG4gKiBDcmVhdGUgRUNTIEZhcmdhdGUgY2x1c3RlciBhbmQgc2hhcmVkIHNlY3VyaXR5IGdyb3VwIGZvciBBTEIgaW5ncmVzc1xyXG4gKi9cclxuZXhwb3J0IGNsYXNzIEVjc0ZhcmdhdGVDbHVzdGVyU3RhY2sgZXh0ZW5kcyBTdGFjayB7XHJcbiAgICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogU3RhY2tDb21tb25Qcm9wcykge1xyXG4gICAgICAgIHN1cGVyKHNjb3BlLCBpZCwgcHJvcHMpO1xyXG5cclxuICAgICAgICBjb25zdCB2cGNJZCA9IHRoaXMubm9kZS50cnlHZXRDb250ZXh0KCd2cGNJZCcpIHx8IHNzbS5TdHJpbmdQYXJhbWV0ZXIudmFsdWVGcm9tTG9va3VwKHRoaXMsIGAke1NTTV9QUkVGSVh9L3ZwYy1pZGApO1xyXG4gICAgICAgIGNvbnN0IHZwYyA9IGVjMi5WcGMuZnJvbUxvb2t1cCh0aGlzLCAndnBjJywgeyB2cGNJZCB9KTtcclxuXHJcbiAgICAgICAgY29uc3QgY2x1c3Rlck5hbWUgPSBgJHtDTFVTVEVSX05BTUV9LSR7cHJvcHMuc3RhZ2V9YDtcclxuICAgICAgICBjb25zdCBjbHVzdGVyID0gbmV3IGVjcy5DbHVzdGVyKHRoaXMsICdlY3MtY2x1c3RlcicsIHtcclxuICAgICAgICAgICAgdnBjLFxyXG4gICAgICAgICAgICBjbHVzdGVyTmFtZSxcclxuICAgICAgICAgICAgY29udGFpbmVySW5zaWdodHM6IHRydWUsXHJcbiAgICAgICAgfSk7XHJcblxyXG4gICAgICAgIGNvbnN0IHNlY3VyaXR5R3JvdXBOYW1lID0gYGVjc3NnLSR7Y2x1c3Rlck5hbWV9YDtcclxuICAgICAgICBjb25zdCBlY3NTZWN1cml0eUdyb3VwID0gbmV3IGVjMi5TZWN1cml0eUdyb3VwKHRoaXMsICdlY3Mtc2VjdXJpdHktZ3JvdXAnLCB7XHJcbiAgICAgICAgICAgIHZwYyxcclxuICAgICAgICAgICAgc2VjdXJpdHlHcm91cE5hbWUsXHJcbiAgICAgICAgICAgIGRlc2NyaXB0aW9uOiBgRUNTIEZhcmdhdGUgc2hhcmVkIHNlY3VyaXR5IGdyb3VwIGZvciBBTEIgaW5ncmVzcywgY2x1c3RlcjogJHtjbHVzdGVyfWAsXHJcbiAgICAgICAgfSk7XHJcbiAgICAgICAgVGFncy5vZihlY3NTZWN1cml0eUdyb3VwKS5hZGQoJ1N0YWdlJywgcHJvcHMuc3RhZ2UpO1xyXG4gICAgICAgIFRhZ3Mub2YoZWNzU2VjdXJpdHlHcm91cCkuYWRkKCdOYW1lJywgc2VjdXJpdHlHcm91cE5hbWUpO1xyXG4gICAgICAgIFxyXG4gICAgICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ0NsdXN0ZXInLCB7IHZhbHVlOiBjbHVzdGVyLmNsdXN0ZXJOYW1lIH0pO1xyXG4gICAgICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ0VDUyBTZWN1cml0eSBHcm91cCBJRCcsIHt2YWx1ZTogZWNzU2VjdXJpdHlHcm91cC5zZWN1cml0eUdyb3VwSWR9KTtcclxuXHJcbiAgICAgICAgLy8gY2x1c3Rlci1uYW1lIGFuZCBjbHVzdGVyLWFybiBpcyB1c2VkIGZvciBkZXBsb3ltZW50IHBpcGVsaW5lXHJcbiAgICAgICAgbmV3IHNzbS5TdHJpbmdQYXJhbWV0ZXIodGhpcywgJ3NzbS1jbHVzdGVyLW5hbWUnLCB7IHBhcmFtZXRlck5hbWU6IGAke1NTTV9QUkVGSVh9L2NsdXN0ZXItbmFtZWAsIHN0cmluZ1ZhbHVlOiBjbHVzdGVyLmNsdXN0ZXJOYW1lIH0pO1xyXG4gICAgICAgIG5ldyBzc20uU3RyaW5nUGFyYW1ldGVyKHRoaXMsICdzc20tY2x1c3Rlci1hcm4nLCB7IHBhcmFtZXRlck5hbWU6IGAke1NTTV9QUkVGSVh9L2NsdXN0ZXItYXJuYCwgc3RyaW5nVmFsdWU6IGNsdXN0ZXIuY2x1c3RlckFybiB9KTtcclxuXHJcbiAgICAgICAgLy8gY2x1c3Rlci1zZWN1cml0eWdyb3VwLWlkIGlzIHVzZWQgdG8gYWRkIGluYm91ZCBmcm9tIEFMQiB0byBGYXJnYXRlIHNlcnZpY2VcclxuICAgICAgICBuZXcgc3NtLlN0cmluZ1BhcmFtZXRlcih0aGlzLCAnc3NtLWNsdXN0ZXItc2VjdXJpdHlncm91cC1pZCcsIHsgcGFyYW1ldGVyTmFtZTogYCR7U1NNX1BSRUZJWH0vY2x1c3Rlci1zZWN1cml0eWdyb3VwLWlkYCwgc3RyaW5nVmFsdWU6IGVjc1NlY3VyaXR5R3JvdXAuc2VjdXJpdHlHcm91cElkIH0pO1xyXG4gICAgfVxyXG59XHJcbiJdfQ== \ No newline at end of file diff --git a/ts.out/ecs-fargate-service-restapi/bin/index.d.ts b/ts.out/ecs-fargate-service-restapi/bin/index.d.ts new file mode 100644 index 0000000..b798801 --- /dev/null +++ b/ts.out/ecs-fargate-service-restapi/bin/index.d.ts @@ -0,0 +1,2 @@ +#!/usr/bin/env node +export {}; diff --git a/ts.out/ecs-fargate-service-restapi/bin/index.js b/ts.out/ecs-fargate-service-restapi/bin/index.js new file mode 100644 index 0000000..f723788 --- /dev/null +++ b/ts.out/ecs-fargate-service-restapi/bin/index.js @@ -0,0 +1,38 @@ +#!/usr/bin/env node +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const cdk = __importStar(require("aws-cdk-lib")); +const config_1 = require("../../config"); +const ecs_fargate_service_restapi_stack_1 = require("../lib/ecs-fargate-service-restapi-stack"); +const app = new cdk.App(); +const env = { + account: process.env.CDK_DEFAULT_ACCOUNT, + region: process.env.CDK_DEFAULT_REGION +}; +const stage = app.node.tryGetContext('stage') || config_1.DEFAULT_STAGE; +new ecs_fargate_service_restapi_stack_1.FargateRestAPIServiceStack(app, `ecs-fargate-service-restapi-${stage}`, { + env, + stage, + description: 'ECS Fargate service for RESTful API with ALB', + terminationProtection: stage !== config_1.DEFAULT_STAGE +}); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9lY3MtZmFyZ2F0ZS1zZXJ2aWNlLXJlc3RhcGkvYmluL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFDQSxpREFBbUM7QUFDbkMseUNBQTZDO0FBQzdDLGdHQUFzRjtBQUV0RixNQUFNLEdBQUcsR0FBRyxJQUFJLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQztBQUMxQixNQUFNLEdBQUcsR0FBRztJQUNSLE9BQU8sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLG1CQUFtQjtJQUN4QyxNQUFNLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxrQkFBa0I7Q0FDekMsQ0FBQztBQUNGLE1BQU0sS0FBSyxHQUFHLEdBQUcsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxJQUFJLHNCQUFhLENBQUM7QUFFL0QsSUFBSSw4REFBMEIsQ0FBQyxHQUFHLEVBQUUsK0JBQStCLEtBQUssRUFBRSxFQUFFO0lBQ3hFLEdBQUc7SUFDSCxLQUFLO0lBQ0wsV0FBVyxFQUFFLDhDQUE4QztJQUMzRCxxQkFBcUIsRUFBRSxLQUFLLEtBQUcsc0JBQWE7Q0FDL0MsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiIyEvdXNyL2Jpbi9lbnYgbm9kZVxyXG5pbXBvcnQgKiBhcyBjZGsgZnJvbSAnYXdzLWNkay1saWInO1xyXG5pbXBvcnQgeyBERUZBVUxUX1NUQUdFIH0gZnJvbSAnLi4vLi4vY29uZmlnJztcclxuaW1wb3J0IHsgRmFyZ2F0ZVJlc3RBUElTZXJ2aWNlU3RhY2sgfSBmcm9tICcuLi9saWIvZWNzLWZhcmdhdGUtc2VydmljZS1yZXN0YXBpLXN0YWNrJztcclxuXHJcbmNvbnN0IGFwcCA9IG5ldyBjZGsuQXBwKCk7XHJcbmNvbnN0IGVudiA9IHtcclxuICAgIGFjY291bnQ6IHByb2Nlc3MuZW52LkNES19ERUZBVUxUX0FDQ09VTlQsXHJcbiAgICByZWdpb246IHByb2Nlc3MuZW52LkNES19ERUZBVUxUX1JFR0lPTlxyXG59O1xyXG5jb25zdCBzdGFnZSA9IGFwcC5ub2RlLnRyeUdldENvbnRleHQoJ3N0YWdlJykgfHwgREVGQVVMVF9TVEFHRTtcclxuXHJcbm5ldyBGYXJnYXRlUmVzdEFQSVNlcnZpY2VTdGFjayhhcHAsIGBlY3MtZmFyZ2F0ZS1zZXJ2aWNlLXJlc3RhcGktJHtzdGFnZX1gLCB7XHJcbiAgICBlbnYsXHJcbiAgICBzdGFnZSxcclxuICAgIGRlc2NyaXB0aW9uOiAnRUNTIEZhcmdhdGUgc2VydmljZSBmb3IgUkVTVGZ1bCBBUEkgd2l0aCBBTEInLFxyXG4gICAgdGVybWluYXRpb25Qcm90ZWN0aW9uOiBzdGFnZSE9PURFRkFVTFRfU1RBR0VcclxufSk7XHJcbiJdfQ== \ No newline at end of file diff --git a/ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.d.ts b/ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.d.ts new file mode 100644 index 0000000..772da03 --- /dev/null +++ b/ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.d.ts @@ -0,0 +1,10 @@ +import { Construct } from 'constructs'; +import { Stack } from 'aws-cdk-lib'; +import { StackCommonProps } from '../../config'; +/** + * Crearte Fargate Service, Auto Scaling, ALB, and Log Group. + * Set the ALB options for the production-level. + */ +export declare class FargateRestAPIServiceStack extends Stack { + constructor(scope: Construct, id: string, props: StackCommonProps); +} diff --git a/ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.js b/ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.js new file mode 100644 index 0000000..9dabdad --- /dev/null +++ b/ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.js @@ -0,0 +1,142 @@ +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.FargateRestAPIServiceStack = void 0; +const cdk = __importStar(require("aws-cdk-lib")); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const ecs = __importStar(require("aws-cdk-lib/aws-ecs")); +const ec2 = __importStar(require("aws-cdk-lib/aws-ec2")); +const elbv2 = __importStar(require("aws-cdk-lib/aws-elasticloadbalancingv2")); +const logs = __importStar(require("aws-cdk-lib/aws-logs")); +const iam = __importStar(require("aws-cdk-lib/aws-iam")); +const ssm = __importStar(require("aws-cdk-lib/aws-ssm")); +const cluster_config_1 = require("../../ecs-fargate-cluster/lib/cluster-config"); +const config_1 = require("../../config"); +/** + * Crearte Fargate Service, Auto Scaling, ALB, and Log Group. + * Set the ALB options for the production-level. + */ +class FargateRestAPIServiceStack extends aws_cdk_lib_1.Stack { + constructor(scope, id, props) { + var _a, _b; + super(scope, id, props); + const vpcId = this.node.tryGetContext('vpcId') || ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/vpc-id`); + const vpc = ec2.Vpc.fromLookup(this, 'vpc', { vpcId }); + const clusterSgId = ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/cluster-securitygroup-id`); + const ecsSecurityGroup = ec2.SecurityGroup.fromSecurityGroupId(this, 'ecs-security-group', clusterSgId); + const cluster = ecs.Cluster.fromClusterAttributes(this, 'ecs-fargate-cluster', { + clusterName: `${cluster_config_1.CLUSTER_NAME}-${props.stage}`, + vpc, + securityGroups: [ecsSecurityGroup] + }); + const serviceName = 'fargate-restapi'; + const containerName = `${serviceName}-container`; + const applicationPort = 8080; + const executionRoleArn = ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/task-execution-role-arn`); + const taskRoleArn = ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/default-task-role-arn`); + const taskDefinition = new ecs.TaskDefinition(this, 'fargate-task-definition', { + cpu: '1024', + memoryMiB: '2048', + compatibility: ecs.Compatibility.FARGATE, + family: `${serviceName}-task`, + executionRole: iam.Role.fromRoleArn(this, 'task-execution-role', cdk.Lazy.string({ produce: () => executionRoleArn })), + taskRole: iam.Role.fromRoleArn(this, 'task-role', cdk.Lazy.string({ produce: () => taskRoleArn })) + }); + const regUrl = `${(_a = props.env) === null || _a === void 0 ? void 0 : _a.account}.dkr.ecr.${(_b = props.env) === null || _b === void 0 ? void 0 : _b.region}.amazonaws.com/fargate-restapi-${props.stage}:latest`; + const container = taskDefinition.addContainer('container-restapi', { + containerName, + image: ecs.ContainerImage.fromRegistry(regUrl), + // or build with /app folder asset + // import * as path from 'path'; + // image: ecs.ContainerImage.fromAsset(path.join(__dirname, "../../", "app")), + cpu: 1024, + memoryReservationMiB: 2048 + }); + container.addPortMappings({ containerPort: applicationPort, hostPort: applicationPort }); + const fargateservice = new ecs.FargateService(this, 'ecs-fargate-service', { + cluster, + serviceName: `${serviceName}-${props.stage}`, + taskDefinition, + enableExecuteCommand: true, + minHealthyPercent: 100, + maxHealthyPercent: 200, + healthCheckGracePeriod: aws_cdk_lib_1.Duration.seconds(0) // set the value as your application initialize time + }); + fargateservice.autoScaleTaskCount({ + minCapacity: 2, + maxCapacity: 100, + }).scaleOnCpuUtilization('cpuscaling', { + targetUtilizationPercent: 50, + scaleOutCooldown: aws_cdk_lib_1.Duration.seconds(60), + scaleInCooldown: aws_cdk_lib_1.Duration.seconds(120) + }); + const logGroup = new logs.LogGroup(this, 'loggroup', { + logGroupName: serviceName, + removalPolicy: cdk.RemovalPolicy.DESTROY, + retention: logs.RetentionDays.TWO_WEEKS, + }); + const albSecurityGroupName = `albsg-${serviceName}`; + const albSecurityGroup = new ec2.SecurityGroup(this, albSecurityGroupName, { + securityGroupName: albSecurityGroupName, + vpc, + allowAllOutbound: true, + description: `ALB security group for ${serviceName} Service` + }); + ecsSecurityGroup.addIngressRule(albSecurityGroup, ec2.Port.tcp(applicationPort), 'Allow from ALB'); + albSecurityGroup.addIngressRule(ec2.Peer.anyIpv4(), ec2.Port.tcp(80), 'Allow any'); + const alb = new elbv2.ApplicationLoadBalancer(this, 'alb', { + securityGroup: albSecurityGroup, + vpc, + loadBalancerName: `alb-${serviceName}`, + internetFacing: true, + deletionProtection: false, + idleTimeout: cdk.Duration.seconds(30), + }); + alb.addListener('https-listener', { + protocol: elbv2.ApplicationProtocol.HTTP, + open: false, + }).addTargets('ec2-service-target', { + targetGroupName: `tg-${serviceName}`, + port: applicationPort, + protocol: elbv2.ApplicationProtocol.HTTP, + targets: [fargateservice.loadBalancerTarget({ + containerName: containerName, + containerPort: applicationPort, + })], + healthCheck: { + healthyThresholdCount: 2, + unhealthyThresholdCount: 5, + interval: aws_cdk_lib_1.Duration.seconds(31), + path: '/ping', + timeout: aws_cdk_lib_1.Duration.seconds(30), + }, + deregistrationDelay: aws_cdk_lib_1.Duration.seconds(15) + }); + aws_cdk_lib_1.Tags.of(albSecurityGroup).add('Stage', props.stage); + aws_cdk_lib_1.Tags.of(albSecurityGroup).add('Name', albSecurityGroupName); + new aws_cdk_lib_1.CfnOutput(this, 'Service', { value: fargateservice.serviceArn }); + new aws_cdk_lib_1.CfnOutput(this, 'TaskDefinition', { value: taskDefinition.family }); + new aws_cdk_lib_1.CfnOutput(this, 'LogGroup', { value: logGroup.logGroupName }); + new aws_cdk_lib_1.CfnOutput(this, 'ALB', { value: alb.loadBalancerDnsName }); + } +} +exports.FargateRestAPIServiceStack = FargateRestAPIServiceStack; +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecs-fargate-service-restapi-stack.js","sourceRoot":"","sources":["../../../ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from 'constructs';\r\nimport * as cdk from 'aws-cdk-lib';\r\nimport { Stack, CfnOutput, Duration, Tags } from 'aws-cdk-lib';\r\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\r\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\r\nimport * as elbv2 from 'aws-cdk-lib/aws-elasticloadbalancingv2';\r\nimport * as logs from 'aws-cdk-lib/aws-logs';\r\nimport * as iam from 'aws-cdk-lib/aws-iam';\r\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\r\n\r\nimport { CLUSTER_NAME } from '../../ecs-fargate-cluster/lib/cluster-config';\r\nimport { StackCommonProps, SSM_PREFIX } from '../../config';\r\n\r\n/**\r\n * Crearte Fargate Service, Auto Scaling, ALB, and Log Group.\r\n * Set the ALB options for the production-level.\r\n */\r\nexport class FargateRestAPIServiceStack extends Stack {\r\n    constructor(scope: Construct, id: string, props: StackCommonProps) {\r\n        super(scope, id, props);\r\n\r\n        const vpcId = this.node.tryGetContext('vpcId') || ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/vpc-id`);\r\n        const vpc = ec2.Vpc.fromLookup(this, 'vpc', { vpcId });\r\n        const clusterSgId = ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/cluster-securitygroup-id`);\r\n        const ecsSecurityGroup = ec2.SecurityGroup.fromSecurityGroupId(this, 'ecs-security-group', clusterSgId);\r\n\r\n        const cluster = ecs.Cluster.fromClusterAttributes(this, 'ecs-fargate-cluster', {\r\n            clusterName: `${CLUSTER_NAME}-${props.stage}`,\r\n            vpc,\r\n            securityGroups: [ecsSecurityGroup]\r\n        });\r\n        const serviceName = 'fargate-restapi'\r\n        const containerName = `${serviceName}-container`\r\n        const applicationPort = 8080;\r\n\r\n        const executionRoleArn = ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/task-execution-role-arn`);\r\n        const taskRoleArn = ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/default-task-role-arn`);\r\n\r\n        const taskDefinition = new ecs.TaskDefinition(this, 'fargate-task-definition', {\r\n            cpu: '1024',\r\n            memoryMiB: '2048',\r\n            compatibility: ecs.Compatibility.FARGATE,\r\n            family: `${serviceName}-task`,\r\n            executionRole: iam.Role.fromRoleArn(this, 'task-execution-role', cdk.Lazy.string({ produce: () => executionRoleArn })),\r\n            taskRole: iam.Role.fromRoleArn(this, 'task-role', cdk.Lazy.string({ produce: () => taskRoleArn }))\r\n        });\r\n        \r\n        const regUrl = `${props.env?.account}.dkr.ecr.${props.env?.region}.amazonaws.com/fargate-restapi-${props.stage}:latest`;\r\n        const container = taskDefinition.addContainer('container-restapi', {\r\n            containerName,\r\n            image: ecs.ContainerImage.fromRegistry(regUrl),\r\n            // or build with /app folder asset\r\n            // import * as path from 'path';\r\n            // image: ecs.ContainerImage.fromAsset(path.join(__dirname, \"../../\", \"app\")),\r\n            cpu: 1024,\r\n            memoryReservationMiB: 2048\r\n        });\r\n        container.addPortMappings({ containerPort: applicationPort, hostPort: applicationPort });\r\n\r\n        const fargateservice = new ecs.FargateService(this, 'ecs-fargate-service', {\r\n            cluster,\r\n            serviceName: `${serviceName}-${props.stage}`,\r\n            taskDefinition,\r\n            enableExecuteCommand: true,\r\n            minHealthyPercent: 100,\r\n            maxHealthyPercent: 200,\r\n            healthCheckGracePeriod: Duration.seconds(0) // set the value as your application initialize time \r\n        });\r\n        fargateservice.autoScaleTaskCount({\r\n            minCapacity: 2,\r\n            maxCapacity: 100,\r\n        }).scaleOnCpuUtilization('cpuscaling', {\r\n            targetUtilizationPercent: 50,\r\n            scaleOutCooldown: Duration.seconds(60),\r\n            scaleInCooldown: Duration.seconds(120)\r\n        });\r\n\r\n        const logGroup = new logs.LogGroup(this, 'loggroup', {\r\n            logGroupName: serviceName,\r\n            removalPolicy: cdk.RemovalPolicy.DESTROY,\r\n            retention: logs.RetentionDays.TWO_WEEKS,\r\n        });\r\n\r\n        const albSecurityGroupName = `albsg-${serviceName}`\r\n        const albSecurityGroup = new ec2.SecurityGroup(this, albSecurityGroupName, {\r\n            securityGroupName: albSecurityGroupName,\r\n            vpc,\r\n            allowAllOutbound: true,\r\n            description: `ALB security group for ${serviceName} Service`\r\n        });\r\n        ecsSecurityGroup.addIngressRule(albSecurityGroup, ec2.Port.tcp(applicationPort), 'Allow from ALB');\r\n        albSecurityGroup.addIngressRule(ec2.Peer.anyIpv4(), ec2.Port.tcp(80), 'Allow any');\r\n\r\n        const alb = new elbv2.ApplicationLoadBalancer(this, 'alb', {\r\n            securityGroup: albSecurityGroup,\r\n            vpc,\r\n            loadBalancerName: `alb-${serviceName}`,\r\n            internetFacing: true,\r\n            deletionProtection: false,\r\n            idleTimeout: cdk.Duration.seconds(30),\r\n        });\r\n        alb.addListener('https-listener', {\r\n            protocol: elbv2.ApplicationProtocol.HTTP,\r\n            open: false,\r\n        }).addTargets('ec2-service-target', {\r\n            targetGroupName: `tg-${serviceName}`,\r\n            port: applicationPort,\r\n            protocol: elbv2.ApplicationProtocol.HTTP,\r\n            targets: [fargateservice.loadBalancerTarget({\r\n                containerName: containerName,\r\n                containerPort: applicationPort,\r\n            })],\r\n            healthCheck: {\r\n                healthyThresholdCount: 2,\r\n                unhealthyThresholdCount: 5,\r\n                interval: Duration.seconds(31),\r\n                path: '/ping',\r\n                timeout: Duration.seconds(30),\r\n            },\r\n            deregistrationDelay: Duration.seconds(15)\r\n        });\r\n\r\n        Tags.of(albSecurityGroup).add('Stage', props.stage);\r\n        Tags.of(albSecurityGroup).add('Name', albSecurityGroupName);\r\n\r\n        new CfnOutput(this, 'Service', { value: fargateservice.serviceArn });\r\n        new CfnOutput(this, 'TaskDefinition', { value: taskDefinition.family });\r\n        new CfnOutput(this, 'LogGroup', { value: logGroup.logGroupName });\r\n        new CfnOutput(this, 'ALB', { value: alb.loadBalancerDnsName });\r\n    }\r\n}\r\n"]} \ No newline at end of file diff --git a/ts.out/ecs-fargatespot-service-restapi/bin/index.d.ts b/ts.out/ecs-fargatespot-service-restapi/bin/index.d.ts new file mode 100644 index 0000000..b798801 --- /dev/null +++ b/ts.out/ecs-fargatespot-service-restapi/bin/index.d.ts @@ -0,0 +1,2 @@ +#!/usr/bin/env node +export {}; diff --git a/ts.out/ecs-fargatespot-service-restapi/bin/index.js b/ts.out/ecs-fargatespot-service-restapi/bin/index.js new file mode 100644 index 0000000..cf46341 --- /dev/null +++ b/ts.out/ecs-fargatespot-service-restapi/bin/index.js @@ -0,0 +1,38 @@ +#!/usr/bin/env node +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const cdk = __importStar(require("aws-cdk-lib")); +const config_1 = require("../../config"); +const ecs_fargatespot_service_restapi_stack_1 = require("../lib/ecs-fargatespot-service-restapi-stack"); +const app = new cdk.App(); +const env = { + account: process.env.CDK_DEFAULT_ACCOUNT, + region: process.env.CDK_DEFAULT_REGION +}; +const stage = app.node.tryGetContext('stage') || config_1.DEFAULT_STAGE; +new ecs_fargatespot_service_restapi_stack_1.FargateSpotRestAPIServiceStack(app, `ecs-fargatespot-service-restapi-${stage}`, { + env, + stage, + description: 'ECS Fargate service for RESTful API with Spot CapacityProvider and ALB', + terminationProtection: stage != config_1.DEFAULT_STAGE +}); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9lY3MtZmFyZ2F0ZXNwb3Qtc2VydmljZS1yZXN0YXBpL2Jpbi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQ0EsaURBQW1DO0FBQ25DLHlDQUE2QztBQUM3Qyx3R0FBOEY7QUFFOUYsTUFBTSxHQUFHLEdBQUcsSUFBSSxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUM7QUFDMUIsTUFBTSxHQUFHLEdBQUc7SUFDUixPQUFPLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxtQkFBbUI7SUFDeEMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCO0NBQ3pDLENBQUM7QUFDRixNQUFNLEtBQUssR0FBRyxHQUFHLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsSUFBSSxzQkFBYSxDQUFDO0FBRS9ELElBQUksc0VBQThCLENBQUMsR0FBRyxFQUFFLG1DQUFtQyxLQUFLLEVBQUUsRUFBRTtJQUNoRixHQUFHO0lBQ0gsS0FBSztJQUNMLFdBQVcsRUFBRSx3RUFBd0U7SUFDckYscUJBQXFCLEVBQUUsS0FBSyxJQUFFLHNCQUFhO0NBQzlDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIiMhL3Vzci9iaW4vZW52IG5vZGVcclxuaW1wb3J0ICogYXMgY2RrIGZyb20gJ2F3cy1jZGstbGliJztcclxuaW1wb3J0IHsgREVGQVVMVF9TVEFHRSB9IGZyb20gJy4uLy4uL2NvbmZpZyc7XHJcbmltcG9ydCB7IEZhcmdhdGVTcG90UmVzdEFQSVNlcnZpY2VTdGFjayB9IGZyb20gJy4uL2xpYi9lY3MtZmFyZ2F0ZXNwb3Qtc2VydmljZS1yZXN0YXBpLXN0YWNrJztcclxuXHJcbmNvbnN0IGFwcCA9IG5ldyBjZGsuQXBwKCk7XHJcbmNvbnN0IGVudiA9IHtcclxuICAgIGFjY291bnQ6IHByb2Nlc3MuZW52LkNES19ERUZBVUxUX0FDQ09VTlQsXHJcbiAgICByZWdpb246IHByb2Nlc3MuZW52LkNES19ERUZBVUxUX1JFR0lPTlxyXG59O1xyXG5jb25zdCBzdGFnZSA9IGFwcC5ub2RlLnRyeUdldENvbnRleHQoJ3N0YWdlJykgfHwgREVGQVVMVF9TVEFHRTtcclxuXHJcbm5ldyBGYXJnYXRlU3BvdFJlc3RBUElTZXJ2aWNlU3RhY2soYXBwLCBgZWNzLWZhcmdhdGVzcG90LXNlcnZpY2UtcmVzdGFwaS0ke3N0YWdlfWAsIHtcclxuICAgIGVudixcclxuICAgIHN0YWdlLFxyXG4gICAgZGVzY3JpcHRpb246ICdFQ1MgRmFyZ2F0ZSBzZXJ2aWNlIGZvciBSRVNUZnVsIEFQSSB3aXRoIFNwb3QgQ2FwYWNpdHlQcm92aWRlciBhbmQgQUxCJyxcclxuICAgIHRlcm1pbmF0aW9uUHJvdGVjdGlvbjogc3RhZ2UhPURFRkFVTFRfU1RBR0VcclxufSk7XHJcbiJdfQ== \ No newline at end of file diff --git a/ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.d.ts b/ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.d.ts new file mode 100644 index 0000000..afe9224 --- /dev/null +++ b/ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.d.ts @@ -0,0 +1,10 @@ +import { Construct } from 'constructs'; +import { Stack } from 'aws-cdk-lib'; +import { StackCommonProps } from '../../config'; +/** + * Crearte Fargate Service with Spot CapacityProvider, Auto Scaling, ALB, and Log Group. + * Set the ALB logs for the production-level. + */ +export declare class FargateSpotRestAPIServiceStack extends Stack { + constructor(scope: Construct, id: string, props: StackCommonProps); +} diff --git a/ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.js b/ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.js new file mode 100644 index 0000000..8355c22 --- /dev/null +++ b/ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.js @@ -0,0 +1,151 @@ +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.FargateSpotRestAPIServiceStack = void 0; +const cdk = __importStar(require("aws-cdk-lib")); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const ecs = __importStar(require("aws-cdk-lib/aws-ecs")); +const ec2 = __importStar(require("aws-cdk-lib/aws-ec2")); +const elbv2 = __importStar(require("aws-cdk-lib/aws-elasticloadbalancingv2")); +const logs = __importStar(require("aws-cdk-lib/aws-logs")); +const iam = __importStar(require("aws-cdk-lib/aws-iam")); +const ssm = __importStar(require("aws-cdk-lib/aws-ssm")); +const cluster_config_1 = require("../../ecs-fargate-cluster/lib/cluster-config"); +const config_1 = require("../../config"); +/** + * Crearte Fargate Service with Spot CapacityProvider, Auto Scaling, ALB, and Log Group. + * Set the ALB logs for the production-level. + */ +class FargateSpotRestAPIServiceStack extends aws_cdk_lib_1.Stack { + constructor(scope, id, props) { + var _a, _b; + super(scope, id, props); + const vpcId = this.node.tryGetContext('vpcId') || ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/vpc-id`); + const vpc = ec2.Vpc.fromLookup(this, 'vpc', { vpcId }); + const clusterSgId = ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/cluster-securitygroup-id`); + const ecsSecurityGroup = ec2.SecurityGroup.fromSecurityGroupId(this, 'ecs-security-group', clusterSgId); + const cluster = ecs.Cluster.fromClusterAttributes(this, 'ecs-fargate-cluster', { + clusterName: `${cluster_config_1.CLUSTER_NAME}-${props.stage}`, + vpc, + securityGroups: [ecsSecurityGroup] + }); + const serviceName = 'fargatespot-restapi'; + const containerName = `${serviceName}-container`; + const applicationPort = 8080; + const executionRoleArn = ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/task-execution-role-arn`); + const taskRoleArn = ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/default-task-role-arn`); + const taskDefinition = new ecs.TaskDefinition(this, 'fargate-task-definition', { + cpu: '1024', + memoryMiB: '2048', + compatibility: ecs.Compatibility.FARGATE, + family: `${serviceName}-task`, + executionRole: iam.Role.fromRoleArn(this, 'task-execution-role', cdk.Lazy.string({ produce: () => executionRoleArn })), + taskRole: iam.Role.fromRoleArn(this, 'task-role', cdk.Lazy.string({ produce: () => taskRoleArn })) + }); + const container = taskDefinition.addContainer('container-restapi', { + containerName, + image: ecs.ContainerImage.fromRegistry(`${(_a = props.env) === null || _a === void 0 ? void 0 : _a.account}.dkr.ecr.${(_b = props.env) === null || _b === void 0 ? void 0 : _b.region}.amazonaws.com/fargate-restapi-${props.stage}:latest`), + // or build with /app folder + // import * as path from 'path'; + // image: ecs.ContainerImage.fromAsset(path.join(__dirname, "../../", "app")), + cpu: 1024, + memoryReservationMiB: 2048 + }); + container.addPortMappings({ containerPort: applicationPort, hostPort: applicationPort }); + const fargateservice = new ecs.FargateService(this, 'ecs-fargate-service', { + cluster, + serviceName: `${serviceName}-${props.stage}`, + taskDefinition, + enableExecuteCommand: true, + minHealthyPercent: 100, + maxHealthyPercent: 200, + healthCheckGracePeriod: aws_cdk_lib_1.Duration.seconds(0), + capacityProviderStrategies: [ + { + capacityProvider: 'FARGATE_SPOT', + weight: 1, + }, + { + capacityProvider: 'FARGATE', + weight: 1, + } + ] + }); + fargateservice.autoScaleTaskCount({ + minCapacity: 2, + maxCapacity: 100, + }).scaleOnCpuUtilization('cpuscaling', { + targetUtilizationPercent: 50, + scaleOutCooldown: aws_cdk_lib_1.Duration.seconds(60), + scaleInCooldown: aws_cdk_lib_1.Duration.seconds(120) + }); + const logGroup = new logs.LogGroup(this, 'loggroup', { + logGroupName: serviceName, + removalPolicy: cdk.RemovalPolicy.DESTROY, + retention: logs.RetentionDays.TWO_WEEKS, + }); + const albSecurityGroupName = `albsg-${serviceName}`; + const albSecurityGroup = new ec2.SecurityGroup(this, albSecurityGroupName, { + securityGroupName: albSecurityGroupName, + vpc, + allowAllOutbound: true, + description: `ALB security group for ${serviceName} Service` + }); + ecsSecurityGroup.addIngressRule(albSecurityGroup, ec2.Port.tcp(applicationPort), 'Allow from ALB'); + albSecurityGroup.addIngressRule(ec2.Peer.anyIpv4(), ec2.Port.tcp(80), 'Allow any'); + const alb = new elbv2.ApplicationLoadBalancer(this, 'alb', { + securityGroup: albSecurityGroup, + vpc, + loadBalancerName: `alb-${serviceName}`, + internetFacing: true, + deletionProtection: false, + idleTimeout: cdk.Duration.seconds(30), + }); + alb.addListener('https-listener', { + protocol: elbv2.ApplicationProtocol.HTTP, + open: false, + }).addTargets('ec2-service-target', { + targetGroupName: `tg-${serviceName}`, + port: applicationPort, + protocol: elbv2.ApplicationProtocol.HTTP, + targets: [fargateservice.loadBalancerTarget({ + containerName: containerName, + containerPort: applicationPort, + })], + healthCheck: { + healthyThresholdCount: 2, + unhealthyThresholdCount: 5, + interval: aws_cdk_lib_1.Duration.seconds(31), + path: '/ping', + timeout: aws_cdk_lib_1.Duration.seconds(30), + }, + deregistrationDelay: aws_cdk_lib_1.Duration.seconds(15) + }); + aws_cdk_lib_1.Tags.of(albSecurityGroup).add('Stage', props.stage); + aws_cdk_lib_1.Tags.of(albSecurityGroup).add('Name', albSecurityGroupName); + new aws_cdk_lib_1.CfnOutput(this, 'Service', { value: fargateservice.serviceArn }); + new aws_cdk_lib_1.CfnOutput(this, 'TaskDefinition', { value: taskDefinition.family }); + new aws_cdk_lib_1.CfnOutput(this, 'LogGroup', { value: logGroup.logGroupName }); + new aws_cdk_lib_1.CfnOutput(this, 'ALB', { value: alb.loadBalancerDnsName }); + } +} +exports.FargateSpotRestAPIServiceStack = FargateSpotRestAPIServiceStack; +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecs-fargatespot-service-restapi-stack.js","sourceRoot":"","sources":["../../../ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from 'constructs';\r\nimport * as cdk from 'aws-cdk-lib';\r\nimport { Stack, CfnOutput, Duration, Tags } from 'aws-cdk-lib';\r\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\r\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\r\nimport * as elbv2 from 'aws-cdk-lib/aws-elasticloadbalancingv2';\r\nimport * as logs from 'aws-cdk-lib/aws-logs';\r\nimport * as iam from 'aws-cdk-lib/aws-iam';\r\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\r\n\r\nimport { CLUSTER_NAME } from '../../ecs-fargate-cluster/lib/cluster-config';\r\nimport { StackCommonProps, SSM_PREFIX } from '../../config';\r\n\r\n/**\r\n * Crearte Fargate Service with Spot CapacityProvider, Auto Scaling, ALB, and Log Group.\r\n * Set the ALB logs for the production-level.\r\n */\r\nexport class FargateSpotRestAPIServiceStack extends Stack {\r\n    constructor(scope: Construct, id: string, props: StackCommonProps) {\r\n        super(scope, id, props);\r\n\r\n        const vpcId = this.node.tryGetContext('vpcId') || ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/vpc-id`);\r\n        const vpc = ec2.Vpc.fromLookup(this, 'vpc', { vpcId });\r\n        const clusterSgId = ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/cluster-securitygroup-id`);\r\n        const ecsSecurityGroup = ec2.SecurityGroup.fromSecurityGroupId(this, 'ecs-security-group', clusterSgId);\r\n\r\n        const cluster = ecs.Cluster.fromClusterAttributes(this, 'ecs-fargate-cluster', {\r\n            clusterName: `${CLUSTER_NAME}-${props.stage}`,\r\n            vpc,\r\n            securityGroups: [ecsSecurityGroup]\r\n        });\r\n\r\n        const serviceName = 'fargatespot-restapi'\r\n        const containerName = `${serviceName}-container`\r\n        const applicationPort = 8080;\r\n\r\n        const executionRoleArn = ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/task-execution-role-arn`);\r\n        const taskRoleArn = ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/default-task-role-arn`);\r\n\r\n        const taskDefinition = new ecs.TaskDefinition(this, 'fargate-task-definition', {\r\n            cpu: '1024',\r\n            memoryMiB: '2048',\r\n            compatibility: ecs.Compatibility.FARGATE,\r\n            family: `${serviceName}-task`,\r\n            executionRole: iam.Role.fromRoleArn(this, 'task-execution-role', cdk.Lazy.string({ produce: () => executionRoleArn })),\r\n            taskRole: iam.Role.fromRoleArn(this, 'task-role', cdk.Lazy.string({ produce: () => taskRoleArn }))\r\n        });\r\n        const container = taskDefinition.addContainer('container-restapi', {\r\n            containerName,\r\n            image: ecs.ContainerImage.fromRegistry(`${props.env?.account}.dkr.ecr.${props.env?.region}.amazonaws.com/fargate-restapi-${props.stage}:latest`),\r\n            // or build with /app folder\r\n            // import * as path from 'path';\r\n            // image: ecs.ContainerImage.fromAsset(path.join(__dirname, \"../../\", \"app\")),\r\n            cpu: 1024,\r\n            memoryReservationMiB: 2048\r\n        });\r\n        container.addPortMappings({ containerPort: applicationPort, hostPort: applicationPort });\r\n\r\n        const fargateservice = new ecs.FargateService(this, 'ecs-fargate-service', {\r\n            cluster,\r\n            serviceName: `${serviceName}-${props.stage}`,\r\n            taskDefinition,\r\n            enableExecuteCommand: true,\r\n            minHealthyPercent: 100,\r\n            maxHealthyPercent: 200,\r\n            healthCheckGracePeriod: Duration.seconds(0), // set the value as your application initialize time \r\n            capacityProviderStrategies: [\r\n                {\r\n                    capacityProvider: 'FARGATE_SPOT',\r\n                    weight: 1,\r\n                },\r\n                {\r\n                    capacityProvider: 'FARGATE',\r\n                    weight: 1,\r\n                }\r\n            ]\r\n        });\r\n        fargateservice.autoScaleTaskCount({\r\n            minCapacity: 2,\r\n            maxCapacity: 100,\r\n        }).scaleOnCpuUtilization('cpuscaling', {\r\n            targetUtilizationPercent: 50,\r\n            scaleOutCooldown: Duration.seconds(60),\r\n            scaleInCooldown: Duration.seconds(120)\r\n        });\r\n\r\n        const logGroup = new logs.LogGroup(this, 'loggroup', {\r\n            logGroupName: serviceName,\r\n            removalPolicy: cdk.RemovalPolicy.DESTROY,\r\n            retention: logs.RetentionDays.TWO_WEEKS,\r\n        });\r\n\r\n        const albSecurityGroupName = `albsg-${serviceName}`\r\n        const albSecurityGroup = new ec2.SecurityGroup(this, albSecurityGroupName, {\r\n            securityGroupName: albSecurityGroupName,\r\n            vpc,\r\n            allowAllOutbound: true,\r\n            description: `ALB security group for ${serviceName} Service`\r\n        });\r\n        ecsSecurityGroup.addIngressRule(albSecurityGroup, ec2.Port.tcp(applicationPort), 'Allow from ALB');\r\n        albSecurityGroup.addIngressRule(ec2.Peer.anyIpv4(), ec2.Port.tcp(80), 'Allow any');\r\n\r\n        const alb = new elbv2.ApplicationLoadBalancer(this, 'alb', {\r\n            securityGroup: albSecurityGroup,\r\n            vpc,\r\n            loadBalancerName: `alb-${serviceName}`,\r\n            internetFacing: true,\r\n            deletionProtection: false,\r\n            idleTimeout: cdk.Duration.seconds(30),\r\n        });\r\n        alb.addListener('https-listener', {\r\n            protocol: elbv2.ApplicationProtocol.HTTP,\r\n            open: false,\r\n        }).addTargets('ec2-service-target', {\r\n            targetGroupName: `tg-${serviceName}`,\r\n            port: applicationPort,\r\n            protocol: elbv2.ApplicationProtocol.HTTP,\r\n            targets: [fargateservice.loadBalancerTarget({\r\n                containerName: containerName,\r\n                containerPort: applicationPort,\r\n            })],\r\n            healthCheck: {\r\n                healthyThresholdCount: 2,\r\n                unhealthyThresholdCount: 5,\r\n                interval: Duration.seconds(31),\r\n                path: '/ping',\r\n                timeout: Duration.seconds(30),\r\n            },\r\n            deregistrationDelay: Duration.seconds(15)\r\n        });\r\n\r\n        Tags.of(albSecurityGroup).add('Stage', props.stage);\r\n        Tags.of(albSecurityGroup).add('Name', albSecurityGroupName);\r\n\r\n        new CfnOutput(this, 'Service', { value: fargateservice.serviceArn });\r\n        new CfnOutput(this, 'TaskDefinition', { value: taskDefinition.family });\r\n        new CfnOutput(this, 'LogGroup', { value: logGroup.logGroupName });\r\n        new CfnOutput(this, 'ALB', { value: alb.loadBalancerDnsName });\r\n    }\r\n}\r\n"]} \ No newline at end of file diff --git a/ts.out/ecs-iam-role/bin/index.d.ts b/ts.out/ecs-iam-role/bin/index.d.ts new file mode 100644 index 0000000..b798801 --- /dev/null +++ b/ts.out/ecs-iam-role/bin/index.d.ts @@ -0,0 +1,2 @@ +#!/usr/bin/env node +export {}; diff --git a/ts.out/ecs-iam-role/bin/index.js b/ts.out/ecs-iam-role/bin/index.js new file mode 100644 index 0000000..a18ad6f --- /dev/null +++ b/ts.out/ecs-iam-role/bin/index.js @@ -0,0 +1,37 @@ +#!/usr/bin/env node +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const cdk = __importStar(require("aws-cdk-lib")); +const config_1 = require("../../config"); +const ecs_iam_role_stack_1 = require("../lib/ecs-iam-role-stack"); +const app = new cdk.App(); +const env = { + account: process.env.CDK_DEFAULT_ACCOUNT, + region: process.env.CDK_DEFAULT_REGION +}; +const stage = app.node.tryGetContext('stage') || config_1.DEFAULT_STAGE; +new ecs_iam_role_stack_1.EcsIamRoleStack(app, `ecs-fargate-iam-role-${stage}`, { + env, + description: 'ECS Fargate IAM Role', + terminationProtection: stage !== config_1.DEFAULT_STAGE +}); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9lY3MtaWFtLXJvbGUvYmluL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFDQSxpREFBbUM7QUFDbkMseUNBQTZDO0FBQzdDLGtFQUE0RDtBQUU1RCxNQUFNLEdBQUcsR0FBRyxJQUFJLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQztBQUMxQixNQUFNLEdBQUcsR0FBRztJQUNSLE9BQU8sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLG1CQUFtQjtJQUN4QyxNQUFNLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxrQkFBa0I7Q0FDekMsQ0FBQztBQUNGLE1BQU0sS0FBSyxHQUFHLEdBQUcsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxJQUFJLHNCQUFhLENBQUM7QUFFL0QsSUFBSSxvQ0FBZSxDQUFDLEdBQUcsRUFBRSx3QkFBd0IsS0FBSyxFQUFFLEVBQUc7SUFDdkQsR0FBRztJQUNILFdBQVcsRUFBRSxzQkFBc0I7SUFDbkMscUJBQXFCLEVBQUUsS0FBSyxLQUFHLHNCQUFhO0NBQy9DLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIiMhL3Vzci9iaW4vZW52IG5vZGVcclxuaW1wb3J0ICogYXMgY2RrIGZyb20gJ2F3cy1jZGstbGliJztcclxuaW1wb3J0IHsgREVGQVVMVF9TVEFHRSB9IGZyb20gJy4uLy4uL2NvbmZpZyc7XHJcbmltcG9ydCB7IEVjc0lhbVJvbGVTdGFjayB9IGZyb20gJy4uL2xpYi9lY3MtaWFtLXJvbGUtc3RhY2snO1xyXG5cclxuY29uc3QgYXBwID0gbmV3IGNkay5BcHAoKTtcclxuY29uc3QgZW52ID0ge1xyXG4gICAgYWNjb3VudDogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfQUNDT1VOVCxcclxuICAgIHJlZ2lvbjogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfUkVHSU9OXHJcbn07XHJcbmNvbnN0IHN0YWdlID0gYXBwLm5vZGUudHJ5R2V0Q29udGV4dCgnc3RhZ2UnKSB8fCBERUZBVUxUX1NUQUdFO1xyXG5cclxubmV3IEVjc0lhbVJvbGVTdGFjayhhcHAsIGBlY3MtZmFyZ2F0ZS1pYW0tcm9sZS0ke3N0YWdlfWAsICB7XHJcbiAgICBlbnYsXHJcbiAgICBkZXNjcmlwdGlvbjogJ0VDUyBGYXJnYXRlIElBTSBSb2xlJyxcclxuICAgIHRlcm1pbmF0aW9uUHJvdGVjdGlvbjogc3RhZ2UhPT1ERUZBVUxUX1NUQUdFXHJcbn0pOyJdfQ== \ No newline at end of file diff --git a/ts.out/ecs-iam-role/lib/ecs-iam-role-stack.d.ts b/ts.out/ecs-iam-role/lib/ecs-iam-role-stack.d.ts new file mode 100644 index 0000000..424b96c --- /dev/null +++ b/ts.out/ecs-iam-role/lib/ecs-iam-role-stack.d.ts @@ -0,0 +1,13 @@ +import { Stack, StackProps } from 'aws-cdk-lib'; +import { Construct } from 'constructs'; +/** + * This stack is written to share IAM role among multiple-cluster + * + * https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html + * + * https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-exec.html + * + */ +export declare class EcsIamRoleStack extends Stack { + constructor(scope: Construct, id: string, props?: StackProps); +} diff --git a/ts.out/ecs-iam-role/lib/ecs-iam-role-stack.js b/ts.out/ecs-iam-role/lib/ecs-iam-role-stack.js new file mode 100644 index 0000000..ecdba39 --- /dev/null +++ b/ts.out/ecs-iam-role/lib/ecs-iam-role-stack.js @@ -0,0 +1,79 @@ +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.EcsIamRoleStack = void 0; +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const ssm = __importStar(require("aws-cdk-lib/aws-ssm")); +const iam = __importStar(require("aws-cdk-lib/aws-iam")); +const config_1 = require("../../config"); +/** + * This stack is written to share IAM role among multiple-cluster + * + * https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html + * + * https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-exec.html + * + */ +class EcsIamRoleStack extends aws_cdk_lib_1.Stack { + constructor(scope, id, props) { + super(scope, id, props); + // AmazonECSTaskExecutionRole based on https://us-east-1.console.aws.amazon.com/iam/home#/policies/arn:aws:iam::aws:policy/service-role/AmazonECSTaskExecutionRolePolicy$jsonEditor + const taskExecutionRole = new iam.Role(this, 'task-execution-role', { + roleName: 'AmazonECSFargateTaskExecutionRole', + assumedBy: new iam.ServicePrincipal('ecs-tasks.amazonaws.com'), + managedPolicies: [ + iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AmazonECSTaskExecutionRolePolicy'), + ] + }); + const defaultTaskRole = new iam.Role(this, 'default-task-role', { + roleName: 'ECSFargateDefaultTaskRole', + assumedBy: new iam.ServicePrincipal('ecs-tasks.amazonaws.com'), + managedPolicies: [ + iam.ManagedPolicy.fromAwsManagedPolicyName('AWSXrayWriteOnlyAccess'), + iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMReadOnlyAccess') + ], + inlinePolicies: { + ECSExec: new iam.PolicyDocument({ + statements: [ + new iam.PolicyStatement({ + effect: iam.Effect.ALLOW, + actions: [ + "ssmmessages:CreateControlChannel", + "ssmmessages:CreateDataChannel", + "ssmmessages:OpenControlChannel", + "ssmmessages:OpenDataChannel", + ], + resources: ["*"], + }), + ], + }), + } + }); + const taskExecRoleParam = new ssm.StringParameter(this, 'ssm-task-execution-role', { parameterName: `${config_1.SSM_PREFIX}/task-execution-role-arn`, stringValue: taskExecutionRole.roleArn }); + const defaultTaskRoleParam = new ssm.StringParameter(this, 'ssm-default-task-role', { parameterName: `${config_1.SSM_PREFIX}/default-task-role-arn`, stringValue: defaultTaskRole.roleArn }); + new aws_cdk_lib_1.CfnOutput(this, 'SSMTaskExecRoleParam', { value: taskExecRoleParam.parameterName }); + new aws_cdk_lib_1.CfnOutput(this, 'SSMTaskExecRoleParamValue', { value: taskExecRoleParam.stringValue }); + new aws_cdk_lib_1.CfnOutput(this, 'SSMDefaultTaskRoleParam', { value: defaultTaskRoleParam.parameterName }); + new aws_cdk_lib_1.CfnOutput(this, 'SSMDefaultTaskRoleParamValue', { value: defaultTaskRoleParam.stringValue }); + } +} +exports.EcsIamRoleStack = EcsIamRoleStack; +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNzLWlhbS1yb2xlLXN0YWNrLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vZWNzLWlhbS1yb2xlL2xpYi9lY3MtaWFtLXJvbGUtc3RhY2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDZDQUEyRDtBQUUzRCx5REFBMkM7QUFDM0MseURBQTJDO0FBRzNDLHlDQUEwQztBQUUxQzs7Ozs7OztHQU9HO0FBQ0gsTUFBYSxlQUFnQixTQUFRLG1CQUFLO0lBQ3hDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBa0I7UUFDMUQsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFFeEIsbUxBQW1MO1FBQ25MLE1BQU0saUJBQWlCLEdBQUcsSUFBSSxHQUFHLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxxQkFBcUIsRUFBRTtZQUNsRSxRQUFRLEVBQUUsbUNBQW1DO1lBQzdDLFNBQVMsRUFBRSxJQUFJLEdBQUcsQ0FBQyxnQkFBZ0IsQ0FBQyx5QkFBeUIsQ0FBQztZQUM5RCxlQUFlLEVBQUU7Z0JBQ2YsR0FBRyxDQUFDLGFBQWEsQ0FBQyx3QkFBd0IsQ0FDeEMsK0NBQStDLENBQ2hEO2FBQ0Y7U0FDRixDQUFDLENBQUM7UUFFSCxNQUFNLGVBQWUsR0FBRyxJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLG1CQUFtQixFQUFFO1lBQzlELFFBQVEsRUFBRSwyQkFBMkI7WUFDckMsU0FBUyxFQUFFLElBQUksR0FBRyxDQUFDLGdCQUFnQixDQUFDLHlCQUF5QixDQUFDO1lBQzlELGVBQWUsRUFBRTtnQkFDZixHQUFHLENBQUMsYUFBYSxDQUFDLHdCQUF3QixDQUN4Qyx3QkFBd0IsQ0FDekI7Z0JBQ0QsR0FBRyxDQUFDLGFBQWEsQ0FBQyx3QkFBd0IsQ0FDeEMseUJBQXlCLENBQzFCO2FBQ0Y7WUFDRCxjQUFjLEVBQUU7Z0JBQ2QsT0FBTyxFQUFFLElBQUksR0FBRyxDQUFDLGNBQWMsQ0FBQztvQkFDOUIsVUFBVSxFQUFFO3dCQUNWLElBQUksR0FBRyxDQUFDLGVBQWUsQ0FBQzs0QkFDdEIsTUFBTSxFQUFFLEdBQUcsQ0FBQyxNQUFNLENBQUMsS0FBSzs0QkFDeEIsT0FBTyxFQUFFO2dDQUNQLGtDQUFrQztnQ0FDbEMsK0JBQStCO2dDQUMvQixnQ0FBZ0M7Z0NBQ2hDLDZCQUE2Qjs2QkFDOUI7NEJBQ0QsU0FBUyxFQUFFLENBQUMsR0FBRyxDQUFDO3lCQUNqQixDQUFDO3FCQUNIO2lCQUNGLENBQUM7YUFDSDtTQUNGLENBQUMsQ0FBQztRQUVILE1BQU0saUJBQWlCLEdBQUcsSUFBSSxHQUFHLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSx5QkFBeUIsRUFBRSxFQUFFLGFBQWEsRUFBRSxHQUFHLG1CQUFVLDBCQUEwQixFQUFFLFdBQVcsRUFBRSxpQkFBaUIsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQ3ZMLE1BQU0sb0JBQW9CLEdBQUcsSUFBSSxHQUFHLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSx1QkFBdUIsRUFBRSxFQUFFLGFBQWEsRUFBRSxHQUFHLG1CQUFVLHdCQUF3QixFQUFFLFdBQVcsRUFBRSxlQUFlLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztRQUVwTCxJQUFJLHVCQUFTLENBQUMsSUFBSSxFQUFFLHNCQUFzQixFQUFFLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixDQUFDLGFBQWEsRUFBRSxDQUFDLENBQUM7UUFDeEYsSUFBSSx1QkFBUyxDQUFDLElBQUksRUFBRSwyQkFBMkIsRUFBRSxFQUFFLEtBQUssRUFBRSxpQkFBaUIsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1FBQzNGLElBQUksdUJBQVMsQ0FBQyxJQUFJLEVBQUUseUJBQXlCLEVBQUUsRUFBRSxLQUFLLEVBQUUsb0JBQW9CLENBQUMsYUFBYSxFQUFFLENBQUMsQ0FBQztRQUM5RixJQUFJLHVCQUFTLENBQUMsSUFBSSxFQUFFLDhCQUE4QixFQUFFLEVBQUUsS0FBSyxFQUFFLG9CQUFvQixDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7SUFDbkcsQ0FBQztDQUNGO0FBcERELDBDQW9EQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFN0YWNrLCBTdGFja1Byb3BzLCBDZm5PdXRwdXQgfSBmcm9tICdhd3MtY2RrLWxpYic7XHJcblxyXG5pbXBvcnQgKiBhcyBzc20gZnJvbSAnYXdzLWNkay1saWIvYXdzLXNzbSc7XHJcbmltcG9ydCAqIGFzIGlhbSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcclxuXHJcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xyXG5pbXBvcnQgeyBTU01fUFJFRklYIH0gZnJvbSAnLi4vLi4vY29uZmlnJztcclxuXHJcbi8qKlxyXG4gKiBUaGlzIHN0YWNrIGlzIHdyaXR0ZW4gdG8gc2hhcmUgSUFNIHJvbGUgYW1vbmcgbXVsdGlwbGUtY2x1c3RlclxyXG4gKiBcclxuICogaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FtYXpvbkVDUy9sYXRlc3QvZGV2ZWxvcGVyZ3VpZGUvdGFzay1pYW0tcm9sZXMuaHRtbFxyXG4gKiBcclxuICogaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FtYXpvbkVDUy9sYXRlc3QvZGV2ZWxvcGVyZ3VpZGUvZWNzLWV4ZWMuaHRtbFxyXG4gKiBcclxuICovXHJcbmV4cG9ydCBjbGFzcyBFY3NJYW1Sb2xlU3RhY2sgZXh0ZW5kcyBTdGFjayB7XHJcbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM/OiBTdGFja1Byb3BzKSB7XHJcbiAgICBzdXBlcihzY29wZSwgaWQsIHByb3BzKTtcclxuXHJcbiAgICAvLyBBbWF6b25FQ1NUYXNrRXhlY3V0aW9uUm9sZSBiYXNlZCBvbiBodHRwczovL3VzLWVhc3QtMS5jb25zb2xlLmF3cy5hbWF6b24uY29tL2lhbS9ob21lIy9wb2xpY2llcy9hcm46YXdzOmlhbTo6YXdzOnBvbGljeS9zZXJ2aWNlLXJvbGUvQW1hem9uRUNTVGFza0V4ZWN1dGlvblJvbGVQb2xpY3kkanNvbkVkaXRvclxyXG4gICAgY29uc3QgdGFza0V4ZWN1dGlvblJvbGUgPSBuZXcgaWFtLlJvbGUodGhpcywgJ3Rhc2stZXhlY3V0aW9uLXJvbGUnLCB7XHJcbiAgICAgIHJvbGVOYW1lOiAnQW1hem9uRUNTRmFyZ2F0ZVRhc2tFeGVjdXRpb25Sb2xlJyxcclxuICAgICAgYXNzdW1lZEJ5OiBuZXcgaWFtLlNlcnZpY2VQcmluY2lwYWwoJ2Vjcy10YXNrcy5hbWF6b25hd3MuY29tJyksXHJcbiAgICAgIG1hbmFnZWRQb2xpY2llczogW1xyXG4gICAgICAgIGlhbS5NYW5hZ2VkUG9saWN5LmZyb21Bd3NNYW5hZ2VkUG9saWN5TmFtZShcclxuICAgICAgICAgICdzZXJ2aWNlLXJvbGUvQW1hem9uRUNTVGFza0V4ZWN1dGlvblJvbGVQb2xpY3knLFxyXG4gICAgICAgICksXHJcbiAgICAgIF1cclxuICAgIH0pO1xyXG5cclxuICAgIGNvbnN0IGRlZmF1bHRUYXNrUm9sZSA9IG5ldyBpYW0uUm9sZSh0aGlzLCAnZGVmYXVsdC10YXNrLXJvbGUnLCB7XHJcbiAgICAgIHJvbGVOYW1lOiAnRUNTRmFyZ2F0ZURlZmF1bHRUYXNrUm9sZScsXHJcbiAgICAgIGFzc3VtZWRCeTogbmV3IGlhbS5TZXJ2aWNlUHJpbmNpcGFsKCdlY3MtdGFza3MuYW1hem9uYXdzLmNvbScpLFxyXG4gICAgICBtYW5hZ2VkUG9saWNpZXM6IFtcclxuICAgICAgICBpYW0uTWFuYWdlZFBvbGljeS5mcm9tQXdzTWFuYWdlZFBvbGljeU5hbWUoXHJcbiAgICAgICAgICAnQVdTWHJheVdyaXRlT25seUFjY2VzcycsXHJcbiAgICAgICAgKSxcclxuICAgICAgICBpYW0uTWFuYWdlZFBvbGljeS5mcm9tQXdzTWFuYWdlZFBvbGljeU5hbWUoXHJcbiAgICAgICAgICAnQW1hem9uU1NNUmVhZE9ubHlBY2Nlc3MnLFxyXG4gICAgICAgIClcclxuICAgICAgXSxcclxuICAgICAgaW5saW5lUG9saWNpZXM6IHtcclxuICAgICAgICBFQ1NFeGVjOiBuZXcgaWFtLlBvbGljeURvY3VtZW50KHtcclxuICAgICAgICAgIHN0YXRlbWVudHM6IFtcclxuICAgICAgICAgICAgbmV3IGlhbS5Qb2xpY3lTdGF0ZW1lbnQoe1xyXG4gICAgICAgICAgICAgIGVmZmVjdDogaWFtLkVmZmVjdC5BTExPVyxcclxuICAgICAgICAgICAgICBhY3Rpb25zOiBbXHJcbiAgICAgICAgICAgICAgICBcInNzbW1lc3NhZ2VzOkNyZWF0ZUNvbnRyb2xDaGFubmVsXCIsXHJcbiAgICAgICAgICAgICAgICBcInNzbW1lc3NhZ2VzOkNyZWF0ZURhdGFDaGFubmVsXCIsXHJcbiAgICAgICAgICAgICAgICBcInNzbW1lc3NhZ2VzOk9wZW5Db250cm9sQ2hhbm5lbFwiLFxyXG4gICAgICAgICAgICAgICAgXCJzc21tZXNzYWdlczpPcGVuRGF0YUNoYW5uZWxcIixcclxuICAgICAgICAgICAgICBdLFxyXG4gICAgICAgICAgICAgIHJlc291cmNlczogW1wiKlwiXSxcclxuICAgICAgICAgICAgfSksXHJcbiAgICAgICAgICBdLFxyXG4gICAgICAgIH0pLFxyXG4gICAgICB9XHJcbiAgICB9KTtcclxuXHJcbiAgICBjb25zdCB0YXNrRXhlY1JvbGVQYXJhbSA9IG5ldyBzc20uU3RyaW5nUGFyYW1ldGVyKHRoaXMsICdzc20tdGFzay1leGVjdXRpb24tcm9sZScsIHsgcGFyYW1ldGVyTmFtZTogYCR7U1NNX1BSRUZJWH0vdGFzay1leGVjdXRpb24tcm9sZS1hcm5gLCBzdHJpbmdWYWx1ZTogdGFza0V4ZWN1dGlvblJvbGUucm9sZUFybiB9KTtcclxuICAgIGNvbnN0IGRlZmF1bHRUYXNrUm9sZVBhcmFtID0gbmV3IHNzbS5TdHJpbmdQYXJhbWV0ZXIodGhpcywgJ3NzbS1kZWZhdWx0LXRhc2stcm9sZScsIHsgcGFyYW1ldGVyTmFtZTogYCR7U1NNX1BSRUZJWH0vZGVmYXVsdC10YXNrLXJvbGUtYXJuYCwgc3RyaW5nVmFsdWU6IGRlZmF1bHRUYXNrUm9sZS5yb2xlQXJuIH0pO1xyXG5cclxuICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ1NTTVRhc2tFeGVjUm9sZVBhcmFtJywgeyB2YWx1ZTogdGFza0V4ZWNSb2xlUGFyYW0ucGFyYW1ldGVyTmFtZSB9KTtcclxuICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ1NTTVRhc2tFeGVjUm9sZVBhcmFtVmFsdWUnLCB7IHZhbHVlOiB0YXNrRXhlY1JvbGVQYXJhbS5zdHJpbmdWYWx1ZSB9KTtcclxuICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ1NTTURlZmF1bHRUYXNrUm9sZVBhcmFtJywgeyB2YWx1ZTogZGVmYXVsdFRhc2tSb2xlUGFyYW0ucGFyYW1ldGVyTmFtZSB9KTtcclxuICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ1NTTURlZmF1bHRUYXNrUm9sZVBhcmFtVmFsdWUnLCB7IHZhbHVlOiBkZWZhdWx0VGFza1JvbGVQYXJhbS5zdHJpbmdWYWx1ZSB9KTtcclxuICB9XHJcbn1cclxuIl19 \ No newline at end of file diff --git a/ts.out/vpc/bin/index.d.ts b/ts.out/vpc/bin/index.d.ts new file mode 100644 index 0000000..b798801 --- /dev/null +++ b/ts.out/vpc/bin/index.d.ts @@ -0,0 +1,2 @@ +#!/usr/bin/env node +export {}; diff --git a/ts.out/vpc/bin/index.js b/ts.out/vpc/bin/index.js new file mode 100644 index 0000000..a2f1965 --- /dev/null +++ b/ts.out/vpc/bin/index.js @@ -0,0 +1,37 @@ +#!/usr/bin/env node +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const cdk = __importStar(require("aws-cdk-lib")); +const vpc_stack_1 = require("../lib/vpc-stack"); +const config_1 = require("../../config"); +const app = new cdk.App(); +const env = { + account: process.env.CDK_DEFAULT_ACCOUNT, + region: process.env.CDK_DEFAULT_REGION +}; +const stage = app.node.tryGetContext('stage') || config_1.DEFAULT_STAGE; +new vpc_stack_1.VpcStack(app, `ecs-vpc-${stage}`, { + env, + description: 'VPC for Fargate and EC2 ECS', + terminationProtection: stage !== config_1.DEFAULT_STAGE +}); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi92cGMvYmluL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFDQSxpREFBbUM7QUFDbkMsZ0RBQTRDO0FBQzVDLHlDQUE2QztBQUU3QyxNQUFNLEdBQUcsR0FBRyxJQUFJLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQztBQUMxQixNQUFNLEdBQUcsR0FBRztJQUNSLE9BQU8sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLG1CQUFtQjtJQUN4QyxNQUFNLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxrQkFBa0I7Q0FDekMsQ0FBQztBQUNGLE1BQU0sS0FBSyxHQUFHLEdBQUcsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxJQUFJLHNCQUFhLENBQUM7QUFFL0QsSUFBSSxvQkFBUSxDQUFDLEdBQUcsRUFBRSxXQUFXLEtBQUssRUFBRSxFQUFHO0lBQ25DLEdBQUc7SUFDSCxXQUFXLEVBQUUsNkJBQTZCO0lBQzFDLHFCQUFxQixFQUFFLEtBQUssS0FBRyxzQkFBYTtDQUMvQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIjIS91c3IvYmluL2VudiBub2RlXHJcbmltcG9ydCAqIGFzIGNkayBmcm9tICdhd3MtY2RrLWxpYic7XHJcbmltcG9ydCB7IFZwY1N0YWNrIH0gZnJvbSAnLi4vbGliL3ZwYy1zdGFjayc7XHJcbmltcG9ydCB7IERFRkFVTFRfU1RBR0UgfSBmcm9tICcuLi8uLi9jb25maWcnO1xyXG5cclxuY29uc3QgYXBwID0gbmV3IGNkay5BcHAoKTtcclxuY29uc3QgZW52ID0ge1xyXG4gICAgYWNjb3VudDogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfQUNDT1VOVCxcclxuICAgIHJlZ2lvbjogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfUkVHSU9OXHJcbn07XHJcbmNvbnN0IHN0YWdlID0gYXBwLm5vZGUudHJ5R2V0Q29udGV4dCgnc3RhZ2UnKSB8fCBERUZBVUxUX1NUQUdFO1xyXG5cclxubmV3IFZwY1N0YWNrKGFwcCwgYGVjcy12cGMtJHtzdGFnZX1gLCAge1xyXG4gICAgZW52LFxyXG4gICAgZGVzY3JpcHRpb246ICdWUEMgZm9yIEZhcmdhdGUgYW5kIEVDMiBFQ1MnLFxyXG4gICAgdGVybWluYXRpb25Qcm90ZWN0aW9uOiBzdGFnZSE9PURFRkFVTFRfU1RBR0VcclxufSk7Il19 \ No newline at end of file diff --git a/ts.out/vpc/lib/vpc-stack.d.ts b/ts.out/vpc/lib/vpc-stack.d.ts new file mode 100644 index 0000000..8d92f51 --- /dev/null +++ b/ts.out/vpc/lib/vpc-stack.d.ts @@ -0,0 +1,5 @@ +import { Stack, StackProps } from 'aws-cdk-lib'; +import { Construct } from 'constructs'; +export declare class VpcStack extends Stack { + constructor(scope: Construct, id: string, props?: StackProps); +} diff --git a/ts.out/vpc/lib/vpc-stack.js b/ts.out/vpc/lib/vpc-stack.js new file mode 100644 index 0000000..8e05b2d --- /dev/null +++ b/ts.out/vpc/lib/vpc-stack.js @@ -0,0 +1,56 @@ +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.VpcStack = void 0; +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const ec2 = __importStar(require("aws-cdk-lib/aws-ec2")); +const ssm = __importStar(require("aws-cdk-lib/aws-ssm")); +const config_1 = require("../../config"); +class VpcStack extends aws_cdk_lib_1.Stack { + constructor(scope, id, props) { + super(scope, id, props); + const cidr = `10.100.0.0/16`; + const vpc = new ec2.Vpc(this, 'Vpc', { + maxAzs: 3, + natGateways: 3, + cidr, + subnetConfiguration: [ + { + cidrMask: 20, + name: 'public', + subnetType: ec2.SubnetType.PUBLIC, + }, + { + cidrMask: 20, + name: 'private', + subnetType: ec2.SubnetType.PRIVATE_WITH_NAT, + } + ] + }); + const parameter = new ssm.StringParameter(this, 'SSMVPCID', { parameterName: `${config_1.SSM_PREFIX}/vpc-id`, stringValue: vpc.vpcId }); + new aws_cdk_lib_1.CfnOutput(this, 'VPC', { value: vpc.vpcId }); + new aws_cdk_lib_1.CfnOutput(this, 'SSMParameter', { value: parameter.parameterName }); + new aws_cdk_lib_1.CfnOutput(this, 'SSMParameterValue', { value: vpc.vpcId }); + new aws_cdk_lib_1.CfnOutput(this, 'SSMURL', { value: `https://${this.region}.console.aws.amazon.com/systems-manager/parameters/` }); + } +} +exports.VpcStack = VpcStack; +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidnBjLXN0YWNrLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vdnBjL2xpYi92cGMtc3RhY2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDZDQUEyRDtBQUczRCx5REFBMkM7QUFDM0MseURBQTJDO0FBRTNDLHlDQUEwQztBQUUxQyxNQUFhLFFBQVMsU0FBUSxtQkFBSztJQUMvQixZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQWtCO1FBQ3hELEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBRXhCLE1BQU0sSUFBSSxHQUFHLGVBQWUsQ0FBQztRQUM3QixNQUFNLEdBQUcsR0FBRyxJQUFJLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRTtZQUNqQyxNQUFNLEVBQUUsQ0FBQztZQUNULFdBQVcsRUFBRSxDQUFDO1lBQ2QsSUFBSTtZQUNKLG1CQUFtQixFQUFFO2dCQUNqQjtvQkFDSSxRQUFRLEVBQUUsRUFBRTtvQkFDWixJQUFJLEVBQUUsUUFBUTtvQkFDZCxVQUFVLEVBQUUsR0FBRyxDQUFDLFVBQVUsQ0FBQyxNQUFNO2lCQUNwQztnQkFDRDtvQkFDSSxRQUFRLEVBQUUsRUFBRTtvQkFDWixJQUFJLEVBQUUsU0FBUztvQkFDZixVQUFVLEVBQUUsR0FBRyxDQUFDLFVBQVUsQ0FBQyxnQkFBZ0I7aUJBQzlDO2FBQ0o7U0FDSixDQUFDLENBQUM7UUFFSCxNQUFNLFNBQVMsR0FBRyxJQUFJLEdBQUcsQ0FBQyxlQUFlLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRSxFQUFFLGFBQWEsRUFBRSxHQUFHLG1CQUFVLFNBQVMsRUFBRSxXQUFXLEVBQUUsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7UUFDL0gsSUFBSSx1QkFBUyxDQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsRUFBRSxLQUFLLEVBQUUsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7UUFDakQsSUFBSSx1QkFBUyxDQUFDLElBQUksRUFBRSxjQUFjLEVBQUUsRUFBRSxLQUFLLEVBQUUsU0FBUyxDQUFDLGFBQWEsRUFBRSxDQUFDLENBQUM7UUFDeEUsSUFBSSx1QkFBUyxDQUFDLElBQUksRUFBRSxtQkFBbUIsRUFBRSxFQUFFLEtBQUssRUFBRSxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztRQUMvRCxJQUFJLHVCQUFTLENBQUMsSUFBSSxFQUFFLFFBQVEsRUFBRSxFQUFFLEtBQUssRUFBRSxXQUFXLElBQUksQ0FBQyxNQUFNLHFEQUFxRCxFQUFFLENBQUMsQ0FBQztJQUMxSCxDQUFDO0NBQ0o7QUE3QkQsNEJBNkJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3RhY2ssIFN0YWNrUHJvcHMsIENmbk91dHB1dCB9IGZyb20gJ2F3cy1jZGstbGliJztcclxuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnY29uc3RydWN0cyc7XHJcblxyXG5pbXBvcnQgKiBhcyBlYzIgZnJvbSAnYXdzLWNkay1saWIvYXdzLWVjMic7XHJcbmltcG9ydCAqIGFzIHNzbSBmcm9tICdhd3MtY2RrLWxpYi9hd3Mtc3NtJztcclxuXHJcbmltcG9ydCB7IFNTTV9QUkVGSVggfSBmcm9tICcuLi8uLi9jb25maWcnO1xyXG5cclxuZXhwb3J0IGNsYXNzIFZwY1N0YWNrIGV4dGVuZHMgU3RhY2sge1xyXG4gICAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM/OiBTdGFja1Byb3BzKSB7XHJcbiAgICAgICAgc3VwZXIoc2NvcGUsIGlkLCBwcm9wcyk7XHJcblxyXG4gICAgICAgIGNvbnN0IGNpZHIgPSBgMTAuMTAwLjAuMC8xNmA7XHJcbiAgICAgICAgY29uc3QgdnBjID0gbmV3IGVjMi5WcGModGhpcywgJ1ZwYycsIHtcclxuICAgICAgICAgICAgbWF4QXpzOiAzLFxyXG4gICAgICAgICAgICBuYXRHYXRld2F5czogMyxcclxuICAgICAgICAgICAgY2lkcixcclxuICAgICAgICAgICAgc3VibmV0Q29uZmlndXJhdGlvbjogW1xyXG4gICAgICAgICAgICAgICAge1xyXG4gICAgICAgICAgICAgICAgICAgIGNpZHJNYXNrOiAyMCxcclxuICAgICAgICAgICAgICAgICAgICBuYW1lOiAncHVibGljJyxcclxuICAgICAgICAgICAgICAgICAgICBzdWJuZXRUeXBlOiBlYzIuU3VibmV0VHlwZS5QVUJMSUMsXHJcbiAgICAgICAgICAgICAgICB9LFxyXG4gICAgICAgICAgICAgICAge1xyXG4gICAgICAgICAgICAgICAgICAgIGNpZHJNYXNrOiAyMCxcclxuICAgICAgICAgICAgICAgICAgICBuYW1lOiAncHJpdmF0ZScsXHJcbiAgICAgICAgICAgICAgICAgICAgc3VibmV0VHlwZTogZWMyLlN1Ym5ldFR5cGUuUFJJVkFURV9XSVRIX05BVCxcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgXVxyXG4gICAgICAgIH0pO1xyXG5cclxuICAgICAgICBjb25zdCBwYXJhbWV0ZXIgPSBuZXcgc3NtLlN0cmluZ1BhcmFtZXRlcih0aGlzLCAnU1NNVlBDSUQnLCB7IHBhcmFtZXRlck5hbWU6IGAke1NTTV9QUkVGSVh9L3ZwYy1pZGAsIHN0cmluZ1ZhbHVlOiB2cGMudnBjSWQgfSk7XHJcbiAgICAgICAgbmV3IENmbk91dHB1dCh0aGlzLCAnVlBDJywgeyB2YWx1ZTogdnBjLnZwY0lkIH0pO1xyXG4gICAgICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ1NTTVBhcmFtZXRlcicsIHsgdmFsdWU6IHBhcmFtZXRlci5wYXJhbWV0ZXJOYW1lIH0pO1xyXG4gICAgICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ1NTTVBhcmFtZXRlclZhbHVlJywgeyB2YWx1ZTogdnBjLnZwY0lkIH0pO1xyXG4gICAgICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ1NTTVVSTCcsIHsgdmFsdWU6IGBodHRwczovLyR7dGhpcy5yZWdpb259LmNvbnNvbGUuYXdzLmFtYXpvbi5jb20vc3lzdGVtcy1tYW5hZ2VyL3BhcmFtZXRlcnMvYCB9KTtcclxuICAgIH1cclxufSJdfQ== \ No newline at end of file From d039296f35af60c37072b96450bf79d8ffcfef15 Mon Sep 17 00:00:00 2001 From: engel80 Date: Tue, 20 Dec 2022 13:18:13 +0900 Subject: [PATCH 2/2] . --- .gitignore | 1 + ts.out/code-pipeline/bin/index.d.ts | 2 - ts.out/code-pipeline/bin/index.js | 40 ----- .../lib/ecs-codedeploy-stack.d.ts | 17 -- .../code-pipeline/lib/ecs-codedeploy-stack.js | 149 ----------------- ts.out/config.d.ts | 18 --- ts.out/config.js | 18 --- ts.out/ecr-codecommit/bin/index.d.ts | 2 - ts.out/ecr-codecommit/bin/index.js | 40 ----- .../lib/ecr-codecommit-stack.d.ts | 12 -- .../lib/ecr-codecommit-stack.js | 77 --------- ts.out/ecs-fargate-cluster/bin/index.d.ts | 2 - ts.out/ecs-fargate-cluster/bin/index.js | 39 ----- .../lib/cluster-config.d.ts | 3 - .../ecs-fargate-cluster/lib/cluster-config.js | 7 - .../lib/ecs-fargate-cluster-stack.d.ts | 9 -- .../lib/ecs-fargate-cluster-stack.js | 61 ------- .../bin/index.d.ts | 2 - .../ecs-fargate-service-restapi/bin/index.js | 38 ----- .../ecs-fargate-service-restapi-stack.d.ts | 10 -- .../lib/ecs-fargate-service-restapi-stack.js | 142 ---------------- .../bin/index.d.ts | 2 - .../bin/index.js | 38 ----- ...ecs-fargatespot-service-restapi-stack.d.ts | 10 -- .../ecs-fargatespot-service-restapi-stack.js | 151 ------------------ ts.out/ecs-iam-role/bin/index.d.ts | 2 - ts.out/ecs-iam-role/bin/index.js | 37 ----- .../ecs-iam-role/lib/ecs-iam-role-stack.d.ts | 13 -- ts.out/ecs-iam-role/lib/ecs-iam-role-stack.js | 79 --------- ts.out/vpc/bin/index.d.ts | 2 - ts.out/vpc/bin/index.js | 37 ----- ts.out/vpc/lib/vpc-stack.d.ts | 5 - ts.out/vpc/lib/vpc-stack.js | 56 ------- 33 files changed, 1 insertion(+), 1120 deletions(-) delete mode 100644 ts.out/code-pipeline/bin/index.d.ts delete mode 100644 ts.out/code-pipeline/bin/index.js delete mode 100644 ts.out/code-pipeline/lib/ecs-codedeploy-stack.d.ts delete mode 100644 ts.out/code-pipeline/lib/ecs-codedeploy-stack.js delete mode 100644 ts.out/config.d.ts delete mode 100644 ts.out/config.js delete mode 100644 ts.out/ecr-codecommit/bin/index.d.ts delete mode 100644 ts.out/ecr-codecommit/bin/index.js delete mode 100644 ts.out/ecr-codecommit/lib/ecr-codecommit-stack.d.ts delete mode 100644 ts.out/ecr-codecommit/lib/ecr-codecommit-stack.js delete mode 100644 ts.out/ecs-fargate-cluster/bin/index.d.ts delete mode 100644 ts.out/ecs-fargate-cluster/bin/index.js delete mode 100644 ts.out/ecs-fargate-cluster/lib/cluster-config.d.ts delete mode 100644 ts.out/ecs-fargate-cluster/lib/cluster-config.js delete mode 100644 ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.d.ts delete mode 100644 ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.js delete mode 100644 ts.out/ecs-fargate-service-restapi/bin/index.d.ts delete mode 100644 ts.out/ecs-fargate-service-restapi/bin/index.js delete mode 100644 ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.d.ts delete mode 100644 ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.js delete mode 100644 ts.out/ecs-fargatespot-service-restapi/bin/index.d.ts delete mode 100644 ts.out/ecs-fargatespot-service-restapi/bin/index.js delete mode 100644 ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.d.ts delete mode 100644 ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.js delete mode 100644 ts.out/ecs-iam-role/bin/index.d.ts delete mode 100644 ts.out/ecs-iam-role/bin/index.js delete mode 100644 ts.out/ecs-iam-role/lib/ecs-iam-role-stack.d.ts delete mode 100644 ts.out/ecs-iam-role/lib/ecs-iam-role-stack.js delete mode 100644 ts.out/vpc/bin/index.d.ts delete mode 100644 ts.out/vpc/bin/index.js delete mode 100644 ts.out/vpc/lib/vpc-stack.d.ts delete mode 100644 ts.out/vpc/lib/vpc-stack.js diff --git a/.gitignore b/.gitignore index 2c83b75..b09f9b6 100644 --- a/.gitignore +++ b/.gitignore @@ -28,6 +28,7 @@ **/cdk.out **/cdk.context.json **/cdk-outputs.json +**/ts.out #------------------- diff --git a/ts.out/code-pipeline/bin/index.d.ts b/ts.out/code-pipeline/bin/index.d.ts deleted file mode 100644 index b798801..0000000 --- a/ts.out/code-pipeline/bin/index.d.ts +++ /dev/null @@ -1,2 +0,0 @@ -#!/usr/bin/env node -export {}; diff --git a/ts.out/code-pipeline/bin/index.js b/ts.out/code-pipeline/bin/index.js deleted file mode 100644 index dfbc643..0000000 --- a/ts.out/code-pipeline/bin/index.js +++ /dev/null @@ -1,40 +0,0 @@ -#!/usr/bin/env node -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -const cdk = __importStar(require("aws-cdk-lib")); -const config_1 = require("../../config"); -const ecs_codedeploy_stack_1 = require("../lib/ecs-codedeploy-stack"); -const app = new cdk.App(); -const env = { - account: process.env.CDK_DEFAULT_ACCOUNT, - region: process.env.CDK_DEFAULT_REGION, -}; -const stage = app.node.tryGetContext('stage') || config_1.DEFAULT_STAGE; -const serviceName = 'fargate-restapi'; -new ecs_codedeploy_stack_1.EcsCodeDeployStack(app, `codepipeline-${serviceName}-${stage}`, { - env, - stage, - serviceName, - description: `Code Pipeline, service name: ${serviceName}-${stage}`, - terminationProtection: stage !== config_1.DEFAULT_STAGE -}); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9jb2RlLXBpcGVsaW5lL2Jpbi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQ0EsaURBQW1DO0FBQ25DLHlDQUE2QztBQUM3QyxzRUFBaUU7QUFFakUsTUFBTSxHQUFHLEdBQUcsSUFBSSxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUM7QUFDMUIsTUFBTSxHQUFHLEdBQUc7SUFDUixPQUFPLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxtQkFBbUI7SUFDeEMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCO0NBQ3pDLENBQUM7QUFDRixNQUFNLEtBQUssR0FBRyxHQUFHLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsSUFBSSxzQkFBYSxDQUFDO0FBRS9ELE1BQU0sV0FBVyxHQUFHLGlCQUFpQixDQUFDO0FBRXRDLElBQUkseUNBQWtCLENBQUMsR0FBRyxFQUFFLGdCQUFnQixXQUFXLElBQUksS0FBSyxFQUFFLEVBQUU7SUFDaEUsR0FBRztJQUNILEtBQUs7SUFDTCxXQUFXO0lBQ1gsV0FBVyxFQUFFLGdDQUFnQyxXQUFXLElBQUksS0FBSyxFQUFFO0lBQ25FLHFCQUFxQixFQUFFLEtBQUssS0FBRyxzQkFBYTtDQUMvQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIjIS91c3IvYmluL2VudiBub2RlXG5pbXBvcnQgKiBhcyBjZGsgZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0IHsgREVGQVVMVF9TVEFHRSB9IGZyb20gJy4uLy4uL2NvbmZpZyc7XG5pbXBvcnQgeyBFY3NDb2RlRGVwbG95U3RhY2sgfSBmcm9tICcuLi9saWIvZWNzLWNvZGVkZXBsb3ktc3RhY2snO1xuXG5jb25zdCBhcHAgPSBuZXcgY2RrLkFwcCgpO1xuY29uc3QgZW52ID0ge1xuICAgIGFjY291bnQ6IHByb2Nlc3MuZW52LkNES19ERUZBVUxUX0FDQ09VTlQsXG4gICAgcmVnaW9uOiBwcm9jZXNzLmVudi5DREtfREVGQVVMVF9SRUdJT04sXG59O1xuY29uc3Qgc3RhZ2UgPSBhcHAubm9kZS50cnlHZXRDb250ZXh0KCdzdGFnZScpIHx8IERFRkFVTFRfU1RBR0U7XG5cbmNvbnN0IHNlcnZpY2VOYW1lID0gJ2ZhcmdhdGUtcmVzdGFwaSc7XG5cbm5ldyBFY3NDb2RlRGVwbG95U3RhY2soYXBwLCBgY29kZXBpcGVsaW5lLSR7c2VydmljZU5hbWV9LSR7c3RhZ2V9YCwge1xuICAgIGVudixcbiAgICBzdGFnZSxcbiAgICBzZXJ2aWNlTmFtZSxcbiAgICBkZXNjcmlwdGlvbjogYENvZGUgUGlwZWxpbmUsIHNlcnZpY2UgbmFtZTogJHtzZXJ2aWNlTmFtZX0tJHtzdGFnZX1gLFxuICAgIHRlcm1pbmF0aW9uUHJvdGVjdGlvbjogc3RhZ2UhPT1ERUZBVUxUX1NUQUdFXG59KTtcbiJdfQ== \ No newline at end of file diff --git a/ts.out/code-pipeline/lib/ecs-codedeploy-stack.d.ts b/ts.out/code-pipeline/lib/ecs-codedeploy-stack.d.ts deleted file mode 100644 index 5aeeb21..0000000 --- a/ts.out/code-pipeline/lib/ecs-codedeploy-stack.d.ts +++ /dev/null @@ -1,17 +0,0 @@ -import { Stack, StackProps } from 'aws-cdk-lib'; -import { Construct } from 'constructs'; -export interface EcsCodeDeployStackProps extends StackProps { - stage: string; - serviceName: string; -} -/** - * SSM parameters: - * /cdk-ecs-fargate/ecr-repo-arn - * /cdk-ecs-fargate/ecr-repo-name - * /cdk-ecs-fargate/cluster-securitygroup-id - * /cdk-ecs-fargate/cluster-name - * /cdk-ecs-fargate/codecommit-arn - */ -export declare class EcsCodeDeployStack extends Stack { - constructor(scope: Construct, id: string, props: EcsCodeDeployStackProps); -} diff --git a/ts.out/code-pipeline/lib/ecs-codedeploy-stack.js b/ts.out/code-pipeline/lib/ecs-codedeploy-stack.js deleted file mode 100644 index bed7e38..0000000 --- a/ts.out/code-pipeline/lib/ecs-codedeploy-stack.js +++ /dev/null @@ -1,149 +0,0 @@ -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.EcsCodeDeployStack = void 0; -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const cdk = __importStar(require("aws-cdk-lib")); -const ssm = __importStar(require("aws-cdk-lib/aws-ssm")); -const ecr = __importStar(require("aws-cdk-lib/aws-ecr")); -const ec2 = __importStar(require("aws-cdk-lib/aws-ec2")); -const ecs = __importStar(require("aws-cdk-lib/aws-ecs")); -const iam = __importStar(require("aws-cdk-lib/aws-iam")); -const codebuild = __importStar(require("aws-cdk-lib/aws-codebuild")); -const codepipeline = __importStar(require("aws-cdk-lib/aws-codepipeline")); -const codecommit = __importStar(require("aws-cdk-lib/aws-codecommit")); -const codepipeline_actions = __importStar(require("aws-cdk-lib/aws-codepipeline-actions")); -const cluster_config_1 = require("../../ecs-fargate-cluster/lib/cluster-config"); -const config_1 = require("../../config"); -/** - * SSM parameters: - * /cdk-ecs-fargate/ecr-repo-arn - * /cdk-ecs-fargate/ecr-repo-name - * /cdk-ecs-fargate/cluster-securitygroup-id - * /cdk-ecs-fargate/cluster-name - * /cdk-ecs-fargate/codecommit-arn - */ -class EcsCodeDeployStack extends aws_cdk_lib_1.Stack { - constructor(scope, id, props) { - var _a, _b; - super(scope, id, props); - const ecrRepo = ecr.Repository.fromRepositoryAttributes(this, 'ecr-repo', { - repositoryArn: cdk.Lazy.string({ produce: () => ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/ecr-repo-arn`) }), - repositoryName: ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/ecr-repo-name`) - }); - const vpcId = this.node.tryGetContext('vpcId') || ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/vpc-id`); - const vpc = ec2.Vpc.fromLookup(this, 'vpc', { vpcId }); - const clusterSgId = ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/cluster-securitygroup-id`); - const ecsSecurityGroup = ec2.SecurityGroup.fromSecurityGroupId(this, 'ecs-security-group', clusterSgId); - const cluster = ecs.Cluster.fromClusterAttributes(this, 'ecs-fargate-cluster', { - clusterName: `${cluster_config_1.CLUSTER_NAME}-${props.stage}`, - vpc, - securityGroups: [ecsSecurityGroup] - }); - const service = ecs.FargateService.fromFargateServiceAttributes(this, 'fargate-cluster', { - cluster, - serviceName: cdk.Lazy.string({ produce: () => ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/cluster-name`) }) - }); - const serviceName = props.serviceName; - const repository = codecommit.Repository.fromRepositoryArn(this, `${serviceName}-codecommit-arn`, cdk.Lazy.string({ produce: () => ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/codecommit-arn`) })); - /** - * buildImage: codebuild.LinuxBuildImage.AMAZON_LINUX_2_4, - * buildImage: codebuild.LinuxBuildImage.fromDockerRegistry('public.ecr.aws/h1a5s9h8/alpine:latest') - */ - const project = new codebuild.Project(this, `cb-project-${serviceName}`, { - projectName: `${serviceName}-build`, - source: codebuild.Source.codeCommit({ repository }), - environment: { - buildImage: codebuild.LinuxBuildImage.STANDARD_6_0, - privileged: true - }, - buildSpec: codebuild.BuildSpec.fromSourceFilename('./buildspec.yaml'), - badge: true, - environmentVariables: { - 'ACCOUNT_ID': { - value: (_a = props === null || props === void 0 ? void 0 : props.env) === null || _a === void 0 ? void 0 : _a.account - }, - 'CLUSTER_NAME': { - value: `${service.cluster.clusterName}` - }, - 'SERVICE_NAME': { - value: `${service.serviceName}` - }, - 'ECR_REPO_URI': { - value: `${ecrRepo.repositoryUri}` - } - } - }); - ecrRepo.grantPullPush(project.role); - (_b = project.role) === null || _b === void 0 ? void 0 : _b.addManagedPolicy(iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonEC2ContainerRegistryPowerUser')); - const sourceOutput = new codepipeline.Artifact(); - const buildOutput = new codepipeline.Artifact(); - /** - * aws secretsmanager create-secret --name '/github/token' --secret-string {your-token} - * or set the token with oauthToken: cdk.SecretValue.plainText(''), - */ - const sourceAction = new codepipeline_actions.GitHubSourceAction({ - actionName: 'GitHub_Source', - owner: 'engel80', - repo: 'fargate-restapi-local', - branch: 'master', - oauthToken: cdk.SecretValue.secretsManager("/github/token"), - output: sourceOutput - }); - const buildAction = new codepipeline_actions.CodeBuildAction({ - actionName: 'CodeBuild', - project, - input: sourceOutput, - outputs: [buildOutput], - }); - const manualApprovalAction = new codepipeline_actions.ManualApprovalAction({ - actionName: 'Approve', - }); - const deployAction = new codepipeline_actions.EcsDeployAction({ - actionName: 'DeployAction', - service: service, - imageFile: new codepipeline.ArtifactPath(buildOutput, `imagedefinitions.json`) - }); - new codepipeline.Pipeline(this, 'ecs-deploy-pipeline', { - pipelineName: `ecs-deploy-${service.serviceName}`, - stages: [ - { - stageName: 'Source', - actions: [sourceAction], - }, - { - stageName: 'Build', - actions: [buildAction], - }, - { - stageName: 'Approve', - actions: [manualApprovalAction], - }, - { - stageName: 'Deploy', - actions: [deployAction], - } - ] - }); - } -} -exports.EcsCodeDeployStack = EcsCodeDeployStack; -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecs-codedeploy-stack.js","sourceRoot":"","sources":["../../../code-pipeline/lib/ecs-codedeploy-stack.ts"],"names":[],"mappings":"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","sourcesContent":["import { Stack, StackProps } from 'aws-cdk-lib';\nimport * as cdk from 'aws-cdk-lib';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\n\nimport * as ecr from 'aws-cdk-lib/aws-ecr';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as codebuild from 'aws-cdk-lib/aws-codebuild';\nimport * as codepipeline from 'aws-cdk-lib/aws-codepipeline';\nimport * as codecommit from 'aws-cdk-lib/aws-codecommit';\nimport * as codepipeline_actions from 'aws-cdk-lib/aws-codepipeline-actions';\n\nimport { Construct } from 'constructs';\n\nimport { CLUSTER_NAME } from '../../ecs-fargate-cluster/lib/cluster-config';\nimport { SSM_PREFIX } from '../../config';\nimport { IBaseService } from 'aws-cdk-lib/aws-ecs';\n\nexport interface EcsCodeDeployStackProps extends StackProps {\n    stage: string;\n    serviceName: string;\n}\n/**\n * SSM parameters:\n * /cdk-ecs-fargate/ecr-repo-arn\n * /cdk-ecs-fargate/ecr-repo-name\n * /cdk-ecs-fargate/cluster-securitygroup-id\n * /cdk-ecs-fargate/cluster-name\n * /cdk-ecs-fargate/codecommit-arn\n */\nexport class EcsCodeDeployStack extends Stack {\n    constructor(scope: Construct, id: string, props: EcsCodeDeployStackProps) {\n        super(scope, id, props);\n\n        const ecrRepo = ecr.Repository.fromRepositoryAttributes(this, 'ecr-repo', {\n            repositoryArn: cdk.Lazy.string({ produce: () => ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/ecr-repo-arn`) }),\n            repositoryName: ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/ecr-repo-name`)\n        });\n\n        const vpcId = this.node.tryGetContext('vpcId') || ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/vpc-id`);\n        const vpc = ec2.Vpc.fromLookup(this, 'vpc', { vpcId });\n        const clusterSgId = ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/cluster-securitygroup-id`);\n        const ecsSecurityGroup = ec2.SecurityGroup.fromSecurityGroupId(this, 'ecs-security-group', clusterSgId);\n\n        const cluster = ecs.Cluster.fromClusterAttributes(this, 'ecs-fargate-cluster', {\n            clusterName: `${CLUSTER_NAME}-${props.stage}`,\n            vpc,\n            securityGroups: [ecsSecurityGroup]\n        });\n        const service = ecs.FargateService.fromFargateServiceAttributes(this, 'fargate-cluster', {\n            cluster,\n            serviceName: cdk.Lazy.string({ produce: () => ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/cluster-name`) })\n        }) as IBaseService;\n\n        const serviceName = props.serviceName;\n        const repository = codecommit.Repository.fromRepositoryArn(this, `${serviceName}-codecommit-arn`,\n            cdk.Lazy.string({ produce: () => ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/codecommit-arn`) }));\n\n        /**\n         * buildImage: codebuild.LinuxBuildImage.AMAZON_LINUX_2_4,\n         * buildImage: codebuild.LinuxBuildImage.fromDockerRegistry('public.ecr.aws/h1a5s9h8/alpine:latest')\n         */\n        const project = new codebuild.Project(this, `cb-project-${serviceName}`, {\n            projectName: `${serviceName}-build`,\n            source: codebuild.Source.codeCommit({ repository }),\n            environment: {\n                buildImage: codebuild.LinuxBuildImage.STANDARD_6_0,\n                privileged: true\n            },\n            buildSpec: codebuild.BuildSpec.fromSourceFilename('./buildspec.yaml'),\n            badge: true,\n            environmentVariables: {\n                'ACCOUNT_ID': {\n                    value: props?.env?.account\n                },\n                'CLUSTER_NAME': {\n                    value: `${service.cluster.clusterName}`\n                },\n                'SERVICE_NAME': {\n                    value: `${service.serviceName}`\n                },\n                'ECR_REPO_URI': {\n                    value: `${ecrRepo.repositoryUri}`\n                }\n            }\n        });\n        ecrRepo.grantPullPush(project.role!);\n        project.role?.addManagedPolicy(iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonEC2ContainerRegistryPowerUser'));\n\n        const sourceOutput = new codepipeline.Artifact();\n        const buildOutput = new codepipeline.Artifact();\n\n        /**\n         * aws secretsmanager create-secret --name '/github/token' --secret-string {your-token}\n         * or set the token with oauthToken: cdk.SecretValue.plainText('<plain-text>'),\n         */\n        const sourceAction = new codepipeline_actions.GitHubSourceAction({\n            actionName: 'GitHub_Source',\n            owner: 'engel80',\n            repo: 'fargate-restapi-local',\n            branch: 'master',\n            oauthToken: cdk.SecretValue.secretsManager(\"/github/token\"),\n            output: sourceOutput\n        });\n\n        const buildAction = new codepipeline_actions.CodeBuildAction({\n            actionName: 'CodeBuild',\n            project,\n            input: sourceOutput,\n            outputs: [buildOutput],\n        });\n        const manualApprovalAction = new codepipeline_actions.ManualApprovalAction({\n            actionName: 'Approve',\n        });\n        const deployAction = new codepipeline_actions.EcsDeployAction({\n            actionName: 'DeployAction',\n            service: service,\n            imageFile: new codepipeline.ArtifactPath(buildOutput, `imagedefinitions.json`)\n        });\n\n        new codepipeline.Pipeline(this, 'ecs-deploy-pipeline', {\n            pipelineName: `ecs-deploy-${service.serviceName}`,\n            stages: [\n                {\n                    stageName: 'Source',\n                    actions: [sourceAction],\n                },\n                {\n                    stageName: 'Build',\n                    actions: [buildAction],\n                },\n                {\n                    stageName: 'Approve',\n                    actions: [manualApprovalAction],\n                },\n                {\n                    stageName: 'Deploy',\n                    actions: [deployAction],\n                }\n            ]\n        });\n    }\n}\n"]} \ No newline at end of file diff --git a/ts.out/config.d.ts b/ts.out/config.d.ts deleted file mode 100644 index 316142e..0000000 --- a/ts.out/config.d.ts +++ /dev/null @@ -1,18 +0,0 @@ -import * as cdk from 'aws-cdk-lib'; -/** - * /cdk-ecs-fargate/vpc-id - * - * ecs-fargate-cluster: - * /cdk-ecs-fargate/cluster-capacityprovider-name - * /cdk-ecs-fargate/cluster-securitygroup-id - * - * iam-role: - * /cdk-ecs-fargate/task-execution-role-arn - * /cdk-ecs-fargate/default-task-role-arn - * - */ -export declare const SSM_PREFIX = "/cdk-ecs-fargate"; -export declare const DEFAULT_STAGE = "dev"; -export interface StackCommonProps extends cdk.StackProps { - stage: string; -} diff --git a/ts.out/config.js b/ts.out/config.js deleted file mode 100644 index 75adcb3..0000000 --- a/ts.out/config.js +++ /dev/null @@ -1,18 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.DEFAULT_STAGE = exports.SSM_PREFIX = void 0; -/** - * /cdk-ecs-fargate/vpc-id - * - * ecs-fargate-cluster: - * /cdk-ecs-fargate/cluster-capacityprovider-name - * /cdk-ecs-fargate/cluster-securitygroup-id - * - * iam-role: - * /cdk-ecs-fargate/task-execution-role-arn - * /cdk-ecs-fargate/default-task-role-arn - * - */ -exports.SSM_PREFIX = '/cdk-ecs-fargate'; -exports.DEFAULT_STAGE = 'dev'; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBOzs7Ozs7Ozs7OztHQVdHO0FBQ1UsUUFBQSxVQUFVLEdBQUcsa0JBQWtCLENBQUM7QUFHaEMsUUFBQSxhQUFhLEdBQUcsS0FBSyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgY2RrIGZyb20gJ2F3cy1jZGstbGliJztcblxuLyoqXG4gKiAvY2RrLWVjcy1mYXJnYXRlL3ZwYy1pZFxuICogXG4gKiBlY3MtZmFyZ2F0ZS1jbHVzdGVyOlxuICogICAvY2RrLWVjcy1mYXJnYXRlL2NsdXN0ZXItY2FwYWNpdHlwcm92aWRlci1uYW1lXG4gKiAgIC9jZGstZWNzLWZhcmdhdGUvY2x1c3Rlci1zZWN1cml0eWdyb3VwLWlkXG4gKiBcbiAqIGlhbS1yb2xlOlxuICogICAvY2RrLWVjcy1mYXJnYXRlL3Rhc2stZXhlY3V0aW9uLXJvbGUtYXJuXG4gKiAgIC9jZGstZWNzLWZhcmdhdGUvZGVmYXVsdC10YXNrLXJvbGUtYXJuXG4gKiBcbiAqL1xuZXhwb3J0IGNvbnN0IFNTTV9QUkVGSVggPSAnL2Nkay1lY3MtZmFyZ2F0ZSc7XG5cblxuZXhwb3J0IGNvbnN0IERFRkFVTFRfU1RBR0UgPSAnZGV2JztcblxuZXhwb3J0IGludGVyZmFjZSBTdGFja0NvbW1vblByb3BzIGV4dGVuZHMgY2RrLlN0YWNrUHJvcHMge1xuICAgIHN0YWdlOiBzdHJpbmc7XG59Il19 \ No newline at end of file diff --git a/ts.out/ecr-codecommit/bin/index.d.ts b/ts.out/ecr-codecommit/bin/index.d.ts deleted file mode 100644 index b798801..0000000 --- a/ts.out/ecr-codecommit/bin/index.d.ts +++ /dev/null @@ -1,2 +0,0 @@ -#!/usr/bin/env node -export {}; diff --git a/ts.out/ecr-codecommit/bin/index.js b/ts.out/ecr-codecommit/bin/index.js deleted file mode 100644 index 86d1cb0..0000000 --- a/ts.out/ecr-codecommit/bin/index.js +++ /dev/null @@ -1,40 +0,0 @@ -#!/usr/bin/env node -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -const cdk = __importStar(require("aws-cdk-lib")); -const ecr_codecommit_stack_1 = require("../lib/ecr-codecommit-stack"); -const config_1 = require("../../config"); -const app = new cdk.App(); -const env = { - account: process.env.CDK_DEFAULT_ACCOUNT, - region: process.env.CDK_DEFAULT_REGION -}; -const stage = app.node.tryGetContext('stage') || config_1.DEFAULT_STAGE; -const serviceName = `fargate-restapi-${stage}`; -new ecr_codecommit_stack_1.EcrCodeCommitStack(app, `ecr-${serviceName}`, { - env, - stage, - serviceName, - description: `ECR: ${serviceName}`, - terminationProtection: stage !== config_1.DEFAULT_STAGE -}); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9lY3ItY29kZWNvbW1pdC9iaW4vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUNBLGlEQUFtQztBQUNuQyxzRUFBaUU7QUFDakUseUNBQTZDO0FBRTdDLE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO0FBQzFCLE1BQU0sR0FBRyxHQUFHO0lBQ1IsT0FBTyxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsbUJBQW1CO0lBQ3hDLE1BQU0sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQjtDQUN6QyxDQUFDO0FBQ0YsTUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLElBQUksc0JBQWEsQ0FBQztBQUMvRCxNQUFNLFdBQVcsR0FBRyxtQkFBbUIsS0FBSyxFQUFFLENBQUE7QUFFOUMsSUFBSSx5Q0FBa0IsQ0FBQyxHQUFHLEVBQUUsT0FBTyxXQUFXLEVBQUUsRUFBRTtJQUM5QyxHQUFHO0lBQ0gsS0FBSztJQUNMLFdBQVc7SUFDWCxXQUFXLEVBQUUsUUFBUSxXQUFXLEVBQUU7SUFDbEMscUJBQXFCLEVBQUUsS0FBSyxLQUFHLHNCQUFhO0NBQy9DLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIiMhL3Vzci9iaW4vZW52IG5vZGVcclxuaW1wb3J0ICogYXMgY2RrIGZyb20gJ2F3cy1jZGstbGliJztcclxuaW1wb3J0IHsgRWNyQ29kZUNvbW1pdFN0YWNrIH0gZnJvbSAnLi4vbGliL2Vjci1jb2RlY29tbWl0LXN0YWNrJztcclxuaW1wb3J0IHsgREVGQVVMVF9TVEFHRSB9IGZyb20gJy4uLy4uL2NvbmZpZyc7XHJcblxyXG5jb25zdCBhcHAgPSBuZXcgY2RrLkFwcCgpO1xyXG5jb25zdCBlbnYgPSB7XHJcbiAgICBhY2NvdW50OiBwcm9jZXNzLmVudi5DREtfREVGQVVMVF9BQ0NPVU5ULFxyXG4gICAgcmVnaW9uOiBwcm9jZXNzLmVudi5DREtfREVGQVVMVF9SRUdJT05cclxufTtcclxuY29uc3Qgc3RhZ2UgPSBhcHAubm9kZS50cnlHZXRDb250ZXh0KCdzdGFnZScpIHx8IERFRkFVTFRfU1RBR0U7XHJcbmNvbnN0IHNlcnZpY2VOYW1lID0gYGZhcmdhdGUtcmVzdGFwaS0ke3N0YWdlfWBcclxuXHJcbm5ldyBFY3JDb2RlQ29tbWl0U3RhY2soYXBwLCBgZWNyLSR7c2VydmljZU5hbWV9YCwge1xyXG4gICAgZW52LFxyXG4gICAgc3RhZ2UsXHJcbiAgICBzZXJ2aWNlTmFtZSxcclxuICAgIGRlc2NyaXB0aW9uOiBgRUNSOiAke3NlcnZpY2VOYW1lfWAsXHJcbiAgICB0ZXJtaW5hdGlvblByb3RlY3Rpb246IHN0YWdlIT09REVGQVVMVF9TVEFHRVxyXG59KTtcclxuIl19 \ No newline at end of file diff --git a/ts.out/ecr-codecommit/lib/ecr-codecommit-stack.d.ts b/ts.out/ecr-codecommit/lib/ecr-codecommit-stack.d.ts deleted file mode 100644 index c120464..0000000 --- a/ts.out/ecr-codecommit/lib/ecr-codecommit-stack.d.ts +++ /dev/null @@ -1,12 +0,0 @@ -import { Construct } from 'constructs'; -import { Stack } from 'aws-cdk-lib'; -import { StackCommonProps } from '../../config'; -export interface EcrStackProps extends StackCommonProps { - serviceName: string; -} -/** - * Build 'app/Dockerfile' and push to ECR for X86 and ARM - */ -export declare class EcrCodeCommitStack extends Stack { - constructor(scope: Construct, id: string, props: EcrStackProps); -} diff --git a/ts.out/ecr-codecommit/lib/ecr-codecommit-stack.js b/ts.out/ecr-codecommit/lib/ecr-codecommit-stack.js deleted file mode 100644 index 4817230..0000000 --- a/ts.out/ecr-codecommit/lib/ecr-codecommit-stack.js +++ /dev/null @@ -1,77 +0,0 @@ -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.EcrCodeCommitStack = void 0; -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const path = __importStar(require("path")); -const codecommit = __importStar(require("aws-cdk-lib/aws-codecommit")); -const ssm = __importStar(require("aws-cdk-lib/aws-ssm")); -const ecr = __importStar(require("aws-cdk-lib/aws-ecr")); -const assets = __importStar(require("aws-cdk-lib/aws-ecr-assets")); -const ecrdeploy = __importStar(require("cdk-ecr-deployment")); -const config_1 = require("../../config"); -/** - * Build 'app/Dockerfile' and push to ECR for X86 and ARM - */ -class EcrCodeCommitStack extends aws_cdk_lib_1.Stack { - constructor(scope, id, props) { - super(scope, id, props); - const stage = props.stage; - const serviceName = props.serviceName; - const assetX86 = new assets.DockerImageAsset(this, 'ecr-image-x86', { - directory: path.join(__dirname, "../../", "app") - }); - const ecrRepo = new ecr.Repository(this, `${serviceName}`, { - repositoryName: `${serviceName}` - }); - new ecrdeploy.ECRDeployment(this, 'ecr-deploy-x86', { - src: new ecrdeploy.DockerImageName(assetX86.imageUri), - dest: new ecrdeploy.DockerImageName(`${ecrRepo.repositoryUriForTag('latest')}`), - }); - const assetArm = new assets.DockerImageAsset(this, 'ecr-image-arm', { - directory: path.join(__dirname, "../../", "app"), - platform: assets.Platform.LINUX_ARM64, - }); - const ecrArmRepo = new ecr.Repository(this, `${serviceName}-arm`, { - repositoryName: `${serviceName}-arm` - }); - new ecrdeploy.ECRDeployment(this, 'ecr-deploy-arm', { - src: new ecrdeploy.DockerImageName(assetArm.imageUri), - dest: new ecrdeploy.DockerImageName(`${ecrArmRepo.repositoryUriForTag('latest')}`), - }); - const codecommitRepo = new codecommit.Repository(this, `${serviceName}-codecommit`, { - repositoryName: `${serviceName}` - }); - aws_cdk_lib_1.Tags.of(codecommitRepo).add('Stage', stage); - aws_cdk_lib_1.Tags.of(ecrRepo).add('Stage', stage); - aws_cdk_lib_1.Tags.of(ecrArmRepo).add('Stage', stage); - new aws_cdk_lib_1.CfnOutput(this, 'URI', { value: ecrRepo.repositoryUri }); - new aws_cdk_lib_1.CfnOutput(this, 'URIARM', { value: ecrArmRepo.repositoryUri }); - new ssm.StringParameter(this, 'ssm-codecommit-arn', { parameterName: `${config_1.SSM_PREFIX}/codecommit-arn`, stringValue: codecommitRepo.repositoryArn }); - new ssm.StringParameter(this, 'ssm-ecr-repo-name', { parameterName: `${config_1.SSM_PREFIX}/ecr-repo-name`, stringValue: ecrRepo.repositoryName }); - new ssm.StringParameter(this, 'ssm-ecr-repo-arn', { parameterName: `${config_1.SSM_PREFIX}/ecr-repo-arn`, stringValue: ecrRepo.repositoryArn }); - new ssm.StringParameter(this, 'ssm-ecr-armrepo-name', { parameterName: `${config_1.SSM_PREFIX}/ecr-armrepo-name`, stringValue: ecrArmRepo.repositoryUri }); - new ssm.StringParameter(this, 'ssm-ecr-armrepo-arn', { parameterName: `${config_1.SSM_PREFIX}/ecr-armrepo-arn`, stringValue: ecrArmRepo.repositoryArn }); - new aws_cdk_lib_1.CfnOutput(this, 'CodeCommitRepoUrl', { value: codecommitRepo.repositoryCloneUrlHttp }); - } -} -exports.EcrCodeCommitStack = EcrCodeCommitStack; -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecr-codecommit-stack.js","sourceRoot":"","sources":["../../../ecr-codecommit/lib/ecr-codecommit-stack.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from 'constructs';\r\nimport { Stack, CfnOutput, Tags } from 'aws-cdk-lib';\r\nimport * as path from 'path';\r\nimport * as codecommit from 'aws-cdk-lib/aws-codecommit';\r\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\r\nimport * as ecr from 'aws-cdk-lib/aws-ecr';\r\nimport * as assets from 'aws-cdk-lib/aws-ecr-assets';\r\nimport * as ecrdeploy from 'cdk-ecr-deployment';\r\n\r\nimport { StackCommonProps, SSM_PREFIX } from '../../config';\r\n\r\nexport interface EcrStackProps extends StackCommonProps {\r\n    serviceName: string;\r\n}\r\n/**\r\n * Build 'app/Dockerfile' and push to ECR for X86 and ARM\r\n */\r\nexport class EcrCodeCommitStack extends Stack {\r\n    constructor(scope: Construct, id: string, props: EcrStackProps) {\r\n        super(scope, id, props);\r\n\r\n        const stage = props.stage;\r\n        const serviceName = props.serviceName;\r\n\r\n        const assetX86 = new assets.DockerImageAsset(this, 'ecr-image-x86', {\r\n            directory: path.join(__dirname, \"../../\", \"app\")\r\n        });\r\n        const ecrRepo = new ecr.Repository(this, `${serviceName}`, {\r\n            repositoryName: `${serviceName}`\r\n        });\r\n        new ecrdeploy.ECRDeployment(this, 'ecr-deploy-x86', {\r\n            src: new ecrdeploy.DockerImageName(assetX86.imageUri),\r\n            dest: new ecrdeploy.DockerImageName(`${ecrRepo.repositoryUriForTag('latest')}`),\r\n        });\r\n\r\n        const assetArm = new assets.DockerImageAsset(this, 'ecr-image-arm', {\r\n            directory: path.join(__dirname, \"../../\", \"app\"),\r\n            platform: assets.Platform.LINUX_ARM64,\r\n        });\r\n        const ecrArmRepo = new ecr.Repository(this, `${serviceName}-arm`, {\r\n            repositoryName: `${serviceName}-arm`\r\n        });\r\n        new ecrdeploy.ECRDeployment(this, 'ecr-deploy-arm', {\r\n            src: new ecrdeploy.DockerImageName(assetArm.imageUri),\r\n            dest: new ecrdeploy.DockerImageName(`${ecrArmRepo.repositoryUriForTag('latest')}`),\r\n        });\r\n\r\n        const codecommitRepo = new codecommit.Repository(this, `${serviceName}-codecommit`, {\r\n            repositoryName: `${serviceName}`\r\n        });\r\n\r\n        Tags.of(codecommitRepo).add('Stage', stage);\r\n        Tags.of(ecrRepo).add('Stage', stage);\r\n        Tags.of(ecrArmRepo).add('Stage', stage);\r\n\r\n        new CfnOutput(this, 'URI', { value: ecrRepo.repositoryUri });\r\n        new CfnOutput(this, 'URIARM', { value: ecrArmRepo.repositoryUri });\r\n\r\n        new ssm.StringParameter(this, 'ssm-codecommit-arn', { parameterName: `${SSM_PREFIX}/codecommit-arn`, stringValue: codecommitRepo.repositoryArn });\r\n\r\n        new ssm.StringParameter(this, 'ssm-ecr-repo-name', { parameterName: `${SSM_PREFIX}/ecr-repo-name`, stringValue: ecrRepo.repositoryName });\r\n        new ssm.StringParameter(this, 'ssm-ecr-repo-arn', { parameterName: `${SSM_PREFIX}/ecr-repo-arn`, stringValue: ecrRepo.repositoryArn });\r\n        new ssm.StringParameter(this, 'ssm-ecr-armrepo-name', { parameterName: `${SSM_PREFIX}/ecr-armrepo-name`, stringValue: ecrArmRepo.repositoryUri });\r\n        new ssm.StringParameter(this, 'ssm-ecr-armrepo-arn', { parameterName: `${SSM_PREFIX}/ecr-armrepo-arn`, stringValue: ecrArmRepo.repositoryArn });\r\n\r\n        new CfnOutput(this, 'CodeCommitRepoUrl', { value: codecommitRepo.repositoryCloneUrlHttp });\r\n    }\r\n}\r\n"]} \ No newline at end of file diff --git a/ts.out/ecs-fargate-cluster/bin/index.d.ts b/ts.out/ecs-fargate-cluster/bin/index.d.ts deleted file mode 100644 index b798801..0000000 --- a/ts.out/ecs-fargate-cluster/bin/index.d.ts +++ /dev/null @@ -1,2 +0,0 @@ -#!/usr/bin/env node -export {}; diff --git a/ts.out/ecs-fargate-cluster/bin/index.js b/ts.out/ecs-fargate-cluster/bin/index.js deleted file mode 100644 index f4eb09f..0000000 --- a/ts.out/ecs-fargate-cluster/bin/index.js +++ /dev/null @@ -1,39 +0,0 @@ -#!/usr/bin/env node -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -const cdk = __importStar(require("aws-cdk-lib")); -const config_1 = require("../../config"); -const cluster_config_1 = require("../lib/cluster-config"); -const ecs_fargate_cluster_stack_1 = require("../lib/ecs-fargate-cluster-stack"); -const app = new cdk.App(); -const env = { - account: process.env.CDK_DEFAULT_ACCOUNT, - region: process.env.CDK_DEFAULT_REGION, -}; -const stage = app.node.tryGetContext('stage') || config_1.DEFAULT_STAGE; -new ecs_fargate_cluster_stack_1.EcsFargateClusterStack(app, `ecs-fargate-cluster-${cluster_config_1.CLUSTER_NAME}-${stage}`, { - env, - stage, - description: `ECS Fargate cluster, cluster name: ${cluster_config_1.CLUSTER_NAME}-${stage}`, - terminationProtection: stage !== config_1.DEFAULT_STAGE -}); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9lY3MtZmFyZ2F0ZS1jbHVzdGVyL2Jpbi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQ0EsaURBQW1DO0FBRW5DLHlDQUE2QztBQUM3QywwREFBcUQ7QUFDckQsZ0ZBQTBFO0FBRTFFLE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO0FBQzFCLE1BQU0sR0FBRyxHQUFHO0lBQ1IsT0FBTyxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsbUJBQW1CO0lBQ3hDLE1BQU0sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQjtDQUN6QyxDQUFDO0FBQ0YsTUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLElBQUksc0JBQWEsQ0FBQztBQUUvRCxJQUFJLGtEQUFzQixDQUFDLEdBQUcsRUFBRSx1QkFBdUIsNkJBQVksSUFBSSxLQUFLLEVBQUUsRUFBRTtJQUM1RSxHQUFHO0lBQ0gsS0FBSztJQUNMLFdBQVcsRUFBRSxzQ0FBc0MsNkJBQVksSUFBSSxLQUFLLEVBQUU7SUFDMUUscUJBQXFCLEVBQUUsS0FBSyxLQUFHLHNCQUFhO0NBQy9DLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIiMhL3Vzci9iaW4vZW52IG5vZGVcbmltcG9ydCAqIGFzIGNkayBmcm9tICdhd3MtY2RrLWxpYic7XG5cbmltcG9ydCB7IERFRkFVTFRfU1RBR0UgfSBmcm9tICcuLi8uLi9jb25maWcnO1xuaW1wb3J0IHsgQ0xVU1RFUl9OQU1FIH0gZnJvbSAnLi4vbGliL2NsdXN0ZXItY29uZmlnJztcbmltcG9ydCB7IEVjc0ZhcmdhdGVDbHVzdGVyU3RhY2sgfSBmcm9tICcuLi9saWIvZWNzLWZhcmdhdGUtY2x1c3Rlci1zdGFjayc7XG5cbmNvbnN0IGFwcCA9IG5ldyBjZGsuQXBwKCk7XG5jb25zdCBlbnYgPSB7XG4gICAgYWNjb3VudDogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfQUNDT1VOVCxcbiAgICByZWdpb246IHByb2Nlc3MuZW52LkNES19ERUZBVUxUX1JFR0lPTixcbn07XG5jb25zdCBzdGFnZSA9IGFwcC5ub2RlLnRyeUdldENvbnRleHQoJ3N0YWdlJykgfHwgREVGQVVMVF9TVEFHRTtcblxubmV3IEVjc0ZhcmdhdGVDbHVzdGVyU3RhY2soYXBwLCBgZWNzLWZhcmdhdGUtY2x1c3Rlci0ke0NMVVNURVJfTkFNRX0tJHtzdGFnZX1gLCB7XG4gICAgZW52LFxuICAgIHN0YWdlLFxuICAgIGRlc2NyaXB0aW9uOiBgRUNTIEZhcmdhdGUgY2x1c3RlciwgY2x1c3RlciBuYW1lOiAke0NMVVNURVJfTkFNRX0tJHtzdGFnZX1gLFxuICAgIHRlcm1pbmF0aW9uUHJvdGVjdGlvbjogc3RhZ2UhPT1ERUZBVUxUX1NUQUdFXG59KTtcbiJdfQ== \ No newline at end of file diff --git a/ts.out/ecs-fargate-cluster/lib/cluster-config.d.ts b/ts.out/ecs-fargate-cluster/lib/cluster-config.d.ts deleted file mode 100644 index b0ed70b..0000000 --- a/ts.out/ecs-fargate-cluster/lib/cluster-config.d.ts +++ /dev/null @@ -1,3 +0,0 @@ -#!/usr/bin/env node -export declare const CLUSTER_NAME = "fargate"; -export declare const INSTANCE_TYPE = "c5.xlarge"; diff --git a/ts.out/ecs-fargate-cluster/lib/cluster-config.js b/ts.out/ecs-fargate-cluster/lib/cluster-config.js deleted file mode 100644 index 2400c9e..0000000 --- a/ts.out/ecs-fargate-cluster/lib/cluster-config.js +++ /dev/null @@ -1,7 +0,0 @@ -#!/usr/bin/env node -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.INSTANCE_TYPE = exports.CLUSTER_NAME = void 0; -exports.CLUSTER_NAME = 'fargate'; -exports.INSTANCE_TYPE = 'c5.xlarge'; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2x1c3Rlci1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9lY3MtZmFyZ2F0ZS1jbHVzdGVyL2xpYi9jbHVzdGVyLWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBRWEsUUFBQSxZQUFZLEdBQUcsU0FBUyxDQUFDO0FBRXpCLFFBQUEsYUFBYSxHQUFHLFdBQVcsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIiMhL3Vzci9iaW4vZW52IG5vZGVcblxuZXhwb3J0IGNvbnN0IENMVVNURVJfTkFNRSA9ICdmYXJnYXRlJztcblxuZXhwb3J0IGNvbnN0IElOU1RBTkNFX1RZUEUgPSAnYzUueGxhcmdlJztcbiJdfQ== \ No newline at end of file diff --git a/ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.d.ts b/ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.d.ts deleted file mode 100644 index 286570f..0000000 --- a/ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.d.ts +++ /dev/null @@ -1,9 +0,0 @@ -import { Stack } from 'aws-cdk-lib'; -import { Construct } from 'constructs'; -import { StackCommonProps } from '../../config'; -/** - * Create ECS Fargate cluster and shared security group for ALB ingress - */ -export declare class EcsFargateClusterStack extends Stack { - constructor(scope: Construct, id: string, props: StackCommonProps); -} diff --git a/ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.js b/ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.js deleted file mode 100644 index b1a0d53..0000000 --- a/ts.out/ecs-fargate-cluster/lib/ecs-fargate-cluster-stack.js +++ /dev/null @@ -1,61 +0,0 @@ -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.EcsFargateClusterStack = void 0; -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const ec2 = __importStar(require("aws-cdk-lib/aws-ec2")); -const ssm = __importStar(require("aws-cdk-lib/aws-ssm")); -const ecs = __importStar(require("aws-cdk-lib/aws-ecs")); -const cluster_config_1 = require("../lib/cluster-config"); -const config_1 = require("../../config"); -/** - * Create ECS Fargate cluster and shared security group for ALB ingress - */ -class EcsFargateClusterStack extends aws_cdk_lib_1.Stack { - constructor(scope, id, props) { - super(scope, id, props); - const vpcId = this.node.tryGetContext('vpcId') || ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/vpc-id`); - const vpc = ec2.Vpc.fromLookup(this, 'vpc', { vpcId }); - const clusterName = `${cluster_config_1.CLUSTER_NAME}-${props.stage}`; - const cluster = new ecs.Cluster(this, 'ecs-cluster', { - vpc, - clusterName, - containerInsights: true, - }); - const securityGroupName = `ecssg-${clusterName}`; - const ecsSecurityGroup = new ec2.SecurityGroup(this, 'ecs-security-group', { - vpc, - securityGroupName, - description: `ECS Fargate shared security group for ALB ingress, cluster: ${cluster}`, - }); - aws_cdk_lib_1.Tags.of(ecsSecurityGroup).add('Stage', props.stage); - aws_cdk_lib_1.Tags.of(ecsSecurityGroup).add('Name', securityGroupName); - new aws_cdk_lib_1.CfnOutput(this, 'Cluster', { value: cluster.clusterName }); - new aws_cdk_lib_1.CfnOutput(this, 'ECS Security Group ID', { value: ecsSecurityGroup.securityGroupId }); - // cluster-name and cluster-arn is used for deployment pipeline - new ssm.StringParameter(this, 'ssm-cluster-name', { parameterName: `${config_1.SSM_PREFIX}/cluster-name`, stringValue: cluster.clusterName }); - new ssm.StringParameter(this, 'ssm-cluster-arn', { parameterName: `${config_1.SSM_PREFIX}/cluster-arn`, stringValue: cluster.clusterArn }); - // cluster-securitygroup-id is used to add inboud from ALB to Fargate service - new ssm.StringParameter(this, 'ssm-cluster-securitygroup-id', { parameterName: `${config_1.SSM_PREFIX}/cluster-securitygroup-id`, stringValue: ecsSecurityGroup.securityGroupId }); - } -} -exports.EcsFargateClusterStack = EcsFargateClusterStack; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNzLWZhcmdhdGUtY2x1c3Rlci1zdGFjay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2Vjcy1mYXJnYXRlLWNsdXN0ZXIvbGliL2Vjcy1mYXJnYXRlLWNsdXN0ZXItc3RhY2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDZDQUFxRDtBQUNyRCx5REFBMkM7QUFDM0MseURBQTJDO0FBQzNDLHlEQUEyQztBQUczQywwREFBcUQ7QUFDckQseUNBQTREO0FBRTVEOztHQUVHO0FBQ0gsTUFBYSxzQkFBdUIsU0FBUSxtQkFBSztJQUM3QyxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQXVCO1FBQzdELEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBRXhCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEdBQUcsQ0FBQyxlQUFlLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSxHQUFHLG1CQUFVLFNBQVMsQ0FBQyxDQUFDO1FBQ3BILE1BQU0sR0FBRyxHQUFHLEdBQUcsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO1FBRXZELE1BQU0sV0FBVyxHQUFHLEdBQUcsNkJBQVksSUFBSSxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDckQsTUFBTSxPQUFPLEdBQUcsSUFBSSxHQUFHLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxhQUFhLEVBQUU7WUFDakQsR0FBRztZQUNILFdBQVc7WUFDWCxpQkFBaUIsRUFBRSxJQUFJO1NBQzFCLENBQUMsQ0FBQztRQUVILE1BQU0saUJBQWlCLEdBQUcsU0FBUyxXQUFXLEVBQUUsQ0FBQztRQUNqRCxNQUFNLGdCQUFnQixHQUFHLElBQUksR0FBRyxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsb0JBQW9CLEVBQUU7WUFDdkUsR0FBRztZQUNILGlCQUFpQjtZQUNqQixXQUFXLEVBQUUsK0RBQStELE9BQU8sRUFBRTtTQUN4RixDQUFDLENBQUM7UUFDSCxrQkFBSSxDQUFDLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3BELGtCQUFJLENBQUMsRUFBRSxDQUFDLGdCQUFnQixDQUFDLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO1FBRXpELElBQUksdUJBQVMsQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFLEVBQUUsS0FBSyxFQUFFLE9BQU8sQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1FBQy9ELElBQUksdUJBQVMsQ0FBQyxJQUFJLEVBQUUsdUJBQXVCLEVBQUUsRUFBQyxLQUFLLEVBQUUsZ0JBQWdCLENBQUMsZUFBZSxFQUFDLENBQUMsQ0FBQztRQUV4RiwrREFBK0Q7UUFDL0QsSUFBSSxHQUFHLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSxrQkFBa0IsRUFBRSxFQUFFLGFBQWEsRUFBRSxHQUFHLG1CQUFVLGVBQWUsRUFBRSxXQUFXLEVBQUUsT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7UUFDckksSUFBSSxHQUFHLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSxpQkFBaUIsRUFBRSxFQUFFLGFBQWEsRUFBRSxHQUFHLG1CQUFVLGNBQWMsRUFBRSxXQUFXLEVBQUUsT0FBTyxDQUFDLFVBQVUsRUFBRSxDQUFDLENBQUM7UUFFbEksNkVBQTZFO1FBQzdFLElBQUksR0FBRyxDQUFDLGVBQWUsQ0FBQyxJQUFJLEVBQUUsOEJBQThCLEVBQUUsRUFBRSxhQUFhLEVBQUUsR0FBRyxtQkFBVSwyQkFBMkIsRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLENBQUMsZUFBZSxFQUFFLENBQUMsQ0FBQztJQUM5SyxDQUFDO0NBQ0o7QUFqQ0Qsd0RBaUNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3RhY2ssIENmbk91dHB1dCwgVGFncyB9IGZyb20gJ2F3cy1jZGstbGliJztcclxuaW1wb3J0ICogYXMgZWMyIGZyb20gJ2F3cy1jZGstbGliL2F3cy1lYzInO1xyXG5pbXBvcnQgKiBhcyBzc20gZnJvbSAnYXdzLWNkay1saWIvYXdzLXNzbSc7XHJcbmltcG9ydCAqIGFzIGVjcyBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWNzJztcclxuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnY29uc3RydWN0cyc7XHJcblxyXG5pbXBvcnQgeyBDTFVTVEVSX05BTUUgfSBmcm9tICcuLi9saWIvY2x1c3Rlci1jb25maWcnO1xyXG5pbXBvcnQgeyBTdGFja0NvbW1vblByb3BzLCBTU01fUFJFRklYIH0gZnJvbSAnLi4vLi4vY29uZmlnJztcclxuXHJcbi8qKlxyXG4gKiBDcmVhdGUgRUNTIEZhcmdhdGUgY2x1c3RlciBhbmQgc2hhcmVkIHNlY3VyaXR5IGdyb3VwIGZvciBBTEIgaW5ncmVzc1xyXG4gKi9cclxuZXhwb3J0IGNsYXNzIEVjc0ZhcmdhdGVDbHVzdGVyU3RhY2sgZXh0ZW5kcyBTdGFjayB7XHJcbiAgICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogU3RhY2tDb21tb25Qcm9wcykge1xyXG4gICAgICAgIHN1cGVyKHNjb3BlLCBpZCwgcHJvcHMpO1xyXG5cclxuICAgICAgICBjb25zdCB2cGNJZCA9IHRoaXMubm9kZS50cnlHZXRDb250ZXh0KCd2cGNJZCcpIHx8IHNzbS5TdHJpbmdQYXJhbWV0ZXIudmFsdWVGcm9tTG9va3VwKHRoaXMsIGAke1NTTV9QUkVGSVh9L3ZwYy1pZGApO1xyXG4gICAgICAgIGNvbnN0IHZwYyA9IGVjMi5WcGMuZnJvbUxvb2t1cCh0aGlzLCAndnBjJywgeyB2cGNJZCB9KTtcclxuXHJcbiAgICAgICAgY29uc3QgY2x1c3Rlck5hbWUgPSBgJHtDTFVTVEVSX05BTUV9LSR7cHJvcHMuc3RhZ2V9YDtcclxuICAgICAgICBjb25zdCBjbHVzdGVyID0gbmV3IGVjcy5DbHVzdGVyKHRoaXMsICdlY3MtY2x1c3RlcicsIHtcclxuICAgICAgICAgICAgdnBjLFxyXG4gICAgICAgICAgICBjbHVzdGVyTmFtZSxcclxuICAgICAgICAgICAgY29udGFpbmVySW5zaWdodHM6IHRydWUsXHJcbiAgICAgICAgfSk7XHJcblxyXG4gICAgICAgIGNvbnN0IHNlY3VyaXR5R3JvdXBOYW1lID0gYGVjc3NnLSR7Y2x1c3Rlck5hbWV9YDtcclxuICAgICAgICBjb25zdCBlY3NTZWN1cml0eUdyb3VwID0gbmV3IGVjMi5TZWN1cml0eUdyb3VwKHRoaXMsICdlY3Mtc2VjdXJpdHktZ3JvdXAnLCB7XHJcbiAgICAgICAgICAgIHZwYyxcclxuICAgICAgICAgICAgc2VjdXJpdHlHcm91cE5hbWUsXHJcbiAgICAgICAgICAgIGRlc2NyaXB0aW9uOiBgRUNTIEZhcmdhdGUgc2hhcmVkIHNlY3VyaXR5IGdyb3VwIGZvciBBTEIgaW5ncmVzcywgY2x1c3RlcjogJHtjbHVzdGVyfWAsXHJcbiAgICAgICAgfSk7XHJcbiAgICAgICAgVGFncy5vZihlY3NTZWN1cml0eUdyb3VwKS5hZGQoJ1N0YWdlJywgcHJvcHMuc3RhZ2UpO1xyXG4gICAgICAgIFRhZ3Mub2YoZWNzU2VjdXJpdHlHcm91cCkuYWRkKCdOYW1lJywgc2VjdXJpdHlHcm91cE5hbWUpO1xyXG4gICAgICAgIFxyXG4gICAgICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ0NsdXN0ZXInLCB7IHZhbHVlOiBjbHVzdGVyLmNsdXN0ZXJOYW1lIH0pO1xyXG4gICAgICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ0VDUyBTZWN1cml0eSBHcm91cCBJRCcsIHt2YWx1ZTogZWNzU2VjdXJpdHlHcm91cC5zZWN1cml0eUdyb3VwSWR9KTtcclxuXHJcbiAgICAgICAgLy8gY2x1c3Rlci1uYW1lIGFuZCBjbHVzdGVyLWFybiBpcyB1c2VkIGZvciBkZXBsb3ltZW50IHBpcGVsaW5lXHJcbiAgICAgICAgbmV3IHNzbS5TdHJpbmdQYXJhbWV0ZXIodGhpcywgJ3NzbS1jbHVzdGVyLW5hbWUnLCB7IHBhcmFtZXRlck5hbWU6IGAke1NTTV9QUkVGSVh9L2NsdXN0ZXItbmFtZWAsIHN0cmluZ1ZhbHVlOiBjbHVzdGVyLmNsdXN0ZXJOYW1lIH0pO1xyXG4gICAgICAgIG5ldyBzc20uU3RyaW5nUGFyYW1ldGVyKHRoaXMsICdzc20tY2x1c3Rlci1hcm4nLCB7IHBhcmFtZXRlck5hbWU6IGAke1NTTV9QUkVGSVh9L2NsdXN0ZXItYXJuYCwgc3RyaW5nVmFsdWU6IGNsdXN0ZXIuY2x1c3RlckFybiB9KTtcclxuXHJcbiAgICAgICAgLy8gY2x1c3Rlci1zZWN1cml0eWdyb3VwLWlkIGlzIHVzZWQgdG8gYWRkIGluYm91ZCBmcm9tIEFMQiB0byBGYXJnYXRlIHNlcnZpY2VcclxuICAgICAgICBuZXcgc3NtLlN0cmluZ1BhcmFtZXRlcih0aGlzLCAnc3NtLWNsdXN0ZXItc2VjdXJpdHlncm91cC1pZCcsIHsgcGFyYW1ldGVyTmFtZTogYCR7U1NNX1BSRUZJWH0vY2x1c3Rlci1zZWN1cml0eWdyb3VwLWlkYCwgc3RyaW5nVmFsdWU6IGVjc1NlY3VyaXR5R3JvdXAuc2VjdXJpdHlHcm91cElkIH0pO1xyXG4gICAgfVxyXG59XHJcbiJdfQ== \ No newline at end of file diff --git a/ts.out/ecs-fargate-service-restapi/bin/index.d.ts b/ts.out/ecs-fargate-service-restapi/bin/index.d.ts deleted file mode 100644 index b798801..0000000 --- a/ts.out/ecs-fargate-service-restapi/bin/index.d.ts +++ /dev/null @@ -1,2 +0,0 @@ -#!/usr/bin/env node -export {}; diff --git a/ts.out/ecs-fargate-service-restapi/bin/index.js b/ts.out/ecs-fargate-service-restapi/bin/index.js deleted file mode 100644 index f723788..0000000 --- a/ts.out/ecs-fargate-service-restapi/bin/index.js +++ /dev/null @@ -1,38 +0,0 @@ -#!/usr/bin/env node -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -const cdk = __importStar(require("aws-cdk-lib")); -const config_1 = require("../../config"); -const ecs_fargate_service_restapi_stack_1 = require("../lib/ecs-fargate-service-restapi-stack"); -const app = new cdk.App(); -const env = { - account: process.env.CDK_DEFAULT_ACCOUNT, - region: process.env.CDK_DEFAULT_REGION -}; -const stage = app.node.tryGetContext('stage') || config_1.DEFAULT_STAGE; -new ecs_fargate_service_restapi_stack_1.FargateRestAPIServiceStack(app, `ecs-fargate-service-restapi-${stage}`, { - env, - stage, - description: 'ECS Fargate service for RESTful API with ALB', - terminationProtection: stage !== config_1.DEFAULT_STAGE -}); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9lY3MtZmFyZ2F0ZS1zZXJ2aWNlLXJlc3RhcGkvYmluL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFDQSxpREFBbUM7QUFDbkMseUNBQTZDO0FBQzdDLGdHQUFzRjtBQUV0RixNQUFNLEdBQUcsR0FBRyxJQUFJLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQztBQUMxQixNQUFNLEdBQUcsR0FBRztJQUNSLE9BQU8sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLG1CQUFtQjtJQUN4QyxNQUFNLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxrQkFBa0I7Q0FDekMsQ0FBQztBQUNGLE1BQU0sS0FBSyxHQUFHLEdBQUcsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxJQUFJLHNCQUFhLENBQUM7QUFFL0QsSUFBSSw4REFBMEIsQ0FBQyxHQUFHLEVBQUUsK0JBQStCLEtBQUssRUFBRSxFQUFFO0lBQ3hFLEdBQUc7SUFDSCxLQUFLO0lBQ0wsV0FBVyxFQUFFLDhDQUE4QztJQUMzRCxxQkFBcUIsRUFBRSxLQUFLLEtBQUcsc0JBQWE7Q0FDL0MsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiIyEvdXNyL2Jpbi9lbnYgbm9kZVxyXG5pbXBvcnQgKiBhcyBjZGsgZnJvbSAnYXdzLWNkay1saWInO1xyXG5pbXBvcnQgeyBERUZBVUxUX1NUQUdFIH0gZnJvbSAnLi4vLi4vY29uZmlnJztcclxuaW1wb3J0IHsgRmFyZ2F0ZVJlc3RBUElTZXJ2aWNlU3RhY2sgfSBmcm9tICcuLi9saWIvZWNzLWZhcmdhdGUtc2VydmljZS1yZXN0YXBpLXN0YWNrJztcclxuXHJcbmNvbnN0IGFwcCA9IG5ldyBjZGsuQXBwKCk7XHJcbmNvbnN0IGVudiA9IHtcclxuICAgIGFjY291bnQ6IHByb2Nlc3MuZW52LkNES19ERUZBVUxUX0FDQ09VTlQsXHJcbiAgICByZWdpb246IHByb2Nlc3MuZW52LkNES19ERUZBVUxUX1JFR0lPTlxyXG59O1xyXG5jb25zdCBzdGFnZSA9IGFwcC5ub2RlLnRyeUdldENvbnRleHQoJ3N0YWdlJykgfHwgREVGQVVMVF9TVEFHRTtcclxuXHJcbm5ldyBGYXJnYXRlUmVzdEFQSVNlcnZpY2VTdGFjayhhcHAsIGBlY3MtZmFyZ2F0ZS1zZXJ2aWNlLXJlc3RhcGktJHtzdGFnZX1gLCB7XHJcbiAgICBlbnYsXHJcbiAgICBzdGFnZSxcclxuICAgIGRlc2NyaXB0aW9uOiAnRUNTIEZhcmdhdGUgc2VydmljZSBmb3IgUkVTVGZ1bCBBUEkgd2l0aCBBTEInLFxyXG4gICAgdGVybWluYXRpb25Qcm90ZWN0aW9uOiBzdGFnZSE9PURFRkFVTFRfU1RBR0VcclxufSk7XHJcbiJdfQ== \ No newline at end of file diff --git a/ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.d.ts b/ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.d.ts deleted file mode 100644 index 772da03..0000000 --- a/ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.d.ts +++ /dev/null @@ -1,10 +0,0 @@ -import { Construct } from 'constructs'; -import { Stack } from 'aws-cdk-lib'; -import { StackCommonProps } from '../../config'; -/** - * Crearte Fargate Service, Auto Scaling, ALB, and Log Group. - * Set the ALB options for the production-level. - */ -export declare class FargateRestAPIServiceStack extends Stack { - constructor(scope: Construct, id: string, props: StackCommonProps); -} diff --git a/ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.js b/ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.js deleted file mode 100644 index 9dabdad..0000000 --- a/ts.out/ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.js +++ /dev/null @@ -1,142 +0,0 @@ -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.FargateRestAPIServiceStack = void 0; -const cdk = __importStar(require("aws-cdk-lib")); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const ecs = __importStar(require("aws-cdk-lib/aws-ecs")); -const ec2 = __importStar(require("aws-cdk-lib/aws-ec2")); -const elbv2 = __importStar(require("aws-cdk-lib/aws-elasticloadbalancingv2")); -const logs = __importStar(require("aws-cdk-lib/aws-logs")); -const iam = __importStar(require("aws-cdk-lib/aws-iam")); -const ssm = __importStar(require("aws-cdk-lib/aws-ssm")); -const cluster_config_1 = require("../../ecs-fargate-cluster/lib/cluster-config"); -const config_1 = require("../../config"); -/** - * Crearte Fargate Service, Auto Scaling, ALB, and Log Group. - * Set the ALB options for the production-level. - */ -class FargateRestAPIServiceStack extends aws_cdk_lib_1.Stack { - constructor(scope, id, props) { - var _a, _b; - super(scope, id, props); - const vpcId = this.node.tryGetContext('vpcId') || ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/vpc-id`); - const vpc = ec2.Vpc.fromLookup(this, 'vpc', { vpcId }); - const clusterSgId = ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/cluster-securitygroup-id`); - const ecsSecurityGroup = ec2.SecurityGroup.fromSecurityGroupId(this, 'ecs-security-group', clusterSgId); - const cluster = ecs.Cluster.fromClusterAttributes(this, 'ecs-fargate-cluster', { - clusterName: `${cluster_config_1.CLUSTER_NAME}-${props.stage}`, - vpc, - securityGroups: [ecsSecurityGroup] - }); - const serviceName = 'fargate-restapi'; - const containerName = `${serviceName}-container`; - const applicationPort = 8080; - const executionRoleArn = ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/task-execution-role-arn`); - const taskRoleArn = ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/default-task-role-arn`); - const taskDefinition = new ecs.TaskDefinition(this, 'fargate-task-definition', { - cpu: '1024', - memoryMiB: '2048', - compatibility: ecs.Compatibility.FARGATE, - family: `${serviceName}-task`, - executionRole: iam.Role.fromRoleArn(this, 'task-execution-role', cdk.Lazy.string({ produce: () => executionRoleArn })), - taskRole: iam.Role.fromRoleArn(this, 'task-role', cdk.Lazy.string({ produce: () => taskRoleArn })) - }); - const regUrl = `${(_a = props.env) === null || _a === void 0 ? void 0 : _a.account}.dkr.ecr.${(_b = props.env) === null || _b === void 0 ? void 0 : _b.region}.amazonaws.com/fargate-restapi-${props.stage}:latest`; - const container = taskDefinition.addContainer('container-restapi', { - containerName, - image: ecs.ContainerImage.fromRegistry(regUrl), - // or build with /app folder asset - // import * as path from 'path'; - // image: ecs.ContainerImage.fromAsset(path.join(__dirname, "../../", "app")), - cpu: 1024, - memoryReservationMiB: 2048 - }); - container.addPortMappings({ containerPort: applicationPort, hostPort: applicationPort }); - const fargateservice = new ecs.FargateService(this, 'ecs-fargate-service', { - cluster, - serviceName: `${serviceName}-${props.stage}`, - taskDefinition, - enableExecuteCommand: true, - minHealthyPercent: 100, - maxHealthyPercent: 200, - healthCheckGracePeriod: aws_cdk_lib_1.Duration.seconds(0) // set the value as your application initialize time - }); - fargateservice.autoScaleTaskCount({ - minCapacity: 2, - maxCapacity: 100, - }).scaleOnCpuUtilization('cpuscaling', { - targetUtilizationPercent: 50, - scaleOutCooldown: aws_cdk_lib_1.Duration.seconds(60), - scaleInCooldown: aws_cdk_lib_1.Duration.seconds(120) - }); - const logGroup = new logs.LogGroup(this, 'loggroup', { - logGroupName: serviceName, - removalPolicy: cdk.RemovalPolicy.DESTROY, - retention: logs.RetentionDays.TWO_WEEKS, - }); - const albSecurityGroupName = `albsg-${serviceName}`; - const albSecurityGroup = new ec2.SecurityGroup(this, albSecurityGroupName, { - securityGroupName: albSecurityGroupName, - vpc, - allowAllOutbound: true, - description: `ALB security group for ${serviceName} Service` - }); - ecsSecurityGroup.addIngressRule(albSecurityGroup, ec2.Port.tcp(applicationPort), 'Allow from ALB'); - albSecurityGroup.addIngressRule(ec2.Peer.anyIpv4(), ec2.Port.tcp(80), 'Allow any'); - const alb = new elbv2.ApplicationLoadBalancer(this, 'alb', { - securityGroup: albSecurityGroup, - vpc, - loadBalancerName: `alb-${serviceName}`, - internetFacing: true, - deletionProtection: false, - idleTimeout: cdk.Duration.seconds(30), - }); - alb.addListener('https-listener', { - protocol: elbv2.ApplicationProtocol.HTTP, - open: false, - }).addTargets('ec2-service-target', { - targetGroupName: `tg-${serviceName}`, - port: applicationPort, - protocol: elbv2.ApplicationProtocol.HTTP, - targets: [fargateservice.loadBalancerTarget({ - containerName: containerName, - containerPort: applicationPort, - })], - healthCheck: { - healthyThresholdCount: 2, - unhealthyThresholdCount: 5, - interval: aws_cdk_lib_1.Duration.seconds(31), - path: '/ping', - timeout: aws_cdk_lib_1.Duration.seconds(30), - }, - deregistrationDelay: aws_cdk_lib_1.Duration.seconds(15) - }); - aws_cdk_lib_1.Tags.of(albSecurityGroup).add('Stage', props.stage); - aws_cdk_lib_1.Tags.of(albSecurityGroup).add('Name', albSecurityGroupName); - new aws_cdk_lib_1.CfnOutput(this, 'Service', { value: fargateservice.serviceArn }); - new aws_cdk_lib_1.CfnOutput(this, 'TaskDefinition', { value: taskDefinition.family }); - new aws_cdk_lib_1.CfnOutput(this, 'LogGroup', { value: logGroup.logGroupName }); - new aws_cdk_lib_1.CfnOutput(this, 'ALB', { value: alb.loadBalancerDnsName }); - } -} -exports.FargateRestAPIServiceStack = FargateRestAPIServiceStack; -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecs-fargate-service-restapi-stack.js","sourceRoot":"","sources":["../../../ecs-fargate-service-restapi/lib/ecs-fargate-service-restapi-stack.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from 'constructs';\r\nimport * as cdk from 'aws-cdk-lib';\r\nimport { Stack, CfnOutput, Duration, Tags } from 'aws-cdk-lib';\r\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\r\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\r\nimport * as elbv2 from 'aws-cdk-lib/aws-elasticloadbalancingv2';\r\nimport * as logs from 'aws-cdk-lib/aws-logs';\r\nimport * as iam from 'aws-cdk-lib/aws-iam';\r\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\r\n\r\nimport { CLUSTER_NAME } from '../../ecs-fargate-cluster/lib/cluster-config';\r\nimport { StackCommonProps, SSM_PREFIX } from '../../config';\r\n\r\n/**\r\n * Crearte Fargate Service, Auto Scaling, ALB, and Log Group.\r\n * Set the ALB options for the production-level.\r\n */\r\nexport class FargateRestAPIServiceStack extends Stack {\r\n    constructor(scope: Construct, id: string, props: StackCommonProps) {\r\n        super(scope, id, props);\r\n\r\n        const vpcId = this.node.tryGetContext('vpcId') || ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/vpc-id`);\r\n        const vpc = ec2.Vpc.fromLookup(this, 'vpc', { vpcId });\r\n        const clusterSgId = ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/cluster-securitygroup-id`);\r\n        const ecsSecurityGroup = ec2.SecurityGroup.fromSecurityGroupId(this, 'ecs-security-group', clusterSgId);\r\n\r\n        const cluster = ecs.Cluster.fromClusterAttributes(this, 'ecs-fargate-cluster', {\r\n            clusterName: `${CLUSTER_NAME}-${props.stage}`,\r\n            vpc,\r\n            securityGroups: [ecsSecurityGroup]\r\n        });\r\n        const serviceName = 'fargate-restapi'\r\n        const containerName = `${serviceName}-container`\r\n        const applicationPort = 8080;\r\n\r\n        const executionRoleArn = ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/task-execution-role-arn`);\r\n        const taskRoleArn = ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/default-task-role-arn`);\r\n\r\n        const taskDefinition = new ecs.TaskDefinition(this, 'fargate-task-definition', {\r\n            cpu: '1024',\r\n            memoryMiB: '2048',\r\n            compatibility: ecs.Compatibility.FARGATE,\r\n            family: `${serviceName}-task`,\r\n            executionRole: iam.Role.fromRoleArn(this, 'task-execution-role', cdk.Lazy.string({ produce: () => executionRoleArn })),\r\n            taskRole: iam.Role.fromRoleArn(this, 'task-role', cdk.Lazy.string({ produce: () => taskRoleArn }))\r\n        });\r\n        \r\n        const regUrl = `${props.env?.account}.dkr.ecr.${props.env?.region}.amazonaws.com/fargate-restapi-${props.stage}:latest`;\r\n        const container = taskDefinition.addContainer('container-restapi', {\r\n            containerName,\r\n            image: ecs.ContainerImage.fromRegistry(regUrl),\r\n            // or build with /app folder asset\r\n            // import * as path from 'path';\r\n            // image: ecs.ContainerImage.fromAsset(path.join(__dirname, \"../../\", \"app\")),\r\n            cpu: 1024,\r\n            memoryReservationMiB: 2048\r\n        });\r\n        container.addPortMappings({ containerPort: applicationPort, hostPort: applicationPort });\r\n\r\n        const fargateservice = new ecs.FargateService(this, 'ecs-fargate-service', {\r\n            cluster,\r\n            serviceName: `${serviceName}-${props.stage}`,\r\n            taskDefinition,\r\n            enableExecuteCommand: true,\r\n            minHealthyPercent: 100,\r\n            maxHealthyPercent: 200,\r\n            healthCheckGracePeriod: Duration.seconds(0) // set the value as your application initialize time \r\n        });\r\n        fargateservice.autoScaleTaskCount({\r\n            minCapacity: 2,\r\n            maxCapacity: 100,\r\n        }).scaleOnCpuUtilization('cpuscaling', {\r\n            targetUtilizationPercent: 50,\r\n            scaleOutCooldown: Duration.seconds(60),\r\n            scaleInCooldown: Duration.seconds(120)\r\n        });\r\n\r\n        const logGroup = new logs.LogGroup(this, 'loggroup', {\r\n            logGroupName: serviceName,\r\n            removalPolicy: cdk.RemovalPolicy.DESTROY,\r\n            retention: logs.RetentionDays.TWO_WEEKS,\r\n        });\r\n\r\n        const albSecurityGroupName = `albsg-${serviceName}`\r\n        const albSecurityGroup = new ec2.SecurityGroup(this, albSecurityGroupName, {\r\n            securityGroupName: albSecurityGroupName,\r\n            vpc,\r\n            allowAllOutbound: true,\r\n            description: `ALB security group for ${serviceName} Service`\r\n        });\r\n        ecsSecurityGroup.addIngressRule(albSecurityGroup, ec2.Port.tcp(applicationPort), 'Allow from ALB');\r\n        albSecurityGroup.addIngressRule(ec2.Peer.anyIpv4(), ec2.Port.tcp(80), 'Allow any');\r\n\r\n        const alb = new elbv2.ApplicationLoadBalancer(this, 'alb', {\r\n            securityGroup: albSecurityGroup,\r\n            vpc,\r\n            loadBalancerName: `alb-${serviceName}`,\r\n            internetFacing: true,\r\n            deletionProtection: false,\r\n            idleTimeout: cdk.Duration.seconds(30),\r\n        });\r\n        alb.addListener('https-listener', {\r\n            protocol: elbv2.ApplicationProtocol.HTTP,\r\n            open: false,\r\n        }).addTargets('ec2-service-target', {\r\n            targetGroupName: `tg-${serviceName}`,\r\n            port: applicationPort,\r\n            protocol: elbv2.ApplicationProtocol.HTTP,\r\n            targets: [fargateservice.loadBalancerTarget({\r\n                containerName: containerName,\r\n                containerPort: applicationPort,\r\n            })],\r\n            healthCheck: {\r\n                healthyThresholdCount: 2,\r\n                unhealthyThresholdCount: 5,\r\n                interval: Duration.seconds(31),\r\n                path: '/ping',\r\n                timeout: Duration.seconds(30),\r\n            },\r\n            deregistrationDelay: Duration.seconds(15)\r\n        });\r\n\r\n        Tags.of(albSecurityGroup).add('Stage', props.stage);\r\n        Tags.of(albSecurityGroup).add('Name', albSecurityGroupName);\r\n\r\n        new CfnOutput(this, 'Service', { value: fargateservice.serviceArn });\r\n        new CfnOutput(this, 'TaskDefinition', { value: taskDefinition.family });\r\n        new CfnOutput(this, 'LogGroup', { value: logGroup.logGroupName });\r\n        new CfnOutput(this, 'ALB', { value: alb.loadBalancerDnsName });\r\n    }\r\n}\r\n"]} \ No newline at end of file diff --git a/ts.out/ecs-fargatespot-service-restapi/bin/index.d.ts b/ts.out/ecs-fargatespot-service-restapi/bin/index.d.ts deleted file mode 100644 index b798801..0000000 --- a/ts.out/ecs-fargatespot-service-restapi/bin/index.d.ts +++ /dev/null @@ -1,2 +0,0 @@ -#!/usr/bin/env node -export {}; diff --git a/ts.out/ecs-fargatespot-service-restapi/bin/index.js b/ts.out/ecs-fargatespot-service-restapi/bin/index.js deleted file mode 100644 index cf46341..0000000 --- a/ts.out/ecs-fargatespot-service-restapi/bin/index.js +++ /dev/null @@ -1,38 +0,0 @@ -#!/usr/bin/env node -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -const cdk = __importStar(require("aws-cdk-lib")); -const config_1 = require("../../config"); -const ecs_fargatespot_service_restapi_stack_1 = require("../lib/ecs-fargatespot-service-restapi-stack"); -const app = new cdk.App(); -const env = { - account: process.env.CDK_DEFAULT_ACCOUNT, - region: process.env.CDK_DEFAULT_REGION -}; -const stage = app.node.tryGetContext('stage') || config_1.DEFAULT_STAGE; -new ecs_fargatespot_service_restapi_stack_1.FargateSpotRestAPIServiceStack(app, `ecs-fargatespot-service-restapi-${stage}`, { - env, - stage, - description: 'ECS Fargate service for RESTful API with Spot CapacityProvider and ALB', - terminationProtection: stage != config_1.DEFAULT_STAGE -}); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9lY3MtZmFyZ2F0ZXNwb3Qtc2VydmljZS1yZXN0YXBpL2Jpbi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQ0EsaURBQW1DO0FBQ25DLHlDQUE2QztBQUM3Qyx3R0FBOEY7QUFFOUYsTUFBTSxHQUFHLEdBQUcsSUFBSSxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUM7QUFDMUIsTUFBTSxHQUFHLEdBQUc7SUFDUixPQUFPLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxtQkFBbUI7SUFDeEMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCO0NBQ3pDLENBQUM7QUFDRixNQUFNLEtBQUssR0FBRyxHQUFHLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsSUFBSSxzQkFBYSxDQUFDO0FBRS9ELElBQUksc0VBQThCLENBQUMsR0FBRyxFQUFFLG1DQUFtQyxLQUFLLEVBQUUsRUFBRTtJQUNoRixHQUFHO0lBQ0gsS0FBSztJQUNMLFdBQVcsRUFBRSx3RUFBd0U7SUFDckYscUJBQXFCLEVBQUUsS0FBSyxJQUFFLHNCQUFhO0NBQzlDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIiMhL3Vzci9iaW4vZW52IG5vZGVcclxuaW1wb3J0ICogYXMgY2RrIGZyb20gJ2F3cy1jZGstbGliJztcclxuaW1wb3J0IHsgREVGQVVMVF9TVEFHRSB9IGZyb20gJy4uLy4uL2NvbmZpZyc7XHJcbmltcG9ydCB7IEZhcmdhdGVTcG90UmVzdEFQSVNlcnZpY2VTdGFjayB9IGZyb20gJy4uL2xpYi9lY3MtZmFyZ2F0ZXNwb3Qtc2VydmljZS1yZXN0YXBpLXN0YWNrJztcclxuXHJcbmNvbnN0IGFwcCA9IG5ldyBjZGsuQXBwKCk7XHJcbmNvbnN0IGVudiA9IHtcclxuICAgIGFjY291bnQ6IHByb2Nlc3MuZW52LkNES19ERUZBVUxUX0FDQ09VTlQsXHJcbiAgICByZWdpb246IHByb2Nlc3MuZW52LkNES19ERUZBVUxUX1JFR0lPTlxyXG59O1xyXG5jb25zdCBzdGFnZSA9IGFwcC5ub2RlLnRyeUdldENvbnRleHQoJ3N0YWdlJykgfHwgREVGQVVMVF9TVEFHRTtcclxuXHJcbm5ldyBGYXJnYXRlU3BvdFJlc3RBUElTZXJ2aWNlU3RhY2soYXBwLCBgZWNzLWZhcmdhdGVzcG90LXNlcnZpY2UtcmVzdGFwaS0ke3N0YWdlfWAsIHtcclxuICAgIGVudixcclxuICAgIHN0YWdlLFxyXG4gICAgZGVzY3JpcHRpb246ICdFQ1MgRmFyZ2F0ZSBzZXJ2aWNlIGZvciBSRVNUZnVsIEFQSSB3aXRoIFNwb3QgQ2FwYWNpdHlQcm92aWRlciBhbmQgQUxCJyxcclxuICAgIHRlcm1pbmF0aW9uUHJvdGVjdGlvbjogc3RhZ2UhPURFRkFVTFRfU1RBR0VcclxufSk7XHJcbiJdfQ== \ No newline at end of file diff --git a/ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.d.ts b/ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.d.ts deleted file mode 100644 index afe9224..0000000 --- a/ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.d.ts +++ /dev/null @@ -1,10 +0,0 @@ -import { Construct } from 'constructs'; -import { Stack } from 'aws-cdk-lib'; -import { StackCommonProps } from '../../config'; -/** - * Crearte Fargate Service with Spot CapacityProvider, Auto Scaling, ALB, and Log Group. - * Set the ALB logs for the production-level. - */ -export declare class FargateSpotRestAPIServiceStack extends Stack { - constructor(scope: Construct, id: string, props: StackCommonProps); -} diff --git a/ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.js b/ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.js deleted file mode 100644 index 8355c22..0000000 --- a/ts.out/ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.js +++ /dev/null @@ -1,151 +0,0 @@ -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.FargateSpotRestAPIServiceStack = void 0; -const cdk = __importStar(require("aws-cdk-lib")); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const ecs = __importStar(require("aws-cdk-lib/aws-ecs")); -const ec2 = __importStar(require("aws-cdk-lib/aws-ec2")); -const elbv2 = __importStar(require("aws-cdk-lib/aws-elasticloadbalancingv2")); -const logs = __importStar(require("aws-cdk-lib/aws-logs")); -const iam = __importStar(require("aws-cdk-lib/aws-iam")); -const ssm = __importStar(require("aws-cdk-lib/aws-ssm")); -const cluster_config_1 = require("../../ecs-fargate-cluster/lib/cluster-config"); -const config_1 = require("../../config"); -/** - * Crearte Fargate Service with Spot CapacityProvider, Auto Scaling, ALB, and Log Group. - * Set the ALB logs for the production-level. - */ -class FargateSpotRestAPIServiceStack extends aws_cdk_lib_1.Stack { - constructor(scope, id, props) { - var _a, _b; - super(scope, id, props); - const vpcId = this.node.tryGetContext('vpcId') || ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/vpc-id`); - const vpc = ec2.Vpc.fromLookup(this, 'vpc', { vpcId }); - const clusterSgId = ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/cluster-securitygroup-id`); - const ecsSecurityGroup = ec2.SecurityGroup.fromSecurityGroupId(this, 'ecs-security-group', clusterSgId); - const cluster = ecs.Cluster.fromClusterAttributes(this, 'ecs-fargate-cluster', { - clusterName: `${cluster_config_1.CLUSTER_NAME}-${props.stage}`, - vpc, - securityGroups: [ecsSecurityGroup] - }); - const serviceName = 'fargatespot-restapi'; - const containerName = `${serviceName}-container`; - const applicationPort = 8080; - const executionRoleArn = ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/task-execution-role-arn`); - const taskRoleArn = ssm.StringParameter.valueFromLookup(this, `${config_1.SSM_PREFIX}/default-task-role-arn`); - const taskDefinition = new ecs.TaskDefinition(this, 'fargate-task-definition', { - cpu: '1024', - memoryMiB: '2048', - compatibility: ecs.Compatibility.FARGATE, - family: `${serviceName}-task`, - executionRole: iam.Role.fromRoleArn(this, 'task-execution-role', cdk.Lazy.string({ produce: () => executionRoleArn })), - taskRole: iam.Role.fromRoleArn(this, 'task-role', cdk.Lazy.string({ produce: () => taskRoleArn })) - }); - const container = taskDefinition.addContainer('container-restapi', { - containerName, - image: ecs.ContainerImage.fromRegistry(`${(_a = props.env) === null || _a === void 0 ? void 0 : _a.account}.dkr.ecr.${(_b = props.env) === null || _b === void 0 ? void 0 : _b.region}.amazonaws.com/fargate-restapi-${props.stage}:latest`), - // or build with /app folder - // import * as path from 'path'; - // image: ecs.ContainerImage.fromAsset(path.join(__dirname, "../../", "app")), - cpu: 1024, - memoryReservationMiB: 2048 - }); - container.addPortMappings({ containerPort: applicationPort, hostPort: applicationPort }); - const fargateservice = new ecs.FargateService(this, 'ecs-fargate-service', { - cluster, - serviceName: `${serviceName}-${props.stage}`, - taskDefinition, - enableExecuteCommand: true, - minHealthyPercent: 100, - maxHealthyPercent: 200, - healthCheckGracePeriod: aws_cdk_lib_1.Duration.seconds(0), - capacityProviderStrategies: [ - { - capacityProvider: 'FARGATE_SPOT', - weight: 1, - }, - { - capacityProvider: 'FARGATE', - weight: 1, - } - ] - }); - fargateservice.autoScaleTaskCount({ - minCapacity: 2, - maxCapacity: 100, - }).scaleOnCpuUtilization('cpuscaling', { - targetUtilizationPercent: 50, - scaleOutCooldown: aws_cdk_lib_1.Duration.seconds(60), - scaleInCooldown: aws_cdk_lib_1.Duration.seconds(120) - }); - const logGroup = new logs.LogGroup(this, 'loggroup', { - logGroupName: serviceName, - removalPolicy: cdk.RemovalPolicy.DESTROY, - retention: logs.RetentionDays.TWO_WEEKS, - }); - const albSecurityGroupName = `albsg-${serviceName}`; - const albSecurityGroup = new ec2.SecurityGroup(this, albSecurityGroupName, { - securityGroupName: albSecurityGroupName, - vpc, - allowAllOutbound: true, - description: `ALB security group for ${serviceName} Service` - }); - ecsSecurityGroup.addIngressRule(albSecurityGroup, ec2.Port.tcp(applicationPort), 'Allow from ALB'); - albSecurityGroup.addIngressRule(ec2.Peer.anyIpv4(), ec2.Port.tcp(80), 'Allow any'); - const alb = new elbv2.ApplicationLoadBalancer(this, 'alb', { - securityGroup: albSecurityGroup, - vpc, - loadBalancerName: `alb-${serviceName}`, - internetFacing: true, - deletionProtection: false, - idleTimeout: cdk.Duration.seconds(30), - }); - alb.addListener('https-listener', { - protocol: elbv2.ApplicationProtocol.HTTP, - open: false, - }).addTargets('ec2-service-target', { - targetGroupName: `tg-${serviceName}`, - port: applicationPort, - protocol: elbv2.ApplicationProtocol.HTTP, - targets: [fargateservice.loadBalancerTarget({ - containerName: containerName, - containerPort: applicationPort, - })], - healthCheck: { - healthyThresholdCount: 2, - unhealthyThresholdCount: 5, - interval: aws_cdk_lib_1.Duration.seconds(31), - path: '/ping', - timeout: aws_cdk_lib_1.Duration.seconds(30), - }, - deregistrationDelay: aws_cdk_lib_1.Duration.seconds(15) - }); - aws_cdk_lib_1.Tags.of(albSecurityGroup).add('Stage', props.stage); - aws_cdk_lib_1.Tags.of(albSecurityGroup).add('Name', albSecurityGroupName); - new aws_cdk_lib_1.CfnOutput(this, 'Service', { value: fargateservice.serviceArn }); - new aws_cdk_lib_1.CfnOutput(this, 'TaskDefinition', { value: taskDefinition.family }); - new aws_cdk_lib_1.CfnOutput(this, 'LogGroup', { value: logGroup.logGroupName }); - new aws_cdk_lib_1.CfnOutput(this, 'ALB', { value: alb.loadBalancerDnsName }); - } -} -exports.FargateSpotRestAPIServiceStack = FargateSpotRestAPIServiceStack; -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecs-fargatespot-service-restapi-stack.js","sourceRoot":"","sources":["../../../ecs-fargatespot-service-restapi/lib/ecs-fargatespot-service-restapi-stack.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from 'constructs';\r\nimport * as cdk from 'aws-cdk-lib';\r\nimport { Stack, CfnOutput, Duration, Tags } from 'aws-cdk-lib';\r\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\r\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\r\nimport * as elbv2 from 'aws-cdk-lib/aws-elasticloadbalancingv2';\r\nimport * as logs from 'aws-cdk-lib/aws-logs';\r\nimport * as iam from 'aws-cdk-lib/aws-iam';\r\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\r\n\r\nimport { CLUSTER_NAME } from '../../ecs-fargate-cluster/lib/cluster-config';\r\nimport { StackCommonProps, SSM_PREFIX } from '../../config';\r\n\r\n/**\r\n * Crearte Fargate Service with Spot CapacityProvider, Auto Scaling, ALB, and Log Group.\r\n * Set the ALB logs for the production-level.\r\n */\r\nexport class FargateSpotRestAPIServiceStack extends Stack {\r\n    constructor(scope: Construct, id: string, props: StackCommonProps) {\r\n        super(scope, id, props);\r\n\r\n        const vpcId = this.node.tryGetContext('vpcId') || ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/vpc-id`);\r\n        const vpc = ec2.Vpc.fromLookup(this, 'vpc', { vpcId });\r\n        const clusterSgId = ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/cluster-securitygroup-id`);\r\n        const ecsSecurityGroup = ec2.SecurityGroup.fromSecurityGroupId(this, 'ecs-security-group', clusterSgId);\r\n\r\n        const cluster = ecs.Cluster.fromClusterAttributes(this, 'ecs-fargate-cluster', {\r\n            clusterName: `${CLUSTER_NAME}-${props.stage}`,\r\n            vpc,\r\n            securityGroups: [ecsSecurityGroup]\r\n        });\r\n\r\n        const serviceName = 'fargatespot-restapi'\r\n        const containerName = `${serviceName}-container`\r\n        const applicationPort = 8080;\r\n\r\n        const executionRoleArn = ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/task-execution-role-arn`);\r\n        const taskRoleArn = ssm.StringParameter.valueFromLookup(this, `${SSM_PREFIX}/default-task-role-arn`);\r\n\r\n        const taskDefinition = new ecs.TaskDefinition(this, 'fargate-task-definition', {\r\n            cpu: '1024',\r\n            memoryMiB: '2048',\r\n            compatibility: ecs.Compatibility.FARGATE,\r\n            family: `${serviceName}-task`,\r\n            executionRole: iam.Role.fromRoleArn(this, 'task-execution-role', cdk.Lazy.string({ produce: () => executionRoleArn })),\r\n            taskRole: iam.Role.fromRoleArn(this, 'task-role', cdk.Lazy.string({ produce: () => taskRoleArn }))\r\n        });\r\n        const container = taskDefinition.addContainer('container-restapi', {\r\n            containerName,\r\n            image: ecs.ContainerImage.fromRegistry(`${props.env?.account}.dkr.ecr.${props.env?.region}.amazonaws.com/fargate-restapi-${props.stage}:latest`),\r\n            // or build with /app folder\r\n            // import * as path from 'path';\r\n            // image: ecs.ContainerImage.fromAsset(path.join(__dirname, \"../../\", \"app\")),\r\n            cpu: 1024,\r\n            memoryReservationMiB: 2048\r\n        });\r\n        container.addPortMappings({ containerPort: applicationPort, hostPort: applicationPort });\r\n\r\n        const fargateservice = new ecs.FargateService(this, 'ecs-fargate-service', {\r\n            cluster,\r\n            serviceName: `${serviceName}-${props.stage}`,\r\n            taskDefinition,\r\n            enableExecuteCommand: true,\r\n            minHealthyPercent: 100,\r\n            maxHealthyPercent: 200,\r\n            healthCheckGracePeriod: Duration.seconds(0), // set the value as your application initialize time \r\n            capacityProviderStrategies: [\r\n                {\r\n                    capacityProvider: 'FARGATE_SPOT',\r\n                    weight: 1,\r\n                },\r\n                {\r\n                    capacityProvider: 'FARGATE',\r\n                    weight: 1,\r\n                }\r\n            ]\r\n        });\r\n        fargateservice.autoScaleTaskCount({\r\n            minCapacity: 2,\r\n            maxCapacity: 100,\r\n        }).scaleOnCpuUtilization('cpuscaling', {\r\n            targetUtilizationPercent: 50,\r\n            scaleOutCooldown: Duration.seconds(60),\r\n            scaleInCooldown: Duration.seconds(120)\r\n        });\r\n\r\n        const logGroup = new logs.LogGroup(this, 'loggroup', {\r\n            logGroupName: serviceName,\r\n            removalPolicy: cdk.RemovalPolicy.DESTROY,\r\n            retention: logs.RetentionDays.TWO_WEEKS,\r\n        });\r\n\r\n        const albSecurityGroupName = `albsg-${serviceName}`\r\n        const albSecurityGroup = new ec2.SecurityGroup(this, albSecurityGroupName, {\r\n            securityGroupName: albSecurityGroupName,\r\n            vpc,\r\n            allowAllOutbound: true,\r\n            description: `ALB security group for ${serviceName} Service`\r\n        });\r\n        ecsSecurityGroup.addIngressRule(albSecurityGroup, ec2.Port.tcp(applicationPort), 'Allow from ALB');\r\n        albSecurityGroup.addIngressRule(ec2.Peer.anyIpv4(), ec2.Port.tcp(80), 'Allow any');\r\n\r\n        const alb = new elbv2.ApplicationLoadBalancer(this, 'alb', {\r\n            securityGroup: albSecurityGroup,\r\n            vpc,\r\n            loadBalancerName: `alb-${serviceName}`,\r\n            internetFacing: true,\r\n            deletionProtection: false,\r\n            idleTimeout: cdk.Duration.seconds(30),\r\n        });\r\n        alb.addListener('https-listener', {\r\n            protocol: elbv2.ApplicationProtocol.HTTP,\r\n            open: false,\r\n        }).addTargets('ec2-service-target', {\r\n            targetGroupName: `tg-${serviceName}`,\r\n            port: applicationPort,\r\n            protocol: elbv2.ApplicationProtocol.HTTP,\r\n            targets: [fargateservice.loadBalancerTarget({\r\n                containerName: containerName,\r\n                containerPort: applicationPort,\r\n            })],\r\n            healthCheck: {\r\n                healthyThresholdCount: 2,\r\n                unhealthyThresholdCount: 5,\r\n                interval: Duration.seconds(31),\r\n                path: '/ping',\r\n                timeout: Duration.seconds(30),\r\n            },\r\n            deregistrationDelay: Duration.seconds(15)\r\n        });\r\n\r\n        Tags.of(albSecurityGroup).add('Stage', props.stage);\r\n        Tags.of(albSecurityGroup).add('Name', albSecurityGroupName);\r\n\r\n        new CfnOutput(this, 'Service', { value: fargateservice.serviceArn });\r\n        new CfnOutput(this, 'TaskDefinition', { value: taskDefinition.family });\r\n        new CfnOutput(this, 'LogGroup', { value: logGroup.logGroupName });\r\n        new CfnOutput(this, 'ALB', { value: alb.loadBalancerDnsName });\r\n    }\r\n}\r\n"]} \ No newline at end of file diff --git a/ts.out/ecs-iam-role/bin/index.d.ts b/ts.out/ecs-iam-role/bin/index.d.ts deleted file mode 100644 index b798801..0000000 --- a/ts.out/ecs-iam-role/bin/index.d.ts +++ /dev/null @@ -1,2 +0,0 @@ -#!/usr/bin/env node -export {}; diff --git a/ts.out/ecs-iam-role/bin/index.js b/ts.out/ecs-iam-role/bin/index.js deleted file mode 100644 index a18ad6f..0000000 --- a/ts.out/ecs-iam-role/bin/index.js +++ /dev/null @@ -1,37 +0,0 @@ -#!/usr/bin/env node -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -const cdk = __importStar(require("aws-cdk-lib")); -const config_1 = require("../../config"); -const ecs_iam_role_stack_1 = require("../lib/ecs-iam-role-stack"); -const app = new cdk.App(); -const env = { - account: process.env.CDK_DEFAULT_ACCOUNT, - region: process.env.CDK_DEFAULT_REGION -}; -const stage = app.node.tryGetContext('stage') || config_1.DEFAULT_STAGE; -new ecs_iam_role_stack_1.EcsIamRoleStack(app, `ecs-fargate-iam-role-${stage}`, { - env, - description: 'ECS Fargate IAM Role', - terminationProtection: stage !== config_1.DEFAULT_STAGE -}); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9lY3MtaWFtLXJvbGUvYmluL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFDQSxpREFBbUM7QUFDbkMseUNBQTZDO0FBQzdDLGtFQUE0RDtBQUU1RCxNQUFNLEdBQUcsR0FBRyxJQUFJLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQztBQUMxQixNQUFNLEdBQUcsR0FBRztJQUNSLE9BQU8sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLG1CQUFtQjtJQUN4QyxNQUFNLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxrQkFBa0I7Q0FDekMsQ0FBQztBQUNGLE1BQU0sS0FBSyxHQUFHLEdBQUcsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxJQUFJLHNCQUFhLENBQUM7QUFFL0QsSUFBSSxvQ0FBZSxDQUFDLEdBQUcsRUFBRSx3QkFBd0IsS0FBSyxFQUFFLEVBQUc7SUFDdkQsR0FBRztJQUNILFdBQVcsRUFBRSxzQkFBc0I7SUFDbkMscUJBQXFCLEVBQUUsS0FBSyxLQUFHLHNCQUFhO0NBQy9DLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIiMhL3Vzci9iaW4vZW52IG5vZGVcclxuaW1wb3J0ICogYXMgY2RrIGZyb20gJ2F3cy1jZGstbGliJztcclxuaW1wb3J0IHsgREVGQVVMVF9TVEFHRSB9IGZyb20gJy4uLy4uL2NvbmZpZyc7XHJcbmltcG9ydCB7IEVjc0lhbVJvbGVTdGFjayB9IGZyb20gJy4uL2xpYi9lY3MtaWFtLXJvbGUtc3RhY2snO1xyXG5cclxuY29uc3QgYXBwID0gbmV3IGNkay5BcHAoKTtcclxuY29uc3QgZW52ID0ge1xyXG4gICAgYWNjb3VudDogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfQUNDT1VOVCxcclxuICAgIHJlZ2lvbjogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfUkVHSU9OXHJcbn07XHJcbmNvbnN0IHN0YWdlID0gYXBwLm5vZGUudHJ5R2V0Q29udGV4dCgnc3RhZ2UnKSB8fCBERUZBVUxUX1NUQUdFO1xyXG5cclxubmV3IEVjc0lhbVJvbGVTdGFjayhhcHAsIGBlY3MtZmFyZ2F0ZS1pYW0tcm9sZS0ke3N0YWdlfWAsICB7XHJcbiAgICBlbnYsXHJcbiAgICBkZXNjcmlwdGlvbjogJ0VDUyBGYXJnYXRlIElBTSBSb2xlJyxcclxuICAgIHRlcm1pbmF0aW9uUHJvdGVjdGlvbjogc3RhZ2UhPT1ERUZBVUxUX1NUQUdFXHJcbn0pOyJdfQ== \ No newline at end of file diff --git a/ts.out/ecs-iam-role/lib/ecs-iam-role-stack.d.ts b/ts.out/ecs-iam-role/lib/ecs-iam-role-stack.d.ts deleted file mode 100644 index 424b96c..0000000 --- a/ts.out/ecs-iam-role/lib/ecs-iam-role-stack.d.ts +++ /dev/null @@ -1,13 +0,0 @@ -import { Stack, StackProps } from 'aws-cdk-lib'; -import { Construct } from 'constructs'; -/** - * This stack is written to share IAM role among multiple-cluster - * - * https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html - * - * https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-exec.html - * - */ -export declare class EcsIamRoleStack extends Stack { - constructor(scope: Construct, id: string, props?: StackProps); -} diff --git a/ts.out/ecs-iam-role/lib/ecs-iam-role-stack.js b/ts.out/ecs-iam-role/lib/ecs-iam-role-stack.js deleted file mode 100644 index ecdba39..0000000 --- a/ts.out/ecs-iam-role/lib/ecs-iam-role-stack.js +++ /dev/null @@ -1,79 +0,0 @@ -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.EcsIamRoleStack = void 0; -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const ssm = __importStar(require("aws-cdk-lib/aws-ssm")); -const iam = __importStar(require("aws-cdk-lib/aws-iam")); -const config_1 = require("../../config"); -/** - * This stack is written to share IAM role among multiple-cluster - * - * https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html - * - * https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-exec.html - * - */ -class EcsIamRoleStack extends aws_cdk_lib_1.Stack { - constructor(scope, id, props) { - super(scope, id, props); - // AmazonECSTaskExecutionRole based on https://us-east-1.console.aws.amazon.com/iam/home#/policies/arn:aws:iam::aws:policy/service-role/AmazonECSTaskExecutionRolePolicy$jsonEditor - const taskExecutionRole = new iam.Role(this, 'task-execution-role', { - roleName: 'AmazonECSFargateTaskExecutionRole', - assumedBy: new iam.ServicePrincipal('ecs-tasks.amazonaws.com'), - managedPolicies: [ - iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AmazonECSTaskExecutionRolePolicy'), - ] - }); - const defaultTaskRole = new iam.Role(this, 'default-task-role', { - roleName: 'ECSFargateDefaultTaskRole', - assumedBy: new iam.ServicePrincipal('ecs-tasks.amazonaws.com'), - managedPolicies: [ - iam.ManagedPolicy.fromAwsManagedPolicyName('AWSXrayWriteOnlyAccess'), - iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMReadOnlyAccess') - ], - inlinePolicies: { - ECSExec: new iam.PolicyDocument({ - statements: [ - new iam.PolicyStatement({ - effect: iam.Effect.ALLOW, - actions: [ - "ssmmessages:CreateControlChannel", - "ssmmessages:CreateDataChannel", - "ssmmessages:OpenControlChannel", - "ssmmessages:OpenDataChannel", - ], - resources: ["*"], - }), - ], - }), - } - }); - const taskExecRoleParam = new ssm.StringParameter(this, 'ssm-task-execution-role', { parameterName: `${config_1.SSM_PREFIX}/task-execution-role-arn`, stringValue: taskExecutionRole.roleArn }); - const defaultTaskRoleParam = new ssm.StringParameter(this, 'ssm-default-task-role', { parameterName: `${config_1.SSM_PREFIX}/default-task-role-arn`, stringValue: defaultTaskRole.roleArn }); - new aws_cdk_lib_1.CfnOutput(this, 'SSMTaskExecRoleParam', { value: taskExecRoleParam.parameterName }); - new aws_cdk_lib_1.CfnOutput(this, 'SSMTaskExecRoleParamValue', { value: taskExecRoleParam.stringValue }); - new aws_cdk_lib_1.CfnOutput(this, 'SSMDefaultTaskRoleParam', { value: defaultTaskRoleParam.parameterName }); - new aws_cdk_lib_1.CfnOutput(this, 'SSMDefaultTaskRoleParamValue', { value: defaultTaskRoleParam.stringValue }); - } -} -exports.EcsIamRoleStack = EcsIamRoleStack; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNzLWlhbS1yb2xlLXN0YWNrLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vZWNzLWlhbS1yb2xlL2xpYi9lY3MtaWFtLXJvbGUtc3RhY2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDZDQUEyRDtBQUUzRCx5REFBMkM7QUFDM0MseURBQTJDO0FBRzNDLHlDQUEwQztBQUUxQzs7Ozs7OztHQU9HO0FBQ0gsTUFBYSxlQUFnQixTQUFRLG1CQUFLO0lBQ3hDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBa0I7UUFDMUQsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFFeEIsbUxBQW1MO1FBQ25MLE1BQU0saUJBQWlCLEdBQUcsSUFBSSxHQUFHLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxxQkFBcUIsRUFBRTtZQUNsRSxRQUFRLEVBQUUsbUNBQW1DO1lBQzdDLFNBQVMsRUFBRSxJQUFJLEdBQUcsQ0FBQyxnQkFBZ0IsQ0FBQyx5QkFBeUIsQ0FBQztZQUM5RCxlQUFlLEVBQUU7Z0JBQ2YsR0FBRyxDQUFDLGFBQWEsQ0FBQyx3QkFBd0IsQ0FDeEMsK0NBQStDLENBQ2hEO2FBQ0Y7U0FDRixDQUFDLENBQUM7UUFFSCxNQUFNLGVBQWUsR0FBRyxJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLG1CQUFtQixFQUFFO1lBQzlELFFBQVEsRUFBRSwyQkFBMkI7WUFDckMsU0FBUyxFQUFFLElBQUksR0FBRyxDQUFDLGdCQUFnQixDQUFDLHlCQUF5QixDQUFDO1lBQzlELGVBQWUsRUFBRTtnQkFDZixHQUFHLENBQUMsYUFBYSxDQUFDLHdCQUF3QixDQUN4Qyx3QkFBd0IsQ0FDekI7Z0JBQ0QsR0FBRyxDQUFDLGFBQWEsQ0FBQyx3QkFBd0IsQ0FDeEMseUJBQXlCLENBQzFCO2FBQ0Y7WUFDRCxjQUFjLEVBQUU7Z0JBQ2QsT0FBTyxFQUFFLElBQUksR0FBRyxDQUFDLGNBQWMsQ0FBQztvQkFDOUIsVUFBVSxFQUFFO3dCQUNWLElBQUksR0FBRyxDQUFDLGVBQWUsQ0FBQzs0QkFDdEIsTUFBTSxFQUFFLEdBQUcsQ0FBQyxNQUFNLENBQUMsS0FBSzs0QkFDeEIsT0FBTyxFQUFFO2dDQUNQLGtDQUFrQztnQ0FDbEMsK0JBQStCO2dDQUMvQixnQ0FBZ0M7Z0NBQ2hDLDZCQUE2Qjs2QkFDOUI7NEJBQ0QsU0FBUyxFQUFFLENBQUMsR0FBRyxDQUFDO3lCQUNqQixDQUFDO3FCQUNIO2lCQUNGLENBQUM7YUFDSDtTQUNGLENBQUMsQ0FBQztRQUVILE1BQU0saUJBQWlCLEdBQUcsSUFBSSxHQUFHLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSx5QkFBeUIsRUFBRSxFQUFFLGFBQWEsRUFBRSxHQUFHLG1CQUFVLDBCQUEwQixFQUFFLFdBQVcsRUFBRSxpQkFBaUIsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQ3ZMLE1BQU0sb0JBQW9CLEdBQUcsSUFBSSxHQUFHLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSx1QkFBdUIsRUFBRSxFQUFFLGFBQWEsRUFBRSxHQUFHLG1CQUFVLHdCQUF3QixFQUFFLFdBQVcsRUFBRSxlQUFlLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztRQUVwTCxJQUFJLHVCQUFTLENBQUMsSUFBSSxFQUFFLHNCQUFzQixFQUFFLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixDQUFDLGFBQWEsRUFBRSxDQUFDLENBQUM7UUFDeEYsSUFBSSx1QkFBUyxDQUFDLElBQUksRUFBRSwyQkFBMkIsRUFBRSxFQUFFLEtBQUssRUFBRSxpQkFBaUIsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1FBQzNGLElBQUksdUJBQVMsQ0FBQyxJQUFJLEVBQUUseUJBQXlCLEVBQUUsRUFBRSxLQUFLLEVBQUUsb0JBQW9CLENBQUMsYUFBYSxFQUFFLENBQUMsQ0FBQztRQUM5RixJQUFJLHVCQUFTLENBQUMsSUFBSSxFQUFFLDhCQUE4QixFQUFFLEVBQUUsS0FBSyxFQUFFLG9CQUFvQixDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7SUFDbkcsQ0FBQztDQUNGO0FBcERELDBDQW9EQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFN0YWNrLCBTdGFja1Byb3BzLCBDZm5PdXRwdXQgfSBmcm9tICdhd3MtY2RrLWxpYic7XHJcblxyXG5pbXBvcnQgKiBhcyBzc20gZnJvbSAnYXdzLWNkay1saWIvYXdzLXNzbSc7XHJcbmltcG9ydCAqIGFzIGlhbSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcclxuXHJcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xyXG5pbXBvcnQgeyBTU01fUFJFRklYIH0gZnJvbSAnLi4vLi4vY29uZmlnJztcclxuXHJcbi8qKlxyXG4gKiBUaGlzIHN0YWNrIGlzIHdyaXR0ZW4gdG8gc2hhcmUgSUFNIHJvbGUgYW1vbmcgbXVsdGlwbGUtY2x1c3RlclxyXG4gKiBcclxuICogaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FtYXpvbkVDUy9sYXRlc3QvZGV2ZWxvcGVyZ3VpZGUvdGFzay1pYW0tcm9sZXMuaHRtbFxyXG4gKiBcclxuICogaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FtYXpvbkVDUy9sYXRlc3QvZGV2ZWxvcGVyZ3VpZGUvZWNzLWV4ZWMuaHRtbFxyXG4gKiBcclxuICovXHJcbmV4cG9ydCBjbGFzcyBFY3NJYW1Sb2xlU3RhY2sgZXh0ZW5kcyBTdGFjayB7XHJcbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM/OiBTdGFja1Byb3BzKSB7XHJcbiAgICBzdXBlcihzY29wZSwgaWQsIHByb3BzKTtcclxuXHJcbiAgICAvLyBBbWF6b25FQ1NUYXNrRXhlY3V0aW9uUm9sZSBiYXNlZCBvbiBodHRwczovL3VzLWVhc3QtMS5jb25zb2xlLmF3cy5hbWF6b24uY29tL2lhbS9ob21lIy9wb2xpY2llcy9hcm46YXdzOmlhbTo6YXdzOnBvbGljeS9zZXJ2aWNlLXJvbGUvQW1hem9uRUNTVGFza0V4ZWN1dGlvblJvbGVQb2xpY3kkanNvbkVkaXRvclxyXG4gICAgY29uc3QgdGFza0V4ZWN1dGlvblJvbGUgPSBuZXcgaWFtLlJvbGUodGhpcywgJ3Rhc2stZXhlY3V0aW9uLXJvbGUnLCB7XHJcbiAgICAgIHJvbGVOYW1lOiAnQW1hem9uRUNTRmFyZ2F0ZVRhc2tFeGVjdXRpb25Sb2xlJyxcclxuICAgICAgYXNzdW1lZEJ5OiBuZXcgaWFtLlNlcnZpY2VQcmluY2lwYWwoJ2Vjcy10YXNrcy5hbWF6b25hd3MuY29tJyksXHJcbiAgICAgIG1hbmFnZWRQb2xpY2llczogW1xyXG4gICAgICAgIGlhbS5NYW5hZ2VkUG9saWN5LmZyb21Bd3NNYW5hZ2VkUG9saWN5TmFtZShcclxuICAgICAgICAgICdzZXJ2aWNlLXJvbGUvQW1hem9uRUNTVGFza0V4ZWN1dGlvblJvbGVQb2xpY3knLFxyXG4gICAgICAgICksXHJcbiAgICAgIF1cclxuICAgIH0pO1xyXG5cclxuICAgIGNvbnN0IGRlZmF1bHRUYXNrUm9sZSA9IG5ldyBpYW0uUm9sZSh0aGlzLCAnZGVmYXVsdC10YXNrLXJvbGUnLCB7XHJcbiAgICAgIHJvbGVOYW1lOiAnRUNTRmFyZ2F0ZURlZmF1bHRUYXNrUm9sZScsXHJcbiAgICAgIGFzc3VtZWRCeTogbmV3IGlhbS5TZXJ2aWNlUHJpbmNpcGFsKCdlY3MtdGFza3MuYW1hem9uYXdzLmNvbScpLFxyXG4gICAgICBtYW5hZ2VkUG9saWNpZXM6IFtcclxuICAgICAgICBpYW0uTWFuYWdlZFBvbGljeS5mcm9tQXdzTWFuYWdlZFBvbGljeU5hbWUoXHJcbiAgICAgICAgICAnQVdTWHJheVdyaXRlT25seUFjY2VzcycsXHJcbiAgICAgICAgKSxcclxuICAgICAgICBpYW0uTWFuYWdlZFBvbGljeS5mcm9tQXdzTWFuYWdlZFBvbGljeU5hbWUoXHJcbiAgICAgICAgICAnQW1hem9uU1NNUmVhZE9ubHlBY2Nlc3MnLFxyXG4gICAgICAgIClcclxuICAgICAgXSxcclxuICAgICAgaW5saW5lUG9saWNpZXM6IHtcclxuICAgICAgICBFQ1NFeGVjOiBuZXcgaWFtLlBvbGljeURvY3VtZW50KHtcclxuICAgICAgICAgIHN0YXRlbWVudHM6IFtcclxuICAgICAgICAgICAgbmV3IGlhbS5Qb2xpY3lTdGF0ZW1lbnQoe1xyXG4gICAgICAgICAgICAgIGVmZmVjdDogaWFtLkVmZmVjdC5BTExPVyxcclxuICAgICAgICAgICAgICBhY3Rpb25zOiBbXHJcbiAgICAgICAgICAgICAgICBcInNzbW1lc3NhZ2VzOkNyZWF0ZUNvbnRyb2xDaGFubmVsXCIsXHJcbiAgICAgICAgICAgICAgICBcInNzbW1lc3NhZ2VzOkNyZWF0ZURhdGFDaGFubmVsXCIsXHJcbiAgICAgICAgICAgICAgICBcInNzbW1lc3NhZ2VzOk9wZW5Db250cm9sQ2hhbm5lbFwiLFxyXG4gICAgICAgICAgICAgICAgXCJzc21tZXNzYWdlczpPcGVuRGF0YUNoYW5uZWxcIixcclxuICAgICAgICAgICAgICBdLFxyXG4gICAgICAgICAgICAgIHJlc291cmNlczogW1wiKlwiXSxcclxuICAgICAgICAgICAgfSksXHJcbiAgICAgICAgICBdLFxyXG4gICAgICAgIH0pLFxyXG4gICAgICB9XHJcbiAgICB9KTtcclxuXHJcbiAgICBjb25zdCB0YXNrRXhlY1JvbGVQYXJhbSA9IG5ldyBzc20uU3RyaW5nUGFyYW1ldGVyKHRoaXMsICdzc20tdGFzay1leGVjdXRpb24tcm9sZScsIHsgcGFyYW1ldGVyTmFtZTogYCR7U1NNX1BSRUZJWH0vdGFzay1leGVjdXRpb24tcm9sZS1hcm5gLCBzdHJpbmdWYWx1ZTogdGFza0V4ZWN1dGlvblJvbGUucm9sZUFybiB9KTtcclxuICAgIGNvbnN0IGRlZmF1bHRUYXNrUm9sZVBhcmFtID0gbmV3IHNzbS5TdHJpbmdQYXJhbWV0ZXIodGhpcywgJ3NzbS1kZWZhdWx0LXRhc2stcm9sZScsIHsgcGFyYW1ldGVyTmFtZTogYCR7U1NNX1BSRUZJWH0vZGVmYXVsdC10YXNrLXJvbGUtYXJuYCwgc3RyaW5nVmFsdWU6IGRlZmF1bHRUYXNrUm9sZS5yb2xlQXJuIH0pO1xyXG5cclxuICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ1NTTVRhc2tFeGVjUm9sZVBhcmFtJywgeyB2YWx1ZTogdGFza0V4ZWNSb2xlUGFyYW0ucGFyYW1ldGVyTmFtZSB9KTtcclxuICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ1NTTVRhc2tFeGVjUm9sZVBhcmFtVmFsdWUnLCB7IHZhbHVlOiB0YXNrRXhlY1JvbGVQYXJhbS5zdHJpbmdWYWx1ZSB9KTtcclxuICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ1NTTURlZmF1bHRUYXNrUm9sZVBhcmFtJywgeyB2YWx1ZTogZGVmYXVsdFRhc2tSb2xlUGFyYW0ucGFyYW1ldGVyTmFtZSB9KTtcclxuICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ1NTTURlZmF1bHRUYXNrUm9sZVBhcmFtVmFsdWUnLCB7IHZhbHVlOiBkZWZhdWx0VGFza1JvbGVQYXJhbS5zdHJpbmdWYWx1ZSB9KTtcclxuICB9XHJcbn1cclxuIl19 \ No newline at end of file diff --git a/ts.out/vpc/bin/index.d.ts b/ts.out/vpc/bin/index.d.ts deleted file mode 100644 index b798801..0000000 --- a/ts.out/vpc/bin/index.d.ts +++ /dev/null @@ -1,2 +0,0 @@ -#!/usr/bin/env node -export {}; diff --git a/ts.out/vpc/bin/index.js b/ts.out/vpc/bin/index.js deleted file mode 100644 index a2f1965..0000000 --- a/ts.out/vpc/bin/index.js +++ /dev/null @@ -1,37 +0,0 @@ -#!/usr/bin/env node -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -const cdk = __importStar(require("aws-cdk-lib")); -const vpc_stack_1 = require("../lib/vpc-stack"); -const config_1 = require("../../config"); -const app = new cdk.App(); -const env = { - account: process.env.CDK_DEFAULT_ACCOUNT, - region: process.env.CDK_DEFAULT_REGION -}; -const stage = app.node.tryGetContext('stage') || config_1.DEFAULT_STAGE; -new vpc_stack_1.VpcStack(app, `ecs-vpc-${stage}`, { - env, - description: 'VPC for Fargate and EC2 ECS', - terminationProtection: stage !== config_1.DEFAULT_STAGE -}); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi92cGMvYmluL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFDQSxpREFBbUM7QUFDbkMsZ0RBQTRDO0FBQzVDLHlDQUE2QztBQUU3QyxNQUFNLEdBQUcsR0FBRyxJQUFJLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQztBQUMxQixNQUFNLEdBQUcsR0FBRztJQUNSLE9BQU8sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLG1CQUFtQjtJQUN4QyxNQUFNLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxrQkFBa0I7Q0FDekMsQ0FBQztBQUNGLE1BQU0sS0FBSyxHQUFHLEdBQUcsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxJQUFJLHNCQUFhLENBQUM7QUFFL0QsSUFBSSxvQkFBUSxDQUFDLEdBQUcsRUFBRSxXQUFXLEtBQUssRUFBRSxFQUFHO0lBQ25DLEdBQUc7SUFDSCxXQUFXLEVBQUUsNkJBQTZCO0lBQzFDLHFCQUFxQixFQUFFLEtBQUssS0FBRyxzQkFBYTtDQUMvQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIjIS91c3IvYmluL2VudiBub2RlXHJcbmltcG9ydCAqIGFzIGNkayBmcm9tICdhd3MtY2RrLWxpYic7XHJcbmltcG9ydCB7IFZwY1N0YWNrIH0gZnJvbSAnLi4vbGliL3ZwYy1zdGFjayc7XHJcbmltcG9ydCB7IERFRkFVTFRfU1RBR0UgfSBmcm9tICcuLi8uLi9jb25maWcnO1xyXG5cclxuY29uc3QgYXBwID0gbmV3IGNkay5BcHAoKTtcclxuY29uc3QgZW52ID0ge1xyXG4gICAgYWNjb3VudDogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfQUNDT1VOVCxcclxuICAgIHJlZ2lvbjogcHJvY2Vzcy5lbnYuQ0RLX0RFRkFVTFRfUkVHSU9OXHJcbn07XHJcbmNvbnN0IHN0YWdlID0gYXBwLm5vZGUudHJ5R2V0Q29udGV4dCgnc3RhZ2UnKSB8fCBERUZBVUxUX1NUQUdFO1xyXG5cclxubmV3IFZwY1N0YWNrKGFwcCwgYGVjcy12cGMtJHtzdGFnZX1gLCAge1xyXG4gICAgZW52LFxyXG4gICAgZGVzY3JpcHRpb246ICdWUEMgZm9yIEZhcmdhdGUgYW5kIEVDMiBFQ1MnLFxyXG4gICAgdGVybWluYXRpb25Qcm90ZWN0aW9uOiBzdGFnZSE9PURFRkFVTFRfU1RBR0VcclxufSk7Il19 \ No newline at end of file diff --git a/ts.out/vpc/lib/vpc-stack.d.ts b/ts.out/vpc/lib/vpc-stack.d.ts deleted file mode 100644 index 8d92f51..0000000 --- a/ts.out/vpc/lib/vpc-stack.d.ts +++ /dev/null @@ -1,5 +0,0 @@ -import { Stack, StackProps } from 'aws-cdk-lib'; -import { Construct } from 'constructs'; -export declare class VpcStack extends Stack { - constructor(scope: Construct, id: string, props?: StackProps); -} diff --git a/ts.out/vpc/lib/vpc-stack.js b/ts.out/vpc/lib/vpc-stack.js deleted file mode 100644 index 8e05b2d..0000000 --- a/ts.out/vpc/lib/vpc-stack.js +++ /dev/null @@ -1,56 +0,0 @@ -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.VpcStack = void 0; -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const ec2 = __importStar(require("aws-cdk-lib/aws-ec2")); -const ssm = __importStar(require("aws-cdk-lib/aws-ssm")); -const config_1 = require("../../config"); -class VpcStack extends aws_cdk_lib_1.Stack { - constructor(scope, id, props) { - super(scope, id, props); - const cidr = `10.100.0.0/16`; - const vpc = new ec2.Vpc(this, 'Vpc', { - maxAzs: 3, - natGateways: 3, - cidr, - subnetConfiguration: [ - { - cidrMask: 20, - name: 'public', - subnetType: ec2.SubnetType.PUBLIC, - }, - { - cidrMask: 20, - name: 'private', - subnetType: ec2.SubnetType.PRIVATE_WITH_NAT, - } - ] - }); - const parameter = new ssm.StringParameter(this, 'SSMVPCID', { parameterName: `${config_1.SSM_PREFIX}/vpc-id`, stringValue: vpc.vpcId }); - new aws_cdk_lib_1.CfnOutput(this, 'VPC', { value: vpc.vpcId }); - new aws_cdk_lib_1.CfnOutput(this, 'SSMParameter', { value: parameter.parameterName }); - new aws_cdk_lib_1.CfnOutput(this, 'SSMParameterValue', { value: vpc.vpcId }); - new aws_cdk_lib_1.CfnOutput(this, 'SSMURL', { value: `https://${this.region}.console.aws.amazon.com/systems-manager/parameters/` }); - } -} -exports.VpcStack = VpcStack; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidnBjLXN0YWNrLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vdnBjL2xpYi92cGMtc3RhY2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDZDQUEyRDtBQUczRCx5REFBMkM7QUFDM0MseURBQTJDO0FBRTNDLHlDQUEwQztBQUUxQyxNQUFhLFFBQVMsU0FBUSxtQkFBSztJQUMvQixZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQWtCO1FBQ3hELEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBRXhCLE1BQU0sSUFBSSxHQUFHLGVBQWUsQ0FBQztRQUM3QixNQUFNLEdBQUcsR0FBRyxJQUFJLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRTtZQUNqQyxNQUFNLEVBQUUsQ0FBQztZQUNULFdBQVcsRUFBRSxDQUFDO1lBQ2QsSUFBSTtZQUNKLG1CQUFtQixFQUFFO2dCQUNqQjtvQkFDSSxRQUFRLEVBQUUsRUFBRTtvQkFDWixJQUFJLEVBQUUsUUFBUTtvQkFDZCxVQUFVLEVBQUUsR0FBRyxDQUFDLFVBQVUsQ0FBQyxNQUFNO2lCQUNwQztnQkFDRDtvQkFDSSxRQUFRLEVBQUUsRUFBRTtvQkFDWixJQUFJLEVBQUUsU0FBUztvQkFDZixVQUFVLEVBQUUsR0FBRyxDQUFDLFVBQVUsQ0FBQyxnQkFBZ0I7aUJBQzlDO2FBQ0o7U0FDSixDQUFDLENBQUM7UUFFSCxNQUFNLFNBQVMsR0FBRyxJQUFJLEdBQUcsQ0FBQyxlQUFlLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRSxFQUFFLGFBQWEsRUFBRSxHQUFHLG1CQUFVLFNBQVMsRUFBRSxXQUFXLEVBQUUsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7UUFDL0gsSUFBSSx1QkFBUyxDQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsRUFBRSxLQUFLLEVBQUUsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7UUFDakQsSUFBSSx1QkFBUyxDQUFDLElBQUksRUFBRSxjQUFjLEVBQUUsRUFBRSxLQUFLLEVBQUUsU0FBUyxDQUFDLGFBQWEsRUFBRSxDQUFDLENBQUM7UUFDeEUsSUFBSSx1QkFBUyxDQUFDLElBQUksRUFBRSxtQkFBbUIsRUFBRSxFQUFFLEtBQUssRUFBRSxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztRQUMvRCxJQUFJLHVCQUFTLENBQUMsSUFBSSxFQUFFLFFBQVEsRUFBRSxFQUFFLEtBQUssRUFBRSxXQUFXLElBQUksQ0FBQyxNQUFNLHFEQUFxRCxFQUFFLENBQUMsQ0FBQztJQUMxSCxDQUFDO0NBQ0o7QUE3QkQsNEJBNkJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3RhY2ssIFN0YWNrUHJvcHMsIENmbk91dHB1dCB9IGZyb20gJ2F3cy1jZGstbGliJztcclxuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnY29uc3RydWN0cyc7XHJcblxyXG5pbXBvcnQgKiBhcyBlYzIgZnJvbSAnYXdzLWNkay1saWIvYXdzLWVjMic7XHJcbmltcG9ydCAqIGFzIHNzbSBmcm9tICdhd3MtY2RrLWxpYi9hd3Mtc3NtJztcclxuXHJcbmltcG9ydCB7IFNTTV9QUkVGSVggfSBmcm9tICcuLi8uLi9jb25maWcnO1xyXG5cclxuZXhwb3J0IGNsYXNzIFZwY1N0YWNrIGV4dGVuZHMgU3RhY2sge1xyXG4gICAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM/OiBTdGFja1Byb3BzKSB7XHJcbiAgICAgICAgc3VwZXIoc2NvcGUsIGlkLCBwcm9wcyk7XHJcblxyXG4gICAgICAgIGNvbnN0IGNpZHIgPSBgMTAuMTAwLjAuMC8xNmA7XHJcbiAgICAgICAgY29uc3QgdnBjID0gbmV3IGVjMi5WcGModGhpcywgJ1ZwYycsIHtcclxuICAgICAgICAgICAgbWF4QXpzOiAzLFxyXG4gICAgICAgICAgICBuYXRHYXRld2F5czogMyxcclxuICAgICAgICAgICAgY2lkcixcclxuICAgICAgICAgICAgc3VibmV0Q29uZmlndXJhdGlvbjogW1xyXG4gICAgICAgICAgICAgICAge1xyXG4gICAgICAgICAgICAgICAgICAgIGNpZHJNYXNrOiAyMCxcclxuICAgICAgICAgICAgICAgICAgICBuYW1lOiAncHVibGljJyxcclxuICAgICAgICAgICAgICAgICAgICBzdWJuZXRUeXBlOiBlYzIuU3VibmV0VHlwZS5QVUJMSUMsXHJcbiAgICAgICAgICAgICAgICB9LFxyXG4gICAgICAgICAgICAgICAge1xyXG4gICAgICAgICAgICAgICAgICAgIGNpZHJNYXNrOiAyMCxcclxuICAgICAgICAgICAgICAgICAgICBuYW1lOiAncHJpdmF0ZScsXHJcbiAgICAgICAgICAgICAgICAgICAgc3VibmV0VHlwZTogZWMyLlN1Ym5ldFR5cGUuUFJJVkFURV9XSVRIX05BVCxcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgXVxyXG4gICAgICAgIH0pO1xyXG5cclxuICAgICAgICBjb25zdCBwYXJhbWV0ZXIgPSBuZXcgc3NtLlN0cmluZ1BhcmFtZXRlcih0aGlzLCAnU1NNVlBDSUQnLCB7IHBhcmFtZXRlck5hbWU6IGAke1NTTV9QUkVGSVh9L3ZwYy1pZGAsIHN0cmluZ1ZhbHVlOiB2cGMudnBjSWQgfSk7XHJcbiAgICAgICAgbmV3IENmbk91dHB1dCh0aGlzLCAnVlBDJywgeyB2YWx1ZTogdnBjLnZwY0lkIH0pO1xyXG4gICAgICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ1NTTVBhcmFtZXRlcicsIHsgdmFsdWU6IHBhcmFtZXRlci5wYXJhbWV0ZXJOYW1lIH0pO1xyXG4gICAgICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ1NTTVBhcmFtZXRlclZhbHVlJywgeyB2YWx1ZTogdnBjLnZwY0lkIH0pO1xyXG4gICAgICAgIG5ldyBDZm5PdXRwdXQodGhpcywgJ1NTTVVSTCcsIHsgdmFsdWU6IGBodHRwczovLyR7dGhpcy5yZWdpb259LmNvbnNvbGUuYXdzLmFtYXpvbi5jb20vc3lzdGVtcy1tYW5hZ2VyL3BhcmFtZXRlcnMvYCB9KTtcclxuICAgIH1cclxufSJdfQ== \ No newline at end of file