projen-pipelines 0.0.1 → 0.0.2

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/.jsii CHANGED
@@ -73,7 +73,7 @@
73
73
  },
74
74
  "name": "projen-pipelines",
75
75
  "readme": {
76
- "markdown": "# replace this"
76
+ "markdown": "# Projen Pipelines\n\n[![npm version](https://badge.fury.io/js/projen-pipelines.svg)](https://www.npmjs.com/package/projen-pipelines)\n\n\nProjen Pipelines is a projen library that provides high-level abstractions for defining continuous delivery (CD) pipelines for AWS CDK applications.\nIt is specifically designed to work with the projen project configuration engine.\n\nThis library provides high-level abstractions for defining multi-environment and multi-account AWS CDK applications with ease.\nWith this library, you can handle complex deployment scenarios with less code and manage your AWS infrastructure in a more efficient and straightforward way.\n\n## Getting Started\n\n### Installation\n\nTo install the package, add teh package `projen-pipelines` to your projects devDeps in your projen configuration file.\n\n\nAfter installing the package, you can import and use the constructs to define your CDK Pipelines.\n\n### Usage\n\nYou can start using the constructs provided by Projen Pipelines in your AWS CDK applications. Here's a brief example:\n\n```typescript\nimport { awscdk } from 'projen';\nimport { CDKPipeline, CDKPipelineOptions } from 'projen-pipelines';\n\n// Define your AWS CDK TypeScript App\nconst app = new awscdk.AwsCdkTypeScriptApp({\n cdkVersion: '2.80.0',\n name: 'my-awesome-app',\n defaultReleaseBranch: 'main',\n devDeps: [\n 'projen-pipelines',\n ],\n});\n\n// Create the pipeline\nnew CDKPipeline(app, {\n stackPrefix: 'MyApp',\n pkgNamespace: '@company-assemblies',\n environments: {\n dev: { account: '111111111111', region: 'eu-central-1' },\n prod: { account: '222222222222', region: 'eu-central-1' },\n },\n});\n```\n\nAfter running projen (`npx projen`) a new file called `src/app.ts` will be created and contain a specialized CDK App class for your project.\n\nYou can then use this in your `main.ts` to configure your deployment.\n\n```typescript\nimport { PipelineApp } from './app';\nimport { BackendStack } from './stack';\n\nconst app = new PipelineApp({\n provideDevStack: (scope, id, props) => {\n return new BackendStack(scope, id, {\n ...props,\n apiHostname: 'api-dev',\n myConfigSetting: 'value-for-dev',\n });\n },\n provideProdStack: (scope, id, props) => {\n return new BackendStack(scope, id, {\n ...props,\n apiHostname: 'api',\n myConfigSetting: 'value-for-prod',\n });\n },\n providePersonalStack: (scope, id, props) => {\n return new BackendStack(scope, id, {\n ...props,\n apiHostname: `api-${props.stageName}`,\n myConfigSetting: 'value-for-personal-stage',\n });\n },\n});\n\napp.synth();\n```\n\n### Deployment\n\nThe `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.\n\nHere's a brief description of each one:\n\n1. **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.\n\n2. **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.\n\n3. **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.\n\n4. **destroy:personal** - This task destroys the resources created for the personal stage of the application.\n\n5. **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.\n\n6. **diff:feature** - This task is similar to `diff:personal`, but for the feature stage.\n\n7. **destroy:feature** - This task destroys the resources created for the feature stage of the application.\n\n8. **deploy:<stageName>** - This task deploys a specific stage of the application (like 'dev' or 'prod').\n\n9. **diff:<stageName>** - This task compares the specified application stage with the current state of the application code.\n\n10. **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.\n\n11. **bump** - This task bumps the version based on the latest git tag and pushes the updated tag to the git repository.\n\n12. **release:push-assembly** - This task creates a manifest, bumps the version without creating a git tag, and publishes the cloud assembly to your registry.\n\nRemember that these tasks are created and managed automatically by the `CDKPipeline` class. You can run these tasks using the `npx projen TASK_NAME` command.\n\n\n## Contributing\n\nWe welcome all contributions to Projen Pipelines! Here's how you can get started:\n\n1. **Fork the Repository**: Click the 'Fork' button at the top right of this page to duplicate this repository in your GitHub account.\n\n2. **Clone your Fork**: Clone the forked repository to your local machine.\n\n```bash\ngit clone https://github.com/<your_username>/projen-pipelines.git\n```\n\n3. **Create a Branch**: To keep your work organized, create a branch for your contribution.\n\n```bash\ngit checkout -b my-branch\n```\n\n4. **Make your Changes**: Make your changes, additions, or fixes to the codebase. Remember to follow the existing code style.\n\n5. **Test your Changes**: Before committing your changes, make sure to test them to ensure they work as expected and do not introduce bugs.\n\n6. **Commit your Changes**: Commit your changes with a descriptive commit message using conventional commit messages.\n\n```bash\ngit commit -m \"feat: Your descriptive commit message\"\n```\n\n7. **Push to your Fork**: Push your commits to the branch in your forked repository.\n\n```bash\ngit push origin my-branch\n```\n\n8. **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.\n\nYour pull request will be reviewed and hopefully merged quickly. Thanks for contributing!\n"
77
77
  },
78
78
  "repository": {
79
79
  "type": "git",
@@ -90,7 +90,9 @@
90
90
  "assembly": "projen-pipelines",
91
91
  "base": "projen.Component",
92
92
  "docs": {
93
- "stability": "stable"
93
+ "remarks": "It also manages tasks such as publishing CDK assets, bumping version based on git tags, and cleaning up conflicting tasks.",
94
+ "stability": "stable",
95
+ "summary": "The CDKPipeline class extends the Component class and sets up the necessary configuration for deploying AWS CDK (Cloud Development Kit) applications across multiple stages."
94
96
  },
95
97
  "fqn": "projen-pipelines.CDKPipeline",
96
98
  "initializer": {
@@ -99,7 +101,7 @@
99
101
  },
100
102
  "locationInModule": {
101
103
  "filename": "src/pipeline.ts",
102
- "line": 24
104
+ "line": 94
103
105
  },
104
106
  "parameters": [
105
107
  {
@@ -119,7 +121,7 @@
119
121
  "kind": "class",
120
122
  "locationInModule": {
121
123
  "filename": "src/pipeline.ts",
122
- "line": 22
124
+ "line": 92
123
125
  },
124
126
  "name": "CDKPipeline",
125
127
  "symbolId": "src/pipeline:CDKPipeline"
@@ -128,25 +130,29 @@
128
130
  "assembly": "projen-pipelines",
129
131
  "datatype": true,
130
132
  "docs": {
131
- "stability": "stable"
133
+ "remarks": "It allows the definition\nof settings such as the stack prefix and package namespace to be used in the\nAWS stack, along with the environments configuration to be used.",
134
+ "stability": "stable",
135
+ "summary": "The CDKPipelineOptions interface is designed to provide configuration options for a CDK (Cloud Development Kit) pipeline."
132
136
  },
133
137
  "fqn": "projen-pipelines.CDKPipelineOptions",
134
138
  "kind": "interface",
135
139
  "locationInModule": {
136
140
  "filename": "src/pipeline.ts",
137
- "line": 16
141
+ "line": 66
138
142
  },
139
143
  "name": "CDKPipelineOptions",
140
144
  "properties": [
141
145
  {
142
146
  "abstract": true,
143
147
  "docs": {
144
- "stability": "stable"
148
+ "remarks": "It allows the\npipeline to deploy to different environments based on the stage of the\ndeployment process, whether that's a personal, feature, dev, or prod stage.",
149
+ "stability": "stable",
150
+ "summary": "This is a map of environments to be used in the pipeline."
145
151
  },
146
152
  "immutable": true,
147
153
  "locationInModule": {
148
154
  "filename": "src/pipeline.ts",
149
- "line": 19
155
+ "line": 85
150
156
  },
151
157
  "name": "environments",
152
158
  "type": {
@@ -156,12 +162,14 @@
156
162
  {
157
163
  "abstract": true,
158
164
  "docs": {
159
- "stability": "stable"
165
+ "remarks": "A namespace helps group related resources together, providing\nbetter organization and ease of management.",
166
+ "stability": "stable",
167
+ "summary": "This field determines the NPM namespace to be used when packaging CDK cloud assemblies."
160
168
  },
161
169
  "immutable": true,
162
170
  "locationInModule": {
163
171
  "filename": "src/pipeline.ts",
164
- "line": 18
172
+ "line": 78
165
173
  },
166
174
  "name": "pkgNamespace",
167
175
  "type": {
@@ -171,12 +179,13 @@
171
179
  {
172
180
  "abstract": true,
173
181
  "docs": {
174
- "stability": "stable"
182
+ "stability": "stable",
183
+ "summary": "This field is used to define a prefix for the AWS Stack resources created during the pipeline's operation."
175
184
  },
176
185
  "immutable": true,
177
186
  "locationInModule": {
178
187
  "filename": "src/pipeline.ts",
179
- "line": 17
188
+ "line": 71
180
189
  },
181
190
  "name": "stackPrefix",
182
191
  "type": {
@@ -190,25 +199,29 @@
190
199
  "assembly": "projen-pipelines",
191
200
  "datatype": true,
192
201
  "docs": {
193
- "stability": "stable"
202
+ "remarks": "Each environment requires a specific account and region for its resources.",
203
+ "stability": "stable",
204
+ "summary": "The Environment interface is designed to hold AWS related information for a specific deployment environment within your infrastructure."
194
205
  },
195
206
  "fqn": "projen-pipelines.Environment",
196
207
  "kind": "interface",
197
208
  "locationInModule": {
198
209
  "filename": "src/pipeline.ts",
199
- "line": 4
210
+ "line": 9
200
211
  },
201
212
  "name": "Environment",
202
213
  "properties": [
203
214
  {
204
215
  "abstract": true,
205
216
  "docs": {
206
- "stability": "stable"
217
+ "remarks": "It's important because\ndifferent services or features could have distinct permissions and settings\nin different accounts.",
218
+ "stability": "stable",
219
+ "summary": "The AWS Account ID associated with the environment."
207
220
  },
208
221
  "immutable": true,
209
222
  "locationInModule": {
210
223
  "filename": "src/pipeline.ts",
211
- "line": 5
224
+ "line": 15
212
225
  },
213
226
  "name": "account",
214
227
  "type": {
@@ -218,12 +231,14 @@
218
231
  {
219
232
  "abstract": true,
220
233
  "docs": {
221
- "stability": "stable"
234
+ "remarks": "This determines where your resources\nare created and where your application will run. It can affect latency,\navailability, and pricing.",
235
+ "stability": "stable",
236
+ "summary": "The AWS Region for the environment."
222
237
  },
223
238
  "immutable": true,
224
239
  "locationInModule": {
225
240
  "filename": "src/pipeline.ts",
226
- "line": 6
241
+ "line": 22
227
242
  },
228
243
  "name": "region",
229
244
  "type": {
@@ -237,25 +252,29 @@
237
252
  "assembly": "projen-pipelines",
238
253
  "datatype": true,
239
254
  "docs": {
240
- "stability": "stable"
255
+ "remarks": "Each type of environment - personal,\nfeature, dev, and prod, represents a different stage of development or usage.",
256
+ "stability": "stable",
257
+ "summary": "The EnvironmentMap interface is used to maintain a mapping of different types of environments used in the application."
241
258
  },
242
259
  "fqn": "projen-pipelines.EnvironmentMap",
243
260
  "kind": "interface",
244
261
  "locationInModule": {
245
262
  "filename": "src/pipeline.ts",
246
- "line": 9
263
+ "line": 30
247
264
  },
248
265
  "name": "EnvironmentMap",
249
266
  "properties": [
250
267
  {
251
268
  "abstract": true,
252
269
  "docs": {
253
- "stability": "stable"
270
+ "remarks": "It represents the latest version of the application\nbut may not be as stable as the production environment.",
271
+ "stability": "stable",
272
+ "summary": "The dev environment is a shared environment where developers integrate their feature changes."
254
273
  },
255
274
  "immutable": true,
256
275
  "locationInModule": {
257
276
  "filename": "src/pipeline.ts",
258
- "line": 12
277
+ "line": 51
259
278
  },
260
279
  "name": "dev",
261
280
  "type": {
@@ -265,12 +284,14 @@
265
284
  {
266
285
  "abstract": true,
267
286
  "docs": {
268
- "stability": "stable"
287
+ "remarks": "This allows developers to work on\nindividual features without impacting the stability of the dev or prod\nenvironments.",
288
+ "stability": "stable",
289
+ "summary": "The feature environment is typically used for developing specific features in isolation from the main codebase."
269
290
  },
270
291
  "immutable": true,
271
292
  "locationInModule": {
272
293
  "filename": "src/pipeline.ts",
273
- "line": 11
294
+ "line": 44
274
295
  },
275
296
  "name": "feature",
276
297
  "type": {
@@ -280,12 +301,13 @@
280
301
  {
281
302
  "abstract": true,
282
303
  "docs": {
283
- "stability": "stable"
304
+ "stability": "stable",
305
+ "summary": "The personal environment is usually used for individual development and testing, allowing developers to freely test and experiment without affecting the shared development environment."
284
306
  },
285
307
  "immutable": true,
286
308
  "locationInModule": {
287
309
  "filename": "src/pipeline.ts",
288
- "line": 10
310
+ "line": 36
289
311
  },
290
312
  "name": "personal",
291
313
  "type": {
@@ -295,12 +317,14 @@
295
317
  {
296
318
  "abstract": true,
297
319
  "docs": {
298
- "stability": "stable"
320
+ "remarks": "It should be stable and only receive thoroughly tested changes.",
321
+ "stability": "stable",
322
+ "summary": "The prod environment is where the live, user-facing application runs."
299
323
  },
300
324
  "immutable": true,
301
325
  "locationInModule": {
302
326
  "filename": "src/pipeline.ts",
303
- "line": 13
327
+ "line": 57
304
328
  },
305
329
  "name": "prod",
306
330
  "type": {
@@ -311,6 +335,6 @@
311
335
  "symbolId": "src/pipeline:EnvironmentMap"
312
336
  }
313
337
  },
314
- "version": "0.0.1",
315
- "fingerprint": "2LYbS7mnYEB7BvVsmfx7xZ2z3b2bi5G6OW2IkIWWAjs="
338
+ "version": "0.0.2",
339
+ "fingerprint": "waYM4hyDn3h3HyWbjkniKI5tGRzEWHiWZjTSiUvbuxI="
316
340
  }
package/API.md CHANGED
@@ -1,4 +1,158 @@
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 teh 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!
155
+
2
156
  # API Reference <a name="API Reference" id="api-reference"></a>
3
157
 
4
158
 
@@ -6,6 +160,12 @@
6
160
 
7
161
  ### CDKPipelineOptions <a name="CDKPipelineOptions" id="projen-pipelines.CDKPipelineOptions"></a>
8
162
 
163
+ The CDKPipelineOptions interface is designed to provide configuration options for a CDK (Cloud Development Kit) pipeline.
164
+
165
+ It allows the definition
166
+ of settings such as the stack prefix and package namespace to be used in the
167
+ AWS stack, along with the environments configuration to be used.
168
+
9
169
  #### Initializer <a name="Initializer" id="projen-pipelines.CDKPipelineOptions.Initializer"></a>
10
170
 
11
171
  ```typescript
@@ -18,9 +178,9 @@ const cDKPipelineOptions: CDKPipelineOptions = { ... }
18
178
 
19
179
  | **Name** | **Type** | **Description** |
20
180
  | --- | --- | --- |
21
- | <code><a href="#projen-pipelines.CDKPipelineOptions.property.environments">environments</a></code> | <code><a href="#projen-pipelines.EnvironmentMap">EnvironmentMap</a></code> | *No description.* |
22
- | <code><a href="#projen-pipelines.CDKPipelineOptions.property.pkgNamespace">pkgNamespace</a></code> | <code>string</code> | *No description.* |
23
- | <code><a href="#projen-pipelines.CDKPipelineOptions.property.stackPrefix">stackPrefix</a></code> | <code>string</code> | *No description.* |
181
+ | <code><a href="#projen-pipelines.CDKPipelineOptions.property.environments">environments</a></code> | <code><a href="#projen-pipelines.EnvironmentMap">EnvironmentMap</a></code> | This is a map of environments to be used in the pipeline. |
182
+ | <code><a href="#projen-pipelines.CDKPipelineOptions.property.pkgNamespace">pkgNamespace</a></code> | <code>string</code> | This field determines the NPM namespace to be used when packaging CDK cloud assemblies. |
183
+ | <code><a href="#projen-pipelines.CDKPipelineOptions.property.stackPrefix">stackPrefix</a></code> | <code>string</code> | This field is used to define a prefix for the AWS Stack resources created during the pipeline's operation. |
24
184
 
25
185
  ---
26
186
 
@@ -32,6 +192,12 @@ public readonly environments: EnvironmentMap;
32
192
 
33
193
  - *Type:* <a href="#projen-pipelines.EnvironmentMap">EnvironmentMap</a>
34
194
 
195
+ This is a map of environments to be used in the pipeline.
196
+
197
+ It allows the
198
+ pipeline to deploy to different environments based on the stage of the
199
+ deployment process, whether that's a personal, feature, dev, or prod stage.
200
+
35
201
  ---
36
202
 
37
203
  ##### `pkgNamespace`<sup>Required</sup> <a name="pkgNamespace" id="projen-pipelines.CDKPipelineOptions.property.pkgNamespace"></a>
@@ -42,6 +208,11 @@ public readonly pkgNamespace: string;
42
208
 
43
209
  - *Type:* string
44
210
 
211
+ This field determines the NPM namespace to be used when packaging CDK cloud assemblies.
212
+
213
+ A namespace helps group related resources together, providing
214
+ better organization and ease of management.
215
+
45
216
  ---
46
217
 
47
218
  ##### `stackPrefix`<sup>Required</sup> <a name="stackPrefix" id="projen-pipelines.CDKPipelineOptions.property.stackPrefix"></a>
@@ -52,10 +223,16 @@ public readonly stackPrefix: string;
52
223
 
53
224
  - *Type:* string
54
225
 
226
+ This field is used to define a prefix for the AWS Stack resources created during the pipeline's operation.
227
+
55
228
  ---
56
229
 
57
230
  ### Environment <a name="Environment" id="projen-pipelines.Environment"></a>
58
231
 
232
+ The Environment interface is designed to hold AWS related information for a specific deployment environment within your infrastructure.
233
+
234
+ Each environment requires a specific account and region for its resources.
235
+
59
236
  #### Initializer <a name="Initializer" id="projen-pipelines.Environment.Initializer"></a>
60
237
 
61
238
  ```typescript
@@ -68,8 +245,8 @@ const environment: Environment = { ... }
68
245
 
69
246
  | **Name** | **Type** | **Description** |
70
247
  | --- | --- | --- |
71
- | <code><a href="#projen-pipelines.Environment.property.account">account</a></code> | <code>string</code> | *No description.* |
72
- | <code><a href="#projen-pipelines.Environment.property.region">region</a></code> | <code>string</code> | *No description.* |
248
+ | <code><a href="#projen-pipelines.Environment.property.account">account</a></code> | <code>string</code> | The AWS Account ID associated with the environment. |
249
+ | <code><a href="#projen-pipelines.Environment.property.region">region</a></code> | <code>string</code> | The AWS Region for the environment. |
73
250
 
74
251
  ---
75
252
 
@@ -81,6 +258,12 @@ public readonly account: string;
81
258
 
82
259
  - *Type:* string
83
260
 
261
+ The AWS Account ID associated with the environment.
262
+
263
+ It's important because
264
+ different services or features could have distinct permissions and settings
265
+ in different accounts.
266
+
84
267
  ---
85
268
 
86
269
  ##### `region`<sup>Required</sup> <a name="region" id="projen-pipelines.Environment.property.region"></a>
@@ -91,10 +274,21 @@ public readonly region: string;
91
274
 
92
275
  - *Type:* string
93
276
 
277
+ The AWS Region for the environment.
278
+
279
+ This determines where your resources
280
+ are created and where your application will run. It can affect latency,
281
+ availability, and pricing.
282
+
94
283
  ---
95
284
 
96
285
  ### EnvironmentMap <a name="EnvironmentMap" id="projen-pipelines.EnvironmentMap"></a>
97
286
 
287
+ The EnvironmentMap interface is used to maintain a mapping of different types of environments used in the application.
288
+
289
+ Each type of environment - personal,
290
+ feature, dev, and prod, represents a different stage of development or usage.
291
+
98
292
  #### Initializer <a name="Initializer" id="projen-pipelines.EnvironmentMap.Initializer"></a>
99
293
 
100
294
  ```typescript
@@ -107,10 +301,10 @@ const environmentMap: EnvironmentMap = { ... }
107
301
 
108
302
  | **Name** | **Type** | **Description** |
109
303
  | --- | --- | --- |
110
- | <code><a href="#projen-pipelines.EnvironmentMap.property.dev">dev</a></code> | <code><a href="#projen-pipelines.Environment">Environment</a></code> | *No description.* |
111
- | <code><a href="#projen-pipelines.EnvironmentMap.property.feature">feature</a></code> | <code><a href="#projen-pipelines.Environment">Environment</a></code> | *No description.* |
112
- | <code><a href="#projen-pipelines.EnvironmentMap.property.personal">personal</a></code> | <code><a href="#projen-pipelines.Environment">Environment</a></code> | *No description.* |
113
- | <code><a href="#projen-pipelines.EnvironmentMap.property.prod">prod</a></code> | <code><a href="#projen-pipelines.Environment">Environment</a></code> | *No description.* |
304
+ | <code><a href="#projen-pipelines.EnvironmentMap.property.dev">dev</a></code> | <code><a href="#projen-pipelines.Environment">Environment</a></code> | The dev environment is a shared environment where developers integrate their feature changes. |
305
+ | <code><a href="#projen-pipelines.EnvironmentMap.property.feature">feature</a></code> | <code><a href="#projen-pipelines.Environment">Environment</a></code> | The feature environment is typically used for developing specific features in isolation from the main codebase. |
306
+ | <code><a href="#projen-pipelines.EnvironmentMap.property.personal">personal</a></code> | <code><a href="#projen-pipelines.Environment">Environment</a></code> | The personal environment is usually used for individual development and testing, allowing developers to freely test and experiment without affecting the shared development environment. |
307
+ | <code><a href="#projen-pipelines.EnvironmentMap.property.prod">prod</a></code> | <code><a href="#projen-pipelines.Environment">Environment</a></code> | The prod environment is where the live, user-facing application runs. |
114
308
 
115
309
  ---
116
310
 
@@ -122,6 +316,11 @@ public readonly dev: Environment;
122
316
 
123
317
  - *Type:* <a href="#projen-pipelines.Environment">Environment</a>
124
318
 
319
+ The dev environment is a shared environment where developers integrate their feature changes.
320
+
321
+ It represents the latest version of the application
322
+ but may not be as stable as the production environment.
323
+
125
324
  ---
126
325
 
127
326
  ##### `feature`<sup>Required</sup> <a name="feature" id="projen-pipelines.EnvironmentMap.property.feature"></a>
@@ -132,6 +331,12 @@ public readonly feature: Environment;
132
331
 
133
332
  - *Type:* <a href="#projen-pipelines.Environment">Environment</a>
134
333
 
334
+ The feature environment is typically used for developing specific features in isolation from the main codebase.
335
+
336
+ This allows developers to work on
337
+ individual features without impacting the stability of the dev or prod
338
+ environments.
339
+
135
340
  ---
136
341
 
137
342
  ##### `personal`<sup>Required</sup> <a name="personal" id="projen-pipelines.EnvironmentMap.property.personal"></a>
@@ -142,6 +347,8 @@ public readonly personal: Environment;
142
347
 
143
348
  - *Type:* <a href="#projen-pipelines.Environment">Environment</a>
144
349
 
350
+ The personal environment is usually used for individual development and testing, allowing developers to freely test and experiment without affecting the shared development environment.
351
+
145
352
  ---
146
353
 
147
354
  ##### `prod`<sup>Required</sup> <a name="prod" id="projen-pipelines.EnvironmentMap.property.prod"></a>
@@ -152,12 +359,20 @@ public readonly prod: Environment;
152
359
 
153
360
  - *Type:* <a href="#projen-pipelines.Environment">Environment</a>
154
361
 
362
+ The prod environment is where the live, user-facing application runs.
363
+
364
+ It should be stable and only receive thoroughly tested changes.
365
+
155
366
  ---
156
367
 
157
368
  ## Classes <a name="Classes" id="Classes"></a>
158
369
 
159
370
  ### CDKPipeline <a name="CDKPipeline" id="projen-pipelines.CDKPipeline"></a>
160
371
 
372
+ The CDKPipeline class extends the Component class and sets up the necessary configuration for deploying AWS CDK (Cloud Development Kit) applications across multiple stages.
373
+
374
+ It also manages tasks such as publishing CDK assets, bumping version based on git tags, and cleaning up conflicting tasks.
375
+
161
376
  #### Initializers <a name="Initializers" id="projen-pipelines.CDKPipeline.Initializer"></a>
162
377
 
163
378
  ```typescript
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 teh 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!
package/lib/pipeline.d.ts CHANGED
@@ -1,26 +1,110 @@
1
1
  import { Component, awscdk } from 'projen';
2
+ /**
3
+ * The Environment interface is designed to hold AWS related information
4
+ * for a specific deployment environment within your infrastructure.
5
+ * Each environment requires a specific account and region for its resources.
6
+ */
2
7
  export interface Environment {
8
+ /**
9
+ * The AWS Account ID associated with the environment. It's important because
10
+ * different services or features could have distinct permissions and settings
11
+ * in different accounts.
12
+ */
3
13
  readonly account: string;
14
+ /**
15
+ * The AWS Region for the environment. This determines where your resources
16
+ * are created and where your application will run. It can affect latency,
17
+ * availability, and pricing.
18
+ */
4
19
  readonly region: string;
5
20
  }
21
+ /**
22
+ * The EnvironmentMap interface is used to maintain a mapping of different types
23
+ * of environments used in the application. Each type of environment - personal,
24
+ * feature, dev, and prod, represents a different stage of development or usage.
25
+ */
6
26
  export interface EnvironmentMap {
27
+ /**
28
+ * The personal environment is usually used for individual development and
29
+ * testing, allowing developers to freely test and experiment without
30
+ * affecting the shared development environment.
31
+ */
7
32
  readonly personal: Environment;
33
+ /**
34
+ * The feature environment is typically used for developing specific features
35
+ * in isolation from the main codebase. This allows developers to work on
36
+ * individual features without impacting the stability of the dev or prod
37
+ * environments.
38
+ */
8
39
  readonly feature: Environment;
40
+ /**
41
+ * The dev environment is a shared environment where developers integrate
42
+ * their feature changes. It represents the latest version of the application
43
+ * but may not be as stable as the production environment.
44
+ */
9
45
  readonly dev: Environment;
46
+ /**
47
+ * The prod environment is where the live, user-facing application runs.
48
+ * It should be stable and only receive thoroughly tested changes.
49
+ */
10
50
  readonly prod: Environment;
11
51
  }
52
+ /**
53
+ * The CDKPipelineOptions interface is designed to provide configuration
54
+ * options for a CDK (Cloud Development Kit) pipeline. It allows the definition
55
+ * of settings such as the stack prefix and package namespace to be used in the
56
+ * AWS stack, along with the environments configuration to be used.
57
+ */
12
58
  export interface CDKPipelineOptions {
59
+ /**
60
+ * This field is used to define a prefix for the AWS Stack resources created
61
+ * during the pipeline's operation.
62
+ */
13
63
  readonly stackPrefix: string;
64
+ /**
65
+ * This field determines the NPM namespace to be used when packaging CDK cloud
66
+ * assemblies. A namespace helps group related resources together, providing
67
+ * better organization and ease of management.
68
+ */
14
69
  readonly pkgNamespace: string;
70
+ /**
71
+ * This is a map of environments to be used in the pipeline. It allows the
72
+ * pipeline to deploy to different environments based on the stage of the
73
+ * deployment process, whether that's a personal, feature, dev, or prod stage.
74
+ */
15
75
  readonly environments: EnvironmentMap;
16
76
  }
77
+ /**
78
+ * The CDKPipeline class extends the Component class and sets up the necessary configuration for deploying AWS CDK (Cloud Development Kit) applications across multiple stages.
79
+ * It also manages tasks such as publishing CDK assets, bumping version based on git tags, and cleaning up conflicting tasks.
80
+ */
17
81
  export declare class CDKPipeline extends Component {
18
82
  private app;
19
83
  private props;
20
84
  constructor(app: awscdk.AwsCdkTypeScriptApp, props: CDKPipelineOptions);
85
+ /**
86
+ * This method generates the entry point for the application, including interfaces and classes
87
+ * necessary to set up the pipeline and define the AWS CDK stacks for different environments.
88
+ */
21
89
  private createApplicationEntrypoint;
90
+ /**
91
+ * This method sets up tasks to publish CDK assets to all accounts and handle versioning, including bumping the version
92
+ * based on the latest git tag and pushing the CDK assembly to the package repository.
93
+ */
22
94
  private createReleaseTasks;
95
+ /**
96
+ * This method sets up tasks for the personal deployment stage, including deployment, watching for changes,
97
+ * comparing changes (diff), and destroying the stack when no longer needed.
98
+ */
23
99
  private createPersonalStage;
100
+ /**
101
+ * This method sets up tasks for the feature deployment stage, including deployment, comparing changes (diff),
102
+ * and destroying the stack when no longer needed.
103
+ */
24
104
  private createFeatureStage;
105
+ /**
106
+ * This method sets up tasks for the general pipeline stages (dev, prod), including deployment and comparing changes (diff).
107
+ * @param {string} stageName - The name of the stage (e.g., 'dev', 'prod')
108
+ */
25
109
  private createPipelineStage;
26
110
  }
package/lib/pipeline.js CHANGED
@@ -5,29 +5,41 @@ exports.CDKPipeline = 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
+ /**
9
+ * 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
+ * It also manages tasks such as publishing CDK assets, bumping version based on git tags, and cleaning up conflicting tasks.
11
+ */
8
12
  class CDKPipeline extends projen_1.Component {
9
13
  constructor(app, props) {
10
14
  super(app);
11
15
  this.app = app;
12
16
  this.props = props;
17
+ // Add development dependencies
13
18
  this.app.addDevDeps('@types/standard-version', 'standard-version', 'cdk-assets');
14
19
  // this.app.addDeps(
15
20
  // );
16
- // Remove assembly before synth
21
+ // Removes the compiled cloud assembly before each synth
17
22
  this.project.tasks.tryFind('synth')?.prependExec(`rm -rf ${this.app.cdkConfig.cdkout}`);
18
23
  this.project.tasks.tryFind('synth:silent')?.prependExec(`rm -rf ${this.app.cdkConfig.cdkout}`);
19
- // Remove conflicting tasks
24
+ // Remove tasks that might conflict with the pipeline process
20
25
  this.project.removeTask('deploy');
21
26
  this.project.removeTask('diff');
22
27
  this.project.removeTask('destroy');
23
28
  this.project.removeTask('watch');
29
+ // Creates different deployment stages
24
30
  this.createPersonalStage();
25
31
  this.createFeatureStage();
26
32
  this.createPipelineStage('dev');
27
33
  this.createPipelineStage('prod');
34
+ // Creates tasks to handle the release process
28
35
  this.createReleaseTasks();
36
+ // Creates a specialized CDK App class
29
37
  this.createApplicationEntrypoint();
30
38
  }
39
+ /**
40
+ * This method generates the entry point for the application, including interfaces and classes
41
+ * necessary to set up the pipeline and define the AWS CDK stacks for different environments.
42
+ */
31
43
  createApplicationEntrypoint() {
32
44
  const appFile = new projen_1.TextFile(this.project, `${this.app.srcdir}/app.ts`);
33
45
  appFile.addLine(`// ${common_1.PROJEN_MARKER}
@@ -38,31 +50,61 @@ class CDKPipeline extends projen_1.Component {
38
50
  /* eslint-disable quote-props */
39
51
  import { App, AppProps, Stack, StackProps } from 'aws-cdk-lib';
40
52
 
53
+ /**
54
+ * PipelineAppProps is an extension of AppProps, which is part of the AWS CDK core.
55
+ * It includes optional functions to provide AWS Stacks for different stages.
56
+ *
57
+ * Use these functions to instantiate your application stacks with the parameters for
58
+ * each stage
59
+ */
41
60
  export interface PipelineAppProps extends AppProps {
61
+ /** This optional function, if provided, will be used to generate a development stack. */
42
62
  provideDevStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;
63
+
64
+ /** This optional function, if provided, will be used to generate a production stack. */
43
65
  provideProdStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;
66
+
67
+ /** This optional function, if provided, will be used to generate a personal stack. */
44
68
  providePersonalStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;
69
+
70
+ /** This optional function, if provided, will be used to generate a feature stack. */
45
71
  provideFeatureStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;
46
72
  }
47
73
 
74
+ /**
75
+ * PipelineAppStackProps is an extension of StackProps, which is part of the AWS CDK core.
76
+ * It includes an additional property to specify the stage name.
77
+ */
48
78
  export interface PipelineAppStackProps extends StackProps {
49
79
  stageName: string;
50
80
  }
51
81
 
82
+ /**
83
+ * 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
85
+ * stack-providing functions from the props.
86
+ */
52
87
  export class PipelineApp extends App {
53
88
  constructor(props: PipelineAppProps) {
54
89
  super(props);
55
90
 
91
+ // If a function is provided for creating a development stack, it is called with necessary arguments.
56
92
  if (props.provideDevStack) {
57
93
  props.provideDevStack(this, '${this.props.stackPrefix}-dev', { env: ${JSON.stringify(this.props.environments.dev)}, stackName: '${this.props.stackPrefix}-dev', stageName: 'dev' });
58
94
  }
95
+
96
+ // If a function is provided for creating a production stack, it is called with necessary arguments.
59
97
  if (props.provideProdStack) {
60
98
  props.provideProdStack(this, '${this.props.stackPrefix}-prod', { env: ${JSON.stringify(this.props.environments.prod)}, stackName: '${this.props.stackPrefix}-prod', stageName: 'prod' });
61
99
  }
100
+
101
+ // If the environment variable USER is set and a function is provided for creating a personal stack, it is called with necessary arguments.
62
102
  if (props.providePersonalStack && process.env.USER) {
63
103
  const stageName = 'personal-' + process.env.USER.toLowerCase().replace(/\\\//g, '-');
64
104
  props.providePersonalStack(this, '${this.props.stackPrefix}-personal', { env: ${JSON.stringify(this.props.environments.personal)}, stackName: \`${this.props.stackPrefix}-\${stageName}\`, stageName });
65
105
  }
106
+
107
+ // If the environment variable BRANCH is set and a function is provided for creating a feature stack, it is called with necessary arguments.
66
108
  if (props.provideFeatureStack && process.env.BRANCH) {
67
109
  const stageName = 'feature-' + process.env.BRANCH.toLowerCase().replace(/\\\//g, '-');
68
110
  props.provideFeatureStack(this, '${this.props.stackPrefix}-feature', { env: ${JSON.stringify(this.props.environments.feature)}, stackName: \`${this.props.stackPrefix}-\${stageName}\`, stageName });
@@ -71,6 +113,10 @@ export class PipelineApp extends App {
71
113
  }
72
114
  `);
73
115
  }
116
+ /**
117
+ * This method sets up tasks to publish CDK assets to all accounts and handle versioning, including bumping the version
118
+ * based on the latest git tag and pushing the CDK assembly to the package repository.
119
+ */
74
120
  createReleaseTasks() {
75
121
  // Task to publish the CDK assets to all accounts
76
122
  this.project.addTask('publish:assets', {
@@ -110,6 +156,10 @@ export class PipelineApp extends App {
110
156
  ],
111
157
  });
112
158
  }
159
+ /**
160
+ * This method sets up tasks for the personal deployment stage, including deployment, watching for changes,
161
+ * comparing changes (diff), and destroying the stack when no longer needed.
162
+ */
113
163
  createPersonalStage() {
114
164
  this.project.addTask('deploy:personal', {
115
165
  exec: `cdk deploy ${this.props.stackPrefix}-personal`,
@@ -124,6 +174,10 @@ export class PipelineApp extends App {
124
174
  exec: `cdk destroy ${this.props.stackPrefix}-personal`,
125
175
  });
126
176
  }
177
+ /**
178
+ * This method sets up tasks for the feature deployment stage, including deployment, comparing changes (diff),
179
+ * and destroying the stack when no longer needed.
180
+ */
127
181
  createFeatureStage() {
128
182
  this.project.addTask('deploy:feature', {
129
183
  exec: `cdk --progress events --require-approval never deploy ${this.props.stackPrefix}-feature`,
@@ -135,6 +189,10 @@ export class PipelineApp extends App {
135
189
  exec: `cdk destroy ${this.props.stackPrefix}-feature`,
136
190
  });
137
191
  }
192
+ /**
193
+ * This method sets up tasks for the general pipeline stages (dev, prod), including deployment and comparing changes (diff).
194
+ * @param {string} stageName - The name of the stage (e.g., 'dev', 'prod')
195
+ */
138
196
  createPipelineStage(stageName) {
139
197
  this.project.addTask(`deploy:${stageName}`, {
140
198
  exec: `cdk --app ${this.app.cdkConfig.cdkout} --progress events --require-approval never deploy ${this.props.stackPrefix}-${stageName}`,
@@ -145,6 +203,6 @@ export class PipelineApp extends App {
145
203
  }
146
204
  }
147
205
  _a = JSII_RTTI_SYMBOL_1;
148
- CDKPipeline[_a] = { fqn: "projen-pipelines.CDKPipeline", version: "0.0.1" };
206
+ CDKPipeline[_a] = { fqn: "projen-pipelines.CDKPipeline", version: "0.0.2" };
149
207
  exports.CDKPipeline = CDKPipeline;
150
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline.js","sourceRoot":"","sources":["../src/pipeline.ts"],"names":[],"mappings":";;;;;AAAA,mCAAqD;AACrD,8CAAkD;AAoBlD,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,IAAI,CAAC,GAAG,CAAC,UAAU,CACjB,yBAAyB,EACzB,kBAAkB,EAClB,YAAY,CACb,CAAC;QACF,oBAAoB;QACpB,KAAK;QAEL,+BAA+B;QAC/B,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,2BAA2B;QAC3B,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,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAE3B,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAE1B,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;QAChC,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;QAEjC,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAE1B,IAAI,CAAC,2BAA2B,EAAE,CAAC;IACrC,CAAC;IAEO,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;;;;;;;;;;;;;;;;;;;;;;;;qCAwBF,IAAI,CAAC,KAAK,CAAC,WAAW,iBAAiB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,iBAAiB,IAAI,CAAC,KAAK,CAAC,WAAW;;;sCAGxH,IAAI,CAAC,KAAK,CAAC,WAAW,kBAAkB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,IAAI,CAAC,KAAK,CAAC,WAAW;;;;0CAIvH,IAAI,CAAC,KAAK,CAAC,WAAW,sBAAsB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,CAAC,kBAAkB,IAAI,CAAC,KAAK,CAAC,WAAW;;;;yCAIrI,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;IAEO,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;IAEO,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;IAEO,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;IAEO,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;;;;AA1JU,kCAAW","sourcesContent":["import { Component, TextFile, awscdk } from 'projen';\nimport { PROJEN_MARKER } from 'projen/lib/common';\n\nexport interface Environment {\n  readonly account: string;\n  readonly region: string;\n}\n\nexport interface EnvironmentMap {\n  readonly personal: Environment;\n  readonly feature: Environment;\n  readonly dev: Environment;\n  readonly prod: Environment;\n}\n\nexport interface CDKPipelineOptions {\n  readonly stackPrefix: string;\n  readonly pkgNamespace: string;\n  readonly environments: EnvironmentMap;\n}\n\nexport class CDKPipeline extends Component {\n\n  constructor(private app: awscdk.AwsCdkTypeScriptApp, private props: CDKPipelineOptions) {\n    super(app);\n\n    this.app.addDevDeps(\n      '@types/standard-version',\n      'standard-version',\n      'cdk-assets',\n    );\n    // this.app.addDeps(\n    // );\n\n    // Remove assembly before 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 conflicting tasks\n    this.project.removeTask('deploy');\n    this.project.removeTask('diff');\n    this.project.removeTask('destroy');\n    this.project.removeTask('watch');\n\n    this.createPersonalStage();\n\n    this.createFeatureStage();\n\n    this.createPipelineStage('dev');\n    this.createPipelineStage('prod');\n\n    this.createReleaseTasks();\n\n    this.createApplicationEntrypoint();\n  }\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\nexport interface PipelineAppProps extends AppProps {\n  provideDevStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;\n  provideProdStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;\n  providePersonalStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;\n  provideFeatureStack?: (app: App, stackId: string, props: PipelineAppStackProps) => Stack;\n}\n\nexport interface PipelineAppStackProps extends StackProps {\n  stageName: string;\n}\n\nexport class PipelineApp extends App {\n  constructor(props: PipelineAppProps) {\n    super(props);\n\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    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    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    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  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  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  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  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}"]}
208
+ //# 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';\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}"]}
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.1",
76
+ "version": "0.0.2",
77
77
  "jest": {
78
78
  "testMatch": [
79
79
  "<rootDir>/src/**/__tests__/**/*.ts?(x)",