@cdk8s/projen-common 0.0.524 → 0.0.526

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/API.md CHANGED
@@ -4378,6 +4378,173 @@ public readonly DEFAULT_TS_JEST_TRANFORM_PATTERN: string;
4378
4378
 
4379
4379
  ---
4380
4380
 
4381
+ ### Triage <a name="Triage" id="@cdk8s/projen-common.Triage"></a>
4382
+
4383
+ Add a Triage workflow to our repos.
4384
+
4385
+ > [https://github.com/marketplace/actions/add-to-github-projects](https://github.com/marketplace/actions/add-to-github-projects)
4386
+
4387
+ #### Initializers <a name="Initializers" id="@cdk8s/projen-common.Triage.Initializer"></a>
4388
+
4389
+ ```typescript
4390
+ import { Triage } from '@cdk8s/projen-common'
4391
+
4392
+ new Triage(project: NodeProject, props: TriageProps)
4393
+ ```
4394
+
4395
+ | **Name** | **Type** | **Description** |
4396
+ | --- | --- | --- |
4397
+ | <code><a href="#@cdk8s/projen-common.Triage.Initializer.parameter.project">project</a></code> | <code>projen.javascript.NodeProject</code> | *No description.* |
4398
+ | <code><a href="#@cdk8s/projen-common.Triage.Initializer.parameter.props">props</a></code> | <code><a href="#@cdk8s/projen-common.TriageProps">TriageProps</a></code> | *No description.* |
4399
+
4400
+ ---
4401
+
4402
+ ##### `project`<sup>Required</sup> <a name="project" id="@cdk8s/projen-common.Triage.Initializer.parameter.project"></a>
4403
+
4404
+ - *Type:* projen.javascript.NodeProject
4405
+
4406
+ ---
4407
+
4408
+ ##### `props`<sup>Required</sup> <a name="props" id="@cdk8s/projen-common.Triage.Initializer.parameter.props"></a>
4409
+
4410
+ - *Type:* <a href="#@cdk8s/projen-common.TriageProps">TriageProps</a>
4411
+
4412
+ ---
4413
+
4414
+ #### Methods <a name="Methods" id="Methods"></a>
4415
+
4416
+ | **Name** | **Description** |
4417
+ | --- | --- |
4418
+ | <code><a href="#@cdk8s/projen-common.Triage.toString">toString</a></code> | Returns a string representation of this construct. |
4419
+ | <code><a href="#@cdk8s/projen-common.Triage.postSynthesize">postSynthesize</a></code> | Called after synthesis. |
4420
+ | <code><a href="#@cdk8s/projen-common.Triage.preSynthesize">preSynthesize</a></code> | Called before synthesis. |
4421
+ | <code><a href="#@cdk8s/projen-common.Triage.synthesize">synthesize</a></code> | Synthesizes files to the project output directory. |
4422
+
4423
+ ---
4424
+
4425
+ ##### `toString` <a name="toString" id="@cdk8s/projen-common.Triage.toString"></a>
4426
+
4427
+ ```typescript
4428
+ public toString(): string
4429
+ ```
4430
+
4431
+ Returns a string representation of this construct.
4432
+
4433
+ ##### `postSynthesize` <a name="postSynthesize" id="@cdk8s/projen-common.Triage.postSynthesize"></a>
4434
+
4435
+ ```typescript
4436
+ public postSynthesize(): void
4437
+ ```
4438
+
4439
+ Called after synthesis.
4440
+
4441
+ Order is *not* guaranteed.
4442
+
4443
+ ##### `preSynthesize` <a name="preSynthesize" id="@cdk8s/projen-common.Triage.preSynthesize"></a>
4444
+
4445
+ ```typescript
4446
+ public preSynthesize(): void
4447
+ ```
4448
+
4449
+ Called before synthesis.
4450
+
4451
+ ##### `synthesize` <a name="synthesize" id="@cdk8s/projen-common.Triage.synthesize"></a>
4452
+
4453
+ ```typescript
4454
+ public synthesize(): void
4455
+ ```
4456
+
4457
+ Synthesizes files to the project output directory.
4458
+
4459
+ #### Static Functions <a name="Static Functions" id="Static Functions"></a>
4460
+
4461
+ | **Name** | **Description** |
4462
+ | --- | --- |
4463
+ | <code><a href="#@cdk8s/projen-common.Triage.isConstruct">isConstruct</a></code> | Checks if `x` is a construct. |
4464
+ | <code><a href="#@cdk8s/projen-common.Triage.isComponent">isComponent</a></code> | Test whether the given construct is a component. |
4465
+
4466
+ ---
4467
+
4468
+ ##### `isConstruct` <a name="isConstruct" id="@cdk8s/projen-common.Triage.isConstruct"></a>
4469
+
4470
+ ```typescript
4471
+ import { Triage } from '@cdk8s/projen-common'
4472
+
4473
+ Triage.isConstruct(x: any)
4474
+ ```
4475
+
4476
+ Checks if `x` is a construct.
4477
+
4478
+ Use this method instead of `instanceof` to properly detect `Construct`
4479
+ instances, even when the construct library is symlinked.
4480
+
4481
+ Explanation: in JavaScript, multiple copies of the `constructs` library on
4482
+ disk are seen as independent, completely different libraries. As a
4483
+ consequence, the class `Construct` in each copy of the `constructs` library
4484
+ is seen as a different class, and an instance of one class will not test as
4485
+ `instanceof` the other class. `npm install` will not create installations
4486
+ like this, but users may manually symlink construct libraries together or
4487
+ use a monorepo tool: in those cases, multiple copies of the `constructs`
4488
+ library can be accidentally installed, and `instanceof` will behave
4489
+ unpredictably. It is safest to avoid using `instanceof`, and using
4490
+ this type-testing method instead.
4491
+
4492
+ ###### `x`<sup>Required</sup> <a name="x" id="@cdk8s/projen-common.Triage.isConstruct.parameter.x"></a>
4493
+
4494
+ - *Type:* any
4495
+
4496
+ Any object.
4497
+
4498
+ ---
4499
+
4500
+ ##### `isComponent` <a name="isComponent" id="@cdk8s/projen-common.Triage.isComponent"></a>
4501
+
4502
+ ```typescript
4503
+ import { Triage } from '@cdk8s/projen-common'
4504
+
4505
+ Triage.isComponent(x: any)
4506
+ ```
4507
+
4508
+ Test whether the given construct is a component.
4509
+
4510
+ ###### `x`<sup>Required</sup> <a name="x" id="@cdk8s/projen-common.Triage.isComponent.parameter.x"></a>
4511
+
4512
+ - *Type:* any
4513
+
4514
+ ---
4515
+
4516
+ #### Properties <a name="Properties" id="Properties"></a>
4517
+
4518
+ | **Name** | **Type** | **Description** |
4519
+ | --- | --- | --- |
4520
+ | <code><a href="#@cdk8s/projen-common.Triage.property.node">node</a></code> | <code>constructs.Node</code> | The tree node. |
4521
+ | <code><a href="#@cdk8s/projen-common.Triage.property.project">project</a></code> | <code>projen.Project</code> | *No description.* |
4522
+
4523
+ ---
4524
+
4525
+ ##### `node`<sup>Required</sup> <a name="node" id="@cdk8s/projen-common.Triage.property.node"></a>
4526
+
4527
+ ```typescript
4528
+ public readonly node: Node;
4529
+ ```
4530
+
4531
+ - *Type:* constructs.Node
4532
+
4533
+ The tree node.
4534
+
4535
+ ---
4536
+
4537
+ ##### `project`<sup>Required</sup> <a name="project" id="@cdk8s/projen-common.Triage.property.project"></a>
4538
+
4539
+ ```typescript
4540
+ public readonly project: Project;
4541
+ ```
4542
+
4543
+ - *Type:* projen.Project
4544
+
4545
+ ---
4546
+
4547
+
4381
4548
  ## Structs <a name="Structs" id="Structs"></a>
4382
4549
 
4383
4550
  ### Cdk8sTeamJsiiProjectOptions <a name="Cdk8sTeamJsiiProjectOptions" id="@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions"></a>
@@ -4551,6 +4718,7 @@ const cdk8sTeamJsiiProjectOptions: Cdk8sTeamJsiiProjectOptions = { ... }
4551
4718
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.backport">backport</a></code> | <code>boolean</code> | Configure a backport workflow. |
4552
4719
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.backportBranches">backportBranches</a></code> | <code>string[]</code> | Branches to backport to. |
4553
4720
  | <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. |
4721
+ | <code><a href="#@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.triageOptions">triageOptions</a></code> | <code><a href="#@cdk8s/projen-common.TriageOptions">TriageOptions</a></code> | Options for the `triage` workflow. |
4554
4722
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.golang">golang</a></code> | <code>boolean</code> | Publish Golang bindings to GitHub. |
4555
4723
  | <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. |
4556
4724
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.jsiiVersion">jsiiVersion</a></code> | <code>string</code> | JSII version to use. |
@@ -6671,6 +6839,19 @@ The name of the repository inside the cdk8s-team org where the code of the proje
6671
6839
 
6672
6840
  ---
6673
6841
 
6842
+ ##### `triageOptions`<sup>Optional</sup> <a name="triageOptions" id="@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.triageOptions"></a>
6843
+
6844
+ ```typescript
6845
+ public readonly triageOptions: TriageOptions;
6846
+ ```
6847
+
6848
+ - *Type:* <a href="#@cdk8s/projen-common.TriageOptions">TriageOptions</a>
6849
+ - *Default:* no custom options.
6850
+
6851
+ Options for the `triage` workflow.
6852
+
6853
+ ---
6854
+
6674
6855
  ##### `golang`<sup>Optional</sup> <a name="golang" id="@cdk8s/projen-common.Cdk8sTeamJsiiProjectOptions.property.golang"></a>
6675
6856
 
6676
6857
  ```typescript
@@ -6895,6 +7076,7 @@ const cdk8sTeamNodeProjectOptions: Cdk8sTeamNodeProjectOptions = { ... }
6895
7076
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamNodeProjectOptions.property.backport">backport</a></code> | <code>boolean</code> | Configure a backport workflow. |
6896
7077
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamNodeProjectOptions.property.backportBranches">backportBranches</a></code> | <code>string[]</code> | Branches to backport to. |
6897
7078
  | <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. |
7079
+ | <code><a href="#@cdk8s/projen-common.Cdk8sTeamNodeProjectOptions.property.triageOptions">triageOptions</a></code> | <code><a href="#@cdk8s/projen-common.TriageOptions">TriageOptions</a></code> | Options for the `triage` workflow. |
6898
7080
 
6899
7081
  ---
6900
7082
 
@@ -8754,6 +8936,19 @@ The name of the repository inside the cdk8s-team org where the code of the proje
8754
8936
 
8755
8937
  ---
8756
8938
 
8939
+ ##### `triageOptions`<sup>Optional</sup> <a name="triageOptions" id="@cdk8s/projen-common.Cdk8sTeamNodeProjectOptions.property.triageOptions"></a>
8940
+
8941
+ ```typescript
8942
+ public readonly triageOptions: TriageOptions;
8943
+ ```
8944
+
8945
+ - *Type:* <a href="#@cdk8s/projen-common.TriageOptions">TriageOptions</a>
8946
+ - *Default:* no custom options.
8947
+
8948
+ Options for the `triage` workflow.
8949
+
8950
+ ---
8951
+
8757
8952
  ### Cdk8sTeamTypeScriptProjectOptions <a name="Cdk8sTeamTypeScriptProjectOptions" id="@cdk8s/projen-common.Cdk8sTeamTypeScriptProjectOptions"></a>
8758
8953
 
8759
8954
  Options for `Cdk8sTeamTypeScriptProject`.
@@ -8919,6 +9114,7 @@ const cdk8sTeamTypeScriptProjectOptions: Cdk8sTeamTypeScriptProjectOptions = { .
8919
9114
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamTypeScriptProjectOptions.property.backport">backport</a></code> | <code>boolean</code> | Configure a backport workflow. |
8920
9115
  | <code><a href="#@cdk8s/projen-common.Cdk8sTeamTypeScriptProjectOptions.property.backportBranches">backportBranches</a></code> | <code>string[]</code> | Branches to backport to. |
8921
9116
  | <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. |
9117
+ | <code><a href="#@cdk8s/projen-common.Cdk8sTeamTypeScriptProjectOptions.property.triageOptions">triageOptions</a></code> | <code><a href="#@cdk8s/projen-common.TriageOptions">TriageOptions</a></code> | Options for the `triage` workflow. |
8922
9118
 
8923
9119
  ---
8924
9120
 
@@ -11033,5 +11229,153 @@ The name of the repository inside the cdk8s-team org where the code of the proje
11033
11229
 
11034
11230
  ---
11035
11231
 
11232
+ ##### `triageOptions`<sup>Optional</sup> <a name="triageOptions" id="@cdk8s/projen-common.Cdk8sTeamTypeScriptProjectOptions.property.triageOptions"></a>
11233
+
11234
+ ```typescript
11235
+ public readonly triageOptions: TriageOptions;
11236
+ ```
11237
+
11238
+ - *Type:* <a href="#@cdk8s/projen-common.TriageOptions">TriageOptions</a>
11239
+ - *Default:* no custom options.
11240
+
11241
+ Options for the `triage` workflow.
11242
+
11243
+ ---
11244
+
11245
+ ### CommonComponentsOptions <a name="CommonComponentsOptions" id="@cdk8s/projen-common.CommonComponentsOptions"></a>
11246
+
11247
+ Options for `addComponents`.
11248
+
11249
+ #### Initializer <a name="Initializer" id="@cdk8s/projen-common.CommonComponentsOptions.Initializer"></a>
11250
+
11251
+ ```typescript
11252
+ import { CommonComponentsOptions } from '@cdk8s/projen-common'
11253
+
11254
+ const commonComponentsOptions: CommonComponentsOptions = { ... }
11255
+ ```
11256
+
11257
+ #### Properties <a name="Properties" id="Properties"></a>
11258
+
11259
+ | **Name** | **Type** | **Description** |
11260
+ | --- | --- | --- |
11261
+ | <code><a href="#@cdk8s/projen-common.CommonComponentsOptions.property.branches">branches</a></code> | <code>string[]</code> | *No description.* |
11262
+ | <code><a href="#@cdk8s/projen-common.CommonComponentsOptions.property.compilerDeps">compilerDeps</a></code> | <code>string[]</code> | *No description.* |
11263
+ | <code><a href="#@cdk8s/projen-common.CommonComponentsOptions.property.triageOptions">triageOptions</a></code> | <code><a href="#@cdk8s/projen-common.TriageOptions">TriageOptions</a></code> | *No description.* |
11264
+
11265
+ ---
11266
+
11267
+ ##### `branches`<sup>Optional</sup> <a name="branches" id="@cdk8s/projen-common.CommonComponentsOptions.property.branches"></a>
11268
+
11269
+ ```typescript
11270
+ public readonly branches: string[];
11271
+ ```
11272
+
11273
+ - *Type:* string[]
11274
+
11275
+ ---
11276
+
11277
+ ##### `compilerDeps`<sup>Optional</sup> <a name="compilerDeps" id="@cdk8s/projen-common.CommonComponentsOptions.property.compilerDeps"></a>
11278
+
11279
+ ```typescript
11280
+ public readonly compilerDeps: string[];
11281
+ ```
11282
+
11283
+ - *Type:* string[]
11284
+
11285
+ ---
11286
+
11287
+ ##### `triageOptions`<sup>Optional</sup> <a name="triageOptions" id="@cdk8s/projen-common.CommonComponentsOptions.property.triageOptions"></a>
11288
+
11289
+ ```typescript
11290
+ public readonly triageOptions: TriageOptions;
11291
+ ```
11292
+
11293
+ - *Type:* <a href="#@cdk8s/projen-common.TriageOptions">TriageOptions</a>
11294
+
11295
+ ---
11296
+
11297
+ ### TriageOptions <a name="TriageOptions" id="@cdk8s/projen-common.TriageOptions"></a>
11298
+
11299
+ Options for `Triage`.
11300
+
11301
+ #### Initializer <a name="Initializer" id="@cdk8s/projen-common.TriageOptions.Initializer"></a>
11302
+
11303
+ ```typescript
11304
+ import { TriageOptions } from '@cdk8s/projen-common'
11305
+
11306
+ const triageOptions: TriageOptions = { ... }
11307
+ ```
11308
+
11309
+ #### Properties <a name="Properties" id="Properties"></a>
11310
+
11311
+ | **Name** | **Type** | **Description** |
11312
+ | --- | --- | --- |
11313
+ | <code><a href="#@cdk8s/projen-common.TriageOptions.property.prLabels">prLabels</a></code> | <code>string[]</code> | A list of labels automatically added to PRs. |
11314
+
11315
+ ---
11316
+
11317
+ ##### `prLabels`<sup>Optional</sup> <a name="prLabels" id="@cdk8s/projen-common.TriageOptions.property.prLabels"></a>
11318
+
11319
+ ```typescript
11320
+ public readonly prLabels: string[];
11321
+ ```
11322
+
11323
+ - *Type:* string[]
11324
+ - *Default:* no labels.
11325
+
11326
+ A list of labels automatically added to PRs.
11327
+
11328
+ Automation PRs are excluded.
11329
+
11330
+ ---
11331
+
11332
+ ### TriageProps <a name="TriageProps" id="@cdk8s/projen-common.TriageProps"></a>
11333
+
11334
+ Props for `Triage`.
11335
+
11336
+ #### Initializer <a name="Initializer" id="@cdk8s/projen-common.TriageProps.Initializer"></a>
11337
+
11338
+ ```typescript
11339
+ import { TriageProps } from '@cdk8s/projen-common'
11340
+
11341
+ const triageProps: TriageProps = { ... }
11342
+ ```
11343
+
11344
+ #### Properties <a name="Properties" id="Properties"></a>
11345
+
11346
+ | **Name** | **Type** | **Description** |
11347
+ | --- | --- | --- |
11348
+ | <code><a href="#@cdk8s/projen-common.TriageProps.property.prLabels">prLabels</a></code> | <code>string[]</code> | A list of labels automatically added to PRs. |
11349
+ | <code><a href="#@cdk8s/projen-common.TriageProps.property.repoName">repoName</a></code> | <code>string</code> | The repository name. |
11350
+
11351
+ ---
11352
+
11353
+ ##### `prLabels`<sup>Optional</sup> <a name="prLabels" id="@cdk8s/projen-common.TriageProps.property.prLabels"></a>
11354
+
11355
+ ```typescript
11356
+ public readonly prLabels: string[];
11357
+ ```
11358
+
11359
+ - *Type:* string[]
11360
+ - *Default:* no labels.
11361
+
11362
+ A list of labels automatically added to PRs.
11363
+
11364
+ Automation PRs are excluded.
11365
+
11366
+ ---
11367
+
11368
+ ##### `repoName`<sup>Required</sup> <a name="repoName" id="@cdk8s/projen-common.TriageProps.property.repoName"></a>
11369
+
11370
+ ```typescript
11371
+ public readonly repoName: string;
11372
+ ```
11373
+
11374
+ - *Type:* string
11375
+
11376
+ The repository name.
11377
+
11378
+ ---
11379
+
11036
11380
 
11037
11381
 
@@ -28,9 +28,7 @@ class Backport extends projen_1.Component {
28
28
  },
29
29
  });
30
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' } });
31
+ project.addDevDeps('backport@8.5.0');
34
32
  // backport task to branches based on pr labels (i.e not branch specific)
35
33
  const backportTask = this.createTask(project);
36
34
  // backport tasks to explicit branches based on input
@@ -98,4 +96,4 @@ class Backport extends projen_1.Component {
98
96
  }
99
97
  }
100
98
  exports.Backport = Backport;
101
- //# 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        ...project.renderWorkflowSetup({ mutable: false }),\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}"]}
99
+ //# 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    project.addDevDeps('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        ...project.renderWorkflowSetup({ mutable: false }),\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}"]}
@@ -52,9 +52,7 @@ export class Backport extends Component {
52
52
  });
53
53
 
54
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' } });
55
+ project.addDevDeps('backport@8.5.0');
58
56
 
59
57
  // backport task to branches based on pr labels (i.e not branch specific)
60
58
  const backportTask = this.createTask(project);
@@ -0,0 +1 @@
1
+ export * from './triage/triage';
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
+ for (var p in m) if (p !== "default" && !exports.hasOwnProperty(p)) __createBinding(exports, m, p);
11
+ };
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ __exportStar(require("./triage/triage"), exports);
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQSxrREFBZ0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3RyaWFnZS90cmlhZ2UnOyJdfQ==
@@ -0,0 +1 @@
1
+ export * from './triage/triage';
@@ -1,19 +1,31 @@
1
1
  import { Component } from 'projen';
2
2
  import { NodeProject } from 'projen/lib/javascript';
3
3
  /**
4
- * Options for `Triage`.
4
+ * Props for `Triage`.
5
5
  */
6
- export interface TriageOptions {
6
+ export interface TriageProps extends TriageOptions {
7
7
  /**
8
8
  * The repository name.
9
9
  */
10
10
  readonly repoName: string;
11
11
  }
12
+ /**
13
+ * Options for `Triage`.
14
+ */
15
+ export interface TriageOptions {
16
+ /**
17
+ * A list of labels automatically added to PRs.
18
+ * Automation PRs are excluded.
19
+ *
20
+ * @default - no labels.
21
+ */
22
+ readonly prLabels?: string[];
23
+ }
12
24
  /**
13
25
  * Add a Triage workflow to our repos.
14
26
  *
15
27
  * @see https://github.com/marketplace/actions/add-to-github-projects
16
28
  */
17
29
  export declare class Triage extends Component {
18
- constructor(project: NodeProject, options: TriageOptions);
30
+ constructor(project: NodeProject, props: TriageProps);
19
31
  }
@@ -1,6 +1,8 @@
1
1
  "use strict";
2
+ var _a;
2
3
  Object.defineProperty(exports, "__esModule", { value: true });
3
4
  exports.Triage = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
4
6
  const projen_1 = require("projen");
5
7
  const workflows_model_1 = require("projen/lib/github/workflows-model");
6
8
  /**
@@ -9,7 +11,7 @@ const workflows_model_1 = require("projen/lib/github/workflows-model");
9
11
  * @see https://github.com/marketplace/actions/add-to-github-projects
10
12
  */
11
13
  class Triage extends projen_1.Component {
12
- constructor(project, options) {
14
+ constructor(project, props) {
13
15
  super(project);
14
16
  // hmm, we need to remember to update this in 2024
15
17
  // or figure out how to make this dynamic.
@@ -25,10 +27,10 @@ class Triage extends projen_1.Component {
25
27
  });
26
28
  workflow.addJob('assign-to-project', {
27
29
  permissions: { issues: workflows_model_1.JobPermission.WRITE, pullRequests: workflows_model_1.JobPermission.WRITE },
28
- // dont dont triage issues/prs on forks
30
+ // dont triage issues/prs on forks
29
31
  // dont triage autimation bot prs
30
32
  // see https://docs.github.com/en/actions/using-jobs/using-conditions-to-control-job-execution#example-only-run-job-for-specific-repository
31
- if: `(github.repository == \'cdk8s-team/${options.repoName}\') && (github.event.issue || (github.event.pull_request.user.login != \'cdk8s-automation\' && github.event.pull_request.head.repo.full_name == github.repository))`,
33
+ if: `(github.repository == \'cdk8s-team/${props.repoName}\') && (github.event.issue || (github.event.pull_request.user.login != \'cdk8s-automation\' && github.event.pull_request.head.repo.full_name == github.repository))`,
32
34
  runsOn: ['ubuntu-latest'],
33
35
  steps: [{
34
36
  uses: 'actions/add-to-project@v0.4.0',
@@ -38,7 +40,24 @@ class Triage extends projen_1.Component {
38
40
  },
39
41
  }],
40
42
  });
43
+ if (props.prLabels) {
44
+ workflow.addJob('add-labels-to-pr', {
45
+ permissions: { pullRequests: workflows_model_1.JobPermission.WRITE },
46
+ if: `(github.repository == \'cdk8s-team/${props.repoName}\') && (github.event.pull_request && github.event.pull_request.user.login != \'cdk8s-automation\')`,
47
+ runsOn: ['ubuntu-latest'],
48
+ steps: [{
49
+ uses: 'actions-ecosystem/action-add-labels@v1',
50
+ with: {
51
+ // weird: https://github.com/actions-ecosystem/action-add-labels/blob/main/src/main.ts#L10
52
+ labels: props.prLabels.join('\n'),
53
+ github_token: '${{ secrets.PROJEN_GITHUB_TOKEN }}',
54
+ },
55
+ }],
56
+ });
57
+ }
41
58
  }
42
59
  }
43
60
  exports.Triage = Triage;
44
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJpYWdlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvdHJpYWdlL3RyaWFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtQ0FBbUM7QUFDbkMsdUVBQWtFO0FBZWxFOzs7O0dBSUc7QUFDSCxNQUFhLE1BQU8sU0FBUSxrQkFBUztJQUVuQyxZQUFZLE9BQW9CLEVBQUUsT0FBc0I7UUFDdEQsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRWYsa0RBQWtEO1FBQ2xELDBDQUEwQztRQUMxQyxNQUFNLFVBQVUsR0FBRyxnREFBZ0QsQ0FBQztRQUVwRSxNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsTUFBTyxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUN2RCxRQUFRLENBQUMsRUFBRSxDQUFDO1lBQ1YsTUFBTSxFQUFFO2dCQUNOLEtBQUssRUFBRSxDQUFDLFFBQVEsQ0FBQzthQUNsQjtZQUNELFdBQVcsRUFBRTtnQkFDWCxLQUFLLEVBQUUsQ0FBQyxRQUFRLENBQUM7YUFDbEI7U0FDRixDQUFDLENBQUM7UUFDSCxRQUFRLENBQUMsTUFBTSxDQUFDLG1CQUFtQixFQUFFO1lBQ25DLFdBQVcsRUFBRSxFQUFFLE1BQU0sRUFBRSwrQkFBYSxDQUFDLEtBQUssRUFBRSxZQUFZLEVBQUUsK0JBQWEsQ0FBQyxLQUFLLEVBQUU7WUFDL0UsdUNBQXVDO1lBQ3ZDLGlDQUFpQztZQUNqQywySUFBMkk7WUFDM0ksRUFBRSxFQUFFLHNDQUFzQyxPQUFPLENBQUMsUUFBUSxxS0FBcUs7WUFDL04sTUFBTSxFQUFFLENBQUMsZUFBZSxDQUFDO1lBQ3pCLEtBQUssRUFBRSxDQUFDO29CQUNOLElBQUksRUFBRSwrQkFBK0I7b0JBQ3JDLElBQUksRUFBRTt3QkFDSixhQUFhLEVBQUUsVUFBVTt3QkFDekIsY0FBYyxFQUFFLG9DQUFvQztxQkFDckQ7aUJBQ0YsQ0FBQztTQUNILENBQUMsQ0FBQztJQUVMLENBQUM7Q0FDRjtBQW5DRCx3QkFtQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdwcm9qZW4nO1xuaW1wb3J0IHsgSm9iUGVybWlzc2lvbiB9IGZyb20gJ3Byb2plbi9saWIvZ2l0aHViL3dvcmtmbG93cy1tb2RlbCc7XG5pbXBvcnQgeyBOb2RlUHJvamVjdCB9IGZyb20gJ3Byb2plbi9saWIvamF2YXNjcmlwdCc7XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgYFRyaWFnZWAuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVHJpYWdlT3B0aW9ucyB7XG5cbiAgLyoqXG4gICAqIFRoZSByZXBvc2l0b3J5IG5hbWUuXG4gICAqL1xuICByZWFkb25seSByZXBvTmFtZTogc3RyaW5nO1xuXG59XG5cbi8qKlxuICogQWRkIGEgVHJpYWdlIHdvcmtmbG93IHRvIG91ciByZXBvcy5cbiAqXG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9tYXJrZXRwbGFjZS9hY3Rpb25zL2FkZC10by1naXRodWItcHJvamVjdHNcbiAqL1xuZXhwb3J0IGNsYXNzIFRyaWFnZSBleHRlbmRzIENvbXBvbmVudCB7XG5cbiAgY29uc3RydWN0b3IocHJvamVjdDogTm9kZVByb2plY3QsIG9wdGlvbnM6IFRyaWFnZU9wdGlvbnMpIHtcbiAgICBzdXBlcihwcm9qZWN0KTtcblxuICAgIC8vIGhtbSwgd2UgbmVlZCB0byByZW1lbWJlciB0byB1cGRhdGUgdGhpcyBpbiAyMDI0XG4gICAgLy8gb3IgZmlndXJlIG91dCBob3cgdG8gbWFrZSB0aGlzIGR5bmFtaWMuXG4gICAgY29uc3QgcHJvamVjdFVybCA9ICdodHRwczovL2dpdGh1Yi5jb20vb3Jncy9jZGs4cy10ZWFtL3Byb2plY3RzLzEyJztcblxuICAgIGNvbnN0IHdvcmtmbG93ID0gcHJvamVjdC5naXRodWIhLmFkZFdvcmtmbG93KCd0cmlhZ2UnKTtcbiAgICB3b3JrZmxvdy5vbih7XG4gICAgICBpc3N1ZXM6IHtcbiAgICAgICAgdHlwZXM6IFsnb3BlbmVkJ10sXG4gICAgICB9LFxuICAgICAgcHVsbFJlcXVlc3Q6IHtcbiAgICAgICAgdHlwZXM6IFsnb3BlbmVkJ10sXG4gICAgICB9LFxuICAgIH0pO1xuICAgIHdvcmtmbG93LmFkZEpvYignYXNzaWduLXRvLXByb2plY3QnLCB7XG4gICAgICBwZXJtaXNzaW9uczogeyBpc3N1ZXM6IEpvYlBlcm1pc3Npb24uV1JJVEUsIHB1bGxSZXF1ZXN0czogSm9iUGVybWlzc2lvbi5XUklURSB9LFxuICAgICAgLy8gZG9udCBkb250IHRyaWFnZSBpc3N1ZXMvcHJzIG9uIGZvcmtzXG4gICAgICAvLyBkb250IHRyaWFnZSBhdXRpbWF0aW9uIGJvdCBwcnNcbiAgICAgIC8vIHNlZSBodHRwczovL2RvY3MuZ2l0aHViLmNvbS9lbi9hY3Rpb25zL3VzaW5nLWpvYnMvdXNpbmctY29uZGl0aW9ucy10by1jb250cm9sLWpvYi1leGVjdXRpb24jZXhhbXBsZS1vbmx5LXJ1bi1qb2ItZm9yLXNwZWNpZmljLXJlcG9zaXRvcnlcbiAgICAgIGlmOiBgKGdpdGh1Yi5yZXBvc2l0b3J5ID09IFxcJ2NkazhzLXRlYW0vJHtvcHRpb25zLnJlcG9OYW1lfVxcJykgJiYgKGdpdGh1Yi5ldmVudC5pc3N1ZSB8fCAoZ2l0aHViLmV2ZW50LnB1bGxfcmVxdWVzdC51c2VyLmxvZ2luICE9IFxcJ2NkazhzLWF1dG9tYXRpb25cXCcgJiYgZ2l0aHViLmV2ZW50LnB1bGxfcmVxdWVzdC5oZWFkLnJlcG8uZnVsbF9uYW1lID09IGdpdGh1Yi5yZXBvc2l0b3J5KSlgLFxuICAgICAgcnVuc09uOiBbJ3VidW50dS1sYXRlc3QnXSxcbiAgICAgIHN0ZXBzOiBbe1xuICAgICAgICB1c2VzOiAnYWN0aW9ucy9hZGQtdG8tcHJvamVjdEB2MC40LjAnLFxuICAgICAgICB3aXRoOiB7XG4gICAgICAgICAgJ3Byb2plY3QtdXJsJzogcHJvamVjdFVybCxcbiAgICAgICAgICAnZ2l0aHViLXRva2VuJzogJyR7eyBzZWNyZXRzLlBST0pFTl9HSVRIVUJfVE9LRU4gfX0nLFxuICAgICAgICB9LFxuICAgICAgfV0sXG4gICAgfSk7XG5cbiAgfVxufSJdfQ==
61
+ _a = JSII_RTTI_SYMBOL_1;
62
+ Triage[_a] = { fqn: "@cdk8s/projen-common.Triage", version: "0.0.526" };
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJpYWdlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvdHJpYWdlL3RyaWFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLG1DQUFtQztBQUNuQyx1RUFBa0U7QUErQmxFOzs7O0dBSUc7QUFDSCxNQUFhLE1BQU8sU0FBUSxrQkFBUztJQUVuQyxZQUFZLE9BQW9CLEVBQUUsS0FBa0I7UUFDbEQsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRWYsa0RBQWtEO1FBQ2xELDBDQUEwQztRQUMxQyxNQUFNLFVBQVUsR0FBRyxnREFBZ0QsQ0FBQztRQUVwRSxNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsTUFBTyxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUN2RCxRQUFRLENBQUMsRUFBRSxDQUFDO1lBQ1YsTUFBTSxFQUFFO2dCQUNOLEtBQUssRUFBRSxDQUFDLFFBQVEsQ0FBQzthQUNsQjtZQUNELFdBQVcsRUFBRTtnQkFDWCxLQUFLLEVBQUUsQ0FBQyxRQUFRLENBQUM7YUFDbEI7U0FDRixDQUFDLENBQUM7UUFDSCxRQUFRLENBQUMsTUFBTSxDQUFDLG1CQUFtQixFQUFFO1lBQ25DLFdBQVcsRUFBRSxFQUFFLE1BQU0sRUFBRSwrQkFBYSxDQUFDLEtBQUssRUFBRSxZQUFZLEVBQUUsK0JBQWEsQ0FBQyxLQUFLLEVBQUU7WUFDL0Usa0NBQWtDO1lBQ2xDLGlDQUFpQztZQUNqQywySUFBMkk7WUFDM0ksRUFBRSxFQUFFLHNDQUFzQyxLQUFLLENBQUMsUUFBUSxxS0FBcUs7WUFDN04sTUFBTSxFQUFFLENBQUMsZUFBZSxDQUFDO1lBQ3pCLEtBQUssRUFBRSxDQUFDO29CQUNOLElBQUksRUFBRSwrQkFBK0I7b0JBQ3JDLElBQUksRUFBRTt3QkFDSixhQUFhLEVBQUUsVUFBVTt3QkFDekIsY0FBYyxFQUFFLG9DQUFvQztxQkFDckQ7aUJBQ0YsQ0FBQztTQUNILENBQUMsQ0FBQztRQUVILElBQUksS0FBSyxDQUFDLFFBQVEsRUFBRTtZQUNsQixRQUFRLENBQUMsTUFBTSxDQUFDLGtCQUFrQixFQUFFO2dCQUNsQyxXQUFXLEVBQUUsRUFBRSxZQUFZLEVBQUUsK0JBQWEsQ0FBQyxLQUFLLEVBQUU7Z0JBQ2xELEVBQUUsRUFBRSxzQ0FBc0MsS0FBSyxDQUFDLFFBQVEsb0dBQW9HO2dCQUM1SixNQUFNLEVBQUUsQ0FBQyxlQUFlLENBQUM7Z0JBQ3pCLEtBQUssRUFBRSxDQUFDO3dCQUNOLElBQUksRUFBRSx3Q0FBd0M7d0JBQzlDLElBQUksRUFBRTs0QkFDSiwwRkFBMEY7NEJBQzFGLE1BQU0sRUFBRSxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUM7NEJBQ2pDLFlBQVksRUFBRSxvQ0FBb0M7eUJBQ25EO3FCQUNGLENBQUM7YUFDSCxDQUFDLENBQUM7U0FDSjtJQUVILENBQUM7O0FBbERILHdCQW1EQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ3Byb2plbic7XG5pbXBvcnQgeyBKb2JQZXJtaXNzaW9uIH0gZnJvbSAncHJvamVuL2xpYi9naXRodWIvd29ya2Zsb3dzLW1vZGVsJztcbmltcG9ydCB7IE5vZGVQcm9qZWN0IH0gZnJvbSAncHJvamVuL2xpYi9qYXZhc2NyaXB0JztcblxuLyoqXG4gKiBQcm9wcyBmb3IgYFRyaWFnZWAuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVHJpYWdlUHJvcHMgZXh0ZW5kcyBUcmlhZ2VPcHRpb25zIHtcblxuICAvKipcbiAgICogVGhlIHJlcG9zaXRvcnkgbmFtZS5cbiAgICovXG4gIHJlYWRvbmx5IHJlcG9OYW1lOiBzdHJpbmc7XG5cbn1cblxuLyoqXG4gKiBPcHRpb25zIGZvciBgVHJpYWdlYC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUcmlhZ2VPcHRpb25zIHtcblxuXG4gIC8qKlxuICAgKiBBIGxpc3Qgb2YgbGFiZWxzIGF1dG9tYXRpY2FsbHkgYWRkZWQgdG8gUFJzLlxuICAgKiBBdXRvbWF0aW9uIFBScyBhcmUgZXhjbHVkZWQuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gbm8gbGFiZWxzLlxuICAgKi9cbiAgcmVhZG9ubHkgcHJMYWJlbHM/OiBzdHJpbmdbXTtcblxufVxuXG4vKipcbiAqIEFkZCBhIFRyaWFnZSB3b3JrZmxvdyB0byBvdXIgcmVwb3MuXG4gKlxuICogQHNlZSBodHRwczovL2dpdGh1Yi5jb20vbWFya2V0cGxhY2UvYWN0aW9ucy9hZGQtdG8tZ2l0aHViLXByb2plY3RzXG4gKi9cbmV4cG9ydCBjbGFzcyBUcmlhZ2UgZXh0ZW5kcyBDb21wb25lbnQge1xuXG4gIGNvbnN0cnVjdG9yKHByb2plY3Q6IE5vZGVQcm9qZWN0LCBwcm9wczogVHJpYWdlUHJvcHMpIHtcbiAgICBzdXBlcihwcm9qZWN0KTtcblxuICAgIC8vIGhtbSwgd2UgbmVlZCB0byByZW1lbWJlciB0byB1cGRhdGUgdGhpcyBpbiAyMDI0XG4gICAgLy8gb3IgZmlndXJlIG91dCBob3cgdG8gbWFrZSB0aGlzIGR5bmFtaWMuXG4gICAgY29uc3QgcHJvamVjdFVybCA9ICdodHRwczovL2dpdGh1Yi5jb20vb3Jncy9jZGs4cy10ZWFtL3Byb2plY3RzLzEyJztcblxuICAgIGNvbnN0IHdvcmtmbG93ID0gcHJvamVjdC5naXRodWIhLmFkZFdvcmtmbG93KCd0cmlhZ2UnKTtcbiAgICB3b3JrZmxvdy5vbih7XG4gICAgICBpc3N1ZXM6IHtcbiAgICAgICAgdHlwZXM6IFsnb3BlbmVkJ10sXG4gICAgICB9LFxuICAgICAgcHVsbFJlcXVlc3Q6IHtcbiAgICAgICAgdHlwZXM6IFsnb3BlbmVkJ10sXG4gICAgICB9LFxuICAgIH0pO1xuICAgIHdvcmtmbG93LmFkZEpvYignYXNzaWduLXRvLXByb2plY3QnLCB7XG4gICAgICBwZXJtaXNzaW9uczogeyBpc3N1ZXM6IEpvYlBlcm1pc3Npb24uV1JJVEUsIHB1bGxSZXF1ZXN0czogSm9iUGVybWlzc2lvbi5XUklURSB9LFxuICAgICAgLy8gZG9udCB0cmlhZ2UgaXNzdWVzL3BycyBvbiBmb3Jrc1xuICAgICAgLy8gZG9udCB0cmlhZ2UgYXV0aW1hdGlvbiBib3QgcHJzXG4gICAgICAvLyBzZWUgaHR0cHM6Ly9kb2NzLmdpdGh1Yi5jb20vZW4vYWN0aW9ucy91c2luZy1qb2JzL3VzaW5nLWNvbmRpdGlvbnMtdG8tY29udHJvbC1qb2ItZXhlY3V0aW9uI2V4YW1wbGUtb25seS1ydW4tam9iLWZvci1zcGVjaWZpYy1yZXBvc2l0b3J5XG4gICAgICBpZjogYChnaXRodWIucmVwb3NpdG9yeSA9PSBcXCdjZGs4cy10ZWFtLyR7cHJvcHMucmVwb05hbWV9XFwnKSAmJiAoZ2l0aHViLmV2ZW50Lmlzc3VlIHx8IChnaXRodWIuZXZlbnQucHVsbF9yZXF1ZXN0LnVzZXIubG9naW4gIT0gXFwnY2RrOHMtYXV0b21hdGlvblxcJyAmJiBnaXRodWIuZXZlbnQucHVsbF9yZXF1ZXN0LmhlYWQucmVwby5mdWxsX25hbWUgPT0gZ2l0aHViLnJlcG9zaXRvcnkpKWAsXG4gICAgICBydW5zT246IFsndWJ1bnR1LWxhdGVzdCddLFxuICAgICAgc3RlcHM6IFt7XG4gICAgICAgIHVzZXM6ICdhY3Rpb25zL2FkZC10by1wcm9qZWN0QHYwLjQuMCcsXG4gICAgICAgIHdpdGg6IHtcbiAgICAgICAgICAncHJvamVjdC11cmwnOiBwcm9qZWN0VXJsLFxuICAgICAgICAgICdnaXRodWItdG9rZW4nOiAnJHt7IHNlY3JldHMuUFJPSkVOX0dJVEhVQl9UT0tFTiB9fScsXG4gICAgICAgIH0sXG4gICAgICB9XSxcbiAgICB9KTtcblxuICAgIGlmIChwcm9wcy5wckxhYmVscykge1xuICAgICAgd29ya2Zsb3cuYWRkSm9iKCdhZGQtbGFiZWxzLXRvLXByJywge1xuICAgICAgICBwZXJtaXNzaW9uczogeyBwdWxsUmVxdWVzdHM6IEpvYlBlcm1pc3Npb24uV1JJVEUgfSxcbiAgICAgICAgaWY6IGAoZ2l0aHViLnJlcG9zaXRvcnkgPT0gXFwnY2RrOHMtdGVhbS8ke3Byb3BzLnJlcG9OYW1lfVxcJykgJiYgKGdpdGh1Yi5ldmVudC5wdWxsX3JlcXVlc3QgJiYgZ2l0aHViLmV2ZW50LnB1bGxfcmVxdWVzdC51c2VyLmxvZ2luICE9IFxcJ2NkazhzLWF1dG9tYXRpb25cXCcpYCxcbiAgICAgICAgcnVuc09uOiBbJ3VidW50dS1sYXRlc3QnXSxcbiAgICAgICAgc3RlcHM6IFt7XG4gICAgICAgICAgdXNlczogJ2FjdGlvbnMtZWNvc3lzdGVtL2FjdGlvbi1hZGQtbGFiZWxzQHYxJyxcbiAgICAgICAgICB3aXRoOiB7XG4gICAgICAgICAgICAvLyB3ZWlyZDogaHR0cHM6Ly9naXRodWIuY29tL2FjdGlvbnMtZWNvc3lzdGVtL2FjdGlvbi1hZGQtbGFiZWxzL2Jsb2IvbWFpbi9zcmMvbWFpbi50cyNMMTBcbiAgICAgICAgICAgIGxhYmVsczogcHJvcHMucHJMYWJlbHMuam9pbignXFxuJyksXG4gICAgICAgICAgICBnaXRodWJfdG9rZW46ICcke3sgc2VjcmV0cy5QUk9KRU5fR0lUSFVCX1RPS0VOIH19JyxcbiAgICAgICAgICB9LFxuICAgICAgICB9XSxcbiAgICAgIH0pO1xuICAgIH1cblxuICB9XG59Il19