@cdk8s/projen-common 0.0.525 → 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/.jsii CHANGED
@@ -290,7 +290,7 @@
290
290
  },
291
291
  "locationInModule": {
292
292
  "filename": "src/projects/node.ts",
293
- "line": 155
293
+ "line": 163
294
294
  },
295
295
  "parameters": [
296
296
  {
@@ -304,7 +304,7 @@
304
304
  "kind": "class",
305
305
  "locationInModule": {
306
306
  "filename": "src/projects/node.ts",
307
- "line": 153
307
+ "line": 161
308
308
  },
309
309
  "name": "Cdk8sTeamNodeProject",
310
310
  "symbolId": "src/projects/node:Cdk8sTeamNodeProject"
@@ -385,6 +385,24 @@
385
385
  "type": {
386
386
  "primitive": "string"
387
387
  }
388
+ },
389
+ {
390
+ "abstract": true,
391
+ "docs": {
392
+ "default": "- no custom options.",
393
+ "stability": "stable",
394
+ "summary": "Options for the `triage` workflow."
395
+ },
396
+ "immutable": true,
397
+ "locationInModule": {
398
+ "filename": "src/projects/node.ts",
399
+ "line": 154
400
+ },
401
+ "name": "triageOptions",
402
+ "optional": true,
403
+ "type": {
404
+ "fqn": "@cdk8s/projen-common.TriageOptions"
405
+ }
388
406
  }
389
407
  ],
390
408
  "symbolId": "src/projects/node:Cdk8sTeamNodeProjectOptions"
@@ -405,7 +423,7 @@
405
423
  },
406
424
  "locationInModule": {
407
425
  "filename": "src/projects/typescript.ts",
408
- "line": 46
426
+ "line": 55
409
427
  },
410
428
  "parameters": [
411
429
  {
@@ -419,7 +437,7 @@
419
437
  "kind": "class",
420
438
  "locationInModule": {
421
439
  "filename": "src/projects/typescript.ts",
422
- "line": 44
440
+ "line": 53
423
441
  },
424
442
  "name": "Cdk8sTeamTypeScriptProject",
425
443
  "symbolId": "src/projects/typescript:Cdk8sTeamTypeScriptProject"
@@ -438,7 +456,7 @@
438
456
  "kind": "interface",
439
457
  "locationInModule": {
440
458
  "filename": "src/projects/typescript.ts",
441
- "line": 9
459
+ "line": 10
442
460
  },
443
461
  "name": "Cdk8sTeamTypeScriptProjectOptions",
444
462
  "properties": [
@@ -453,7 +471,7 @@
453
471
  "immutable": true,
454
472
  "locationInModule": {
455
473
  "filename": "src/projects/typescript.ts",
456
- "line": 38
474
+ "line": 39
457
475
  },
458
476
  "name": "additionalCompilerDependencies",
459
477
  "optional": true,
@@ -476,7 +494,7 @@
476
494
  "immutable": true,
477
495
  "locationInModule": {
478
496
  "filename": "src/projects/typescript.ts",
479
- "line": 23
497
+ "line": 24
480
498
  },
481
499
  "name": "backport",
482
500
  "optional": true,
@@ -494,7 +512,7 @@
494
512
  "immutable": true,
495
513
  "locationInModule": {
496
514
  "filename": "src/projects/typescript.ts",
497
- "line": 30
515
+ "line": 31
498
516
  },
499
517
  "name": "backportBranches",
500
518
  "optional": true,
@@ -517,18 +535,231 @@
517
535
  "immutable": true,
518
536
  "locationInModule": {
519
537
  "filename": "src/projects/typescript.ts",
520
- "line": 17
538
+ "line": 18
521
539
  },
522
540
  "name": "repoName",
523
541
  "optional": true,
524
542
  "type": {
525
543
  "primitive": "string"
526
544
  }
545
+ },
546
+ {
547
+ "abstract": true,
548
+ "docs": {
549
+ "default": "- no custom options.",
550
+ "stability": "stable",
551
+ "summary": "Options for the `triage` workflow."
552
+ },
553
+ "immutable": true,
554
+ "locationInModule": {
555
+ "filename": "src/projects/typescript.ts",
556
+ "line": 46
557
+ },
558
+ "name": "triageOptions",
559
+ "optional": true,
560
+ "type": {
561
+ "fqn": "@cdk8s/projen-common.TriageOptions"
562
+ }
527
563
  }
528
564
  ],
529
565
  "symbolId": "src/projects/typescript:Cdk8sTeamTypeScriptProjectOptions"
566
+ },
567
+ "@cdk8s/projen-common.CommonComponentsOptions": {
568
+ "assembly": "@cdk8s/projen-common",
569
+ "datatype": true,
570
+ "docs": {
571
+ "stability": "stable",
572
+ "summary": "Options for `addComponents`."
573
+ },
574
+ "fqn": "@cdk8s/projen-common.CommonComponentsOptions",
575
+ "kind": "interface",
576
+ "locationInModule": {
577
+ "filename": "src/projects/node.ts",
578
+ "line": 242
579
+ },
580
+ "name": "CommonComponentsOptions",
581
+ "properties": [
582
+ {
583
+ "abstract": true,
584
+ "docs": {
585
+ "stability": "stable"
586
+ },
587
+ "immutable": true,
588
+ "locationInModule": {
589
+ "filename": "src/projects/node.ts",
590
+ "line": 243
591
+ },
592
+ "name": "branches",
593
+ "optional": true,
594
+ "type": {
595
+ "collection": {
596
+ "elementtype": {
597
+ "primitive": "string"
598
+ },
599
+ "kind": "array"
600
+ }
601
+ }
602
+ },
603
+ {
604
+ "abstract": true,
605
+ "docs": {
606
+ "stability": "stable"
607
+ },
608
+ "immutable": true,
609
+ "locationInModule": {
610
+ "filename": "src/projects/node.ts",
611
+ "line": 244
612
+ },
613
+ "name": "compilerDeps",
614
+ "optional": true,
615
+ "type": {
616
+ "collection": {
617
+ "elementtype": {
618
+ "primitive": "string"
619
+ },
620
+ "kind": "array"
621
+ }
622
+ }
623
+ },
624
+ {
625
+ "abstract": true,
626
+ "docs": {
627
+ "stability": "stable"
628
+ },
629
+ "immutable": true,
630
+ "locationInModule": {
631
+ "filename": "src/projects/node.ts",
632
+ "line": 245
633
+ },
634
+ "name": "triageOptions",
635
+ "optional": true,
636
+ "type": {
637
+ "fqn": "@cdk8s/projen-common.TriageOptions"
638
+ }
639
+ }
640
+ ],
641
+ "symbolId": "src/projects/node:CommonComponentsOptions"
642
+ },
643
+ "@cdk8s/projen-common.Triage": {
644
+ "assembly": "@cdk8s/projen-common",
645
+ "base": "projen.Component",
646
+ "docs": {
647
+ "see": "https://github.com/marketplace/actions/add-to-github-projects",
648
+ "stability": "stable",
649
+ "summary": "Add a Triage workflow to our repos."
650
+ },
651
+ "fqn": "@cdk8s/projen-common.Triage",
652
+ "initializer": {
653
+ "docs": {
654
+ "stability": "stable"
655
+ },
656
+ "locationInModule": {
657
+ "filename": "src/components/triage/triage.ts",
658
+ "line": 40
659
+ },
660
+ "parameters": [
661
+ {
662
+ "name": "project",
663
+ "type": {
664
+ "fqn": "projen.javascript.NodeProject"
665
+ }
666
+ },
667
+ {
668
+ "name": "props",
669
+ "type": {
670
+ "fqn": "@cdk8s/projen-common.TriageProps"
671
+ }
672
+ }
673
+ ]
674
+ },
675
+ "kind": "class",
676
+ "locationInModule": {
677
+ "filename": "src/components/triage/triage.ts",
678
+ "line": 38
679
+ },
680
+ "name": "Triage",
681
+ "symbolId": "src/components/triage/triage:Triage"
682
+ },
683
+ "@cdk8s/projen-common.TriageOptions": {
684
+ "assembly": "@cdk8s/projen-common",
685
+ "datatype": true,
686
+ "docs": {
687
+ "stability": "stable",
688
+ "summary": "Options for `Triage`."
689
+ },
690
+ "fqn": "@cdk8s/projen-common.TriageOptions",
691
+ "kind": "interface",
692
+ "locationInModule": {
693
+ "filename": "src/components/triage/triage.ts",
694
+ "line": 20
695
+ },
696
+ "name": "TriageOptions",
697
+ "properties": [
698
+ {
699
+ "abstract": true,
700
+ "docs": {
701
+ "default": "- no labels.",
702
+ "remarks": "Automation PRs are excluded.",
703
+ "stability": "stable",
704
+ "summary": "A list of labels automatically added to PRs."
705
+ },
706
+ "immutable": true,
707
+ "locationInModule": {
708
+ "filename": "src/components/triage/triage.ts",
709
+ "line": 29
710
+ },
711
+ "name": "prLabels",
712
+ "optional": true,
713
+ "type": {
714
+ "collection": {
715
+ "elementtype": {
716
+ "primitive": "string"
717
+ },
718
+ "kind": "array"
719
+ }
720
+ }
721
+ }
722
+ ],
723
+ "symbolId": "src/components/triage/triage:TriageOptions"
724
+ },
725
+ "@cdk8s/projen-common.TriageProps": {
726
+ "assembly": "@cdk8s/projen-common",
727
+ "datatype": true,
728
+ "docs": {
729
+ "stability": "stable",
730
+ "summary": "Props for `Triage`."
731
+ },
732
+ "fqn": "@cdk8s/projen-common.TriageProps",
733
+ "interfaces": [
734
+ "@cdk8s/projen-common.TriageOptions"
735
+ ],
736
+ "kind": "interface",
737
+ "locationInModule": {
738
+ "filename": "src/components/triage/triage.ts",
739
+ "line": 8
740
+ },
741
+ "name": "TriageProps",
742
+ "properties": [
743
+ {
744
+ "abstract": true,
745
+ "docs": {
746
+ "stability": "stable",
747
+ "summary": "The repository name."
748
+ },
749
+ "immutable": true,
750
+ "locationInModule": {
751
+ "filename": "src/components/triage/triage.ts",
752
+ "line": 13
753
+ },
754
+ "name": "repoName",
755
+ "type": {
756
+ "primitive": "string"
757
+ }
758
+ }
759
+ ],
760
+ "symbolId": "src/components/triage/triage:TriageProps"
530
761
  }
531
762
  },
532
- "version": "0.0.525",
533
- "fingerprint": "FHgqaEYhjVgVW65B6bLWkuG0mSX8JxaQ3DhnApCEIDE="
763
+ "version": "0.0.526",
764
+ "fingerprint": "s2xI0fEu9crqEgDwqcbxgysdX0q7BejorDc3t4cMPxA="
534
765
  }
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
 
@@ -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
@@ -3,9 +3,9 @@ import { JobPermission } from 'projen/lib/github/workflows-model';
3
3
  import { NodeProject } from 'projen/lib/javascript';
4
4
 
5
5
  /**
6
- * Options for `Triage`.
6
+ * Props for `Triage`.
7
7
  */
8
- export interface TriageOptions {
8
+ export interface TriageProps extends TriageOptions {
9
9
 
10
10
  /**
11
11
  * The repository name.
@@ -14,6 +14,22 @@ export interface TriageOptions {
14
14
 
15
15
  }
16
16
 
17
+ /**
18
+ * Options for `Triage`.
19
+ */
20
+ export interface TriageOptions {
21
+
22
+
23
+ /**
24
+ * A list of labels automatically added to PRs.
25
+ * Automation PRs are excluded.
26
+ *
27
+ * @default - no labels.
28
+ */
29
+ readonly prLabels?: string[];
30
+
31
+ }
32
+
17
33
  /**
18
34
  * Add a Triage workflow to our repos.
19
35
  *
@@ -21,7 +37,7 @@ export interface TriageOptions {
21
37
  */
22
38
  export class Triage extends Component {
23
39
 
24
- constructor(project: NodeProject, options: TriageOptions) {
40
+ constructor(project: NodeProject, props: TriageProps) {
25
41
  super(project);
26
42
 
27
43
  // hmm, we need to remember to update this in 2024
@@ -39,10 +55,10 @@ export class Triage extends Component {
39
55
  });
40
56
  workflow.addJob('assign-to-project', {
41
57
  permissions: { issues: JobPermission.WRITE, pullRequests: JobPermission.WRITE },
42
- // dont dont triage issues/prs on forks
58
+ // dont triage issues/prs on forks
43
59
  // dont triage autimation bot prs
44
60
  // see https://docs.github.com/en/actions/using-jobs/using-conditions-to-control-job-execution#example-only-run-job-for-specific-repository
45
- 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))`,
61
+ 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))`,
46
62
  runsOn: ['ubuntu-latest'],
47
63
  steps: [{
48
64
  uses: 'actions/add-to-project@v0.4.0',
@@ -53,5 +69,21 @@ export class Triage extends Component {
53
69
  }],
54
70
  });
55
71
 
72
+ if (props.prLabels) {
73
+ workflow.addJob('add-labels-to-pr', {
74
+ permissions: { pullRequests: JobPermission.WRITE },
75
+ if: `(github.repository == \'cdk8s-team/${props.repoName}\') && (github.event.pull_request && github.event.pull_request.user.login != \'cdk8s-automation\')`,
76
+ runsOn: ['ubuntu-latest'],
77
+ steps: [{
78
+ uses: 'actions-ecosystem/action-add-labels@v1',
79
+ with: {
80
+ // weird: https://github.com/actions-ecosystem/action-add-labels/blob/main/src/main.ts#L10
81
+ labels: props.prLabels.join('\n'),
82
+ github_token: '${{ secrets.PROJEN_GITHUB_TOKEN }}',
83
+ },
84
+ }],
85
+ });
86
+ }
87
+
56
88
  }
57
89
  }
package/lib/index.d.ts CHANGED
@@ -1 +1,2 @@
1
1
  export * from './projects';
2
+ export * from './components';
package/lib/index.js CHANGED
@@ -11,4 +11,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
11
11
  };
12
12
  Object.defineProperty(exports, "__esModule", { value: true });
13
13
  __exportStar(require("./projects"), exports);
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsNkNBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9wcm9qZWN0cyc7Il19
14
+ __exportStar(require("./components"), exports);
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsNkNBQTJCO0FBQzNCLCtDQUE2QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcHJvamVjdHMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzJzsiXX0=
@@ -42,7 +42,11 @@ class Cdk8sTeamJsiiProject extends projen_1.cdk.JsiiProject {
42
42
  'jsii-pacmak',
43
43
  'jsii-rosetta',
44
44
  'typescript'];
45
- node.addComponents(this, repoName, finalOptions.depsUpgradeOptions?.workflowOptions?.branches, compilerDependencies);
45
+ node.addComponents(this, repoName, {
46
+ branches: finalOptions.depsUpgradeOptions?.workflowOptions?.branches,
47
+ compilerDeps: compilerDependencies,
48
+ triageOptions: options.triageOptions,
49
+ });
46
50
  if (options.backport ?? false) {
47
51
  new backport_1.Backport(this, { branches: options.backportBranches, repoName });
48
52
  }
@@ -58,7 +62,7 @@ class Cdk8sTeamJsiiProject extends projen_1.cdk.JsiiProject {
58
62
  }
59
63
  exports.Cdk8sTeamJsiiProject = Cdk8sTeamJsiiProject;
60
64
  _a = JSII_RTTI_SYMBOL_1;
61
- Cdk8sTeamJsiiProject[_a] = { fqn: "@cdk8s/projen-common.Cdk8sTeamJsiiProject", version: "0.0.525" };
65
+ Cdk8sTeamJsiiProject[_a] = { fqn: "@cdk8s/projen-common.Cdk8sTeamJsiiProject", version: "0.0.526" };
62
66
  function pythonTarget(name) {
63
67
  const repoName = node.buildRepositoryName(name);
64
68
  return {
@@ -92,4 +96,4 @@ function golangTarget(repoName, branch) {
92
96
  moduleName: `github.com/cdk8s-team/${repoName}-go`,
93
97
  };
94
98
  }
95
- //# 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 * as deepmerge from 'deepmerge';\nimport { DependencyType, 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   * JSII version to use\n   *\n   * @default '1.x'\n   */\n  readonly jsiiVersion?: string;\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 fixedNodeOptions = node.buildNodeProjectFixedOptions(options);\n    const defaultNodeOptions = 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    const finalOptions = deepmerge.all([{\n      author: fixedNodeOptions.authorName!,\n      repositoryUrl: fixedNodeOptions.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      ...fixedNodeOptions,\n      ...defaultNodeOptions,\n    }, options]) as cdk.JsiiProjectOptions;\n\n    super(finalOptions);\n\n    const compilerDependencies = [...(options.additionalCompilerDependencies ?? []),\n      'jsii',\n      'jsii-docgen',\n      'jsii-pacmak',\n      'jsii-rosetta',\n      'typescript'];\n\n    node.addComponents(this, repoName, finalOptions.depsUpgradeOptions?.workflowOptions?.branches, compilerDependencies);\n\n    if (options.backport ?? false) {\n      new Backport(this, { branches: options.backportBranches, repoName });\n    }\n\n    // prevent upgrading the typescript version used by downlevel-dts because\n    // it depends on typescript@next - which causes daily identical releases.\n    this.package.addPackageResolutions('**/downlevel-dts/**/typescript@~5.2.2');\n\n    // prevent upgrading @types/node because crypto and events broke their type definitions.\n    // see https://github.com/cdk8s-team/cdk8s-projen-common/actions/runs/8672468454/job/23782820098?pr=727\n    // hopefully by the time we actually need to upgrade, it will already be fixed.\n    this.deps.removeDependency('@types/node^16');\n    this.deps.addDependency('@types/node@16.18.78', DependencyType.BUILD);\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"]}
99
+ //# 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 * as deepmerge from 'deepmerge';\nimport { DependencyType, 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   * JSII version to use\n   *\n   * @default '1.x'\n   */\n  readonly jsiiVersion?: string;\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 fixedNodeOptions = node.buildNodeProjectFixedOptions(options);\n    const defaultNodeOptions = 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    const finalOptions = deepmerge.all([{\n      author: fixedNodeOptions.authorName!,\n      repositoryUrl: fixedNodeOptions.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      ...fixedNodeOptions,\n      ...defaultNodeOptions,\n    }, options]) as cdk.JsiiProjectOptions;\n\n    super(finalOptions);\n\n    const compilerDependencies = [...(options.additionalCompilerDependencies ?? []),\n      'jsii',\n      'jsii-docgen',\n      'jsii-pacmak',\n      'jsii-rosetta',\n      'typescript'];\n\n    node.addComponents(this, repoName, {\n      branches: finalOptions.depsUpgradeOptions?.workflowOptions?.branches,\n      compilerDeps: compilerDependencies,\n      triageOptions: options.triageOptions,\n    });\n\n    if (options.backport ?? false) {\n      new Backport(this, { branches: options.backportBranches, repoName });\n    }\n\n    // prevent upgrading the typescript version used by downlevel-dts because\n    // it depends on typescript@next - which causes daily identical releases.\n    this.package.addPackageResolutions('**/downlevel-dts/**/typescript@~5.2.2');\n\n    // prevent upgrading @types/node because crypto and events broke their type definitions.\n    // see https://github.com/cdk8s-team/cdk8s-projen-common/actions/runs/8672468454/job/23782820098?pr=727\n    // hopefully by the time we actually need to upgrade, it will already be fixed.\n    this.deps.removeDependency('@types/node^16');\n    this.deps.addDependency('@types/node@16.18.78', DependencyType.BUILD);\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"]}
@@ -1,5 +1,6 @@
1
1
  import { javascript } from 'projen';
2
2
  import { NodeProject } from 'projen/lib/javascript';
3
+ import { TriageOptions } from '../components/triage/triage';
3
4
  export declare const NAME_PREFIX = "cdk8s-";
4
5
  export declare const SCOPE = "@cdk8s/";
5
6
  /**
@@ -48,6 +49,12 @@ export interface Cdk8sTeamNodeProjectOptions extends javascript.NodeProjectOptio
48
49
  * @default - Will be derived from PR labels.
49
50
  */
50
51
  readonly backportBranches?: string[];
52
+ /**
53
+ * Options for the `triage` workflow.
54
+ *
55
+ * @default - no custom options.
56
+ */
57
+ readonly triageOptions?: TriageOptions;
51
58
  }
52
59
  /**
53
60
  * @pjid cdk8s-team-node-project
@@ -65,7 +72,15 @@ export declare function validateOptions(options: any): void;
65
72
  * Validate the name of a project.
66
73
  */
67
74
  export declare function validateProjectName(options: Cdk8sTeamNodeProjectOptions): void;
75
+ /**
76
+ * Options for `addComponents`.
77
+ */
78
+ export interface CommonComponentsOptions {
79
+ readonly branches?: string[];
80
+ readonly compilerDeps?: string[];
81
+ readonly triageOptions?: TriageOptions;
82
+ }
68
83
  /**
69
84
  * Add common components to the project.
70
85
  */
71
- export declare function addComponents(project: NodeProject, repoName: string, branches?: string[], compilerDeps?: string[]): void;
86
+ export declare function addComponents(project: NodeProject, repoName: string, options: CommonComponentsOptions): void;
@@ -125,7 +125,10 @@ class Cdk8sTeamNodeProject extends projen_1.javascript.NodeProject {
125
125
  }, options]);
126
126
  super(finalOptions);
127
127
  const repoName = options.repoName ?? buildRepositoryName(options.name);
128
- addComponents(this, repoName, finalOptions.depsUpgradeOptions?.workflowOptions?.branches);
128
+ addComponents(this, repoName, {
129
+ branches: finalOptions.depsUpgradeOptions?.workflowOptions?.branches,
130
+ triageOptions: options.triageOptions,
131
+ });
129
132
  if (options.backport ?? false) {
130
133
  new backport_1.Backport(this, { branches: options.backportBranches, repoName });
131
134
  }
@@ -133,7 +136,7 @@ class Cdk8sTeamNodeProject extends projen_1.javascript.NodeProject {
133
136
  }
134
137
  exports.Cdk8sTeamNodeProject = Cdk8sTeamNodeProject;
135
138
  _a = JSII_RTTI_SYMBOL_1;
136
- Cdk8sTeamNodeProject[_a] = { fqn: "@cdk8s/projen-common.Cdk8sTeamNodeProject", version: "0.0.525" };
139
+ Cdk8sTeamNodeProject[_a] = { fqn: "@cdk8s/projen-common.Cdk8sTeamNodeProject", version: "0.0.526" };
137
140
  /**
138
141
  * Validate that the options map does not contain any invalid option.
139
142
  * This would usually be implemented at compile time using Omit/Pick but jsii
@@ -178,13 +181,13 @@ exports.validateProjectName = validateProjectName;
178
181
  /**
179
182
  * Add common components to the project.
180
183
  */
181
- function addComponents(project, repoName, branches, compilerDeps) {
184
+ function addComponents(project, repoName, options) {
182
185
  new code_of_conduct_1.CodeOfConductMD(project);
183
186
  new devco_1.DCO(project);
184
187
  new git_hooks_1.GitHooks(project);
185
188
  new issue_templates_1.IssueTemplates(project, { repoName });
186
189
  new security_1.Security(project);
187
- new triage_1.Triage(project, { repoName });
190
+ new triage_1.Triage(project, { repoName, ...options.triageOptions });
188
191
  new stale_1.Stale(project);
189
192
  const configDeps = ['projen'];
190
193
  if (project.name !== '@cdk8s/projen-common') {
@@ -196,29 +199,29 @@ function addComponents(project, repoName, branches, compilerDeps) {
196
199
  pullRequestTitle: 'upgrade configuration',
197
200
  types: [projen_1.DependencyType.BUILD],
198
201
  workflowOptions: {
199
- branches,
202
+ branches: options.branches,
200
203
  labels: ['auto-approve'],
201
204
  schedule: javascript_1.UpgradeDependenciesSchedule.expressions([UPGRADE_CONFIGURATION_SCHEDULE]),
202
205
  },
203
206
  });
204
207
  new javascript_1.UpgradeDependencies(project, {
205
- exclude: [...configDeps, ...(compilerDeps ?? [])],
208
+ exclude: [...configDeps, ...(options.compilerDeps ?? [])],
206
209
  taskName: 'upgrade-dev-dependencies',
207
210
  pullRequestTitle: 'upgrade dev dependencies',
208
211
  workflowOptions: {
209
- branches,
212
+ branches: options.branches,
210
213
  labels: ['auto-approve'],
211
214
  schedule: javascript_1.UpgradeDependenciesSchedule.expressions([UPGRADE_DEV_DEPENDENCIES_SCHEDULE]),
212
215
  },
213
216
  types: [projen_1.DependencyType.BUILD, projen_1.DependencyType.BUNDLED, projen_1.DependencyType.DEVENV, projen_1.DependencyType.TEST],
214
217
  });
215
- if (compilerDeps && compilerDeps.length > 0) {
218
+ if (options.compilerDeps && options.compilerDeps.length > 0) {
216
219
  new javascript_1.UpgradeDependencies(project, {
217
- include: compilerDeps,
220
+ include: options.compilerDeps,
218
221
  taskName: 'upgrade-compiler-dependencies',
219
222
  pullRequestTitle: 'upgrade compiler dependencies',
220
223
  workflowOptions: {
221
- branches,
224
+ branches: options.branches,
222
225
  labels: ['auto-approve'],
223
226
  schedule: javascript_1.UpgradeDependenciesSchedule.expressions([UPGRADE_COMPILER_DEPENDENCIES_SCHEDULE]),
224
227
  },
@@ -227,4 +230,4 @@ function addComponents(project, repoName, branches, compilerDeps) {
227
230
  }
228
231
  }
229
232
  exports.addComponents = addComponents;
230
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.js","sourceRoot":"","sources":["../../src/projects/node.ts"],"names":[],"mappings":"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","sourcesContent":["import * as deepmerge from 'deepmerge';\nimport { DependencyType, ReleasableCommits, javascript } from 'projen';\nimport { NodeProject, NodeProjectOptions, UpgradeDependencies, UpgradeDependenciesOptions, UpgradeDependenciesSchedule } 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 { Security } from '../components/security/security';\nimport { Stale } from '../components/stale/stale';\nimport { Triage } from '../components/triage/triage';\n\nexport const NAME_PREFIX = 'cdk8s-';\nexport const SCOPE = '@cdk8s/';\n\n// they need to be far enough apart so they don't\n// create merge conflicts on one another.\nconst UPGRADE_RUNTIME_DEPENDENCIES_SCHEDULE = '0 6 * * *';\nconst UPGRADE_DEV_DEPENDENCIES_SCHEDULE = '0 9 * * *';\nconst UPGRADE_COMPILER_DEPENDENCIES_SCHEDULE = '0 12 * * *';\nconst UPGRADE_CONFIGURATION_SCHEDULE = '0 15 * * *';\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  'releasableCommits',\n  'workflowNodeVersion',\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  'depsUpgradeOptions',\n  'workflowNodeVersion',\n] as const;\nexport type defaultOptionsKeysType = typeof defaultOptionsKeys[number];\n\n/**\n * Create the fixed typescript project options.\n */\nexport function buildNodeProjectFixedOptions(options: Cdk8sTeamNodeProjectOptions): Pick<javascript.NodeProjectOptions, fixedOptionsKeysType> {\n\n  const releasableCommitsCmd = [\n    ReleasableCommits.featuresAndFixes().cmd,\n\n    // runtime and compiler dependencies should trigger a release because\n    // they have the potential to change the published artifact.\n    \"'chore\\\\(deps\\\\): upgrade runtime dependencies'\",\n    \"'chore\\\\(deps\\\\): upgrade compiler dependencies'\",\n  ];\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    releasableCommits: ReleasableCommits.exec(releasableCommitsCmd.join(' --grep ')),\n\n    // This is the version we actually run GitHub workflows on\n    workflowNodeVersion: '18.12.0',\n  };\n}\n\n/**\n * Create the default typescript project options.\n */\nexport function buildNodeProjectDefaultOptions(options: Cdk8sTeamNodeProjectOptions): Pick<javascript.NodeProjectOptions, defaultOptionsKeysType> {\n\n  const depsUpgradeOptions: UpgradeDependenciesOptions = {\n    taskName: 'upgrade-runtime-dependencies',\n    pullRequestTitle: 'upgrade runtime dependencies',\n    // only include plain dependency because we will created a non release triggering PR for the rest\n    // NOTE: we explicitly do NOT upgrade PEER dependencies. We want the widest range of compatibility possible,\n    // and by bumping peer dependencies we force the customer to also unnecessarily upgrade, which they may not want\n    // to do. Never mind that peerDependencies are usually also devDependencies, so it doesn't make sense to upgrade\n    // them without also upgrading devDependencies.\n    types: [DependencyType.RUNTIME, DependencyType.OPTIONAL, DependencyType.BUNDLED],\n    workflowOptions: {\n      schedule: UpgradeDependenciesSchedule.expressions([UPGRADE_RUNTIME_DEPENDENCIES_SCHEDULE]),\n    },\n  };\n\n  return {\n    // if release is enabled, default to releasing to npm as well\n    releaseToNpm: options.release,\n\n    // This is the minimum version that our consumers should have\n    // (moving this to 18.x requires moving off of TypeScript 4/jsii-compiler 1)\n    minNodeVersion: '16.20.0',\n    workflowNodeVersion: 'lts/*',\n    depsUpgradeOptions,\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  /** 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 * @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    const finalOptions: NodeProjectOptions = deepmerge.all([{\n      ...fixedOptions,\n      ...defaultOptions,\n    }, options]) as NodeProjectOptions;\n\n    super(finalOptions);\n\n    const repoName = options.repoName ?? buildRepositoryName(options.name);\n\n    addComponents(this, repoName, finalOptions.depsUpgradeOptions?.workflowOptions?.branches);\n\n    if (options.backport ?? false) {\n      new Backport(this, { branches: options.backportBranches, repoName });\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, branches?: string[], compilerDeps?: string[]) {\n\n  new CodeOfConductMD(project);\n  new DCO(project);\n  new GitHooks(project);\n  new IssueTemplates(project, { repoName });\n  new Security(project);\n  new Triage(project, { repoName });\n  new Stale(project);\n\n  const configDeps = ['projen'];\n  if (project.name !== '@cdk8s/projen-common') {\n    configDeps.push('@cdk8s/projen-common');\n  }\n\n  new UpgradeDependencies(project, {\n    include: configDeps,\n    taskName: 'upgrade-configuration',\n    pullRequestTitle: 'upgrade configuration',\n    types: [DependencyType.BUILD],\n    workflowOptions: {\n      branches,\n      labels: ['auto-approve'],\n      schedule: UpgradeDependenciesSchedule.expressions([UPGRADE_CONFIGURATION_SCHEDULE]),\n    },\n  });\n\n  new UpgradeDependencies(project, {\n    exclude: [...configDeps, ...(compilerDeps ?? [])],\n    taskName: 'upgrade-dev-dependencies',\n    pullRequestTitle: 'upgrade dev dependencies',\n    workflowOptions: {\n      branches,\n      labels: ['auto-approve'],\n      schedule: UpgradeDependenciesSchedule.expressions([UPGRADE_DEV_DEPENDENCIES_SCHEDULE]),\n    },\n    types: [DependencyType.BUILD, DependencyType.BUNDLED, DependencyType.DEVENV, DependencyType.TEST],\n  });\n\n  if (compilerDeps && compilerDeps.length > 0) {\n    new UpgradeDependencies(project, {\n      include: compilerDeps,\n      taskName: 'upgrade-compiler-dependencies',\n      pullRequestTitle: 'upgrade compiler dependencies',\n      workflowOptions: {\n        branches,\n        labels: ['auto-approve'],\n        schedule: UpgradeDependenciesSchedule.expressions([UPGRADE_COMPILER_DEPENDENCIES_SCHEDULE]),\n      },\n      types: [DependencyType.BUILD],\n    });\n  }\n\n}\n"]}
233
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.js","sourceRoot":"","sources":["../../src/projects/node.ts"],"names":[],"mappings":"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","sourcesContent":["import * as deepmerge from 'deepmerge';\nimport { DependencyType, ReleasableCommits, javascript } from 'projen';\nimport { NodeProject, NodeProjectOptions, UpgradeDependencies, UpgradeDependenciesOptions, UpgradeDependenciesSchedule } 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 { Security } from '../components/security/security';\nimport { Stale } from '../components/stale/stale';\nimport { Triage, TriageOptions } from '../components/triage/triage';\n\nexport const NAME_PREFIX = 'cdk8s-';\nexport const SCOPE = '@cdk8s/';\n\n// they need to be far enough apart so they don't\n// create merge conflicts on one another.\nconst UPGRADE_RUNTIME_DEPENDENCIES_SCHEDULE = '0 6 * * *';\nconst UPGRADE_DEV_DEPENDENCIES_SCHEDULE = '0 9 * * *';\nconst UPGRADE_COMPILER_DEPENDENCIES_SCHEDULE = '0 12 * * *';\nconst UPGRADE_CONFIGURATION_SCHEDULE = '0 15 * * *';\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  'releasableCommits',\n  'workflowNodeVersion',\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  'depsUpgradeOptions',\n  'workflowNodeVersion',\n] as const;\nexport type defaultOptionsKeysType = typeof defaultOptionsKeys[number];\n\n/**\n * Create the fixed typescript project options.\n */\nexport function buildNodeProjectFixedOptions(options: Cdk8sTeamNodeProjectOptions): Pick<javascript.NodeProjectOptions, fixedOptionsKeysType> {\n\n  const releasableCommitsCmd = [\n    ReleasableCommits.featuresAndFixes().cmd,\n\n    // runtime and compiler dependencies should trigger a release because\n    // they have the potential to change the published artifact.\n    \"'chore\\\\(deps\\\\): upgrade runtime dependencies'\",\n    \"'chore\\\\(deps\\\\): upgrade compiler dependencies'\",\n  ];\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    releasableCommits: ReleasableCommits.exec(releasableCommitsCmd.join(' --grep ')),\n\n    // This is the version we actually run GitHub workflows on\n    workflowNodeVersion: '18.12.0',\n  };\n}\n\n/**\n * Create the default typescript project options.\n */\nexport function buildNodeProjectDefaultOptions(options: Cdk8sTeamNodeProjectOptions): Pick<javascript.NodeProjectOptions, defaultOptionsKeysType> {\n\n  const depsUpgradeOptions: UpgradeDependenciesOptions = {\n    taskName: 'upgrade-runtime-dependencies',\n    pullRequestTitle: 'upgrade runtime dependencies',\n    // only include plain dependency because we will created a non release triggering PR for the rest\n    // NOTE: we explicitly do NOT upgrade PEER dependencies. We want the widest range of compatibility possible,\n    // and by bumping peer dependencies we force the customer to also unnecessarily upgrade, which they may not want\n    // to do. Never mind that peerDependencies are usually also devDependencies, so it doesn't make sense to upgrade\n    // them without also upgrading devDependencies.\n    types: [DependencyType.RUNTIME, DependencyType.OPTIONAL, DependencyType.BUNDLED],\n    workflowOptions: {\n      schedule: UpgradeDependenciesSchedule.expressions([UPGRADE_RUNTIME_DEPENDENCIES_SCHEDULE]),\n    },\n  };\n\n  return {\n    // if release is enabled, default to releasing to npm as well\n    releaseToNpm: options.release,\n\n    // This is the minimum version that our consumers should have\n    // (moving this to 18.x requires moving off of TypeScript 4/jsii-compiler 1)\n    minNodeVersion: '16.20.0',\n    workflowNodeVersion: 'lts/*',\n    depsUpgradeOptions,\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  /** 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   * Options for the `triage` workflow.\n   *\n   * @default - no custom options.\n   */\n  readonly triageOptions?: TriageOptions;\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    const finalOptions: NodeProjectOptions = deepmerge.all([{\n      ...fixedOptions,\n      ...defaultOptions,\n    }, options]) as NodeProjectOptions;\n\n    super(finalOptions);\n\n    const repoName = options.repoName ?? buildRepositoryName(options.name);\n\n    addComponents(this, repoName, {\n      branches: finalOptions.depsUpgradeOptions?.workflowOptions?.branches,\n      triageOptions: options.triageOptions,\n    });\n\n    if (options.backport ?? false) {\n      new Backport(this, { branches: options.backportBranches, repoName });\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 * Options for `addComponents`.\n */\nexport interface CommonComponentsOptions {\n  readonly branches?: string[];\n  readonly compilerDeps?: string[];\n  readonly triageOptions?: TriageOptions;\n}\n\n/**\n * Add common components to the project.\n */\nexport function addComponents(project: NodeProject, repoName: string, options: CommonComponentsOptions) {\n\n  new CodeOfConductMD(project);\n  new DCO(project);\n  new GitHooks(project);\n  new IssueTemplates(project, { repoName });\n  new Security(project);\n  new Triage(project, { repoName, ...options.triageOptions });\n  new Stale(project);\n\n  const configDeps = ['projen'];\n  if (project.name !== '@cdk8s/projen-common') {\n    configDeps.push('@cdk8s/projen-common');\n  }\n\n  new UpgradeDependencies(project, {\n    include: configDeps,\n    taskName: 'upgrade-configuration',\n    pullRequestTitle: 'upgrade configuration',\n    types: [DependencyType.BUILD],\n    workflowOptions: {\n      branches: options.branches,\n      labels: ['auto-approve'],\n      schedule: UpgradeDependenciesSchedule.expressions([UPGRADE_CONFIGURATION_SCHEDULE]),\n    },\n  });\n\n  new UpgradeDependencies(project, {\n    exclude: [...configDeps, ...(options.compilerDeps ?? [])],\n    taskName: 'upgrade-dev-dependencies',\n    pullRequestTitle: 'upgrade dev dependencies',\n    workflowOptions: {\n      branches: options.branches,\n      labels: ['auto-approve'],\n      schedule: UpgradeDependenciesSchedule.expressions([UPGRADE_DEV_DEPENDENCIES_SCHEDULE]),\n    },\n    types: [DependencyType.BUILD, DependencyType.BUNDLED, DependencyType.DEVENV, DependencyType.TEST],\n  });\n\n  if (options.compilerDeps && options.compilerDeps.length > 0) {\n    new UpgradeDependencies(project, {\n      include: options.compilerDeps,\n      taskName: 'upgrade-compiler-dependencies',\n      pullRequestTitle: 'upgrade compiler dependencies',\n      workflowOptions: {\n        branches: options.branches,\n        labels: ['auto-approve'],\n        schedule: UpgradeDependenciesSchedule.expressions([UPGRADE_COMPILER_DEPENDENCIES_SCHEDULE]),\n      },\n      types: [DependencyType.BUILD],\n    });\n  }\n\n}\n"]}
@@ -1,4 +1,5 @@
1
1
  import { typescript } from 'projen';
2
+ import { TriageOptions } from '../components';
2
3
  /**
3
4
  * Options for `Cdk8sTeamTypeScriptProject`.
4
5
  */
@@ -28,6 +29,12 @@ export interface Cdk8sTeamTypeScriptProjectOptions extends typescript.TypeScript
28
29
  * @default - No additional compiler dependencies.
29
30
  */
30
31
  readonly additionalCompilerDependencies?: string[];
32
+ /**
33
+ * Options for the `triage` workflow.
34
+ *
35
+ * @default - no custom options.
36
+ */
37
+ readonly triageOptions?: TriageOptions;
31
38
  }
32
39
  /**
33
40
  * @pjid cdk8s-team-typescript-project
@@ -23,7 +23,11 @@ class Cdk8sTeamTypeScriptProject extends projen_1.typescript.TypeScriptProject {
23
23
  super(finalOptions);
24
24
  const repoName = options.repoName ?? node.buildRepositoryName(options.name);
25
25
  const compilerDependencies = [...(options.additionalCompilerDependencies ?? []), 'typescript'];
26
- node.addComponents(this, repoName, finalOptions.depsUpgradeOptions?.workflowOptions?.branches, compilerDependencies);
26
+ node.addComponents(this, repoName, {
27
+ branches: finalOptions.depsUpgradeOptions?.workflowOptions?.branches,
28
+ compilerDeps: compilerDependencies,
29
+ triageOptions: options.triageOptions,
30
+ });
27
31
  if (options.backport ?? false) {
28
32
  new backport_1.Backport(this, { branches: options.backportBranches, repoName });
29
33
  }
@@ -36,5 +40,5 @@ class Cdk8sTeamTypeScriptProject extends projen_1.typescript.TypeScriptProject {
36
40
  }
37
41
  exports.Cdk8sTeamTypeScriptProject = Cdk8sTeamTypeScriptProject;
38
42
  _a = JSII_RTTI_SYMBOL_1;
39
- Cdk8sTeamTypeScriptProject[_a] = { fqn: "@cdk8s/projen-common.Cdk8sTeamTypeScriptProject", version: "0.0.525" };
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXNjcmlwdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wcm9qZWN0cy90eXBlc2NyaXB0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsdUNBQXVDO0FBQ3ZDLG1DQUFvRDtBQUNwRCwrQkFBK0I7QUFDL0IsOERBQTJEO0FBcUMzRDs7R0FFRztBQUNILE1BQWEsMEJBQTJCLFNBQVEsbUJBQVUsQ0FBQyxpQkFBaUI7SUFFMUUsWUFBWSxPQUEwQztRQUNwRCxJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzlCLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVsQyxNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQyw0QkFBNEIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNwRSxNQUFNLGtCQUFrQixHQUFHLElBQUksQ0FBQyw4QkFBOEIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUV4RSxNQUFNLFlBQVksR0FBRyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUM7Z0JBQ2xDLEdBQUcsZ0JBQWdCO2dCQUNuQixHQUFHLGtCQUFrQjthQUN0QixFQUFFLE9BQU8sQ0FBQyxDQUF3QyxDQUFDO1FBRXBELEtBQUssQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUVwQixNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFNUUsTUFBTSxvQkFBb0IsR0FBRyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsOEJBQThCLElBQUksRUFBRSxDQUFDLEVBQUUsWUFBWSxDQUFDLENBQUM7UUFFL0YsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsUUFBUSxFQUFFLFlBQVksQ0FBQyxrQkFBa0IsRUFBRSxlQUFlLEVBQUUsUUFBUSxFQUFFLG9CQUFvQixDQUFDLENBQUM7UUFFckgsSUFBSSxPQUFPLENBQUMsUUFBUSxJQUFJLEtBQUssRUFBRTtZQUM3QixJQUFJLG1CQUFRLENBQUMsSUFBSSxFQUFFLEVBQUUsUUFBUSxFQUFFLE9BQU8sQ0FBQyxnQkFBZ0IsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO1NBQ3RFO1FBRUQsd0ZBQXdGO1FBQ3hGLHVHQUF1RztRQUN2RywrRUFBK0U7UUFDL0UsSUFBSSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUMxQyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxzQkFBc0IsRUFBRSx1QkFBYyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBRXhFLENBQUM7O0FBaENILGdFQWlDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGRlZXBtZXJnZSBmcm9tICdkZWVwbWVyZ2UnO1xuaW1wb3J0IHsgRGVwZW5kZW5jeVR5cGUsIHR5cGVzY3JpcHQgfSBmcm9tICdwcm9qZW4nO1xuaW1wb3J0ICogYXMgbm9kZSBmcm9tICcuL25vZGUnO1xuaW1wb3J0IHsgQmFja3BvcnQgfSBmcm9tICcuLi9jb21wb25lbnRzL2JhY2twb3J0L2JhY2twb3J0JztcblxuLyoqXG4gKiBPcHRpb25zIGZvciBgQ2RrOHNUZWFtVHlwZVNjcmlwdFByb2plY3RgLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENkazhzVGVhbVR5cGVTY3JpcHRQcm9qZWN0T3B0aW9ucyBleHRlbmRzIHR5cGVzY3JpcHQuVHlwZVNjcmlwdFByb2plY3RPcHRpb25zIHtcblxuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIHJlcG9zaXRvcnkgaW5zaWRlIHRoZSBjZGs4cy10ZWFtXG4gICAqIG9yZyB3aGVyZSB0aGUgY29kZSBvZiB0aGUgcHJvamVjdCBpcyBsb2NhdGUgaW4uXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gdGhlIHBhY2thZ2UgbmFtZS5cbiAgICovXG4gIHJlYWRvbmx5IHJlcG9OYW1lPzogc3RyaW5nO1xuXG4gIC8qKiBDb25maWd1cmUgYSBiYWNrcG9ydCB3b3JrZmxvdy5cbiAgICpcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIHJlYWRvbmx5IGJhY2twb3J0PzogYm9vbGVhbjtcblxuICAvKipcbiAgICogQnJhbmNoZXMgdG8gYmFja3BvcnQgdG8uXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gV2lsbCBiZSBkZXJpdmVkIGZyb20gUFIgbGFiZWxzLlxuICAgKi9cbiAgcmVhZG9ubHkgYmFja3BvcnRCcmFuY2hlcz86IHN0cmluZ1tdO1xuXG4gIC8qKlxuICAgKiBQYWNrYWdlcyB0aGF0IGNvbXBpbGUgdGhlIHByb2plY3QgYXBhcnQgZnJvbSB0aGUgdHlwZXNjcmlwdC9qc2lpIGNvbXBpbGVyLlxuICAgKiBBbnkgcGFja2FnZSB0aGF0IHByb2R1Y2VzIGEgcHVibGlzaGVkIGFydGlmYWN0IHNob3VsZCBiZSBpbmNsdWRlZCBpbiB0aGlzIGxpc3QuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gTm8gYWRkaXRpb25hbCBjb21waWxlciBkZXBlbmRlbmNpZXMuXG4gICAqL1xuICByZWFkb25seSBhZGRpdGlvbmFsQ29tcGlsZXJEZXBlbmRlbmNpZXM/OiBzdHJpbmdbXTtcbn1cblxuLyoqXG4gKiBAcGppZCBjZGs4cy10ZWFtLXR5cGVzY3JpcHQtcHJvamVjdFxuICovXG5leHBvcnQgY2xhc3MgQ2RrOHNUZWFtVHlwZVNjcmlwdFByb2plY3QgZXh0ZW5kcyB0eXBlc2NyaXB0LlR5cGVTY3JpcHRQcm9qZWN0IHtcblxuICBjb25zdHJ1Y3RvcihvcHRpb25zOiBDZGs4c1RlYW1UeXBlU2NyaXB0UHJvamVjdE9wdGlvbnMpIHtcbiAgICBub2RlLnZhbGlkYXRlT3B0aW9ucyhvcHRpb25zKTtcbiAgICBub2RlLnZhbGlkYXRlUHJvamVjdE5hbWUob3B0aW9ucyk7XG5cbiAgICBjb25zdCBmaXhlZE5vZGVPcHRpb25zID0gbm9kZS5idWlsZE5vZGVQcm9qZWN0Rml4ZWRPcHRpb25zKG9wdGlvbnMpO1xuICAgIGNvbnN0IGRlZmF1bHROb2RlT3B0aW9ucyA9IG5vZGUuYnVpbGROb2RlUHJvamVjdERlZmF1bHRPcHRpb25zKG9wdGlvbnMpO1xuXG4gICAgY29uc3QgZmluYWxPcHRpb25zID0gZGVlcG1lcmdlLmFsbChbe1xuICAgICAgLi4uZml4ZWROb2RlT3B0aW9ucyxcbiAgICAgIC4uLmRlZmF1bHROb2RlT3B0aW9ucyxcbiAgICB9LCBvcHRpb25zXSkgYXMgdHlwZXNjcmlwdC5UeXBlU2NyaXB0UHJvamVjdE9wdGlvbnM7XG5cbiAgICBzdXBlcihmaW5hbE9wdGlvbnMpO1xuXG4gICAgY29uc3QgcmVwb05hbWUgPSBvcHRpb25zLnJlcG9OYW1lID8/IG5vZGUuYnVpbGRSZXBvc2l0b3J5TmFtZShvcHRpb25zLm5hbWUpO1xuXG4gICAgY29uc3QgY29tcGlsZXJEZXBlbmRlbmNpZXMgPSBbLi4uKG9wdGlvbnMuYWRkaXRpb25hbENvbXBpbGVyRGVwZW5kZW5jaWVzID8/IFtdKSwgJ3R5cGVzY3JpcHQnXTtcblxuICAgIG5vZGUuYWRkQ29tcG9uZW50cyh0aGlzLCByZXBvTmFtZSwgZmluYWxPcHRpb25zLmRlcHNVcGdyYWRlT3B0aW9ucz8ud29ya2Zsb3dPcHRpb25zPy5icmFuY2hlcywgY29tcGlsZXJEZXBlbmRlbmNpZXMpO1xuXG4gICAgaWYgKG9wdGlvbnMuYmFja3BvcnQgPz8gZmFsc2UpIHtcbiAgICAgIG5ldyBCYWNrcG9ydCh0aGlzLCB7IGJyYW5jaGVzOiBvcHRpb25zLmJhY2twb3J0QnJhbmNoZXMsIHJlcG9OYW1lIH0pO1xuICAgIH1cblxuICAgIC8vIHByZXZlbnQgdXBncmFkaW5nIEB0eXBlcy9ub2RlIGJlY2F1c2UgY3J5cHRvIGFuZCBldmVudHMgYnJva2UgdGhlaXIgdHlwZSBkZWZpbml0aW9ucy5cbiAgICAvLyBzZWUgaHR0cHM6Ly9naXRodWIuY29tL2NkazhzLXRlYW0vY2RrOHMtcHJvamVuLWNvbW1vbi9hY3Rpb25zL3J1bnMvODY3MjQ2ODQ1NC9qb2IvMjM3ODI4MjAwOTg/cHI9NzI3XG4gICAgLy8gaG9wZWZ1bGx5IGJ5IHRoZSB0aW1lIHdlIGFjdHVhbGx5IG5lZWQgdG8gdXBncmFkZSwgaXQgd2lsbCBhbHJlYWR5IGJlIGZpeGVkLlxuICAgIHRoaXMuZGVwcy5yZW1vdmVEZXBlbmRlbmN5KCdAdHlwZXMvbm9kZScpO1xuICAgIHRoaXMuZGVwcy5hZGREZXBlbmRlbmN5KCdAdHlwZXMvbm9kZUAxNi4xOC43OCcsIERlcGVuZGVuY3lUeXBlLkJVSUxEKTtcblxuICB9XG59XG4iXX0=
43
+ Cdk8sTeamTypeScriptProject[_a] = { fqn: "@cdk8s/projen-common.Cdk8sTeamTypeScriptProject", version: "0.0.526" };
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXNjcmlwdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wcm9qZWN0cy90eXBlc2NyaXB0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsdUNBQXVDO0FBQ3ZDLG1DQUFvRDtBQUNwRCwrQkFBK0I7QUFFL0IsOERBQTJEO0FBNkMzRDs7R0FFRztBQUNILE1BQWEsMEJBQTJCLFNBQVEsbUJBQVUsQ0FBQyxpQkFBaUI7SUFFMUUsWUFBWSxPQUEwQztRQUNwRCxJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzlCLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVsQyxNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQyw0QkFBNEIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNwRSxNQUFNLGtCQUFrQixHQUFHLElBQUksQ0FBQyw4QkFBOEIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUV4RSxNQUFNLFlBQVksR0FBRyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUM7Z0JBQ2xDLEdBQUcsZ0JBQWdCO2dCQUNuQixHQUFHLGtCQUFrQjthQUN0QixFQUFFLE9BQU8sQ0FBQyxDQUF3QyxDQUFDO1FBRXBELEtBQUssQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUVwQixNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFNUUsTUFBTSxvQkFBb0IsR0FBRyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsOEJBQThCLElBQUksRUFBRSxDQUFDLEVBQUUsWUFBWSxDQUFDLENBQUM7UUFFL0YsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsUUFBUSxFQUFFO1lBQ2pDLFFBQVEsRUFBRSxZQUFZLENBQUMsa0JBQWtCLEVBQUUsZUFBZSxFQUFFLFFBQVE7WUFDcEUsWUFBWSxFQUFFLG9CQUFvQjtZQUNsQyxhQUFhLEVBQUUsT0FBTyxDQUFDLGFBQWE7U0FDckMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxPQUFPLENBQUMsUUFBUSxJQUFJLEtBQUssRUFBRTtZQUM3QixJQUFJLG1CQUFRLENBQUMsSUFBSSxFQUFFLEVBQUUsUUFBUSxFQUFFLE9BQU8sQ0FBQyxnQkFBZ0IsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO1NBQ3RFO1FBRUQsd0ZBQXdGO1FBQ3hGLHVHQUF1RztRQUN2RywrRUFBK0U7UUFDL0UsSUFBSSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUMxQyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxzQkFBc0IsRUFBRSx1QkFBYyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBRXhFLENBQUM7O0FBcENILGdFQXFDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGRlZXBtZXJnZSBmcm9tICdkZWVwbWVyZ2UnO1xuaW1wb3J0IHsgRGVwZW5kZW5jeVR5cGUsIHR5cGVzY3JpcHQgfSBmcm9tICdwcm9qZW4nO1xuaW1wb3J0ICogYXMgbm9kZSBmcm9tICcuL25vZGUnO1xuaW1wb3J0IHsgVHJpYWdlT3B0aW9ucyB9IGZyb20gJy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgQmFja3BvcnQgfSBmcm9tICcuLi9jb21wb25lbnRzL2JhY2twb3J0L2JhY2twb3J0JztcblxuLyoqXG4gKiBPcHRpb25zIGZvciBgQ2RrOHNUZWFtVHlwZVNjcmlwdFByb2plY3RgLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENkazhzVGVhbVR5cGVTY3JpcHRQcm9qZWN0T3B0aW9ucyBleHRlbmRzIHR5cGVzY3JpcHQuVHlwZVNjcmlwdFByb2plY3RPcHRpb25zIHtcblxuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIHJlcG9zaXRvcnkgaW5zaWRlIHRoZSBjZGs4cy10ZWFtXG4gICAqIG9yZyB3aGVyZSB0aGUgY29kZSBvZiB0aGUgcHJvamVjdCBpcyBsb2NhdGUgaW4uXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gdGhlIHBhY2thZ2UgbmFtZS5cbiAgICovXG4gIHJlYWRvbmx5IHJlcG9OYW1lPzogc3RyaW5nO1xuXG4gIC8qKiBDb25maWd1cmUgYSBiYWNrcG9ydCB3b3JrZmxvdy5cbiAgICpcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIHJlYWRvbmx5IGJhY2twb3J0PzogYm9vbGVhbjtcblxuICAvKipcbiAgICogQnJhbmNoZXMgdG8gYmFja3BvcnQgdG8uXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gV2lsbCBiZSBkZXJpdmVkIGZyb20gUFIgbGFiZWxzLlxuICAgKi9cbiAgcmVhZG9ubHkgYmFja3BvcnRCcmFuY2hlcz86IHN0cmluZ1tdO1xuXG4gIC8qKlxuICAgKiBQYWNrYWdlcyB0aGF0IGNvbXBpbGUgdGhlIHByb2plY3QgYXBhcnQgZnJvbSB0aGUgdHlwZXNjcmlwdC9qc2lpIGNvbXBpbGVyLlxuICAgKiBBbnkgcGFja2FnZSB0aGF0IHByb2R1Y2VzIGEgcHVibGlzaGVkIGFydGlmYWN0IHNob3VsZCBiZSBpbmNsdWRlZCBpbiB0aGlzIGxpc3QuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gTm8gYWRkaXRpb25hbCBjb21waWxlciBkZXBlbmRlbmNpZXMuXG4gICAqL1xuICByZWFkb25seSBhZGRpdGlvbmFsQ29tcGlsZXJEZXBlbmRlbmNpZXM/OiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogT3B0aW9ucyBmb3IgdGhlIGB0cmlhZ2VgIHdvcmtmbG93LlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIG5vIGN1c3RvbSBvcHRpb25zLlxuICAgKi9cbiAgcmVhZG9ubHkgdHJpYWdlT3B0aW9ucz86IFRyaWFnZU9wdGlvbnM7XG5cbn1cblxuLyoqXG4gKiBAcGppZCBjZGs4cy10ZWFtLXR5cGVzY3JpcHQtcHJvamVjdFxuICovXG5leHBvcnQgY2xhc3MgQ2RrOHNUZWFtVHlwZVNjcmlwdFByb2plY3QgZXh0ZW5kcyB0eXBlc2NyaXB0LlR5cGVTY3JpcHRQcm9qZWN0IHtcblxuICBjb25zdHJ1Y3RvcihvcHRpb25zOiBDZGs4c1RlYW1UeXBlU2NyaXB0UHJvamVjdE9wdGlvbnMpIHtcbiAgICBub2RlLnZhbGlkYXRlT3B0aW9ucyhvcHRpb25zKTtcbiAgICBub2RlLnZhbGlkYXRlUHJvamVjdE5hbWUob3B0aW9ucyk7XG5cbiAgICBjb25zdCBmaXhlZE5vZGVPcHRpb25zID0gbm9kZS5idWlsZE5vZGVQcm9qZWN0Rml4ZWRPcHRpb25zKG9wdGlvbnMpO1xuICAgIGNvbnN0IGRlZmF1bHROb2RlT3B0aW9ucyA9IG5vZGUuYnVpbGROb2RlUHJvamVjdERlZmF1bHRPcHRpb25zKG9wdGlvbnMpO1xuXG4gICAgY29uc3QgZmluYWxPcHRpb25zID0gZGVlcG1lcmdlLmFsbChbe1xuICAgICAgLi4uZml4ZWROb2RlT3B0aW9ucyxcbiAgICAgIC4uLmRlZmF1bHROb2RlT3B0aW9ucyxcbiAgICB9LCBvcHRpb25zXSkgYXMgdHlwZXNjcmlwdC5UeXBlU2NyaXB0UHJvamVjdE9wdGlvbnM7XG5cbiAgICBzdXBlcihmaW5hbE9wdGlvbnMpO1xuXG4gICAgY29uc3QgcmVwb05hbWUgPSBvcHRpb25zLnJlcG9OYW1lID8/IG5vZGUuYnVpbGRSZXBvc2l0b3J5TmFtZShvcHRpb25zLm5hbWUpO1xuXG4gICAgY29uc3QgY29tcGlsZXJEZXBlbmRlbmNpZXMgPSBbLi4uKG9wdGlvbnMuYWRkaXRpb25hbENvbXBpbGVyRGVwZW5kZW5jaWVzID8/IFtdKSwgJ3R5cGVzY3JpcHQnXTtcblxuICAgIG5vZGUuYWRkQ29tcG9uZW50cyh0aGlzLCByZXBvTmFtZSwge1xuICAgICAgYnJhbmNoZXM6IGZpbmFsT3B0aW9ucy5kZXBzVXBncmFkZU9wdGlvbnM/LndvcmtmbG93T3B0aW9ucz8uYnJhbmNoZXMsXG4gICAgICBjb21waWxlckRlcHM6IGNvbXBpbGVyRGVwZW5kZW5jaWVzLFxuICAgICAgdHJpYWdlT3B0aW9uczogb3B0aW9ucy50cmlhZ2VPcHRpb25zLFxuICAgIH0pO1xuXG4gICAgaWYgKG9wdGlvbnMuYmFja3BvcnQgPz8gZmFsc2UpIHtcbiAgICAgIG5ldyBCYWNrcG9ydCh0aGlzLCB7IGJyYW5jaGVzOiBvcHRpb25zLmJhY2twb3J0QnJhbmNoZXMsIHJlcG9OYW1lIH0pO1xuICAgIH1cblxuICAgIC8vIHByZXZlbnQgdXBncmFkaW5nIEB0eXBlcy9ub2RlIGJlY2F1c2UgY3J5cHRvIGFuZCBldmVudHMgYnJva2UgdGhlaXIgdHlwZSBkZWZpbml0aW9ucy5cbiAgICAvLyBzZWUgaHR0cHM6Ly9naXRodWIuY29tL2NkazhzLXRlYW0vY2RrOHMtcHJvamVuLWNvbW1vbi9hY3Rpb25zL3J1bnMvODY3MjQ2ODQ1NC9qb2IvMjM3ODI4MjAwOTg/cHI9NzI3XG4gICAgLy8gaG9wZWZ1bGx5IGJ5IHRoZSB0aW1lIHdlIGFjdHVhbGx5IG5lZWQgdG8gdXBncmFkZSwgaXQgd2lsbCBhbHJlYWR5IGJlIGZpeGVkLlxuICAgIHRoaXMuZGVwcy5yZW1vdmVEZXBlbmRlbmN5KCdAdHlwZXMvbm9kZScpO1xuICAgIHRoaXMuZGVwcy5hZGREZXBlbmRlbmN5KCdAdHlwZXMvbm9kZUAxNi4xOC43OCcsIERlcGVuZGVuY3lUeXBlLkJVSUxEKTtcblxuICB9XG59XG4iXX0=
package/package.json CHANGED
@@ -77,7 +77,7 @@
77
77
  },
78
78
  "main": "lib/index.js",
79
79
  "license": "Apache-2.0",
80
- "version": "0.0.525",
80
+ "version": "0.0.526",
81
81
  "jest": {
82
82
  "testMatch": [
83
83
  "<rootDir>/src/**/__tests__/**/*.ts?(x)",