@codedrifters/configulator 0.0.64 → 0.0.65
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/lib/pnpm/pnpm-workspace.d.ts +141 -1
- package/lib/pnpm/pnpm-workspace.js +113 -11
- package/package.json +1 -1
|
@@ -1,5 +1,145 @@
|
|
|
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
|
+
}
|
|
2
83
|
export declare class PnpmWorkspace extends Component {
|
|
84
|
+
/**
|
|
85
|
+
* Get the pnpm workspace component of a project. If it does not exist,
|
|
86
|
+
* return undefined.
|
|
87
|
+
*
|
|
88
|
+
* @param project
|
|
89
|
+
* @returns
|
|
90
|
+
*/
|
|
3
91
|
static of(project: Project): PnpmWorkspace | undefined;
|
|
4
|
-
|
|
92
|
+
/**
|
|
93
|
+
* Filename for the pnpm workspace file.
|
|
94
|
+
*/
|
|
95
|
+
readonly fileName: string;
|
|
96
|
+
/**
|
|
97
|
+
* To reduce the risk of installing compromised packages, you can delay the
|
|
98
|
+
* installation of newly published versions. In most cases, malicious releases
|
|
99
|
+
* are discovered and removed from the registry within an hour.
|
|
100
|
+
*
|
|
101
|
+
* minimumReleaseAge defines the minimum number of minutes that must pass
|
|
102
|
+
* after a version is published before pnpm will install it. This applies to
|
|
103
|
+
* all dependencies, including transitive ones.
|
|
104
|
+
*
|
|
105
|
+
* Note: this should match depsUpgradeOptions.cooldown in the project config.
|
|
106
|
+
*
|
|
107
|
+
* See: https://pnpm.io/settings#minimumreleaseage
|
|
108
|
+
*/
|
|
109
|
+
minimumReleaseAge: ValueOf<typeof MIMIMUM_RELEASE_AGE>;
|
|
110
|
+
/**
|
|
111
|
+
* If you set minimumReleaseAge but need certain dependencies to always
|
|
112
|
+
* install the newest version immediately, you can list them under
|
|
113
|
+
* minimumReleaseAgeExclude. The exclusion works by package name and applies
|
|
114
|
+
* to all versions of that package.
|
|
115
|
+
*
|
|
116
|
+
* See: https://pnpm.io/settings#minimumreleaseageexclude
|
|
117
|
+
*/
|
|
118
|
+
minimumReleaseAgeExclude: Array<string>;
|
|
119
|
+
/**
|
|
120
|
+
* A list of package names that are allowed to execute "preinstall",
|
|
121
|
+
* "install", and/or "postinstall" scripts during installation. Only the
|
|
122
|
+
* packages listed in this array will be able to run those lifecycle scripts.
|
|
123
|
+
* If onlyBuiltDependenciesFile and neverBuiltDependencies are omitted, this
|
|
124
|
+
* configuration option will default to blocking all install scripts.
|
|
125
|
+
*
|
|
126
|
+
* You may restrict allowances to specific versions (and lists of versions
|
|
127
|
+
* using a disjunction with ||). When versions are specified, only those
|
|
128
|
+
* versions of the package may run lifecycle scripts:
|
|
129
|
+
*
|
|
130
|
+
* See: https://pnpm.io/settings#onlybuiltdependencies
|
|
131
|
+
*/
|
|
132
|
+
onlyBuiltDependencies: Array<string>;
|
|
133
|
+
/**
|
|
134
|
+
* A list of package names that are NOT allowed to execute "preinstall",
|
|
135
|
+
* "install", and/or "postinstall" scripts during installation and will not
|
|
136
|
+
* warn or ask to be executed.
|
|
137
|
+
*
|
|
138
|
+
* This is useful when you want to hide the warning because you know the
|
|
139
|
+
* lifecycle scripts are not needed.
|
|
140
|
+
*
|
|
141
|
+
* https://pnpm.io/settings#ignoredbuiltdependencies
|
|
142
|
+
*/
|
|
143
|
+
ignoredBuiltDependencies: Array<string>;
|
|
144
|
+
constructor(project: Project, options?: PnpmWorkspaceOptions);
|
|
5
145
|
}
|
|
@@ -1,36 +1,138 @@
|
|
|
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
|
+
: [];
|
|
14
83
|
/**
|
|
15
84
|
* In case that this file is in a package, don't package it.
|
|
16
85
|
*/
|
|
17
|
-
project.addPackageIgnore(fileName);
|
|
86
|
+
project.addPackageIgnore(this.fileName);
|
|
18
87
|
/**
|
|
19
88
|
* Write pnpm workspace file
|
|
20
89
|
*/
|
|
21
|
-
new projen_1.YamlFile(this.project, fileName, {
|
|
22
|
-
obj: {
|
|
23
|
-
|
|
24
|
-
|
|
90
|
+
new projen_1.YamlFile(this.project, this.fileName, {
|
|
91
|
+
obj: () => {
|
|
92
|
+
const pnpmConfig = {};
|
|
93
|
+
const packages = new Array();
|
|
94
|
+
/**
|
|
95
|
+
* If any subprojects exist, output all subprojects in the workspace as
|
|
96
|
+
* packages.
|
|
97
|
+
*/
|
|
98
|
+
if (this.project.subprojects.length > 0) {
|
|
25
99
|
for (const subproject of project.subprojects) {
|
|
26
100
|
// grab the relative out directory
|
|
27
101
|
packages.push((0, path_1.relative)(this.project.outdir, subproject.outdir));
|
|
28
102
|
}
|
|
29
|
-
|
|
30
|
-
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Set minimum release age.
|
|
106
|
+
*/
|
|
107
|
+
pnpmConfig.minimumReleaseAge = this.minimumReleaseAge;
|
|
108
|
+
/**
|
|
109
|
+
* Set minimum release age exclude if any are provided.
|
|
110
|
+
*/
|
|
111
|
+
if (this.minimumReleaseAgeExclude.length > 0) {
|
|
112
|
+
pnpmConfig.minimumReleaseAgeExclude = this.minimumReleaseAgeExclude;
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Set only built dependencies if any are provided.
|
|
116
|
+
*/
|
|
117
|
+
if (this.onlyBuiltDependencies.length > 0) {
|
|
118
|
+
pnpmConfig.onlyBuiltDependencies = this.onlyBuiltDependencies;
|
|
119
|
+
}
|
|
120
|
+
/**
|
|
121
|
+
* Set ignored built dependencies if any are provided.
|
|
122
|
+
*/
|
|
123
|
+
if (this.ignoredBuiltDependencies.length > 0) {
|
|
124
|
+
pnpmConfig.ignoreBuiltDependencies = this.ignoredBuiltDependencies;
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Return the final pnpm config object.
|
|
128
|
+
*/
|
|
129
|
+
return {
|
|
130
|
+
...(packages.length > 0 ? { packages } : {}),
|
|
131
|
+
...(pnpmConfig ? { ...pnpmConfig } : {}),
|
|
132
|
+
};
|
|
31
133
|
},
|
|
32
134
|
});
|
|
33
135
|
}
|
|
34
136
|
}
|
|
35
137
|
exports.PnpmWorkspace = PnpmWorkspace;
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG5wbS13b3Jrc3BhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcG5wbS9wbnBtLXdvcmtzcGFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwrQkFBZ0M7QUFDaEMsbUNBQXNEO0FBRXRELE1BQWEsYUFBYyxTQUFRLGtCQUFTO0lBQ25DLE1BQU0sQ0FBQyxFQUFFLENBQUMsT0FBZ0I7UUFDL0IsTUFBTSxTQUFTLEdBQUcsQ0FBQyxDQUFZLEVBQXNCLEVBQUUsQ0FDckQsQ0FBQyxZQUFZLGFBQWEsQ0FBQztRQUM3QixPQUFPLE9BQU8sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNqRCxDQUFDO0lBRUQsWUFBWSxPQUFnQjtRQUMxQixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFZixNQUFNLFFBQVEsR0FBVyxxQkFBcUIsQ0FBQztRQUUvQzs7V0FFRztRQUNILE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUVuQzs7V0FFRztRQUNILElBQUksaUJBQVEsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLFFBQVEsRUFBRTtZQUNuQyxHQUFHLEVBQUU7Z0JBQ0gsUUFBUSxFQUFFLEdBQUcsRUFBRTtvQkFDYixNQUFNLFFBQVEsR0FBRyxJQUFJLEtBQUssRUFBVSxDQUFDO29CQUNyQyxLQUFLLE1BQU0sVUFBVSxJQUFJLE9BQU8sQ0FBQyxXQUFXLEVBQUUsQ0FBQzt3QkFDN0Msa0NBQWtDO3dCQUNsQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUEsZUFBUSxFQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFLFVBQVUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO29CQUNsRSxDQUFDO29CQUNELE9BQU8sUUFBUSxDQUFDO2dCQUNsQixDQUFDO2FBQ0Y7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUFqQ0Qsc0NBaUNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcmVsYXRpdmUgfSBmcm9tIFwicGF0aFwiO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBQcm9qZWN0LCBZYW1sRmlsZSB9IGZyb20gXCJwcm9qZW5cIjtcblxuZXhwb3J0IGNsYXNzIFBucG1Xb3Jrc3BhY2UgZXh0ZW5kcyBDb21wb25lbnQge1xuICBwdWJsaWMgc3RhdGljIG9mKHByb2plY3Q6IFByb2plY3QpOiBQbnBtV29ya3NwYWNlIHwgdW5kZWZpbmVkIHtcbiAgICBjb25zdCBpc0RlZmluZWQgPSAoYzogQ29tcG9uZW50KTogYyBpcyBQbnBtV29ya3NwYWNlID0+XG4gICAgICBjIGluc3RhbmNlb2YgUG5wbVdvcmtzcGFjZTtcbiAgICByZXR1cm4gcHJvamVjdC5yb290LmNvbXBvbmVudHMuZmluZChpc0RlZmluZWQpO1xuICB9XG5cbiAgY29uc3RydWN0b3IocHJvamVjdDogUHJvamVjdCkge1xuICAgIHN1cGVyKHByb2plY3QpO1xuXG4gICAgY29uc3QgZmlsZU5hbWU6IHN0cmluZyA9IFwicG5wbS13b3Jrc3BhY2UueWFtbFwiO1xuXG4gICAgLyoqXG4gICAgICogSW4gY2FzZSB0aGF0IHRoaXMgZmlsZSBpcyBpbiBhIHBhY2thZ2UsIGRvbid0IHBhY2thZ2UgaXQuXG4gICAgICovXG4gICAgcHJvamVjdC5hZGRQYWNrYWdlSWdub3JlKGZpbGVOYW1lKTtcblxuICAgIC8qKlxuICAgICAqIFdyaXRlIHBucG0gd29ya3NwYWNlIGZpbGVcbiAgICAgKi9cbiAgICBuZXcgWWFtbEZpbGUodGhpcy5wcm9qZWN0LCBmaWxlTmFtZSwge1xuICAgICAgb2JqOiB7XG4gICAgICAgIHBhY2thZ2VzOiAoKSA9PiB7XG4gICAgICAgICAgY29uc3QgcGFja2FnZXMgPSBuZXcgQXJyYXk8c3RyaW5nPigpO1xuICAgICAgICAgIGZvciAoY29uc3Qgc3VicHJvamVjdCBvZiBwcm9qZWN0LnN1YnByb2plY3RzKSB7XG4gICAgICAgICAgICAvLyBncmFiIHRoZSByZWxhdGl2ZSBvdXQgZGlyZWN0b3J5XG4gICAgICAgICAgICBwYWNrYWdlcy5wdXNoKHJlbGF0aXZlKHRoaXMucHJvamVjdC5vdXRkaXIsIHN1YnByb2plY3Qub3V0ZGlyKSk7XG4gICAgICAgICAgfVxuICAgICAgICAgIHJldHVybiBwYWNrYWdlcztcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
|
|
138
|
+
//# 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\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  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     * 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         * If any subprojects exist, output all subprojects in the workspace as\n         * packages.\n         */\n        if (this.project.subprojects.length > 0) {\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        /**\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         * Return the final pnpm config object.\n         */\n        return {\n          ...(packages.length > 0 ? { packages } : {}),\n          ...(pnpmConfig ? { ...pnpmConfig } : {}),\n        };\n      },\n    });\n  }\n}\n"]}
|
package/package.json
CHANGED