@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.
Files changed (38) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +761 -1
  3. package/lib/aws/aws-deployment-config.d.ts +45 -108
  4. package/lib/aws/aws-deployment-config.js +69 -100
  5. package/lib/aws/aws-deployment-target.d.ts +210 -0
  6. package/lib/aws/aws-deployment-target.js +202 -0
  7. package/lib/aws/index.d.ts +1 -1
  8. package/lib/aws/index.js +2 -2
  9. package/lib/index.d.ts +9 -0
  10. package/lib/index.js +26 -0
  11. package/lib/jsii/index.d.ts +1 -0
  12. package/lib/jsii/index.js +18 -0
  13. package/lib/jsii/jsii-faker.d.ts +47 -0
  14. package/lib/jsii/jsii-faker.js +103 -0
  15. package/lib/pnpm/pnpm-workspace.d.ts +240 -1
  16. package/lib/pnpm/pnpm-workspace.js +155 -15
  17. package/lib/projects/index.d.ts +2 -0
  18. package/lib/projects/index.js +19 -0
  19. package/lib/projects/monorepo-project.d.ts +50 -0
  20. package/lib/projects/monorepo-project.js +203 -0
  21. package/lib/projects/typescript-project.d.ts +4 -0
  22. package/lib/projects/typescript-project.js +150 -0
  23. package/lib/turbo/turbo-repo.d.ts +116 -9
  24. package/lib/turbo/turbo-repo.js +107 -20
  25. package/lib/versions.d.ts +19 -7
  26. package/lib/versions.js +20 -8
  27. package/lib/vscode/vscode.js +2 -1
  28. package/lib/workflows/aws-deploy-workflow.d.ts +84 -0
  29. package/lib/workflows/aws-deploy-workflow.js +312 -0
  30. package/lib/workflows/index.d.ts +1 -2
  31. package/lib/workflows/index.js +2 -3
  32. package/package.json +21 -20
  33. package/lib/workflows/build-workflow.d.ts +0 -13
  34. package/lib/workflows/build-workflow.js +0 -64
  35. package/lib/workflows/deploy-workflow.d.ts +0 -17
  36. package/lib/workflows/deploy-workflow.js +0 -113
  37. package/lib/workflows/steps/deploy.d.ts +0 -4
  38. 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
- constructor(project: Project);
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
- const fileName = "pnpm-workspace.yaml";
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
- packages: () => {
24
- const packages = new Array();
25
- for (const subproject of project.subprojects) {
26
- // grab the relative out directory
27
- packages.push((0, path_1.relative)(this.project.outdir, subproject.outdir));
28
- }
29
- return packages;
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,2 @@
1
+ export * from "./monorepo-project";
2
+ export * from "./typescript-project";
@@ -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==