@cdk8s/projen-common 0.0.524 → 0.0.526
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +242 -11
- package/API.md +344 -0
- package/lib/components/backport/backport.js +2 -4
- package/lib/components/backport/backport.ts +1 -3
- package/lib/components/index.d.ts +1 -0
- package/lib/components/index.js +14 -0
- package/lib/components/index.ts +1 -0
- package/lib/components/triage/triage.d.ts +15 -3
- package/lib/components/triage/triage.js +23 -4
- package/lib/components/triage/triage.ts +37 -5
- package/lib/index.d.ts +1 -0
- package/lib/index.js +2 -1
- package/lib/projects/jsii.js +7 -3
- package/lib/projects/node.d.ts +16 -1
- package/lib/projects/node.js +14 -11
- package/lib/projects/typescript.d.ts +7 -0
- package/lib/projects/typescript.js +7 -3
- package/package.json +1 -1
|
@@ -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
|
-
*
|
|
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,
|
|
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
|
|
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/${
|
|
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
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
|
-
|
|
14
|
+
__exportStar(require("./components"), exports);
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsNkNBQTJCO0FBQzNCLCtDQUE2QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcHJvamVjdHMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzJzsiXX0=
|
package/lib/projects/jsii.js
CHANGED
|
@@ -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,
|
|
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.
|
|
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"]}
|
package/lib/projects/node.d.ts
CHANGED
|
@@ -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,
|
|
86
|
+
export declare function addComponents(project: NodeProject, repoName: string, options: CommonComponentsOptions): void;
|
package/lib/projects/node.js
CHANGED
|
@@ -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,
|
|
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.
|
|
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,
|
|
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,
|
|
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.
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
Cdk8sTeamTypeScriptProject[_a] = { fqn: "@cdk8s/projen-common.Cdk8sTeamTypeScriptProject", version: "0.0.526" };
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXNjcmlwdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wcm9qZWN0cy90eXBlc2NyaXB0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsdUNBQXVDO0FBQ3ZDLG1DQUFvRDtBQUNwRCwrQkFBK0I7QUFFL0IsOERBQTJEO0FBNkMzRDs7R0FFRztBQUNILE1BQWEsMEJBQTJCLFNBQVEsbUJBQVUsQ0FBQyxpQkFBaUI7SUFFMUUsWUFBWSxPQUEwQztRQUNwRCxJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzlCLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVsQyxNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQyw0QkFBNEIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNwRSxNQUFNLGtCQUFrQixHQUFHLElBQUksQ0FBQyw4QkFBOEIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUV4RSxNQUFNLFlBQVksR0FBRyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUM7Z0JBQ2xDLEdBQUcsZ0JBQWdCO2dCQUNuQixHQUFHLGtCQUFrQjthQUN0QixFQUFFLE9BQU8sQ0FBQyxDQUF3QyxDQUFDO1FBRXBELEtBQUssQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUVwQixNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFNUUsTUFBTSxvQkFBb0IsR0FBRyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsOEJBQThCLElBQUksRUFBRSxDQUFDLEVBQUUsWUFBWSxDQUFDLENBQUM7UUFFL0YsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsUUFBUSxFQUFFO1lBQ2pDLFFBQVEsRUFBRSxZQUFZLENBQUMsa0JBQWtCLEVBQUUsZUFBZSxFQUFFLFFBQVE7WUFDcEUsWUFBWSxFQUFFLG9CQUFvQjtZQUNsQyxhQUFhLEVBQUUsT0FBTyxDQUFDLGFBQWE7U0FDckMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxPQUFPLENBQUMsUUFBUSxJQUFJLEtBQUssRUFBRTtZQUM3QixJQUFJLG1CQUFRLENBQUMsSUFBSSxFQUFFLEVBQUUsUUFBUSxFQUFFLE9BQU8sQ0FBQyxnQkFBZ0IsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO1NBQ3RFO1FBRUQsd0ZBQXdGO1FBQ3hGLHVHQUF1RztRQUN2RywrRUFBK0U7UUFDL0UsSUFBSSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUMxQyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxzQkFBc0IsRUFBRSx1QkFBYyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBRXhFLENBQUM7O0FBcENILGdFQXFDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGRlZXBtZXJnZSBmcm9tICdkZWVwbWVyZ2UnO1xuaW1wb3J0IHsgRGVwZW5kZW5jeVR5cGUsIHR5cGVzY3JpcHQgfSBmcm9tICdwcm9qZW4nO1xuaW1wb3J0ICogYXMgbm9kZSBmcm9tICcuL25vZGUnO1xuaW1wb3J0IHsgVHJpYWdlT3B0aW9ucyB9IGZyb20gJy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgQmFja3BvcnQgfSBmcm9tICcuLi9jb21wb25lbnRzL2JhY2twb3J0L2JhY2twb3J0JztcblxuLyoqXG4gKiBPcHRpb25zIGZvciBgQ2RrOHNUZWFtVHlwZVNjcmlwdFByb2plY3RgLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENkazhzVGVhbVR5cGVTY3JpcHRQcm9qZWN0T3B0aW9ucyBleHRlbmRzIHR5cGVzY3JpcHQuVHlwZVNjcmlwdFByb2plY3RPcHRpb25zIHtcblxuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIHJlcG9zaXRvcnkgaW5zaWRlIHRoZSBjZGs4cy10ZWFtXG4gICAqIG9yZyB3aGVyZSB0aGUgY29kZSBvZiB0aGUgcHJvamVjdCBpcyBsb2NhdGUgaW4uXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gdGhlIHBhY2thZ2UgbmFtZS5cbiAgICovXG4gIHJlYWRvbmx5IHJlcG9OYW1lPzogc3RyaW5nO1xuXG4gIC8qKiBDb25maWd1cmUgYSBiYWNrcG9ydCB3b3JrZmxvdy5cbiAgICpcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIHJlYWRvbmx5IGJhY2twb3J0PzogYm9vbGVhbjtcblxuICAvKipcbiAgICogQnJhbmNoZXMgdG8gYmFja3BvcnQgdG8uXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gV2lsbCBiZSBkZXJpdmVkIGZyb20gUFIgbGFiZWxzLlxuICAgKi9cbiAgcmVhZG9ubHkgYmFja3BvcnRCcmFuY2hlcz86IHN0cmluZ1tdO1xuXG4gIC8qKlxuICAgKiBQYWNrYWdlcyB0aGF0IGNvbXBpbGUgdGhlIHByb2plY3QgYXBhcnQgZnJvbSB0aGUgdHlwZXNjcmlwdC9qc2lpIGNvbXBpbGVyLlxuICAgKiBBbnkgcGFja2FnZSB0aGF0IHByb2R1Y2VzIGEgcHVibGlzaGVkIGFydGlmYWN0IHNob3VsZCBiZSBpbmNsdWRlZCBpbiB0aGlzIGxpc3QuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gTm8gYWRkaXRpb25hbCBjb21waWxlciBkZXBlbmRlbmNpZXMuXG4gICAqL1xuICByZWFkb25seSBhZGRpdGlvbmFsQ29tcGlsZXJEZXBlbmRlbmNpZXM/OiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogT3B0aW9ucyBmb3IgdGhlIGB0cmlhZ2VgIHdvcmtmbG93LlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIG5vIGN1c3RvbSBvcHRpb25zLlxuICAgKi9cbiAgcmVhZG9ubHkgdHJpYWdlT3B0aW9ucz86IFRyaWFnZU9wdGlvbnM7XG5cbn1cblxuLyoqXG4gKiBAcGppZCBjZGs4cy10ZWFtLXR5cGVzY3JpcHQtcHJvamVjdFxuICovXG5leHBvcnQgY2xhc3MgQ2RrOHNUZWFtVHlwZVNjcmlwdFByb2plY3QgZXh0ZW5kcyB0eXBlc2NyaXB0LlR5cGVTY3JpcHRQcm9qZWN0IHtcblxuICBjb25zdHJ1Y3RvcihvcHRpb25zOiBDZGs4c1RlYW1UeXBlU2NyaXB0UHJvamVjdE9wdGlvbnMpIHtcbiAgICBub2RlLnZhbGlkYXRlT3B0aW9ucyhvcHRpb25zKTtcbiAgICBub2RlLnZhbGlkYXRlUHJvamVjdE5hbWUob3B0aW9ucyk7XG5cbiAgICBjb25zdCBmaXhlZE5vZGVPcHRpb25zID0gbm9kZS5idWlsZE5vZGVQcm9qZWN0Rml4ZWRPcHRpb25zKG9wdGlvbnMpO1xuICAgIGNvbnN0IGRlZmF1bHROb2RlT3B0aW9ucyA9IG5vZGUuYnVpbGROb2RlUHJvamVjdERlZmF1bHRPcHRpb25zKG9wdGlvbnMpO1xuXG4gICAgY29uc3QgZmluYWxPcHRpb25zID0gZGVlcG1lcmdlLmFsbChbe1xuICAgICAgLi4uZml4ZWROb2RlT3B0aW9ucyxcbiAgICAgIC4uLmRlZmF1bHROb2RlT3B0aW9ucyxcbiAgICB9LCBvcHRpb25zXSkgYXMgdHlwZXNjcmlwdC5UeXBlU2NyaXB0UHJvamVjdE9wdGlvbnM7XG5cbiAgICBzdXBlcihmaW5hbE9wdGlvbnMpO1xuXG4gICAgY29uc3QgcmVwb05hbWUgPSBvcHRpb25zLnJlcG9OYW1lID8/IG5vZGUuYnVpbGRSZXBvc2l0b3J5TmFtZShvcHRpb25zLm5hbWUpO1xuXG4gICAgY29uc3QgY29tcGlsZXJEZXBlbmRlbmNpZXMgPSBbLi4uKG9wdGlvbnMuYWRkaXRpb25hbENvbXBpbGVyRGVwZW5kZW5jaWVzID8/IFtdKSwgJ3R5cGVzY3JpcHQnXTtcblxuICAgIG5vZGUuYWRkQ29tcG9uZW50cyh0aGlzLCByZXBvTmFtZSwge1xuICAgICAgYnJhbmNoZXM6IGZpbmFsT3B0aW9ucy5kZXBzVXBncmFkZU9wdGlvbnM/LndvcmtmbG93T3B0aW9ucz8uYnJhbmNoZXMsXG4gICAgICBjb21waWxlckRlcHM6IGNvbXBpbGVyRGVwZW5kZW5jaWVzLFxuICAgICAgdHJpYWdlT3B0aW9uczogb3B0aW9ucy50cmlhZ2VPcHRpb25zLFxuICAgIH0pO1xuXG4gICAgaWYgKG9wdGlvbnMuYmFja3BvcnQgPz8gZmFsc2UpIHtcbiAgICAgIG5ldyBCYWNrcG9ydCh0aGlzLCB7IGJyYW5jaGVzOiBvcHRpb25zLmJhY2twb3J0QnJhbmNoZXMsIHJlcG9OYW1lIH0pO1xuICAgIH1cblxuICAgIC8vIHByZXZlbnQgdXBncmFkaW5nIEB0eXBlcy9ub2RlIGJlY2F1c2UgY3J5cHRvIGFuZCBldmVudHMgYnJva2UgdGhlaXIgdHlwZSBkZWZpbml0aW9ucy5cbiAgICAvLyBzZWUgaHR0cHM6Ly9naXRodWIuY29tL2NkazhzLXRlYW0vY2RrOHMtcHJvamVuLWNvbW1vbi9hY3Rpb25zL3J1bnMvODY3MjQ2ODQ1NC9qb2IvMjM3ODI4MjAwOTg/cHI9NzI3XG4gICAgLy8gaG9wZWZ1bGx5IGJ5IHRoZSB0aW1lIHdlIGFjdHVhbGx5IG5lZWQgdG8gdXBncmFkZSwgaXQgd2lsbCBhbHJlYWR5IGJlIGZpeGVkLlxuICAgIHRoaXMuZGVwcy5yZW1vdmVEZXBlbmRlbmN5KCdAdHlwZXMvbm9kZScpO1xuICAgIHRoaXMuZGVwcy5hZGREZXBlbmRlbmN5KCdAdHlwZXMvbm9kZUAxNi4xOC43OCcsIERlcGVuZGVuY3lUeXBlLkJVSUxEKTtcblxuICB9XG59XG4iXX0=
|