@codedrifters/configulator 0.0.38 → 0.0.40
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -84,44 +84,39 @@ class AwsDeploymentConfig extends projen_1.Component {
|
|
|
84
84
|
* @returns All production deployment targets.
|
|
85
85
|
*/
|
|
86
86
|
get prodTargets() {
|
|
87
|
-
return this.awsDeploymentTargets.filter((target) => target.
|
|
87
|
+
return this.awsDeploymentTargets.filter((target) => target.awsStageType === aws_deployment_target_1.AWS_STAGE_TYPE.PROD);
|
|
88
88
|
}
|
|
89
89
|
get prodTargetsForCI() {
|
|
90
|
-
return this.awsDeploymentTargets.filter((target) => target.
|
|
91
|
-
target.ciDeployment);
|
|
90
|
+
return this.awsDeploymentTargets.filter((target) => target.awsStageType === aws_deployment_target_1.AWS_STAGE_TYPE.PROD && target.ciDeployment);
|
|
92
91
|
}
|
|
93
92
|
get prodTargetsForLocal() {
|
|
94
|
-
return this.awsDeploymentTargets.filter((target) => target.
|
|
95
|
-
target.localDeployment);
|
|
93
|
+
return this.awsDeploymentTargets.filter((target) => target.awsStageType === aws_deployment_target_1.AWS_STAGE_TYPE.PROD && target.localDeployment);
|
|
96
94
|
}
|
|
97
95
|
/**
|
|
98
96
|
*
|
|
99
97
|
* @returns All stage deployment targets.
|
|
100
98
|
*/
|
|
101
99
|
get stageTargets() {
|
|
102
|
-
return this.awsDeploymentTargets.filter((target) => target.
|
|
100
|
+
return this.awsDeploymentTargets.filter((target) => target.awsStageType === aws_deployment_target_1.AWS_STAGE_TYPE.STAGE);
|
|
103
101
|
}
|
|
104
102
|
get stageTargetsForCI() {
|
|
105
|
-
return this.awsDeploymentTargets.filter((target) => target.
|
|
106
|
-
target.ciDeployment);
|
|
103
|
+
return this.awsDeploymentTargets.filter((target) => target.awsStageType === aws_deployment_target_1.AWS_STAGE_TYPE.STAGE && target.ciDeployment);
|
|
107
104
|
}
|
|
108
105
|
get stageTargetsForLocal() {
|
|
109
|
-
return this.awsDeploymentTargets.filter((target) => target.
|
|
110
|
-
target.localDeployment);
|
|
106
|
+
return this.awsDeploymentTargets.filter((target) => target.awsStageType === aws_deployment_target_1.AWS_STAGE_TYPE.STAGE && target.localDeployment);
|
|
111
107
|
}
|
|
112
108
|
/**
|
|
113
109
|
*
|
|
114
110
|
* @returns All dev deployment targets.
|
|
115
111
|
*/
|
|
116
112
|
get devTargets() {
|
|
117
|
-
return this.awsDeploymentTargets.filter((target) => target.
|
|
113
|
+
return this.awsDeploymentTargets.filter((target) => target.awsStageType === aws_deployment_target_1.AWS_STAGE_TYPE.DEV);
|
|
118
114
|
}
|
|
119
115
|
get devTargetsForCI() {
|
|
120
|
-
return this.awsDeploymentTargets.filter((target) => target.
|
|
116
|
+
return this.awsDeploymentTargets.filter((target) => target.awsStageType === aws_deployment_target_1.AWS_STAGE_TYPE.DEV && target.ciDeployment);
|
|
121
117
|
}
|
|
122
118
|
get devTargetsForLocal() {
|
|
123
|
-
return this.awsDeploymentTargets.filter((target) => target.
|
|
124
|
-
target.localDeployment);
|
|
119
|
+
return this.awsDeploymentTargets.filter((target) => target.awsStageType === aws_deployment_target_1.AWS_STAGE_TYPE.DEV && target.localDeployment);
|
|
125
120
|
}
|
|
126
121
|
preSynthesize() {
|
|
127
122
|
super.preSynthesize();
|
|
@@ -136,4 +131,4 @@ class AwsDeploymentConfig extends projen_1.Component {
|
|
|
136
131
|
}
|
|
137
132
|
}
|
|
138
133
|
exports.AwsDeploymentConfig = AwsDeploymentConfig;
|
|
139
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-deployment-config.js","sourceRoot":"","sources":["../../src/aws/aws-deployment-config.ts"],"names":[],"mappings":"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","sourcesContent":["import { join, relative } from \"node:path\";\nimport { Component } from \"projen\";\nimport { AwsCdkTypeScriptApp } from \"projen/lib/awscdk\";\nimport { AWS_DEPLOY_TYPE, AwsDeploymentTarget } from \"./aws-deployment-target\";\nimport { TurboRepo } from \"../turbo\";\n\n/*******************************************************************************\n *\n * AWS Deployment Configuration\n *\n * This component allows configuration of multiple AWS deployment\n * targets, each with its own account, region, and deployment type\n * (dev, stage, prod). It supports both local and CI deployments,\n * with customizable settings for each target.\n *\n ******************************************************************************/\n\n/*\nexport interface AwsDeploymentConfigOptions {}\n*/\n\nexport class AwsDeploymentConfig extends Component {\n  public static of(\n    project: AwsCdkTypeScriptApp,\n  ): AwsDeploymentConfig | undefined {\n    const isDefined = (c: Component): c is AwsDeploymentConfig =>\n      c instanceof AwsDeploymentConfig;\n    return project.components.find(isDefined);\n  }\n\n  /**\n   * Environment variables to be injected into all tasks.\n   */\n  public readonly env: Record<string, string>;\n\n  /**\n   * The relative path to the project directory from the root of the project.\n   */\n  public readonly projectPath: string;\n\n  /**\n   * The relative path to the root of the project from the output directory.\n   */\n  public readonly rootPath: string;\n\n  /**\n   * The output directory for the CDK synthesis, from the root directory.\n   */\n  public readonly rootCdkOut: string;\n\n  /**\n   * The output directory for the CDK synthesis.\n   */\n  public readonly cdkOut: string;\n\n  /**\n   * Array of targets for deployment.\n   */\n  public readonly awsDeploymentTargets: Array<AwsDeploymentTarget> = [];\n\n  constructor(project: AwsCdkTypeScriptApp) {\n    super(project);\n\n    /**\n     * Common variables used across tasks.\n     */\n    this.env = { GIT_BRANCH: \"$(git branch --show-current)\" };\n    this.projectPath = relative(project.root.outdir, project.outdir);\n    this.rootPath = relative(project.outdir, project.root.outdir);\n    this.rootCdkOut = join(\"dist\", this.projectPath, \"cdk.out\");\n    this.cdkOut = join(this.rootPath, \"dist\", this.projectPath, \"cdk.out\");\n\n    /**\n     * Reset some tasks we will rebuild below.\n     */\n    [\"deploy\", \"watch\"].forEach((taskName) => {\n      const task = project.tasks.tryFind(taskName);\n      if (task) {\n        task.reset();\n        task.say(\n          \"Generic task is disabled. Please use the specific task for your deployment target.\",\n        );\n      }\n    });\n\n    /**\n     * Redefine Synth here\n     *\n     * Deploy and watch get reconfigured per deployment target.\n     * @see addDeploymentTarget()\n     */\n    this.configureSynthTask();\n  }\n\n  /*****************************************************************************\n   *\n   * Target filter helpers\n   *\n   * Return various targets for deployment scripts to use.\n   *\n   ****************************************************************************/\n\n  /**\n   * @returns All production deployment targets.\n   */\n  public get prodTargets(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) => target.awsDeploymentType === AWS_DEPLOY_TYPE.PROD,\n    );\n  }\n  public get prodTargetsForCI(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) =>\n        target.awsDeploymentType === AWS_DEPLOY_TYPE.PROD &&\n        target.ciDeployment,\n    );\n  }\n  public get prodTargetsForLocal(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) =>\n        target.awsDeploymentType === AWS_DEPLOY_TYPE.PROD &&\n        target.localDeployment,\n    );\n  }\n\n  /**\n   *\n   * @returns All stage deployment targets.\n   */\n  public get stageTargets(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) => target.awsDeploymentType === AWS_DEPLOY_TYPE.STAGE,\n    );\n  }\n  public get stageTargetsForCI(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) =>\n        target.awsDeploymentType === AWS_DEPLOY_TYPE.STAGE &&\n        target.ciDeployment,\n    );\n  }\n  public get stageTargetsForLocal(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) =>\n        target.awsDeploymentType === AWS_DEPLOY_TYPE.STAGE &&\n        target.localDeployment,\n    );\n  }\n\n  /**\n   *\n   * @returns All dev deployment targets.\n   */\n  public get devTargets(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) => target.awsDeploymentType === AWS_DEPLOY_TYPE.DEV,\n    );\n  }\n  public get devTargetsForCI(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) =>\n        target.awsDeploymentType === AWS_DEPLOY_TYPE.DEV && target.ciDeployment,\n    );\n  }\n  public get devTargetsForLocal(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) =>\n        target.awsDeploymentType === AWS_DEPLOY_TYPE.DEV &&\n        target.localDeployment,\n    );\n  }\n\n  /*****************************************************************************\n   *\n   * Synth Tasks\n   *\n   * - Configure synth task to use the branch name\n   * - Change the output location for easier workflows.\n   *\n   ****************************************************************************/\n\n  private configureSynthTask = (): void => {\n    this.project.tasks.tryFind(\"synth\")?.reset(`rm -rf ${this.cdkOut}`);\n    this.project.tasks\n      .tryFind(\"synth\")\n      ?.exec(`cdk synth --output ${this.cdkOut}`, { env: this.env });\n\n    this.project.tasks.tryFind(\"synth:silent\")?.reset(`rm -rf ${this.cdkOut}`);\n    this.project.tasks\n      .tryFind(\"synth:silent\")\n      ?.exec(`cdk synth -q --output ${this.cdkOut}`, { env: this.env });\n  };\n\n  preSynthesize(): void {\n    super.preSynthesize();\n\n    /**\n     * If turbo's active we should ensure the post compile task\n     * is configured to consider the cdk output directory in it's root location.\n     */\n    if (TurboRepo.of(this.project)) {\n      const turbo = TurboRepo.of(this.project)!;\n      turbo.postCompileTask?.outputs.push(join(this.cdkOut, \"**\"));\n    }\n  }\n}\n"]}
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-deployment-config.js","sourceRoot":"","sources":["../../src/aws/aws-deployment-config.ts"],"names":[],"mappings":"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","sourcesContent":["import { join, relative } from \"node:path\";\nimport { Component } from \"projen\";\nimport { AwsCdkTypeScriptApp } from \"projen/lib/awscdk\";\nimport { AWS_STAGE_TYPE, AwsDeploymentTarget } from \"./aws-deployment-target\";\nimport { TurboRepo } from \"../turbo\";\n\n/*******************************************************************************\n *\n * AWS Deployment Configuration\n *\n * This component allows configuration of multiple AWS deployment\n * targets, each with its own account, region, and deployment type\n * (dev, stage, prod). It supports both local and CI deployments,\n * with customizable settings for each target.\n *\n ******************************************************************************/\n\n/*\nexport interface AwsDeploymentConfigOptions {}\n*/\n\nexport class AwsDeploymentConfig extends Component {\n  public static of(\n    project: AwsCdkTypeScriptApp,\n  ): AwsDeploymentConfig | undefined {\n    const isDefined = (c: Component): c is AwsDeploymentConfig =>\n      c instanceof AwsDeploymentConfig;\n    return project.components.find(isDefined);\n  }\n\n  /**\n   * Environment variables to be injected into all tasks.\n   */\n  public readonly env: Record<string, string>;\n\n  /**\n   * The relative path to the project directory from the root of the project.\n   */\n  public readonly projectPath: string;\n\n  /**\n   * The relative path to the root of the project from the output directory.\n   */\n  public readonly rootPath: string;\n\n  /**\n   * The output directory for the CDK synthesis, from the root directory.\n   */\n  public readonly rootCdkOut: string;\n\n  /**\n   * The output directory for the CDK synthesis.\n   */\n  public readonly cdkOut: string;\n\n  /**\n   * Array of targets for deployment.\n   */\n  public readonly awsDeploymentTargets: Array<AwsDeploymentTarget> = [];\n\n  constructor(project: AwsCdkTypeScriptApp) {\n    super(project);\n\n    /**\n     * Common variables used across tasks.\n     */\n    this.env = { GIT_BRANCH: \"$(git branch --show-current)\" };\n    this.projectPath = relative(project.root.outdir, project.outdir);\n    this.rootPath = relative(project.outdir, project.root.outdir);\n    this.rootCdkOut = join(\"dist\", this.projectPath, \"cdk.out\");\n    this.cdkOut = join(this.rootPath, \"dist\", this.projectPath, \"cdk.out\");\n\n    /**\n     * Reset some tasks we will rebuild below.\n     */\n    [\"deploy\", \"watch\"].forEach((taskName) => {\n      const task = project.tasks.tryFind(taskName);\n      if (task) {\n        task.reset();\n        task.say(\n          \"Generic task is disabled. Please use the specific task for your deployment target.\",\n        );\n      }\n    });\n\n    /**\n     * Redefine Synth here\n     *\n     * Deploy and watch get reconfigured per deployment target.\n     * @see addDeploymentTarget()\n     */\n    this.configureSynthTask();\n  }\n\n  /*****************************************************************************\n   *\n   * Target filter helpers\n   *\n   * Return various targets for deployment scripts to use.\n   *\n   ****************************************************************************/\n\n  /**\n   * @returns All production deployment targets.\n   */\n  public get prodTargets(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) => target.awsStageType === AWS_STAGE_TYPE.PROD,\n    );\n  }\n  public get prodTargetsForCI(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) =>\n        target.awsStageType === AWS_STAGE_TYPE.PROD && target.ciDeployment,\n    );\n  }\n  public get prodTargetsForLocal(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) =>\n        target.awsStageType === AWS_STAGE_TYPE.PROD && target.localDeployment,\n    );\n  }\n\n  /**\n   *\n   * @returns All stage deployment targets.\n   */\n  public get stageTargets(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) => target.awsStageType === AWS_STAGE_TYPE.STAGE,\n    );\n  }\n  public get stageTargetsForCI(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) =>\n        target.awsStageType === AWS_STAGE_TYPE.STAGE && target.ciDeployment,\n    );\n  }\n  public get stageTargetsForLocal(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) =>\n        target.awsStageType === AWS_STAGE_TYPE.STAGE && target.localDeployment,\n    );\n  }\n\n  /**\n   *\n   * @returns All dev deployment targets.\n   */\n  public get devTargets(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) => target.awsStageType === AWS_STAGE_TYPE.DEV,\n    );\n  }\n  public get devTargetsForCI(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) =>\n        target.awsStageType === AWS_STAGE_TYPE.DEV && target.ciDeployment,\n    );\n  }\n  public get devTargetsForLocal(): Array<AwsDeploymentTarget> {\n    return this.awsDeploymentTargets.filter(\n      (target) =>\n        target.awsStageType === AWS_STAGE_TYPE.DEV && target.localDeployment,\n    );\n  }\n\n  /*****************************************************************************\n   *\n   * Synth Tasks\n   *\n   * - Configure synth task to use the branch name\n   * - Change the output location for easier workflows.\n   *\n   ****************************************************************************/\n\n  private configureSynthTask = (): void => {\n    this.project.tasks.tryFind(\"synth\")?.reset(`rm -rf ${this.cdkOut}`);\n    this.project.tasks\n      .tryFind(\"synth\")\n      ?.exec(`cdk synth --output ${this.cdkOut}`, { env: this.env });\n\n    this.project.tasks.tryFind(\"synth:silent\")?.reset(`rm -rf ${this.cdkOut}`);\n    this.project.tasks\n      .tryFind(\"synth:silent\")\n      ?.exec(`cdk synth -q --output ${this.cdkOut}`, { env: this.env });\n  };\n\n  preSynthesize(): void {\n    super.preSynthesize();\n\n    /**\n     * If turbo's active we should ensure the post compile task\n     * is configured to consider the cdk output directory in it's root location.\n     */\n    if (TurboRepo.of(this.project)) {\n      const turbo = TurboRepo.of(this.project)!;\n      turbo.postCompileTask?.outputs.push(join(this.cdkOut, \"**\"));\n    }\n  }\n}\n"]}
|
|
@@ -9,7 +9,12 @@ import { GitBranch } from "../git";
|
|
|
9
9
|
* A single deployment target that CDK applications can be deployed into.
|
|
10
10
|
*
|
|
11
11
|
******************************************************************************/
|
|
12
|
-
|
|
12
|
+
/**
|
|
13
|
+
* Stage Types
|
|
14
|
+
*
|
|
15
|
+
* What stage of deployment is this? Dev, staging, or prod?
|
|
16
|
+
*/
|
|
17
|
+
export declare const AWS_STAGE_TYPE: {
|
|
13
18
|
/**
|
|
14
19
|
* Development environment, typically used for testing and development.
|
|
15
20
|
*/
|
|
@@ -26,7 +31,28 @@ export declare const AWS_DEPLOY_TYPE: {
|
|
|
26
31
|
/**
|
|
27
32
|
* Above const as a type.
|
|
28
33
|
*/
|
|
29
|
-
export type
|
|
34
|
+
export type AwsStageType = (typeof AWS_STAGE_TYPE)[keyof typeof AWS_STAGE_TYPE];
|
|
35
|
+
/**
|
|
36
|
+
* Environment Types
|
|
37
|
+
*
|
|
38
|
+
* Is this a primary of secondary region / environment?
|
|
39
|
+
*/
|
|
40
|
+
export declare const AWS_ENVIRONMENT_TYPE: {
|
|
41
|
+
/**
|
|
42
|
+
* Account and region that represents the primary region for this service.
|
|
43
|
+
* For example, the base DynamoDB Region for global tables.
|
|
44
|
+
*/
|
|
45
|
+
readonly PRIMARY: "primary";
|
|
46
|
+
/**
|
|
47
|
+
* Account and region that represents a secondary region for this service.
|
|
48
|
+
* For example, a replica region for a global DynamoDB table.
|
|
49
|
+
*/
|
|
50
|
+
readonly SECONDARY: "secondary";
|
|
51
|
+
};
|
|
52
|
+
/**
|
|
53
|
+
* Above const as a type.
|
|
54
|
+
*/
|
|
55
|
+
export type AwsEnvironmentType = (typeof AWS_ENVIRONMENT_TYPE)[keyof typeof AWS_ENVIRONMENT_TYPE];
|
|
30
56
|
/**
|
|
31
57
|
* Represents the configuration for local deployment in AWS.
|
|
32
58
|
*/
|
|
@@ -40,7 +66,7 @@ export interface AwsLocalDeploymentConfig {
|
|
|
40
66
|
/**
|
|
41
67
|
* Named Role used to conduct local deployments.
|
|
42
68
|
*
|
|
43
|
-
* @default "
|
|
69
|
+
* @default "poweruseraccess"
|
|
44
70
|
*/
|
|
45
71
|
readonly roleName?: string;
|
|
46
72
|
/**
|
|
@@ -80,7 +106,13 @@ export interface AwsDeploymentTargetOptions {
|
|
|
80
106
|
*
|
|
81
107
|
* @default 'dev'
|
|
82
108
|
*/
|
|
83
|
-
readonly
|
|
109
|
+
readonly awsStageType?: AwsStageType;
|
|
110
|
+
/**
|
|
111
|
+
* AWS environment type, such as primary or secondary.
|
|
112
|
+
*
|
|
113
|
+
* @default 'primary'
|
|
114
|
+
*/
|
|
115
|
+
readonly awsEnvironmentType?: AwsEnvironmentType;
|
|
84
116
|
/**
|
|
85
117
|
* The AWS profile to use for this deployment target.
|
|
86
118
|
*
|
|
@@ -119,11 +151,17 @@ export declare class AwsDeploymentTarget extends Component {
|
|
|
119
151
|
*/
|
|
120
152
|
region: string;
|
|
121
153
|
/**'
|
|
122
|
-
* AWS
|
|
154
|
+
* AWS stage type, such as dev, stage, or prod.
|
|
123
155
|
*
|
|
124
156
|
* @default 'dev'
|
|
125
157
|
*/
|
|
126
|
-
|
|
158
|
+
awsStageType: AwsStageType;
|
|
159
|
+
/**
|
|
160
|
+
* AWS environment type, such as primary or secondary.
|
|
161
|
+
*
|
|
162
|
+
* @default 'primary'
|
|
163
|
+
*/
|
|
164
|
+
awsEnvironmentType: AwsEnvironmentType;
|
|
127
165
|
/**
|
|
128
166
|
* The AWS profile to use for this deployment target.
|
|
129
167
|
*
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AwsDeploymentTarget = exports.
|
|
3
|
+
exports.AwsDeploymentTarget = exports.AWS_ENVIRONMENT_TYPE = exports.AWS_STAGE_TYPE = void 0;
|
|
4
4
|
const projen_1 = require("projen");
|
|
5
5
|
const aws_deployment_config_1 = require("./aws-deployment-config");
|
|
6
6
|
/*******************************************************************************
|
|
@@ -10,7 +10,12 @@ const aws_deployment_config_1 = require("./aws-deployment-config");
|
|
|
10
10
|
* A single deployment target that CDK applications can be deployed into.
|
|
11
11
|
*
|
|
12
12
|
******************************************************************************/
|
|
13
|
-
|
|
13
|
+
/**
|
|
14
|
+
* Stage Types
|
|
15
|
+
*
|
|
16
|
+
* What stage of deployment is this? Dev, staging, or prod?
|
|
17
|
+
*/
|
|
18
|
+
exports.AWS_STAGE_TYPE = {
|
|
14
19
|
/**
|
|
15
20
|
* Development environment, typically used for testing and development.
|
|
16
21
|
*/
|
|
@@ -24,6 +29,23 @@ exports.AWS_DEPLOY_TYPE = {
|
|
|
24
29
|
*/
|
|
25
30
|
PROD: "prod",
|
|
26
31
|
};
|
|
32
|
+
/**
|
|
33
|
+
* Environment Types
|
|
34
|
+
*
|
|
35
|
+
* Is this a primary of secondary region / environment?
|
|
36
|
+
*/
|
|
37
|
+
exports.AWS_ENVIRONMENT_TYPE = {
|
|
38
|
+
/**
|
|
39
|
+
* Account and region that represents the primary region for this service.
|
|
40
|
+
* For example, the base DynamoDB Region for global tables.
|
|
41
|
+
*/
|
|
42
|
+
PRIMARY: "primary",
|
|
43
|
+
/**
|
|
44
|
+
* Account and region that represents a secondary region for this service.
|
|
45
|
+
* For example, a replica region for a global DynamoDB table.
|
|
46
|
+
*/
|
|
47
|
+
SECONDARY: "secondary",
|
|
48
|
+
};
|
|
27
49
|
class AwsDeploymentTarget extends projen_1.Component {
|
|
28
50
|
/**
|
|
29
51
|
* Static method to discovert targets in a project.
|
|
@@ -51,7 +73,7 @@ class AwsDeploymentTarget extends projen_1.Component {
|
|
|
51
73
|
if (this.localDeployment) {
|
|
52
74
|
const taskName = [
|
|
53
75
|
"deploy",
|
|
54
|
-
this.
|
|
76
|
+
this.awsStageType,
|
|
55
77
|
this.account,
|
|
56
78
|
this.region,
|
|
57
79
|
].join(":");
|
|
@@ -73,7 +95,7 @@ class AwsDeploymentTarget extends projen_1.Component {
|
|
|
73
95
|
if (this.localDeployment) {
|
|
74
96
|
const taskName = [
|
|
75
97
|
"watch",
|
|
76
|
-
this.
|
|
98
|
+
this.awsStageType,
|
|
77
99
|
this.account,
|
|
78
100
|
this.region,
|
|
79
101
|
].join(":");
|
|
@@ -99,12 +121,17 @@ class AwsDeploymentTarget extends projen_1.Component {
|
|
|
99
121
|
/**
|
|
100
122
|
* Set default type
|
|
101
123
|
*/
|
|
102
|
-
this.
|
|
124
|
+
this.awsStageType = options.awsStageType || exports.AWS_STAGE_TYPE.DEV;
|
|
125
|
+
/**
|
|
126
|
+
* Set default environment type
|
|
127
|
+
*/
|
|
128
|
+
this.awsEnvironmentType =
|
|
129
|
+
options.awsEnvironmentType || exports.AWS_ENVIRONMENT_TYPE.PRIMARY;
|
|
103
130
|
/**
|
|
104
131
|
* Set default Branches
|
|
105
132
|
*/
|
|
106
133
|
this.branches =
|
|
107
|
-
options.branches || this.
|
|
134
|
+
options.branches || this.awsStageType === exports.AWS_STAGE_TYPE.PROD
|
|
108
135
|
? [
|
|
109
136
|
{
|
|
110
137
|
branch: "main",
|
|
@@ -119,17 +146,17 @@ class AwsDeploymentTarget extends projen_1.Component {
|
|
|
119
146
|
* Set default for local deployment
|
|
120
147
|
*/
|
|
121
148
|
this.localDeployment =
|
|
122
|
-
options.localDeployment ?? this.
|
|
149
|
+
options.localDeployment ?? this.awsStageType === exports.AWS_STAGE_TYPE.DEV;
|
|
123
150
|
/**
|
|
124
151
|
* Some default configurations for local deployments.
|
|
125
152
|
*/
|
|
126
153
|
if (this.localDeployment) {
|
|
127
154
|
const roleName = options.localDeploymentConfig?.roleName?.toLowerCase() ||
|
|
128
|
-
"
|
|
155
|
+
"poweruseraccess";
|
|
129
156
|
const profile = options.localDeploymentConfig?.profile ||
|
|
130
|
-
`${roleName}-${this.
|
|
157
|
+
`${roleName}-${this.awsStageType}-${this.account}-${this.region}`;
|
|
131
158
|
const stackPattern = options.localDeploymentConfig?.stackPattern ||
|
|
132
|
-
|
|
159
|
+
`${this.awsStageType}/${this.awsEnvironmentType}/*-${this.account}-${this.region}`;
|
|
133
160
|
this.localDeploymentConfig = {
|
|
134
161
|
profile,
|
|
135
162
|
roleName,
|
|
@@ -171,4 +198,4 @@ class AwsDeploymentTarget extends projen_1.Component {
|
|
|
171
198
|
}
|
|
172
199
|
}
|
|
173
200
|
exports.AwsDeploymentTarget = AwsDeploymentTarget;
|
|
174
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-deployment-target.js","sourceRoot":"","sources":["../../src/aws/aws-deployment-target.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component } from \"projen\";\nimport { AwsCdkTypeScriptApp } from \"projen/lib/awscdk\";\nimport { AwsDeploymentConfig } from \"./aws-deployment-config\";\nimport { GitBranch } from \"../git\";\n\n/*******************************************************************************\n *\n * AWS Deployment Configuration\n *\n * A single deployment target that CDK applications can be deployed into.\n *\n ******************************************************************************/\n\nexport const AWS_DEPLOY_TYPE = {\n  /**\n   * Development environment, typically used for testing and development.\n   */\n  DEV: \"dev\",\n\n  /**\n   * Staging environment, used for pre-production testing.\n   */\n  STAGE: \"stage\",\n\n  /**\n   * Production environment, used for live deployments.\n   */\n  PROD: \"prod\",\n} as const;\n\n/**\n * Above const as a type.\n */\nexport type AwsDeploymentType =\n  (typeof AWS_DEPLOY_TYPE)[keyof typeof AWS_DEPLOY_TYPE];\n\n/**\n * Represents the configuration for local deployment in AWS.\n */\nexport interface AwsLocalDeploymentConfig {\n  /**\n   * The AWS profile (in ~/.aws/config) to use for local deployment.\n   *\n   * @default generated dynamically based role name, account and region\n   */\n  readonly profile?: string;\n\n  /**\n   * Named Role used to conduct local deployments.\n   *\n   * @default \"administratoraccess\"\n   */\n  readonly roleName?: string;\n\n  /**\n   * The pattern used to identify stacks to deploy in CI deployments.\n   *\n   * @default *-${account}-${region}\n   */\n  readonly stackPattern?: string;\n}\n\nexport interface CiDeploymentConfig {\n  /**\n   * The OIDC IAM Role to assume for CI deployments.\n   */\n  readonly roleArn: string;\n\n  /**\n   * The pattern used to identify stacks to deploy in CI deployments.\n   *\n   * @default *-${account}-${region}\n   */\n  readonly stackPattern?: string;\n}\n\n/**\n * Represents a deployment target in AWS, including account and region, and\n * branches allowed to deploy to this target.\n */\nexport interface AwsDeploymentTargetOptions {\n  /**\n   * The account name for the deployment target.\n   */\n  readonly account: string;\n\n  /**\n   * The AWS region for the deployment target.\n   */\n  readonly region: string;\n\n  /**\n   * AWS deployment type, such as dev, stage, or prod.\n   *\n   * @default 'dev'\n   */\n  readonly awsDeploymentType?: AwsDeploymentType;\n\n  /**\n   * The AWS profile to use for this deployment target.\n   *\n   * @default ['main'] when prod release type, ['feature/*'] when dev type\n   */\n  readonly branches?: Array<GitBranch>;\n\n  /**\n   * Can this deployment target be used for local development?\n   *\n   * @default true for dev environments, false for prod environments\n   */\n  readonly localDeployment?: boolean;\n\n  /**\n   * Configuration when deploying to this target locally.\n   */\n  readonly localDeploymentConfig?: AwsLocalDeploymentConfig;\n\n  /**\n   * Can this deployment target be used in CI deployments?\n   *\n   * @default false\n   */\n  readonly ciDeployment?: boolean;\n\n  /*\n   * Configuration when deploying to this target in CI.\n\n   */\n  readonly ciDeploymentConfig?: CiDeploymentConfig;\n}\n\nexport class AwsDeploymentTarget extends Component {\n  /**\n   * Static method to discovert targets in a project.\n   */\n  public static of(\n    project: AwsCdkTypeScriptApp,\n  ): Array<AwsDeploymentTarget> | undefined {\n    const isDefined = (c: Component): c is AwsDeploymentTarget =>\n      c instanceof AwsDeploymentTarget;\n    return project.components.filter(isDefined);\n  }\n\n  /**\n   * The account name for the deployment target.\n   */\n  public account: string;\n\n  /**\n   * The AWS region for the deployment target.\n   */\n  public region: string;\n\n  /**'\n   * AWS deployment type, such as dev, stage, or prod.\n   *\n   * @default 'dev'\n   */\n  public awsDeploymentType?: AwsDeploymentType;\n\n  /**\n   * The AWS profile to use for this deployment target.\n   *\n   * @default ['main'] when prod release type, ['feature/*'] when dev type\n   */\n  public branches: Array<GitBranch> = [];\n\n  /**\n   * Can this deployment target be used for local development?\n   *\n   * @default true for dev environments, false for prod environments\n   */\n  public localDeployment?: boolean;\n\n  /**\n   * Configuration when deploying to this target locally.\n   */\n  public localDeploymentConfig?: AwsLocalDeploymentConfig;\n\n  /**\n   * Can this deployment target be used in CI deployments?\n   *\n   * @default false\n   */\n  public ciDeployment?: boolean;\n\n  /*\n   * Configuration when deploying to this target in CI.\n   */\n  public ciDeploymentConfig?: Required<CiDeploymentConfig>;\n\n  /**\n   * Configuration for the CDK output directory for this deployment target.\n   */\n  public awsDeploymentConfig: AwsDeploymentConfig;\n\n  constructor(\n    project: AwsCdkTypeScriptApp,\n    options: AwsDeploymentTargetOptions,\n  ) {\n    super(project);\n\n    /**\n     * Set target region and account.\n     */\n    this.account = options.account;\n    this.region = options.region;\n\n    /**\n     * Set default type\n     */\n    this.awsDeploymentType = options.awsDeploymentType || AWS_DEPLOY_TYPE.DEV;\n\n    /**\n     * Set default Branches\n     */\n\n    this.branches =\n      options.branches || this.awsDeploymentType === AWS_DEPLOY_TYPE.PROD\n        ? [\n            {\n              branch: \"main\",\n            },\n          ]\n        : [\n            {\n              branch: \"feature/*\",\n            },\n          ];\n\n    /**\n     * Set default for local deployment\n     */\n    this.localDeployment =\n      options.localDeployment ?? this.awsDeploymentType === AWS_DEPLOY_TYPE.DEV;\n\n    /**\n     * Some default configurations for local deployments.\n     */\n    if (this.localDeployment) {\n      const roleName =\n        options.localDeploymentConfig?.roleName?.toLowerCase() ||\n        \"administratoraccess\";\n      const profile =\n        options.localDeploymentConfig?.profile ||\n        `${roleName}-${this.awsDeploymentType}-${this.account}-${this.region}`;\n\n      const stackPattern =\n        options.localDeploymentConfig?.stackPattern ||\n        `*-${this.account}-${this.region}`;\n\n      this.localDeploymentConfig = {\n        profile,\n        roleName,\n        stackPattern,\n        ...options.localDeploymentConfig,\n      };\n    }\n\n    /**\n     * Set CI deployment default\n     */\n    this.ciDeployment = options.ciDeployment ?? false;\n\n    /**\n     * Some defaults for CI deployments.\n     */\n    if (this.ciDeployment) {\n      const roleArn =\n        options.ciDeploymentConfig?.roleArn ||\n        `arn:aws:iam::${this.account}:role/GitHubDeployer}`;\n\n      const stackPattern =\n        options.ciDeploymentConfig?.stackPattern ||\n        `*-${this.account}-${this.region}`;\n\n      this.ciDeploymentConfig = {\n        roleArn,\n        stackPattern,\n        ...options.ciDeploymentConfig,\n      };\n    }\n\n    /**\n     * Find or create CDK folder config for this project.\n     */\n    this.awsDeploymentConfig =\n      AwsDeploymentConfig.of(project) || new AwsDeploymentConfig(project);\n\n    /**\n     * Add the target to the deployment targets array.\n     */\n    this.awsDeploymentConfig.awsDeploymentTargets.push(this);\n\n    // Deploy tasks are configured per target.\n    this.configureDeployTask();\n\n    // Watch tasks are configured per target.\n    this.configureWatchTask();\n  }\n\n  /*****************************************************************************\n   *\n   * Deploy Tasks\n   *\n   * - If local deploy, add a deploy task.\n   *\n   ****************************************************************************/\n\n  private configureDeployTask = (): void => {\n    if (this.localDeployment) {\n      const taskName = [\n        \"deploy\",\n        this.awsDeploymentType,\n        this.account,\n        this.region,\n      ].join(\":\");\n      const deployTask = this.project.tasks.addTask(taskName, {\n        env: this.awsDeploymentConfig.env,\n      });\n      deployTask.exec(\n        `cdk deploy --lookups=false --require-approval=never --profile=${this.localDeploymentConfig?.profile} --app=${this.awsDeploymentConfig.cdkOut} \"${this.localDeploymentConfig?.stackPattern}\"`,\n      );\n    }\n  };\n\n  /*****************************************************************************\n   *\n   * Watch tasks\n   *\n   * - Configure watch task to use the branch name\n   * - configure watch task to use the correct synth output location.\n   *\n   ****************************************************************************/\n\n  private configureWatchTask = (): void => {\n    if (this.localDeployment) {\n      const taskName = [\n        \"watch\",\n        this.awsDeploymentType,\n        this.account,\n        this.region,\n      ].join(\":\");\n      const watchTask = this.project.tasks.addTask(taskName, {\n        env: this.awsDeploymentConfig.env,\n      });\n\n      // update the synth first\n      const synthSilent = this.project.tasks.tryFind(\"synth:silent\");\n      if (synthSilent) {\n        watchTask.spawn(synthSilent);\n      }\n\n      // do a normal deploy\n      watchTask.exec(\n        `cdk deploy --lookups=false --require-approval=never --profile=${this.localDeploymentConfig?.profile} --app=${this.awsDeploymentConfig.cdkOut} \"${this.localDeploymentConfig?.stackPattern}\"`,\n      );\n\n      // watch for changes and log output\n      watchTask.exec(\n        `cdk watch --lookups=false --require-approval=never --hotswap --profile=${this.localDeploymentConfig?.profile} \"${this.localDeploymentConfig?.stackPattern}\"`,\n      );\n    }\n  };\n}\n"]}
|
|
201
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-deployment-target.js","sourceRoot":"","sources":["../../src/aws/aws-deployment-target.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component } from \"projen\";\nimport { AwsCdkTypeScriptApp } from \"projen/lib/awscdk\";\nimport { AwsDeploymentConfig } from \"./aws-deployment-config\";\nimport { GitBranch } from \"../git\";\n\n/*******************************************************************************\n *\n * AWS Deployment Configuration\n *\n * A single deployment target that CDK applications can be deployed into.\n *\n ******************************************************************************/\n\n/**\n * Stage Types\n *\n * What stage of deployment is this? Dev, staging, or prod?\n */\nexport const AWS_STAGE_TYPE = {\n  /**\n   * Development environment, typically used for testing and development.\n   */\n  DEV: \"dev\",\n\n  /**\n   * Staging environment, used for pre-production testing.\n   */\n  STAGE: \"stage\",\n\n  /**\n   * Production environment, used for live deployments.\n   */\n  PROD: \"prod\",\n} as const;\n\n/**\n * Above const as a type.\n */\nexport type AwsStageType = (typeof AWS_STAGE_TYPE)[keyof typeof AWS_STAGE_TYPE];\n\n/**\n * Environment Types\n *\n * Is this a primary of secondary region / environment?\n */\nexport const AWS_ENVIRONMENT_TYPE = {\n  /**\n   * Account and region that represents the primary region for this service.\n   * For example, the base DynamoDB Region for global tables.\n   */\n  PRIMARY: \"primary\",\n  /**\n   * Account and region that represents a secondary region for this service.\n   * For example, a replica region for a global DynamoDB table.\n   */\n  SECONDARY: \"secondary\",\n} as const;\n\n/**\n * Above const as a type.\n */\nexport type AwsEnvironmentType =\n  (typeof AWS_ENVIRONMENT_TYPE)[keyof typeof AWS_ENVIRONMENT_TYPE];\n\n/**\n * Represents the configuration for local deployment in AWS.\n */\nexport interface AwsLocalDeploymentConfig {\n  /**\n   * The AWS profile (in ~/.aws/config) to use for local deployment.\n   *\n   * @default generated dynamically based role name, account and region\n   */\n  readonly profile?: string;\n\n  /**\n   * Named Role used to conduct local deployments.\n   *\n   * @default \"poweruseraccess\"\n   */\n  readonly roleName?: string;\n\n  /**\n   * The pattern used to identify stacks to deploy in CI deployments.\n   *\n   * @default *-${account}-${region}\n   */\n  readonly stackPattern?: string;\n}\n\nexport interface CiDeploymentConfig {\n  /**\n   * The OIDC IAM Role to assume for CI deployments.\n   */\n  readonly roleArn: string;\n\n  /**\n   * The pattern used to identify stacks to deploy in CI deployments.\n   *\n   * @default *-${account}-${region}\n   */\n  readonly stackPattern?: string;\n}\n\n/**\n * Represents a deployment target in AWS, including account and region, and\n * branches allowed to deploy to this target.\n */\nexport interface AwsDeploymentTargetOptions {\n  /**\n   * The account name for the deployment target.\n   */\n  readonly account: string;\n\n  /**\n   * The AWS region for the deployment target.\n   */\n  readonly region: string;\n\n  /**\n   * AWS deployment type, such as dev, stage, or prod.\n   *\n   * @default 'dev'\n   */\n  readonly awsStageType?: AwsStageType;\n\n  /**\n   * AWS environment type, such as primary or secondary.\n   *\n   * @default 'primary'\n   */\n  readonly awsEnvironmentType?: AwsEnvironmentType;\n\n  /**\n   * The AWS profile to use for this deployment target.\n   *\n   * @default ['main'] when prod release type, ['feature/*'] when dev type\n   */\n  readonly branches?: Array<GitBranch>;\n\n  /**\n   * Can this deployment target be used for local development?\n   *\n   * @default true for dev environments, false for prod environments\n   */\n  readonly localDeployment?: boolean;\n\n  /**\n   * Configuration when deploying to this target locally.\n   */\n  readonly localDeploymentConfig?: AwsLocalDeploymentConfig;\n\n  /**\n   * Can this deployment target be used in CI deployments?\n   *\n   * @default false\n   */\n  readonly ciDeployment?: boolean;\n\n  /*\n   * Configuration when deploying to this target in CI.\n\n   */\n  readonly ciDeploymentConfig?: CiDeploymentConfig;\n}\n\nexport class AwsDeploymentTarget extends Component {\n  /**\n   * Static method to discovert targets in a project.\n   */\n  public static of(\n    project: AwsCdkTypeScriptApp,\n  ): Array<AwsDeploymentTarget> | undefined {\n    const isDefined = (c: Component): c is AwsDeploymentTarget =>\n      c instanceof AwsDeploymentTarget;\n    return project.components.filter(isDefined);\n  }\n\n  /**\n   * The account name for the deployment target.\n   */\n  public account: string;\n\n  /**\n   * The AWS region for the deployment target.\n   */\n  public region: string;\n\n  /**'\n   * AWS stage type, such as dev, stage, or prod.\n   *\n   * @default 'dev'\n   */\n  public awsStageType: AwsStageType;\n\n  /**\n   * AWS environment type, such as primary or secondary.\n   *\n   * @default 'primary'\n   */\n  public awsEnvironmentType: AwsEnvironmentType;\n\n  /**\n   * The AWS profile to use for this deployment target.\n   *\n   * @default ['main'] when prod release type, ['feature/*'] when dev type\n   */\n  public branches: Array<GitBranch> = [];\n\n  /**\n   * Can this deployment target be used for local development?\n   *\n   * @default true for dev environments, false for prod environments\n   */\n  public localDeployment?: boolean;\n\n  /**\n   * Configuration when deploying to this target locally.\n   */\n  public localDeploymentConfig?: AwsLocalDeploymentConfig;\n\n  /**\n   * Can this deployment target be used in CI deployments?\n   *\n   * @default false\n   */\n  public ciDeployment?: boolean;\n\n  /*\n   * Configuration when deploying to this target in CI.\n   */\n  public ciDeploymentConfig?: Required<CiDeploymentConfig>;\n\n  /**\n   * Configuration for the CDK output directory for this deployment target.\n   */\n  public awsDeploymentConfig: AwsDeploymentConfig;\n\n  constructor(\n    project: AwsCdkTypeScriptApp,\n    options: AwsDeploymentTargetOptions,\n  ) {\n    super(project);\n\n    /**\n     * Set target region and account.\n     */\n    this.account = options.account;\n    this.region = options.region;\n\n    /**\n     * Set default type\n     */\n    this.awsStageType = options.awsStageType || AWS_STAGE_TYPE.DEV;\n\n    /**\n     * Set default environment type\n     */\n    this.awsEnvironmentType =\n      options.awsEnvironmentType || AWS_ENVIRONMENT_TYPE.PRIMARY;\n\n    /**\n     * Set default Branches\n     */\n\n    this.branches =\n      options.branches || this.awsStageType === AWS_STAGE_TYPE.PROD\n        ? [\n            {\n              branch: \"main\",\n            },\n          ]\n        : [\n            {\n              branch: \"feature/*\",\n            },\n          ];\n\n    /**\n     * Set default for local deployment\n     */\n    this.localDeployment =\n      options.localDeployment ?? this.awsStageType === AWS_STAGE_TYPE.DEV;\n\n    /**\n     * Some default configurations for local deployments.\n     */\n    if (this.localDeployment) {\n      const roleName =\n        options.localDeploymentConfig?.roleName?.toLowerCase() ||\n        \"poweruseraccess\";\n      const profile =\n        options.localDeploymentConfig?.profile ||\n        `${roleName}-${this.awsStageType}-${this.account}-${this.region}`;\n\n      const stackPattern =\n        options.localDeploymentConfig?.stackPattern ||\n        `${this.awsStageType}/${this.awsEnvironmentType}/*-${this.account}-${this.region}`;\n\n      this.localDeploymentConfig = {\n        profile,\n        roleName,\n        stackPattern,\n        ...options.localDeploymentConfig,\n      };\n    }\n\n    /**\n     * Set CI deployment default\n     */\n    this.ciDeployment = options.ciDeployment ?? false;\n\n    /**\n     * Some defaults for CI deployments.\n     */\n    if (this.ciDeployment) {\n      const roleArn =\n        options.ciDeploymentConfig?.roleArn ||\n        `arn:aws:iam::${this.account}:role/GitHubDeployer}`;\n\n      const stackPattern =\n        options.ciDeploymentConfig?.stackPattern ||\n        `*-${this.account}-${this.region}`;\n\n      this.ciDeploymentConfig = {\n        roleArn,\n        stackPattern,\n        ...options.ciDeploymentConfig,\n      };\n    }\n\n    /**\n     * Find or create CDK folder config for this project.\n     */\n    this.awsDeploymentConfig =\n      AwsDeploymentConfig.of(project) || new AwsDeploymentConfig(project);\n\n    /**\n     * Add the target to the deployment targets array.\n     */\n    this.awsDeploymentConfig.awsDeploymentTargets.push(this);\n\n    // Deploy tasks are configured per target.\n    this.configureDeployTask();\n\n    // Watch tasks are configured per target.\n    this.configureWatchTask();\n  }\n\n  /*****************************************************************************\n   *\n   * Deploy Tasks\n   *\n   * - If local deploy, add a deploy task.\n   *\n   ****************************************************************************/\n\n  private configureDeployTask = (): void => {\n    if (this.localDeployment) {\n      const taskName = [\n        \"deploy\",\n        this.awsStageType,\n        this.account,\n        this.region,\n      ].join(\":\");\n      const deployTask = this.project.tasks.addTask(taskName, {\n        env: this.awsDeploymentConfig.env,\n      });\n      deployTask.exec(\n        `cdk deploy --lookups=false --require-approval=never --profile=${this.localDeploymentConfig?.profile} --app=${this.awsDeploymentConfig.cdkOut} \"${this.localDeploymentConfig?.stackPattern}\"`,\n      );\n    }\n  };\n\n  /*****************************************************************************\n   *\n   * Watch tasks\n   *\n   * - Configure watch task to use the branch name\n   * - configure watch task to use the correct synth output location.\n   *\n   ****************************************************************************/\n\n  private configureWatchTask = (): void => {\n    if (this.localDeployment) {\n      const taskName = [\n        \"watch\",\n        this.awsStageType,\n        this.account,\n        this.region,\n      ].join(\":\");\n      const watchTask = this.project.tasks.addTask(taskName, {\n        env: this.awsDeploymentConfig.env,\n      });\n\n      // update the synth first\n      const synthSilent = this.project.tasks.tryFind(\"synth:silent\");\n      if (synthSilent) {\n        watchTask.spawn(synthSilent);\n      }\n\n      // do a normal deploy\n      watchTask.exec(\n        `cdk deploy --lookups=false --require-approval=never --profile=${this.localDeploymentConfig?.profile} --app=${this.awsDeploymentConfig.cdkOut} \"${this.localDeploymentConfig?.stackPattern}\"`,\n      );\n\n      // watch for changes and log output\n      watchTask.exec(\n        `cdk watch --lookups=false --require-approval=never --hotswap --profile=${this.localDeploymentConfig?.profile} \"${this.localDeploymentConfig?.stackPattern}\"`,\n      );\n    }\n  };\n}\n"]}
|
|
@@ -3,19 +3,19 @@ import { AwsCdkTypeScriptApp } from "projen/lib/awscdk";
|
|
|
3
3
|
import { BuildWorkflow, BuildWorkflowOptions } from "projen/lib/build";
|
|
4
4
|
import { JobStep } from "projen/lib/github/workflows-model";
|
|
5
5
|
import { ValueOf } from "type-fest";
|
|
6
|
-
import {
|
|
6
|
+
import { AWS_STAGE_TYPE, AwsDeploymentTarget, AwsEnvironmentType, AwsStageType } from "../aws/aws-deployment-target";
|
|
7
7
|
export declare const PROD_DEPLOY_NAME = "prod-deploy";
|
|
8
8
|
export interface DeployWorkflowOptions {
|
|
9
9
|
/**
|
|
10
10
|
* What type of deploy is this workflow for?
|
|
11
11
|
*
|
|
12
|
-
* @default
|
|
12
|
+
* @default AWS_STAGE_TYPE.DEV
|
|
13
13
|
*/
|
|
14
|
-
readonly
|
|
14
|
+
readonly awsStageType?: ValueOf<typeof AWS_STAGE_TYPE>;
|
|
15
15
|
/**
|
|
16
16
|
* Optionally feed a list of targets to deploy to.
|
|
17
17
|
*
|
|
18
|
-
* @default discovers all targets using
|
|
18
|
+
* @default discovers all targets using stageType
|
|
19
19
|
*/
|
|
20
20
|
readonly awsDeploymentTargets?: Array<AwsDeploymentTarget>;
|
|
21
21
|
/**
|
|
@@ -38,7 +38,13 @@ export declare class AwsDeployWorkflow extends Component {
|
|
|
38
38
|
/**
|
|
39
39
|
* What type of deploy is this workflow for?
|
|
40
40
|
*/
|
|
41
|
-
|
|
41
|
+
awsStageType: AwsStageType;
|
|
42
|
+
/**
|
|
43
|
+
* AWS environment type, such as primary or secondary.
|
|
44
|
+
*
|
|
45
|
+
* @default 'primary' (this is the only type supported currently)
|
|
46
|
+
*/
|
|
47
|
+
awsEnvironmentType: AwsEnvironmentType;
|
|
42
48
|
/**
|
|
43
49
|
* The list of targets to deploy to.
|
|
44
50
|
*/
|
|
@@ -19,6 +19,12 @@ class AwsDeployWorkflow extends projen_1.Component {
|
|
|
19
19
|
constructor(project, options = {}) {
|
|
20
20
|
super(project);
|
|
21
21
|
this.project = project;
|
|
22
|
+
/**
|
|
23
|
+
* AWS environment type, such as primary or secondary.
|
|
24
|
+
*
|
|
25
|
+
* @default 'primary' (this is the only type supported currently)
|
|
26
|
+
*/
|
|
27
|
+
this.awsEnvironmentType = aws_deployment_target_1.AWS_ENVIRONMENT_TYPE.PRIMARY;
|
|
22
28
|
this.setupNode = () => {
|
|
23
29
|
return [
|
|
24
30
|
{
|
|
@@ -44,7 +50,7 @@ class AwsDeployWorkflow extends projen_1.Component {
|
|
|
44
50
|
];
|
|
45
51
|
};
|
|
46
52
|
this.deploySteps = (target) => {
|
|
47
|
-
const {
|
|
53
|
+
const { awsStageType, awsEnvironmentType, account, region, ciDeploymentConfig, awsDeploymentConfig, } = target;
|
|
48
54
|
const { roleArn, stackPattern } = ciDeploymentConfig ?? {};
|
|
49
55
|
const { rootCdkOut } = awsDeploymentConfig;
|
|
50
56
|
return [
|
|
@@ -61,7 +67,7 @@ class AwsDeployWorkflow extends projen_1.Component {
|
|
|
61
67
|
* Configure AWS creds.
|
|
62
68
|
*/
|
|
63
69
|
{
|
|
64
|
-
name: `AWS Creds ${
|
|
70
|
+
name: `AWS Creds ${awsStageType}/${awsEnvironmentType}/${account}/${region}`,
|
|
65
71
|
uses: "aws-actions/configure-aws-credentials@v4",
|
|
66
72
|
with: {
|
|
67
73
|
"role-to-assume": roleArn,
|
|
@@ -73,7 +79,7 @@ class AwsDeployWorkflow extends projen_1.Component {
|
|
|
73
79
|
* Run CDK Deploy
|
|
74
80
|
*/
|
|
75
81
|
{
|
|
76
|
-
name: `Deploy ${
|
|
82
|
+
name: `Deploy ${awsStageType}/${awsEnvironmentType}/${account}/${region}`,
|
|
77
83
|
run: `pnpm dlx aws-cdk deploy --no-rollback --require-approval=never --app=${rootCdkOut} "${stackPattern}"`,
|
|
78
84
|
},
|
|
79
85
|
];
|
|
@@ -120,7 +126,7 @@ class AwsDeployWorkflow extends projen_1.Component {
|
|
|
120
126
|
* be safe.
|
|
121
127
|
*
|
|
122
128
|
**************************************************************************/
|
|
123
|
-
this.
|
|
129
|
+
this.awsStageType = options.awsStageType ?? aws_deployment_target_1.AWS_STAGE_TYPE.DEV;
|
|
124
130
|
/***************************************************************************
|
|
125
131
|
*
|
|
126
132
|
* Workflow Deploy Targets
|
|
@@ -131,8 +137,7 @@ class AwsDeployWorkflow extends projen_1.Component {
|
|
|
131
137
|
**************************************************************************/
|
|
132
138
|
this.awsDeploymentTargets =
|
|
133
139
|
options.awsDeploymentTargets ??
|
|
134
|
-
aws_1.AwsDeploymentConfig.of(project)?.awsDeploymentTargets.filter((target) => target.
|
|
135
|
-
target.ciDeployment) ??
|
|
140
|
+
aws_1.AwsDeploymentConfig.of(project)?.awsDeploymentTargets.filter((target) => target.awsStageType === this.awsStageType && target.ciDeployment) ??
|
|
136
141
|
[];
|
|
137
142
|
/***************************************************************************
|
|
138
143
|
*
|
|
@@ -158,7 +163,12 @@ class AwsDeployWorkflow extends projen_1.Component {
|
|
|
158
163
|
/**
|
|
159
164
|
* Name based on project and environment.
|
|
160
165
|
*/
|
|
161
|
-
name: [
|
|
166
|
+
name: [
|
|
167
|
+
"deploy",
|
|
168
|
+
project.name,
|
|
169
|
+
this.awsStageType,
|
|
170
|
+
this.awsEnvironmentType,
|
|
171
|
+
].join("-"),
|
|
162
172
|
/**
|
|
163
173
|
* Use the root projects build task.
|
|
164
174
|
*/
|
|
@@ -211,9 +221,16 @@ class AwsDeployWorkflow extends projen_1.Component {
|
|
|
211
221
|
*
|
|
212
222
|
**************************************************************************/
|
|
213
223
|
this.awsDeploymentTargets.forEach((target) => {
|
|
214
|
-
const deployJobName =
|
|
224
|
+
const deployJobName = [
|
|
225
|
+
target.awsStageType,
|
|
226
|
+
target.awsEnvironmentType,
|
|
227
|
+
"deploy",
|
|
228
|
+
this.project.name,
|
|
229
|
+
target.account,
|
|
230
|
+
target.region,
|
|
231
|
+
].join("-");
|
|
215
232
|
this.buildWorkflow.addPostBuildJob(deployJobName, {
|
|
216
|
-
name: `Deploy ${target.
|
|
233
|
+
name: `Deploy ${target.awsStageType}/${target.awsEnvironmentType}/${target.account}/${target.region}`,
|
|
217
234
|
runsOn: ["ubuntu-latest"],
|
|
218
235
|
permissions: {
|
|
219
236
|
contents: workflows_model_1.JobPermission.READ,
|
|
@@ -238,4 +255,4 @@ class AwsDeployWorkflow extends projen_1.Component {
|
|
|
238
255
|
}
|
|
239
256
|
}
|
|
240
257
|
exports.AwsDeployWorkflow = AwsDeployWorkflow;
|
|
241
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-deploy-workflow.js","sourceRoot":"","sources":["../../src/workflows/aws-deploy-workflow.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component } from \"projen\";\nimport { AwsCdkTypeScriptApp } from \"projen/lib/awscdk\";\nimport { BuildWorkflow, BuildWorkflowOptions } from \"projen/lib/build\";\nimport { GitHub } from \"projen/lib/github\";\nimport { JobPermission, JobStep } from \"projen/lib/github/workflows-model\";\nimport { ValueOf } from \"type-fest\";\nimport { AwsDeploymentConfig } from \"../aws\";\nimport {\n  AWS_DEPLOY_TYPE,\n  AwsDeploymentTarget,\n} from \"../aws/aws-deployment-target\";\nimport { MonorepoProject } from \"../projects\";\nimport { ROOT_CI_TASK_NAME, TurboRepo } from \"../turbo\";\nimport { VERSION } from \"../versions\";\n\nexport const PROD_DEPLOY_NAME = \"prod-deploy\";\n\nexport interface DeployWorkflowOptions {\n  /**\n   * What type of deploy is this workflow for?\n   *\n   * @default AWS_DEPLOY_TYPE.DEV\n   */\n  readonly awsDeployType?: ValueOf<typeof AWS_DEPLOY_TYPE>;\n\n  /**\n   * Optionally feed a list of targets to deploy to.\n   *\n   * @default discovers all targets using deployType\n   */\n  readonly awsDeploymentTargets?: Array<AwsDeploymentTarget>;\n\n  /**\n   * Existing workflow, useful if we're tacking deployments onto an existing\n   * build workflow\n   */\n  readonly buildWorkflow?: BuildWorkflow;\n\n  /**\n   * Options for the build workflow, if no build workflow is provided.\n   */\n  readonly buildWorkflowOptions?: Partial<BuildWorkflowOptions>;\n}\n\nexport class AwsDeployWorkflow extends Component {\n  public static of(\n    project: AwsCdkTypeScriptApp,\n    buildWorkflow: BuildWorkflow,\n  ): AwsDeployWorkflow | undefined {\n    const isDefined = (c: Component): c is AwsDeployWorkflow =>\n      c instanceof AwsDeployWorkflow && c.buildWorkflow === buildWorkflow;\n    return project.components.find(isDefined);\n  }\n\n  /**\n   * The root project for this deploy workflow. Must be a monorepo project.\n   */\n  private rootProject: MonorepoProject;\n\n  /**\n   * What type of deploy is this workflow for?\n   */\n  public awsDeployType: ValueOf<typeof AWS_DEPLOY_TYPE>;\n\n  /**\n   * The list of targets to deploy to.\n   */\n  readonly awsDeploymentTargets: Array<AwsDeploymentTarget>;\n\n  /**\n   * Hold the deploy workflow so we can add to it in preSynth\n   */\n  public buildWorkflow: BuildWorkflow;\n\n  /**\n   * Was this workflow created externally?\n   */\n  public externalWorkflow: boolean;\n\n  constructor(\n    public project: AwsCdkTypeScriptApp,\n    options: DeployWorkflowOptions = {},\n  ) {\n    super(project);\n\n    /***************************************************************************\n     *\n     * Root project check\n     *\n     * Detect the root project and ensure it's of type MonorepoProject.\n     *\n     **************************************************************************/\n\n    if (!(project.root instanceof MonorepoProject)) {\n      throw new Error(\n        \"AwsDeployWorkflow requires the root project to be a MonorepoProject\",\n      );\n    }\n\n    this.rootProject = project.root;\n\n    /***************************************************************************\n     *\n     * GitHub Check\n     *\n     * Make sure github config is active in the project. This is to ensure all\n     * workflows will be output properly during synth.\n     *\n     **************************************************************************/\n\n    const github = GitHub.of(this.rootProject);\n\n    if (!github) {\n      throw new Error(\n        \"AwsDeployWorkflow requires a GitHub component in the root project\",\n      );\n    }\n\n    /***************************************************************************\n     *\n     * TurboRepo Check\n     *\n     * If turbo is enabled, we may need the options later in this file.\n     *\n     **************************************************************************/\n\n    const turbo = TurboRepo.of(this.rootProject);\n    const buildWorkflowOptions: Partial<BuildWorkflowOptions> =\n      turbo?.remoteCacheOptions\n        ? TurboRepo.buildWorkflowOptions(turbo.remoteCacheOptions)\n        : {};\n\n    /***************************************************************************\n     *\n     * Workflow Deploy Type\n     *\n     * What type of environments are we deploying into? We'll default to dev to\n     * be safe.\n     *\n     **************************************************************************/\n\n    this.awsDeployType = options.awsDeployType ?? AWS_DEPLOY_TYPE.DEV;\n\n    /***************************************************************************\n     *\n     * Workflow Deploy Targets\n     *\n     * Use provided targets or discover them based on the deploy type. Only\n     * include targets that are marked for CI/CD.\n     *\n     **************************************************************************/\n\n    this.awsDeploymentTargets =\n      options.awsDeploymentTargets ??\n      AwsDeploymentConfig.of(project)?.awsDeploymentTargets.filter(\n        (target) =>\n          target.awsDeploymentType === this.awsDeployType &&\n          target.ciDeployment,\n      ) ??\n      [];\n\n    /***************************************************************************\n     *\n     * Build Workflow Options\n     *\n     * Can't use the options if an existing workflow was passed in.\n     *\n     **************************************************************************/\n\n    if (options.buildWorkflow && options.buildWorkflowOptions) {\n      throw new Error(\n        \"Cannot provide both buildWorkflow and buildWorkflowOptions\",\n      );\n    }\n\n    this.externalWorkflow = !!options.buildWorkflow;\n\n    /***************************************************************************\n     *\n     * Build Workflow\n     *\n     * Create a workflow either based on input or from scratch.\n     *\n     **************************************************************************/\n\n    this.buildWorkflow =\n      options.buildWorkflow ??\n      new BuildWorkflow(this.rootProject, {\n        /**\n         * Name based on project and environment.\n         */\n        name: [\"deploy\", project.name, this.awsDeployType].join(\"-\"),\n\n        /**\n         * Use the root projects build task.\n         */\n        buildTask: this.rootProject.buildTask,\n\n        /**\n         * Use push triggers based n the branch config for each environment.\n         */\n        workflowTriggers: {\n          push: {\n            branches: [\n              ...this.awsDeploymentTargets.flatMap((t) =>\n                t.branches.map((b) => b.branch),\n              ),\n            ],\n          },\n          workflowDispatch: {},\n          ...options.buildWorkflowOptions?.workflowTriggers,\n        },\n\n        /**\n         * Never allow mutations for deploys. This should have been handled\n         * during build.\n         */\n        mutableBuild: false,\n\n        /**\n         * Do this pre-merge of permissions and build steps\n         */\n        ...options.buildWorkflowOptions,\n\n        /**\n         * Some additional permissions may be required when turbo's involved.\n         */\n        permissions: {\n          ...options.buildWorkflowOptions?.permissions,\n          ...buildWorkflowOptions?.permissions,\n        },\n\n        /**\n         * Assemble all pre-build steps\n         */\n        preBuildSteps: [\n          ...this.setupPnpm(),\n          ...this.setupNode(),\n          {\n            name: \"Install dependencies\",\n            run: \"pnpm i --no-frozen-lockfile\",\n          },\n          ...(options.buildWorkflowOptions?.preBuildSteps ?? []),\n          ...(buildWorkflowOptions?.preBuildSteps ?? []),\n        ],\n      });\n\n    /***************************************************************************\n     *\n     * Add Deployments to workflow\n     *\n     **************************************************************************/\n\n    this.awsDeploymentTargets.forEach((target) => {\n      const deployJobName = `${target.awsDeploymentType}-deploy-${this.project.name}-${target.account}-${target.region}`;\n\n      this.buildWorkflow.addPostBuildJob(deployJobName, {\n        name: `Deploy ${target.awsDeploymentType}/${target.account}/${target.region}`,\n        runsOn: [\"ubuntu-latest\"],\n        permissions: {\n          contents: JobPermission.READ,\n          idToken: JobPermission.WRITE,\n        },\n        concurrency: deployJobName,\n        steps: [...this.deploySteps(target)],\n      });\n    });\n  }\n\n  public setupNode = (): Array<JobStep> => {\n    return [\n      {\n        name: \"Setup Node\",\n        uses: \"actions/setup-node@v4\",\n        with: {\n          [\"node-version\"]: VERSION.NODE_WORKFLOWS,\n        },\n        // occasionally this step fails due to internal issues at github\n        timeoutMinutes: 1,\n      },\n    ];\n  };\n\n  public setupPnpm = (): Array<JobStep> => {\n    return [\n      {\n        name: \"Setup PNPM\",\n        uses: \"pnpm/action-setup@v3\",\n        with: {\n          version: VERSION.PNPM_VERSION,\n        },\n      },\n    ];\n  };\n\n  private deploySteps = (target: AwsDeploymentTarget): Array<JobStep> => {\n    const {\n      awsDeploymentType,\n      account,\n      region,\n      ciDeploymentConfig,\n      awsDeploymentConfig,\n    } = target;\n    const { roleArn, stackPattern } = ciDeploymentConfig ?? {};\n    const { rootCdkOut } = awsDeploymentConfig;\n\n    return [\n      ...this.setupPnpm(),\n      ...this.setupNode(),\n\n      /**\n       * Install CDK\n       */\n      {\n        name: \"Install CDK\",\n        run: \"pnpm add aws-cdk\",\n      },\n\n      /**\n       * Configure AWS creds.\n       */\n      {\n        name: `AWS Creds ${awsDeploymentType}/${account}/${region}`,\n        uses: \"aws-actions/configure-aws-credentials@v4\",\n        with: {\n          \"role-to-assume\": roleArn,\n          \"aws-region\": region,\n          \"role-duration-seconds\": 900, // 15 minutes\n        },\n      },\n\n      /**\n       * Run CDK Deploy\n       */\n      {\n        name: `Deploy ${target.awsDeploymentType}/${target.account}/${target.region}`,\n        run: `pnpm dlx aws-cdk deploy --no-rollback --require-approval=never --app=${rootCdkOut} \"${stackPattern}\"`,\n      },\n    ];\n  };\n\n  preSynthesize(): void {\n    /**\n     * Ensure turbo is active when needed.\n     */\n    if (!this.externalWorkflow && TurboRepo.of(this.rootProject)) {\n      this.buildWorkflow.addPostBuildSteps({\n        name: \"Build Sub Projects\",\n        run: `npx projen ${ROOT_CI_TASK_NAME}`,\n      });\n    }\n\n    super.preSynthesize();\n  }\n}\n"]}
|
|
258
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-deploy-workflow.js","sourceRoot":"","sources":["../../src/workflows/aws-deploy-workflow.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component } from \"projen\";\nimport { AwsCdkTypeScriptApp } from \"projen/lib/awscdk\";\nimport { BuildWorkflow, BuildWorkflowOptions } from \"projen/lib/build\";\nimport { GitHub } from \"projen/lib/github\";\nimport { JobPermission, JobStep } from \"projen/lib/github/workflows-model\";\nimport { ValueOf } from \"type-fest\";\nimport { AwsDeploymentConfig } from \"../aws\";\nimport {\n  AWS_ENVIRONMENT_TYPE,\n  AWS_STAGE_TYPE,\n  AwsDeploymentTarget,\n  AwsEnvironmentType,\n  AwsStageType,\n} from \"../aws/aws-deployment-target\";\nimport { MonorepoProject } from \"../projects\";\nimport { ROOT_CI_TASK_NAME, TurboRepo } from \"../turbo\";\nimport { VERSION } from \"../versions\";\n\nexport const PROD_DEPLOY_NAME = \"prod-deploy\";\n\nexport interface DeployWorkflowOptions {\n  /**\n   * What type of deploy is this workflow for?\n   *\n   * @default AWS_STAGE_TYPE.DEV\n   */\n  readonly awsStageType?: ValueOf<typeof AWS_STAGE_TYPE>;\n\n  /**\n   * Optionally feed a list of targets to deploy to.\n   *\n   * @default discovers all targets using stageType\n   */\n  readonly awsDeploymentTargets?: Array<AwsDeploymentTarget>;\n\n  /**\n   * Existing workflow, useful if we're tacking deployments onto an existing\n   * build workflow\n   */\n  readonly buildWorkflow?: BuildWorkflow;\n\n  /**\n   * Options for the build workflow, if no build workflow is provided.\n   */\n  readonly buildWorkflowOptions?: Partial<BuildWorkflowOptions>;\n}\n\nexport class AwsDeployWorkflow extends Component {\n  public static of(\n    project: AwsCdkTypeScriptApp,\n    buildWorkflow: BuildWorkflow,\n  ): AwsDeployWorkflow | undefined {\n    const isDefined = (c: Component): c is AwsDeployWorkflow =>\n      c instanceof AwsDeployWorkflow && c.buildWorkflow === buildWorkflow;\n    return project.components.find(isDefined);\n  }\n\n  /**\n   * The root project for this deploy workflow. Must be a monorepo project.\n   */\n  private rootProject: MonorepoProject;\n\n  /**\n   * What type of deploy is this workflow for?\n   */\n  public awsStageType: AwsStageType;\n\n  /**\n   * AWS environment type, such as primary or secondary.\n   *\n   * @default 'primary' (this is the only type supported currently)\n   */\n  public awsEnvironmentType: AwsEnvironmentType = AWS_ENVIRONMENT_TYPE.PRIMARY;\n\n  /**\n   * The list of targets to deploy to.\n   */\n  readonly awsDeploymentTargets: Array<AwsDeploymentTarget>;\n\n  /**\n   * Hold the deploy workflow so we can add to it in preSynth\n   */\n  public buildWorkflow: BuildWorkflow;\n\n  /**\n   * Was this workflow created externally?\n   */\n  public externalWorkflow: boolean;\n\n  constructor(\n    public project: AwsCdkTypeScriptApp,\n    options: DeployWorkflowOptions = {},\n  ) {\n    super(project);\n\n    /***************************************************************************\n     *\n     * Root project check\n     *\n     * Detect the root project and ensure it's of type MonorepoProject.\n     *\n     **************************************************************************/\n\n    if (!(project.root instanceof MonorepoProject)) {\n      throw new Error(\n        \"AwsDeployWorkflow requires the root project to be a MonorepoProject\",\n      );\n    }\n\n    this.rootProject = project.root;\n\n    /***************************************************************************\n     *\n     * GitHub Check\n     *\n     * Make sure github config is active in the project. This is to ensure all\n     * workflows will be output properly during synth.\n     *\n     **************************************************************************/\n\n    const github = GitHub.of(this.rootProject);\n\n    if (!github) {\n      throw new Error(\n        \"AwsDeployWorkflow requires a GitHub component in the root project\",\n      );\n    }\n\n    /***************************************************************************\n     *\n     * TurboRepo Check\n     *\n     * If turbo is enabled, we may need the options later in this file.\n     *\n     **************************************************************************/\n\n    const turbo = TurboRepo.of(this.rootProject);\n    const buildWorkflowOptions: Partial<BuildWorkflowOptions> =\n      turbo?.remoteCacheOptions\n        ? TurboRepo.buildWorkflowOptions(turbo.remoteCacheOptions)\n        : {};\n\n    /***************************************************************************\n     *\n     * Workflow Deploy Type\n     *\n     * What type of environments are we deploying into? We'll default to dev to\n     * be safe.\n     *\n     **************************************************************************/\n\n    this.awsStageType = options.awsStageType ?? AWS_STAGE_TYPE.DEV;\n\n    /***************************************************************************\n     *\n     * Workflow Deploy Targets\n     *\n     * Use provided targets or discover them based on the deploy type. Only\n     * include targets that are marked for CI/CD.\n     *\n     **************************************************************************/\n\n    this.awsDeploymentTargets =\n      options.awsDeploymentTargets ??\n      AwsDeploymentConfig.of(project)?.awsDeploymentTargets.filter(\n        (target) =>\n          target.awsStageType === this.awsStageType && target.ciDeployment,\n      ) ??\n      [];\n\n    /***************************************************************************\n     *\n     * Build Workflow Options\n     *\n     * Can't use the options if an existing workflow was passed in.\n     *\n     **************************************************************************/\n\n    if (options.buildWorkflow && options.buildWorkflowOptions) {\n      throw new Error(\n        \"Cannot provide both buildWorkflow and buildWorkflowOptions\",\n      );\n    }\n\n    this.externalWorkflow = !!options.buildWorkflow;\n\n    /***************************************************************************\n     *\n     * Build Workflow\n     *\n     * Create a workflow either based on input or from scratch.\n     *\n     **************************************************************************/\n\n    this.buildWorkflow =\n      options.buildWorkflow ??\n      new BuildWorkflow(this.rootProject, {\n        /**\n         * Name based on project and environment.\n         */\n        name: [\n          \"deploy\",\n          project.name,\n          this.awsStageType,\n          this.awsEnvironmentType,\n        ].join(\"-\"),\n\n        /**\n         * Use the root projects build task.\n         */\n        buildTask: this.rootProject.buildTask,\n\n        /**\n         * Use push triggers based n the branch config for each environment.\n         */\n        workflowTriggers: {\n          push: {\n            branches: [\n              ...this.awsDeploymentTargets.flatMap((t) =>\n                t.branches.map((b) => b.branch),\n              ),\n            ],\n          },\n          workflowDispatch: {},\n          ...options.buildWorkflowOptions?.workflowTriggers,\n        },\n\n        /**\n         * Never allow mutations for deploys. This should have been handled\n         * during build.\n         */\n        mutableBuild: false,\n\n        /**\n         * Do this pre-merge of permissions and build steps\n         */\n        ...options.buildWorkflowOptions,\n\n        /**\n         * Some additional permissions may be required when turbo's involved.\n         */\n        permissions: {\n          ...options.buildWorkflowOptions?.permissions,\n          ...buildWorkflowOptions?.permissions,\n        },\n\n        /**\n         * Assemble all pre-build steps\n         */\n        preBuildSteps: [\n          ...this.setupPnpm(),\n          ...this.setupNode(),\n          {\n            name: \"Install dependencies\",\n            run: \"pnpm i --no-frozen-lockfile\",\n          },\n          ...(options.buildWorkflowOptions?.preBuildSteps ?? []),\n          ...(buildWorkflowOptions?.preBuildSteps ?? []),\n        ],\n      });\n\n    /***************************************************************************\n     *\n     * Add Deployments to workflow\n     *\n     **************************************************************************/\n\n    this.awsDeploymentTargets.forEach((target) => {\n      const deployJobName = [\n        target.awsStageType,\n        target.awsEnvironmentType,\n        \"deploy\",\n        this.project.name,\n        target.account,\n        target.region,\n      ].join(\"-\");\n\n      this.buildWorkflow.addPostBuildJob(deployJobName, {\n        name: `Deploy ${target.awsStageType}/${target.awsEnvironmentType}/${target.account}/${target.region}`,\n        runsOn: [\"ubuntu-latest\"],\n        permissions: {\n          contents: JobPermission.READ,\n          idToken: JobPermission.WRITE,\n        },\n        concurrency: deployJobName,\n        steps: [...this.deploySteps(target)],\n      });\n    });\n  }\n\n  public setupNode = (): Array<JobStep> => {\n    return [\n      {\n        name: \"Setup Node\",\n        uses: \"actions/setup-node@v4\",\n        with: {\n          [\"node-version\"]: VERSION.NODE_WORKFLOWS,\n        },\n        // occasionally this step fails due to internal issues at github\n        timeoutMinutes: 1,\n      },\n    ];\n  };\n\n  public setupPnpm = (): Array<JobStep> => {\n    return [\n      {\n        name: \"Setup PNPM\",\n        uses: \"pnpm/action-setup@v3\",\n        with: {\n          version: VERSION.PNPM_VERSION,\n        },\n      },\n    ];\n  };\n\n  private deploySteps = (target: AwsDeploymentTarget): Array<JobStep> => {\n    const {\n      awsStageType,\n      awsEnvironmentType,\n      account,\n      region,\n      ciDeploymentConfig,\n      awsDeploymentConfig,\n    } = target;\n    const { roleArn, stackPattern } = ciDeploymentConfig ?? {};\n    const { rootCdkOut } = awsDeploymentConfig;\n\n    return [\n      ...this.setupPnpm(),\n      ...this.setupNode(),\n\n      /**\n       * Install CDK\n       */\n      {\n        name: \"Install CDK\",\n        run: \"pnpm add aws-cdk\",\n      },\n\n      /**\n       * Configure AWS creds.\n       */\n      {\n        name: `AWS Creds ${awsStageType}/${awsEnvironmentType}/${account}/${region}`,\n        uses: \"aws-actions/configure-aws-credentials@v4\",\n        with: {\n          \"role-to-assume\": roleArn,\n          \"aws-region\": region,\n          \"role-duration-seconds\": 900, // 15 minutes\n        },\n      },\n\n      /**\n       * Run CDK Deploy\n       */\n      {\n        name: `Deploy ${awsStageType}/${awsEnvironmentType}/${account}/${region}`,\n        run: `pnpm dlx aws-cdk deploy --no-rollback --require-approval=never --app=${rootCdkOut} \"${stackPattern}\"`,\n      },\n    ];\n  };\n\n  preSynthesize(): void {\n    /**\n     * Ensure turbo is active when needed.\n     */\n    if (!this.externalWorkflow && TurboRepo.of(this.rootProject)) {\n      this.buildWorkflow.addPostBuildSteps({\n        name: \"Build Sub Projects\",\n        run: `npx projen ${ROOT_CI_TASK_NAME}`,\n      });\n    }\n\n    super.preSynthesize();\n  }\n}\n"]}
|
package/package.json
CHANGED