@cdk8s/projen-common 0.0.277 → 0.0.279

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
@@ -99,7 +99,7 @@
99
99
  },
100
100
  "locationInModule": {
101
101
  "filename": "src/projects/jsii.ts",
102
- "line": 61
102
+ "line": 62
103
103
  },
104
104
  "parameters": [
105
105
  {
@@ -113,7 +113,7 @@
113
113
  "kind": "class",
114
114
  "locationInModule": {
115
115
  "filename": "src/projects/jsii.ts",
116
- "line": 59
116
+ "line": 60
117
117
  },
118
118
  "name": "Cdk8sTeamJsiiProject",
119
119
  "symbolId": "src/projects/jsii:Cdk8sTeamJsiiProject"
@@ -133,7 +133,7 @@
133
133
  "kind": "interface",
134
134
  "locationInModule": {
135
135
  "filename": "src/projects/jsii.ts",
136
- "line": 17
136
+ "line": 18
137
137
  },
138
138
  "name": "Cdk8sTeamJsiiProjectOptions",
139
139
  "properties": [
@@ -147,7 +147,7 @@
147
147
  "immutable": true,
148
148
  "locationInModule": {
149
149
  "filename": "src/projects/jsii.ts",
150
- "line": 24
150
+ "line": 25
151
151
  },
152
152
  "name": "golang",
153
153
  "optional": true,
@@ -165,7 +165,7 @@
165
165
  "immutable": true,
166
166
  "locationInModule": {
167
167
  "filename": "src/projects/jsii.ts",
168
- "line": 31
168
+ "line": 32
169
169
  },
170
170
  "name": "golangBranch",
171
171
  "optional": true,
@@ -183,7 +183,7 @@
183
183
  "immutable": true,
184
184
  "locationInModule": {
185
185
  "filename": "src/projects/jsii.ts",
186
- "line": 45
186
+ "line": 46
187
187
  },
188
188
  "name": "maven",
189
189
  "optional": true,
@@ -201,7 +201,7 @@
201
201
  "immutable": true,
202
202
  "locationInModule": {
203
203
  "filename": "src/projects/jsii.ts",
204
- "line": 52
204
+ "line": 53
205
205
  },
206
206
  "name": "nuget",
207
207
  "optional": true,
@@ -219,7 +219,7 @@
219
219
  "immutable": true,
220
220
  "locationInModule": {
221
221
  "filename": "src/projects/jsii.ts",
222
- "line": 38
222
+ "line": 39
223
223
  },
224
224
  "name": "pypi",
225
225
  "optional": true,
@@ -246,7 +246,7 @@
246
246
  },
247
247
  "locationInModule": {
248
248
  "filename": "src/projects/node.ts",
249
- "line": 98
249
+ "line": 113
250
250
  },
251
251
  "parameters": [
252
252
  {
@@ -260,7 +260,7 @@
260
260
  "kind": "class",
261
261
  "locationInModule": {
262
262
  "filename": "src/projects/node.ts",
263
- "line": 96
263
+ "line": 111
264
264
  },
265
265
  "name": "Cdk8sTeamNodeProject",
266
266
  "symbolId": "src/projects/node:Cdk8sTeamNodeProject"
@@ -279,10 +279,51 @@
279
279
  "kind": "interface",
280
280
  "locationInModule": {
281
281
  "filename": "src/projects/node.ts",
282
- "line": 81
282
+ "line": 82
283
283
  },
284
284
  "name": "Cdk8sTeamNodeProjectOptions",
285
285
  "properties": [
286
+ {
287
+ "abstract": true,
288
+ "docs": {
289
+ "default": "false",
290
+ "stability": "stable",
291
+ "summary": "Configure a backport workflow."
292
+ },
293
+ "immutable": true,
294
+ "locationInModule": {
295
+ "filename": "src/projects/node.ts",
296
+ "line": 97
297
+ },
298
+ "name": "backport",
299
+ "optional": true,
300
+ "type": {
301
+ "primitive": "boolean"
302
+ }
303
+ },
304
+ {
305
+ "abstract": true,
306
+ "docs": {
307
+ "default": "- Will be derived from PR labels.",
308
+ "stability": "stable",
309
+ "summary": "Branches to backport to."
310
+ },
311
+ "immutable": true,
312
+ "locationInModule": {
313
+ "filename": "src/projects/node.ts",
314
+ "line": 104
315
+ },
316
+ "name": "backportBranches",
317
+ "optional": true,
318
+ "type": {
319
+ "collection": {
320
+ "elementtype": {
321
+ "primitive": "string"
322
+ },
323
+ "kind": "array"
324
+ }
325
+ }
326
+ },
286
327
  {
287
328
  "abstract": true,
288
329
  "docs": {
@@ -293,7 +334,7 @@
293
334
  "immutable": true,
294
335
  "locationInModule": {
295
336
  "filename": "src/projects/node.ts",
296
- "line": 89
337
+ "line": 90
297
338
  },
298
339
  "name": "repoName",
299
340
  "optional": true,
@@ -320,7 +361,7 @@
320
361
  },
321
362
  "locationInModule": {
322
363
  "filename": "src/projects/typescript.ts",
323
- "line": 24
364
+ "line": 39
324
365
  },
325
366
  "parameters": [
326
367
  {
@@ -334,7 +375,7 @@
334
375
  "kind": "class",
335
376
  "locationInModule": {
336
377
  "filename": "src/projects/typescript.ts",
337
- "line": 22
378
+ "line": 37
338
379
  },
339
380
  "name": "Cdk8sTeamTypeScriptProject",
340
381
  "symbolId": "src/projects/typescript:Cdk8sTeamTypeScriptProject"
@@ -353,10 +394,51 @@
353
394
  "kind": "interface",
354
395
  "locationInModule": {
355
396
  "filename": "src/projects/typescript.ts",
356
- "line": 7
397
+ "line": 8
357
398
  },
358
399
  "name": "Cdk8sTeamTypeScriptProjectOptions",
359
400
  "properties": [
401
+ {
402
+ "abstract": true,
403
+ "docs": {
404
+ "default": "false",
405
+ "stability": "stable",
406
+ "summary": "Configure a backport workflow."
407
+ },
408
+ "immutable": true,
409
+ "locationInModule": {
410
+ "filename": "src/projects/typescript.ts",
411
+ "line": 23
412
+ },
413
+ "name": "backport",
414
+ "optional": true,
415
+ "type": {
416
+ "primitive": "boolean"
417
+ }
418
+ },
419
+ {
420
+ "abstract": true,
421
+ "docs": {
422
+ "default": "- Will be derived from PR labels.",
423
+ "stability": "stable",
424
+ "summary": "Branches to backport to."
425
+ },
426
+ "immutable": true,
427
+ "locationInModule": {
428
+ "filename": "src/projects/typescript.ts",
429
+ "line": 30
430
+ },
431
+ "name": "backportBranches",
432
+ "optional": true,
433
+ "type": {
434
+ "collection": {
435
+ "elementtype": {
436
+ "primitive": "string"
437
+ },
438
+ "kind": "array"
439
+ }
440
+ }
441
+ },
360
442
  {
361
443
  "abstract": true,
362
444
  "docs": {
@@ -367,7 +449,7 @@
367
449
  "immutable": true,
368
450
  "locationInModule": {
369
451
  "filename": "src/projects/typescript.ts",
370
- "line": 15
452
+ "line": 16
371
453
  },
372
454
  "name": "repoName",
373
455
  "optional": true,
@@ -379,6 +461,6 @@
379
461
  "symbolId": "src/projects/typescript:Cdk8sTeamTypeScriptProjectOptions"
380
462
  }
381
463
  },
382
- "version": "0.0.277",
383
- "fingerprint": "lVuzhLjzgl8hZYBqKBNorQzbggJ3xX0Dowtr+SmdJAw="
464
+ "version": "0.0.279",
465
+ "fingerprint": "wELx6Gi5FanGu/XC/hwMqrvJBYX2/6Gw3Gs/l91C8D0="
384
466
  }
package/API.md CHANGED
@@ -159,6 +159,8 @@ const cdk8sTeamJsiiProjectOptions: Cdk8sTeamJsiiProjectOptions = { ... }
159
159
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.tsconfigDev">tsconfigDev</a></code> | <code>projen.javascript.TypescriptConfigOptions</code> | Custom tsconfig options for the development tsconfig.json file (used for testing). |
160
160
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.tsconfigDevFile">tsconfigDevFile</a></code> | <code>string</code> | The name of the development tsconfig.json file. |
161
161
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.typescriptVersion">typescriptVersion</a></code> | <code>string</code> | TypeScript version to use. |
162
+ | <code><a href="#@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.backport">backport</a></code> | <code>boolean</code> | Configure a backport workflow. |
163
+ | <code><a href="#@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.backportBranches">backportBranches</a></code> | <code>string[]</code> | Branches to backport to. |
162
164
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.repoName">repoName</a></code> | <code>string</code> | The name of the repository inside the cdk8s-team org where the code of the project is locate in. |
163
165
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.golang">golang</a></code> | <code>boolean</code> | Publish Golang bindings to GitHub. |
164
166
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.golangBranch">golangBranch</a></code> | <code>string</code> | Name of the branch in the golang repository to publish to. |
@@ -2070,6 +2072,32 @@ same minor, so we recommend using a `~` dependency (e.g. `~1.2.3`).
2070
2072
 
2071
2073
  ---
2072
2074
 
2075
+ ##### `backport`<sup>Optional</sup> <a name="backport" id="@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.backport"></a>
2076
+
2077
+ ```typescript
2078
+ public readonly backport: boolean;
2079
+ ```
2080
+
2081
+ - *Type:* boolean
2082
+ - *Default:* false
2083
+
2084
+ Configure a backport workflow.
2085
+
2086
+ ---
2087
+
2088
+ ##### `backportBranches`<sup>Optional</sup> <a name="backportBranches" id="@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.backportBranches"></a>
2089
+
2090
+ ```typescript
2091
+ public readonly backportBranches: string[];
2092
+ ```
2093
+
2094
+ - *Type:* string[]
2095
+ - *Default:* Will be derived from PR labels.
2096
+
2097
+ Branches to backport to.
2098
+
2099
+ ---
2100
+
2073
2101
  ##### `repoName`<sup>Optional</sup> <a name="repoName" id="@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.repoName"></a>
2074
2102
 
2075
2103
  ```typescript
@@ -2282,6 +2310,8 @@ const cdk8sTeamNodeProjectOptions: Cdk8sTeamNodeProjectOptions = { ... }
2282
2310
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamNodeProjectOptions.property.workflowBootstrapSteps">workflowBootstrapSteps</a></code> | <code>projen.github.workflows.JobStep[]</code> | Workflow steps to use in order to bootstrap this repo. |
2283
2311
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamNodeProjectOptions.property.workflowGitIdentity">workflowGitIdentity</a></code> | <code>projen.github.GitIdentity</code> | The git identity to use in workflows. |
2284
2312
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamNodeProjectOptions.property.workflowNodeVersion">workflowNodeVersion</a></code> | <code>string</code> | The node version to use in GitHub workflows. |
2313
+ | <code><a href="#@cdk8s/projen-common.Cdk8sTeamNodeProjectOptions.property.backport">backport</a></code> | <code>boolean</code> | Configure a backport workflow. |
2314
+ | <code><a href="#@cdk8s/projen-common.Cdk8sTeamNodeProjectOptions.property.backportBranches">backportBranches</a></code> | <code>string[]</code> | Branches to backport to. |
2285
2315
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamNodeProjectOptions.property.repoName">repoName</a></code> | <code>string</code> | The name of the repository inside the cdk8s-team org where the code of the project is locate in. |
2286
2316
 
2287
2317
  ---
@@ -3973,6 +4003,32 @@ The node version to use in GitHub workflows.
3973
4003
 
3974
4004
  ---
3975
4005
 
4006
+ ##### `backport`<sup>Optional</sup> <a name="backport" id="@cdk8s/projen-common.Cdk8sTeamNodeProjectOptions.property.backport"></a>
4007
+
4008
+ ```typescript
4009
+ public readonly backport: boolean;
4010
+ ```
4011
+
4012
+ - *Type:* boolean
4013
+ - *Default:* false
4014
+
4015
+ Configure a backport workflow.
4016
+
4017
+ ---
4018
+
4019
+ ##### `backportBranches`<sup>Optional</sup> <a name="backportBranches" id="@cdk8s/projen-common.Cdk8sTeamNodeProjectOptions.property.backportBranches"></a>
4020
+
4021
+ ```typescript
4022
+ public readonly backportBranches: string[];
4023
+ ```
4024
+
4025
+ - *Type:* string[]
4026
+ - *Default:* Will be derived from PR labels.
4027
+
4028
+ Branches to backport to.
4029
+
4030
+ ---
4031
+
3976
4032
  ##### `repoName`<sup>Optional</sup> <a name="repoName" id="@cdk8s/projen-common.Cdk8sTeamNodeProjectOptions.property.repoName"></a>
3977
4033
 
3978
4034
  ```typescript
@@ -4136,6 +4192,8 @@ const cdk8sTeamTypeScriptProjectOptions: Cdk8sTeamTypeScriptProjectOptions = { .
4136
4192
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamTypeScriptProjectOptions.property.tsconfigDev">tsconfigDev</a></code> | <code>projen.javascript.TypescriptConfigOptions</code> | Custom tsconfig options for the development tsconfig.json file (used for testing). |
4137
4193
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamTypeScriptProjectOptions.property.tsconfigDevFile">tsconfigDevFile</a></code> | <code>string</code> | The name of the development tsconfig.json file. |
4138
4194
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamTypeScriptProjectOptions.property.typescriptVersion">typescriptVersion</a></code> | <code>string</code> | TypeScript version to use. |
4195
+ | <code><a href="#@cdk8s/projen-common.Cdk8sTeamTypeScriptProjectOptions.property.backport">backport</a></code> | <code>boolean</code> | Configure a backport workflow. |
4196
+ | <code><a href="#@cdk8s/projen-common.Cdk8sTeamTypeScriptProjectOptions.property.backportBranches">backportBranches</a></code> | <code>string[]</code> | Branches to backport to. |
4139
4197
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamTypeScriptProjectOptions.property.repoName">repoName</a></code> | <code>string</code> | The name of the repository inside the cdk8s-team org where the code of the project is locate in. |
4140
4198
 
4141
4199
  ---
@@ -6042,6 +6100,32 @@ same minor, so we recommend using a `~` dependency (e.g. `~1.2.3`).
6042
6100
 
6043
6101
  ---
6044
6102
 
6103
+ ##### `backport`<sup>Optional</sup> <a name="backport" id="@cdk8s/projen-common.Cdk8sTeamTypeScriptProjectOptions.property.backport"></a>
6104
+
6105
+ ```typescript
6106
+ public readonly backport: boolean;
6107
+ ```
6108
+
6109
+ - *Type:* boolean
6110
+ - *Default:* false
6111
+
6112
+ Configure a backport workflow.
6113
+
6114
+ ---
6115
+
6116
+ ##### `backportBranches`<sup>Optional</sup> <a name="backportBranches" id="@cdk8s/projen-common.Cdk8sTeamTypeScriptProjectOptions.property.backportBranches"></a>
6117
+
6118
+ ```typescript
6119
+ public readonly backportBranches: string[];
6120
+ ```
6121
+
6122
+ - *Type:* string[]
6123
+ - *Default:* Will be derived from PR labels.
6124
+
6125
+ Branches to backport to.
6126
+
6127
+ ---
6128
+
6045
6129
  ##### `repoName`<sup>Optional</sup> <a name="repoName" id="@cdk8s/projen-common.Cdk8sTeamTypeScriptProjectOptions.property.repoName"></a>
6046
6130
 
6047
6131
  ```typescript
@@ -0,0 +1,27 @@
1
+ import { Component } from 'projen';
2
+ import { NodeProject } from 'projen/lib/javascript';
3
+ /**
4
+ * Options for `Backport`.
5
+ */
6
+ export interface BackportOptions {
7
+ /**
8
+ * The repository name.
9
+ */
10
+ readonly repoName: string;
11
+ /**
12
+ * List of specific branches to backport to.
13
+ *
14
+ * @default - No specific branches. Will be determined by PR labels.
15
+ */
16
+ readonly branches?: string[];
17
+ }
18
+ /**
19
+ * Add a Backport workflow to our repos.
20
+ */
21
+ export declare class Backport extends Component {
22
+ private readonly repoName;
23
+ private readonly config;
24
+ constructor(project: NodeProject, options: BackportOptions);
25
+ private createTask;
26
+ private createWorkflow;
27
+ }
@@ -0,0 +1,100 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Backport = void 0;
4
+ const projen_1 = require("projen");
5
+ const workflows_model_1 = require("projen/lib/github/workflows-model");
6
+ /**
7
+ * Add a Backport workflow to our repos.
8
+ */
9
+ class Backport extends projen_1.Component {
10
+ constructor(project, options) {
11
+ super(project);
12
+ this.repoName = options.repoName;
13
+ this.config = new projen_1.JsonFile(project, '.backportrc.json', {
14
+ // see https://github.com/sqren/backport/blob/main/docs/config-file-options.md
15
+ obj: {
16
+ repoOwner: 'cdk8s-team',
17
+ repoName: this.repoName,
18
+ signoff: true,
19
+ branchLabelMapping: {
20
+ '^backport-to-(.+)$': '$1',
21
+ },
22
+ prTitle: '{commitMessages}',
23
+ fork: false,
24
+ publishStatusCommentOnFailure: true,
25
+ publishStatusCommentOnSuccess: true,
26
+ publishStatusCommentOnAbort: true,
27
+ targetPRLabels: [project.autoApprove.label],
28
+ },
29
+ });
30
+ // pinning because of https://github.com/sqren/backport/issues/451
31
+ // optional because it requires node 16 which is only available in the
32
+ // backport workflow environment.
33
+ project.addFields({ optionalDependencies: { backport: '8.5.0' } });
34
+ // backport task to branches based on pr labels (i.e not branch specific)
35
+ const backportTask = this.createTask(project);
36
+ // backport tasks to explicit branches based on input
37
+ for (const branch of options.branches ?? []) {
38
+ this.createTask(project, branch);
39
+ }
40
+ this.createWorkflow(project, backportTask);
41
+ }
42
+ createTask(project, branch) {
43
+ const name = branch ? `backport:${branch}` : 'backport';
44
+ const task = project.addTask(name, { requiredEnv: ['BACKPORT_PR_NUMBER', 'GITHUB_TOKEN'] });
45
+ const commands = [
46
+ 'BACKPORT_HOME=$(mktemp -d)',
47
+ 'mkdir -p ${BACKPORT_HOME}',
48
+ `cp ${this.config.path} \${BACKPORT_HOME}`,
49
+ 'cd ${BACKPORT_HOME}',
50
+ ];
51
+ const backport = ['backport', '--dir', `\${BACKPORT_HOME}/${this.repoName}`, '--accesstoken', '${GITHUB_TOKEN}', '--pr', '${BACKPORT_PR_NUMBER}'];
52
+ if (branch) {
53
+ backport.push(...['--branch', branch]);
54
+ }
55
+ else {
56
+ backport.push('--non-interactive');
57
+ }
58
+ commands.push(backport.join(' '));
59
+ task.exec(commands.join(' && '));
60
+ return task;
61
+ }
62
+ createWorkflow(project, task) {
63
+ const backportWorkflow = project.github.addWorkflow('backport');
64
+ backportWorkflow.on({ pullRequestTarget: { types: ['closed'] } });
65
+ backportWorkflow.addJob('backport', {
66
+ runsOn: ['ubuntu-latest'],
67
+ permissions: {
68
+ contents: workflows_model_1.JobPermission.WRITE,
69
+ },
70
+ steps: [
71
+ // needed in order to run the projen task as well
72
+ // as use the backport configuration in the repo.
73
+ {
74
+ name: 'checkout',
75
+ uses: 'actions/checkout@v3',
76
+ with: {
77
+ // required because we need the full history
78
+ // for proper backports.
79
+ 'fetch-depth': 0,
80
+ },
81
+ },
82
+ {
83
+ name: 'Set Git Identity',
84
+ run: 'git config --global user.name "github-actions" && git config --global user.email "github-actions@github.com"',
85
+ },
86
+ {
87
+ name: 'backport',
88
+ if: 'github.event.pull_request.merged == true',
89
+ run: `npx projen ${task.name}`,
90
+ env: {
91
+ GITHUB_TOKEN: '${{ secrets.PROJEN_GITHUB_TOKEN }}',
92
+ BACKPORT_PR_NUMBER: '${{ github.event.pull_request.number }}',
93
+ },
94
+ },
95
+ ],
96
+ });
97
+ }
98
+ }
99
+ exports.Backport = Backport;
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"backport.js","sourceRoot":"","sources":["../../../src/components/backport/backport.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, JsonFile, Task } from 'projen';\nimport { JobPermission } from 'projen/lib/github/workflows-model';\nimport { NodeProject } from 'projen/lib/javascript';\n\n/**\n * Options for `Backport`.\n */\nexport interface BackportOptions {\n\n  /**\n   * The repository name.\n   */\n  readonly repoName: string;\n\n  /**\n   * List of specific branches to backport to.\n   *\n   * @default - No specific branches. Will be determined by PR labels.\n   */\n  readonly branches?: string[];\n}\n\n/**\n * Add a Backport workflow to our repos.\n */\nexport class Backport extends Component {\n\n  private readonly repoName: string;\n  private readonly config: JsonFile;\n\n  constructor(project: NodeProject, options: BackportOptions) {\n    super(project);\n\n    this.repoName = options.repoName;\n\n    this.config = new JsonFile(project, '.backportrc.json', {\n      // see https://github.com/sqren/backport/blob/main/docs/config-file-options.md\n      obj: {\n        repoOwner: 'cdk8s-team',\n        repoName: this.repoName,\n        signoff: true,\n        branchLabelMapping: {\n          '^backport-to-(.+)$': '$1',\n        },\n        prTitle: '{commitMessages}',\n        fork: false,\n        publishStatusCommentOnFailure: true,\n        publishStatusCommentOnSuccess: true,\n        publishStatusCommentOnAbort: true,\n        targetPRLabels: [project.autoApprove!.label],\n      },\n    });\n\n    // pinning because of https://github.com/sqren/backport/issues/451\n    // optional because it requires node 16 which is only available in the\n    // backport workflow environment.\n    project.addFields({ optionalDependencies: { backport: '8.5.0' } });\n\n    // backport task to branches based on pr labels (i.e not branch specific)\n    const backportTask = this.createTask(project);\n\n    // backport tasks to explicit branches based on input\n    for (const branch of options.branches ?? []) {\n      this.createTask(project, branch);\n    }\n\n    this.createWorkflow(project, backportTask);\n\n  }\n\n  private createTask(project: NodeProject, branch?: string): Task {\n    const name = branch ? `backport:${branch}` : 'backport';\n    const task = project.addTask(name, { requiredEnv: ['BACKPORT_PR_NUMBER', 'GITHUB_TOKEN'] });\n    const commands = [\n      'BACKPORT_HOME=$(mktemp -d)',\n      'mkdir -p ${BACKPORT_HOME}',\n      `cp ${this.config.path} \\${BACKPORT_HOME}`,\n      'cd ${BACKPORT_HOME}',\n    ];\n    const backport = ['backport', '--dir', `\\${BACKPORT_HOME}/${this.repoName}`, '--accesstoken', '${GITHUB_TOKEN}', '--pr', '${BACKPORT_PR_NUMBER}'];\n    if (branch) {\n      backport.push(...['--branch', branch]);\n    } else {\n      backport.push('--non-interactive');\n    }\n\n    commands.push(backport.join(' '));\n    task.exec(commands.join(' && '));\n    return task;\n  }\n\n  private createWorkflow(project: NodeProject, task: Task) {\n\n    const backportWorkflow = project.github!.addWorkflow('backport');\n    backportWorkflow.on({ pullRequestTarget: { types: ['closed'] } });\n    backportWorkflow.addJob('backport', {\n      runsOn: ['ubuntu-latest'],\n      permissions: {\n        contents: JobPermission.WRITE,\n      },\n      steps: [\n        // needed in order to run the projen task as well\n        // as use the backport configuration in the repo.\n        {\n          name: 'checkout',\n          uses: 'actions/checkout@v3',\n          with: {\n            // required because we need the full history\n            // for proper backports.\n            'fetch-depth': 0,\n          },\n        },\n        {\n          name: 'Set Git Identity',\n          run: 'git config --global user.name \"github-actions\" && git config --global user.email \"github-actions@github.com\"',\n        },\n        {\n          name: 'backport',\n          if: 'github.event.pull_request.merged == true',\n          run: `npx projen ${task.name}`,\n          env: {\n            GITHUB_TOKEN: '${{ secrets.PROJEN_GITHUB_TOKEN }}',\n            BACKPORT_PR_NUMBER: '${{ github.event.pull_request.number }}',\n          },\n        },\n      ],\n    });\n\n  }\n\n}"]}
@@ -0,0 +1,131 @@
1
+ import { Component, JsonFile, Task } from 'projen';
2
+ import { JobPermission } from 'projen/lib/github/workflows-model';
3
+ import { NodeProject } from 'projen/lib/javascript';
4
+
5
+ /**
6
+ * Options for `Backport`.
7
+ */
8
+ export interface BackportOptions {
9
+
10
+ /**
11
+ * The repository name.
12
+ */
13
+ readonly repoName: string;
14
+
15
+ /**
16
+ * List of specific branches to backport to.
17
+ *
18
+ * @default - No specific branches. Will be determined by PR labels.
19
+ */
20
+ readonly branches?: string[];
21
+ }
22
+
23
+ /**
24
+ * Add a Backport workflow to our repos.
25
+ */
26
+ export class Backport extends Component {
27
+
28
+ private readonly repoName: string;
29
+ private readonly config: JsonFile;
30
+
31
+ constructor(project: NodeProject, options: BackportOptions) {
32
+ super(project);
33
+
34
+ this.repoName = options.repoName;
35
+
36
+ this.config = new JsonFile(project, '.backportrc.json', {
37
+ // see https://github.com/sqren/backport/blob/main/docs/config-file-options.md
38
+ obj: {
39
+ repoOwner: 'cdk8s-team',
40
+ repoName: this.repoName,
41
+ signoff: true,
42
+ branchLabelMapping: {
43
+ '^backport-to-(.+)$': '$1',
44
+ },
45
+ prTitle: '{commitMessages}',
46
+ fork: false,
47
+ publishStatusCommentOnFailure: true,
48
+ publishStatusCommentOnSuccess: true,
49
+ publishStatusCommentOnAbort: true,
50
+ targetPRLabels: [project.autoApprove!.label],
51
+ },
52
+ });
53
+
54
+ // pinning because of https://github.com/sqren/backport/issues/451
55
+ // optional because it requires node 16 which is only available in the
56
+ // backport workflow environment.
57
+ project.addFields({ optionalDependencies: { backport: '8.5.0' } });
58
+
59
+ // backport task to branches based on pr labels (i.e not branch specific)
60
+ const backportTask = this.createTask(project);
61
+
62
+ // backport tasks to explicit branches based on input
63
+ for (const branch of options.branches ?? []) {
64
+ this.createTask(project, branch);
65
+ }
66
+
67
+ this.createWorkflow(project, backportTask);
68
+
69
+ }
70
+
71
+ private createTask(project: NodeProject, branch?: string): Task {
72
+ const name = branch ? `backport:${branch}` : 'backport';
73
+ const task = project.addTask(name, { requiredEnv: ['BACKPORT_PR_NUMBER', 'GITHUB_TOKEN'] });
74
+ const commands = [
75
+ 'BACKPORT_HOME=$(mktemp -d)',
76
+ 'mkdir -p ${BACKPORT_HOME}',
77
+ `cp ${this.config.path} \${BACKPORT_HOME}`,
78
+ 'cd ${BACKPORT_HOME}',
79
+ ];
80
+ const backport = ['backport', '--dir', `\${BACKPORT_HOME}/${this.repoName}`, '--accesstoken', '${GITHUB_TOKEN}', '--pr', '${BACKPORT_PR_NUMBER}'];
81
+ if (branch) {
82
+ backport.push(...['--branch', branch]);
83
+ } else {
84
+ backport.push('--non-interactive');
85
+ }
86
+
87
+ commands.push(backport.join(' '));
88
+ task.exec(commands.join(' && '));
89
+ return task;
90
+ }
91
+
92
+ private createWorkflow(project: NodeProject, task: Task) {
93
+
94
+ const backportWorkflow = project.github!.addWorkflow('backport');
95
+ backportWorkflow.on({ pullRequestTarget: { types: ['closed'] } });
96
+ backportWorkflow.addJob('backport', {
97
+ runsOn: ['ubuntu-latest'],
98
+ permissions: {
99
+ contents: JobPermission.WRITE,
100
+ },
101
+ steps: [
102
+ // needed in order to run the projen task as well
103
+ // as use the backport configuration in the repo.
104
+ {
105
+ name: 'checkout',
106
+ uses: 'actions/checkout@v3',
107
+ with: {
108
+ // required because we need the full history
109
+ // for proper backports.
110
+ 'fetch-depth': 0,
111
+ },
112
+ },
113
+ {
114
+ name: 'Set Git Identity',
115
+ run: 'git config --global user.name "github-actions" && git config --global user.email "github-actions@github.com"',
116
+ },
117
+ {
118
+ name: 'backport',
119
+ if: 'github.event.pull_request.merged == true',
120
+ run: `npx projen ${task.name}`,
121
+ env: {
122
+ GITHUB_TOKEN: '${{ secrets.PROJEN_GITHUB_TOKEN }}',
123
+ BACKPORT_PR_NUMBER: '${{ github.event.pull_request.number }}',
124
+ },
125
+ },
126
+ ],
127
+ });
128
+
129
+ }
130
+
131
+ }
@@ -1,10 +1,19 @@
1
1
  import { Component } from 'projen';
2
2
  import { NodeProject } from 'projen/lib/javascript';
3
+ /**
4
+ * Options for `Triage`.
5
+ */
6
+ export interface TriageOptions {
7
+ /**
8
+ * The repository name.
9
+ */
10
+ readonly repoName: string;
11
+ }
3
12
  /**
4
13
  * Add a Triage workflow to our repos.
5
14
  *
6
15
  * @see https://github.com/marketplace/actions/add-to-github-projects
7
16
  */
8
17
  export declare class Triage extends Component {
9
- constructor(project: NodeProject);
18
+ constructor(project: NodeProject, options: TriageOptions);
10
19
  }
@@ -9,7 +9,7 @@ const workflows_model_1 = require("projen/lib/github/workflows-model");
9
9
  * @see https://github.com/marketplace/actions/add-to-github-projects
10
10
  */
11
11
  class Triage extends projen_1.Component {
12
- constructor(project) {
12
+ constructor(project, options) {
13
13
  super(project);
14
14
  // hmm, we need to remember to update this in 2024
15
15
  // or figure out how to make this dynamic.
@@ -22,6 +22,9 @@ class Triage extends projen_1.Component {
22
22
  });
23
23
  workflow.addJob('assign-to-project', {
24
24
  permissions: { issues: workflows_model_1.JobPermission.WRITE },
25
+ // dont run this action in forks as it contains a hard link to our project board.
26
+ // see https://docs.github.com/en/actions/using-jobs/using-conditions-to-control-job-execution#example-only-run-job-for-specific-repository
27
+ if: `github.repository == cdk8s-team/${options.repoName}`,
25
28
  runsOn: ['ubuntu-latest'],
26
29
  steps: [{
27
30
  uses: 'actions/add-to-project@v0.4.0',
@@ -35,4 +38,4 @@ class Triage extends projen_1.Component {
35
38
  }
36
39
  }
37
40
  exports.Triage = Triage;
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJpYWdlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvdHJpYWdlL3RyaWFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtQ0FBbUM7QUFDbkMsdUVBQWtFO0FBR2xFOzs7O0dBSUc7QUFDSCxNQUFhLE1BQU8sU0FBUSxrQkFBUztJQUVuQyxZQUFZLE9BQW9CO1FBQzlCLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVmLGtEQUFrRDtRQUNsRCwwQ0FBMEM7UUFDMUMsTUFBTSxVQUFVLEdBQUcsZ0RBQWdELENBQUM7UUFFcEUsTUFBTSxRQUFRLEdBQUcsT0FBTyxDQUFDLE1BQU8sQ0FBQyxXQUFXLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDdkQsUUFBUSxDQUFDLEVBQUUsQ0FBQztZQUNWLE1BQU0sRUFBRTtnQkFDTixLQUFLLEVBQUUsQ0FBQyxRQUFRLENBQUM7YUFDbEI7U0FDRixDQUFDLENBQUM7UUFDSCxRQUFRLENBQUMsTUFBTSxDQUFDLG1CQUFtQixFQUFFO1lBQ25DLFdBQVcsRUFBRSxFQUFFLE1BQU0sRUFBRSwrQkFBYSxDQUFDLEtBQUssRUFBRTtZQUM1QyxNQUFNLEVBQUUsQ0FBQyxlQUFlLENBQUM7WUFDekIsS0FBSyxFQUFFLENBQUM7b0JBQ04sSUFBSSxFQUFFLCtCQUErQjtvQkFDckMsSUFBSSxFQUFFO3dCQUNKLGFBQWEsRUFBRSxVQUFVO3dCQUN6QixjQUFjLEVBQUUsb0NBQW9DO3dCQUNwRCxTQUFTLEVBQUUsY0FBYztxQkFDMUI7aUJBQ0YsQ0FBQztTQUNILENBQUMsQ0FBQztJQUVMLENBQUM7Q0FDRjtBQTdCRCx3QkE2QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdwcm9qZW4nO1xuaW1wb3J0IHsgSm9iUGVybWlzc2lvbiB9IGZyb20gJ3Byb2plbi9saWIvZ2l0aHViL3dvcmtmbG93cy1tb2RlbCc7XG5pbXBvcnQgeyBOb2RlUHJvamVjdCB9IGZyb20gJ3Byb2plbi9saWIvamF2YXNjcmlwdCc7XG5cbi8qKlxuICogQWRkIGEgVHJpYWdlIHdvcmtmbG93IHRvIG91ciByZXBvcy5cbiAqXG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9tYXJrZXRwbGFjZS9hY3Rpb25zL2FkZC10by1naXRodWItcHJvamVjdHNcbiAqL1xuZXhwb3J0IGNsYXNzIFRyaWFnZSBleHRlbmRzIENvbXBvbmVudCB7XG5cbiAgY29uc3RydWN0b3IocHJvamVjdDogTm9kZVByb2plY3QpIHtcbiAgICBzdXBlcihwcm9qZWN0KTtcblxuICAgIC8vIGhtbSwgd2UgbmVlZCB0byByZW1lbWJlciB0byB1cGRhdGUgdGhpcyBpbiAyMDI0XG4gICAgLy8gb3IgZmlndXJlIG91dCBob3cgdG8gbWFrZSB0aGlzIGR5bmFtaWMuXG4gICAgY29uc3QgcHJvamVjdFVybCA9ICdodHRwczovL2dpdGh1Yi5jb20vb3Jncy9jZGs4cy10ZWFtL3Byb2plY3RzLzEyJztcblxuICAgIGNvbnN0IHdvcmtmbG93ID0gcHJvamVjdC5naXRodWIhLmFkZFdvcmtmbG93KCd0cmlhZ2UnKTtcbiAgICB3b3JrZmxvdy5vbih7XG4gICAgICBpc3N1ZXM6IHtcbiAgICAgICAgdHlwZXM6IFsnb3BlbmVkJ10sXG4gICAgICB9LFxuICAgIH0pO1xuICAgIHdvcmtmbG93LmFkZEpvYignYXNzaWduLXRvLXByb2plY3QnLCB7XG4gICAgICBwZXJtaXNzaW9uczogeyBpc3N1ZXM6IEpvYlBlcm1pc3Npb24uV1JJVEUgfSxcbiAgICAgIHJ1bnNPbjogWyd1YnVudHUtbGF0ZXN0J10sXG4gICAgICBzdGVwczogW3tcbiAgICAgICAgdXNlczogJ2FjdGlvbnMvYWRkLXRvLXByb2plY3RAdjAuNC4wJyxcbiAgICAgICAgd2l0aDoge1xuICAgICAgICAgICdwcm9qZWN0LXVybCc6IHByb2plY3RVcmwsXG4gICAgICAgICAgJ2dpdGh1Yi10b2tlbic6ICcke3sgc2VjcmV0cy5QUk9KRU5fR0lUSFVCX1RPS0VOIH19JyxcbiAgICAgICAgICAnbGFiZWxlZCc6ICduZWVkcy10cmlhZ2UnLFxuICAgICAgICB9LFxuICAgICAgfV0sXG4gICAgfSk7XG5cbiAgfVxufSJdfQ==
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJpYWdlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvdHJpYWdlL3RyaWFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtQ0FBbUM7QUFDbkMsdUVBQWtFO0FBZWxFOzs7O0dBSUc7QUFDSCxNQUFhLE1BQU8sU0FBUSxrQkFBUztJQUVuQyxZQUFZLE9BQW9CLEVBQUUsT0FBc0I7UUFDdEQsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRWYsa0RBQWtEO1FBQ2xELDBDQUEwQztRQUMxQyxNQUFNLFVBQVUsR0FBRyxnREFBZ0QsQ0FBQztRQUVwRSxNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsTUFBTyxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUN2RCxRQUFRLENBQUMsRUFBRSxDQUFDO1lBQ1YsTUFBTSxFQUFFO2dCQUNOLEtBQUssRUFBRSxDQUFDLFFBQVEsQ0FBQzthQUNsQjtTQUNGLENBQUMsQ0FBQztRQUNILFFBQVEsQ0FBQyxNQUFNLENBQUMsbUJBQW1CLEVBQUU7WUFDbkMsV0FBVyxFQUFFLEVBQUUsTUFBTSxFQUFFLCtCQUFhLENBQUMsS0FBSyxFQUFFO1lBQzVDLGlGQUFpRjtZQUNqRiwySUFBMkk7WUFDM0ksRUFBRSxFQUFFLG1DQUFtQyxPQUFPLENBQUMsUUFBUSxFQUFFO1lBQ3pELE1BQU0sRUFBRSxDQUFDLGVBQWUsQ0FBQztZQUN6QixLQUFLLEVBQUUsQ0FBQztvQkFDTixJQUFJLEVBQUUsK0JBQStCO29CQUNyQyxJQUFJLEVBQUU7d0JBQ0osYUFBYSxFQUFFLFVBQVU7d0JBQ3pCLGNBQWMsRUFBRSxvQ0FBb0M7d0JBQ3BELFNBQVMsRUFBRSxjQUFjO3FCQUMxQjtpQkFDRixDQUFDO1NBQ0gsQ0FBQyxDQUFDO0lBRUwsQ0FBQztDQUNGO0FBaENELHdCQWdDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ3Byb2plbic7XG5pbXBvcnQgeyBKb2JQZXJtaXNzaW9uIH0gZnJvbSAncHJvamVuL2xpYi9naXRodWIvd29ya2Zsb3dzLW1vZGVsJztcbmltcG9ydCB7IE5vZGVQcm9qZWN0IH0gZnJvbSAncHJvamVuL2xpYi9qYXZhc2NyaXB0JztcblxuLyoqXG4gKiBPcHRpb25zIGZvciBgVHJpYWdlYC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUcmlhZ2VPcHRpb25zIHtcblxuICAvKipcbiAgICogVGhlIHJlcG9zaXRvcnkgbmFtZS5cbiAgICovXG4gIHJlYWRvbmx5IHJlcG9OYW1lOiBzdHJpbmc7XG5cbn1cblxuLyoqXG4gKiBBZGQgYSBUcmlhZ2Ugd29ya2Zsb3cgdG8gb3VyIHJlcG9zLlxuICpcbiAqIEBzZWUgaHR0cHM6Ly9naXRodWIuY29tL21hcmtldHBsYWNlL2FjdGlvbnMvYWRkLXRvLWdpdGh1Yi1wcm9qZWN0c1xuICovXG5leHBvcnQgY2xhc3MgVHJpYWdlIGV4dGVuZHMgQ29tcG9uZW50IHtcblxuICBjb25zdHJ1Y3Rvcihwcm9qZWN0OiBOb2RlUHJvamVjdCwgb3B0aW9uczogVHJpYWdlT3B0aW9ucykge1xuICAgIHN1cGVyKHByb2plY3QpO1xuXG4gICAgLy8gaG1tLCB3ZSBuZWVkIHRvIHJlbWVtYmVyIHRvIHVwZGF0ZSB0aGlzIGluIDIwMjRcbiAgICAvLyBvciBmaWd1cmUgb3V0IGhvdyB0byBtYWtlIHRoaXMgZHluYW1pYy5cbiAgICBjb25zdCBwcm9qZWN0VXJsID0gJ2h0dHBzOi8vZ2l0aHViLmNvbS9vcmdzL2NkazhzLXRlYW0vcHJvamVjdHMvMTInO1xuXG4gICAgY29uc3Qgd29ya2Zsb3cgPSBwcm9qZWN0LmdpdGh1YiEuYWRkV29ya2Zsb3coJ3RyaWFnZScpO1xuICAgIHdvcmtmbG93Lm9uKHtcbiAgICAgIGlzc3Vlczoge1xuICAgICAgICB0eXBlczogWydvcGVuZWQnXSxcbiAgICAgIH0sXG4gICAgfSk7XG4gICAgd29ya2Zsb3cuYWRkSm9iKCdhc3NpZ24tdG8tcHJvamVjdCcsIHtcbiAgICAgIHBlcm1pc3Npb25zOiB7IGlzc3VlczogSm9iUGVybWlzc2lvbi5XUklURSB9LFxuICAgICAgLy8gZG9udCBydW4gdGhpcyBhY3Rpb24gaW4gZm9ya3MgYXMgaXQgY29udGFpbnMgYSBoYXJkIGxpbmsgdG8gb3VyIHByb2plY3QgYm9hcmQuXG4gICAgICAvLyBzZWUgaHR0cHM6Ly9kb2NzLmdpdGh1Yi5jb20vZW4vYWN0aW9ucy91c2luZy1qb2JzL3VzaW5nLWNvbmRpdGlvbnMtdG8tY29udHJvbC1qb2ItZXhlY3V0aW9uI2V4YW1wbGUtb25seS1ydW4tam9iLWZvci1zcGVjaWZpYy1yZXBvc2l0b3J5XG4gICAgICBpZjogYGdpdGh1Yi5yZXBvc2l0b3J5ID09IGNkazhzLXRlYW0vJHtvcHRpb25zLnJlcG9OYW1lfWAsXG4gICAgICBydW5zT246IFsndWJ1bnR1LWxhdGVzdCddLFxuICAgICAgc3RlcHM6IFt7XG4gICAgICAgIHVzZXM6ICdhY3Rpb25zL2FkZC10by1wcm9qZWN0QHYwLjQuMCcsXG4gICAgICAgIHdpdGg6IHtcbiAgICAgICAgICAncHJvamVjdC11cmwnOiBwcm9qZWN0VXJsLFxuICAgICAgICAgICdnaXRodWItdG9rZW4nOiAnJHt7IHNlY3JldHMuUFJPSkVOX0dJVEhVQl9UT0tFTiB9fScsXG4gICAgICAgICAgJ2xhYmVsZWQnOiAnbmVlZHMtdHJpYWdlJyxcbiAgICAgICAgfSxcbiAgICAgIH1dLFxuICAgIH0pO1xuXG4gIH1cbn0iXX0=
@@ -2,6 +2,18 @@ import { Component } from 'projen';
2
2
  import { JobPermission } from 'projen/lib/github/workflows-model';
3
3
  import { NodeProject } from 'projen/lib/javascript';
4
4
 
5
+ /**
6
+ * Options for `Triage`.
7
+ */
8
+ export interface TriageOptions {
9
+
10
+ /**
11
+ * The repository name.
12
+ */
13
+ readonly repoName: string;
14
+
15
+ }
16
+
5
17
  /**
6
18
  * Add a Triage workflow to our repos.
7
19
  *
@@ -9,7 +21,7 @@ import { NodeProject } from 'projen/lib/javascript';
9
21
  */
10
22
  export class Triage extends Component {
11
23
 
12
- constructor(project: NodeProject) {
24
+ constructor(project: NodeProject, options: TriageOptions) {
13
25
  super(project);
14
26
 
15
27
  // hmm, we need to remember to update this in 2024
@@ -24,6 +36,9 @@ export class Triage extends Component {
24
36
  });
25
37
  workflow.addJob('assign-to-project', {
26
38
  permissions: { issues: JobPermission.WRITE },
39
+ // dont run this action in forks as it contains a hard link to our project board.
40
+ // see https://docs.github.com/en/actions/using-jobs/using-conditions-to-control-job-execution#example-only-run-job-for-specific-repository
41
+ if: `github.repository == cdk8s-team/${options.repoName}`,
27
42
  runsOn: ['ubuntu-latest'],
28
43
  steps: [{
29
44
  uses: 'actions/add-to-project@v0.4.0',
@@ -6,6 +6,7 @@ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const maker = require("codemaker");
7
7
  const projen_1 = require("projen");
8
8
  const node = require("./node");
9
+ const backport_1 = require("../components/backport/backport");
9
10
  const code = new maker.CodeMaker();
10
11
  /**
11
12
  * @pjid cdk8s-team-jsii-project
@@ -35,11 +36,14 @@ class Cdk8sTeamJsiiProject extends projen_1.cdk.JsiiProject {
35
36
  ...options,
36
37
  });
37
38
  node.addComponents(this, repoName);
39
+ if (options.backport ?? false) {
40
+ new backport_1.Backport(this, { branches: options.backportBranches, repoName });
41
+ }
38
42
  }
39
43
  }
40
44
  exports.Cdk8sTeamJsiiProject = Cdk8sTeamJsiiProject;
41
45
  _a = JSII_RTTI_SYMBOL_1;
42
- Cdk8sTeamJsiiProject[_a] = { fqn: "@cdk8s/projen-common.Cdk8sTeamJsiiProject", version: "0.0.277" };
46
+ Cdk8sTeamJsiiProject[_a] = { fqn: "@cdk8s/projen-common.Cdk8sTeamJsiiProject", version: "0.0.279" };
43
47
  function pythonTarget(name) {
44
48
  const repoName = node.buildRepositoryName(name);
45
49
  return {
@@ -73,4 +77,4 @@ function golangTarget(repoName, branch) {
73
77
  moduleName: `github.com/cdk8s-team/${repoName}-go`,
74
78
  };
75
79
  }
76
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jsii.js","sourceRoot":"","sources":["../../src/projects/jsii.ts"],"names":[],"mappings":"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","sourcesContent":["import * as maker from 'codemaker';\nimport { cdk } from 'projen';\nimport * as node from './node';\nimport * as ts from './typescript';\n\nconst code = new maker.CodeMaker();\n\n/**\n * Options for `Cdk8sTeamJsiiProject`.\n *\n * Note that this extends `Cdk8sTeamTypeScriptProjectOptions` and not `cdk.JsiiProjectOptions`\n * because `cdk.JsiiProjectOptions` has required properties (namely 'author' and 'authorAddress')\n * that we want to hardcode and disallow customization of. This means that any jsii specific feature\n * cannot be customized on the project level. This is ok because we don't expect much deviation\n * with those features between projects. If this turns out to not be the case, we will change appropriately.\n */\nexport interface Cdk8sTeamJsiiProjectOptions extends ts.Cdk8sTeamTypeScriptProjectOptions {\n\n  /**\n   * Publish Golang bindings to GitHub.\n   *\n   * @default true\n   */\n  readonly golang?: boolean;\n\n  /**\n   * Name of the branch in the golang repository to publish to.\n   *\n   * @default 'main'\n   */\n  readonly golangBranch?: string;\n\n  /**\n   * Publish Python bindings to PyPI.\n   *\n   * @default true\n   */\n  readonly pypi?: boolean;\n\n  /**\n   * Publish Java bindings to Maven.\n   *\n   * @default true\n   */\n  readonly maven?: boolean;\n\n  /**\n   * Publish Dotnet bindings to Nuget.\n   *\n   * @default true\n   */\n  readonly nuget?: boolean;\n\n}\n\n/**\n * @pjid cdk8s-team-jsii-project\n */\nexport class Cdk8sTeamJsiiProject extends cdk.JsiiProject {\n\n  constructor(options: Cdk8sTeamJsiiProjectOptions) {\n\n    node.validateOptions(options);\n    node.validateProjectName(options);\n\n    const fixedTypeScriptOptions = node.buildNodeProjectFixedOptions(options);\n    const defaultTypeScriptOptions = node.buildNodeProjectDefaultOptions(options);\n    const repoName = options.repoName ?? node.buildRepositoryName(options.name);\n\n    const golangBranch = options.golangBranch ?? 'main';\n    const golang = options.golang ?? true;\n    const pypi = options.pypi ?? true;\n    const maven = options.maven ?? true;\n    const nuget = options.nuget ?? true;\n\n    super({\n      author: fixedTypeScriptOptions.authorName!,\n      repositoryUrl: fixedTypeScriptOptions.repository!,\n      authorAddress: 'https://aws.amazon.com',\n      publishToPypi: pypi ? pythonTarget(options.name) : undefined,\n      publishToMaven: maven ? javaTarget(options.name) : undefined,\n      publishToNuget: nuget ? dotnetTarget(options.name) : undefined,\n      publishToGo: golang ? golangTarget(repoName, golangBranch) : undefined,\n      ...fixedTypeScriptOptions,\n      ...defaultTypeScriptOptions,\n      ...options,\n    });\n\n    node.addComponents(this, repoName);\n\n  }\n\n}\n\nfunction pythonTarget(name: string): cdk.JsiiPythonTarget {\n  const repoName = node.buildRepositoryName(name);\n  return {\n    distName: repoName,\n    module: repoName.replace(/-/g, '_'),\n  };\n}\n\nfunction javaTarget(name: string): cdk.JsiiJavaTarget {\n  const repoName = node.buildRepositoryName(name);\n  const pkg = repoName.substring(node.NAME_PREFIX.length).replace(/-/g, '');\n  return {\n    mavenArtifactId: repoName,\n    mavenGroupId: 'org.cdk8s',\n    javaPackage: `org.cdk8s${pkg ? `.${pkg}` : ''}`,\n  };\n}\n\nfunction dotnetTarget(name: string) : cdk.JsiiDotNetTarget {\n  const repoName = node.buildRepositoryName(name);\n  const artifact = repoName.substring(node.NAME_PREFIX.length);\n  const pkg = code.toPascalCase(artifact).replace(/-/g, '');\n  return {\n    dotNetNamespace: `Org.Cdk8s${pkg ? `.${pkg}` : ''}`,\n    packageId: `Org.Cdk8s${pkg ? `.${pkg}` : ''}`,\n  };\n}\n\nfunction golangTarget(repoName: string, branch: string): cdk.JsiiGoTarget {\n  return {\n    gitUserName: 'cdk8s-automation',\n    gitUserEmail: 'cdk8s-team@amazon.com',\n    gitBranch: branch,\n    moduleName: `github.com/cdk8s-team/${repoName}-go`,\n  };\n}\n"]}
80
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jsii.js","sourceRoot":"","sources":["../../src/projects/jsii.ts"],"names":[],"mappings":"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","sourcesContent":["import * as maker from 'codemaker';\nimport { cdk } from 'projen';\nimport * as node from './node';\nimport * as ts from './typescript';\nimport { Backport } from '../components/backport/backport';\n\nconst code = new maker.CodeMaker();\n\n/**\n * Options for `Cdk8sTeamJsiiProject`.\n *\n * Note that this extends `Cdk8sTeamTypeScriptProjectOptions` and not `cdk.JsiiProjectOptions`\n * because `cdk.JsiiProjectOptions` has required properties (namely 'author' and 'authorAddress')\n * that we want to hardcode and disallow customization of. This means that any jsii specific feature\n * cannot be customized on the project level. This is ok because we don't expect much deviation\n * with those features between projects. If this turns out to not be the case, we will change appropriately.\n */\nexport interface Cdk8sTeamJsiiProjectOptions extends ts.Cdk8sTeamTypeScriptProjectOptions {\n\n  /**\n   * Publish Golang bindings to GitHub.\n   *\n   * @default true\n   */\n  readonly golang?: boolean;\n\n  /**\n   * Name of the branch in the golang repository to publish to.\n   *\n   * @default 'main'\n   */\n  readonly golangBranch?: string;\n\n  /**\n   * Publish Python bindings to PyPI.\n   *\n   * @default true\n   */\n  readonly pypi?: boolean;\n\n  /**\n   * Publish Java bindings to Maven.\n   *\n   * @default true\n   */\n  readonly maven?: boolean;\n\n  /**\n   * Publish Dotnet bindings to Nuget.\n   *\n   * @default true\n   */\n  readonly nuget?: boolean;\n\n}\n\n/**\n * @pjid cdk8s-team-jsii-project\n */\nexport class Cdk8sTeamJsiiProject extends cdk.JsiiProject {\n\n  constructor(options: Cdk8sTeamJsiiProjectOptions) {\n\n    node.validateOptions(options);\n    node.validateProjectName(options);\n\n    const fixedTypeScriptOptions = node.buildNodeProjectFixedOptions(options);\n    const defaultTypeScriptOptions = node.buildNodeProjectDefaultOptions(options);\n    const repoName = options.repoName ?? node.buildRepositoryName(options.name);\n\n    const golangBranch = options.golangBranch ?? 'main';\n    const golang = options.golang ?? true;\n    const pypi = options.pypi ?? true;\n    const maven = options.maven ?? true;\n    const nuget = options.nuget ?? true;\n\n    super({\n      author: fixedTypeScriptOptions.authorName!,\n      repositoryUrl: fixedTypeScriptOptions.repository!,\n      authorAddress: 'https://aws.amazon.com',\n      publishToPypi: pypi ? pythonTarget(options.name) : undefined,\n      publishToMaven: maven ? javaTarget(options.name) : undefined,\n      publishToNuget: nuget ? dotnetTarget(options.name) : undefined,\n      publishToGo: golang ? golangTarget(repoName, golangBranch) : undefined,\n      ...fixedTypeScriptOptions,\n      ...defaultTypeScriptOptions,\n      ...options,\n    });\n\n    node.addComponents(this, repoName);\n\n    if (options.backport ?? false) {\n      new Backport(this, { branches: options.backportBranches, repoName });\n    }\n\n  }\n\n}\n\nfunction pythonTarget(name: string): cdk.JsiiPythonTarget {\n  const repoName = node.buildRepositoryName(name);\n  return {\n    distName: repoName,\n    module: repoName.replace(/-/g, '_'),\n  };\n}\n\nfunction javaTarget(name: string): cdk.JsiiJavaTarget {\n  const repoName = node.buildRepositoryName(name);\n  const pkg = repoName.substring(node.NAME_PREFIX.length).replace(/-/g, '');\n  return {\n    mavenArtifactId: repoName,\n    mavenGroupId: 'org.cdk8s',\n    javaPackage: `org.cdk8s${pkg ? `.${pkg}` : ''}`,\n  };\n}\n\nfunction dotnetTarget(name: string) : cdk.JsiiDotNetTarget {\n  const repoName = node.buildRepositoryName(name);\n  const artifact = repoName.substring(node.NAME_PREFIX.length);\n  const pkg = code.toPascalCase(artifact).replace(/-/g, '');\n  return {\n    dotNetNamespace: `Org.Cdk8s${pkg ? `.${pkg}` : ''}`,\n    packageId: `Org.Cdk8s${pkg ? `.${pkg}` : ''}`,\n  };\n}\n\nfunction golangTarget(repoName: string, branch: string): cdk.JsiiGoTarget {\n  return {\n    gitUserName: 'cdk8s-automation',\n    gitUserEmail: 'cdk8s-team@amazon.com',\n    gitBranch: branch,\n    moduleName: `github.com/cdk8s-team/${repoName}-go`,\n  };\n}\n"]}
@@ -37,6 +37,18 @@ export interface Cdk8sTeamNodeProjectOptions extends javascript.NodeProjectOptio
37
37
  * @default - the package name.
38
38
  */
39
39
  readonly repoName?: string;
40
+ /**
41
+ * Configure a backport workflow.
42
+ *
43
+ * @default false
44
+ */
45
+ readonly backport?: boolean;
46
+ /**
47
+ * Branches to backport to.
48
+ *
49
+ * @default - Will be derived from PR labels.
50
+ */
51
+ readonly backportBranches?: string[];
40
52
  }
41
53
  /**
42
54
  * @pjid cdk8s-team-node-project
@@ -4,6 +4,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
4
4
  exports.addComponents = exports.validateProjectName = exports.validateOptions = exports.Cdk8sTeamNodeProject = exports.buildRepositoryName = exports.buildNodeProjectDefaultOptions = exports.buildNodeProjectFixedOptions = exports.defaultOptionsKeys = exports.fixedOptionsKeys = exports.SCOPE = exports.NAME_PREFIX = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const projen_1 = require("projen");
7
+ const backport_1 = require("../components/backport/backport");
7
8
  const code_of_conduct_1 = require("../components/code-of-conduct/code-of-conduct");
8
9
  const devco_1 = require("../components/dco/devco");
9
10
  const git_hooks_1 = require("../components/git-hooks/git-hooks");
@@ -85,11 +86,14 @@ class Cdk8sTeamNodeProject extends projen_1.javascript.NodeProject {
85
86
  });
86
87
  const repoName = options.repoName ?? buildRepositoryName(options.name);
87
88
  addComponents(this, repoName);
89
+ if (options.backport ?? false) {
90
+ new backport_1.Backport(this, { branches: options.backportBranches, repoName });
91
+ }
88
92
  }
89
93
  }
90
94
  exports.Cdk8sTeamNodeProject = Cdk8sTeamNodeProject;
91
95
  _a = JSII_RTTI_SYMBOL_1;
92
- Cdk8sTeamNodeProject[_a] = { fqn: "@cdk8s/projen-common.Cdk8sTeamNodeProject", version: "0.0.277" };
96
+ Cdk8sTeamNodeProject[_a] = { fqn: "@cdk8s/projen-common.Cdk8sTeamNodeProject", version: "0.0.279" };
93
97
  /**
94
98
  * Validate that the options map does not contain any invalid option.
95
99
  * This would usually be implemented at compile time using Omit/Pick but jsii
@@ -140,7 +144,7 @@ function addComponents(project, repoName) {
140
144
  new git_hooks_1.GitHooks(project);
141
145
  new issue_templates_1.IssueTemplates(project, { repoName });
142
146
  new security_1.SecurityMD(project);
143
- new triage_1.Triage(project);
147
+ new triage_1.Triage(project, { repoName });
144
148
  }
145
149
  exports.addComponents = addComponents;
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.js","sourceRoot":"","sources":["../../src/projects/node.ts"],"names":[],"mappings":"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","sourcesContent":["import { javascript } from 'projen';\nimport { NodeProject } from 'projen/lib/javascript';\nimport { CodeOfConductMD } from '../components/code-of-conduct/code-of-conduct';\nimport { DCO } from '../components/dco/devco';\nimport { GitHooks } from '../components/git-hooks/git-hooks';\nimport { IssueTemplates } from '../components/issue-templates/issue-templates';\nimport { SecurityMD } from '../components/security/security';\nimport { Triage } from '../components/triage/triage';\n\nexport const NAME_PREFIX = 'cdk8s-';\nexport const SCOPE = '@cdk8s/';\n\n/**\n * Subset of options that should be fixed for all cdk8s-team node projects.\n * These will not be available for customization by individual projects.\n */\nexport const fixedOptionsKeys = [\n  'authorName',\n  'authorEmail',\n  'repository',\n  'autoApproveOptions',\n  'autoApproveUpgrades',\n\n  // this is deprecated in favor of 'release'.\n  // lets disallow using it.\n  'releaseWorkflow',\n] as const;\nexport type fixedOptionsKeysType = typeof fixedOptionsKeys[number];\n\n/**\n * Subset of options that have default values for all cdk8s-team node projects.\n * These will be available for customization by individual projects.\n */\nexport const defaultOptionsKeys = [\n  'releaseToNpm',\n  'release',\n  'minNodeVersion',\n] as const;\nexport type defaultOptionsKeysType = typeof defaultOptionsKeys[number];\n\n/**\n * Create the fixed typescript project options.\n */\nexport function buildNodeProjectFixedOptions(options: Cdk8sTeamNodeProjectOptions):\nPick<javascript.NodeProjectOptions, fixedOptionsKeysType> {\n\n  return {\n    authorName: 'Amazon Web Services',\n    repository: `https://github.com/cdk8s-team/${options.repoName ?? buildRepositoryName(options.name)}.git`,\n    autoApproveOptions: {\n      allowedUsernames: ['cdk8s-automation'],\n      secret: 'GITHUB_TOKEN',\n    },\n    autoApproveUpgrades: true,\n    releaseWorkflow: options.release,\n  };\n}\n\n/**\n * Create the default typescript project options.\n */\nexport function buildNodeProjectDefaultOptions(options: Cdk8sTeamNodeProjectOptions):\nPick<javascript.NodeProjectOptions, defaultOptionsKeysType> {\n  return {\n    // if release is enabled, default to releasing to npm as well\n    releaseToNpm: options.release,\n    minNodeVersion: '14.17.0',\n  };\n}\n\n/**\n * Create the repository name based on the project name.\n */\nexport function buildRepositoryName(projectName: string) {\n  return projectName.startsWith(SCOPE) ? projectName.replace(SCOPE, NAME_PREFIX) : projectName;\n}\n\n/**\n * Options for `Cdk8sTeamNodeProject`.\n */\nexport interface Cdk8sTeamNodeProjectOptions extends javascript.NodeProjectOptions {\n\n  /**\n   * The name of the repository inside the cdk8s-team\n   * org where the code of the project is locate in.\n   *\n   * @default - the package name.\n   */\n  readonly repoName?: string;\n\n}\n\n/**\n * @pjid cdk8s-team-node-project\n */\nexport class Cdk8sTeamNodeProject extends javascript.NodeProject {\n\n  constructor(options: Cdk8sTeamNodeProjectOptions) {\n\n    validateOptions(options);\n    validateProjectName(options);\n\n    const fixedOptions = buildNodeProjectFixedOptions(options);\n    const defaultOptions = buildNodeProjectDefaultOptions(options);\n\n    super({\n      ...fixedOptions,\n      ...defaultOptions,\n      ...options,\n    });\n\n    const repoName = options.repoName ?? buildRepositoryName(options.name);\n\n    addComponents(this, repoName);\n\n  }\n\n}\n\n/**\n * Validate that the options map does not contain any invalid option.\n * This would usually be implemented at compile time using Omit/Pick but jsii\n * doesn't allow this.\n */\nexport function validateOptions(options: any) {\n\n  const keys = Object.keys(options);\n\n  for (const key of fixedOptionsKeys) {\n    if (keys.includes(key)) {\n      throw new Error(`Invalid option: ${key}`);\n    }\n  }\n\n}\n\n/**\n * Validate the name of a project.\n */\nexport function validateProjectName(options: Cdk8sTeamNodeProjectOptions) {\n\n  // snowflake for monorepos\n  if (options.name === 'root') {\n    return;\n  }\n\n  // snowflake for cdk8s-core\n  if (options.name === 'cdk8s') {\n    return;\n  }\n\n  // otherwise we want it to either start with the '@cdk8s' scope of 'cdk8s-' prefix.\n  const name = options.name;\n  const scoped = name.startsWith('@');\n\n  if (scoped) {\n    if (!name.startsWith(SCOPE)) {\n      throw new Error(`Illegal project scope: ${name}. Scope must be '@cdk8s/'`);\n    }\n  } else {\n    if (!name.startsWith(NAME_PREFIX)) {\n      throw new Error(`Illegal project name: ${name}. Name must start with 'cdk8s-'`);\n    }\n  }\n\n}\n\n/**\n * Add common components to the project.\n */\nexport function addComponents(project: NodeProject, repoName: string) {\n\n  new CodeOfConductMD(project);\n  new DCO(project);\n  new GitHooks(project);\n  new IssueTemplates(project, { repoName });\n  new SecurityMD(project);\n  new Triage(project);\n\n}\n\n"]}
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.js","sourceRoot":"","sources":["../../src/projects/node.ts"],"names":[],"mappings":"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","sourcesContent":["import { javascript } from 'projen';\nimport { NodeProject } from 'projen/lib/javascript';\nimport { Backport } from '../components/backport/backport';\nimport { CodeOfConductMD } from '../components/code-of-conduct/code-of-conduct';\nimport { DCO } from '../components/dco/devco';\nimport { GitHooks } from '../components/git-hooks/git-hooks';\nimport { IssueTemplates } from '../components/issue-templates/issue-templates';\nimport { SecurityMD } from '../components/security/security';\nimport { Triage } from '../components/triage/triage';\n\nexport const NAME_PREFIX = 'cdk8s-';\nexport const SCOPE = '@cdk8s/';\n\n/**\n * Subset of options that should be fixed for all cdk8s-team node projects.\n * These will not be available for customization by individual projects.\n */\nexport const fixedOptionsKeys = [\n  'authorName',\n  'authorEmail',\n  'repository',\n  'autoApproveOptions',\n  'autoApproveUpgrades',\n\n  // this is deprecated in favor of 'release'.\n  // lets disallow using it.\n  'releaseWorkflow',\n] as const;\nexport type fixedOptionsKeysType = typeof fixedOptionsKeys[number];\n\n/**\n * Subset of options that have default values for all cdk8s-team node projects.\n * These will be available for customization by individual projects.\n */\nexport const defaultOptionsKeys = [\n  'releaseToNpm',\n  'release',\n  'minNodeVersion',\n] as const;\nexport type defaultOptionsKeysType = typeof defaultOptionsKeys[number];\n\n/**\n * Create the fixed typescript project options.\n */\nexport function buildNodeProjectFixedOptions(options: Cdk8sTeamNodeProjectOptions):\nPick<javascript.NodeProjectOptions, fixedOptionsKeysType> {\n\n  return {\n    authorName: 'Amazon Web Services',\n    repository: `https://github.com/cdk8s-team/${options.repoName ?? buildRepositoryName(options.name)}.git`,\n    autoApproveOptions: {\n      allowedUsernames: ['cdk8s-automation'],\n      secret: 'GITHUB_TOKEN',\n    },\n    autoApproveUpgrades: true,\n    releaseWorkflow: options.release,\n  };\n}\n\n/**\n * Create the default typescript project options.\n */\nexport function buildNodeProjectDefaultOptions(options: Cdk8sTeamNodeProjectOptions):\nPick<javascript.NodeProjectOptions, defaultOptionsKeysType> {\n  return {\n    // if release is enabled, default to releasing to npm as well\n    releaseToNpm: options.release,\n    minNodeVersion: '14.17.0',\n  };\n}\n\n/**\n * Create the repository name based on the project name.\n */\nexport function buildRepositoryName(projectName: string) {\n  return projectName.startsWith(SCOPE) ? projectName.replace(SCOPE, NAME_PREFIX) : projectName;\n}\n\n/**\n * Options for `Cdk8sTeamNodeProject`.\n */\nexport interface Cdk8sTeamNodeProjectOptions extends javascript.NodeProjectOptions {\n\n  /**\n   * The name of the repository inside the cdk8s-team\n   * org where the code of the project is locate in.\n   *\n   * @default - the package name.\n   */\n  readonly repoName?: string;\n\n  /**\n   * Configure a backport workflow.\n   *\n   * @default false\n   */\n  readonly backport?: boolean;\n\n  /**\n   * Branches to backport to.\n   *\n   * @default - Will be derived from PR labels.\n   */\n  readonly backportBranches?: string[];\n\n}\n\n/**\n * @pjid cdk8s-team-node-project\n */\nexport class Cdk8sTeamNodeProject extends javascript.NodeProject {\n\n  constructor(options: Cdk8sTeamNodeProjectOptions) {\n\n    validateOptions(options);\n    validateProjectName(options);\n\n    const fixedOptions = buildNodeProjectFixedOptions(options);\n    const defaultOptions = buildNodeProjectDefaultOptions(options);\n\n    super({\n      ...fixedOptions,\n      ...defaultOptions,\n      ...options,\n    });\n\n    const repoName = options.repoName ?? buildRepositoryName(options.name);\n\n    addComponents(this, repoName);\n\n    if (options.backport ?? false) {\n      new Backport(this, { branches: options.backportBranches, repoName });\n    }\n\n  }\n\n}\n\n/**\n * Validate that the options map does not contain any invalid option.\n * This would usually be implemented at compile time using Omit/Pick but jsii\n * doesn't allow this.\n */\nexport function validateOptions(options: any) {\n\n  const keys = Object.keys(options);\n\n  for (const key of fixedOptionsKeys) {\n    if (keys.includes(key)) {\n      throw new Error(`Invalid option: ${key}`);\n    }\n  }\n\n}\n\n/**\n * Validate the name of a project.\n */\nexport function validateProjectName(options: Cdk8sTeamNodeProjectOptions) {\n\n  // snowflake for monorepos\n  if (options.name === 'root') {\n    return;\n  }\n\n  // snowflake for cdk8s-core\n  if (options.name === 'cdk8s') {\n    return;\n  }\n\n  // otherwise we want it to either start with the '@cdk8s' scope of 'cdk8s-' prefix.\n  const name = options.name;\n  const scoped = name.startsWith('@');\n\n  if (scoped) {\n    if (!name.startsWith(SCOPE)) {\n      throw new Error(`Illegal project scope: ${name}. Scope must be '@cdk8s/'`);\n    }\n  } else {\n    if (!name.startsWith(NAME_PREFIX)) {\n      throw new Error(`Illegal project name: ${name}. Name must start with 'cdk8s-'`);\n    }\n  }\n\n}\n\n/**\n * Add common components to the project.\n */\nexport function addComponents(project: NodeProject, repoName: string) {\n\n  new CodeOfConductMD(project);\n  new DCO(project);\n  new GitHooks(project);\n  new IssueTemplates(project, { repoName });\n  new SecurityMD(project);\n  new Triage(project, { repoName });\n\n}\n\n"]}
@@ -10,6 +10,18 @@ export interface Cdk8sTeamTypeScriptProjectOptions extends typescript.TypeScript
10
10
  * @default - the package name.
11
11
  */
12
12
  readonly repoName?: string;
13
+ /**
14
+ * Configure a backport workflow.
15
+ *
16
+ * @default false
17
+ */
18
+ readonly backport?: boolean;
19
+ /**
20
+ * Branches to backport to.
21
+ *
22
+ * @default - Will be derived from PR labels.
23
+ */
24
+ readonly backportBranches?: string[];
13
25
  }
14
26
  /**
15
27
  * @pjid cdk8s-team-typescript-project
@@ -5,6 +5,7 @@ exports.Cdk8sTeamTypeScriptProject = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const projen_1 = require("projen");
7
7
  const node = require("./node");
8
+ const backport_1 = require("../components/backport/backport");
8
9
  /**
9
10
  * @pjid cdk8s-team-typescript-project
10
11
  */
@@ -21,9 +22,12 @@ class Cdk8sTeamTypeScriptProject extends projen_1.typescript.TypeScriptProject {
21
22
  });
22
23
  const repoName = options.repoName ?? node.buildRepositoryName(options.name);
23
24
  node.addComponents(this, repoName);
25
+ if (options.backport ?? false) {
26
+ new backport_1.Backport(this, { branches: options.backportBranches, repoName });
27
+ }
24
28
  }
25
29
  }
26
30
  exports.Cdk8sTeamTypeScriptProject = Cdk8sTeamTypeScriptProject;
27
31
  _a = JSII_RTTI_SYMBOL_1;
28
- Cdk8sTeamTypeScriptProject[_a] = { fqn: "@cdk8s/projen-common.Cdk8sTeamTypeScriptProject", version: "0.0.277" };
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXNjcmlwdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wcm9qZWN0cy90eXBlc2NyaXB0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsbUNBQW9DO0FBQ3BDLCtCQUErQjtBQWlCL0I7O0dBRUc7QUFDSCxNQUFhLDBCQUEyQixTQUFRLG1CQUFVLENBQUMsaUJBQWlCO0lBRTFFLFlBQVksT0FBMEM7UUFFcEQsSUFBSSxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUM5QixJQUFJLENBQUMsbUJBQW1CLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFbEMsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLDRCQUE0QixDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2hFLE1BQU0sY0FBYyxHQUFHLElBQUksQ0FBQyw4QkFBOEIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUdwRSxLQUFLLENBQUM7WUFDSixHQUFHLFlBQVk7WUFDZixHQUFHLGNBQWM7WUFDakIsR0FBRyxPQUFPO1NBQ1gsQ0FBQyxDQUFDO1FBRUgsTUFBTSxRQUFRLEdBQUcsT0FBTyxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsbUJBQW1CLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRTVFLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBRXJDLENBQUM7O0FBckJILGdFQXVCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHR5cGVzY3JpcHQgfSBmcm9tICdwcm9qZW4nO1xuaW1wb3J0ICogYXMgbm9kZSBmcm9tICcuL25vZGUnO1xuXG4vKipcbiAqIE9wdGlvbnMgZm9yIGBDZGs4c1RlYW1UeXBlU2NyaXB0UHJvamVjdGAuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ2RrOHNUZWFtVHlwZVNjcmlwdFByb2plY3RPcHRpb25zIGV4dGVuZHMgdHlwZXNjcmlwdC5UeXBlU2NyaXB0UHJvamVjdE9wdGlvbnMge1xuXG4gIC8qKlxuICAgKiBUaGUgbmFtZSBvZiB0aGUgcmVwb3NpdG9yeSBpbnNpZGUgdGhlIGNkazhzLXRlYW1cbiAgICogb3JnIHdoZXJlIHRoZSBjb2RlIG9mIHRoZSBwcm9qZWN0IGlzIGxvY2F0ZSBpbi5cbiAgICpcbiAgICogQGRlZmF1bHQgLSB0aGUgcGFja2FnZSBuYW1lLlxuICAgKi9cbiAgcmVhZG9ubHkgcmVwb05hbWU/OiBzdHJpbmc7XG5cbn1cblxuLyoqXG4gKiBAcGppZCBjZGs4cy10ZWFtLXR5cGVzY3JpcHQtcHJvamVjdFxuICovXG5leHBvcnQgY2xhc3MgQ2RrOHNUZWFtVHlwZVNjcmlwdFByb2plY3QgZXh0ZW5kcyB0eXBlc2NyaXB0LlR5cGVTY3JpcHRQcm9qZWN0IHtcblxuICBjb25zdHJ1Y3RvcihvcHRpb25zOiBDZGs4c1RlYW1UeXBlU2NyaXB0UHJvamVjdE9wdGlvbnMpIHtcblxuICAgIG5vZGUudmFsaWRhdGVPcHRpb25zKG9wdGlvbnMpO1xuICAgIG5vZGUudmFsaWRhdGVQcm9qZWN0TmFtZShvcHRpb25zKTtcblxuICAgIGNvbnN0IGZpeGVkT3B0aW9ucyA9IG5vZGUuYnVpbGROb2RlUHJvamVjdEZpeGVkT3B0aW9ucyhvcHRpb25zKTtcbiAgICBjb25zdCBkZWZhdWx0T3B0aW9ucyA9IG5vZGUuYnVpbGROb2RlUHJvamVjdERlZmF1bHRPcHRpb25zKG9wdGlvbnMpO1xuXG5cbiAgICBzdXBlcih7XG4gICAgICAuLi5maXhlZE9wdGlvbnMsXG4gICAgICAuLi5kZWZhdWx0T3B0aW9ucyxcbiAgICAgIC4uLm9wdGlvbnMsXG4gICAgfSk7XG5cbiAgICBjb25zdCByZXBvTmFtZSA9IG9wdGlvbnMucmVwb05hbWUgPz8gbm9kZS5idWlsZFJlcG9zaXRvcnlOYW1lKG9wdGlvbnMubmFtZSk7XG5cbiAgICBub2RlLmFkZENvbXBvbmVudHModGhpcywgcmVwb05hbWUpO1xuXG4gIH1cblxufVxuIl19
32
+ Cdk8sTeamTypeScriptProject[_a] = { fqn: "@cdk8s/projen-common.Cdk8sTeamTypeScriptProject", version: "0.0.279" };
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXNjcmlwdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wcm9qZWN0cy90eXBlc2NyaXB0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsbUNBQW9DO0FBQ3BDLCtCQUErQjtBQUMvQiw4REFBMkQ7QUErQjNEOztHQUVHO0FBQ0gsTUFBYSwwQkFBMkIsU0FBUSxtQkFBVSxDQUFDLGlCQUFpQjtJQUUxRSxZQUFZLE9BQTBDO1FBRXBELElBQUksQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDOUIsSUFBSSxDQUFDLG1CQUFtQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRWxDLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyw0QkFBNEIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNoRSxNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsOEJBQThCLENBQUMsT0FBTyxDQUFDLENBQUM7UUFHcEUsS0FBSyxDQUFDO1lBQ0osR0FBRyxZQUFZO1lBQ2YsR0FBRyxjQUFjO1lBQ2pCLEdBQUcsT0FBTztTQUNYLENBQUMsQ0FBQztRQUVILE1BQU0sUUFBUSxHQUFHLE9BQU8sQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDLG1CQUFtQixDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUU1RSxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxRQUFRLENBQUMsQ0FBQztRQUVuQyxJQUFJLE9BQU8sQ0FBQyxRQUFRLElBQUksS0FBSyxFQUFFO1lBQzdCLElBQUksbUJBQVEsQ0FBQyxJQUFJLEVBQUUsRUFBRSxRQUFRLEVBQUUsT0FBTyxDQUFDLGdCQUFnQixFQUFFLFFBQVEsRUFBRSxDQUFDLENBQUM7U0FDdEU7SUFFSCxDQUFDOztBQXpCSCxnRUEyQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB0eXBlc2NyaXB0IH0gZnJvbSAncHJvamVuJztcbmltcG9ydCAqIGFzIG5vZGUgZnJvbSAnLi9ub2RlJztcbmltcG9ydCB7IEJhY2twb3J0IH0gZnJvbSAnLi4vY29tcG9uZW50cy9iYWNrcG9ydC9iYWNrcG9ydCc7XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgYENkazhzVGVhbVR5cGVTY3JpcHRQcm9qZWN0YC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDZGs4c1RlYW1UeXBlU2NyaXB0UHJvamVjdE9wdGlvbnMgZXh0ZW5kcyB0eXBlc2NyaXB0LlR5cGVTY3JpcHRQcm9qZWN0T3B0aW9ucyB7XG5cbiAgLyoqXG4gICAqIFRoZSBuYW1lIG9mIHRoZSByZXBvc2l0b3J5IGluc2lkZSB0aGUgY2RrOHMtdGVhbVxuICAgKiBvcmcgd2hlcmUgdGhlIGNvZGUgb2YgdGhlIHByb2plY3QgaXMgbG9jYXRlIGluLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIHRoZSBwYWNrYWdlIG5hbWUuXG4gICAqL1xuICByZWFkb25seSByZXBvTmFtZT86IHN0cmluZztcblxuICAvKipcbiAgICogQ29uZmlndXJlIGEgYmFja3BvcnQgd29ya2Zsb3cuXG4gICAqXG4gICAqIEBkZWZhdWx0IGZhbHNlXG4gICAqL1xuICByZWFkb25seSBiYWNrcG9ydD86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIEJyYW5jaGVzIHRvIGJhY2twb3J0IHRvLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIFdpbGwgYmUgZGVyaXZlZCBmcm9tIFBSIGxhYmVscy5cbiAgICovXG4gIHJlYWRvbmx5IGJhY2twb3J0QnJhbmNoZXM/OiBzdHJpbmdbXTtcblxufVxuXG4vKipcbiAqIEBwamlkIGNkazhzLXRlYW0tdHlwZXNjcmlwdC1wcm9qZWN0XG4gKi9cbmV4cG9ydCBjbGFzcyBDZGs4c1RlYW1UeXBlU2NyaXB0UHJvamVjdCBleHRlbmRzIHR5cGVzY3JpcHQuVHlwZVNjcmlwdFByb2plY3Qge1xuXG4gIGNvbnN0cnVjdG9yKG9wdGlvbnM6IENkazhzVGVhbVR5cGVTY3JpcHRQcm9qZWN0T3B0aW9ucykge1xuXG4gICAgbm9kZS52YWxpZGF0ZU9wdGlvbnMob3B0aW9ucyk7XG4gICAgbm9kZS52YWxpZGF0ZVByb2plY3ROYW1lKG9wdGlvbnMpO1xuXG4gICAgY29uc3QgZml4ZWRPcHRpb25zID0gbm9kZS5idWlsZE5vZGVQcm9qZWN0Rml4ZWRPcHRpb25zKG9wdGlvbnMpO1xuICAgIGNvbnN0IGRlZmF1bHRPcHRpb25zID0gbm9kZS5idWlsZE5vZGVQcm9qZWN0RGVmYXVsdE9wdGlvbnMob3B0aW9ucyk7XG5cblxuICAgIHN1cGVyKHtcbiAgICAgIC4uLmZpeGVkT3B0aW9ucyxcbiAgICAgIC4uLmRlZmF1bHRPcHRpb25zLFxuICAgICAgLi4ub3B0aW9ucyxcbiAgICB9KTtcblxuICAgIGNvbnN0IHJlcG9OYW1lID0gb3B0aW9ucy5yZXBvTmFtZSA/PyBub2RlLmJ1aWxkUmVwb3NpdG9yeU5hbWUob3B0aW9ucy5uYW1lKTtcblxuICAgIG5vZGUuYWRkQ29tcG9uZW50cyh0aGlzLCByZXBvTmFtZSk7XG5cbiAgICBpZiAob3B0aW9ucy5iYWNrcG9ydCA/PyBmYWxzZSkge1xuICAgICAgbmV3IEJhY2twb3J0KHRoaXMsIHsgYnJhbmNoZXM6IG9wdGlvbnMuYmFja3BvcnRCcmFuY2hlcywgcmVwb05hbWUgfSk7XG4gICAgfVxuXG4gIH1cblxufVxuIl19
package/package.json CHANGED
@@ -70,7 +70,7 @@
70
70
  },
71
71
  "main": "lib/index.js",
72
72
  "license": "Apache-2.0",
73
- "version": "0.0.277",
73
+ "version": "0.0.279",
74
74
  "jest": {
75
75
  "testMatch": [
76
76
  "<rootDir>/src/**/__tests__/**/*.ts?(x)",