@vltpkg/package-info 1.0.0-rc.3 → 1.0.0-rc.31
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/dist/{esm/index.d.ts → index.d.ts} +8 -2
- package/dist/{esm/index.js → index.js} +157 -42
- package/dist/{esm/rename.d.ts → rename.d.ts} +0 -1
- package/dist/{esm/rename.js → rename.js} +0 -1
- package/package.json +44 -52
- package/dist/esm/index.d.ts.map +0 -1
- package/dist/esm/index.js.map +0 -1
- package/dist/esm/package.json +0 -3
- package/dist/esm/rename.d.ts.map +0 -1
- package/dist/esm/rename.js.map +0 -1
|
@@ -7,7 +7,7 @@ import { Spec } from '@vltpkg/spec';
|
|
|
7
7
|
import { Pool } from '@vltpkg/tar';
|
|
8
8
|
import type { Integrity, Manifest, Packument } from '@vltpkg/types';
|
|
9
9
|
import { Monorepo } from '@vltpkg/workspaces';
|
|
10
|
-
export declare const delimiter = "
|
|
10
|
+
export declare const delimiter = "~";
|
|
11
11
|
export type Resolution = {
|
|
12
12
|
resolved: string;
|
|
13
13
|
integrity?: Integrity;
|
|
@@ -32,6 +32,13 @@ export type PackageInfoClientRequestOptions = PickManifestOptions & RegistryClie
|
|
|
32
32
|
export type PackageInfoClientExtractOptions = PackageInfoClientRequestOptions & {
|
|
33
33
|
integrity?: Integrity;
|
|
34
34
|
resolved?: string;
|
|
35
|
+
/**
|
|
36
|
+
* When true, indicates that integrity + resolved came from a
|
|
37
|
+
* lockfile (i.e. they were already verified on first install).
|
|
38
|
+
* Skips the client-side tarball integrity check.
|
|
39
|
+
* Defaults to false — fresh installs always verify integrity.
|
|
40
|
+
*/
|
|
41
|
+
fromLockfile?: boolean;
|
|
35
42
|
};
|
|
36
43
|
export declare class PackageInfoClient {
|
|
37
44
|
#private;
|
|
@@ -53,4 +60,3 @@ export declare class PackageInfoClient {
|
|
|
53
60
|
packument(spec: Spec | string, options?: PackageInfoClientRequestOptions): Promise<Packument>;
|
|
54
61
|
resolve(spec: Spec | string, options?: PackageInfoClientRequestOptions): Promise<Resolution>;
|
|
55
62
|
}
|
|
56
|
-
//# sourceMappingURL=index.d.ts.map
|
|
@@ -5,16 +5,17 @@ import { pickManifest } from '@vltpkg/pick-manifest';
|
|
|
5
5
|
import { RegistryClient } from '@vltpkg/registry-client';
|
|
6
6
|
import { Spec } from '@vltpkg/spec';
|
|
7
7
|
import { Pool } from '@vltpkg/tar';
|
|
8
|
-
import { asPackument
|
|
8
|
+
import { asPackument } from '@vltpkg/types';
|
|
9
|
+
import ssri from 'ssri';
|
|
9
10
|
import { Monorepo } from '@vltpkg/workspaces';
|
|
10
11
|
import { XDG } from '@vltpkg/xdg';
|
|
11
|
-
import { randomBytes } from 'node:crypto';
|
|
12
|
+
import { createHash, randomBytes } from 'node:crypto';
|
|
12
13
|
import { mkdir, readFile, rm, stat, symlink, unlink, writeFile, } from 'node:fs/promises';
|
|
13
14
|
import { basename, dirname, resolve as pathResolve, relative, } from 'node:path';
|
|
14
15
|
import { create as tarC } from 'tar';
|
|
15
16
|
import { rename } from "./rename.js";
|
|
16
17
|
const xdg = new XDG('vlt');
|
|
17
|
-
export const delimiter = '
|
|
18
|
+
export const delimiter = '~';
|
|
18
19
|
// the maximum duration of a manifest cache file
|
|
19
20
|
const manifestCacheMaxAge = 5 * 60 * 1000;
|
|
20
21
|
export class PackageInfoClient {
|
|
@@ -64,9 +65,12 @@ export class PackageInfoClient {
|
|
|
64
65
|
async extract(spec, target, options = {}) {
|
|
65
66
|
if (typeof spec === 'string')
|
|
66
67
|
spec = Spec.parse(spec, this.options);
|
|
67
|
-
const { from = this.#projectRoot, integrity, resolved } = options;
|
|
68
|
+
const { from = this.#projectRoot, integrity, resolved, fromLockfile = false, } = options;
|
|
68
69
|
const f = spec.final;
|
|
69
|
-
|
|
70
|
+
// If the caller already provides both integrity and resolved
|
|
71
|
+
// (from lockfile or prior resolution), skip re-resolving.
|
|
72
|
+
const alreadyResolved = !!(integrity && resolved);
|
|
73
|
+
const r = alreadyResolved ?
|
|
70
74
|
{ resolved, integrity, spec }
|
|
71
75
|
: await this.resolve(spec, options);
|
|
72
76
|
switch (f.type) {
|
|
@@ -96,29 +100,108 @@ export class PackageInfoClient {
|
|
|
96
100
|
}
|
|
97
101
|
// fallthrough if a remote tarball url present
|
|
98
102
|
}
|
|
99
|
-
case 'registry':
|
|
103
|
+
case 'registry': {
|
|
104
|
+
const fetchTarball = async (useCache) => {
|
|
105
|
+
const trustIntegrity = this.#trustedIntegrities.get(r.resolved) === r.integrity;
|
|
106
|
+
const response = await this.registryClient.request(r.resolved, {
|
|
107
|
+
integrity: r.integrity,
|
|
108
|
+
trustIntegrity,
|
|
109
|
+
...(useCache === false ? { useCache } : {}),
|
|
110
|
+
});
|
|
111
|
+
if (response.statusCode !== 200) {
|
|
112
|
+
throw this.#resolveError(spec, options, 'failed to fetch tarball', {
|
|
113
|
+
url: r.resolved,
|
|
114
|
+
response,
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
// if it's not trusted already, but valid, start trusting
|
|
118
|
+
if (!trustIntegrity &&
|
|
119
|
+
response.checkIntegrity({ spec, url: resolved })) {
|
|
120
|
+
this.#trustedIntegrities.set(r.resolved, response.integrity);
|
|
121
|
+
}
|
|
122
|
+
const buf = response.buffer();
|
|
123
|
+
// Verify tarball integrity against the manifest's
|
|
124
|
+
// dist.integrity. This is a supply-chain security measure:
|
|
125
|
+
// the registry may not validate integrity, so we do it
|
|
126
|
+
// client-side on every fresh download. Skip when integrity
|
|
127
|
+
// came from lockfile/cache (it was already verified on
|
|
128
|
+
// first install).
|
|
129
|
+
/* c8 ignore start - defense-in-depth: registry client's
|
|
130
|
+
* checkIntegrity() usually catches mismatches first since
|
|
131
|
+
* it checks the same gzip bytes. This fires only when the
|
|
132
|
+
* registry client check is skipped (trustIntegrity=true). */
|
|
133
|
+
if (r.integrity && !fromLockfile) {
|
|
134
|
+
const hash = createHash('sha512');
|
|
135
|
+
hash.update(buf);
|
|
136
|
+
const computed = `sha512-${hash.digest('base64')}`;
|
|
137
|
+
if (computed !== r.integrity) {
|
|
138
|
+
throw error('Tarball integrity check failed', {
|
|
139
|
+
code: 'EINTEGRITY',
|
|
140
|
+
spec,
|
|
141
|
+
url: r.resolved,
|
|
142
|
+
wanted: r.integrity,
|
|
143
|
+
found: computed,
|
|
144
|
+
});
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
/* c8 ignore stop */
|
|
148
|
+
return buf;
|
|
149
|
+
};
|
|
150
|
+
let buf;
|
|
151
|
+
try {
|
|
152
|
+
buf = await fetchTarball();
|
|
153
|
+
}
|
|
154
|
+
catch (er) {
|
|
155
|
+
// On EINTEGRITY, retry once bypassing cache. This handles
|
|
156
|
+
// transient issues such as corrupted downloads or CDN
|
|
157
|
+
// inconsistencies that cause the cached tarball to not
|
|
158
|
+
// match the expected integrity hash.
|
|
159
|
+
if (er instanceof Error &&
|
|
160
|
+
'cause' in er &&
|
|
161
|
+
er.cause
|
|
162
|
+
?.code === 'EINTEGRITY') {
|
|
163
|
+
buf = await fetchTarball(false);
|
|
164
|
+
}
|
|
165
|
+
else {
|
|
166
|
+
throw er;
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
try {
|
|
170
|
+
await this.tarPool.unpack(buf, target);
|
|
171
|
+
}
|
|
172
|
+
catch (er) {
|
|
173
|
+
throw this.#resolveError(spec, options, 'tar unpack failed', { cause: er });
|
|
174
|
+
}
|
|
175
|
+
return r;
|
|
176
|
+
}
|
|
100
177
|
case 'remote': {
|
|
101
|
-
const
|
|
102
|
-
const response = await this.registryClient.request(r.resolved, {
|
|
103
|
-
integrity: r.integrity,
|
|
104
|
-
trustIntegrity,
|
|
105
|
-
});
|
|
178
|
+
const response = await this.registryClient.request(r.resolved);
|
|
106
179
|
if (response.statusCode !== 200) {
|
|
107
|
-
throw this.#resolveError(spec, options, 'failed to fetch tarball', {
|
|
180
|
+
throw this.#resolveError(spec, options, 'failed to fetch remote tarball', {
|
|
108
181
|
url: r.resolved,
|
|
109
182
|
response,
|
|
110
183
|
});
|
|
111
184
|
}
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
185
|
+
const buf = response.buffer();
|
|
186
|
+
// Compute integrity for remote/git-with-tarball deps
|
|
187
|
+
const computed = ssri
|
|
188
|
+
.fromData(buf, { algorithms: ['sha512'] })
|
|
189
|
+
.toString();
|
|
190
|
+
if (r.integrity && r.integrity !== computed) {
|
|
191
|
+
throw error('Integrity check failure', {
|
|
192
|
+
code: 'EINTEGRITY',
|
|
193
|
+
spec,
|
|
194
|
+
url: r.resolved,
|
|
195
|
+
wanted: r.integrity,
|
|
196
|
+
found: computed,
|
|
197
|
+
});
|
|
116
198
|
}
|
|
199
|
+
r.integrity = computed;
|
|
117
200
|
try {
|
|
118
|
-
await this.tarPool.unpack(
|
|
201
|
+
await this.tarPool.unpack(buf, target);
|
|
119
202
|
}
|
|
120
203
|
catch (er) {
|
|
121
|
-
throw this.#resolveError(spec, options, 'tar unpack failed', { cause: er });
|
|
204
|
+
throw this.#resolveError(spec, options, 'remote tar unpack failed', { cause: er });
|
|
122
205
|
}
|
|
123
206
|
return r;
|
|
124
207
|
}
|
|
@@ -247,21 +330,56 @@ export class PackageInfoClient {
|
|
|
247
330
|
if (!tarball) {
|
|
248
331
|
throw this.#resolveError(spec, options, 'no tarball found in manifest.dist');
|
|
249
332
|
}
|
|
250
|
-
const
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
333
|
+
const fetchTarball = async (useCache) => {
|
|
334
|
+
const trustIntegrity = this.#trustedIntegrities.get(tarball) === integrity;
|
|
335
|
+
const response = await this.registryClient.request(tarball, {
|
|
336
|
+
...options,
|
|
337
|
+
integrity,
|
|
338
|
+
trustIntegrity,
|
|
339
|
+
...(useCache === false ? { useCache } : {}),
|
|
340
|
+
});
|
|
341
|
+
if (response.statusCode !== 200) {
|
|
342
|
+
throw this.#resolveError(spec, options, 'failed to fetch tarball', { response, url: tarball });
|
|
343
|
+
}
|
|
344
|
+
// if we don't already trust it, but it's valid, start
|
|
345
|
+
// trusting it
|
|
346
|
+
if (!trustIntegrity &&
|
|
347
|
+
response.checkIntegrity({ spec, url: tarball })) {
|
|
348
|
+
this.#trustedIntegrities.set(tarball, response.integrity);
|
|
349
|
+
}
|
|
350
|
+
const buf = response.buffer();
|
|
351
|
+
// Verify tarball integrity against the manifest's
|
|
352
|
+
// dist.integrity.
|
|
353
|
+
/* c8 ignore start - defense-in-depth (see extract) */
|
|
354
|
+
if (integrity) {
|
|
355
|
+
const hash = createHash('sha512');
|
|
356
|
+
hash.update(buf);
|
|
357
|
+
const computed = `sha512-${hash.digest('base64')}`;
|
|
358
|
+
if (computed !== integrity) {
|
|
359
|
+
throw error('Tarball integrity check failed', {
|
|
360
|
+
code: 'EINTEGRITY',
|
|
361
|
+
spec,
|
|
362
|
+
url: tarball,
|
|
363
|
+
wanted: integrity,
|
|
364
|
+
found: computed,
|
|
365
|
+
});
|
|
366
|
+
}
|
|
367
|
+
}
|
|
368
|
+
/* c8 ignore stop */
|
|
369
|
+
return buf;
|
|
370
|
+
};
|
|
371
|
+
try {
|
|
372
|
+
return await fetchTarball();
|
|
258
373
|
}
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
374
|
+
catch (er) {
|
|
375
|
+
if (er instanceof Error &&
|
|
376
|
+
'cause' in er &&
|
|
377
|
+
er.cause
|
|
378
|
+
?.code === 'EINTEGRITY') {
|
|
379
|
+
return await fetchTarball(false);
|
|
380
|
+
}
|
|
381
|
+
throw er;
|
|
263
382
|
}
|
|
264
|
-
return response.buffer();
|
|
265
383
|
}
|
|
266
384
|
case 'git': {
|
|
267
385
|
const { remoteURL, gitRemote, gitCommittish, gitSelectorParsed, } = f;
|
|
@@ -361,15 +479,6 @@ export class PackageInfoClient {
|
|
|
361
479
|
: pickManifest(await this.packument(f, options), spec, options);
|
|
362
480
|
if (!mani)
|
|
363
481
|
throw this.#resolveError(spec, options);
|
|
364
|
-
const { integrity, tarball } = mani.dist ?? /* c8 ignore next */ {};
|
|
365
|
-
if (isIntegrity(integrity) && tarball) {
|
|
366
|
-
const registryOrigin = new URL(String(f.registry)).origin;
|
|
367
|
-
const tgzOrigin = new URL(tarball).origin;
|
|
368
|
-
// if it comes from the same origin, trust the integrity
|
|
369
|
-
if (tgzOrigin === registryOrigin) {
|
|
370
|
-
this.#trustedIntegrities.set(tarball, integrity);
|
|
371
|
-
}
|
|
372
|
-
}
|
|
373
482
|
// Cache the manifest data
|
|
374
483
|
if (cachePath) {
|
|
375
484
|
const json = JSON.stringify({
|
|
@@ -421,13 +530,20 @@ export class PackageInfoClient {
|
|
|
421
530
|
throw this.#resolveError(s, options, 'failed to fetch URL', { response, url: remoteURL });
|
|
422
531
|
}
|
|
423
532
|
const buf = response.buffer();
|
|
533
|
+
// Compute integrity for remote/git-with-tarball deps
|
|
534
|
+
const computed = ssri
|
|
535
|
+
.fromData(buf, { algorithms: ['sha512'] })
|
|
536
|
+
.toString();
|
|
424
537
|
try {
|
|
425
538
|
await this.tarPool.unpack(buf, dir);
|
|
426
539
|
}
|
|
427
540
|
catch (er) {
|
|
428
541
|
throw this.#resolveError(s, options, 'tar unpack failed', { cause: er });
|
|
429
542
|
}
|
|
430
|
-
return
|
|
543
|
+
// return manifest with computed integrity
|
|
544
|
+
const mani = this.packageJson.read(dir);
|
|
545
|
+
mani.dist = { integrity: computed };
|
|
546
|
+
return mani;
|
|
431
547
|
});
|
|
432
548
|
}
|
|
433
549
|
case 'file': {
|
|
@@ -625,4 +741,3 @@ export class PackageInfoClient {
|
|
|
625
741
|
return er;
|
|
626
742
|
}
|
|
627
743
|
}
|
|
628
|
-
//# sourceMappingURL=index.js.map
|
package/package.json
CHANGED
|
@@ -1,85 +1,77 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@vltpkg/package-info",
|
|
3
3
|
"description": "Resolve and fetch package metadata and tarballs",
|
|
4
|
-
"version": "1.0.0-rc.
|
|
4
|
+
"version": "1.0.0-rc.31",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
7
7
|
"url": "git+https://github.com/vltpkg/vltpkg.git",
|
|
8
8
|
"directory": "src/package-info"
|
|
9
9
|
},
|
|
10
|
-
"author":
|
|
11
|
-
|
|
12
|
-
"
|
|
13
|
-
"
|
|
14
|
-
"dialects": [
|
|
15
|
-
"esm"
|
|
16
|
-
],
|
|
17
|
-
"exports": {
|
|
18
|
-
"./package.json": "./package.json",
|
|
19
|
-
".": "./src/index.ts"
|
|
20
|
-
}
|
|
10
|
+
"author": {
|
|
11
|
+
"name": "vlt technology inc.",
|
|
12
|
+
"email": "support@vlt.sh",
|
|
13
|
+
"url": "http://vlt.sh"
|
|
21
14
|
},
|
|
22
15
|
"dependencies": {
|
|
23
|
-
"
|
|
24
|
-
"@vltpkg/
|
|
25
|
-
"@vltpkg/
|
|
26
|
-
"@vltpkg/
|
|
27
|
-
"@vltpkg/
|
|
28
|
-
"@vltpkg/
|
|
29
|
-
"@vltpkg/
|
|
30
|
-
"@vltpkg/
|
|
31
|
-
"@vltpkg/
|
|
32
|
-
"@vltpkg/
|
|
33
|
-
"
|
|
16
|
+
"@vltpkg/error-cause": "1.0.0-rc.31",
|
|
17
|
+
"@vltpkg/git": "1.0.0-rc.31",
|
|
18
|
+
"@vltpkg/package-json": "1.0.0-rc.31",
|
|
19
|
+
"@vltpkg/pick-manifest": "1.0.0-rc.31",
|
|
20
|
+
"@vltpkg/registry-client": "1.0.0-rc.31",
|
|
21
|
+
"@vltpkg/spec": "1.0.0-rc.31",
|
|
22
|
+
"@vltpkg/tar": "1.0.0-rc.31",
|
|
23
|
+
"@vltpkg/types": "1.0.0-rc.31",
|
|
24
|
+
"@vltpkg/workspaces": "1.0.0-rc.31",
|
|
25
|
+
"@vltpkg/xdg": "1.0.0-rc.31",
|
|
26
|
+
"ssri": "^13.0.0",
|
|
27
|
+
"tar": "^7.5.2"
|
|
34
28
|
},
|
|
35
29
|
"devDependencies": {
|
|
36
|
-
"@eslint/js": "^9.
|
|
37
|
-
"@types/node": "^22.
|
|
30
|
+
"@eslint/js": "^9.39.1",
|
|
31
|
+
"@types/node": "^22.19.2",
|
|
38
32
|
"@types/pacote": "^11.1.8",
|
|
39
|
-
"
|
|
40
|
-
"
|
|
41
|
-
"
|
|
42
|
-
"
|
|
43
|
-
"
|
|
33
|
+
"@vltpkg/benchmark": "0.0.0",
|
|
34
|
+
"@vltpkg/cache-unzip": "1.0.0-rc.31",
|
|
35
|
+
"@vltpkg/vlt-json": "1.0.0-rc.31",
|
|
36
|
+
"eslint": "^9.39.1",
|
|
37
|
+
"pacote": "^21.0.4",
|
|
38
|
+
"prettier": "^3.7.4",
|
|
39
|
+
"tap": "^21.5.0",
|
|
44
40
|
"typedoc": "~0.27.9",
|
|
45
41
|
"typescript": "5.7.3",
|
|
46
|
-
"typescript-eslint": "^8.
|
|
47
|
-
"@vltpkg/benchmark": "0.0.0",
|
|
48
|
-
"@vltpkg/cache-unzip": "1.0.0-rc.3",
|
|
49
|
-
"@vltpkg/vlt-json": "1.0.0-rc.3"
|
|
42
|
+
"typescript-eslint": "^8.49.0"
|
|
50
43
|
},
|
|
51
44
|
"license": "BSD-2-Clause-Patent",
|
|
52
45
|
"engines": {
|
|
53
|
-
"node": ">=22"
|
|
46
|
+
"node": ">=22.22.0"
|
|
47
|
+
},
|
|
48
|
+
"scripts": {
|
|
49
|
+
"benchmark": "./scripts/benchmark.ts",
|
|
50
|
+
"format": "prettier --write . --log-level warn --ignore-path ../../.prettierignore --cache",
|
|
51
|
+
"format:check": "prettier --check . --ignore-path ../../.prettierignore --cache",
|
|
52
|
+
"lint": "eslint . --fix",
|
|
53
|
+
"lint:check": "eslint .",
|
|
54
|
+
"prepack": "tsc -p tsconfig.publish.json && ../../scripts/update-dist-exports.ts",
|
|
55
|
+
"snap": "tap",
|
|
56
|
+
"test": "tap",
|
|
57
|
+
"posttest": "tsc --noEmit",
|
|
58
|
+
"typecheck": "tsc --noEmit"
|
|
54
59
|
},
|
|
55
60
|
"tap": {
|
|
56
61
|
"extends": "../../tap-config.yaml"
|
|
57
62
|
},
|
|
58
63
|
"prettier": "../../.prettierrc.js",
|
|
59
|
-
"module": "./dist/
|
|
64
|
+
"module": "./dist/index.js",
|
|
60
65
|
"type": "module",
|
|
61
66
|
"exports": {
|
|
62
67
|
"./package.json": "./package.json",
|
|
63
68
|
".": {
|
|
64
69
|
"import": {
|
|
65
|
-
"
|
|
66
|
-
"default": "./dist/esm/index.js"
|
|
70
|
+
"default": "./dist/index.js"
|
|
67
71
|
}
|
|
68
72
|
}
|
|
69
73
|
},
|
|
70
74
|
"files": [
|
|
71
75
|
"dist"
|
|
72
|
-
]
|
|
73
|
-
|
|
74
|
-
"benchmark": "./scripts/benchmark.ts",
|
|
75
|
-
"format": "prettier --write . --log-level warn --ignore-path ../../.prettierignore --cache",
|
|
76
|
-
"format:check": "prettier --check . --ignore-path ../../.prettierignore --cache",
|
|
77
|
-
"lint": "eslint . --fix",
|
|
78
|
-
"lint:check": "eslint .",
|
|
79
|
-
"snap": "tap",
|
|
80
|
-
"test": "tap",
|
|
81
|
-
"posttest": "tsc --noEmit",
|
|
82
|
-
"tshy": "tshy",
|
|
83
|
-
"typecheck": "tsc --noEmit"
|
|
84
|
-
}
|
|
85
|
-
}
|
|
76
|
+
]
|
|
77
|
+
}
|
package/dist/esm/index.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAA;AAClD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAA;AAEhE,OAAO,KAAK,EACV,qBAAqB,EACrB,4BAA4B,EAC7B,MAAM,yBAAyB,CAAA;AAChC,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAA;AACxD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,cAAc,CAAA;AAC/C,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;AACnC,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAClC,OAAO,KAAK,EACV,SAAS,EACT,QAAQ,EACR,SAAS,EAEV,MAAM,eAAe,CAAA;AAEtB,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAA;AAsB7C,eAAO,MAAM,SAAS,WAAM,CAAA;AAE5B,MAAM,MAAM,UAAU,GAAG;IACvB,QAAQ,EAAE,MAAM,CAAA;IAChB,SAAS,CAAC,EAAE,SAAS,CAAA;IACrB,UAAU,CAAC,EAAE,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,SAAS,CAAC,CAAC,YAAY,CAAC,CAAA;IAC/D,IAAI,EAAE,IAAI,CAAA;CACX,CAAA;AAED,MAAM,MAAM,wBAAwB,GAAG,qBAAqB,GAC1D,WAAW,GAAG;IACZ,qDAAqD;IACrD,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,yBAAyB;IACzB,WAAW,CAAC,EAAE,WAAW,CAAA;IAEzB,QAAQ,CAAC,EAAE,QAAQ,CAAA;IAEnB,gEAAgE;IAChE,iBAAiB,CAAC,EAAE,MAAM,EAAE,CAAA;IAE5B,+DAA+D;IAC/D,SAAS,CAAC,EAAE,MAAM,EAAE,CAAA;CACrB,CAAA;AAEH,MAAM,MAAM,+BAA+B,GAAG,mBAAmB,GAC/D,4BAA4B,GAAG;IAC7B,4EAA4E;IAC5E,IAAI,CAAC,EAAE,MAAM,CAAA;CACd,CAAA;AAEH,MAAM,MAAM,+BAA+B,GACzC,+BAA+B,GAAG;IAChC,SAAS,CAAC,EAAE,SAAS,CAAA;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB,CAAA;AAKH,qBAAa,iBAAiB;;IAI5B,OAAO,EAAE,wBAAwB,CAAA;IAEjC,WAAW,EAAE,WAAW,CAAA;IACxB,QAAQ,CAAC,EAAE,QAAQ,CAAA;IAKnB,IAAI,cAAc,mBAKjB;IAED,IAAI,OAAO,SAGV;gBAEW,OAAO,GAAE,wBAA6B;IAuB5C,OAAO,CACX,IAAI,EAAE,IAAI,GAAG,MAAM,EACnB,MAAM,EAAE,MAAM,EACd,OAAO,GAAE,+BAAoC,GAC5C,OAAO,CAAC,UAAU,CAAC;IAwLtB;;;;OAIG;IACH,kBAAkB,CAChB,IAAI,EAAE,IAAI,EACV,OAAO,EAAE,+BAA+B,GACvC,MAAM,GAAG,SAAS;IAwDf,OAAO,CACX,IAAI,EAAE,IAAI,GAAG,MAAM,EACnB,OAAO,GAAE,+BAAoC,GAC5C,OAAO,CAAC,MAAM,CAAC;IAsIZ,QAAQ,CACZ,IAAI,EAAE,IAAI,GAAG,MAAM,EACnB,OAAO,GAAE,+BAAoC;IA8KzC,SAAS,CACb,IAAI,EAAE,IAAI,GAAG,MAAM,EACnB,OAAO,GAAE,+BAAoC,GAC5C,OAAO,CAAC,SAAS,CAAC;IA8Df,OAAO,CACX,IAAI,EAAE,IAAI,GAAG,MAAM,EACnB,OAAO,GAAE,+BAAoC,GAC5C,OAAO,CAAC,UAAU,CAAC;CAsJvB"}
|
package/dist/esm/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import type { ErrorCauseOptions } from '@vltpkg/error-cause'\nimport { error } from '@vltpkg/error-cause'\nimport { clone, resolve as gitResolve, revs } from '@vltpkg/git'\nimport { PackageJson } from '@vltpkg/package-json'\nimport type { PickManifestOptions } from '@vltpkg/pick-manifest'\nimport { pickManifest } from '@vltpkg/pick-manifest'\nimport type {\n RegistryClientOptions,\n RegistryClientRequestOptions,\n} from '@vltpkg/registry-client'\nimport { RegistryClient } from '@vltpkg/registry-client'\nimport type { SpecOptions } from '@vltpkg/spec'\nimport { Spec } from '@vltpkg/spec'\nimport { Pool } from '@vltpkg/tar'\nimport type {\n Integrity,\n Manifest,\n Packument,\n ManifestRegistry,\n} from '@vltpkg/types'\nimport { asPackument, isIntegrity } from '@vltpkg/types'\nimport { Monorepo } from '@vltpkg/workspaces'\nimport { XDG } from '@vltpkg/xdg'\nimport { randomBytes } from 'node:crypto'\nimport {\n mkdir,\n readFile,\n rm,\n stat,\n symlink,\n unlink,\n writeFile,\n} from 'node:fs/promises'\nimport {\n basename,\n dirname,\n resolve as pathResolve,\n relative,\n} from 'node:path'\nimport { create as tarC } from 'tar'\nimport { rename } from './rename.ts'\n\nconst xdg = new XDG('vlt')\nexport const delimiter = '·'\n\nexport type Resolution = {\n resolved: string\n integrity?: Integrity\n signatures?: Exclude<Manifest['dist'], undefined>['signatures']\n spec: Spec\n}\n\nexport type PackageInfoClientOptions = RegistryClientOptions &\n SpecOptions & {\n /** root of the project. Defaults to process.cwd() */\n projectRoot?: string\n /** PackageJson object */\n packageJson?: PackageJson\n\n monorepo?: Monorepo\n\n /** workspace groups to load, irrelevant if Monorepo provided */\n 'workspace-group'?: string[]\n\n /** workspace paths to load, irrelevant if Monorepo provided */\n workspace?: string[]\n }\n\nexport type PackageInfoClientRequestOptions = PickManifestOptions &\n RegistryClientRequestOptions & {\n /** dir to resolve `file://` specifiers against. Defaults to projectRoot. */\n from?: string\n }\n\nexport type PackageInfoClientExtractOptions =\n PackageInfoClientRequestOptions & {\n integrity?: Integrity\n resolved?: string\n }\n\n// the maximum duration of a manifest cache file\nconst manifestCacheMaxAge = 5 * 60 * 1000\n\nexport class PackageInfoClient {\n #registryClient?: RegistryClient\n #projectRoot: string\n #tarPool?: Pool\n options: PackageInfoClientOptions\n #resolutions = new Map<string, Resolution>()\n packageJson: PackageJson\n monorepo?: Monorepo\n #trustedIntegrities = new Map<string, Integrity>()\n #manifestCacheMinAge = Date.now() - manifestCacheMaxAge\n #cachePath: string\n\n get registryClient() {\n if (!this.#registryClient) {\n this.#registryClient = new RegistryClient(this.options)\n }\n return this.#registryClient\n }\n\n get tarPool() {\n if (!this.#tarPool) this.#tarPool = new Pool()\n return this.#tarPool\n }\n\n constructor(options: PackageInfoClientOptions = {}) {\n this.options = options\n this.#projectRoot = options.projectRoot || process.cwd()\n this.packageJson = options.packageJson ?? new PackageJson()\n const wsLoad = {\n ...(options.workspace?.length && { paths: options.workspace }),\n ...(options['workspace-group']?.length && {\n groups: options['workspace-group'],\n }),\n }\n this.monorepo =\n options.monorepo ??\n Monorepo.maybeLoad(this.#projectRoot, {\n load: wsLoad,\n packageJson: this.packageJson,\n })\n this.#cachePath = options.cache ?? xdg.cache()\n // optionally create its cache directory if it doesn't exist\n void mkdir(pathResolve(this.#cachePath, 'package-info'), {\n recursive: true,\n }).catch(() => {})\n }\n\n async extract(\n spec: Spec | string,\n target: string,\n options: PackageInfoClientExtractOptions = {},\n ): Promise<Resolution> {\n if (typeof spec === 'string')\n spec = Spec.parse(spec, this.options)\n const { from = this.#projectRoot, integrity, resolved } = options\n const f = spec.final\n const r =\n integrity && resolved ?\n { resolved, integrity, spec }\n : await this.resolve(spec, options)\n\n switch (f.type) {\n case 'git': {\n const {\n gitRemote,\n gitCommittish,\n remoteURL,\n gitSelectorParsed,\n } = f\n if (!remoteURL) {\n /* c8 ignore start - Impossible, would throw on the resolve */\n if (!gitRemote)\n throw this.#resolveError(\n spec,\n options,\n 'no remote on git: specifier',\n )\n /* c8 ignore stop */\n const { path } = gitSelectorParsed ?? {}\n if (path !== undefined) {\n // use obvious name because it's in node_modules\n const tmp = pathResolve(\n dirname(target),\n `.TEMP.${basename(target)}-${randomBytes(6).toString('hex')}`,\n )\n await clone(gitRemote, gitCommittish, tmp, { spec })\n const src = pathResolve(tmp, path)\n await rename(src, target)\n // intentionally not awaited\n void rm(tmp, { recursive: true, force: true })\n } else {\n await clone(gitRemote, gitCommittish, target, { spec })\n // intentionally not awaited\n void rm(target + '/.git', { recursive: true })\n }\n return r\n }\n // fallthrough if a remote tarball url present\n }\n\n case 'registry':\n case 'remote': {\n const trustIntegrity =\n this.#trustedIntegrities.get(r.resolved) === r.integrity\n\n const response = await this.registryClient.request(\n r.resolved,\n {\n integrity: r.integrity,\n trustIntegrity,\n },\n )\n\n if (response.statusCode !== 200) {\n throw this.#resolveError(\n spec,\n options,\n 'failed to fetch tarball',\n {\n url: r.resolved,\n response,\n },\n )\n }\n\n // if it's not trusted already, but valid, start trusting\n if (\n !trustIntegrity &&\n response.checkIntegrity({ spec, url: resolved })\n ) {\n this.#trustedIntegrities.set(r.resolved, response.integrity)\n }\n\n try {\n await this.tarPool.unpack(response.buffer(), target)\n } catch (er) {\n throw this.#resolveError(\n spec,\n options,\n 'tar unpack failed',\n { cause: er },\n )\n }\n return r\n }\n case 'file': {\n // if it's a directory, then \"extract\" means \"symlink\"\n const { file } = f\n /* c8 ignore start - asserted in resolve() */\n if (file === undefined)\n throw this.#resolveError(spec, options, 'no file path')\n /* c8 ignore stop */\n const path = pathResolve(from, file)\n const st = await stat(path)\n if (st.isFile()) {\n try {\n await this.tarPool.unpack(\n await this.tarball(spec, options),\n target,\n )\n } catch (er) {\n throw this.#resolveError(\n spec,\n options,\n 'tar unpack failed',\n { cause: er },\n )\n }\n } else if (st.isDirectory()) {\n const rel = relative(dirname(target), path)\n await symlink(rel, target, 'dir')\n /* c8 ignore start */\n } else {\n throw this.#resolveError(\n spec,\n options,\n 'file: specifier does not resolve to directory or tarball',\n )\n }\n /* c8 ignore stop */\n return r\n }\n case 'workspace': {\n const ws = this.#getWS(spec, options)\n const rel = relative(dirname(target), ws.fullpath)\n await symlink(rel, target, 'dir')\n return r\n }\n }\n }\n\n #getWS(spec: Spec, options: PackageInfoClientRequestOptions) {\n const { workspace } = spec\n /* c8 ignore start - asserted in resolve() */\n if (workspace === undefined)\n throw this.#resolveError(spec, options, 'no workspace ID')\n /* c8 ignore stop */\n if (!this.monorepo) {\n throw this.#resolveError(\n spec,\n options,\n 'Not in a monorepo, cannot resolve workspace spec',\n )\n }\n const ws = this.monorepo.get(workspace)\n if (!ws) {\n throw this.#resolveError(spec, options, 'workspace not found', {\n wanted: workspace,\n })\n }\n return ws\n }\n\n /**\n * Return the manifest cache key for a spec and the current options.\n */\n #manifestCacheKey(\n spec: Spec,\n options: PackageInfoClientRequestOptions,\n ): string {\n let extra = ''\n if (options['node-version']) {\n extra += `${delimiter}node-version:${options['node-version']}`\n }\n if (options.os) {\n extra += `${delimiter}os:${options.os}`\n }\n if (options.arch) {\n extra += `${delimiter}arch:${options.arch}`\n }\n return encodeURIComponent(\n `${spec.registry}${delimiter}${spec}${extra}`,\n )\n }\n\n /**\n * Conditionally return the path to the manifest cache file. The logic\n * to determine if caching should be skipped aligns with `pickManifest`\n * and is used to avoid caching manifest results that can be variable.\n */\n _manifestCachePath(\n spec: Spec,\n options: PackageInfoClientRequestOptions,\n ): string | undefined {\n if (options.before) {\n return\n }\n // if the final resolved spec is either a dist tag or something that\n // matches any range (such as a semver range of `*` or empty string)\n // then we skip caching\n const f = spec.final\n if (f.distTag || f.range?.isAny) {\n return\n }\n const key = this.#manifestCacheKey(f, options)\n return pathResolve(this.#cachePath, 'package-info', key)\n }\n\n async #registryManifestRequest(\n spec: Spec,\n options: PackageInfoClientRequestOptions,\n ): Promise<ManifestRegistry> {\n const { registry, name, registrySpec } = spec.final\n /* c8 ignore start */\n if (!spec.range?.isSingle || !registrySpec) {\n throw this.#resolveError(\n spec,\n options,\n 'failed to request manifest',\n { spec },\n )\n }\n /* c8 ignore stop */\n const possibleLeadingChars = ['=', '^', '~', 'v']\n const hasLeadingRange = possibleLeadingChars.some(char =>\n registrySpec.startsWith(char),\n )\n const version =\n hasLeadingRange ? registrySpec.slice(1) : registrySpec\n const pakuURL = new URL(`${name}/${version}`, registry)\n const response = await this.registryClient.request(pakuURL, {\n headers: {\n accept: 'application/json',\n },\n })\n if (response.statusCode !== 200) {\n throw this.#resolveError(\n spec,\n options,\n 'failed to fetch manifest',\n {\n url: pakuURL,\n response,\n },\n )\n }\n return response.json() as ManifestRegistry\n }\n\n async tarball(\n spec: Spec | string,\n options: PackageInfoClientExtractOptions = {},\n ): Promise<Buffer> {\n if (typeof spec === 'string')\n spec = Spec.parse(spec, this.options)\n const f = spec.final\n\n switch (f.type) {\n case 'registry': {\n const { dist } = await this.manifest(spec, options)\n if (!dist)\n throw this.#resolveError(\n spec,\n options,\n 'no dist object found in manifest',\n )\n\n const { tarball, integrity } = dist\n if (!tarball) {\n throw this.#resolveError(\n spec,\n options,\n 'no tarball found in manifest.dist',\n )\n }\n\n const trustIntegrity =\n this.#trustedIntegrities.get(tarball) === integrity\n\n const response = await this.registryClient.request(tarball, {\n ...options,\n integrity,\n trustIntegrity,\n })\n if (response.statusCode !== 200) {\n throw this.#resolveError(\n spec,\n options,\n 'failed to fetch tarball',\n { response, url: tarball },\n )\n }\n\n // if we don't already trust it, but it's valid, start trusting it\n if (\n !trustIntegrity &&\n response.checkIntegrity({ spec, url: tarball })\n ) {\n this.#trustedIntegrities.set(tarball, response.integrity)\n }\n\n return response.buffer()\n }\n\n case 'git': {\n const {\n remoteURL,\n gitRemote,\n gitCommittish,\n gitSelectorParsed,\n } = f\n const s: Spec = spec\n if (!remoteURL) {\n if (!gitRemote) {\n throw this.#resolveError(\n spec,\n options,\n 'no remote on git: specifier',\n )\n }\n const { path } = gitSelectorParsed ?? {}\n return await this.#tmpdir(async dir => {\n await clone(gitRemote, gitCommittish, dir + '/package', {\n spec: s,\n })\n let cwd = dir\n if (path !== undefined) {\n const src = pathResolve(dir, 'package', path)\n cwd = dirname(src)\n const pkg = pathResolve(cwd, 'package')\n if (src !== pkg) {\n const rand = randomBytes(6).toString('hex')\n // faster than deleting\n await rename(pkg, pkg + rand).catch(() => {})\n await rename(src, pkg)\n }\n }\n return tarC({ cwd, gzip: true }, ['package']).concat()\n })\n }\n // fallthrough if remoteURL set\n }\n\n case 'remote': {\n const { remoteURL } = f\n if (!remoteURL) {\n throw this.#resolveError(spec, options)\n }\n const response = await this.registryClient.request(remoteURL)\n if (response.statusCode !== 200) {\n throw this.#resolveError(\n spec,\n options,\n 'failed to fetch URL',\n { response, url: remoteURL },\n )\n }\n return response.buffer()\n }\n\n case 'file': {\n const { file } = f\n if (file === undefined)\n throw this.#resolveError(spec, options, 'no file path')\n const { from = this.#projectRoot } = options\n const path = pathResolve(from, file)\n const st = await stat(path)\n if (st.isDirectory()) {\n const p = dirname(path)\n const b = basename(path)\n // TODO: Pack properly, ignore stuff, bundleDeps, etc\n return tarC({ cwd: p, gzip: true }, [b]).concat()\n }\n return readFile(path)\n }\n\n case 'workspace': {\n // TODO: Pack properly, ignore stuff, bundleDeps, etc\n const ws = this.#getWS(spec, options)\n const p = dirname(ws.fullpath)\n const b = basename(ws.fullpath)\n return tarC({ cwd: p, gzip: true }, [b]).concat()\n }\n }\n }\n\n async manifest(\n spec: Spec | string,\n options: PackageInfoClientRequestOptions = {},\n ) {\n const { from = this.#projectRoot } = options\n if (typeof spec === 'string')\n spec = Spec.parse(spec, this.options)\n const f = spec.final\n\n switch (f.type) {\n case 'registry': {\n // Check if manifest is cached, if so just return it earlier\n const cachePath = this._manifestCachePath(spec, options)\n if (cachePath) {\n try {\n // Cache file exists, read and return it\n const cached = await readFile(cachePath, 'utf8')\n const json = JSON.parse(cached) as Manifest & {\n __VLT_MANIFEST_CACHE_TIMESTAMP?: number\n }\n // retrieve timestamp to check if cache is still valid\n const timestamp = json.__VLT_MANIFEST_CACHE_TIMESTAMP\n delete json.__VLT_MANIFEST_CACHE_TIMESTAMP\n // removes the cache file if older than its maximum age\n if (\n timestamp != null &&\n timestamp < this.#manifestCacheMinAge\n ) {\n void unlink(cachePath).catch(() => {})\n throw new Error('manifest cache expired')\n }\n return json\n } catch {\n // Cache miss, fetch from packument\n }\n }\n\n const mani =\n spec.range?.isSingle ?\n await this.#registryManifestRequest(spec, options)\n : pickManifest(\n await this.packument(f, options),\n spec,\n options,\n )\n if (!mani) throw this.#resolveError(spec, options)\n const { integrity, tarball } =\n mani.dist ?? /* c8 ignore next */ {}\n if (isIntegrity(integrity) && tarball) {\n const registryOrigin = new URL(String(f.registry)).origin\n const tgzOrigin = new URL(tarball).origin\n // if it comes from the same origin, trust the integrity\n if (tgzOrigin === registryOrigin) {\n this.#trustedIntegrities.set(tarball, integrity)\n }\n }\n\n // Cache the manifest data\n if (cachePath) {\n const json = JSON.stringify({\n ...mani,\n // append a timestamp to the manifest so that we can quickly\n // check if the cache is still valid when loading it\n __VLT_MANIFEST_CACHE_TIMESTAMP: Date.now(),\n })\n void writeFile(cachePath, json, 'utf8').catch(\n (err: unknown) => {\n // in case the cache directory doesn't exist\n // just create it and retry\n if (\n err instanceof Error &&\n 'code' in err &&\n err.code === 'ENOENT'\n ) {\n void mkdir(dirname(cachePath), {\n recursive: true,\n }).then(() => {\n void writeFile(cachePath, json, 'utf8')\n })\n }\n },\n )\n }\n\n return mani\n }\n\n case 'git': {\n const {\n gitRemote,\n gitCommittish,\n remoteURL,\n gitSelectorParsed,\n } = f\n if (!remoteURL) {\n const s = spec\n if (!gitRemote)\n throw this.#resolveError(spec, options, 'no git remote')\n return await this.#tmpdir(async dir => {\n await clone(gitRemote, gitCommittish, dir, { spec: s })\n const { path } = gitSelectorParsed ?? {}\n const pkgDir =\n path !== undefined ? pathResolve(dir, path) : dir\n return this.packageJson.read(pkgDir)\n })\n }\n // fallthrough to remote\n }\n\n case 'remote': {\n const { remoteURL } = f\n if (!remoteURL) {\n throw this.#resolveError(\n spec,\n options,\n 'no remoteURL on remote specifier',\n )\n }\n const s = spec\n return await this.#tmpdir(async dir => {\n const response =\n await this.registryClient.request(remoteURL)\n if (response.statusCode !== 200) {\n throw this.#resolveError(\n s,\n options,\n 'failed to fetch URL',\n { response, url: remoteURL },\n )\n }\n const buf = response.buffer()\n try {\n await this.tarPool.unpack(buf, dir)\n } catch (er) {\n throw this.#resolveError(\n s,\n options,\n 'tar unpack failed',\n { cause: er },\n )\n }\n return this.packageJson.read(dir)\n })\n }\n\n case 'file': {\n const { file } = f\n if (file === undefined)\n throw this.#resolveError(spec, options, 'no file path')\n const path = pathResolve(from, file)\n const st = await stat(path)\n if (st.isDirectory()) {\n return this.packageJson.read(path)\n }\n const s = spec\n return await this.#tmpdir(async dir => {\n try {\n await this.tarPool.unpack(await readFile(path), dir)\n } catch (er) {\n throw this.#resolveError(\n s,\n options,\n 'tar unpack failed',\n { cause: er },\n )\n }\n return this.packageJson.read(dir)\n })\n }\n\n case 'workspace': {\n return this.#getWS(spec, options).manifest\n }\n }\n }\n\n async packument(\n spec: Spec | string,\n options: PackageInfoClientRequestOptions = {},\n ): Promise<Packument> {\n if (typeof spec === 'string')\n spec = Spec.parse(spec, this.options)\n const f = spec.final\n switch (f.type) {\n // RevDoc is the equivalent of a packument for a git repo\n case 'git': {\n const { gitRemote } = f\n if (!gitRemote) {\n throw this.#resolveError(\n spec,\n options,\n 'git remote could not be determined',\n )\n }\n const revDoc = await revs(gitRemote, {\n cwd: this.options.projectRoot,\n })\n if (!revDoc) throw this.#resolveError(spec, options)\n return asPackument(revDoc)\n }\n\n // these are all faked packuments\n case 'file':\n case 'workspace':\n case 'remote': {\n const manifest = await this.manifest(f, options)\n return {\n name: manifest.name ?? '',\n 'dist-tags': {\n latest: manifest.version ?? '',\n },\n versions: {\n [manifest.version ?? '']: manifest as Manifest,\n },\n }\n }\n\n case 'registry': {\n const { registry, name } = f\n const pakuURL = new URL(name, registry)\n const response = await this.registryClient.request(pakuURL, {\n headers: {\n accept: 'application/json',\n },\n })\n if (response.statusCode !== 200) {\n throw this.#resolveError(\n spec,\n options,\n 'failed to fetch packument',\n {\n url: pakuURL,\n response,\n },\n )\n }\n return response.json() as Packument\n }\n }\n }\n\n async resolve(\n spec: Spec | string,\n options: PackageInfoClientRequestOptions = {},\n ): Promise<Resolution> {\n const memoKey = String(spec)\n if (typeof spec === 'string')\n spec = Spec.parse(spec, this.options)\n\n const memo = this.#resolutions.get(memoKey)\n if (memo) return memo\n const f = spec.final\n\n switch (f.type) {\n case 'file': {\n const { file } = f\n if (!file || !f.file) {\n throw this.#resolveError(\n spec,\n options,\n 'no path on file: specifier',\n )\n }\n const { from = this.#projectRoot } = options\n const resolved = pathResolve(from, f.file)\n const r = { resolved, spec }\n this.#resolutions.set(memoKey, r)\n return r\n }\n\n case 'remote': {\n const { remoteURL } = f\n if (!remoteURL)\n throw this.#resolveError(\n spec,\n options,\n 'no URL in remote specifier',\n )\n const r = { resolved: remoteURL, spec }\n this.#resolutions.set(memoKey, r)\n return r\n }\n\n case 'workspace': {\n const ws = this.#getWS(spec, options)\n return {\n resolved: ws.fullpath,\n spec,\n }\n }\n\n case 'registry': {\n const mani = await this.manifest(spec, options)\n if (mani.dist) {\n const { integrity, tarball, signatures } = mani.dist\n if (tarball) {\n const r = {\n resolved: tarball,\n integrity,\n signatures,\n spec,\n }\n this.#resolutions.set(memoKey, r)\n return r\n }\n }\n throw this.#resolveError(spec, options)\n }\n\n case 'git': {\n const { gitRemote, remoteURL, gitSelectorParsed } = f\n if (remoteURL && gitSelectorParsed?.path === undefined) {\n // known git host with a tarball download endpoint\n const r = { resolved: remoteURL, spec }\n this.#resolutions.set(memoKey, r)\n return r\n }\n if (!gitRemote) {\n throw this.#resolveError(\n spec,\n options,\n 'no remote on git specifier',\n )\n }\n const rev = await gitResolve(gitRemote, f.gitCommittish, {\n spec,\n })\n if (rev) {\n const r = {\n resolved: `${gitRemote}#${rev.sha}`,\n spec,\n }\n if (gitSelectorParsed) {\n r.resolved += Object.entries(gitSelectorParsed)\n .filter(([_, v]) => v)\n .map(([k, v]) => `::${k}:${v}`)\n .join('')\n }\n this.#resolutions.set(memoKey, r)\n return r\n }\n // have to actually clone somewhere\n const s: Spec = spec\n return this.#tmpdir(async tmpdir => {\n const sha = await clone(\n gitRemote,\n s.gitCommittish,\n tmpdir,\n {\n spec: s,\n },\n )\n const r = {\n resolved: `${gitRemote}#${sha}`,\n spec: s,\n }\n this.#resolutions.set(memoKey, r)\n return r\n })\n }\n }\n }\n\n async #tmpdir<T>(fn: (dir: string) => Promise<T>): Promise<T> {\n const p = `package-info/${randomBytes(6).toString('hex')}`\n const dir = xdg.runtime(p)\n try {\n return await fn(dir)\n } finally {\n // intentionally do not await\n void rm(dir, { recursive: true, force: true })\n }\n }\n\n // error resolving\n #resolveError(\n spec?: Spec,\n options: PackageInfoClientRequestOptions = {},\n message = 'Could not resolve',\n extra: ErrorCauseOptions = {},\n ) {\n const { from = this.#projectRoot } = options\n const er = error(\n message,\n {\n code: 'ERESOLVE',\n spec,\n from,\n ...extra,\n },\n this.#resolveError,\n )\n return er\n }\n}\n"]}
|
package/dist/esm/package.json
DELETED
package/dist/esm/rename.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rename.d.ts","sourceRoot":"","sources":["../../src/rename.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,MAAM,IAAI,QAAQ,EAAM,MAAM,kBAAkB,CAAA;AACzD,eAAO,MAAM,MAAM,iBAqBhB,CAAA"}
|
package/dist/esm/rename.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rename.js","sourceRoot":"","sources":["../../src/rename.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AACH,MAAM,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAA;AAE5B,OAAO,EAAE,MAAM,IAAI,QAAQ,EAAE,EAAE,EAAE,MAAM,kBAAkB,CAAA;AACzD,MAAM,CAAC,MAAM,MAAM,GACjB,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAChC,KAAK,WACH,OAAiB,EACjB,OAAiB;IAEjB,IAAI,OAAO,GAAG,CAAC,CAAA;IACf,MAAM,KAAK,GAAG,KAAK,EAAE,EAAW,EAAiB,EAAE;QACjD,IACE,OAAO,GAAG,CAAC;YACV,EAA4B,CAAC,IAAI,KAAK,OAAO,EAC9C,CAAC;YACD,OAAO,EAAE,CAAA;YACT,MAAM,EAAE,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAA;YACnD,OAAO,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,GAAE,CAAC,EAAE,KAAK,CAAC,CAAA;QACzD,CAAC;aAAM,CAAC;YACN,MAAM,EAAE,CAAA;QACV,CAAC;IACH,CAAC,CAAA;IACD,OAAO,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,GAAE,CAAC,EAAE,KAAK,CAAC,CAAA;AACzD,CAAC,CACF,CAAA","sourcesContent":["/**\n * On posix systems, rename is atomic and will clobber anything in its way\n * However, on Windows, it can fail with the rather unhelpful EPERM error if\n * the target directory is not removed in time or is currently in use.\n *\n * While true atomic semantics is not available on Windows in this case, we can\n * at least implement the posix overwrite semantics by explicitly removing the\n * target when this error occurs.\n *\n * This is only relevant when renaming *directories*, since files will\n * generally not raise problems. When/if we rename directories outside of\n * package-info, this can be moved to its own shared module.\n * @module\n */\nconst { platform } = process\nimport type { PathLike } from 'node:fs'\nimport { rename as fsRename, rm } from 'node:fs/promises'\nexport const rename =\n platform !== 'win32' ? fsRename : (\n async function (\n oldPath: PathLike,\n newPath: PathLike,\n ): Promise<void> {\n let retries = 3\n const retry = async (er: unknown): Promise<void> => {\n if (\n retries > 0 &&\n (er as NodeJS.ErrnoException).code === 'EPERM'\n ) {\n retries--\n await rm(newPath, { recursive: true, force: true })\n return fsRename(oldPath, newPath).then(() => {}, retry)\n } else {\n throw er\n }\n }\n return fsRename(oldPath, newPath).then(() => {}, retry)\n }\n )\n"]}
|