@codedrifters/configulator 0.0.21 → 0.0.22
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/aws/aws-deployment-config.d.ts +40 -108
- package/lib/aws/aws-deployment-config.js +64 -103
- package/lib/aws/aws-deployment-target.d.ts +160 -0
- package/lib/aws/aws-deployment-target.js +158 -0
- package/lib/turbo/turbo-repo.d.ts +5 -1
- package/lib/turbo/turbo-repo.js +8 -8
- package/lib/versions.d.ts +7 -3
- package/lib/versions.js +8 -4
- package/lib/workflows/aws-deploy-workflow.d.ts +54 -0
- package/lib/workflows/aws-deploy-workflow.js +218 -0
- package/lib/workflows/index.d.ts +1 -2
- package/lib/workflows/index.js +2 -3
- package/package.json +1 -1
- package/lib/workflows/build-workflow.d.ts +0 -13
- package/lib/workflows/build-workflow.js +0 -64
- package/lib/workflows/deploy-workflow.d.ts +0 -17
- package/lib/workflows/deploy-workflow.js +0 -113
- package/lib/workflows/steps/deploy.d.ts +0 -4
- package/lib/workflows/steps/deploy.js +0 -62
|
@@ -1,141 +1,73 @@
|
|
|
1
|
-
import { Component
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
1
|
+
import { Component } from "projen";
|
|
2
|
+
import { AwsCdkTypeScriptApp } from "projen/lib/awscdk";
|
|
3
|
+
import { AwsDeploymentTarget } from "./aws-deployment-target";
|
|
4
4
|
/*******************************************************************************
|
|
5
5
|
*
|
|
6
|
+
* AWS Deployment Configuration
|
|
7
|
+
*
|
|
8
|
+
* This component allows configuration of multiple AWS deployment
|
|
9
|
+
* targets, each with its own account, region, and deployment type
|
|
10
|
+
* (dev, stage, prod). It supports both local and CI deployments,
|
|
11
|
+
* with customizable settings for each target.
|
|
6
12
|
*
|
|
7
13
|
******************************************************************************/
|
|
8
|
-
export interface AwsDeploymentConfigOptions {
|
|
9
|
-
}
|
|
10
|
-
export declare const AWS_DEPLOY_TYPE: {
|
|
11
|
-
/**
|
|
12
|
-
* Development environment, typically used for testing and development.
|
|
13
|
-
*/
|
|
14
|
-
readonly DEV: "dev";
|
|
15
|
-
/**
|
|
16
|
-
* Staging environment, used for pre-production testing.
|
|
17
|
-
*/
|
|
18
|
-
readonly STAGE: "stage";
|
|
19
|
-
/**
|
|
20
|
-
* Production environment, used for live deployments.
|
|
21
|
-
*/
|
|
22
|
-
readonly PROD: "prod";
|
|
23
|
-
};
|
|
24
|
-
/**
|
|
25
|
-
* Above const as a type.
|
|
26
|
-
*/
|
|
27
|
-
export type AwsDeploymentType = (typeof AWS_DEPLOY_TYPE)[keyof typeof AWS_DEPLOY_TYPE];
|
|
28
|
-
/**
|
|
29
|
-
* Represents the configuration for local deployment in AWS.
|
|
30
|
-
*/
|
|
31
|
-
export interface AwsLocalDeploymentConfig {
|
|
32
|
-
/**
|
|
33
|
-
* The AWS profile (in ~/.aws/config) to use for local deployment.
|
|
34
|
-
*
|
|
35
|
-
* @default generated dynamically based role name, account and region
|
|
36
|
-
*/
|
|
37
|
-
profile?: string;
|
|
38
|
-
/**
|
|
39
|
-
* Named Role used to conduct local deployments.
|
|
40
|
-
*
|
|
41
|
-
* @default "administratoraccess"
|
|
42
|
-
*/
|
|
43
|
-
roleName?: string;
|
|
44
|
-
}
|
|
45
|
-
export interface CiDeploymentConfig {
|
|
46
|
-
/**
|
|
47
|
-
* The OIDC IAM Role to assume for CI deployments.
|
|
48
|
-
*/
|
|
49
|
-
roleArn: string;
|
|
50
|
-
}
|
|
51
|
-
/**
|
|
52
|
-
* Represents a deployment target in AWS, including account and region, and
|
|
53
|
-
* branches allowed to deploy to this target.
|
|
54
|
-
*/
|
|
55
|
-
export interface AwsDeploymentTarget {
|
|
56
|
-
/**
|
|
57
|
-
* The account name for the deployment target.
|
|
58
|
-
*/
|
|
59
|
-
account: string;
|
|
60
|
-
/**
|
|
61
|
-
* The AWS region for the deployment target.
|
|
62
|
-
*/
|
|
63
|
-
region: string;
|
|
64
|
-
/**'
|
|
65
|
-
* AWS deployment type, such as dev, stage, or prod.
|
|
66
|
-
*/
|
|
67
|
-
awsDeploymentType: AwsDeploymentType;
|
|
68
|
-
/**
|
|
69
|
-
* The AWS profile to use for this deployment target.
|
|
70
|
-
*/
|
|
71
|
-
branches: Array<GitBranch>;
|
|
72
|
-
/**
|
|
73
|
-
* Can this deployment target be used for local development?
|
|
74
|
-
*/
|
|
75
|
-
localDeployment: boolean;
|
|
76
|
-
/**
|
|
77
|
-
* Configuration when deploying to this target locally.
|
|
78
|
-
*/
|
|
79
|
-
localDeploymentConfig?: AwsLocalDeploymentConfig;
|
|
80
|
-
/**
|
|
81
|
-
* Can this deployment target be used in CI deployments?
|
|
82
|
-
*/
|
|
83
|
-
ciDeployment: boolean;
|
|
84
|
-
ciDeploymentConfig?: CiDeploymentConfig;
|
|
85
|
-
}
|
|
86
14
|
export declare class AwsDeploymentConfig extends Component {
|
|
87
|
-
static of(project:
|
|
15
|
+
static of(project: AwsCdkTypeScriptApp): AwsDeploymentConfig | undefined;
|
|
88
16
|
/**
|
|
89
17
|
* Environment variables to be injected into all tasks.
|
|
90
18
|
*/
|
|
91
|
-
|
|
19
|
+
readonly env: Record<string, string>;
|
|
92
20
|
/**
|
|
93
21
|
* The relative path to the project directory from the root of the project.
|
|
94
22
|
*/
|
|
95
|
-
|
|
23
|
+
readonly projectPath: string;
|
|
96
24
|
/**
|
|
97
25
|
* The relative path to the root of the project from the output directory.
|
|
98
26
|
*/
|
|
99
|
-
|
|
27
|
+
readonly rootPath: string;
|
|
100
28
|
/**
|
|
101
29
|
* The output directory for the CDK synthesis.
|
|
102
30
|
*/
|
|
103
|
-
|
|
31
|
+
readonly cdkOut: string;
|
|
104
32
|
/**
|
|
105
33
|
* Array of targets for deployment.
|
|
106
34
|
*/
|
|
107
|
-
readonly
|
|
108
|
-
constructor(project:
|
|
109
|
-
/**
|
|
110
|
-
* Adds a deployment target to the configuration.
|
|
111
|
-
*
|
|
112
|
-
* @param target The deployment target to add.
|
|
113
|
-
*/
|
|
114
|
-
addDeploymentTarget(target: AwsDeploymentTarget): void;
|
|
35
|
+
readonly awsDeploymentTargets: Array<AwsDeploymentTarget>;
|
|
36
|
+
constructor(project: AwsCdkTypeScriptApp);
|
|
115
37
|
/*****************************************************************************
|
|
116
38
|
*
|
|
117
|
-
*
|
|
39
|
+
* Target filter helpers
|
|
118
40
|
*
|
|
119
|
-
*
|
|
120
|
-
* - Change the output location for easier workflows.
|
|
41
|
+
* Return various targets for deployment scripts to use.
|
|
121
42
|
*
|
|
122
43
|
****************************************************************************/
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
44
|
+
/**
|
|
45
|
+
* @returns All production deployment targets.
|
|
46
|
+
*/
|
|
47
|
+
get prodTargets(): Array<AwsDeploymentTarget>;
|
|
48
|
+
get prodTargetsForCI(): Array<AwsDeploymentTarget>;
|
|
49
|
+
get prodTargetsForLocal(): Array<AwsDeploymentTarget>;
|
|
50
|
+
/**
|
|
127
51
|
*
|
|
128
|
-
*
|
|
52
|
+
* @returns All stage deployment targets.
|
|
53
|
+
*/
|
|
54
|
+
get stageTargets(): Array<AwsDeploymentTarget>;
|
|
55
|
+
get stageTargetsForCI(): Array<AwsDeploymentTarget>;
|
|
56
|
+
get stageTargetsForLocal(): Array<AwsDeploymentTarget>;
|
|
57
|
+
/**
|
|
129
58
|
*
|
|
130
|
-
|
|
131
|
-
|
|
59
|
+
* @returns All dev deployment targets.
|
|
60
|
+
*/
|
|
61
|
+
get devTargets(): Array<AwsDeploymentTarget>;
|
|
62
|
+
get devTargetsForCI(): Array<AwsDeploymentTarget>;
|
|
63
|
+
get devTargetsForLocal(): Array<AwsDeploymentTarget>;
|
|
132
64
|
/*****************************************************************************
|
|
133
65
|
*
|
|
134
|
-
*
|
|
66
|
+
* Synth Tasks
|
|
135
67
|
*
|
|
136
|
-
* - Configure
|
|
137
|
-
* -
|
|
68
|
+
* - Configure synth task to use the branch name
|
|
69
|
+
* - Change the output location for easier workflows.
|
|
138
70
|
*
|
|
139
71
|
****************************************************************************/
|
|
140
|
-
private
|
|
72
|
+
private configureSynthTask;
|
|
141
73
|
}
|
|
@@ -1,33 +1,33 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AwsDeploymentConfig =
|
|
3
|
+
exports.AwsDeploymentConfig = void 0;
|
|
4
4
|
const node_path_1 = require("node:path");
|
|
5
5
|
const projen_1 = require("projen");
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
6
|
+
const aws_deployment_target_1 = require("./aws-deployment-target");
|
|
7
|
+
/*******************************************************************************
|
|
8
|
+
*
|
|
9
|
+
* AWS Deployment Configuration
|
|
10
|
+
*
|
|
11
|
+
* This component allows configuration of multiple AWS deployment
|
|
12
|
+
* targets, each with its own account, region, and deployment type
|
|
13
|
+
* (dev, stage, prod). It supports both local and CI deployments,
|
|
14
|
+
* with customizable settings for each target.
|
|
15
|
+
*
|
|
16
|
+
******************************************************************************/
|
|
17
|
+
/*
|
|
18
|
+
export interface AwsDeploymentConfigOptions {}
|
|
19
|
+
*/
|
|
20
20
|
class AwsDeploymentConfig extends projen_1.Component {
|
|
21
21
|
static of(project) {
|
|
22
22
|
const isDefined = (c) => c instanceof AwsDeploymentConfig;
|
|
23
|
-
return project.components.
|
|
23
|
+
return project.components.find(isDefined);
|
|
24
24
|
}
|
|
25
25
|
constructor(project) {
|
|
26
26
|
super(project);
|
|
27
27
|
/**
|
|
28
28
|
* Array of targets for deployment.
|
|
29
29
|
*/
|
|
30
|
-
this.
|
|
30
|
+
this.awsDeploymentTargets = [];
|
|
31
31
|
/*****************************************************************************
|
|
32
32
|
*
|
|
33
33
|
* Synth Tasks
|
|
@@ -46,45 +46,6 @@ class AwsDeploymentConfig extends projen_1.Component {
|
|
|
46
46
|
.tryFind("synth:silent")
|
|
47
47
|
?.exec(`cdk synth -q --output ${this.cdkOut}`, { env: this.env });
|
|
48
48
|
};
|
|
49
|
-
/*****************************************************************************
|
|
50
|
-
*
|
|
51
|
-
* Deploy Tasks
|
|
52
|
-
*
|
|
53
|
-
* - If local deploy, add a deploy task.
|
|
54
|
-
*
|
|
55
|
-
****************************************************************************/
|
|
56
|
-
this.configureDeployTask = (target) => {
|
|
57
|
-
if (target.localDeployment) {
|
|
58
|
-
const taskName = ["deploy", target.account, target.region].join(":");
|
|
59
|
-
const deployTask = this.project.tasks.addTask(taskName, {
|
|
60
|
-
env: this.env,
|
|
61
|
-
});
|
|
62
|
-
deployTask.exec(`cdk deploy --lookups=false --require-approval=never --profile=${target.localDeploymentConfig?.profile} --app=${this.cdkOut} "*-${target.account}-${target.region}"`);
|
|
63
|
-
}
|
|
64
|
-
};
|
|
65
|
-
/*****************************************************************************
|
|
66
|
-
*
|
|
67
|
-
* Watch tasks
|
|
68
|
-
*
|
|
69
|
-
* - Configure watch task to use the branch name
|
|
70
|
-
* - configure watch task to use the correct synth output location.
|
|
71
|
-
*
|
|
72
|
-
****************************************************************************/
|
|
73
|
-
this.configureWatchTask = (target) => {
|
|
74
|
-
if (target.localDeployment) {
|
|
75
|
-
const taskName = ["watch", target.account, target.region].join(":");
|
|
76
|
-
const watchTask = this.project.tasks.addTask(taskName, { env: this.env });
|
|
77
|
-
// update the synth first
|
|
78
|
-
const synthSilent = this.project.tasks.tryFind("synth:silent");
|
|
79
|
-
if (synthSilent) {
|
|
80
|
-
watchTask.spawn(synthSilent);
|
|
81
|
-
}
|
|
82
|
-
// do a normal deploy
|
|
83
|
-
watchTask.exec(`cdk deploy --lookups=false --require-approval=never --profile=${target.localDeploymentConfig?.profile} --app=${this.cdkOut} "*-${target.account}-${target.region}"`);
|
|
84
|
-
// watch for changes and log output
|
|
85
|
-
watchTask.exec(`cdk watch --lookups=false --require-approval=never --hotswap --profile=${target.localDeploymentConfig?.profile} "*-${target.account}-${target.region}"`);
|
|
86
|
-
}
|
|
87
|
-
};
|
|
88
49
|
/**
|
|
89
50
|
* Common variables used across tasks.
|
|
90
51
|
*/
|
|
@@ -110,56 +71,56 @@ class AwsDeploymentConfig extends projen_1.Component {
|
|
|
110
71
|
*/
|
|
111
72
|
this.configureSynthTask();
|
|
112
73
|
}
|
|
74
|
+
/*****************************************************************************
|
|
75
|
+
*
|
|
76
|
+
* Target filter helpers
|
|
77
|
+
*
|
|
78
|
+
* Return various targets for deployment scripts to use.
|
|
79
|
+
*
|
|
80
|
+
****************************************************************************/
|
|
81
|
+
/**
|
|
82
|
+
* @returns All production deployment targets.
|
|
83
|
+
*/
|
|
84
|
+
get prodTargets() {
|
|
85
|
+
return this.awsDeploymentTargets.filter((target) => target.awsDeploymentType === aws_deployment_target_1.AWS_DEPLOY_TYPE.PROD);
|
|
86
|
+
}
|
|
87
|
+
get prodTargetsForCI() {
|
|
88
|
+
return this.awsDeploymentTargets.filter((target) => target.awsDeploymentType === aws_deployment_target_1.AWS_DEPLOY_TYPE.PROD &&
|
|
89
|
+
target.ciDeployment);
|
|
90
|
+
}
|
|
91
|
+
get prodTargetsForLocal() {
|
|
92
|
+
return this.awsDeploymentTargets.filter((target) => target.awsDeploymentType === aws_deployment_target_1.AWS_DEPLOY_TYPE.PROD &&
|
|
93
|
+
target.localDeployment);
|
|
94
|
+
}
|
|
113
95
|
/**
|
|
114
|
-
* Adds a deployment target to the configuration.
|
|
115
96
|
*
|
|
116
|
-
* @
|
|
97
|
+
* @returns All stage deployment targets.
|
|
117
98
|
*/
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
};
|
|
143
|
-
}
|
|
144
|
-
/**
|
|
145
|
-
* Some defaults for CI deployments.
|
|
146
|
-
*/
|
|
147
|
-
if (target.ciDeployment) {
|
|
148
|
-
const roleArn = target.ciDeploymentConfig?.roleArn ||
|
|
149
|
-
`arn:aws:iam::${target.account}:role/GitHub${this.project.name.replace("-", "")}`;
|
|
150
|
-
target = {
|
|
151
|
-
...target,
|
|
152
|
-
ciDeploymentConfig: {
|
|
153
|
-
roleArn,
|
|
154
|
-
},
|
|
155
|
-
};
|
|
156
|
-
}
|
|
157
|
-
this.deploymentTargets.push(target);
|
|
158
|
-
// Deploy tasks are configured per target.
|
|
159
|
-
this.configureDeployTask(target);
|
|
160
|
-
// Watch tasks are configured per target.
|
|
161
|
-
this.configureWatchTask(target);
|
|
99
|
+
get stageTargets() {
|
|
100
|
+
return this.awsDeploymentTargets.filter((target) => target.awsDeploymentType === aws_deployment_target_1.AWS_DEPLOY_TYPE.STAGE);
|
|
101
|
+
}
|
|
102
|
+
get stageTargetsForCI() {
|
|
103
|
+
return this.awsDeploymentTargets.filter((target) => target.awsDeploymentType === aws_deployment_target_1.AWS_DEPLOY_TYPE.STAGE &&
|
|
104
|
+
target.ciDeployment);
|
|
105
|
+
}
|
|
106
|
+
get stageTargetsForLocal() {
|
|
107
|
+
return this.awsDeploymentTargets.filter((target) => target.awsDeploymentType === aws_deployment_target_1.AWS_DEPLOY_TYPE.STAGE &&
|
|
108
|
+
target.localDeployment);
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
*
|
|
112
|
+
* @returns All dev deployment targets.
|
|
113
|
+
*/
|
|
114
|
+
get devTargets() {
|
|
115
|
+
return this.awsDeploymentTargets.filter((target) => target.awsDeploymentType === aws_deployment_target_1.AWS_DEPLOY_TYPE.DEV);
|
|
116
|
+
}
|
|
117
|
+
get devTargetsForCI() {
|
|
118
|
+
return this.awsDeploymentTargets.filter((target) => target.awsDeploymentType === aws_deployment_target_1.AWS_DEPLOY_TYPE.DEV && target.ciDeployment);
|
|
119
|
+
}
|
|
120
|
+
get devTargetsForLocal() {
|
|
121
|
+
return this.awsDeploymentTargets.filter((target) => target.awsDeploymentType === aws_deployment_target_1.AWS_DEPLOY_TYPE.DEV &&
|
|
122
|
+
target.localDeployment);
|
|
162
123
|
}
|
|
163
124
|
}
|
|
164
125
|
exports.AwsDeploymentConfig = AwsDeploymentConfig;
|
|
165
|
-
//# 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, Project } from \"projen\";\nimport { TypeScriptAppProject } from \"projen/lib/typescript\";\nimport { GitBranch } from \"../git/git-types\";\n\n/*******************************************************************************\n *\n *\n ******************************************************************************/\n\nexport interface AwsDeploymentConfigOptions {\n  /**\n   *\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  profile?: string;\n\n  /**\n   * Named Role used to conduct local deployments.\n   *\n   * @default \"administratoraccess\"\n   */\n  roleName?: string;\n}\n\nexport interface CiDeploymentConfig {\n  /**\n   * The OIDC IAM Role to assume for CI deployments.\n   */\n  roleArn: 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 AwsDeploymentTarget {\n  /**\n   * The account name for the deployment target.\n   */\n  account: string;\n\n  /**\n   * The AWS region for the deployment target.\n   */\n  region: string;\n\n  /**'\n   * AWS deployment type, such as dev, stage, or prod.\n   */\n  awsDeploymentType: AwsDeploymentType;\n\n  /**\n   * The AWS profile to use for this deployment target.\n   */\n  branches: Array<GitBranch>;\n\n  /**\n   * Can this deployment target be used for local development?\n   */\n  localDeployment: boolean;\n\n  /**\n   * Configuration when deploying to this target locally.\n   */\n  localDeploymentConfig?: AwsLocalDeploymentConfig;\n\n  /**\n   * Can this deployment target be used in CI deployments?\n   */\n  ciDeployment: boolean;\n\n  /*\n   * Configuration when deploying to this target in CI.\n\n   */\n  ciDeploymentConfig?: CiDeploymentConfig;\n}\n\nexport class AwsDeploymentConfig extends Component {\n  public static of(project: Project): Array<AwsDeploymentConfig> | undefined {\n    const isDefined = (c: Component): c is AwsDeploymentConfig =>\n      c instanceof AwsDeploymentConfig;\n    return project.components.filter(isDefined);\n  }\n\n  /**\n   * Environment variables to be injected into all tasks.\n   */\n  private readonly env: Record<string, string>;\n\n  /**\n   * The relative path to the project directory from the root of the project.\n   */\n  private readonly projectPath: string;\n\n  /**\n   * The relative path to the root of the project from the output directory.\n   */\n  private readonly rootPath: string;\n\n  /**\n   * The output directory for the CDK synthesis.\n   */\n  private readonly cdkOut: string;\n\n  /**\n   * Array of targets for deployment.\n   */\n  public readonly deploymentTargets: Array<AwsDeploymentTarget> = [];\n\n  constructor(project: TypeScriptAppProject) {\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.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   * Adds a deployment target to the configuration.\n   *\n   * @param target The deployment target to add.\n   */\n  public addDeploymentTarget(target: AwsDeploymentTarget): void {\n    /***************************************************************************\n     *\n     * Configure the deploy target.\n     *\n     * - For local deployments, discover or build profile name.\n     * - For CI deployments, discover or build role ARN.\n     * - Add the target to the deployment targets array.\n     *\n     **************************************************************************/\n\n    /**\n     * Some defaults for local deployments.\n     */\n    if (target.localDeployment) {\n      const roleName =\n        target.localDeploymentConfig?.roleName?.toLowerCase() ||\n        \"administratoraccess\";\n      const profile =\n        target.localDeploymentConfig?.profile ||\n        `${roleName}-${target.account}-${target.region}`;\n\n      target = {\n        ...target,\n        localDeploymentConfig: {\n          profile,\n          roleName,\n        },\n      };\n    }\n\n    /**\n     * Some defaults for CI deployments.\n     */\n    if (target.ciDeployment) {\n      const roleArn =\n        target.ciDeploymentConfig?.roleArn ||\n        `arn:aws:iam::${target.account}:role/GitHub${this.project.name.replace(\"-\", \"\")}`;\n\n      target = {\n        ...target,\n        ciDeploymentConfig: {\n          roleArn,\n        },\n      };\n    }\n\n    this.deploymentTargets.push(target);\n\n    // Deploy tasks are configured per target.\n    this.configureDeployTask(target);\n\n    // Watch tasks are configured per target.\n    this.configureWatchTask(target);\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  /*****************************************************************************\n   *\n   * Deploy Tasks\n   *\n   * - If local deploy, add a deploy task.\n   *\n   ****************************************************************************/\n\n  private configureDeployTask = (target: AwsDeploymentTarget): void => {\n    if (target.localDeployment) {\n      const taskName = [\"deploy\", target.account, target.region].join(\":\");\n      const deployTask = this.project.tasks.addTask(taskName, {\n        env: this.env,\n      });\n      deployTask.exec(\n        `cdk deploy --lookups=false --require-approval=never --profile=${target.localDeploymentConfig?.profile} --app=${this.cdkOut} \"*-${target.account}-${target.region}\"`,\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 = (target: AwsDeploymentTarget): void => {\n    if (target.localDeployment) {\n      const taskName = [\"watch\", target.account, target.region].join(\":\");\n      const watchTask = this.project.tasks.addTask(taskName, { env: this.env });\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=${target.localDeploymentConfig?.profile} --app=${this.cdkOut} \"*-${target.account}-${target.region}\"`,\n      );\n\n      // watch for changes and log output\n      watchTask.exec(\n        `cdk watch --lookups=false --require-approval=never --hotswap --profile=${target.localDeploymentConfig?.profile} \"*-${target.account}-${target.region}\"`,\n      );\n    }\n  };\n}\n"]}
|
|
126
|
+
//# 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\";\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.\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.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"]}
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
import { Component } from "projen";
|
|
2
|
+
import { AwsCdkTypeScriptApp } from "projen/lib/awscdk";
|
|
3
|
+
import { AwsDeploymentConfig } from "./aws-deployment-config";
|
|
4
|
+
import { GitBranch } from "../git";
|
|
5
|
+
/*******************************************************************************
|
|
6
|
+
*
|
|
7
|
+
* AWS Deployment Configuration
|
|
8
|
+
*
|
|
9
|
+
* A single deployment target that CDK applications can be deployed into.
|
|
10
|
+
*
|
|
11
|
+
******************************************************************************/
|
|
12
|
+
export declare const AWS_DEPLOY_TYPE: {
|
|
13
|
+
/**
|
|
14
|
+
* Development environment, typically used for testing and development.
|
|
15
|
+
*/
|
|
16
|
+
readonly DEV: "dev";
|
|
17
|
+
/**
|
|
18
|
+
* Staging environment, used for pre-production testing.
|
|
19
|
+
*/
|
|
20
|
+
readonly STAGE: "stage";
|
|
21
|
+
/**
|
|
22
|
+
* Production environment, used for live deployments.
|
|
23
|
+
*/
|
|
24
|
+
readonly PROD: "prod";
|
|
25
|
+
};
|
|
26
|
+
/**
|
|
27
|
+
* Above const as a type.
|
|
28
|
+
*/
|
|
29
|
+
export type AwsDeploymentType = (typeof AWS_DEPLOY_TYPE)[keyof typeof AWS_DEPLOY_TYPE];
|
|
30
|
+
/**
|
|
31
|
+
* Represents the configuration for local deployment in AWS.
|
|
32
|
+
*/
|
|
33
|
+
export interface AwsLocalDeploymentConfig {
|
|
34
|
+
/**
|
|
35
|
+
* The AWS profile (in ~/.aws/config) to use for local deployment.
|
|
36
|
+
*
|
|
37
|
+
* @default generated dynamically based role name, account and region
|
|
38
|
+
*/
|
|
39
|
+
readonly profile?: string;
|
|
40
|
+
/**
|
|
41
|
+
* Named Role used to conduct local deployments.
|
|
42
|
+
*
|
|
43
|
+
* @default "administratoraccess"
|
|
44
|
+
*/
|
|
45
|
+
readonly roleName?: string;
|
|
46
|
+
}
|
|
47
|
+
export interface CiDeploymentConfig {
|
|
48
|
+
/**
|
|
49
|
+
* The OIDC IAM Role to assume for CI deployments.
|
|
50
|
+
*/
|
|
51
|
+
readonly roleArn: string;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Represents a deployment target in AWS, including account and region, and
|
|
55
|
+
* branches allowed to deploy to this target.
|
|
56
|
+
*/
|
|
57
|
+
export interface AwsDeploymentTargetOptions {
|
|
58
|
+
/**
|
|
59
|
+
* The account name for the deployment target.
|
|
60
|
+
*/
|
|
61
|
+
readonly account: string;
|
|
62
|
+
/**
|
|
63
|
+
* The AWS region for the deployment target.
|
|
64
|
+
*/
|
|
65
|
+
readonly region: string;
|
|
66
|
+
/**
|
|
67
|
+
* AWS deployment type, such as dev, stage, or prod.
|
|
68
|
+
*
|
|
69
|
+
* @default 'dev'
|
|
70
|
+
*/
|
|
71
|
+
readonly awsDeploymentType?: AwsDeploymentType;
|
|
72
|
+
/**
|
|
73
|
+
* The AWS profile to use for this deployment target.
|
|
74
|
+
*
|
|
75
|
+
* @default ['main'] when prod release type, ['feature/*'] when dev type
|
|
76
|
+
*/
|
|
77
|
+
readonly branches?: Array<GitBranch>;
|
|
78
|
+
/**
|
|
79
|
+
* Can this deployment target be used for local development?
|
|
80
|
+
*
|
|
81
|
+
* @default true for dev environments, false for prod environments
|
|
82
|
+
*/
|
|
83
|
+
readonly localDeployment?: boolean;
|
|
84
|
+
/**
|
|
85
|
+
* Configuration when deploying to this target locally.
|
|
86
|
+
*/
|
|
87
|
+
readonly localDeploymentConfig?: AwsLocalDeploymentConfig;
|
|
88
|
+
/**
|
|
89
|
+
* Can this deployment target be used in CI deployments?
|
|
90
|
+
*
|
|
91
|
+
* @default false
|
|
92
|
+
*/
|
|
93
|
+
readonly ciDeployment?: boolean;
|
|
94
|
+
readonly ciDeploymentConfig?: CiDeploymentConfig;
|
|
95
|
+
}
|
|
96
|
+
export declare class AwsDeploymentTarget extends Component {
|
|
97
|
+
/**
|
|
98
|
+
* Static method to discovert targets in a project.
|
|
99
|
+
*/
|
|
100
|
+
static of(project: AwsCdkTypeScriptApp): Array<AwsDeploymentTarget> | undefined;
|
|
101
|
+
/**
|
|
102
|
+
* The account name for the deployment target.
|
|
103
|
+
*/
|
|
104
|
+
account: string;
|
|
105
|
+
/**
|
|
106
|
+
* The AWS region for the deployment target.
|
|
107
|
+
*/
|
|
108
|
+
region: string;
|
|
109
|
+
/**'
|
|
110
|
+
* AWS deployment type, such as dev, stage, or prod.
|
|
111
|
+
*
|
|
112
|
+
* @default 'dev'
|
|
113
|
+
*/
|
|
114
|
+
awsDeploymentType?: AwsDeploymentType;
|
|
115
|
+
/**
|
|
116
|
+
* The AWS profile to use for this deployment target.
|
|
117
|
+
*
|
|
118
|
+
* @default ['main'] when prod release type, ['feature/*'] when dev type
|
|
119
|
+
*/
|
|
120
|
+
branches: Array<GitBranch>;
|
|
121
|
+
/**
|
|
122
|
+
* Can this deployment target be used for local development?
|
|
123
|
+
*
|
|
124
|
+
* @default true for dev environments, false for prod environments
|
|
125
|
+
*/
|
|
126
|
+
localDeployment?: boolean;
|
|
127
|
+
/**
|
|
128
|
+
* Configuration when deploying to this target locally.
|
|
129
|
+
*/
|
|
130
|
+
localDeploymentConfig?: AwsLocalDeploymentConfig;
|
|
131
|
+
/**
|
|
132
|
+
* Can this deployment target be used in CI deployments?
|
|
133
|
+
*
|
|
134
|
+
* @default false
|
|
135
|
+
*/
|
|
136
|
+
ciDeployment?: boolean;
|
|
137
|
+
ciDeploymentConfig?: Required<CiDeploymentConfig>;
|
|
138
|
+
/**
|
|
139
|
+
* Configuration for the CDK output directory for this deployment target.
|
|
140
|
+
*/
|
|
141
|
+
awsDeploymentConfig: AwsDeploymentConfig;
|
|
142
|
+
constructor(project: AwsCdkTypeScriptApp, options: AwsDeploymentTargetOptions);
|
|
143
|
+
/*****************************************************************************
|
|
144
|
+
*
|
|
145
|
+
* Deploy Tasks
|
|
146
|
+
*
|
|
147
|
+
* - If local deploy, add a deploy task.
|
|
148
|
+
*
|
|
149
|
+
****************************************************************************/
|
|
150
|
+
private configureDeployTask;
|
|
151
|
+
/*****************************************************************************
|
|
152
|
+
*
|
|
153
|
+
* Watch tasks
|
|
154
|
+
*
|
|
155
|
+
* - Configure watch task to use the branch name
|
|
156
|
+
* - configure watch task to use the correct synth output location.
|
|
157
|
+
*
|
|
158
|
+
****************************************************************************/
|
|
159
|
+
private configureWatchTask;
|
|
160
|
+
}
|