projen-pipelines 0.0.1 → 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.
package/README.md CHANGED
@@ -1 +1,154 @@
1
- # replace this
1
+ # Projen Pipelines
2
+
3
+ [![npm version](https://badge.fury.io/js/projen-pipelines.svg)](https://www.npmjs.com/package/projen-pipelines)
4
+
5
+
6
+ Projen Pipelines is a projen library that provides high-level abstractions for defining continuous delivery (CD) pipelines for AWS CDK applications.
7
+ It is specifically designed to work with the projen project configuration engine.
8
+
9
+ This library provides high-level abstractions for defining multi-environment and multi-account AWS CDK applications with ease.
10
+ With this library, you can handle complex deployment scenarios with less code and manage your AWS infrastructure in a more efficient and straightforward way.
11
+
12
+ ## Getting Started
13
+
14
+ ### Installation
15
+
16
+ To install the package, add the package `projen-pipelines` to your projects devDeps in your projen configuration file.
17
+
18
+
19
+ After installing the package, you can import and use the constructs to define your CDK Pipelines.
20
+
21
+ ### Usage
22
+
23
+ You can start using the constructs provided by Projen Pipelines in your AWS CDK applications. Here's a brief example:
24
+
25
+ ```typescript
26
+ import { awscdk } from 'projen';
27
+ import { CDKPipeline, CDKPipelineOptions } from 'projen-pipelines';
28
+
29
+ // Define your AWS CDK TypeScript App
30
+ const app = new awscdk.AwsCdkTypeScriptApp({
31
+ cdkVersion: '2.80.0',
32
+ name: 'my-awesome-app',
33
+ defaultReleaseBranch: 'main',
34
+ devDeps: [
35
+ 'projen-pipelines',
36
+ ],
37
+ });
38
+
39
+ // Create the pipeline
40
+ new CDKPipeline(app, {
41
+ stackPrefix: 'MyApp',
42
+ pkgNamespace: '@company-assemblies',
43
+ environments: {
44
+ dev: { account: '111111111111', region: 'eu-central-1' },
45
+ prod: { account: '222222222222', region: 'eu-central-1' },
46
+ },
47
+ });
48
+ ```
49
+
50
+ After running projen (`npx projen`) a new file called `src/app.ts` will be created and contain a specialized CDK App class for your project.
51
+
52
+ You can then use this in your `main.ts` to configure your deployment.
53
+
54
+ ```typescript
55
+ import { PipelineApp } from './app';
56
+ import { BackendStack } from './stack';
57
+
58
+ const app = new PipelineApp({
59
+ provideDevStack: (scope, id, props) => {
60
+ return new BackendStack(scope, id, {
61
+ ...props,
62
+ apiHostname: 'api-dev',
63
+ myConfigSetting: 'value-for-dev',
64
+ });
65
+ },
66
+ provideProdStack: (scope, id, props) => {
67
+ return new BackendStack(scope, id, {
68
+ ...props,
69
+ apiHostname: 'api',
70
+ myConfigSetting: 'value-for-prod',
71
+ });
72
+ },
73
+ providePersonalStack: (scope, id, props) => {
74
+ return new BackendStack(scope, id, {
75
+ ...props,
76
+ apiHostname: `api-${props.stageName}`,
77
+ myConfigSetting: 'value-for-personal-stage',
78
+ });
79
+ },
80
+ });
81
+
82
+ app.synth();
83
+ ```
84
+
85
+ ### Deployment
86
+
87
+ The `CDKPipeline` class creates and adds several tasks to the projen project that then can be used in your pipeline to deploy your application to AWS.
88
+
89
+ Here's a brief description of each one:
90
+
91
+ 1. **deploy:personal** - This task deploys the application's personal stage, which is a distinct, isolated deployment of the application. The personal stage is intended for personal use, such as testing and development.
92
+
93
+ 2. **watch:personal** - This task deploys the personal stage of the application in watch mode. In this mode, the AWS CDK monitors your application source files for changes, automatically re-synthesizing and deploying when it detects any changes.
94
+
95
+ 3. **diff:personal** - This task compares the deployed personal stage with the current state of the application code. It's used to understand what changes would be made if the application were deployed.
96
+
97
+ 4. **destroy:personal** - This task destroys the resources created for the personal stage of the application.
98
+
99
+ 5. **deploy:feature** - This task deploys the application's feature stage. The feature stage is used for new features testing before these are merged into the main branch.
100
+
101
+ 6. **diff:feature** - This task is similar to `diff:personal`, but for the feature stage.
102
+
103
+ 7. **destroy:feature** - This task destroys the resources created for the feature stage of the application.
104
+
105
+ 8. **deploy:<stageName>** - This task deploys a specific stage of the application (like 'dev' or 'prod').
106
+
107
+ 9. **diff:<stageName>** - This task compares the specified application stage with the current state of the application code.
108
+
109
+ 10. **publish:assets** - This task publishes the CDK assets to all accounts. This is useful when the CDK application uses assets like Docker images or files from the S3 bucket.
110
+
111
+ 11. **bump** - This task bumps the version based on the latest git tag and pushes the updated tag to the git repository.
112
+
113
+ 12. **release:push-assembly** - This task creates a manifest, bumps the version without creating a git tag, and publishes the cloud assembly to your registry.
114
+
115
+ Remember that these tasks are created and managed automatically by the `CDKPipeline` class. You can run these tasks using the `npx projen TASK_NAME` command.
116
+
117
+
118
+ ## Contributing
119
+
120
+ We welcome all contributions to Projen Pipelines! Here's how you can get started:
121
+
122
+ 1. **Fork the Repository**: Click the 'Fork' button at the top right of this page to duplicate this repository in your GitHub account.
123
+
124
+ 2. **Clone your Fork**: Clone the forked repository to your local machine.
125
+
126
+ ```bash
127
+ git clone https://github.com/<your_username>/projen-pipelines.git
128
+ ```
129
+
130
+ 3. **Create a Branch**: To keep your work organized, create a branch for your contribution.
131
+
132
+ ```bash
133
+ git checkout -b my-branch
134
+ ```
135
+
136
+ 4. **Make your Changes**: Make your changes, additions, or fixes to the codebase. Remember to follow the existing code style.
137
+
138
+ 5. **Test your Changes**: Before committing your changes, make sure to test them to ensure they work as expected and do not introduce bugs.
139
+
140
+ 6. **Commit your Changes**: Commit your changes with a descriptive commit message using conventional commit messages.
141
+
142
+ ```bash
143
+ git commit -m "feat: Your descriptive commit message"
144
+ ```
145
+
146
+ 7. **Push to your Fork**: Push your commits to the branch in your forked repository.
147
+
148
+ ```bash
149
+ git push origin my-branch
150
+ ```
151
+
152
+ 8. **Submit a Pull Request**: Once your changes are ready to be reviewed, create a pull request from your forked repository's branch into the `main` branch of this repository.
153
+
154
+ Your pull request will be reviewed and hopefully merged quickly. Thanks for contributing!
@@ -0,0 +1,22 @@
1
+ import { awscdk } from 'projen';
2
+ import { CDKPipeline, CDKPipelineOptions, Environment } from '../pipeline';
3
+ export interface SynthStageOptions {
4
+ readonly commands: string[];
5
+ }
6
+ export interface AssetUploadStageOptions {
7
+ readonly commands: string[];
8
+ }
9
+ export interface DeployStageOptions {
10
+ readonly stageName: string;
11
+ readonly commands: string[];
12
+ readonly env: Environment;
13
+ }
14
+ export declare abstract class BaseEngine {
15
+ protected app: awscdk.AwsCdkTypeScriptApp;
16
+ protected props: CDKPipelineOptions;
17
+ protected pipeline: CDKPipeline;
18
+ constructor(app: awscdk.AwsCdkTypeScriptApp, props: CDKPipelineOptions, pipeline: CDKPipeline);
19
+ abstract createSynth(options: SynthStageOptions): void;
20
+ abstract createAssetUpload(options: AssetUploadStageOptions): void;
21
+ abstract createDeployment(options: DeployStageOptions): void;
22
+ }
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.BaseEngine = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ class BaseEngine {
7
+ constructor(app, props, pipeline) {
8
+ this.app = app;
9
+ this.props = props;
10
+ this.pipeline = pipeline;
11
+ }
12
+ }
13
+ _a = JSII_RTTI_SYMBOL_1;
14
+ BaseEngine[_a] = { fqn: "projen-pipelines.BaseEngine", version: "0.0.3" };
15
+ exports.BaseEngine = BaseEngine;
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9lbmdpbmUvYmFzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQWlCQSxNQUFzQixVQUFVO0lBQzlCLFlBQXNCLEdBQStCLEVBQVksS0FBeUIsRUFBWSxRQUFxQjtRQUFyRyxRQUFHLEdBQUgsR0FBRyxDQUE0QjtRQUFZLFVBQUssR0FBTCxLQUFLLENBQW9CO1FBQVksYUFBUSxHQUFSLFFBQVEsQ0FBYTtJQUczSCxDQUFDOzs7O0FBSm1CLGdDQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYXdzY2RrIH0gZnJvbSAncHJvamVuJztcbmltcG9ydCB7IENES1BpcGVsaW5lLCBDREtQaXBlbGluZU9wdGlvbnMsIEVudmlyb25tZW50IH0gZnJvbSAnLi4vcGlwZWxpbmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN5bnRoU3RhZ2VPcHRpb25zIHtcbiAgcmVhZG9ubHkgY29tbWFuZHM6IHN0cmluZ1tdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFzc2V0VXBsb2FkU3RhZ2VPcHRpb25zIHtcbiAgcmVhZG9ubHkgY29tbWFuZHM6IHN0cmluZ1tdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERlcGxveVN0YWdlT3B0aW9ucyB7XG4gIHJlYWRvbmx5IHN0YWdlTmFtZTogc3RyaW5nO1xuICByZWFkb25seSBjb21tYW5kczogc3RyaW5nW107XG4gIHJlYWRvbmx5IGVudjogRW52aXJvbm1lbnQ7XG59XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBCYXNlRW5naW5lIHtcbiAgY29uc3RydWN0b3IocHJvdGVjdGVkIGFwcDogYXdzY2RrLkF3c0Nka1R5cGVTY3JpcHRBcHAsIHByb3RlY3RlZCBwcm9wczogQ0RLUGlwZWxpbmVPcHRpb25zLCBwcm90ZWN0ZWQgcGlwZWxpbmU6IENES1BpcGVsaW5lKSB7XG5cblxuICB9XG5cbiAgYWJzdHJhY3QgY3JlYXRlU3ludGgob3B0aW9uczogU3ludGhTdGFnZU9wdGlvbnMpOiB2b2lkO1xuICBhYnN0cmFjdCBjcmVhdGVBc3NldFVwbG9hZChvcHRpb25zOiBBc3NldFVwbG9hZFN0YWdlT3B0aW9ucyk6IHZvaWQ7XG4gIGFic3RyYWN0IGNyZWF0ZURlcGxveW1lbnQob3B0aW9uczogRGVwbG95U3RhZ2VPcHRpb25zKTogdm9pZDtcblxufSJdfQ==
@@ -0,0 +1,22 @@
1
+ import { awscdk } from 'projen';
2
+ import { AssetUploadStageOptions, BaseEngine, DeployStageOptions, SynthStageOptions } from './base';
3
+ import { CDKPipeline, CDKPipelineOptions } from '../pipeline';
4
+ export interface RoleMap {
5
+ readonly feature?: string;
6
+ readonly dev?: string;
7
+ readonly prod?: string;
8
+ }
9
+ export interface GithubEngineConfig {
10
+ readonly defaultAwsRoleArn?: string;
11
+ readonly awsRoleArnForSynth?: string;
12
+ readonly awsRoleArnForAssetPublishing?: string;
13
+ readonly awsRoleArnForDeployment?: RoleMap;
14
+ }
15
+ export declare class GitHubEngine extends BaseEngine {
16
+ private deploymentWorkflow;
17
+ private deploymentStages;
18
+ constructor(app: awscdk.AwsCdkTypeScriptApp, props: CDKPipelineOptions, pipeline: CDKPipeline);
19
+ createSynth(options: SynthStageOptions): void;
20
+ createAssetUpload(options: AssetUploadStageOptions): void;
21
+ createDeployment(options: DeployStageOptions): void;
22
+ }
@@ -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,26 +1,154 @@
1
1
  import { Component, awscdk } from 'projen';
2
+ import { BaseEngine, GithubEngineConfig } from './engine';
3
+ /**
4
+ * The Environment interface is designed to hold AWS related information
5
+ * for a specific deployment environment within your infrastructure.
6
+ * Each environment requires a specific account and region for its resources.
7
+ */
2
8
  export interface Environment {
9
+ /**
10
+ * The AWS Account ID associated with the environment. It's important because
11
+ * different services or features could have distinct permissions and settings
12
+ * in different accounts.
13
+ */
3
14
  readonly account: string;
15
+ /**
16
+ * The AWS Region for the environment. This determines where your resources
17
+ * are created and where your application will run. It can affect latency,
18
+ * availability, and pricing.
19
+ */
4
20
  readonly region: string;
5
21
  }
22
+ /**
23
+ * The EnvironmentMap interface is used to maintain a mapping of different types
24
+ * of environments used in the application. Each type of environment - personal,
25
+ * feature, dev, and prod, represents a different stage of development or usage.
26
+ */
6
27
  export interface EnvironmentMap {
28
+ /**
29
+ * The personal environment is usually used for individual development and
30
+ * testing, allowing developers to freely test and experiment without
31
+ * affecting the shared development environment.
32
+ */
7
33
  readonly personal: Environment;
34
+ /**
35
+ * The feature environment is typically used for developing specific features
36
+ * in isolation from the main codebase. This allows developers to work on
37
+ * individual features without impacting the stability of the dev or prod
38
+ * environments.
39
+ */
8
40
  readonly feature: Environment;
41
+ /**
42
+ * The dev environment is a shared environment where developers integrate
43
+ * their feature changes. It represents the latest version of the application
44
+ * but may not be as stable as the production environment.
45
+ */
9
46
  readonly dev: Environment;
47
+ /**
48
+ * The prod environment is where the live, user-facing application runs.
49
+ * It should be stable and only receive thoroughly tested changes.
50
+ */
10
51
  readonly prod: Environment;
11
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
+ }
72
+ /**
73
+ * The CDKPipelineOptions interface is designed to provide configuration
74
+ * options for a CDK (Cloud Development Kit) pipeline. It allows the definition
75
+ * of settings such as the stack prefix and package namespace to be used in the
76
+ * AWS stack, along with the environments configuration to be used.
77
+ */
12
78
  export interface CDKPipelineOptions {
13
- readonly stackPrefix: string;
79
+ /**
80
+ * This field is used to define a prefix for the AWS Stack resources created
81
+ * during the pipeline's operation.
82
+ *
83
+ * @default project name
84
+ */
85
+ readonly stackPrefix?: string;
86
+ /**
87
+ * This field determines the NPM namespace to be used when packaging CDK cloud
88
+ * assemblies. A namespace helps group related resources together, providing
89
+ * better organization and ease of management.
90
+ */
14
91
  readonly pkgNamespace: string;
92
+ /**
93
+ * This is a map of environments to be used in the pipeline. It allows the
94
+ * pipeline to deploy to different environments based on the stage of the
95
+ * deployment process, whether that's a personal, feature, dev, or prod stage.
96
+ */
15
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[];
16
117
  }
118
+ /**
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.
120
+ * It also manages tasks such as publishing CDK assets, bumping version based on git tags, and cleaning up conflicting tasks.
121
+ */
17
122
  export declare class CDKPipeline extends Component {
18
123
  private app;
19
124
  private props;
125
+ readonly stackPrefix: string;
126
+ readonly engine: BaseEngine;
20
127
  constructor(app: awscdk.AwsCdkTypeScriptApp, props: CDKPipelineOptions);
128
+ private createSynthStage;
129
+ /**
130
+ * This method generates the entry point for the application, including interfaces and classes
131
+ * necessary to set up the pipeline and define the AWS CDK stacks for different environments.
132
+ */
21
133
  private createApplicationEntrypoint;
134
+ /**
135
+ * This method sets up tasks to publish CDK assets to all accounts and handle versioning, including bumping the version
136
+ * based on the latest git tag and pushing the CDK assembly to the package repository.
137
+ */
22
138
  private createReleaseTasks;
139
+ /**
140
+ * This method sets up tasks for the personal deployment stage, including deployment, watching for changes,
141
+ * comparing changes (diff), and destroying the stack when no longer needed.
142
+ */
23
143
  private createPersonalStage;
144
+ /**
145
+ * This method sets up tasks for the feature deployment stage, including deployment, comparing changes (diff),
146
+ * and destroying the stack when no longer needed.
147
+ */
24
148
  private createFeatureStage;
149
+ /**
150
+ * This method sets up tasks for the general pipeline stages (dev, prod), including deployment and comparing changes (diff).
151
+ * @param {string} stageName - The name of the stage (e.g., 'dev', 'prod')
152
+ */
25
153
  private createPipelineStage;
26
154
  }