@codedrifters/configulator 0.0.0 → 0.0.1
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/LICENSE +1 -1
- package/README.md +761 -1
- package/lib/aws/aws-deployment-config.d.ts +45 -108
- package/lib/aws/aws-deployment-config.js +69 -100
- package/lib/aws/aws-deployment-target.d.ts +210 -0
- package/lib/aws/aws-deployment-target.js +202 -0
- package/lib/aws/index.d.ts +1 -1
- package/lib/aws/index.js +2 -2
- package/lib/index.d.ts +9 -0
- package/lib/index.js +26 -0
- package/lib/jsii/index.d.ts +1 -0
- package/lib/jsii/index.js +18 -0
- package/lib/jsii/jsii-faker.d.ts +47 -0
- package/lib/jsii/jsii-faker.js +103 -0
- package/lib/pnpm/pnpm-workspace.d.ts +240 -1
- package/lib/pnpm/pnpm-workspace.js +155 -15
- package/lib/projects/index.d.ts +2 -0
- package/lib/projects/index.js +19 -0
- package/lib/projects/monorepo-project.d.ts +50 -0
- package/lib/projects/monorepo-project.js +203 -0
- package/lib/projects/typescript-project.d.ts +4 -0
- package/lib/projects/typescript-project.js +150 -0
- package/lib/turbo/turbo-repo.d.ts +116 -9
- package/lib/turbo/turbo-repo.js +107 -20
- package/lib/versions.d.ts +19 -7
- package/lib/versions.js +20 -8
- package/lib/vscode/vscode.js +2 -1
- package/lib/workflows/aws-deploy-workflow.d.ts +84 -0
- package/lib/workflows/aws-deploy-workflow.js +312 -0
- package/lib/workflows/index.d.ts +1 -2
- package/lib/workflows/index.js +2 -3
- package/package.json +21 -20
- package/lib/workflows/build-workflow.d.ts +0 -13
- package/lib/workflows/build-workflow.js +0 -64
- package/lib/workflows/deploy-workflow.d.ts +0 -17
- package/lib/workflows/deploy-workflow.js +0 -113
- package/lib/workflows/steps/deploy.d.ts +0 -4
- package/lib/workflows/steps/deploy.js +0 -62
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.JsiiFaker = void 0;
|
|
37
|
+
const spec = __importStar(require("@jsii/spec"));
|
|
38
|
+
const projen_1 = require("projen");
|
|
39
|
+
/**
|
|
40
|
+
* The FQNs for the base classes and options used by Jsii.
|
|
41
|
+
*
|
|
42
|
+
* These are the defaults used by Projen's TypeScriptProject.
|
|
43
|
+
*/
|
|
44
|
+
const ProjenBaseFqn = {
|
|
45
|
+
TYPESCRIPT_PROJECT: "projen.typescript.TypeScriptProject",
|
|
46
|
+
TYPESCRIPT_PROJECT_OPTIONS: "projen.typescript.TypeScriptProjectOptions",
|
|
47
|
+
};
|
|
48
|
+
class JsiiFaker extends projen_1.Component {
|
|
49
|
+
// find project singleton
|
|
50
|
+
static of(project) {
|
|
51
|
+
const isDefined = (c) => c instanceof JsiiFaker;
|
|
52
|
+
return project.components.find(isDefined);
|
|
53
|
+
}
|
|
54
|
+
constructor(project) {
|
|
55
|
+
super(project);
|
|
56
|
+
this.project = project;
|
|
57
|
+
this._types = {};
|
|
58
|
+
this.toJSON = () => {
|
|
59
|
+
return {
|
|
60
|
+
types: this._types,
|
|
61
|
+
};
|
|
62
|
+
};
|
|
63
|
+
/**
|
|
64
|
+
* In JSII, the assembly name is essentially the package name. It's used as a
|
|
65
|
+
* scope when targeting types and metadata in other "jsii assemblies" that
|
|
66
|
+
* might be in sub-packages used by the project.
|
|
67
|
+
*
|
|
68
|
+
* For this case, we'll just use the package name from Projen.
|
|
69
|
+
*/
|
|
70
|
+
this._assemblyName = this.project.package.packageName;
|
|
71
|
+
new projen_1.JsonFile(project, ".jsii", {
|
|
72
|
+
obj: () => {
|
|
73
|
+
return {
|
|
74
|
+
name: this._assemblyName,
|
|
75
|
+
types: this._types,
|
|
76
|
+
};
|
|
77
|
+
},
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
addClassType(options) {
|
|
81
|
+
const fqn = [this._assemblyName, options.name].join(".");
|
|
82
|
+
const type = {
|
|
83
|
+
assembly: this._assemblyName,
|
|
84
|
+
base: options.baseFqn ?? ProjenBaseFqn.TYPESCRIPT_PROJECT,
|
|
85
|
+
fqn,
|
|
86
|
+
kind: spec.TypeKind.Class,
|
|
87
|
+
name: options.name,
|
|
88
|
+
initializer: {
|
|
89
|
+
parameters: [
|
|
90
|
+
{
|
|
91
|
+
name: "options",
|
|
92
|
+
type: {
|
|
93
|
+
fqn: options.optionsFqn ?? ProjenBaseFqn.TYPESCRIPT_PROJECT_OPTIONS,
|
|
94
|
+
},
|
|
95
|
+
},
|
|
96
|
+
],
|
|
97
|
+
},
|
|
98
|
+
};
|
|
99
|
+
this._types[fqn] = type;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
exports.JsiiFaker = JsiiFaker;
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoianNpaS1mYWtlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9qc2lpL2pzaWktZmFrZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsaURBQW1DO0FBQ25DLG1DQUE2QztBQUk3Qzs7OztHQUlHO0FBQ0gsTUFBTSxhQUFhLEdBQUc7SUFDcEIsa0JBQWtCLEVBQUUscUNBQXFDO0lBQ3pELDBCQUEwQixFQUFFLDRDQUE0QztDQUNoRSxDQUFDO0FBeUJYLE1BQWEsU0FBVSxTQUFRLGtCQUFTO0lBQ3RDLHlCQUF5QjtJQUNsQixNQUFNLENBQUMsRUFBRSxDQUFDLE9BQTBCO1FBQ3pDLE1BQU0sU0FBUyxHQUFHLENBQUMsQ0FBWSxFQUFrQixFQUFFLENBQUMsQ0FBQyxZQUFZLFNBQVMsQ0FBQztRQUMzRSxPQUFPLE9BQU8sQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFLRCxZQUE0QixPQUEwQjtRQUNwRCxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFEVyxZQUFPLEdBQVAsT0FBTyxDQUFtQjtRQUY5QyxXQUFNLEdBQWtDLEVBQUUsQ0FBQztRQXdCNUMsV0FBTSxHQUFHLEdBQUcsRUFBRTtZQUNuQixPQUFPO2dCQUNMLEtBQUssRUFBRSxJQUFJLENBQUMsTUFBTTthQUNuQixDQUFDO1FBQ0osQ0FBQyxDQUFDO1FBdkJBOzs7Ozs7V0FNRztRQUNILElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDO1FBRXRELElBQUksaUJBQVEsQ0FBQyxPQUFPLEVBQUUsT0FBTyxFQUFFO1lBQzdCLEdBQUcsRUFBRSxHQUFHLEVBQUU7Z0JBQ1IsT0FBTztvQkFDTCxJQUFJLEVBQUUsSUFBSSxDQUFDLGFBQWE7b0JBQ3hCLEtBQUssRUFBRSxJQUFJLENBQUMsTUFBTTtpQkFDbkIsQ0FBQztZQUNKLENBQUM7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0lBUU0sWUFBWSxDQUFDLE9BQXlCO1FBQzNDLE1BQU0sR0FBRyxHQUFHLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3pELE1BQU0sSUFBSSxHQUFtQjtZQUMzQixRQUFRLEVBQUUsSUFBSSxDQUFDLGFBQWE7WUFDNUIsSUFBSSxFQUFFLE9BQU8sQ0FBQyxPQUFPLElBQUksYUFBYSxDQUFDLGtCQUFrQjtZQUN6RCxHQUFHO1lBQ0gsSUFBSSxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSztZQUN6QixJQUFJLEVBQUUsT0FBTyxDQUFDLElBQUk7WUFDbEIsV0FBVyxFQUFFO2dCQUNYLFVBQVUsRUFBRTtvQkFDVjt3QkFDRSxJQUFJLEVBQUUsU0FBUzt3QkFDZixJQUFJLEVBQUU7NEJBQ0osR0FBRyxFQUNELE9BQU8sQ0FBQyxVQUFVLElBQUksYUFBYSxDQUFDLDBCQUEwQjt5QkFDakU7cUJBQ0Y7aUJBQ0Y7YUFDRjtTQUNGLENBQUM7UUFFRixJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQztJQUMxQixDQUFDO0NBQ0Y7QUE3REQsOEJBNkRDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgc3BlYyBmcm9tIFwiQGpzaWkvc3BlY1wiO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBKc29uRmlsZSB9IGZyb20gXCJwcm9qZW5cIjtcbmltcG9ydCB7IFR5cGVTY3JpcHRQcm9qZWN0IH0gZnJvbSBcInByb2plbi9saWIvdHlwZXNjcmlwdFwiO1xuaW1wb3J0IHsgVmFsdWVPZiB9IGZyb20gXCJ0eXBlLWZlc3RcIjtcblxuLyoqXG4gKiBUaGUgRlFOcyBmb3IgdGhlIGJhc2UgY2xhc3NlcyBhbmQgb3B0aW9ucyB1c2VkIGJ5IEpzaWkuXG4gKlxuICogVGhlc2UgYXJlIHRoZSBkZWZhdWx0cyB1c2VkIGJ5IFByb2plbidzIFR5cGVTY3JpcHRQcm9qZWN0LlxuICovXG5jb25zdCBQcm9qZW5CYXNlRnFuID0ge1xuICBUWVBFU0NSSVBUX1BST0pFQ1Q6IFwicHJvamVuLnR5cGVzY3JpcHQuVHlwZVNjcmlwdFByb2plY3RcIixcbiAgVFlQRVNDUklQVF9QUk9KRUNUX09QVElPTlM6IFwicHJvamVuLnR5cGVzY3JpcHQuVHlwZVNjcmlwdFByb2plY3RPcHRpb25zXCIsXG59IGFzIGNvbnN0O1xuXG5leHBvcnQgaW50ZXJmYWNlIENsYXNzVHlwZU9wdGlvbnMge1xuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIGNsYXNzLlxuICAgKlxuICAgKiBAZXhhbXBsZSBcIk15UHJvamVjdFwiXG4gICAqL1xuICBuYW1lOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBGUU4gZm9yIHRoZSBiYXNlIGNsYXNzIHRoaXMgY2xhc3MgaXMgZXh0ZW5kaW5nLlxuICAgKlxuICAgKiBAZGVmYXVsdCBQcm9qZW5CYXNlRnFuLlRZUEVTQ1JJUFRfUFJPSkVDVFxuICAgKi9cbiAgYmFzZUZxbj86IFZhbHVlT2Y8dHlwZW9mIFByb2plbkJhc2VGcW4+IHwgc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgRlFOIGZvciB0aGUgb3B0aW9ucyBmb3IgdGhpcyBjbGFzcy5cbiAgICpcbiAgICogQGRlZmF1bHQgUHJvamVuQmFzZUZxbi5UWVBFU0NSSVBUX1BST0pFQ1RfT1BUSU9OU1xuICAgKi9cbiAgb3B0aW9uc0Zxbj86IFZhbHVlT2Y8dHlwZW9mIFByb2plbkJhc2VGcW4+IHwgc3RyaW5nO1xufVxuXG5leHBvcnQgY2xhc3MgSnNpaUZha2VyIGV4dGVuZHMgQ29tcG9uZW50IHtcbiAgLy8gZmluZCBwcm9qZWN0IHNpbmdsZXRvblxuICBwdWJsaWMgc3RhdGljIG9mKHByb2plY3Q6IFR5cGVTY3JpcHRQcm9qZWN0KTogSnNpaUZha2VyIHwgdW5kZWZpbmVkIHtcbiAgICBjb25zdCBpc0RlZmluZWQgPSAoYzogQ29tcG9uZW50KTogYyBpcyBKc2lpRmFrZXIgPT4gYyBpbnN0YW5jZW9mIEpzaWlGYWtlcjtcbiAgICByZXR1cm4gcHJvamVjdC5jb21wb25lbnRzLmZpbmQoaXNEZWZpbmVkKTtcbiAgfVxuXG4gIHByaXZhdGUgX2Fzc2VtYmx5TmFtZTogc3RyaW5nO1xuICBwcml2YXRlIF90eXBlczogeyBbbmFtZTogc3RyaW5nXTogc3BlYy5UeXBlIH0gPSB7fTtcblxuICBjb25zdHJ1Y3RvcihwdWJsaWMgcmVhZG9ubHkgcHJvamVjdDogVHlwZVNjcmlwdFByb2plY3QpIHtcbiAgICBzdXBlcihwcm9qZWN0KTtcblxuICAgIC8qKlxuICAgICAqIEluIEpTSUksIHRoZSBhc3NlbWJseSBuYW1lIGlzIGVzc2VudGlhbGx5IHRoZSBwYWNrYWdlIG5hbWUuIEl0J3MgdXNlZCBhcyBhXG4gICAgICogc2NvcGUgd2hlbiB0YXJnZXRpbmcgdHlwZXMgYW5kIG1ldGFkYXRhIGluIG90aGVyIFwianNpaSBhc3NlbWJsaWVzXCIgdGhhdFxuICAgICAqIG1pZ2h0IGJlIGluIHN1Yi1wYWNrYWdlcyB1c2VkIGJ5IHRoZSBwcm9qZWN0LlxuICAgICAqXG4gICAgICogRm9yIHRoaXMgY2FzZSwgd2UnbGwganVzdCB1c2UgdGhlIHBhY2thZ2UgbmFtZSBmcm9tIFByb2plbi5cbiAgICAgKi9cbiAgICB0aGlzLl9hc3NlbWJseU5hbWUgPSB0aGlzLnByb2plY3QucGFja2FnZS5wYWNrYWdlTmFtZTtcblxuICAgIG5ldyBKc29uRmlsZShwcm9qZWN0LCBcIi5qc2lpXCIsIHtcbiAgICAgIG9iajogKCkgPT4ge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIG5hbWU6IHRoaXMuX2Fzc2VtYmx5TmFtZSxcbiAgICAgICAgICB0eXBlczogdGhpcy5fdHlwZXMsXG4gICAgICAgIH07XG4gICAgICB9LFxuICAgIH0pO1xuICB9XG5cbiAgcHVibGljIHRvSlNPTiA9ICgpID0+IHtcbiAgICByZXR1cm4ge1xuICAgICAgdHlwZXM6IHRoaXMuX3R5cGVzLFxuICAgIH07XG4gIH07XG5cbiAgcHVibGljIGFkZENsYXNzVHlwZShvcHRpb25zOiBDbGFzc1R5cGVPcHRpb25zKSB7XG4gICAgY29uc3QgZnFuID0gW3RoaXMuX2Fzc2VtYmx5TmFtZSwgb3B0aW9ucy5uYW1lXS5qb2luKFwiLlwiKTtcbiAgICBjb25zdCB0eXBlOiBzcGVjLkNsYXNzVHlwZSA9IHtcbiAgICAgIGFzc2VtYmx5OiB0aGlzLl9hc3NlbWJseU5hbWUsXG4gICAgICBiYXNlOiBvcHRpb25zLmJhc2VGcW4gPz8gUHJvamVuQmFzZUZxbi5UWVBFU0NSSVBUX1BST0pFQ1QsXG4gICAgICBmcW4sXG4gICAgICBraW5kOiBzcGVjLlR5cGVLaW5kLkNsYXNzLFxuICAgICAgbmFtZTogb3B0aW9ucy5uYW1lLFxuICAgICAgaW5pdGlhbGl6ZXI6IHtcbiAgICAgICAgcGFyYW1ldGVyczogW1xuICAgICAgICAgIHtcbiAgICAgICAgICAgIG5hbWU6IFwib3B0aW9uc1wiLFxuICAgICAgICAgICAgdHlwZToge1xuICAgICAgICAgICAgICBmcW46XG4gICAgICAgICAgICAgICAgb3B0aW9ucy5vcHRpb25zRnFuID8/IFByb2plbkJhc2VGcW4uVFlQRVNDUklQVF9QUk9KRUNUX09QVElPTlMsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIH0sXG4gICAgICAgIF0sXG4gICAgICB9LFxuICAgIH07XG5cbiAgICB0aGlzLl90eXBlc1tmcW5dID0gdHlwZTtcbiAgfVxufVxuIl19
|
|
@@ -1,5 +1,244 @@
|
|
|
1
1
|
import { Component, Project } from "projen";
|
|
2
|
+
import { ValueOf } from "type-fest";
|
|
3
|
+
/**
|
|
4
|
+
* Predefined minimum release age values in minutes.
|
|
5
|
+
*/
|
|
6
|
+
export declare const MIMIMUM_RELEASE_AGE: {
|
|
7
|
+
ZERO_DAYS: number;
|
|
8
|
+
ONE_HOUR: number;
|
|
9
|
+
SIX_HOURS: number;
|
|
10
|
+
TWELVE_HOURS: number;
|
|
11
|
+
ONE_DAY: number;
|
|
12
|
+
TWO_DAYS: number;
|
|
13
|
+
THREE_DAYS: number;
|
|
14
|
+
FOUR_DAYS: number;
|
|
15
|
+
FIVE_DAYS: number;
|
|
16
|
+
SIX_DAYS: number;
|
|
17
|
+
ONE_WEEK: number;
|
|
18
|
+
};
|
|
19
|
+
export interface PnpmWorkspaceOptions {
|
|
20
|
+
/**
|
|
21
|
+
* Filename for the pnpm workspace file. This should probably never change.
|
|
22
|
+
*
|
|
23
|
+
* @default "pnpm-workspace.yaml"
|
|
24
|
+
*/
|
|
25
|
+
readonly fileName?: string;
|
|
26
|
+
/**
|
|
27
|
+
* To reduce the risk of installing compromised packages, you can delay the
|
|
28
|
+
* installation of newly published versions. In most cases, malicious releases
|
|
29
|
+
* are discovered and removed from the registry within an hour.
|
|
30
|
+
*
|
|
31
|
+
* minimumReleaseAge defines the minimum number of minutes that must pass
|
|
32
|
+
* after a version is published before pnpm will install it. This applies to
|
|
33
|
+
* all dependencies, including transitive ones.
|
|
34
|
+
*
|
|
35
|
+
* Note: this should match depsUpgradeOptions.cooldown in the project config.
|
|
36
|
+
*
|
|
37
|
+
* See: https://pnpm.io/settings#minimumreleaseage
|
|
38
|
+
*
|
|
39
|
+
* @default MIMIMUM_RELEASE_AGE.ONE_DAY
|
|
40
|
+
*/
|
|
41
|
+
readonly minimumReleaseAge?: ValueOf<typeof MIMIMUM_RELEASE_AGE>;
|
|
42
|
+
/**
|
|
43
|
+
* If you set minimumReleaseAge but need certain dependencies to always
|
|
44
|
+
* install the newest version immediately, you can list them under
|
|
45
|
+
* minimumReleaseAgeExclude. The exclusion works by package name and applies
|
|
46
|
+
* to all versions of that package.
|
|
47
|
+
*
|
|
48
|
+
* @default - no exclusions (empty array)
|
|
49
|
+
*
|
|
50
|
+
* See: https://pnpm.io/settings#minimumreleaseageexclude
|
|
51
|
+
*/
|
|
52
|
+
readonly minimumReleaseAgeExclude?: Array<string>;
|
|
53
|
+
/**
|
|
54
|
+
* A list of package names that are allowed to execute "preinstall",
|
|
55
|
+
* "install", and/or "postinstall" scripts during installation. Only the
|
|
56
|
+
* packages listed in this array will be able to run those lifecycle scripts.
|
|
57
|
+
* If onlyBuiltDependenciesFile and neverBuiltDependencies are omitted, this
|
|
58
|
+
* configuration option will default to blocking all install scripts.
|
|
59
|
+
*
|
|
60
|
+
* You may restrict allowances to specific versions (and lists of versions
|
|
61
|
+
* using a disjunction with ||). When versions are specified, only those
|
|
62
|
+
* versions of the package may run lifecycle scripts:
|
|
63
|
+
*
|
|
64
|
+
* See: https://pnpm.io/settings#onlybuiltdependencies
|
|
65
|
+
*
|
|
66
|
+
* @default none (empty array)
|
|
67
|
+
*/
|
|
68
|
+
readonly onlyBuiltDependencies?: Array<string>;
|
|
69
|
+
/**
|
|
70
|
+
* A list of package names that are NOT allowed to execute "preinstall",
|
|
71
|
+
* "install", and/or "postinstall" scripts during installation and will not
|
|
72
|
+
* warn or ask to be executed.
|
|
73
|
+
*
|
|
74
|
+
* This is useful when you want to hide the warning because you know the
|
|
75
|
+
* lifecycle scripts are not needed.
|
|
76
|
+
*
|
|
77
|
+
* https://pnpm.io/settings#ignoredbuiltdependencies
|
|
78
|
+
*
|
|
79
|
+
* @default none (empty array)
|
|
80
|
+
*/
|
|
81
|
+
readonly ignoredBuiltDependencies?: Array<string>;
|
|
82
|
+
/**
|
|
83
|
+
* Additional subproject paths to include in the workspace packages array.
|
|
84
|
+
* These will be combined with any subprojects discovered via projen's
|
|
85
|
+
* project.subprojects property. Paths should be relative to the project root.
|
|
86
|
+
*
|
|
87
|
+
* @default none (empty array)
|
|
88
|
+
*/
|
|
89
|
+
readonly subprojects?: Array<string>;
|
|
90
|
+
/**
|
|
91
|
+
* Catalog of reusable dependency version ranges.
|
|
92
|
+
*
|
|
93
|
+
* The catalog allows you to define dependency versions as reusable constants
|
|
94
|
+
* that can be referenced in package.json files using the catalog: protocol.
|
|
95
|
+
*
|
|
96
|
+
* Example:
|
|
97
|
+
* ```yaml
|
|
98
|
+
* catalog:
|
|
99
|
+
* react: ^18.0.0
|
|
100
|
+
* typescript: ^5.0.0
|
|
101
|
+
* ```
|
|
102
|
+
*
|
|
103
|
+
* Then in package.json:
|
|
104
|
+
* ```json
|
|
105
|
+
* {
|
|
106
|
+
* "dependencies": {
|
|
107
|
+
* "react": "catalog:react"
|
|
108
|
+
* }
|
|
109
|
+
* }
|
|
110
|
+
* ```
|
|
111
|
+
*
|
|
112
|
+
* @default undefined (not included in output)
|
|
113
|
+
*
|
|
114
|
+
* See: https://pnpm.io/pnpm-workspace_yaml#catalog
|
|
115
|
+
*/
|
|
116
|
+
readonly defaultCatalog?: {
|
|
117
|
+
[key: string]: string;
|
|
118
|
+
};
|
|
119
|
+
/**
|
|
120
|
+
* Named catalogs of reusable dependency version ranges.
|
|
121
|
+
*
|
|
122
|
+
* Multiple named catalogs with arbitrarily chosen names can be configured under the namedCatalogs key.
|
|
123
|
+
*
|
|
124
|
+
* Example:
|
|
125
|
+
* ```yaml
|
|
126
|
+
* namedCatalogs:
|
|
127
|
+
* frontend:
|
|
128
|
+
* react: ^18.0.0
|
|
129
|
+
* typescript: ^5.0.0
|
|
130
|
+
* backend:
|
|
131
|
+
* express: ^4.18.0
|
|
132
|
+
* ```
|
|
133
|
+
*
|
|
134
|
+
* Then in package.json:
|
|
135
|
+
* ```json
|
|
136
|
+
* {
|
|
137
|
+
* "dependencies": {
|
|
138
|
+
* "react": "catalog:frontend/react"
|
|
139
|
+
* }
|
|
140
|
+
* }
|
|
141
|
+
* ```
|
|
142
|
+
*
|
|
143
|
+
* @default undefined (not included in output)
|
|
144
|
+
*
|
|
145
|
+
* See: https://pnpm.io/catalogs
|
|
146
|
+
*/
|
|
147
|
+
readonly namedCatalogs?: {
|
|
148
|
+
[catalogName: string]: {
|
|
149
|
+
[dependencyName: string]: string;
|
|
150
|
+
};
|
|
151
|
+
};
|
|
152
|
+
}
|
|
2
153
|
export declare class PnpmWorkspace extends Component {
|
|
154
|
+
/**
|
|
155
|
+
* Get the pnpm workspace component of a project. If it does not exist,
|
|
156
|
+
* return undefined.
|
|
157
|
+
*
|
|
158
|
+
* @param project
|
|
159
|
+
* @returns
|
|
160
|
+
*/
|
|
3
161
|
static of(project: Project): PnpmWorkspace | undefined;
|
|
4
|
-
|
|
162
|
+
/**
|
|
163
|
+
* Filename for the pnpm workspace file.
|
|
164
|
+
*/
|
|
165
|
+
readonly fileName: string;
|
|
166
|
+
/**
|
|
167
|
+
* To reduce the risk of installing compromised packages, you can delay the
|
|
168
|
+
* installation of newly published versions. In most cases, malicious releases
|
|
169
|
+
* are discovered and removed from the registry within an hour.
|
|
170
|
+
*
|
|
171
|
+
* minimumReleaseAge defines the minimum number of minutes that must pass
|
|
172
|
+
* after a version is published before pnpm will install it. This applies to
|
|
173
|
+
* all dependencies, including transitive ones.
|
|
174
|
+
*
|
|
175
|
+
* Note: this should match depsUpgradeOptions.cooldown in the project config.
|
|
176
|
+
*
|
|
177
|
+
* See: https://pnpm.io/settings#minimumreleaseage
|
|
178
|
+
*/
|
|
179
|
+
minimumReleaseAge: ValueOf<typeof MIMIMUM_RELEASE_AGE>;
|
|
180
|
+
/**
|
|
181
|
+
* If you set minimumReleaseAge but need certain dependencies to always
|
|
182
|
+
* install the newest version immediately, you can list them under
|
|
183
|
+
* minimumReleaseAgeExclude. The exclusion works by package name and applies
|
|
184
|
+
* to all versions of that package.
|
|
185
|
+
*
|
|
186
|
+
* See: https://pnpm.io/settings#minimumreleaseageexclude
|
|
187
|
+
*/
|
|
188
|
+
minimumReleaseAgeExclude: Array<string>;
|
|
189
|
+
/**
|
|
190
|
+
* A list of package names that are allowed to execute "preinstall",
|
|
191
|
+
* "install", and/or "postinstall" scripts during installation. Only the
|
|
192
|
+
* packages listed in this array will be able to run those lifecycle scripts.
|
|
193
|
+
* If onlyBuiltDependenciesFile and neverBuiltDependencies are omitted, this
|
|
194
|
+
* configuration option will default to blocking all install scripts.
|
|
195
|
+
*
|
|
196
|
+
* You may restrict allowances to specific versions (and lists of versions
|
|
197
|
+
* using a disjunction with ||). When versions are specified, only those
|
|
198
|
+
* versions of the package may run lifecycle scripts:
|
|
199
|
+
*
|
|
200
|
+
* See: https://pnpm.io/settings#onlybuiltdependencies
|
|
201
|
+
*/
|
|
202
|
+
onlyBuiltDependencies: Array<string>;
|
|
203
|
+
/**
|
|
204
|
+
* A list of package names that are NOT allowed to execute "preinstall",
|
|
205
|
+
* "install", and/or "postinstall" scripts during installation and will not
|
|
206
|
+
* warn or ask to be executed.
|
|
207
|
+
*
|
|
208
|
+
* This is useful when you want to hide the warning because you know the
|
|
209
|
+
* lifecycle scripts are not needed.
|
|
210
|
+
*
|
|
211
|
+
* https://pnpm.io/settings#ignoredbuiltdependencies
|
|
212
|
+
*/
|
|
213
|
+
ignoredBuiltDependencies: Array<string>;
|
|
214
|
+
/**
|
|
215
|
+
* Additional subproject paths to include in the workspace packages array.
|
|
216
|
+
* These will be combined with any subprojects discovered via projen's
|
|
217
|
+
* project.subprojects property.
|
|
218
|
+
*/
|
|
219
|
+
subprojects: Array<string>;
|
|
220
|
+
/**
|
|
221
|
+
* Default catalog of reusable dependency version ranges.
|
|
222
|
+
*
|
|
223
|
+
* The default catalog is used to define dependency versions as reusable constants
|
|
224
|
+
* that can be referenced in package.json files using the catalog: protocol.
|
|
225
|
+
*
|
|
226
|
+
* See:https://pnpm.io/catalogs
|
|
227
|
+
*/
|
|
228
|
+
defaultCatalog?: {
|
|
229
|
+
[key: string]: string;
|
|
230
|
+
};
|
|
231
|
+
/**
|
|
232
|
+
* Named catalogs of reusable dependency version ranges.
|
|
233
|
+
*
|
|
234
|
+
* Multiple named catalogs with arbitrarily chosen names can be configured under the namedCatalogs key.
|
|
235
|
+
*
|
|
236
|
+
* See: https://pnpm.io/catalogs
|
|
237
|
+
*/
|
|
238
|
+
namedCatalogs?: {
|
|
239
|
+
[catalogName: string]: {
|
|
240
|
+
[dependencyName: string]: string;
|
|
241
|
+
};
|
|
242
|
+
};
|
|
243
|
+
constructor(project: Project, options?: PnpmWorkspaceOptions);
|
|
5
244
|
}
|
|
@@ -1,36 +1,176 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.PnpmWorkspace = void 0;
|
|
3
|
+
exports.PnpmWorkspace = exports.MIMIMUM_RELEASE_AGE = void 0;
|
|
4
4
|
const path_1 = require("path");
|
|
5
5
|
const projen_1 = require("projen");
|
|
6
|
+
/**
|
|
7
|
+
* Predefined minimum release age values in minutes.
|
|
8
|
+
*/
|
|
9
|
+
exports.MIMIMUM_RELEASE_AGE = {
|
|
10
|
+
ZERO_DAYS: 0,
|
|
11
|
+
ONE_HOUR: 60,
|
|
12
|
+
SIX_HOURS: 360,
|
|
13
|
+
TWELVE_HOURS: 720,
|
|
14
|
+
ONE_DAY: 1440,
|
|
15
|
+
TWO_DAYS: 2880,
|
|
16
|
+
THREE_DAYS: 4320,
|
|
17
|
+
FOUR_DAYS: 5760,
|
|
18
|
+
FIVE_DAYS: 7200,
|
|
19
|
+
SIX_DAYS: 8640,
|
|
20
|
+
ONE_WEEK: 10080,
|
|
21
|
+
};
|
|
6
22
|
class PnpmWorkspace extends projen_1.Component {
|
|
23
|
+
/**
|
|
24
|
+
* Get the pnpm workspace component of a project. If it does not exist,
|
|
25
|
+
* return undefined.
|
|
26
|
+
*
|
|
27
|
+
* @param project
|
|
28
|
+
* @returns
|
|
29
|
+
*/
|
|
7
30
|
static of(project) {
|
|
8
31
|
const isDefined = (c) => c instanceof PnpmWorkspace;
|
|
9
32
|
return project.root.components.find(isDefined);
|
|
10
33
|
}
|
|
11
|
-
constructor(project) {
|
|
34
|
+
constructor(project, options = {}) {
|
|
12
35
|
super(project);
|
|
13
|
-
|
|
36
|
+
/***************************************************************************
|
|
37
|
+
*
|
|
38
|
+
* CLEAR package,json
|
|
39
|
+
*
|
|
40
|
+
* It appears that if ANY pnpm settings exist in the package.json file, all
|
|
41
|
+
* of the setting in the pnpm-workspace.yaml file are ignored. so we need to
|
|
42
|
+
* clear out anything that was placed into the package.json file.
|
|
43
|
+
*
|
|
44
|
+
**************************************************************************/
|
|
45
|
+
project.tryFindObjectFile("package.json")?.addDeletionOverride("pnpm");
|
|
46
|
+
/***************************************************************************
|
|
47
|
+
*
|
|
48
|
+
* Setup pnpm-workspace.yaml file.
|
|
49
|
+
*
|
|
50
|
+
* Now that the package.json file is cleared of any pnpm settings, we can
|
|
51
|
+
* safely write settings to the pnpm-workspace.yaml file.
|
|
52
|
+
*
|
|
53
|
+
**************************************************************************
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Set filename to default if not provided.
|
|
57
|
+
*/
|
|
58
|
+
this.fileName = options.fileName ?? "pnpm-workspace.yaml";
|
|
59
|
+
/**
|
|
60
|
+
* Set minimum release age to default if not provided
|
|
61
|
+
*/
|
|
62
|
+
this.minimumReleaseAge = options.minimumReleaseAge
|
|
63
|
+
? options.minimumReleaseAge
|
|
64
|
+
: exports.MIMIMUM_RELEASE_AGE.ONE_DAY;
|
|
65
|
+
/**
|
|
66
|
+
* Set minimum release age exclude to empty array if not provided
|
|
67
|
+
*/
|
|
68
|
+
this.minimumReleaseAgeExclude = options.minimumReleaseAgeExclude
|
|
69
|
+
? ["@codedrifters/*", ...options.minimumReleaseAgeExclude]
|
|
70
|
+
: ["@codedrifters/*"];
|
|
71
|
+
/**
|
|
72
|
+
* Set only built dependencies to empty array if not provided
|
|
73
|
+
*/
|
|
74
|
+
this.onlyBuiltDependencies = options.onlyBuiltDependencies
|
|
75
|
+
? options.onlyBuiltDependencies
|
|
76
|
+
: [];
|
|
77
|
+
/**
|
|
78
|
+
* Set ignored built dependencies to empty array if not provided
|
|
79
|
+
*/
|
|
80
|
+
this.ignoredBuiltDependencies = options.ignoredBuiltDependencies
|
|
81
|
+
? options.ignoredBuiltDependencies
|
|
82
|
+
: [];
|
|
83
|
+
/**
|
|
84
|
+
* Store additional subproject paths if provided
|
|
85
|
+
*/
|
|
86
|
+
this.subprojects = options.subprojects ?? [];
|
|
87
|
+
/**
|
|
88
|
+
* Store catalog if provided
|
|
89
|
+
*/
|
|
90
|
+
this.defaultCatalog = options.defaultCatalog;
|
|
91
|
+
/**
|
|
92
|
+
* Store named catalogs if provided
|
|
93
|
+
*/
|
|
94
|
+
this.namedCatalogs = options.namedCatalogs;
|
|
14
95
|
/**
|
|
15
96
|
* In case that this file is in a package, don't package it.
|
|
16
97
|
*/
|
|
17
|
-
project.addPackageIgnore(fileName);
|
|
98
|
+
project.addPackageIgnore(this.fileName);
|
|
18
99
|
/**
|
|
19
100
|
* Write pnpm workspace file
|
|
20
101
|
*/
|
|
21
|
-
new projen_1.YamlFile(this.project, fileName, {
|
|
22
|
-
obj: {
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
102
|
+
new projen_1.YamlFile(this.project, this.fileName, {
|
|
103
|
+
obj: () => {
|
|
104
|
+
const pnpmConfig = {};
|
|
105
|
+
const packages = new Array();
|
|
106
|
+
/**
|
|
107
|
+
* Add projen subprojects to the packages array.
|
|
108
|
+
*/
|
|
109
|
+
for (const subproject of project.subprojects) {
|
|
110
|
+
// grab the relative out directory
|
|
111
|
+
packages.push((0, path_1.relative)(this.project.outdir, subproject.outdir));
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Add additional subproject paths provided via options.
|
|
115
|
+
* Use a Set to deduplicate paths to avoid including the same
|
|
116
|
+
* subproject multiple times.
|
|
117
|
+
*/
|
|
118
|
+
const packageSet = new Set(packages);
|
|
119
|
+
for (const subprojectPath of this.subprojects) {
|
|
120
|
+
packageSet.add(subprojectPath);
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Convert back to array if we added any additional paths
|
|
124
|
+
*/
|
|
125
|
+
if (this.subprojects.length > 0) {
|
|
126
|
+
packages.length = 0;
|
|
127
|
+
packages.push(...packageSet);
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Set minimum release age.
|
|
131
|
+
*/
|
|
132
|
+
pnpmConfig.minimumReleaseAge = this.minimumReleaseAge;
|
|
133
|
+
/**
|
|
134
|
+
* Set minimum release age exclude if any are provided.
|
|
135
|
+
*/
|
|
136
|
+
if (this.minimumReleaseAgeExclude.length > 0) {
|
|
137
|
+
pnpmConfig.minimumReleaseAgeExclude = this.minimumReleaseAgeExclude;
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Set only built dependencies if any are provided.
|
|
141
|
+
*/
|
|
142
|
+
if (this.onlyBuiltDependencies.length > 0) {
|
|
143
|
+
pnpmConfig.onlyBuiltDependencies = this.onlyBuiltDependencies;
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Set ignored built dependencies if any are provided.
|
|
147
|
+
*/
|
|
148
|
+
if (this.ignoredBuiltDependencies.length > 0) {
|
|
149
|
+
pnpmConfig.ignoreBuiltDependencies = this.ignoredBuiltDependencies;
|
|
150
|
+
}
|
|
151
|
+
/**
|
|
152
|
+
* Set default catalog if provided.
|
|
153
|
+
*/
|
|
154
|
+
if (this.defaultCatalog &&
|
|
155
|
+
Object.keys(this.defaultCatalog).length > 0) {
|
|
156
|
+
pnpmConfig.catalog = this.defaultCatalog;
|
|
157
|
+
}
|
|
158
|
+
/**
|
|
159
|
+
* Set named catalogs if provided.
|
|
160
|
+
*/
|
|
161
|
+
if (this.namedCatalogs && Object.keys(this.namedCatalogs).length > 0) {
|
|
162
|
+
pnpmConfig.namedCatalogs = this.namedCatalogs;
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* Return the final pnpm config object.
|
|
166
|
+
*/
|
|
167
|
+
return {
|
|
168
|
+
...(packages.length > 0 ? { packages } : {}),
|
|
169
|
+
...(pnpmConfig ? { ...pnpmConfig } : {}),
|
|
170
|
+
};
|
|
31
171
|
},
|
|
32
172
|
});
|
|
33
173
|
}
|
|
34
174
|
}
|
|
35
175
|
exports.PnpmWorkspace = PnpmWorkspace;
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG5wbS13b3Jrc3BhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcG5wbS9wbnBtLXdvcmtzcGFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwrQkFBZ0M7QUFDaEMsbUNBQXNEO0FBRXRELE1BQWEsYUFBYyxTQUFRLGtCQUFTO0lBQ25DLE1BQU0sQ0FBQyxFQUFFLENBQUMsT0FBZ0I7UUFDL0IsTUFBTSxTQUFTLEdBQUcsQ0FBQyxDQUFZLEVBQXNCLEVBQUUsQ0FDckQsQ0FBQyxZQUFZLGFBQWEsQ0FBQztRQUM3QixPQUFPLE9BQU8sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNqRCxDQUFDO0lBRUQsWUFBWSxPQUFnQjtRQUMxQixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFZixNQUFNLFFBQVEsR0FBVyxxQkFBcUIsQ0FBQztRQUUvQzs7V0FFRztRQUNILE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUVuQzs7V0FFRztRQUNILElBQUksaUJBQVEsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLFFBQVEsRUFBRTtZQUNuQyxHQUFHLEVBQUU7Z0JBQ0gsUUFBUSxFQUFFLEdBQUcsRUFBRTtvQkFDYixNQUFNLFFBQVEsR0FBRyxJQUFJLEtBQUssRUFBVSxDQUFDO29CQUNyQyxLQUFLLE1BQU0sVUFBVSxJQUFJLE9BQU8sQ0FBQyxXQUFXLEVBQUUsQ0FBQzt3QkFDN0Msa0NBQWtDO3dCQUNsQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUEsZUFBUSxFQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFLFVBQVUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO29CQUNsRSxDQUFDO29CQUNELE9BQU8sUUFBUSxDQUFDO2dCQUNsQixDQUFDO2FBQ0Y7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUFqQ0Qsc0NBaUNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcmVsYXRpdmUgfSBmcm9tIFwicGF0aFwiO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBQcm9qZWN0LCBZYW1sRmlsZSB9IGZyb20gXCJwcm9qZW5cIjtcblxuZXhwb3J0IGNsYXNzIFBucG1Xb3Jrc3BhY2UgZXh0ZW5kcyBDb21wb25lbnQge1xuICBwdWJsaWMgc3RhdGljIG9mKHByb2plY3Q6IFByb2plY3QpOiBQbnBtV29ya3NwYWNlIHwgdW5kZWZpbmVkIHtcbiAgICBjb25zdCBpc0RlZmluZWQgPSAoYzogQ29tcG9uZW50KTogYyBpcyBQbnBtV29ya3NwYWNlID0+XG4gICAgICBjIGluc3RhbmNlb2YgUG5wbVdvcmtzcGFjZTtcbiAgICByZXR1cm4gcHJvamVjdC5yb290LmNvbXBvbmVudHMuZmluZChpc0RlZmluZWQpO1xuICB9XG5cbiAgY29uc3RydWN0b3IocHJvamVjdDogUHJvamVjdCkge1xuICAgIHN1cGVyKHByb2plY3QpO1xuXG4gICAgY29uc3QgZmlsZU5hbWU6IHN0cmluZyA9IFwicG5wbS13b3Jrc3BhY2UueWFtbFwiO1xuXG4gICAgLyoqXG4gICAgICogSW4gY2FzZSB0aGF0IHRoaXMgZmlsZSBpcyBpbiBhIHBhY2thZ2UsIGRvbid0IHBhY2thZ2UgaXQuXG4gICAgICovXG4gICAgcHJvamVjdC5hZGRQYWNrYWdlSWdub3JlKGZpbGVOYW1lKTtcblxuICAgIC8qKlxuICAgICAqIFdyaXRlIHBucG0gd29ya3NwYWNlIGZpbGVcbiAgICAgKi9cbiAgICBuZXcgWWFtbEZpbGUodGhpcy5wcm9qZWN0LCBmaWxlTmFtZSwge1xuICAgICAgb2JqOiB7XG4gICAgICAgIHBhY2thZ2VzOiAoKSA9PiB7XG4gICAgICAgICAgY29uc3QgcGFja2FnZXMgPSBuZXcgQXJyYXk8c3RyaW5nPigpO1xuICAgICAgICAgIGZvciAoY29uc3Qgc3VicHJvamVjdCBvZiBwcm9qZWN0LnN1YnByb2plY3RzKSB7XG4gICAgICAgICAgICAvLyBncmFiIHRoZSByZWxhdGl2ZSBvdXQgZGlyZWN0b3J5XG4gICAgICAgICAgICBwYWNrYWdlcy5wdXNoKHJlbGF0aXZlKHRoaXMucHJvamVjdC5vdXRkaXIsIHN1YnByb2plY3Qub3V0ZGlyKSk7XG4gICAgICAgICAgfVxuICAgICAgICAgIHJldHVybiBwYWNrYWdlcztcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
|
|
176
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pnpm-workspace.js","sourceRoot":"","sources":["../../src/pnpm/pnpm-workspace.ts"],"names":[],"mappings":"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","sourcesContent":["import { relative } from \"path\";\nimport { Component, Project, YamlFile } from \"projen\";\nimport { ValueOf } from \"type-fest\";\n\n/**\n * Predefined minimum release age values in minutes.\n */\nexport const MIMIMUM_RELEASE_AGE = {\n  ZERO_DAYS: 0,\n  ONE_HOUR: 60,\n  SIX_HOURS: 360,\n  TWELVE_HOURS: 720,\n  ONE_DAY: 1440,\n  TWO_DAYS: 2880,\n  THREE_DAYS: 4320,\n  FOUR_DAYS: 5760,\n  FIVE_DAYS: 7200,\n  SIX_DAYS: 8640,\n  ONE_WEEK: 10080,\n};\n\nexport interface PnpmWorkspaceOptions {\n  /**\n   * Filename for the pnpm workspace file. This should probably never change.\n   *\n   * @default \"pnpm-workspace.yaml\"\n   */\n  readonly fileName?: string;\n\n  /**\n   * To reduce the risk of installing compromised packages, you can delay the\n   * installation of newly published versions. In most cases, malicious releases\n   * are discovered and removed from the registry within an hour.\n   *\n   * minimumReleaseAge defines the minimum number of minutes that must pass\n   * after a version is published before pnpm will install it. This applies to\n   * all dependencies, including transitive ones.\n   *\n   * Note: this should match depsUpgradeOptions.cooldown in the project config.\n   *\n   * See: https://pnpm.io/settings#minimumreleaseage\n   *\n   * @default MIMIMUM_RELEASE_AGE.ONE_DAY\n   */\n  readonly minimumReleaseAge?: ValueOf<typeof MIMIMUM_RELEASE_AGE>;\n\n  /**\n   * If you set minimumReleaseAge but need certain dependencies to always\n   * install the newest version immediately, you can list them under\n   * minimumReleaseAgeExclude. The exclusion works by package name and applies\n   * to all versions of that package.\n   *\n   * @default - no exclusions (empty array)\n   *\n   * See: https://pnpm.io/settings#minimumreleaseageexclude\n   */\n  readonly minimumReleaseAgeExclude?: Array<string>;\n\n  /**\n   * A list of package names that are allowed to execute \"preinstall\",\n   * \"install\", and/or \"postinstall\" scripts during installation. Only the\n   * packages listed in this array will be able to run those lifecycle scripts.\n   * If onlyBuiltDependenciesFile and neverBuiltDependencies are omitted, this\n   * configuration option will default to blocking all install scripts.\n   *\n   * You may restrict allowances to specific versions (and lists of versions\n   * using a disjunction with ||). When versions are specified, only those\n   * versions of the package may run lifecycle scripts:\n   *\n   * See: https://pnpm.io/settings#onlybuiltdependencies\n   *\n   * @default none (empty array)\n   */\n  readonly onlyBuiltDependencies?: Array<string>;\n\n  /**\n   * A list of package names that are NOT allowed to execute \"preinstall\",\n   * \"install\", and/or \"postinstall\" scripts during installation and will not\n   * warn or ask to be executed.\n   *\n   * This is useful when you want to hide the warning because you know the\n   * lifecycle scripts are not needed.\n   *\n   * https://pnpm.io/settings#ignoredbuiltdependencies\n   *\n   * @default none (empty array)\n   */\n  readonly ignoredBuiltDependencies?: Array<string>;\n\n  /**\n   * Additional subproject paths to include in the workspace packages array.\n   * These will be combined with any subprojects discovered via projen's\n   * project.subprojects property. Paths should be relative to the project root.\n   *\n   * @default none (empty array)\n   */\n  readonly subprojects?: Array<string>;\n\n  /**\n   * Catalog of reusable dependency version ranges.\n   *\n   * The catalog allows you to define dependency versions as reusable constants\n   * that can be referenced in package.json files using the catalog: protocol.\n   *\n   * Example:\n   * ```yaml\n   * catalog:\n   *   react: ^18.0.0\n   *   typescript: ^5.0.0\n   * ```\n   *\n   * Then in package.json:\n   * ```json\n   * {\n   *   \"dependencies\": {\n   *     \"react\": \"catalog:react\"\n   *   }\n   * }\n   * ```\n   *\n   * @default undefined (not included in output)\n   *\n   * See: https://pnpm.io/pnpm-workspace_yaml#catalog\n   */\n  readonly defaultCatalog?: { [key: string]: string };\n\n  /**\n   * Named catalogs of reusable dependency version ranges.\n   *\n   * Multiple named catalogs with arbitrarily chosen names can be configured under the namedCatalogs key.\n   *\n   * Example:\n   * ```yaml\n   * namedCatalogs:\n   *   frontend:\n   *     react: ^18.0.0\n   *     typescript: ^5.0.0\n   *   backend:\n   *     express: ^4.18.0\n   * ```\n   *\n   * Then in package.json:\n   * ```json\n   * {\n   *   \"dependencies\": {\n   *     \"react\": \"catalog:frontend/react\"\n   *   }\n   * }\n   * ```\n   *\n   * @default undefined (not included in output)\n   *\n   * See: https://pnpm.io/catalogs\n   */\n  readonly namedCatalogs?: {\n    [catalogName: string]: { [dependencyName: string]: string };\n  };\n}\n\nexport class PnpmWorkspace extends Component {\n  /**\n   * Get the pnpm workspace component of a project. If it does not exist,\n   * return undefined.\n   *\n   * @param project\n   * @returns\n   */\n  public static of(project: Project): PnpmWorkspace | undefined {\n    const isDefined = (c: Component): c is PnpmWorkspace =>\n      c instanceof PnpmWorkspace;\n    return project.root.components.find(isDefined);\n  }\n\n  /**\n   * Filename for the pnpm workspace file.\n   */\n  public readonly fileName: string;\n\n  /**\n   * To reduce the risk of installing compromised packages, you can delay the\n   * installation of newly published versions. In most cases, malicious releases\n   * are discovered and removed from the registry within an hour.\n   *\n   * minimumReleaseAge defines the minimum number of minutes that must pass\n   * after a version is published before pnpm will install it. This applies to\n   * all dependencies, including transitive ones.\n   *\n   * Note: this should match depsUpgradeOptions.cooldown in the project config.\n   *\n   * See: https://pnpm.io/settings#minimumreleaseage\n   */\n  public minimumReleaseAge: ValueOf<typeof MIMIMUM_RELEASE_AGE>;\n\n  /**\n   * If you set minimumReleaseAge but need certain dependencies to always\n   * install the newest version immediately, you can list them under\n   * minimumReleaseAgeExclude. The exclusion works by package name and applies\n   * to all versions of that package.\n   *\n   * See: https://pnpm.io/settings#minimumreleaseageexclude\n   */\n  public minimumReleaseAgeExclude: Array<string>;\n\n  /**\n   * A list of package names that are allowed to execute \"preinstall\",\n   * \"install\", and/or \"postinstall\" scripts during installation. Only the\n   * packages listed in this array will be able to run those lifecycle scripts.\n   * If onlyBuiltDependenciesFile and neverBuiltDependencies are omitted, this\n   * configuration option will default to blocking all install scripts.\n   *\n   * You may restrict allowances to specific versions (and lists of versions\n   * using a disjunction with ||). When versions are specified, only those\n   * versions of the package may run lifecycle scripts:\n   *\n   * See: https://pnpm.io/settings#onlybuiltdependencies\n   */\n  public onlyBuiltDependencies: Array<string>;\n\n  /**\n   * A list of package names that are NOT allowed to execute \"preinstall\",\n   * \"install\", and/or \"postinstall\" scripts during installation and will not\n   * warn or ask to be executed.\n   *\n   * This is useful when you want to hide the warning because you know the\n   * lifecycle scripts are not needed.\n   *\n   * https://pnpm.io/settings#ignoredbuiltdependencies\n   */\n  public ignoredBuiltDependencies: Array<string>;\n\n  /**\n   * Additional subproject paths to include in the workspace packages array.\n   * These will be combined with any subprojects discovered via projen's\n   * project.subprojects property.\n   */\n  public subprojects: Array<string>;\n\n  /**\n   * Default catalog of reusable dependency version ranges.\n   *\n   * The default catalog is used to define dependency versions as reusable constants\n   * that can be referenced in package.json files using the catalog: protocol.\n   *\n   * See:https://pnpm.io/catalogs\n   */\n  public defaultCatalog?: { [key: string]: string };\n\n  /**\n   * Named catalogs of reusable dependency version ranges.\n   *\n   * Multiple named catalogs with arbitrarily chosen names can be configured under the namedCatalogs key.\n   *\n   * See: https://pnpm.io/catalogs\n   */\n  public namedCatalogs?: {\n    [catalogName: string]: { [dependencyName: string]: string };\n  };\n\n  constructor(project: Project, options: PnpmWorkspaceOptions = {}) {\n    super(project);\n\n    /***************************************************************************\n     *\n     * CLEAR package,json\n     *\n     * It appears that if ANY pnpm settings exist in the package.json file, all\n     * of the setting in the pnpm-workspace.yaml file are ignored. so we need to\n     * clear out anything that was placed into the package.json file.\n     *\n     **************************************************************************/\n\n    project.tryFindObjectFile(\"package.json\")?.addDeletionOverride(\"pnpm\");\n\n    /***************************************************************************\n     * \n     * Setup pnpm-workspace.yaml file.\n     * \n     * Now that the package.json file is cleared of any pnpm settings, we can\n     * safely write settings to the pnpm-workspace.yaml file.\n     * \n     **************************************************************************\n\n    /**\n     * Set filename to default if not provided.\n     */\n    this.fileName = options.fileName ?? \"pnpm-workspace.yaml\";\n\n    /**\n     * Set minimum release age to default if not provided\n     */\n    this.minimumReleaseAge = options.minimumReleaseAge\n      ? options.minimumReleaseAge\n      : MIMIMUM_RELEASE_AGE.ONE_DAY;\n\n    /**\n     * Set minimum release age exclude to empty array if not provided\n     */\n    this.minimumReleaseAgeExclude = options.minimumReleaseAgeExclude\n      ? [\"@codedrifters/*\", ...options.minimumReleaseAgeExclude]\n      : [\"@codedrifters/*\"];\n\n    /**\n     * Set only built dependencies to empty array if not provided\n     */\n    this.onlyBuiltDependencies = options.onlyBuiltDependencies\n      ? options.onlyBuiltDependencies\n      : [];\n\n    /**\n     * Set ignored built dependencies to empty array if not provided\n     */\n    this.ignoredBuiltDependencies = options.ignoredBuiltDependencies\n      ? options.ignoredBuiltDependencies\n      : [];\n\n    /**\n     * Store additional subproject paths if provided\n     */\n    this.subprojects = options.subprojects ?? [];\n\n    /**\n     * Store catalog if provided\n     */\n    this.defaultCatalog = options.defaultCatalog;\n\n    /**\n     * Store named catalogs if provided\n     */\n    this.namedCatalogs = options.namedCatalogs;\n\n    /**\n     * In case that this file is in a package, don't package it.\n     */\n    project.addPackageIgnore(this.fileName);\n\n    /**\n     * Write pnpm workspace file\n     */\n    new YamlFile(this.project, this.fileName, {\n      obj: () => {\n        const pnpmConfig: any = {};\n        const packages = new Array<string>();\n\n        /**\n         * Add projen subprojects to the packages array.\n         */\n        for (const subproject of project.subprojects) {\n          // grab the relative out directory\n          packages.push(relative(this.project.outdir, subproject.outdir));\n        }\n\n        /**\n         * Add additional subproject paths provided via options.\n         * Use a Set to deduplicate paths to avoid including the same\n         * subproject multiple times.\n         */\n        const packageSet = new Set(packages);\n        for (const subprojectPath of this.subprojects) {\n          packageSet.add(subprojectPath);\n        }\n\n        /**\n         * Convert back to array if we added any additional paths\n         */\n        if (this.subprojects.length > 0) {\n          packages.length = 0;\n          packages.push(...packageSet);\n        }\n\n        /**\n         * Set minimum release age.\n         */\n        pnpmConfig.minimumReleaseAge = this.minimumReleaseAge;\n\n        /**\n         * Set minimum release age exclude if any are provided.\n         */\n        if (this.minimumReleaseAgeExclude.length > 0) {\n          pnpmConfig.minimumReleaseAgeExclude = this.minimumReleaseAgeExclude;\n        }\n\n        /**\n         * Set only built dependencies if any are provided.\n         */\n        if (this.onlyBuiltDependencies.length > 0) {\n          pnpmConfig.onlyBuiltDependencies = this.onlyBuiltDependencies;\n        }\n\n        /**\n         * Set ignored built dependencies if any are provided.\n         */\n        if (this.ignoredBuiltDependencies.length > 0) {\n          pnpmConfig.ignoreBuiltDependencies = this.ignoredBuiltDependencies;\n        }\n\n        /**\n         * Set default catalog if provided.\n         */\n        if (\n          this.defaultCatalog &&\n          Object.keys(this.defaultCatalog).length > 0\n        ) {\n          pnpmConfig.catalog = this.defaultCatalog;\n        }\n\n        /**\n         * Set named catalogs if provided.\n         */\n        if (this.namedCatalogs && Object.keys(this.namedCatalogs).length > 0) {\n          pnpmConfig.namedCatalogs = this.namedCatalogs;\n        }\n\n        /**\n         * Return the final pnpm config object.\n         */\n        return {\n          ...(packages.length > 0 ? { packages } : {}),\n          ...(pnpmConfig ? { ...pnpmConfig } : {}),\n        };\n      },\n    });\n  }\n}\n"]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./monorepo-project"), exports);
|
|
18
|
+
__exportStar(require("./typescript-project"), exports);
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcHJvamVjdHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHFEQUFtQztBQUNuQyx1REFBcUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9tb25vcmVwby1wcm9qZWN0XCI7XG5leHBvcnQgKiBmcm9tIFwiLi90eXBlc2NyaXB0LXByb2plY3RcIjtcbiJdfQ==
|