projen-pipelines 0.0.2 → 0.0.3

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.
@@ -0,0 +1,100 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.GitHubEngine = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const workflows_model_1 = require("projen/lib/github/workflows-model");
7
+ const base_1 = require("./base");
8
+ class GitHubEngine extends base_1.BaseEngine {
9
+ constructor(app, props, pipeline) {
10
+ super(app, props, pipeline);
11
+ this.deploymentStages = [];
12
+ this.deploymentWorkflow = this.app.github.addWorkflow('deploy');
13
+ this.deploymentWorkflow.on({
14
+ push: {
15
+ branches: ['main'], // TODO use defaultReleaseBranch
16
+ },
17
+ workflowDispatch: {},
18
+ });
19
+ }
20
+ createSynth(options) {
21
+ const steps = [{
22
+ name: 'Checkout',
23
+ uses: 'actions/checkout@v2',
24
+ env: {
25
+ CI: 'true',
26
+ },
27
+ }];
28
+ if (this.props.githubConfig?.awsRoleArnForSynth) {
29
+ steps.push({
30
+ name: 'AWS Credentials',
31
+ uses: 'aws-actions/configure-aws-credentials@master',
32
+ with: {
33
+ 'role-to-assume': this.props.githubConfig.awsRoleArnForSynth,
34
+ 'role-session-name': 'GitHubAction',
35
+ 'aws-region': 'us-east-1',
36
+ },
37
+ });
38
+ }
39
+ steps.push(...options.commands.map(cmd => ({
40
+ run: cmd,
41
+ })));
42
+ this.deploymentWorkflow.addJob('synth', {
43
+ name: 'Synth CDK application',
44
+ runsOn: ['ubuntu-latest'],
45
+ permissions: { idToken: workflows_model_1.JobPermission.WRITE, contents: workflows_model_1.JobPermission.READ },
46
+ steps,
47
+ });
48
+ }
49
+ createAssetUpload(options) {
50
+ this.deploymentWorkflow.addJob('assetUpload', {
51
+ name: 'Publish assets to AWS',
52
+ needs: ['synth'],
53
+ runsOn: ['ubuntu-latest'],
54
+ permissions: { idToken: workflows_model_1.JobPermission.WRITE, contents: workflows_model_1.JobPermission.READ },
55
+ steps: [{
56
+ name: 'Checkout',
57
+ uses: 'actions/checkout@v2',
58
+ }, {
59
+ name: 'AWS Credentials',
60
+ uses: 'aws-actions/configure-aws-credentials@master',
61
+ with: {
62
+ 'role-to-assume': this.props.githubConfig?.awsRoleArnForAssetPublishing ?? this.props.githubConfig?.defaultAwsRoleArn,
63
+ 'role-session-name': 'GitHubAction',
64
+ 'aws-region': 'us-east-1',
65
+ },
66
+ },
67
+ ...options.commands.map(cmd => ({
68
+ run: cmd,
69
+ }))],
70
+ });
71
+ }
72
+ createDeployment(options) {
73
+ this.deploymentWorkflow.addJob(`deploy-${options.stageName}`, {
74
+ name: `Deploy stage ${options.stageName} to AWS`,
75
+ needs: this.deploymentStages.length > 0 ? ['assetUpload', `deploy-${this.deploymentStages.at(-1)}`] : ['assetUpload'],
76
+ runsOn: ['ubuntu-latest'],
77
+ permissions: { idToken: workflows_model_1.JobPermission.WRITE, contents: workflows_model_1.JobPermission.READ },
78
+ steps: [{
79
+ name: 'Checkout',
80
+ uses: 'actions/checkout@v2',
81
+ }, {
82
+ name: 'AWS Credentials',
83
+ uses: 'aws-actions/configure-aws-credentials@master',
84
+ with: {
85
+ 'role-to-assume': this.props.githubConfig?.awsRoleArnForDeployment?.[options.stageName] ?? this.props.githubConfig?.defaultAwsRoleArn,
86
+ 'role-session-name': 'GitHubAction',
87
+ 'aws-region': options.env.region,
88
+ },
89
+ },
90
+ ...options.commands.map(cmd => ({
91
+ run: cmd,
92
+ }))],
93
+ });
94
+ this.deploymentStages.push(options.stageName);
95
+ }
96
+ }
97
+ _a = JSII_RTTI_SYMBOL_1;
98
+ GitHubEngine[_a] = { fqn: "projen-pipelines.GitHubEngine", version: "0.0.3" };
99
+ exports.GitHubEngine = GitHubEngine;
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"github.js","sourceRoot":"","sources":["../../src/engine/github.ts"],"names":[],"mappings":"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","sourcesContent":["import { awscdk } from 'projen';\nimport { GithubWorkflow } from 'projen/lib/github';\nimport { JobPermission, JobStep } from 'projen/lib/github/workflows-model';\nimport { AssetUploadStageOptions, BaseEngine, DeployStageOptions, SynthStageOptions } from './base';\nimport { CDKPipeline, CDKPipelineOptions } from '../pipeline';\n\nexport interface RoleMap {\n  readonly feature?: string;\n  readonly dev?: string;\n  readonly prod?: string;\n}\n\nexport interface GithubEngineConfig {\n  readonly defaultAwsRoleArn?: string;\n  readonly awsRoleArnForSynth?: string;\n  readonly awsRoleArnForAssetPublishing?: string;\n  readonly awsRoleArnForDeployment?: RoleMap;\n}\n\nexport class GitHubEngine extends BaseEngine {\n\n  private deploymentWorkflow: GithubWorkflow;\n  private deploymentStages: string[] = [];\n\n  constructor(app: awscdk.AwsCdkTypeScriptApp, props: CDKPipelineOptions, pipeline: CDKPipeline) {\n    super(app, props, pipeline);\n\n    this.deploymentWorkflow = this.app.github!.addWorkflow('deploy');\n    this.deploymentWorkflow.on({\n      push: {\n        branches: ['main'], // TODO use defaultReleaseBranch\n      },\n      workflowDispatch: {},\n    });\n  }\n\n  public createSynth(options: SynthStageOptions): void {\n    const steps: JobStep[] = [{\n      name: 'Checkout',\n      uses: 'actions/checkout@v2',\n      env: {\n        CI: 'true',\n      },\n    }];\n\n    if (this.props.githubConfig?.awsRoleArnForSynth) {\n      steps.push({\n        name: 'AWS Credentials',\n        uses: 'aws-actions/configure-aws-credentials@master',\n        with: {\n          'role-to-assume': this.props.githubConfig.awsRoleArnForSynth,\n          'role-session-name': 'GitHubAction',\n          'aws-region': 'us-east-1',\n        },\n      });\n    }\n\n    steps.push(...options.commands.map(cmd => ({\n      run: cmd,\n    })));\n\n    this.deploymentWorkflow.addJob('synth', {\n      name: 'Synth CDK application',\n      runsOn: ['ubuntu-latest'],\n      permissions: { idToken: JobPermission.WRITE, contents: JobPermission.READ },\n      steps,\n    });\n  }\n\n  public createAssetUpload(options: AssetUploadStageOptions): void {\n    this.deploymentWorkflow.addJob('assetUpload', {\n      name: 'Publish assets to AWS',\n      needs: ['synth'],\n      runsOn: ['ubuntu-latest'],\n      permissions: { idToken: JobPermission.WRITE, contents: JobPermission.READ },\n      steps: [{\n        name: 'Checkout',\n        uses: 'actions/checkout@v2',\n      }, {\n        name: 'AWS Credentials',\n        uses: 'aws-actions/configure-aws-credentials@master',\n        with: {\n          'role-to-assume': this.props.githubConfig?.awsRoleArnForAssetPublishing ?? this.props.githubConfig?.defaultAwsRoleArn,\n          'role-session-name': 'GitHubAction',\n          'aws-region': 'us-east-1',\n        },\n      },\n      ...options.commands.map(cmd => ({\n        run: cmd,\n      }))],\n    });\n  }\n\n  public createDeployment(options: DeployStageOptions): void {\n    this.deploymentWorkflow.addJob(`deploy-${options.stageName}`, {\n      name: `Deploy stage ${options.stageName} to AWS`,\n      needs: this.deploymentStages.length > 0 ? ['assetUpload', `deploy-${this.deploymentStages.at(-1)!}`] : ['assetUpload'],\n      runsOn: ['ubuntu-latest'],\n      permissions: { idToken: JobPermission.WRITE, contents: JobPermission.READ },\n      steps: [{\n        name: 'Checkout',\n        uses: 'actions/checkout@v2',\n      }, {\n        name: 'AWS Credentials',\n        uses: 'aws-actions/configure-aws-credentials@master',\n        with: {\n          'role-to-assume': this.props.githubConfig?.awsRoleArnForDeployment?.[options.stageName as keyof RoleMap] ?? this.props.githubConfig?.defaultAwsRoleArn,\n          'role-session-name': 'GitHubAction',\n          'aws-region': options.env.region,\n        },\n      },\n      ...options.commands.map(cmd => ({\n        run: cmd,\n      }))],\n    });\n    this.deploymentStages.push(options.stageName);\n  }\n}"]}
@@ -0,0 +1,2 @@
1
+ export * from './base';
2
+ export * from './github';
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./base"), exports);
18
+ __exportStar(require("./github"), exports);
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZW5naW5lL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSx5Q0FBdUI7QUFDdkIsMkNBQXlCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9iYXNlJztcbmV4cG9ydCAqIGZyb20gJy4vZ2l0aHViJzsiXX0=
package/lib/index.d.ts CHANGED
@@ -1 +1,2 @@
1
1
  export * from './pipeline';
2
+ export * from './engine';
package/lib/index.js CHANGED
@@ -15,4 +15,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./pipeline"), exports);
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDZDQUEyQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcGlwZWxpbmUnOyJdfQ==
18
+ __exportStar(require("./engine"), exports);
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDZDQUEyQjtBQUMzQiwyQ0FBeUIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3BpcGVsaW5lJztcbmV4cG9ydCAqIGZyb20gJy4vZW5naW5lJzsiXX0=
package/lib/pipeline.d.ts CHANGED
@@ -1,4 +1,5 @@
1
1
  import { Component, awscdk } from 'projen';
2
+ import { BaseEngine, GithubEngineConfig } from './engine';
2
3
  /**
3
4
  * The Environment interface is designed to hold AWS related information
4
5
  * for a specific deployment environment within your infrastructure.
@@ -49,6 +50,25 @@ export interface EnvironmentMap {
49
50
  */
50
51
  readonly prod: Environment;
51
52
  }
53
+ /**
54
+ * The CI/CD tooling used to run your pipeline.
55
+ * The component will render workflows for the given system
56
+ */
57
+ export declare enum PipelineEngine {
58
+ /** Create GitHub actions */
59
+ GITHUB = 0,
60
+ /** Create a .gitlab-ci.yaml file */
61
+ GITLAB = 1
62
+ }
63
+ /**
64
+ * Describes the type of pipeline that will be created
65
+ */
66
+ export declare enum DeploymentType {
67
+ /** Deploy every commit as far as possible; hopefully into production */
68
+ CONTINUOUS_DEPLOYMENT = 0,
69
+ /** Build every commit and prepare all assets for a later deployment */
70
+ CONTINUOUS_DELIVERY = 1
71
+ }
52
72
  /**
53
73
  * The CDKPipelineOptions interface is designed to provide configuration
54
74
  * options for a CDK (Cloud Development Kit) pipeline. It allows the definition
@@ -59,8 +79,10 @@ export interface CDKPipelineOptions {
59
79
  /**
60
80
  * This field is used to define a prefix for the AWS Stack resources created
61
81
  * during the pipeline's operation.
82
+ *
83
+ * @default project name
62
84
  */
63
- readonly stackPrefix: string;
85
+ readonly stackPrefix?: string;
64
86
  /**
65
87
  * This field determines the NPM namespace to be used when packaging CDK cloud
66
88
  * assemblies. A namespace helps group related resources together, providing
@@ -73,6 +95,25 @@ export interface CDKPipelineOptions {
73
95
  * deployment process, whether that's a personal, feature, dev, or prod stage.
74
96
  */
75
97
  readonly environments: EnvironmentMap;
98
+ /**
99
+ * This field specifies the type of pipeline to create. If set to CONTINUOUS_DEPLOYMENT,
100
+ * every commit is deployed as far as possible, hopefully into production. If set to
101
+ * CONTINUOUS_DELIVERY, every commit is built and all assets are prepared for a later deployment.
102
+ *
103
+ * @default CONTINUOUS_DELIVERY
104
+ */
105
+ readonly deploymentType?: DeploymentType;
106
+ /**
107
+ * This field determines the CI/CD tooling that will be used to run the pipeline. The component
108
+ * will render workflows for the given system. Options include GitHub and GitLab.
109
+ *
110
+ * @default - tries to derive it from the projects configuration
111
+ */
112
+ readonly engine?: PipelineEngine;
113
+ readonly githubConfig?: GithubEngineConfig;
114
+ readonly preInstallCommands?: string[];
115
+ readonly preSynthCommands?: string[];
116
+ readonly postSynthCommands?: string[];
76
117
  }
77
118
  /**
78
119
  * The CDKPipeline class extends the Component class and sets up the necessary configuration for deploying AWS CDK (Cloud Development Kit) applications across multiple stages.
@@ -81,7 +122,10 @@ export interface CDKPipelineOptions {
81
122
  export declare class CDKPipeline extends Component {
82
123
  private app;
83
124
  private props;
125
+ readonly stackPrefix: string;
126
+ readonly engine: BaseEngine;
84
127
  constructor(app: awscdk.AwsCdkTypeScriptApp, props: CDKPipelineOptions);
128
+ private createSynthStage;
85
129
  /**
86
130
  * This method generates the entry point for the application, including interfaces and classes
87
131
  * necessary to set up the pipeline and define the AWS CDK stacks for different environments.
package/lib/pipeline.js CHANGED
@@ -1,10 +1,34 @@
1
1
  "use strict";
2
2
  var _a;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.CDKPipeline = void 0;
4
+ exports.CDKPipeline = exports.DeploymentType = exports.PipelineEngine = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const projen_1 = require("projen");
7
7
  const common_1 = require("projen/lib/common");
8
+ const engine_1 = require("./engine");
9
+ /**
10
+ * The CI/CD tooling used to run your pipeline.
11
+ * The component will render workflows for the given system
12
+ */
13
+ var PipelineEngine;
14
+ (function (PipelineEngine) {
15
+ /** Create GitHub actions */
16
+ PipelineEngine[PipelineEngine["GITHUB"] = 0] = "GITHUB";
17
+ /** Create a .gitlab-ci.yaml file */
18
+ PipelineEngine[PipelineEngine["GITLAB"] = 1] = "GITLAB";
19
+ // /** Create AWS CodeCatalyst workflows */
20
+ // CODE_CATALYST,
21
+ })(PipelineEngine = exports.PipelineEngine || (exports.PipelineEngine = {}));
22
+ /**
23
+ * Describes the type of pipeline that will be created
24
+ */
25
+ var DeploymentType;
26
+ (function (DeploymentType) {
27
+ /** Deploy every commit as far as possible; hopefully into production */
28
+ DeploymentType[DeploymentType["CONTINUOUS_DEPLOYMENT"] = 0] = "CONTINUOUS_DEPLOYMENT";
29
+ /** Build every commit and prepare all assets for a later deployment */
30
+ DeploymentType[DeploymentType["CONTINUOUS_DELIVERY"] = 1] = "CONTINUOUS_DELIVERY";
31
+ })(DeploymentType = exports.DeploymentType || (exports.DeploymentType = {}));
8
32
  /**
9
33
  * The CDKPipeline class extends the Component class and sets up the necessary configuration for deploying AWS CDK (Cloud Development Kit) applications across multiple stages.
10
34
  * It also manages tasks such as publishing CDK assets, bumping version based on git tags, and cleaning up conflicting tasks.
@@ -18,6 +42,15 @@ class CDKPipeline extends projen_1.Component {
18
42
  this.app.addDevDeps('@types/standard-version', 'standard-version', 'cdk-assets');
19
43
  // this.app.addDeps(
20
44
  // );
45
+ this.stackPrefix = props.stackPrefix ?? app.name;
46
+ // Create engine instance to use
47
+ switch (props.engine) {
48
+ case PipelineEngine.GITHUB:
49
+ this.engine = new engine_1.GitHubEngine(app, props, this);
50
+ break;
51
+ default:
52
+ throw new Error('Invalid engine');
53
+ }
21
54
  // Removes the compiled cloud assembly before each synth
22
55
  this.project.tasks.tryFind('synth')?.prependExec(`rm -rf ${this.app.cdkConfig.cdkout}`);
23
56
  this.project.tasks.tryFind('synth:silent')?.prependExec(`rm -rf ${this.app.cdkConfig.cdkout}`);
@@ -26,6 +59,7 @@ class CDKPipeline extends projen_1.Component {
26
59
  this.project.removeTask('diff');
27
60
  this.project.removeTask('destroy');
28
61
  this.project.removeTask('watch');
62
+ this.createSynthStage();
29
63
  // Creates different deployment stages
30
64
  this.createPersonalStage();
31
65
  this.createFeatureStage();
@@ -36,6 +70,24 @@ class CDKPipeline extends projen_1.Component {
36
70
  // Creates a specialized CDK App class
37
71
  this.createApplicationEntrypoint();
38
72
  }
73
+ createSynthStage() {
74
+ this.engine.createSynth({
75
+ commands: [
76
+ ...(this.props.preInstallCommands ?? []),
77
+ `npx projen ${this.app.package.installCiTask.name}`,
78
+ ...(this.props.preSynthCommands ?? []),
79
+ 'npx projen build',
80
+ ...(this.props.postSynthCommands ?? []),
81
+ ],
82
+ });
83
+ this.engine.createAssetUpload({
84
+ commands: [
85
+ ...(this.props.preInstallCommands ?? []),
86
+ `npx projen ${this.app.package.installCiTask.name}`,
87
+ 'npx projen publish:assets',
88
+ ],
89
+ });
90
+ }
39
91
  /**
40
92
  * This method generates the entry point for the application, including interfaces and classes
41
93
  * necessary to set up the pipeline and define the AWS CDK stacks for different environments.
@@ -43,17 +95,13 @@ class CDKPipeline extends projen_1.Component {
43
95
  createApplicationEntrypoint() {
44
96
  const appFile = new projen_1.TextFile(this.project, `${this.app.srcdir}/app.ts`);
45
97
  appFile.addLine(`// ${common_1.PROJEN_MARKER}
46
- /* eslint-disable object-curly-spacing */
47
- /* eslint-disable comma-spacing */
48
- /* eslint-disable quotes */
49
- /* eslint-disable key-spacing */
50
- /* eslint-disable quote-props */
98
+ /* eslint-disable */
51
99
  import { App, AppProps, Stack, StackProps } from 'aws-cdk-lib';
52
100
 
53
101
  /**
54
102
  * PipelineAppProps is an extension of AppProps, which is part of the AWS CDK core.
55
103
  * It includes optional functions to provide AWS Stacks for different stages.
56
- *
104
+ *
57
105
  * Use these functions to instantiate your application stacks with the parameters for
58
106
  * each stage
59
107
  */
@@ -81,7 +129,7 @@ export interface PipelineAppStackProps extends StackProps {
81
129
 
82
130
  /**
83
131
  * The PipelineApp class extends the App class from AWS CDK and overrides the constructor to support
84
- * different stages of the application (development, production, personal, feature) by invoking the provided
132
+ * different stages of the application (development, production, personal, feature) by invoking the provided
85
133
  * stack-providing functions from the props.
86
134
  */
87
135
  export class PipelineApp extends App {
@@ -90,24 +138,24 @@ export class PipelineApp extends App {
90
138
 
91
139
  // If a function is provided for creating a development stack, it is called with necessary arguments.
92
140
  if (props.provideDevStack) {
93
- props.provideDevStack(this, '${this.props.stackPrefix}-dev', { env: ${JSON.stringify(this.props.environments.dev)}, stackName: '${this.props.stackPrefix}-dev', stageName: 'dev' });
141
+ props.provideDevStack(this, '${this.stackPrefix}-dev', { env: ${JSON.stringify(this.props.environments.dev)}, stackName: '${this.stackPrefix}-dev', stageName: 'dev' });
94
142
  }
95
143
 
96
144
  // If a function is provided for creating a production stack, it is called with necessary arguments.
97
145
  if (props.provideProdStack) {
98
- props.provideProdStack(this, '${this.props.stackPrefix}-prod', { env: ${JSON.stringify(this.props.environments.prod)}, stackName: '${this.props.stackPrefix}-prod', stageName: 'prod' });
146
+ props.provideProdStack(this, '${this.stackPrefix}-prod', { env: ${JSON.stringify(this.props.environments.prod)}, stackName: '${this.stackPrefix}-prod', stageName: 'prod' });
99
147
  }
100
148
 
101
149
  // If the environment variable USER is set and a function is provided for creating a personal stack, it is called with necessary arguments.
102
150
  if (props.providePersonalStack && process.env.USER) {
103
151
  const stageName = 'personal-' + process.env.USER.toLowerCase().replace(/\\\//g, '-');
104
- props.providePersonalStack(this, '${this.props.stackPrefix}-personal', { env: ${JSON.stringify(this.props.environments.personal)}, stackName: \`${this.props.stackPrefix}-\${stageName}\`, stageName });
152
+ props.providePersonalStack(this, '${this.stackPrefix}-personal', { env: ${JSON.stringify(this.props.environments.personal)}, stackName: \`${this.stackPrefix}-\${stageName}\`, stageName });
105
153
  }
106
154
 
107
155
  // If the environment variable BRANCH is set and a function is provided for creating a feature stack, it is called with necessary arguments.
108
156
  if (props.provideFeatureStack && process.env.BRANCH) {
109
157
  const stageName = 'feature-' + process.env.BRANCH.toLowerCase().replace(/\\\//g, '-');
110
- props.provideFeatureStack(this, '${this.props.stackPrefix}-feature', { env: ${JSON.stringify(this.props.environments.feature)}, stackName: \`${this.props.stackPrefix}-\${stageName}\`, stageName });
158
+ props.provideFeatureStack(this, '${this.stackPrefix}-feature', { env: ${JSON.stringify(this.props.environments.feature)}, stackName: \`${this.stackPrefix}-\${stageName}\`, stageName });
111
159
  }
112
160
  }
113
161
  }
@@ -122,10 +170,10 @@ export class PipelineApp extends App {
122
170
  this.project.addTask('publish:assets', {
123
171
  steps: [
124
172
  {
125
- exec: `npx cdk-assets -p ${this.app.cdkConfig.cdkout}/${this.props.stackPrefix}-dev.assets.json publish`,
173
+ exec: `npx cdk-assets -p ${this.app.cdkConfig.cdkout}/${this.stackPrefix}-dev.assets.json publish`,
126
174
  },
127
175
  {
128
- exec: `npx cdk-assets -p ${this.app.cdkConfig.cdkout}/${this.props.stackPrefix}-prod.assets.json publish`,
176
+ exec: `npx cdk-assets -p ${this.app.cdkConfig.cdkout}/${this.stackPrefix}-prod.assets.json publish`,
129
177
  },
130
178
  ],
131
179
  });
@@ -162,16 +210,16 @@ export class PipelineApp extends App {
162
210
  */
163
211
  createPersonalStage() {
164
212
  this.project.addTask('deploy:personal', {
165
- exec: `cdk deploy ${this.props.stackPrefix}-personal`,
213
+ exec: `cdk deploy ${this.stackPrefix}-personal`,
166
214
  });
167
215
  this.project.addTask('watch:personal', {
168
- exec: `cdk deploy --watch --hotswap ${this.props.stackPrefix}-personal`,
216
+ exec: `cdk deploy --watch --hotswap ${this.stackPrefix}-personal`,
169
217
  });
170
218
  this.project.addTask('diff:personal', {
171
- exec: `cdk diff ${this.props.stackPrefix}-personal`,
219
+ exec: `cdk diff ${this.stackPrefix}-personal`,
172
220
  });
173
221
  this.project.addTask('destroy:personal', {
174
- exec: `cdk destroy ${this.props.stackPrefix}-personal`,
222
+ exec: `cdk destroy ${this.stackPrefix}-personal`,
175
223
  });
176
224
  }
177
225
  /**
@@ -180,13 +228,13 @@ export class PipelineApp extends App {
180
228
  */
181
229
  createFeatureStage() {
182
230
  this.project.addTask('deploy:feature', {
183
- exec: `cdk --progress events --require-approval never deploy ${this.props.stackPrefix}-feature`,
231
+ exec: `cdk --progress events --require-approval never deploy ${this.stackPrefix}-feature`,
184
232
  });
185
233
  this.project.addTask('diff:feature', {
186
- exec: `cdk diff ${this.props.stackPrefix}-feature`,
234
+ exec: `cdk diff ${this.stackPrefix}-feature`,
187
235
  });
188
236
  this.project.addTask('destroy:feature', {
189
- exec: `cdk destroy ${this.props.stackPrefix}-feature`,
237
+ exec: `cdk destroy ${this.stackPrefix}-feature`,
190
238
  });
191
239
  }
192
240
  /**
@@ -195,14 +243,21 @@ export class PipelineApp extends App {
195
243
  */
196
244
  createPipelineStage(stageName) {
197
245
  this.project.addTask(`deploy:${stageName}`, {
198
- exec: `cdk --app ${this.app.cdkConfig.cdkout} --progress events --require-approval never deploy ${this.props.stackPrefix}-${stageName}`,
246
+ exec: `cdk --app ${this.app.cdkConfig.cdkout} --progress events --require-approval never deploy ${this.stackPrefix}-${stageName}`,
199
247
  });
200
248
  this.project.addTask(`diff:${stageName}`, {
201
- exec: `cdk --app ${this.app.cdkConfig.cdkout} diff ${this.props.stackPrefix}-${stageName}`,
249
+ exec: `cdk --app ${this.app.cdkConfig.cdkout} diff ${this.stackPrefix}-${stageName}`,
250
+ });
251
+ this.engine.createDeployment({
252
+ stageName,
253
+ env: this.props.environments[stageName],
254
+ commands: [
255
+ `npx projen deploy:${stageName}`,
256
+ ],
202
257
  });
203
258
  }
204
259
  }
205
260
  _a = JSII_RTTI_SYMBOL_1;
206
- CDKPipeline[_a] = { fqn: "projen-pipelines.CDKPipeline", version: "0.0.2" };
261
+ CDKPipeline[_a] = { fqn: "projen-pipelines.CDKPipeline", version: "0.0.3" };
207
262
  exports.CDKPipeline = CDKPipeline;
208
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline.js","sourceRoot":"","sources":["../src/pipeline.ts"],"names":[],"mappings":";;;;;AAAA,mCAAqD;AACrD,8CAAkD;AAsFlD;;;GAGG;AACH,MAAa,WAAY,SAAQ,kBAAS;IAExC,YAAoB,GAA+B,EAAU,KAAyB;QACpF,KAAK,CAAC,GAAG,CAAC,CAAC;QADO,QAAG,GAAH,GAAG,CAA4B;QAAU,UAAK,GAAL,KAAK,CAAoB;QAGpF,+BAA+B;QAC/B,IAAI,CAAC,GAAG,CAAC,UAAU,CACjB,yBAAyB,EACzB,kBAAkB,EAClB,YAAY,CACb,CAAC;QACF,oBAAoB;QACpB,KAAK;QAEL,wDAAwD;QACxD,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,WAAW,CAAC,UAAU,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC;QACxF,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE,WAAW,CAAC,UAAU,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC;QAE/F,6DAA6D;QAC7D,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;QAClC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QAChC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;QACnC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAEjC,sCAAsC;QACtC,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;QAChC,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;QAEjC,8CAA8C;QAC9C,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAE1B,sCAAsC;QACtC,IAAI,CAAC,2BAA2B,EAAE,CAAC;IACrC,CAAC;IAED;;;OAGG;IACK,2BAA2B;QACjC,MAAM,OAAO,GAAG,IAAI,iBAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,SAAS,CAAC,CAAC;QACxE,OAAO,CAAC,OAAO,CAAC,MAAM,sBAAa;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qCAgDF,IAAI,CAAC,KAAK,CAAC,WAAW,iBAAiB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,iBAAiB,IAAI,CAAC,KAAK,CAAC,WAAW;;;;;sCAKxH,IAAI,CAAC,KAAK,CAAC,WAAW,kBAAkB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,IAAI,CAAC,KAAK,CAAC,WAAW;;;;;;0CAMvH,IAAI,CAAC,KAAK,CAAC,WAAW,sBAAsB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,CAAC,kBAAkB,IAAI,CAAC,KAAK,CAAC,WAAW;;;;;;yCAMrI,IAAI,CAAC,KAAK,CAAC,WAAW,qBAAqB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,kBAAkB,IAAI,CAAC,KAAK,CAAC,WAAW;;;;CAI1K,CAAC,CAAC;IACD,CAAC;IAED;;;OAGG;IACK,kBAAkB;QACxB,iDAAiD;QACjD,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,gBAAgB,EAAE;YACrC,KAAK,EAAE;gBACL;oBACE,IAAI,EAAE,qBAAqB,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,0BAA0B;iBACzG;gBACD;oBACE,IAAI,EAAE,qBAAqB,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,2BAA2B;iBAC1G;aACF;SACF,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,EAAE;YAC3B,WAAW,EAAE,uCAAuC;YACpD,KAAK,EAAE;gBACL;oBACE,IAAI,EAAE,wBAAwB;iBAC/B;gBACD;oBACE,IAAI,EAAE,iBAAiB;iBACxB;aACF;SACF,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,uBAAuB,EAAE;YAC5C,KAAK,EAAE;gBACL;oBACE,IAAI,EAAE,sCAAsC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG;iBACvG;gBACD;oBACE,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM;oBAC9B,IAAI,EAAE,2CAA2C;iBAClD;gBACD;oBACE,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM;oBAC9B,IAAI,EAAE,aAAa;iBACpB;aACF;SACF,CAAC,CAAC;IACL,CAAC;IAED;;;OAGG;IACK,mBAAmB;QACzB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,iBAAiB,EAAE;YACtC,IAAI,EAAE,cAAc,IAAI,CAAC,KAAK,CAAC,WAAW,WAAW;SACtD,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,gBAAgB,EAAE;YACrC,IAAI,EAAE,gCAAgC,IAAI,CAAC,KAAK,CAAC,WAAW,WAAW;SACxE,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,eAAe,EAAE;YACpC,IAAI,EAAE,YAAY,IAAI,CAAC,KAAK,CAAC,WAAW,WAAW;SACpD,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,kBAAkB,EAAE;YACvC,IAAI,EAAE,eAAe,IAAI,CAAC,KAAK,CAAC,WAAW,WAAW;SACvD,CAAC,CAAC;IACL,CAAC;IAED;;;OAGG;IACK,kBAAkB;QACxB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,gBAAgB,EAAE;YACrC,IAAI,EAAE,yDAAyD,IAAI,CAAC,KAAK,CAAC,WAAW,UAAU;SAChG,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,cAAc,EAAE;YACnC,IAAI,EAAE,YAAY,IAAI,CAAC,KAAK,CAAC,WAAW,UAAU;SACnD,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,iBAAiB,EAAE;YACtC,IAAI,EAAE,eAAe,IAAI,CAAC,KAAK,CAAC,WAAW,UAAU;SACtD,CAAC,CAAC;IACL,CAAC;IAED;;;OAGG;IACK,mBAAmB,CAAC,SAAiB;QAC3C,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,UAAU,SAAS,EAAE,EAAE;YAC1C,IAAI,EAAE,aAAa,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,sDAAsD,IAAI,CAAC,KAAK,CAAC,WAAW,IAAI,SAAS,EAAE;SACxI,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,SAAS,EAAE,EAAE;YACxC,IAAI,EAAE,aAAa,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,SAAS,IAAI,CAAC,KAAK,CAAC,WAAW,IAAI,SAAS,EAAE;SAC3F,CAAC,CAAC;IACL,CAAC;;;;AA9MU,kCAAW","sourcesContent":["import { Component, TextFile, awscdk } from 'projen';\nimport { PROJEN_MARKER } from 'projen/lib/common';\n\n/**\n * The Environment interface is designed to hold AWS related information\n * for a specific deployment environment within your infrastructure.\n * Each environment requires a specific account and region for its resources.\n */\nexport interface Environment {\n  /**\n   * The AWS Account ID associated with the environment. It's important because\n   * different services or features could have distinct permissions and settings\n   * in different accounts.\n   */\n  readonly account: string;\n\n  /**\n   * The AWS Region for the environment. This determines where your resources\n   * are created and where your application will run. It can affect latency,\n   * availability, and pricing.\n   */\n  readonly region: string;\n}\n\n/**\n * The EnvironmentMap interface is used to maintain a mapping of different types\n * of environments used in the application. Each type of environment - personal,\n * feature, dev, and prod, represents a different stage of development or usage.\n */\nexport interface EnvironmentMap {\n  /**\n   * The personal environment is usually used for individual development and\n   * testing, allowing developers to freely test and experiment without\n   * affecting the shared development environment.\n   */\n  readonly personal: Environment;\n\n  /**\n   * The feature environment is typically used for developing specific features\n   * in isolation from the main codebase. This allows developers to work on\n   * individual features without impacting the stability of the dev or prod\n   * environments.\n   */\n  readonly feature: Environment;\n\n  /**\n   * The dev environment is a shared environment where developers integrate\n   * their feature changes. It represents the latest version of the application\n   * but may not be as stable as the production environment.\n   */\n  readonly dev: Environment;\n\n  /**\n   * The prod environment is where the live, user-facing application runs.\n   * It should be stable and only receive thoroughly tested changes.\n   */\n  readonly prod: Environment;\n}\n\n/**\n * The CDKPipelineOptions interface is designed to provide configuration\n * options for a CDK (Cloud Development Kit) pipeline. It allows the definition\n * of settings such as the stack prefix and package namespace to be used in the\n * AWS stack, along with the environments configuration to be used.\n */\nexport interface CDKPipelineOptions {\n  /**\n   * This field is used to define a prefix for the AWS Stack resources created\n   * during the pipeline's operation.\n   */\n  readonly stackPrefix: string;\n\n  /**\n   * This field determines the NPM namespace to be used when packaging CDK cloud\n   * assemblies. A namespace helps group related resources together, providing\n   * better organization and ease of management.\n   */\n  readonly pkgNamespace: string;\n\n  /**\n   * This is a map of environments to be used in the pipeline. It allows the\n   * pipeline to deploy to different environments based on the stage of the\n   * deployment process, whether that's a personal, feature, dev, or prod stage.\n   */\n  readonly environments: EnvironmentMap;\n}\n\n/**\n * The CDKPipeline class extends the Component class and sets up the necessary configuration for deploying AWS CDK (Cloud Development Kit) applications across multiple stages.\n * It also manages tasks such as publishing CDK assets, bumping version based on git tags, and cleaning up conflicting tasks.\n */\nexport class CDKPipeline extends Component {\n\n  constructor(private app: awscdk.AwsCdkTypeScriptApp, private props: CDKPipelineOptions) {\n    super(app);\n\n    // Add development dependencies\n    this.app.addDevDeps(\n      '@types/standard-version',\n      'standard-version',\n      'cdk-assets',\n    );\n    // this.app.addDeps(\n    // );\n\n    // Removes the compiled cloud assembly before each synth\n    this.project.tasks.tryFind('synth')?.prependExec(`rm -rf ${this.app.cdkConfig.cdkout}`);\n    this.project.tasks.tryFind('synth:silent')?.prependExec(`rm -rf ${this.app.cdkConfig.cdkout}`);\n\n    // Remove tasks that might conflict with the pipeline process\n    this.project.removeTask('deploy');\n    this.project.removeTask('diff');\n    this.project.removeTask('destroy');\n    this.project.removeTask('watch');\n\n    // Creates different deployment stages\n    this.createPersonalStage();\n    this.createFeatureStage();\n    this.createPipelineStage('dev');\n    this.createPipelineStage('prod');\n\n    // Creates tasks to handle the release process\n    this.createReleaseTasks();\n\n    // Creates a specialized CDK App class\n    this.createApplicationEntrypoint();\n  }\n\n  /**\n   * This method generates the entry point for the application, including interfaces and classes\n   * necessary to set up the pipeline and define the AWS CDK stacks for different environments.\n   */\n  private createApplicationEntrypoint() {\n    const appFile = new TextFile(this.project, `${this.app.srcdir}/app.ts`);\n    appFile.addLine(`// ${PROJEN_MARKER}\n/* eslint-disable object-curly-spacing */\n/* eslint-disable comma-spacing */\n/* eslint-disable quotes */\n/* eslint-disable key-spacing */\n/* eslint-disable quote-props */\nimport { App, AppProps, Stack, StackProps } from 'aws-cdk-lib';\n\n/**\n * PipelineAppProps is an extension of AppProps, which is part of the AWS CDK core.\n * It includes optional functions to provide AWS Stacks for different stages.\n * \n * Use these functions to instantiate your application stacks with the parameters for\n * each stage\n */\nexport interface PipelineAppProps extends AppProps {\n  /** This optional function, if provided, will be used to generate a development stack. */\n  provideDevStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;\n\n  /** This optional function, if provided, will be used to generate a production stack. */\n  provideProdStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;\n\n  /** This optional function, if provided, will be used to generate a personal stack. */\n  providePersonalStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;\n\n  /** This optional function, if provided, will be used to generate a feature stack. */\n  provideFeatureStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;\n}\n\n/**\n * PipelineAppStackProps is an extension of StackProps, which is part of the AWS CDK core.\n * It includes an additional property to specify the stage name.\n */\nexport interface PipelineAppStackProps extends StackProps {\n  stageName: string;\n}\n\n/**\n * The PipelineApp class extends the App class from AWS CDK and overrides the constructor to support\n * different stages of the application (development, production, personal, feature) by invoking the provided \n * stack-providing functions from the props.\n */\nexport class PipelineApp extends App {\n  constructor(props: PipelineAppProps) {\n    super(props);\n\n    // If a function is provided for creating a development stack, it is called with necessary arguments.\n    if (props.provideDevStack) {\n      props.provideDevStack(this, '${this.props.stackPrefix}-dev', { env: ${JSON.stringify(this.props.environments.dev)}, stackName: '${this.props.stackPrefix}-dev', stageName: 'dev' });\n    }\n\n    // If a function is provided for creating a production stack, it is called with necessary arguments.\n    if (props.provideProdStack) {\n      props.provideProdStack(this, '${this.props.stackPrefix}-prod', { env: ${JSON.stringify(this.props.environments.prod)}, stackName: '${this.props.stackPrefix}-prod', stageName: 'prod' });\n    }\n\n    // If the environment variable USER is set and a function is provided for creating a personal stack, it is called with necessary arguments.\n    if (props.providePersonalStack && process.env.USER) {\n      const stageName = 'personal-' + process.env.USER.toLowerCase().replace(/\\\\\\//g, '-');\n      props.providePersonalStack(this, '${this.props.stackPrefix}-personal', { env: ${JSON.stringify(this.props.environments.personal)}, stackName: \\`${this.props.stackPrefix}-\\${stageName}\\`, stageName });\n    }\n\n    // If the environment variable BRANCH is set and a function is provided for creating a feature stack, it is called with necessary arguments.\n    if (props.provideFeatureStack && process.env.BRANCH) {\n      const stageName = 'feature-' + process.env.BRANCH.toLowerCase().replace(/\\\\\\//g, '-');\n      props.provideFeatureStack(this, '${this.props.stackPrefix}-feature', { env: ${JSON.stringify(this.props.environments.feature)}, stackName: \\`${this.props.stackPrefix}-\\${stageName}\\`, stageName });\n    }\n  }\n}\n`);\n  }\n\n  /**\n   * This method sets up tasks to publish CDK assets to all accounts and handle versioning, including bumping the version\n   * based on the latest git tag and pushing the CDK assembly to the package repository.\n   */\n  private createReleaseTasks() {\n    // Task to publish the CDK assets to all accounts\n    this.project.addTask('publish:assets', {\n      steps: [\n        {\n          exec: `npx cdk-assets -p ${this.app.cdkConfig.cdkout}/${this.props.stackPrefix}-dev.assets.json publish`,\n        },\n        {\n          exec: `npx cdk-assets -p ${this.app.cdkConfig.cdkout}/${this.props.stackPrefix}-prod.assets.json publish`,\n        },\n      ],\n    });\n\n    this.project.addTask('bump', {\n      description: 'Bumps version based on latest git tag',\n      steps: [\n        {\n          exec: 'pipelines-release bump',\n        },\n        {\n          exec: 'git push --tags',\n        },\n      ],\n    });\n    this.project.addTask('release:push-assembly', {\n      steps: [\n        {\n          exec: `pipelines-release create-manifest \"${this.app.cdkConfig.cdkout}\"  \"${this.props.pkgNamespace}\"`,\n        },\n        {\n          cwd: this.app.cdkConfig.cdkout,\n          exec: 'npm version --no-git-tag-version from-git',\n        },\n        {\n          cwd: this.app.cdkConfig.cdkout,\n          exec: 'npm publish',\n        },\n      ],\n    });\n  }\n\n  /**\n   * This method sets up tasks for the personal deployment stage, including deployment, watching for changes,\n   * comparing changes (diff), and destroying the stack when no longer needed.\n   */\n  private createPersonalStage() {\n    this.project.addTask('deploy:personal', {\n      exec: `cdk deploy ${this.props.stackPrefix}-personal`,\n    });\n    this.project.addTask('watch:personal', {\n      exec: `cdk deploy --watch --hotswap ${this.props.stackPrefix}-personal`,\n    });\n    this.project.addTask('diff:personal', {\n      exec: `cdk diff ${this.props.stackPrefix}-personal`,\n    });\n    this.project.addTask('destroy:personal', {\n      exec: `cdk destroy ${this.props.stackPrefix}-personal`,\n    });\n  }\n\n  /**\n   * This method sets up tasks for the feature deployment stage, including deployment, comparing changes (diff),\n   * and destroying the stack when no longer needed.\n   */\n  private createFeatureStage() {\n    this.project.addTask('deploy:feature', {\n      exec: `cdk --progress events --require-approval never deploy ${this.props.stackPrefix}-feature`,\n    });\n    this.project.addTask('diff:feature', {\n      exec: `cdk diff ${this.props.stackPrefix}-feature`,\n    });\n    this.project.addTask('destroy:feature', {\n      exec: `cdk destroy ${this.props.stackPrefix}-feature`,\n    });\n  }\n\n  /**\n   * This method sets up tasks for the general pipeline stages (dev, prod), including deployment and comparing changes (diff).\n   * @param {string} stageName - The name of the stage (e.g., 'dev', 'prod')\n   */\n  private createPipelineStage(stageName: string) {\n    this.project.addTask(`deploy:${stageName}`, {\n      exec: `cdk --app ${this.app.cdkConfig.cdkout} --progress events --require-approval never deploy ${this.props.stackPrefix}-${stageName}`,\n    });\n    this.project.addTask(`diff:${stageName}`, {\n      exec: `cdk --app ${this.app.cdkConfig.cdkout} diff ${this.props.stackPrefix}-${stageName}`,\n    });\n  }\n}"]}
263
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline.js","sourceRoot":"","sources":["../src/pipeline.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, TextFile, awscdk } from 'projen';\nimport { PROJEN_MARKER } from 'projen/lib/common';\nimport { BaseEngine, GitHubEngine, GithubEngineConfig } from './engine';\n\n/**\n * The Environment interface is designed to hold AWS related information\n * for a specific deployment environment within your infrastructure.\n * Each environment requires a specific account and region for its resources.\n */\nexport interface Environment {\n  /**\n   * The AWS Account ID associated with the environment. It's important because\n   * different services or features could have distinct permissions and settings\n   * in different accounts.\n   */\n  readonly account: string;\n\n  /**\n   * The AWS Region for the environment. This determines where your resources\n   * are created and where your application will run. It can affect latency,\n   * availability, and pricing.\n   */\n  readonly region: string;\n}\n\n/**\n * The EnvironmentMap interface is used to maintain a mapping of different types\n * of environments used in the application. Each type of environment - personal,\n * feature, dev, and prod, represents a different stage of development or usage.\n */\nexport interface EnvironmentMap {\n  /**\n   * The personal environment is usually used for individual development and\n   * testing, allowing developers to freely test and experiment without\n   * affecting the shared development environment.\n   */\n  readonly personal: Environment;\n\n  /**\n   * The feature environment is typically used for developing specific features\n   * in isolation from the main codebase. This allows developers to work on\n   * individual features without impacting the stability of the dev or prod\n   * environments.\n   */\n  readonly feature: Environment;\n\n  /**\n   * The dev environment is a shared environment where developers integrate\n   * their feature changes. It represents the latest version of the application\n   * but may not be as stable as the production environment.\n   */\n  readonly dev: Environment;\n\n  /**\n   * The prod environment is where the live, user-facing application runs.\n   * It should be stable and only receive thoroughly tested changes.\n   */\n  readonly prod: Environment;\n}\n\n/**\n * The CI/CD tooling used to run your pipeline.\n * The component will render workflows for the given system\n */\nexport enum PipelineEngine {\n  /** Create GitHub actions */\n  GITHUB,\n  /** Create a .gitlab-ci.yaml file */\n  GITLAB,\n  // /** Create AWS CodeCatalyst workflows */\n  // CODE_CATALYST,\n}\n\n/**\n * Describes the type of pipeline that will be created\n */\nexport enum DeploymentType {\n  /** Deploy every commit as far as possible; hopefully into production */\n  CONTINUOUS_DEPLOYMENT,\n  /** Build every commit and prepare all assets for a later deployment */\n  CONTINUOUS_DELIVERY,\n}\n\n/**\n * The CDKPipelineOptions interface is designed to provide configuration\n * options for a CDK (Cloud Development Kit) pipeline. It allows the definition\n * of settings such as the stack prefix and package namespace to be used in the\n * AWS stack, along with the environments configuration to be used.\n */\nexport interface CDKPipelineOptions {\n\n  /**\n   * This field is used to define a prefix for the AWS Stack resources created\n   * during the pipeline's operation.\n   *\n   * @default project name\n   */\n  readonly stackPrefix?: string;\n\n  /**\n   * This field determines the NPM namespace to be used when packaging CDK cloud\n   * assemblies. A namespace helps group related resources together, providing\n   * better organization and ease of management.\n   */\n  readonly pkgNamespace: string;\n\n  /**\n   * This is a map of environments to be used in the pipeline. It allows the\n   * pipeline to deploy to different environments based on the stage of the\n   * deployment process, whether that's a personal, feature, dev, or prod stage.\n   */\n  readonly environments: EnvironmentMap;\n\n  /**\n   * This field specifies the type of pipeline to create. If set to CONTINUOUS_DEPLOYMENT,\n   * every commit is deployed as far as possible, hopefully into production. If set to\n   * CONTINUOUS_DELIVERY, every commit is built and all assets are prepared for a later deployment.\n   *\n   * @default CONTINUOUS_DELIVERY\n   */\n  readonly deploymentType?: DeploymentType;\n\n  /**\n   * This field determines the CI/CD tooling that will be used to run the pipeline. The component\n   * will render workflows for the given system. Options include GitHub and GitLab.\n   *\n   * @default - tries to derive it from the projects configuration\n   */\n  readonly engine?: PipelineEngine;\n\n  readonly githubConfig?: GithubEngineConfig;\n\n  readonly preInstallCommands?: string[];\n  readonly preSynthCommands?: string[];\n  readonly postSynthCommands?: string[];\n\n}\n\n/**\n * The CDKPipeline class extends the Component class and sets up the necessary configuration for deploying AWS CDK (Cloud Development Kit) applications across multiple stages.\n * It also manages tasks such as publishing CDK assets, bumping version based on git tags, and cleaning up conflicting tasks.\n */\nexport class CDKPipeline extends Component {\n\n  public readonly stackPrefix: string;\n  public readonly engine: BaseEngine;\n\n  constructor(private app: awscdk.AwsCdkTypeScriptApp, private props: CDKPipelineOptions) {\n    super(app);\n\n    // Add development dependencies\n    this.app.addDevDeps(\n      '@types/standard-version',\n      'standard-version',\n      'cdk-assets',\n    );\n    // this.app.addDeps(\n    // );\n\n    this.stackPrefix = props.stackPrefix ?? app.name;\n\n    // Create engine instance to use\n    switch (props.engine) {\n      case PipelineEngine.GITHUB:\n        this.engine = new GitHubEngine(app, props, this);\n        break;\n      default:\n        throw new Error('Invalid engine');\n    }\n\n    // Removes the compiled cloud assembly before each synth\n    this.project.tasks.tryFind('synth')?.prependExec(`rm -rf ${this.app.cdkConfig.cdkout}`);\n    this.project.tasks.tryFind('synth:silent')?.prependExec(`rm -rf ${this.app.cdkConfig.cdkout}`);\n\n    // Remove tasks that might conflict with the pipeline process\n    this.project.removeTask('deploy');\n    this.project.removeTask('diff');\n    this.project.removeTask('destroy');\n    this.project.removeTask('watch');\n\n    this.createSynthStage();\n\n    // Creates different deployment stages\n    this.createPersonalStage();\n    this.createFeatureStage();\n    this.createPipelineStage('dev');\n    this.createPipelineStage('prod');\n\n    // Creates tasks to handle the release process\n    this.createReleaseTasks();\n\n    // Creates a specialized CDK App class\n    this.createApplicationEntrypoint();\n\n  }\n\n  private createSynthStage() {\n    this.engine.createSynth({\n      commands: [\n        ...(this.props.preInstallCommands ?? []),\n        `npx projen ${this.app.package.installCiTask.name}`,\n        ...(this.props.preSynthCommands ?? []),\n        'npx projen build',\n        ...(this.props.postSynthCommands ?? []),\n      ],\n    });\n    this.engine.createAssetUpload({\n      commands: [\n        ...(this.props.preInstallCommands ?? []),\n        `npx projen ${this.app.package.installCiTask.name}`,\n        'npx projen publish:assets',\n      ],\n    });\n  }\n\n  /**\n   * This method generates the entry point for the application, including interfaces and classes\n   * necessary to set up the pipeline and define the AWS CDK stacks for different environments.\n   */\n  private createApplicationEntrypoint() {\n    const appFile = new TextFile(this.project, `${this.app.srcdir}/app.ts`);\n    appFile.addLine(`// ${PROJEN_MARKER}\n/* eslint-disable */\nimport { App, AppProps, Stack, StackProps } from 'aws-cdk-lib';\n\n/**\n * PipelineAppProps is an extension of AppProps, which is part of the AWS CDK core.\n * It includes optional functions to provide AWS Stacks for different stages.\n *\n * Use these functions to instantiate your application stacks with the parameters for\n * each stage\n */\nexport interface PipelineAppProps extends AppProps {\n  /** This optional function, if provided, will be used to generate a development stack. */\n  provideDevStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;\n\n  /** This optional function, if provided, will be used to generate a production stack. */\n  provideProdStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;\n\n  /** This optional function, if provided, will be used to generate a personal stack. */\n  providePersonalStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;\n\n  /** This optional function, if provided, will be used to generate a feature stack. */\n  provideFeatureStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;\n}\n\n/**\n * PipelineAppStackProps is an extension of StackProps, which is part of the AWS CDK core.\n * It includes an additional property to specify the stage name.\n */\nexport interface PipelineAppStackProps extends StackProps {\n  stageName: string;\n}\n\n/**\n * The PipelineApp class extends the App class from AWS CDK and overrides the constructor to support\n * different stages of the application (development, production, personal, feature) by invoking the provided\n * stack-providing functions from the props.\n */\nexport class PipelineApp extends App {\n  constructor(props: PipelineAppProps) {\n    super(props);\n\n    // If a function is provided for creating a development stack, it is called with necessary arguments.\n    if (props.provideDevStack) {\n      props.provideDevStack(this, '${this.stackPrefix}-dev', { env: ${JSON.stringify(this.props.environments.dev)}, stackName: '${this.stackPrefix}-dev', stageName: 'dev' });\n    }\n\n    // If a function is provided for creating a production stack, it is called with necessary arguments.\n    if (props.provideProdStack) {\n      props.provideProdStack(this, '${this.stackPrefix}-prod', { env: ${JSON.stringify(this.props.environments.prod)}, stackName: '${this.stackPrefix}-prod', stageName: 'prod' });\n    }\n\n    // If the environment variable USER is set and a function is provided for creating a personal stack, it is called with necessary arguments.\n    if (props.providePersonalStack && process.env.USER) {\n      const stageName = 'personal-' + process.env.USER.toLowerCase().replace(/\\\\\\//g, '-');\n      props.providePersonalStack(this, '${this.stackPrefix}-personal', { env: ${JSON.stringify(this.props.environments.personal)}, stackName: \\`${this.stackPrefix}-\\${stageName}\\`, stageName });\n    }\n\n    // If the environment variable BRANCH is set and a function is provided for creating a feature stack, it is called with necessary arguments.\n    if (props.provideFeatureStack && process.env.BRANCH) {\n      const stageName = 'feature-' + process.env.BRANCH.toLowerCase().replace(/\\\\\\//g, '-');\n      props.provideFeatureStack(this, '${this.stackPrefix}-feature', { env: ${JSON.stringify(this.props.environments.feature)}, stackName: \\`${this.stackPrefix}-\\${stageName}\\`, stageName });\n    }\n  }\n}\n`);\n  }\n\n  /**\n   * This method sets up tasks to publish CDK assets to all accounts and handle versioning, including bumping the version\n   * based on the latest git tag and pushing the CDK assembly to the package repository.\n   */\n  private createReleaseTasks() {\n    // Task to publish the CDK assets to all accounts\n    this.project.addTask('publish:assets', {\n      steps: [\n        {\n          exec: `npx cdk-assets -p ${this.app.cdkConfig.cdkout}/${this.stackPrefix}-dev.assets.json publish`,\n        },\n        {\n          exec: `npx cdk-assets -p ${this.app.cdkConfig.cdkout}/${this.stackPrefix}-prod.assets.json publish`,\n        },\n      ],\n    });\n\n    this.project.addTask('bump', {\n      description: 'Bumps version based on latest git tag',\n      steps: [\n        {\n          exec: 'pipelines-release bump',\n        },\n        {\n          exec: 'git push --tags',\n        },\n      ],\n    });\n    this.project.addTask('release:push-assembly', {\n      steps: [\n        {\n          exec: `pipelines-release create-manifest \"${this.app.cdkConfig.cdkout}\"  \"${this.props.pkgNamespace}\"`,\n        },\n        {\n          cwd: this.app.cdkConfig.cdkout,\n          exec: 'npm version --no-git-tag-version from-git',\n        },\n        {\n          cwd: this.app.cdkConfig.cdkout,\n          exec: 'npm publish',\n        },\n      ],\n    });\n  }\n\n  /**\n   * This method sets up tasks for the personal deployment stage, including deployment, watching for changes,\n   * comparing changes (diff), and destroying the stack when no longer needed.\n   */\n  private createPersonalStage() {\n    this.project.addTask('deploy:personal', {\n      exec: `cdk deploy ${this.stackPrefix}-personal`,\n    });\n    this.project.addTask('watch:personal', {\n      exec: `cdk deploy --watch --hotswap ${this.stackPrefix}-personal`,\n    });\n    this.project.addTask('diff:personal', {\n      exec: `cdk diff ${this.stackPrefix}-personal`,\n    });\n    this.project.addTask('destroy:personal', {\n      exec: `cdk destroy ${this.stackPrefix}-personal`,\n    });\n  }\n\n  /**\n   * This method sets up tasks for the feature deployment stage, including deployment, comparing changes (diff),\n   * and destroying the stack when no longer needed.\n   */\n  private createFeatureStage() {\n    this.project.addTask('deploy:feature', {\n      exec: `cdk --progress events --require-approval never deploy ${this.stackPrefix}-feature`,\n    });\n    this.project.addTask('diff:feature', {\n      exec: `cdk diff ${this.stackPrefix}-feature`,\n    });\n    this.project.addTask('destroy:feature', {\n      exec: `cdk destroy ${this.stackPrefix}-feature`,\n    });\n  }\n\n  /**\n   * This method sets up tasks for the general pipeline stages (dev, prod), including deployment and comparing changes (diff).\n   * @param {string} stageName - The name of the stage (e.g., 'dev', 'prod')\n   */\n  private createPipelineStage(stageName: string) {\n    this.project.addTask(`deploy:${stageName}`, {\n      exec: `cdk --app ${this.app.cdkConfig.cdkout} --progress events --require-approval never deploy ${this.stackPrefix}-${stageName}`,\n    });\n    this.project.addTask(`diff:${stageName}`, {\n      exec: `cdk --app ${this.app.cdkConfig.cdkout} diff ${this.stackPrefix}-${stageName}`,\n    });\n\n    this.engine.createDeployment({\n      stageName,\n      env: this.props.environments[stageName as keyof EnvironmentMap],\n      commands: [\n        `npx projen deploy:${stageName}`,\n      ],\n    });\n  }\n}"]}
package/package.json CHANGED
@@ -73,7 +73,7 @@
73
73
  ],
74
74
  "main": "lib/index.js",
75
75
  "license": "Apache-2.0",
76
- "version": "0.0.2",
76
+ "version": "0.0.3",
77
77
  "jest": {
78
78
  "testMatch": [
79
79
  "<rootDir>/src/**/__tests__/**/*.ts?(x)",