@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.
@@ -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 = "\u00B7";
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, isIntegrity } from '@vltpkg/types';
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
- const r = integrity && resolved ?
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 trustIntegrity = this.#trustedIntegrities.get(r.resolved) === r.integrity;
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
- // if it's not trusted already, but valid, start trusting
113
- if (!trustIntegrity &&
114
- response.checkIntegrity({ spec, url: resolved })) {
115
- this.#trustedIntegrities.set(r.resolved, response.integrity);
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(response.buffer(), target);
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 trustIntegrity = this.#trustedIntegrities.get(tarball) === integrity;
251
- const response = await this.registryClient.request(tarball, {
252
- ...options,
253
- integrity,
254
- trustIntegrity,
255
- });
256
- if (response.statusCode !== 200) {
257
- throw this.#resolveError(spec, options, 'failed to fetch tarball', { response, url: tarball });
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
- // if we don't already trust it, but it's valid, start trusting it
260
- if (!trustIntegrity &&
261
- response.checkIntegrity({ spec, url: tarball })) {
262
- this.#trustedIntegrities.set(tarball, response.integrity);
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 this.packageJson.read(dir);
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
@@ -1,3 +1,2 @@
1
1
  import { rename as fsRename } from 'node:fs/promises';
2
2
  export declare const rename: typeof fsRename;
3
- //# sourceMappingURL=rename.d.ts.map
@@ -29,4 +29,3 @@ export const rename = platform !== 'win32' ? fsRename : (async function (oldPath
29
29
  };
30
30
  return fsRename(oldPath, newPath).then(() => { }, retry);
31
31
  });
32
- //# sourceMappingURL=rename.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.3",
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": "vlt technology inc. <support@vlt.sh> (http://vlt.sh)",
11
- "tshy": {
12
- "selfLink": false,
13
- "liveDev": true,
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
- "tar": "^7.4.3",
24
- "@vltpkg/error-cause": "1.0.0-rc.3",
25
- "@vltpkg/git": "1.0.0-rc.3",
26
- "@vltpkg/package-json": "1.0.0-rc.3",
27
- "@vltpkg/pick-manifest": "1.0.0-rc.3",
28
- "@vltpkg/registry-client": "1.0.0-rc.3",
29
- "@vltpkg/spec": "1.0.0-rc.3",
30
- "@vltpkg/tar": "1.0.0-rc.3",
31
- "@vltpkg/xdg": "1.0.0-rc.3",
32
- "@vltpkg/workspaces": "1.0.0-rc.3",
33
- "@vltpkg/types": "1.0.0-rc.3"
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.34.0",
37
- "@types/node": "^22.17.2",
30
+ "@eslint/js": "^9.39.1",
31
+ "@types/node": "^22.19.2",
38
32
  "@types/pacote": "^11.1.8",
39
- "eslint": "^9.34.0",
40
- "pacote": "^21.0.0",
41
- "prettier": "^3.6.2",
42
- "tap": "^21.1.0",
43
- "tshy": "^3.0.2",
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.40.0",
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/esm/index.js",
64
+ "module": "./dist/index.js",
60
65
  "type": "module",
61
66
  "exports": {
62
67
  "./package.json": "./package.json",
63
68
  ".": {
64
69
  "import": {
65
- "types": "./dist/esm/index.d.ts",
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
- "scripts": {
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
+ }
@@ -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"}
@@ -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"]}
@@ -1,3 +0,0 @@
1
- {
2
- "type": "module"
3
- }
@@ -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"}
@@ -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"]}