@socketsecurity/lib 6.0.3 → 6.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (542) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/dist/_virtual/_rolldown/runtime.js +45 -0
  3. package/dist/abort/signal.js +53 -59
  4. package/dist/ai/discover.js +110 -110
  5. package/dist/ai/profiles.js +94 -65
  6. package/dist/ai/spawn.js +172 -194
  7. package/dist/ai/types.js +1 -17
  8. package/dist/ai/worktree.js +160 -183
  9. package/dist/ansi/constants.js +16 -38
  10. package/dist/ansi/strip.js +44 -41
  11. package/dist/archives/_internal.js +64 -73
  12. package/dist/archives/detect.js +30 -43
  13. package/dist/archives/extract.js +43 -50
  14. package/dist/archives/tar.js +197 -228
  15. package/dist/archives/types.js +1 -17
  16. package/dist/archives/zip.js +85 -121
  17. package/dist/argv/flag-predicates.js +203 -101
  18. package/dist/argv/flag-types.js +96 -113
  19. package/dist/argv/parse-args-string.d.ts +16 -14
  20. package/dist/argv/parse-args-string.js +42 -39
  21. package/dist/argv/parse.js +145 -163
  22. package/dist/arrays/_internal.js +65 -48
  23. package/dist/arrays/chunk.js +51 -40
  24. package/dist/arrays/join.js +87 -35
  25. package/dist/arrays/predicates.js +46 -28
  26. package/dist/arrays/unique.js +45 -31
  27. package/dist/bin/_internal.js +34 -42
  28. package/dist/bin/check-primordials.js +175 -233
  29. package/dist/bin/check.js +51 -72
  30. package/dist/bin/exec.js +70 -74
  31. package/dist/bin/find.js +151 -134
  32. package/dist/bin/resolve.js +180 -246
  33. package/dist/bin/shadow.js +24 -33
  34. package/dist/bin/socket-lib.js +51 -73
  35. package/dist/bin/types.js +1 -17
  36. package/dist/bin/which.js +211 -146
  37. package/dist/cacache/_internal.js +25 -40
  38. package/dist/cacache/clear.js +79 -72
  39. package/dist/cacache/read.js +48 -46
  40. package/dist/cacache/tmp.js +29 -36
  41. package/dist/cacache/types.js +1 -17
  42. package/dist/cacache/write.js +43 -48
  43. package/dist/cache/ttl/store.js +232 -288
  44. package/dist/cache/ttl/types.js +1 -17
  45. package/dist/checks/primordials-defaults.js +83 -89
  46. package/dist/checks/primordials.js +225 -277
  47. package/dist/colors/convert.js +45 -37
  48. package/dist/colors/palette.js +88 -45
  49. package/dist/colors/socket-palette.js +74 -84
  50. package/dist/colors/types.js +1 -17
  51. package/dist/compression/_internal.js +57 -72
  52. package/dist/compression/brotli.js +94 -127
  53. package/dist/compression/gzip.js +95 -121
  54. package/dist/compression/types.js +1 -17
  55. package/dist/constants/agents.js +61 -113
  56. package/dist/constants/encoding.js +19 -42
  57. package/dist/constants/github.js +12 -30
  58. package/dist/constants/licenses.js +48 -63
  59. package/dist/constants/lifecycle-script-names.js +31 -45
  60. package/dist/constants/maintained-node-versions.js +22 -37
  61. package/dist/constants/node.js +226 -167
  62. package/dist/constants/package-default-node-range.js +16 -41
  63. package/dist/constants/package-default-socket-categories.js +12 -30
  64. package/dist/constants/packages.js +77 -126
  65. package/dist/constants/platform.js +27 -49
  66. package/dist/constants/sentinels.js +23 -48
  67. package/dist/constants/socket.js +42 -87
  68. package/dist/constants/testing.js +15 -34
  69. package/dist/constants/time.js +16 -36
  70. package/dist/constants/typescript.js +32 -52
  71. package/dist/cover/code.js +111 -142
  72. package/dist/cover/formatters.js +118 -101
  73. package/dist/cover/type.js +50 -76
  74. package/dist/cover/types.js +1 -17
  75. package/dist/crypto/hash.js +54 -46
  76. package/dist/debug/_internal.js +62 -71
  77. package/dist/debug/caller-info.js +53 -64
  78. package/dist/debug/namespace.js +80 -90
  79. package/dist/debug/output.js +172 -188
  80. package/dist/debug/types.js +1 -17
  81. package/dist/dlx/_internal.js +24 -43
  82. package/dist/dlx/arborist.js +162 -160
  83. package/dist/dlx/binary-cache.js +228 -200
  84. package/dist/dlx/binary-download.js +172 -211
  85. package/dist/dlx/binary-resolution.js +165 -157
  86. package/dist/dlx/binary-types.js +1 -17
  87. package/dist/dlx/binary.js +149 -189
  88. package/dist/dlx/cache.js +45 -30
  89. package/dist/dlx/detect.js +245 -159
  90. package/dist/dlx/dir.js +67 -51
  91. package/dist/dlx/firewall.js +62 -100
  92. package/dist/dlx/lockfile.js +122 -127
  93. package/dist/dlx/manifest.js +264 -274
  94. package/dist/dlx/package.js +241 -244
  95. package/dist/dlx/packages.js +99 -96
  96. package/dist/dlx/paths.js +73 -59
  97. package/dist/dlx/spec.js +52 -60
  98. package/dist/dlx/types.js +1 -17
  99. package/dist/eco/cargo/lockfile-format.js +19 -36
  100. package/dist/eco/cargo/manifest-format.js +17 -35
  101. package/dist/eco/cargo/parse-lockfile.js +210 -237
  102. package/dist/eco/manifest/analyze-lockfile.js +46 -63
  103. package/dist/eco/manifest/detect-format.js +66 -90
  104. package/dist/eco/manifest/find-packages.js +39 -64
  105. package/dist/eco/manifest/get-package-versions.js +27 -48
  106. package/dist/eco/manifest/get-package.js +21 -40
  107. package/dist/eco/manifest/manifest-error.js +14 -35
  108. package/dist/eco/manifest/parse-lockfile.js +40 -86
  109. package/dist/eco/manifest/parse-manifest.js +26 -43
  110. package/dist/eco/manifest/parse.js +26 -47
  111. package/dist/eco/manifest/types.js +1 -17
  112. package/dist/eco/npm/bun/exec.js +23 -32
  113. package/dist/eco/npm/manifest-format.js +21 -35
  114. package/dist/eco/npm/npm/exec.js +51 -61
  115. package/dist/eco/npm/npm/extract-package-name-from-path.js +28 -50
  116. package/dist/eco/npm/npm/flags.js +80 -52
  117. package/dist/eco/npm/npm/lockfile-format.js +21 -40
  118. package/dist/eco/npm/npm/parse-git-url.js +26 -40
  119. package/dist/eco/npm/npm/parse-lockfile.js +184 -210
  120. package/dist/eco/npm/parse-package-json.js +71 -102
  121. package/dist/eco/npm/pnpm/detect-pnpm-version.js +22 -43
  122. package/dist/eco/npm/pnpm/exec.js +51 -62
  123. package/dist/eco/npm/pnpm/flags.js +75 -68
  124. package/dist/eco/npm/pnpm/lockfile-format.js +19 -36
  125. package/dist/eco/npm/pnpm/parse-lockfile.js +235 -259
  126. package/dist/eco/npm/pnpm/parse-pnpm-package-id-v5.js +37 -47
  127. package/dist/eco/npm/pnpm/parse-pnpm-package-id-v6-v9.js +36 -49
  128. package/dist/eco/npm/script.js +82 -90
  129. package/dist/eco/npm/vlt/exec.js +24 -32
  130. package/dist/eco/npm/yarnpkg/yarn/exec.js +60 -59
  131. package/dist/eco/npm/yarnpkg/yarn/lockfile-format.js +20 -36
  132. package/dist/eco/npm/yarnpkg/yarn/parse-lockfile.js +194 -242
  133. package/dist/eco/npm/yarnpkg/yarn/parse-yarn-descriptor.js +37 -61
  134. package/dist/eco/purl.js +50 -60
  135. package/dist/eco/types.js +1 -17
  136. package/dist/effects/pulse-frames.js +64 -65
  137. package/dist/effects/shimmer-keyframes.js +71 -52
  138. package/dist/effects/shimmer-terminal.js +81 -50
  139. package/dist/effects/shimmer.js +290 -153
  140. package/dist/env/boolean.js +42 -43
  141. package/dist/env/case-insensitive.js +54 -39
  142. package/dist/env/ci.js +29 -31
  143. package/dist/env/debug.js +28 -31
  144. package/dist/env/github.js +144 -59
  145. package/dist/env/home.js +38 -31
  146. package/dist/env/locale.js +59 -39
  147. package/dist/env/node-auth-token.js +28 -31
  148. package/dist/env/node-env.js +28 -31
  149. package/dist/env/npm.js +94 -47
  150. package/dist/env/number.js +50 -51
  151. package/dist/env/package-manager.js +95 -83
  152. package/dist/env/path.js +28 -31
  153. package/dist/env/pre-commit.js +30 -32
  154. package/dist/env/proxy.js +121 -122
  155. package/dist/env/rewire.js +204 -96
  156. package/dist/env/shell.js +28 -31
  157. package/dist/env/socket-cli.js +233 -81
  158. package/dist/env/socket.js +521 -156
  159. package/dist/env/string.js +43 -44
  160. package/dist/env/temp-dir.js +59 -39
  161. package/dist/env/term.js +28 -31
  162. package/dist/env/test.js +65 -43
  163. package/dist/env/types.js +1 -17
  164. package/dist/env/windows.js +78 -43
  165. package/dist/env/xdg.js +62 -39
  166. package/dist/errors/message.js +40 -46
  167. package/dist/errors/predicates.js +61 -49
  168. package/dist/errors/stack.js +24 -36
  169. package/dist/events/exit/_internal.js +86 -103
  170. package/dist/events/exit/handler.js +48 -55
  171. package/dist/events/exit/intercept.js +49 -70
  172. package/dist/events/exit/lifecycle.js +92 -101
  173. package/dist/events/exit/signals.js +25 -31
  174. package/dist/events/exit/types.js +1 -17
  175. package/dist/events/warning/handler.js +43 -40
  176. package/dist/events/warning/suppress.js +111 -90
  177. package/dist/external/@npmcli/package-json/lib/read-package.js +132 -153
  178. package/dist/external/@npmcli/package-json/lib/sort.js +73 -105
  179. package/dist/external/@npmcli/package-json.js +12705 -15140
  180. package/dist/external/@npmcli/promise-spawn.js +451 -472
  181. package/dist/external/@sinclair/typebox/value.js +7443 -9002
  182. package/dist/external/@sinclair/typebox.js +7516 -7885
  183. package/dist/external/@socketregistry/is-unicode-supported.js +31 -39
  184. package/dist/external/@socketregistry/packageurl-js.js +6127 -7369
  185. package/dist/external/@socketregistry/yocto-spinner.js +394 -455
  186. package/dist/external/@yarnpkg/extensions.js +435 -1022
  187. package/dist/external/adm-zip.js +2313 -2673
  188. package/dist/external/debug.js +700 -687
  189. package/dist/external/external-pack.js +2658 -3171
  190. package/dist/external/fast-sort.js +124 -138
  191. package/dist/external/get-east-asian-width.js +70 -64
  192. package/dist/external/libnpmexec.js +28 -31
  193. package/dist/external/npm-pack.js +43617 -50137
  194. package/dist/external/p-map.js +198 -222
  195. package/dist/external/pico-pack.js +6735 -7304
  196. package/dist/external/pony-cause.js +143 -139
  197. package/dist/external/shell-quote.js +226 -0
  198. package/dist/external/spdx-pack.js +1283 -1403
  199. package/dist/external/streaming-iterables.js +835 -1052
  200. package/dist/external/tar-fs.js +2769 -3048
  201. package/dist/external/which.js +267 -251
  202. package/dist/external/yargs-parser.js +851 -1074
  203. package/dist/external-tools/bazel/asset-names.js +98 -90
  204. package/dist/external-tools/bazel/from-download.js +52 -46
  205. package/dist/external-tools/bazel/from-path.js +27 -38
  206. package/dist/external-tools/bazel/read-bazel-version-file.js +35 -57
  207. package/dist/external-tools/bazel/resolve-asset-url.js +24 -39
  208. package/dist/external-tools/bazel/resolve-bazel-version.js +34 -56
  209. package/dist/external-tools/bazel/resolve.js +44 -58
  210. package/dist/external-tools/bazel/types.js +1 -17
  211. package/dist/external-tools/cdxgen/asset-names.js +59 -66
  212. package/dist/external-tools/cdxgen/from-download.js +52 -80
  213. package/dist/external-tools/cdxgen/from-path.js +19 -37
  214. package/dist/external-tools/cdxgen/from-vfs.js +22 -43
  215. package/dist/external-tools/cdxgen/resolve.js +48 -63
  216. package/dist/external-tools/cdxgen/types.js +1 -17
  217. package/dist/external-tools/from-download.js +107 -67
  218. package/dist/external-tools/janus/asset-names.js +44 -51
  219. package/dist/external-tools/janus/from-download.js +45 -70
  220. package/dist/external-tools/janus/from-path.js +19 -37
  221. package/dist/external-tools/janus/from-vfs.js +22 -43
  222. package/dist/external-tools/janus/resolve.js +45 -63
  223. package/dist/external-tools/janus/types.js +1 -17
  224. package/dist/external-tools/jre/asset-names.js +109 -82
  225. package/dist/external-tools/jre/detect-platform-arch.js +25 -49
  226. package/dist/external-tools/jre/from-download.js +71 -67
  227. package/dist/external-tools/jre/from-java-home.js +27 -54
  228. package/dist/external-tools/jre/from-path.js +27 -49
  229. package/dist/external-tools/jre/from-vfs.js +39 -60
  230. package/dist/external-tools/jre/resolve.js +55 -68
  231. package/dist/external-tools/jre/types.js +1 -17
  232. package/dist/external-tools/manifest.js +130 -150
  233. package/dist/external-tools/opengrep/asset-names.js +60 -72
  234. package/dist/external-tools/opengrep/from-download.js +58 -80
  235. package/dist/external-tools/opengrep/from-path.js +19 -37
  236. package/dist/external-tools/opengrep/from-vfs.js +23 -43
  237. package/dist/external-tools/opengrep/resolve.js +43 -63
  238. package/dist/external-tools/opengrep/types.js +1 -17
  239. package/dist/external-tools/sbt/asset-names.js +21 -30
  240. package/dist/external-tools/sbt/from-download.js +50 -61
  241. package/dist/external-tools/sbt/from-path.js +23 -38
  242. package/dist/external-tools/sbt/from-vfs.js +30 -44
  243. package/dist/external-tools/sbt/resolve.js +45 -63
  244. package/dist/external-tools/sbt/types.js +1 -17
  245. package/dist/external-tools/synp/asset-names.js +11 -29
  246. package/dist/external-tools/synp/from-download.js +24 -41
  247. package/dist/external-tools/synp/from-path.js +19 -37
  248. package/dist/external-tools/synp/from-vfs.js +22 -43
  249. package/dist/external-tools/synp/resolve.js +43 -62
  250. package/dist/external-tools/synp/types.js +1 -17
  251. package/dist/external-tools/trivy/asset-names.js +51 -62
  252. package/dist/external-tools/trivy/from-download.js +42 -64
  253. package/dist/external-tools/trivy/from-path.js +19 -37
  254. package/dist/external-tools/trivy/from-vfs.js +22 -43
  255. package/dist/external-tools/trivy/resolve.js +43 -63
  256. package/dist/external-tools/trivy/types.js +1 -17
  257. package/dist/external-tools/trufflehog/asset-names.js +54 -66
  258. package/dist/external-tools/trufflehog/from-download.js +44 -62
  259. package/dist/external-tools/trufflehog/from-path.js +21 -37
  260. package/dist/external-tools/trufflehog/from-vfs.js +26 -43
  261. package/dist/external-tools/trufflehog/resolve.js +43 -63
  262. package/dist/external-tools/trufflehog/types.js +1 -17
  263. package/dist/external-tools/uv/asset-names.js +64 -74
  264. package/dist/external-tools/uv/from-download.js +44 -65
  265. package/dist/external-tools/uv/from-path.js +19 -37
  266. package/dist/external-tools/uv/from-vfs.js +22 -43
  267. package/dist/external-tools/uv/resolve.js +42 -63
  268. package/dist/external-tools/uv/types.js +1 -17
  269. package/dist/fs/_internal.js +40 -42
  270. package/dist/fs/access.js +57 -54
  271. package/dist/fs/encoding.js +80 -97
  272. package/dist/fs/find-up.js +126 -125
  273. package/dist/fs/inspect.js +168 -99
  274. package/dist/fs/path-cache.js +31 -32
  275. package/dist/fs/read-dir.js +102 -79
  276. package/dist/fs/read-file.js +177 -118
  277. package/dist/fs/read-json-cache.js +150 -134
  278. package/dist/fs/read-json.js +172 -187
  279. package/dist/fs/resolve-module.js +35 -58
  280. package/dist/fs/safe.js +278 -169
  281. package/dist/fs/types.js +1 -17
  282. package/dist/fs/unique.js +52 -48
  283. package/dist/fs/validate.js +56 -40
  284. package/dist/fs/write-json.js +109 -75
  285. package/dist/git/_internal.js +251 -216
  286. package/dist/git/changed.js +191 -74
  287. package/dist/git/repo.js +118 -104
  288. package/dist/git/staged.js +172 -62
  289. package/dist/git/types.js +1 -17
  290. package/dist/git/unstaged.js +175 -62
  291. package/dist/github/constants.js +25 -33
  292. package/dist/github/errors.js +46 -38
  293. package/dist/github/fetch.js +137 -82
  294. package/dist/github/ghsa.js +217 -151
  295. package/dist/github/refs-cache.js +54 -43
  296. package/dist/github/refs-graphql.js +97 -89
  297. package/dist/github/refs-rest.js +70 -101
  298. package/dist/github/refs.js +105 -64
  299. package/dist/github/token.js +96 -48
  300. package/dist/github/types.js +1 -17
  301. package/dist/globs/_internal.js +73 -82
  302. package/dist/globs/defaults.js +40 -59
  303. package/dist/globs/match.js +93 -77
  304. package/dist/globs/matcher.js +104 -92
  305. package/dist/globs/stream.js +43 -55
  306. package/dist/globs/types.js +1 -17
  307. package/dist/http-request/_internal.js +11 -38
  308. package/dist/http-request/browser-fetch.js +19 -29
  309. package/dist/http-request/browser.js +188 -206
  310. package/dist/http-request/checksums.js +101 -65
  311. package/dist/http-request/download-types.js +1 -17
  312. package/dist/http-request/download.js +195 -196
  313. package/dist/http-request/errors.js +39 -47
  314. package/dist/http-request/headers.js +95 -80
  315. package/dist/http-request/http-request.js +10 -35
  316. package/dist/http-request/node.js +71 -97
  317. package/dist/http-request/request-attempt.js +232 -285
  318. package/dist/http-request/request-types.js +1 -17
  319. package/dist/http-request/request.js +106 -108
  320. package/dist/http-request/response-reader.js +47 -51
  321. package/dist/http-request/response-types.js +22 -38
  322. package/dist/http-request/user-agent.js +73 -55
  323. package/dist/integrity.js +105 -106
  324. package/dist/ipc/_internal.js +34 -48
  325. package/dist/ipc/directory.js +55 -63
  326. package/dist/ipc/paths.js +52 -45
  327. package/dist/ipc/types.js +1 -17
  328. package/dist/ipc/write.js +81 -74
  329. package/dist/ipc-cli/get.js +29 -56
  330. package/dist/ipc-cli/types.js +1 -17
  331. package/dist/json/edit.js +182 -242
  332. package/dist/json/format.js +202 -103
  333. package/dist/json/parse.js +206 -109
  334. package/dist/json/types.js +1 -17
  335. package/dist/links/create.js +93 -60
  336. package/dist/links/types.js +1 -17
  337. package/dist/logger/_internal.js +109 -73
  338. package/dist/logger/browser.js +45 -56
  339. package/dist/logger/colors.js +31 -49
  340. package/dist/logger/console.js +89 -112
  341. package/dist/logger/default.js +19 -33
  342. package/dist/logger/logger.js +5 -29
  343. package/dist/logger/node.js +794 -854
  344. package/dist/logger/symbols-builder.js +54 -56
  345. package/dist/logger/symbols.js +135 -118
  346. package/dist/logger/types.js +1 -17
  347. package/dist/memo/_internal.js +39 -49
  348. package/dist/memo/async.js +133 -117
  349. package/dist/memo/clear.js +25 -34
  350. package/dist/memo/decorator.js +43 -37
  351. package/dist/memo/memoize.js +97 -88
  352. package/dist/memo/once.js +42 -41
  353. package/dist/memo/types.js +1 -17
  354. package/dist/memo/weak.js +45 -41
  355. package/dist/node/async-hooks.js +9 -30
  356. package/dist/node/child-process.js +9 -30
  357. package/dist/node/crypto.js +9 -30
  358. package/dist/node/events.js +9 -30
  359. package/dist/node/fs-promises.js +9 -30
  360. package/dist/node/fs.js +9 -30
  361. package/dist/node/http.js +9 -30
  362. package/dist/node/https.js +9 -30
  363. package/dist/node/module.js +20 -34
  364. package/dist/node/os.js +9 -30
  365. package/dist/node/path.js +9 -30
  366. package/dist/node/timers-promises.js +9 -30
  367. package/dist/node/url.js +9 -30
  368. package/dist/node/util.js +9 -30
  369. package/dist/objects/getters.js +185 -126
  370. package/dist/objects/inspect.js +85 -52
  371. package/dist/objects/mutate.js +96 -76
  372. package/dist/objects/predicates.js +112 -59
  373. package/dist/objects/sort.js +120 -76
  374. package/dist/objects/types.js +1 -17
  375. package/dist/packages/edit-class.js +198 -265
  376. package/dist/packages/edit.js +79 -86
  377. package/dist/packages/exports.js +146 -157
  378. package/dist/packages/isolation.js +159 -209
  379. package/dist/packages/licenses.js +207 -189
  380. package/dist/packages/manifest.js +134 -172
  381. package/dist/packages/normalize.js +91 -102
  382. package/dist/packages/operations.d.ts +2 -0
  383. package/dist/packages/operations.js +283 -254
  384. package/dist/packages/provenance.js +195 -245
  385. package/dist/packages/specs.js +94 -84
  386. package/dist/packages/types.js +1 -17
  387. package/dist/packages/validation.js +49 -50
  388. package/dist/paths/_internal.js +82 -86
  389. package/dist/paths/conversion.js +112 -65
  390. package/dist/paths/dirnames.js +17 -42
  391. package/dist/paths/exts.js +23 -54
  392. package/dist/paths/filenames.js +21 -50
  393. package/dist/paths/globs.js +15 -38
  394. package/dist/paths/normalize.js +215 -236
  395. package/dist/paths/packages.js +34 -49
  396. package/dist/paths/predicates.js +184 -106
  397. package/dist/paths/resolve.js +146 -128
  398. package/dist/paths/rewire.js +108 -72
  399. package/dist/paths/socket.js +252 -132
  400. package/dist/paths/walk.js +55 -60
  401. package/dist/perf/_internal.js +10 -28
  402. package/dist/perf/enabled.js +21 -30
  403. package/dist/perf/metrics.js +81 -67
  404. package/dist/perf/report.js +79 -80
  405. package/dist/perf/timer.js +180 -126
  406. package/dist/perf/types.js +1 -17
  407. package/dist/pkg-ext/data.js +29 -82
  408. package/dist/pkg-ext/types.js +1 -17
  409. package/dist/primordials/array.js +120 -198
  410. package/dist/primordials/buffer.js +28 -51
  411. package/dist/primordials/date.js +26 -51
  412. package/dist/primordials/error.js +33 -59
  413. package/dist/primordials/function.js +21 -41
  414. package/dist/primordials/globals.js +25 -48
  415. package/dist/primordials/json.js +14 -30
  416. package/dist/primordials/map-set.js +88 -152
  417. package/dist/primordials/math.js +59 -116
  418. package/dist/primordials/number.js +41 -76
  419. package/dist/primordials/object.js +56 -116
  420. package/dist/primordials/promise.js +28 -52
  421. package/dist/primordials/reflect.js +24 -52
  422. package/dist/primordials/regexp.js +25 -47
  423. package/dist/primordials/string.js +114 -167
  424. package/dist/primordials/symbol.js +40 -72
  425. package/dist/primordials/uncurry.js +38 -55
  426. package/dist/primordials/url.js +27 -66
  427. package/dist/process/_internal.js +7 -32
  428. package/dist/process/abort.js +29 -35
  429. package/dist/process/lock-instance.js +26 -30
  430. package/dist/process/lock-manager.js +279 -307
  431. package/dist/process/lock-types.js +1 -17
  432. package/dist/process/spawn/_internal.js +43 -55
  433. package/dist/process/spawn/child.js +172 -211
  434. package/dist/process/spawn/errors.js +116 -113
  435. package/dist/process/spawn/stdio.js +51 -35
  436. package/dist/process/spawn/types.js +1 -17
  437. package/dist/process/transient.js +49 -66
  438. package/dist/promises/_internal.js +31 -34
  439. package/dist/promises/iterate.js +238 -102
  440. package/dist/promises/options.js +123 -101
  441. package/dist/promises/queue.js +115 -136
  442. package/dist/promises/resolvers.js +77 -46
  443. package/dist/promises/retry.js +156 -101
  444. package/dist/promises/types.js +1 -17
  445. package/dist/regexps/escape.js +32 -30
  446. package/dist/regexps/hex.js +16 -33
  447. package/dist/regexps/spec.js +53 -81
  448. package/dist/releases/github-archives.js +127 -118
  449. package/dist/releases/github-asset-url.js +162 -146
  450. package/dist/releases/github-assets.js +37 -49
  451. package/dist/releases/github-auth.js +32 -48
  452. package/dist/releases/github-downloads.js +118 -138
  453. package/dist/releases/github-listing.js +175 -145
  454. package/dist/releases/github-retry-config.js +41 -47
  455. package/dist/releases/github-types.js +1 -17
  456. package/dist/releases/socket-btm.js +273 -192
  457. package/dist/schema/parse.js +35 -36
  458. package/dist/schema/types.js +1 -17
  459. package/dist/schema/validate.js +118 -99
  460. package/dist/sea/detect.js +57 -52
  461. package/dist/secrets/_internal.js +86 -67
  462. package/dist/secrets/find.js +96 -77
  463. package/dist/secrets/keychain.js +315 -309
  464. package/dist/secrets/linux.js +133 -135
  465. package/dist/secrets/macos.js +151 -147
  466. package/dist/secrets/rc.js +182 -181
  467. package/dist/secrets/socket-api-token.js +28 -43
  468. package/dist/secrets/types.js +1 -17
  469. package/dist/secrets/windows.js +184 -242
  470. package/dist/shadow/skip.js +51 -70
  471. package/dist/shadow/types.js +1 -17
  472. package/dist/shell/parse.d.ts +26 -0
  473. package/dist/shell/parse.js +35 -0
  474. package/dist/shell/quote.d.ts +19 -0
  475. package/dist/shell/quote.js +30 -0
  476. package/dist/smol/detect.js +67 -43
  477. package/dist/smol/http.js +33 -37
  478. package/dist/smol/https.js +31 -37
  479. package/dist/smol/manifest.js +33 -37
  480. package/dist/smol/path.js +33 -37
  481. package/dist/smol/primordial.js +35 -37
  482. package/dist/smol/purl.js +34 -37
  483. package/dist/smol/versions.js +31 -37
  484. package/dist/smol/vfs.js +46 -38
  485. package/dist/sorts/_internal.js +14 -40
  486. package/dist/sorts/natural.js +57 -64
  487. package/dist/sorts/semver.js +33 -43
  488. package/dist/sorts/strings.js +24 -30
  489. package/dist/sorts/types.js +1 -17
  490. package/dist/spinner/default.js +72 -63
  491. package/dist/spinner/format.js +86 -71
  492. package/dist/spinner/spinner.js +749 -797
  493. package/dist/spinner/types.js +1 -17
  494. package/dist/spinner/with.js +193 -137
  495. package/dist/ssri/convert.js +64 -47
  496. package/dist/ssri/parse.js +38 -37
  497. package/dist/ssri/validate.js +51 -34
  498. package/dist/stdio/_internal.js +50 -46
  499. package/dist/stdio/clear.js +208 -86
  500. package/dist/stdio/divider.js +170 -97
  501. package/dist/stdio/footer.js +116 -110
  502. package/dist/stdio/header.js +117 -90
  503. package/dist/stdio/progress.js +189 -218
  504. package/dist/stdio/prompts.js +244 -168
  505. package/dist/stdio/stderr.js +173 -78
  506. package/dist/stdio/stdout.js +177 -94
  507. package/dist/streams/parallel.js +58 -50
  508. package/dist/streams/transform.js +36 -45
  509. package/dist/strings/format.js +145 -63
  510. package/dist/strings/predicates.js +56 -34
  511. package/dist/strings/search.js +52 -42
  512. package/dist/strings/transform.js +113 -72
  513. package/dist/strings/types.js +1 -17
  514. package/dist/strings/width.js +89 -82
  515. package/dist/tables/bordered.js +81 -81
  516. package/dist/tables/padding.js +36 -46
  517. package/dist/tables/simple.js +62 -70
  518. package/dist/tables/types.js +1 -17
  519. package/dist/temporal/instant.js +72 -81
  520. package/dist/temporal/now.js +40 -31
  521. package/dist/temporal/slots.js +42 -36
  522. package/dist/temporal/system.js +36 -36
  523. package/dist/temporal/temporal.js +11 -41
  524. package/dist/themes/context.js +131 -69
  525. package/dist/themes/resolve.js +207 -132
  526. package/dist/themes/themes.js +225 -194
  527. package/dist/themes/types.js +1 -17
  528. package/dist/url/parse.js +48 -51
  529. package/dist/url/predicates.js +24 -31
  530. package/dist/url/search-params.js +133 -101
  531. package/dist/url/types.js +1 -17
  532. package/dist/versions/_internal.js +31 -33
  533. package/dist/versions/compare.js +80 -58
  534. package/dist/versions/modify.js +41 -39
  535. package/dist/versions/parse.js +88 -64
  536. package/dist/versions/range.js +58 -41
  537. package/dist/versions/types.js +1 -17
  538. package/dist/words/article.js +22 -30
  539. package/dist/words/capitalize.js +25 -34
  540. package/dist/words/pluralize.js +23 -31
  541. package/dist/words/types.js +1 -17
  542. package/package.json +17 -5
@@ -1,274 +1,250 @@
1
1
  "use strict";
2
- /* Socket Lib - Built with esbuild */
3
- "use strict";
4
- var __defProp = Object.defineProperty;
5
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
- var __getOwnPropNames = Object.getOwnPropertyNames;
7
- var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __export = (target, all) => {
9
- for (var name in all)
10
- __defProp(target, name, { get: all[name], enumerable: true });
11
- };
12
- var __copyProps = (to, from, except, desc) => {
13
- if (from && typeof from === "object" || typeof from === "function") {
14
- for (let key of __getOwnPropNames(from))
15
- if (!__hasOwnProp.call(to, key) && key !== except)
16
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
- }
18
- return to;
19
- };
20
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
21
- var parse_lockfile_exports = {};
22
- __export(parse_lockfile_exports, {
23
- addToPnpmIndex: () => addToPnpmIndex,
24
- freezeEntry: () => freezeEntry,
25
- indentOf: () => indentOf,
26
- jsParsePnpmLock: () => jsParsePnpmLock,
27
- newPnpmEntry: () => newPnpmEntry,
28
- parsePnpmLock: () => parsePnpmLock,
29
- stripPeerSuffix: () => stripPeerSuffix
30
- });
31
- module.exports = __toCommonJS(parse_lockfile_exports);
32
- var import_array = require("../../../primordials/array");
33
- var import_object = require("../../../primordials/object");
34
- var import_regexp = require("../../../primordials/regexp");
35
- var import_string = require("../../../primordials/string");
36
- var import_manifest = require("../../../smol/manifest");
37
- var import_detect_pnpm_version = require("./detect-pnpm-version");
38
- var import_parse_pnpm_package_id_v5 = require("./parse-pnpm-package-id-v5");
39
- var import_parse_pnpm_package_id_v6_v9 = require("./parse-pnpm-package-id-v6-v9");
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+ const require_primordials_string = require('../../../primordials/string.js');
5
+ const require_primordials_regexp = require('../../../primordials/regexp.js');
6
+ const require_primordials_array = require('../../../primordials/array.js');
7
+ const require_primordials_object = require('../../../primordials/object.js');
8
+ const require_smol_manifest = require('../../../smol/manifest.js');
9
+ const require_eco_npm_pnpm_detect_pnpm_version = require('./detect-pnpm-version.js');
10
+ const require_eco_npm_pnpm_parse_pnpm_package_id_v5 = require('./parse-pnpm-package-id-v5.js');
11
+ const require_eco_npm_pnpm_parse_pnpm_package_id_v6_v9 = require('./parse-pnpm-package-id-v6-v9.js');
12
+
13
+ //#region src/eco/npm/pnpm/parse-lockfile.ts
14
+ /**
15
+ * @file `parsePnpmLock(content)` — parses a `pnpm-lock.yaml` (v5, v6, or v9)
16
+ * into a `ParsedLockfile`. On socket-btm's smol Node binary this routes to
17
+ * `node:smol-manifest`'s native `parseLockfile(content, 'npm', 'pnpm')`; on
18
+ * stock Node it runs the line-scanning JS impl below. The parser supports
19
+ * three top-level sections:
20
+ *
21
+ * - `packages:` pnpm v5/v6 main package entries
22
+ * - `snapshots:` — pnpm v9 main package entries
23
+ * - `importers:` — workspace/monorepo dependency declarations (extracted as
24
+ * ad-hoc package entries so SBOM tooling sees the workspace's own deps even
25
+ * when no `packages:` block lists them) Forgiving by design — unknown keys
26
+ * ignored, missing versions default to `0.0.0`. Never throws. Source
27
+ * material (in lock-step order, newest → oldest):
28
+ *
29
+ * 1. **C++ native parser** in socket-btm/node-smol-builder:
30
+ * additions/source-patched/src/socketsecurity/manifest/parser_pnpm.cc Same
31
+ * algorithm, same fixes — keep the two in lock-step.
32
+ * 2. **socket-sdxgen** algorithm oracle:
33
+ * socket-sdxgen/src/parsers/pnpm/pnpm-lock-v5.mts
34
+ * socket-sdxgen/src/parsers/pnpm/pnpm-lock-v6.mts
35
+ * socket-sdxgen/src/parsers/pnpm/pnpm-lock-v9.mts
36
+ * 3. **cdxgen** (pinned v11.11.0):
37
+ * https://github.com/CycloneDX/cdxgen/blob/v11.11.0/lib/parsers/js.js
38
+ * (parsePnpmLock)
39
+ * 4. **pnpm lockfile spec** + reference implementation:
40
+ * https://github.com/pnpm/spec/blob/master/lockfile/9.0.md
41
+ * https://github.com/pnpm/pnpm/blob/main/packages/lockfile-file/ Bug fixes
42
+ * implemented here (and in the native parser):
43
+ *
44
+ * - Fix 3a Empty-version guard in importer block-shape walk — v9
45
+ * nested-property entries (`pkg:` parent + indented `version:` child) no
46
+ * longer emit a phantom parent PackageRef with `version: ''`.
47
+ * - Fix 3b workspace/file/link protocol filter — importer deps with
48
+ * `workspace:` / `file:` / `link:` values are workspace-local refs, not
49
+ * shippable registry artifacts.
50
+ * - Fix 5 pnpm v9 isDev derivation from importer prod/devOnly sets, post-pass
51
+ * classified. The v9 format dropped per- snapshot `dev: true` markers, so
52
+ * isDev must be derived from importers. Prior impls left every v9 snapshot
53
+ * as `depType: 'prod'`. Regression fixtures live under socket-btm's
54
+ * test/fixtures/ sdxgen-bug-regressions/ — every shipped fix has a matching
55
+ * fixture directory there.
56
+ */
40
57
  const RE_INTEGRITY = /integrity:\s*([a-zA-Z0-9+/=-]+)/;
41
58
  const RE_TARBALL = /tarball:\s*['"]?([^'"}\s]+)['"]?/;
42
59
  function addToPnpmIndex(packageIndex, name, idx) {
43
- const existing = packageIndex[name];
44
- if (existing === void 0) {
45
- packageIndex[name] = idx;
46
- } else if (typeof existing === "number") {
47
- packageIndex[name] = [existing, idx];
48
- } else {
49
- (0, import_array.ArrayPrototypePush)(existing, idx);
50
- }
60
+ const existing = packageIndex[name];
61
+ if (existing === void 0) packageIndex[name] = idx;
62
+ else if (typeof existing === "number") packageIndex[name] = [existing, idx];
63
+ else require_primordials_array.ArrayPrototypePush(existing, idx);
51
64
  }
52
65
  function freezeEntry(entry) {
53
- const { _inDeps, ...rest } = entry;
54
- void _inDeps;
55
- return (0, import_object.ObjectFreeze)({
56
- __proto__: null,
57
- ...rest
58
- });
66
+ const { _inDeps, ...rest } = entry;
67
+ return require_primordials_object.ObjectFreeze({
68
+ __proto__: null,
69
+ ...rest
70
+ });
59
71
  }
60
72
  function indentOf(line) {
61
- let indent = 0;
62
- while (indent < line.length && (line[indent] === " " || line[indent] === " ")) {
63
- indent++;
64
- }
65
- return indent;
73
+ let indent = 0;
74
+ while (indent < line.length && (line[indent] === " " || line[indent] === " ")) indent++;
75
+ return indent;
66
76
  }
67
77
  function jsParsePnpmLock(content) {
68
- const packages = [];
69
- const packageIndex = {
70
- __proto__: null
71
- };
72
- const lockVersion = (0, import_detect_pnpm_version.detectPnpmVersion)(content);
73
- let inPackages = false;
74
- let inSnapshots = false;
75
- let inImporters = false;
76
- let currentPkg;
77
- let currentIndent = 0;
78
- let currentImporter;
79
- let importerIndent = 0;
80
- let pos = 0;
81
- while (pos < content.length) {
82
- const eol = (0, import_string.StringPrototypeIndexOf)(content, "\n", pos);
83
- const end = eol === -1 ? content.length : eol;
84
- const line = (0, import_string.StringPrototypeSlice)(content, pos, end);
85
- pos = end + 1;
86
- const trimmed = (0, import_string.StringPrototypeTrim)(line);
87
- if (trimmed === "packages:") {
88
- inPackages = true;
89
- inSnapshots = false;
90
- inImporters = false;
91
- continue;
92
- }
93
- if (trimmed === "snapshots:") {
94
- inSnapshots = true;
95
- inPackages = false;
96
- inImporters = false;
97
- continue;
98
- }
99
- if (trimmed === "importers:") {
100
- inImporters = true;
101
- inPackages = false;
102
- inSnapshots = false;
103
- continue;
104
- }
105
- if (line[0] !== " " && line[0] !== " " && trimmed.length > 0 && trimmed !== "packages:" && trimmed !== "snapshots:" && trimmed !== "importers:") {
106
- inPackages = false;
107
- inSnapshots = false;
108
- inImporters = false;
109
- continue;
110
- }
111
- if (inImporters) {
112
- const indent2 = indentOf(line);
113
- if (indent2 === 2 && (0, import_string.StringPrototypeEndsWith)(trimmed, ":")) {
114
- currentImporter = { section: void 0 };
115
- importerIndent = indent2;
116
- continue;
117
- }
118
- if (currentImporter && indent2 > importerIndent) {
119
- if ((0, import_string.StringPrototypeIndexOf)(trimmed, "devDependencies:") === 0) {
120
- currentImporter.section = "dev";
121
- } else if ((0, import_string.StringPrototypeIndexOf)(trimmed, "optionalDependencies:") === 0) {
122
- currentImporter.section = "optional";
123
- } else if ((0, import_string.StringPrototypeIndexOf)(trimmed, "dependencies:") === 0) {
124
- currentImporter.section = "prod";
125
- } else if (indent2 > importerIndent + 2) {
126
- if ((0, import_string.StringPrototypeIndexOf)(trimmed, "specifier:") === 0 || (0, import_string.StringPrototypeIndexOf)(trimmed, "version:") === 0 || (0, import_string.StringPrototypeIndexOf)(trimmed, "resolution:") === 0) {
127
- continue;
128
- }
129
- const colonIdx = (0, import_string.StringPrototypeIndexOf)(trimmed, ":");
130
- if (colonIdx > 0) {
131
- const depName = (0, import_string.StringPrototypeSlice)(trimmed, 0, colonIdx);
132
- const depVersion = (0, import_string.StringPrototypeTrim)(
133
- (0, import_string.StringPrototypeSlice)(trimmed, colonIdx + 1)
134
- );
135
- if (depVersion.length === 0 || (0, import_string.StringPrototypeIndexOf)(depVersion, "link:") === 0 || (0, import_string.StringPrototypeIndexOf)(depVersion, "workspace:") === 0 || (0, import_string.StringPrototypeIndexOf)(depVersion, "file:") === 0) {
136
- continue;
137
- }
138
- const versionWithoutPeer = stripPeerSuffix(depVersion);
139
- if (packageIndex[depName] === void 0) {
140
- const section = currentImporter.section;
141
- const ref = (0, import_object.ObjectFreeze)({
142
- __proto__: null,
143
- name: depName,
144
- version: versionWithoutPeer,
145
- resolved: void 0,
146
- integrity: void 0,
147
- ecosystem: "npm",
148
- depType: section === "dev" ? "dev" : section === "optional" ? "optional" : "prod",
149
- isDev: section === "dev",
150
- isOptional: section === "optional",
151
- isPeer: false,
152
- isBundled: false,
153
- vcsUrl: void 0,
154
- vcsCommit: void 0,
155
- dependencies: []
156
- });
157
- (0, import_array.ArrayPrototypePush)(packages, ref);
158
- packageIndex[depName] = packages.length - 1;
159
- }
160
- }
161
- }
162
- }
163
- continue;
164
- }
165
- if (!inPackages && !inSnapshots) {
166
- continue;
167
- }
168
- const indent = indentOf(line);
169
- const isPackageEntry = indent >= 2 && indent <= 4 && (0, import_string.StringPrototypeEndsWith)(trimmed, ":") && trimmed.length > 1 && (currentPkg === void 0 || indent <= currentIndent);
170
- if (isPackageEntry) {
171
- if (currentPkg && currentPkg.name) {
172
- const ref = freezeEntry(currentPkg);
173
- (0, import_array.ArrayPrototypePush)(packages, ref);
174
- addToPnpmIndex(packageIndex, currentPkg.name, packages.length - 1);
175
- }
176
- const key = (0, import_string.StringPrototypeSlice)(trimmed, 0, -1);
177
- const parsed = key[0] === "/" ? (0, import_parse_pnpm_package_id_v5.parsePnpmPackageIdV5)(key) : (0, import_parse_pnpm_package_id_v6_v9.parsePnpmPackageIdV6V9)(key);
178
- currentPkg = newPnpmEntry(parsed.name, parsed.version);
179
- currentIndent = indent;
180
- continue;
181
- }
182
- if (currentPkg && indent > currentIndent) {
183
- if ((0, import_string.StringPrototypeIndexOf)(trimmed, "dev:") === 0) {
184
- if ((0, import_string.StringPrototypeIndexOf)(trimmed, "true") !== -1) {
185
- currentPkg.depType = "dev";
186
- currentPkg.isDev = true;
187
- }
188
- } else if ((0, import_string.StringPrototypeIndexOf)(trimmed, "optional:") === 0) {
189
- if ((0, import_string.StringPrototypeIndexOf)(trimmed, "true") !== -1) {
190
- currentPkg.depType = "optional";
191
- currentPkg.isOptional = true;
192
- }
193
- } else if ((0, import_string.StringPrototypeIndexOf)(trimmed, "integrity:") === 0) {
194
- currentPkg.integrity = (0, import_string.StringPrototypeTrim)(
195
- (0, import_string.StringPrototypeSlice)(trimmed, 10)
196
- );
197
- } else if ((0, import_string.StringPrototypeIndexOf)(trimmed, "resolution:") === 0) {
198
- const intMatch = (0, import_regexp.RegExpPrototypeExec)(RE_INTEGRITY, trimmed);
199
- if (intMatch) {
200
- currentPkg.integrity = intMatch[1];
201
- }
202
- const tarballMatch = (0, import_regexp.RegExpPrototypeExec)(RE_TARBALL, trimmed);
203
- if (tarballMatch) {
204
- currentPkg.resolved = tarballMatch[1];
205
- }
206
- } else if ((0, import_string.StringPrototypeIndexOf)(trimmed, "dependencies:") === 0) {
207
- currentPkg.dependencies = [];
208
- currentPkg._inDeps = true;
209
- } else if (currentPkg._inDeps && ((0, import_string.StringPrototypeIndexOf)(trimmed, "peerDependencies:") === 0 || (0, import_string.StringPrototypeIndexOf)(trimmed, "optionalDependencies:") === 0 || (0, import_string.StringPrototypeIndexOf)(trimmed, "engines:") === 0 || (0, import_string.StringPrototypeIndexOf)(trimmed, "os:") === 0 || (0, import_string.StringPrototypeIndexOf)(trimmed, "cpu:") === 0 || (0, import_string.StringPrototypeIndexOf)(trimmed, "bin:") === 0)) {
210
- currentPkg._inDeps = false;
211
- } else if (currentPkg._inDeps && indent > currentIndent + 2) {
212
- const colonIdx = (0, import_string.StringPrototypeIndexOf)(trimmed, ":");
213
- if (colonIdx > 0) {
214
- (0, import_array.ArrayPrototypePush)(
215
- currentPkg.dependencies,
216
- (0, import_string.StringPrototypeSlice)(trimmed, 0, colonIdx)
217
- );
218
- }
219
- }
220
- }
221
- }
222
- if (currentPkg && currentPkg.name) {
223
- const ref = freezeEntry(currentPkg);
224
- (0, import_array.ArrayPrototypePush)(packages, ref);
225
- addToPnpmIndex(packageIndex, currentPkg.name, packages.length - 1);
226
- }
227
- return (0, import_object.ObjectFreeze)({
228
- __proto__: null,
229
- type: "lockfile",
230
- lockVersion: String(lockVersion),
231
- ecosystem: "npm",
232
- packages: (0, import_object.ObjectFreeze)(packages),
233
- _index: packageIndex
234
- });
78
+ const packages = [];
79
+ const packageIndex = { __proto__: null };
80
+ const lockVersion = require_eco_npm_pnpm_detect_pnpm_version.detectPnpmVersion(content);
81
+ let inPackages = false;
82
+ let inSnapshots = false;
83
+ let inImporters = false;
84
+ let currentPkg;
85
+ let currentIndent = 0;
86
+ let currentImporter;
87
+ let importerIndent = 0;
88
+ let pos = 0;
89
+ while (pos < content.length) {
90
+ const eol = require_primordials_string.StringPrototypeIndexOf(content, "\n", pos);
91
+ const end = eol === -1 ? content.length : eol;
92
+ const line = require_primordials_string.StringPrototypeSlice(content, pos, end);
93
+ pos = end + 1;
94
+ const trimmed = require_primordials_string.StringPrototypeTrim(line);
95
+ if (trimmed === "packages:") {
96
+ inPackages = true;
97
+ inSnapshots = false;
98
+ inImporters = false;
99
+ continue;
100
+ }
101
+ if (trimmed === "snapshots:") {
102
+ inSnapshots = true;
103
+ inPackages = false;
104
+ inImporters = false;
105
+ continue;
106
+ }
107
+ if (trimmed === "importers:") {
108
+ inImporters = true;
109
+ inPackages = false;
110
+ inSnapshots = false;
111
+ continue;
112
+ }
113
+ if (line[0] !== " " && line[0] !== " " && trimmed.length > 0 && trimmed !== "packages:" && trimmed !== "snapshots:" && trimmed !== "importers:") {
114
+ inPackages = false;
115
+ inSnapshots = false;
116
+ inImporters = false;
117
+ continue;
118
+ }
119
+ if (inImporters) {
120
+ const indent = indentOf(line);
121
+ if (indent === 2 && require_primordials_string.StringPrototypeEndsWith(trimmed, ":")) {
122
+ currentImporter = { section: void 0 };
123
+ importerIndent = indent;
124
+ continue;
125
+ }
126
+ if (currentImporter && indent > importerIndent) {
127
+ if (require_primordials_string.StringPrototypeIndexOf(trimmed, "devDependencies:") === 0) currentImporter.section = "dev";
128
+ else if (require_primordials_string.StringPrototypeIndexOf(trimmed, "optionalDependencies:") === 0) currentImporter.section = "optional";
129
+ else if (require_primordials_string.StringPrototypeIndexOf(trimmed, "dependencies:") === 0) currentImporter.section = "prod";
130
+ else if (indent > importerIndent + 2) {
131
+ if (require_primordials_string.StringPrototypeIndexOf(trimmed, "specifier:") === 0 || require_primordials_string.StringPrototypeIndexOf(trimmed, "version:") === 0 || require_primordials_string.StringPrototypeIndexOf(trimmed, "resolution:") === 0) continue;
132
+ const colonIdx = require_primordials_string.StringPrototypeIndexOf(trimmed, ":");
133
+ if (colonIdx > 0) {
134
+ const depName = require_primordials_string.StringPrototypeSlice(trimmed, 0, colonIdx);
135
+ const depVersion = require_primordials_string.StringPrototypeTrim(require_primordials_string.StringPrototypeSlice(trimmed, colonIdx + 1));
136
+ if (depVersion.length === 0 || require_primordials_string.StringPrototypeIndexOf(depVersion, "link:") === 0 || require_primordials_string.StringPrototypeIndexOf(depVersion, "workspace:") === 0 || require_primordials_string.StringPrototypeIndexOf(depVersion, "file:") === 0) continue;
137
+ const versionWithoutPeer = stripPeerSuffix(depVersion);
138
+ if (packageIndex[depName] === void 0) {
139
+ const section = currentImporter.section;
140
+ require_primordials_array.ArrayPrototypePush(packages, require_primordials_object.ObjectFreeze({
141
+ __proto__: null,
142
+ name: depName,
143
+ version: versionWithoutPeer,
144
+ resolved: void 0,
145
+ integrity: void 0,
146
+ ecosystem: "npm",
147
+ depType: section === "dev" ? "dev" : section === "optional" ? "optional" : "prod",
148
+ isDev: section === "dev",
149
+ isOptional: section === "optional",
150
+ isPeer: false,
151
+ isBundled: false,
152
+ vcsUrl: void 0,
153
+ vcsCommit: void 0,
154
+ dependencies: []
155
+ }));
156
+ packageIndex[depName] = packages.length - 1;
157
+ }
158
+ }
159
+ }
160
+ }
161
+ continue;
162
+ }
163
+ if (!inPackages && !inSnapshots) continue;
164
+ const indent = indentOf(line);
165
+ if (indent >= 2 && indent <= 4 && require_primordials_string.StringPrototypeEndsWith(trimmed, ":") && trimmed.length > 1 && (currentPkg === void 0 || indent <= currentIndent)) {
166
+ if (currentPkg && currentPkg.name) {
167
+ require_primordials_array.ArrayPrototypePush(packages, freezeEntry(currentPkg));
168
+ addToPnpmIndex(packageIndex, currentPkg.name, packages.length - 1);
169
+ }
170
+ const key = require_primordials_string.StringPrototypeSlice(trimmed, 0, -1);
171
+ const parsed = key[0] === "/" ? require_eco_npm_pnpm_parse_pnpm_package_id_v5.parsePnpmPackageIdV5(key) : require_eco_npm_pnpm_parse_pnpm_package_id_v6_v9.parsePnpmPackageIdV6V9(key);
172
+ currentPkg = newPnpmEntry(parsed.name, parsed.version);
173
+ currentIndent = indent;
174
+ continue;
175
+ }
176
+ if (currentPkg && indent > currentIndent) {
177
+ if (require_primordials_string.StringPrototypeIndexOf(trimmed, "dev:") === 0) {
178
+ if (require_primordials_string.StringPrototypeIndexOf(trimmed, "true") !== -1) {
179
+ currentPkg.depType = "dev";
180
+ currentPkg.isDev = true;
181
+ }
182
+ } else if (require_primordials_string.StringPrototypeIndexOf(trimmed, "optional:") === 0) {
183
+ if (require_primordials_string.StringPrototypeIndexOf(trimmed, "true") !== -1) {
184
+ currentPkg.depType = "optional";
185
+ currentPkg.isOptional = true;
186
+ }
187
+ } else if (require_primordials_string.StringPrototypeIndexOf(trimmed, "integrity:") === 0) currentPkg.integrity = require_primordials_string.StringPrototypeTrim(require_primordials_string.StringPrototypeSlice(trimmed, 10));
188
+ else if (require_primordials_string.StringPrototypeIndexOf(trimmed, "resolution:") === 0) {
189
+ const intMatch = require_primordials_regexp.RegExpPrototypeExec(RE_INTEGRITY, trimmed);
190
+ if (intMatch) currentPkg.integrity = intMatch[1];
191
+ const tarballMatch = require_primordials_regexp.RegExpPrototypeExec(RE_TARBALL, trimmed);
192
+ if (tarballMatch) currentPkg.resolved = tarballMatch[1];
193
+ } else if (require_primordials_string.StringPrototypeIndexOf(trimmed, "dependencies:") === 0) {
194
+ currentPkg.dependencies = [];
195
+ currentPkg._inDeps = true;
196
+ } else if (currentPkg._inDeps && (require_primordials_string.StringPrototypeIndexOf(trimmed, "peerDependencies:") === 0 || require_primordials_string.StringPrototypeIndexOf(trimmed, "optionalDependencies:") === 0 || require_primordials_string.StringPrototypeIndexOf(trimmed, "engines:") === 0 || require_primordials_string.StringPrototypeIndexOf(trimmed, "os:") === 0 || require_primordials_string.StringPrototypeIndexOf(trimmed, "cpu:") === 0 || require_primordials_string.StringPrototypeIndexOf(trimmed, "bin:") === 0)) currentPkg._inDeps = false;
197
+ else if (currentPkg._inDeps && indent > currentIndent + 2) {
198
+ const colonIdx = require_primordials_string.StringPrototypeIndexOf(trimmed, ":");
199
+ if (colonIdx > 0) require_primordials_array.ArrayPrototypePush(currentPkg.dependencies, require_primordials_string.StringPrototypeSlice(trimmed, 0, colonIdx));
200
+ }
201
+ }
202
+ }
203
+ if (currentPkg && currentPkg.name) {
204
+ require_primordials_array.ArrayPrototypePush(packages, freezeEntry(currentPkg));
205
+ addToPnpmIndex(packageIndex, currentPkg.name, packages.length - 1);
206
+ }
207
+ return require_primordials_object.ObjectFreeze({
208
+ __proto__: null,
209
+ type: "lockfile",
210
+ lockVersion: String(lockVersion),
211
+ ecosystem: "npm",
212
+ packages: require_primordials_object.ObjectFreeze(packages),
213
+ _index: packageIndex
214
+ });
235
215
  }
236
216
  function newPnpmEntry(name, version) {
237
- return {
238
- name,
239
- version,
240
- resolved: void 0,
241
- integrity: void 0,
242
- ecosystem: "npm",
243
- depType: "prod",
244
- isDev: false,
245
- isOptional: false,
246
- isPeer: false,
247
- isBundled: false,
248
- vcsUrl: void 0,
249
- vcsCommit: void 0,
250
- dependencies: [],
251
- _inDeps: false
252
- };
217
+ return {
218
+ name,
219
+ version,
220
+ resolved: void 0,
221
+ integrity: void 0,
222
+ ecosystem: "npm",
223
+ depType: "prod",
224
+ isDev: false,
225
+ isOptional: false,
226
+ isPeer: false,
227
+ isBundled: false,
228
+ vcsUrl: void 0,
229
+ vcsCommit: void 0,
230
+ dependencies: [],
231
+ _inDeps: false
232
+ };
253
233
  }
254
234
  function stripPeerSuffix(version) {
255
- const underIdx = (0, import_string.StringPrototypeIndexOf)(version, "_");
256
- const noUnderscore = underIdx !== -1 ? (0, import_string.StringPrototypeSlice)(version, 0, underIdx) : version;
257
- const parenIdx = (0, import_string.StringPrototypeIndexOf)(noUnderscore, "(");
258
- return parenIdx !== -1 ? (0, import_string.StringPrototypeSlice)(noUnderscore, 0, parenIdx) : noUnderscore;
235
+ const underIdx = require_primordials_string.StringPrototypeIndexOf(version, "_");
236
+ const noUnderscore = underIdx !== -1 ? require_primordials_string.StringPrototypeSlice(version, 0, underIdx) : version;
237
+ const parenIdx = require_primordials_string.StringPrototypeIndexOf(noUnderscore, "(");
238
+ return parenIdx !== -1 ? require_primordials_string.StringPrototypeSlice(noUnderscore, 0, parenIdx) : noUnderscore;
259
239
  }
260
- const _smol = (0, import_manifest.getSmolManifest)();
261
- const parsePnpmLock = _smol ? (
262
- /* c8 ignore next 2 - smol Node binary only. */
263
- (content) => _smol.parseLockfile(content, "npm", "pnpm")
264
- ) : jsParsePnpmLock;
265
- // Annotate the CommonJS export names for ESM import in node:
266
- 0 && (module.exports = {
267
- addToPnpmIndex,
268
- freezeEntry,
269
- indentOf,
270
- jsParsePnpmLock,
271
- newPnpmEntry,
272
- parsePnpmLock,
273
- stripPeerSuffix
274
- });
240
+ const _smol = /* @__PURE__ */ require_smol_manifest.getSmolManifest();
241
+ const parsePnpmLock = _smol ? (content) => _smol.parseLockfile(content, "npm", "pnpm") : jsParsePnpmLock;
242
+
243
+ //#endregion
244
+ exports.addToPnpmIndex = addToPnpmIndex;
245
+ exports.freezeEntry = freezeEntry;
246
+ exports.indentOf = indentOf;
247
+ exports.jsParsePnpmLock = jsParsePnpmLock;
248
+ exports.newPnpmEntry = newPnpmEntry;
249
+ exports.parsePnpmLock = parsePnpmLock;
250
+ exports.stripPeerSuffix = stripPeerSuffix;
@@ -1,50 +1,40 @@
1
1
  "use strict";
2
- /* Socket Lib - Built with esbuild */
3
- "use strict";
4
- var __defProp = Object.defineProperty;
5
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
- var __getOwnPropNames = Object.getOwnPropertyNames;
7
- var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __export = (target, all) => {
9
- for (var name in all)
10
- __defProp(target, name, { get: all[name], enumerable: true });
11
- };
12
- var __copyProps = (to, from, except, desc) => {
13
- if (from && typeof from === "object" || typeof from === "function") {
14
- for (let key of __getOwnPropNames(from))
15
- if (!__hasOwnProp.call(to, key) && key !== except)
16
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
- }
18
- return to;
19
- };
20
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
21
- var parse_pnpm_package_id_v5_exports = {};
22
- __export(parse_pnpm_package_id_v5_exports, {
23
- parsePnpmPackageIdV5: () => parsePnpmPackageIdV5
24
- });
25
- module.exports = __toCommonJS(parse_pnpm_package_id_v5_exports);
26
- var import_string = require("../../../primordials/string");
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+ const require_primordials_string = require('../../../primordials/string.js');
5
+
6
+ //#region src/eco/npm/pnpm/parse-pnpm-package-id-v5.ts
7
+ /**
8
+ * @file `parsePnpmPackageIdV5(pkgId)` — extracts `{ name, version }` from a
9
+ * pnpm v5 package key. Spec forms handled:
10
+ *
11
+ * - `/name/version` → unscoped
12
+ * - `/@scope/name/version` scoped
13
+ * - `/name/version_peer-suffix` peer-dep suffix stripped Returns `{ name:
14
+ * pkgId, version: '0.0.0' }` for unparseable input matches socket-btm's
15
+ * smol-manifest leniency.
16
+ */
27
17
  function parsePnpmPackageIdV5(pkgId) {
28
- const withoutSlash = pkgId[0] === "/" ? (0, import_string.StringPrototypeSlice)(pkgId, 1) : pkgId;
29
- const underscoreIdx = (0, import_string.StringPrototypeIndexOf)(withoutSlash, "_");
30
- const withoutPeerSuffix = underscoreIdx !== -1 ? (0, import_string.StringPrototypeSlice)(withoutSlash, 0, underscoreIdx) : withoutSlash;
31
- if (withoutPeerSuffix[0] === "@") {
32
- const parts2 = (0, import_string.StringPrototypeSplit)(withoutPeerSuffix, "/");
33
- if (parts2.length < 2) {
34
- return { name: withoutPeerSuffix, version: "0.0.0" };
35
- }
36
- return {
37
- name: `${parts2[0]}/${parts2[1]}`,
38
- version: parts2[2] ?? "0.0.0"
39
- };
40
- }
41
- const parts = (0, import_string.StringPrototypeSplit)(withoutPeerSuffix, "/");
42
- return {
43
- name: parts[0] ?? withoutPeerSuffix,
44
- version: parts[1] ?? "0.0.0"
45
- };
18
+ const withoutSlash = pkgId[0] === "/" ? require_primordials_string.StringPrototypeSlice(pkgId, 1) : pkgId;
19
+ const underscoreIdx = require_primordials_string.StringPrototypeIndexOf(withoutSlash, "_");
20
+ const withoutPeerSuffix = underscoreIdx !== -1 ? require_primordials_string.StringPrototypeSlice(withoutSlash, 0, underscoreIdx) : withoutSlash;
21
+ if (withoutPeerSuffix[0] === "@") {
22
+ const parts = require_primordials_string.StringPrototypeSplit(withoutPeerSuffix, "/");
23
+ if (parts.length < 2) return {
24
+ name: withoutPeerSuffix,
25
+ version: "0.0.0"
26
+ };
27
+ return {
28
+ name: `${parts[0]}/${parts[1]}`,
29
+ version: parts[2] ?? "0.0.0"
30
+ };
31
+ }
32
+ const parts = require_primordials_string.StringPrototypeSplit(withoutPeerSuffix, "/");
33
+ return {
34
+ name: parts[0] ?? withoutPeerSuffix,
35
+ version: parts[1] ?? "0.0.0"
36
+ };
46
37
  }
47
- // Annotate the CommonJS export names for ESM import in node:
48
- 0 && (module.exports = {
49
- parsePnpmPackageIdV5
50
- });
38
+
39
+ //#endregion
40
+ exports.parsePnpmPackageIdV5 = parsePnpmPackageIdV5;