@socketsecurity/lib 6.0.2 → 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 (552) hide show
  1. package/CHANGELOG.md +34 -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.d.mts +48 -25
  6. package/dist/ai/profiles.js +95 -59
  7. package/dist/ai/spawn.d.mts +2 -2
  8. package/dist/ai/spawn.js +172 -194
  9. package/dist/ai/types.d.mts +3 -3
  10. package/dist/ai/types.js +1 -17
  11. package/dist/ai/worktree.d.mts +2 -2
  12. package/dist/ai/worktree.js +160 -183
  13. package/dist/ansi/constants.js +16 -38
  14. package/dist/ansi/strip.js +44 -41
  15. package/dist/archives/_internal.js +64 -73
  16. package/dist/archives/detect.js +30 -43
  17. package/dist/archives/extract.js +43 -50
  18. package/dist/archives/tar.js +197 -228
  19. package/dist/archives/types.js +1 -17
  20. package/dist/archives/zip.js +85 -121
  21. package/dist/argv/flag-predicates.js +203 -101
  22. package/dist/argv/flag-types.js +96 -113
  23. package/dist/argv/parse-args-string.d.ts +16 -14
  24. package/dist/argv/parse-args-string.js +42 -39
  25. package/dist/argv/parse.js +145 -163
  26. package/dist/arrays/_internal.js +65 -48
  27. package/dist/arrays/chunk.js +51 -40
  28. package/dist/arrays/join.js +87 -35
  29. package/dist/arrays/predicates.js +46 -28
  30. package/dist/arrays/unique.js +45 -31
  31. package/dist/bin/_internal.js +34 -42
  32. package/dist/bin/check-primordials.js +175 -233
  33. package/dist/bin/check.js +51 -72
  34. package/dist/bin/exec.js +70 -74
  35. package/dist/bin/find.js +151 -134
  36. package/dist/bin/resolve.js +180 -246
  37. package/dist/bin/shadow.js +24 -33
  38. package/dist/bin/socket-lib.js +51 -73
  39. package/dist/bin/types.js +1 -17
  40. package/dist/bin/which.js +211 -146
  41. package/dist/cacache/_internal.js +25 -40
  42. package/dist/cacache/clear.js +79 -72
  43. package/dist/cacache/read.js +48 -46
  44. package/dist/cacache/tmp.js +29 -36
  45. package/dist/cacache/types.js +1 -17
  46. package/dist/cacache/write.js +43 -48
  47. package/dist/cache/ttl/store.js +232 -288
  48. package/dist/cache/ttl/types.js +1 -17
  49. package/dist/checks/primordials-defaults.js +83 -89
  50. package/dist/checks/primordials.js +225 -277
  51. package/dist/colors/convert.js +45 -37
  52. package/dist/colors/palette.js +88 -45
  53. package/dist/colors/socket-palette.js +74 -84
  54. package/dist/colors/types.js +1 -17
  55. package/dist/compression/_internal.js +57 -72
  56. package/dist/compression/brotli.js +94 -127
  57. package/dist/compression/gzip.js +95 -121
  58. package/dist/compression/types.js +1 -17
  59. package/dist/constants/agents.js +61 -113
  60. package/dist/constants/encoding.js +19 -42
  61. package/dist/constants/github.js +12 -30
  62. package/dist/constants/licenses.js +48 -63
  63. package/dist/constants/lifecycle-script-names.js +31 -45
  64. package/dist/constants/maintained-node-versions.js +22 -37
  65. package/dist/constants/node.js +226 -167
  66. package/dist/constants/package-default-node-range.js +16 -41
  67. package/dist/constants/package-default-socket-categories.js +12 -30
  68. package/dist/constants/packages.js +77 -126
  69. package/dist/constants/platform.js +27 -49
  70. package/dist/constants/sentinels.js +23 -48
  71. package/dist/constants/socket.js +42 -87
  72. package/dist/constants/testing.js +15 -34
  73. package/dist/constants/time.js +16 -36
  74. package/dist/constants/typescript.js +32 -52
  75. package/dist/cover/code.js +111 -142
  76. package/dist/cover/formatters.js +118 -101
  77. package/dist/cover/type.js +50 -76
  78. package/dist/cover/types.js +1 -17
  79. package/dist/crypto/hash.js +54 -46
  80. package/dist/debug/_internal.js +62 -71
  81. package/dist/debug/caller-info.js +53 -64
  82. package/dist/debug/namespace.js +80 -90
  83. package/dist/debug/output.js +172 -188
  84. package/dist/debug/types.js +1 -17
  85. package/dist/dlx/_internal.js +24 -43
  86. package/dist/dlx/arborist.js +162 -160
  87. package/dist/dlx/binary-cache.js +228 -200
  88. package/dist/dlx/binary-download.js +172 -211
  89. package/dist/dlx/binary-resolution.js +165 -157
  90. package/dist/dlx/binary-types.js +1 -17
  91. package/dist/dlx/binary.js +149 -189
  92. package/dist/dlx/cache.js +45 -30
  93. package/dist/dlx/detect.js +245 -167
  94. package/dist/dlx/dir.js +67 -51
  95. package/dist/dlx/firewall.js +62 -100
  96. package/dist/dlx/lockfile.js +122 -127
  97. package/dist/dlx/manifest.js +264 -274
  98. package/dist/dlx/package.js +241 -244
  99. package/dist/dlx/packages.js +99 -96
  100. package/dist/dlx/paths.js +73 -59
  101. package/dist/dlx/spec.js +52 -60
  102. package/dist/dlx/types.js +1 -17
  103. package/dist/eco/cargo/lockfile-format.js +19 -36
  104. package/dist/eco/cargo/manifest-format.js +17 -35
  105. package/dist/eco/cargo/parse-lockfile.js +210 -237
  106. package/dist/eco/manifest/analyze-lockfile.js +46 -63
  107. package/dist/eco/manifest/detect-format.js +66 -90
  108. package/dist/eco/manifest/find-packages.js +39 -64
  109. package/dist/eco/manifest/get-package-versions.js +27 -48
  110. package/dist/eco/manifest/get-package.js +21 -40
  111. package/dist/eco/manifest/manifest-error.js +14 -35
  112. package/dist/eco/manifest/parse-lockfile.js +40 -86
  113. package/dist/eco/manifest/parse-manifest.js +26 -43
  114. package/dist/eco/manifest/parse.js +26 -47
  115. package/dist/eco/manifest/types.js +1 -17
  116. package/dist/eco/npm/bun/exec.js +23 -32
  117. package/dist/eco/npm/manifest-format.js +21 -35
  118. package/dist/eco/npm/npm/exec.js +51 -61
  119. package/dist/eco/npm/npm/extract-package-name-from-path.js +28 -50
  120. package/dist/eco/npm/npm/flags.js +80 -52
  121. package/dist/eco/npm/npm/lockfile-format.js +21 -40
  122. package/dist/eco/npm/npm/parse-git-url.js +26 -40
  123. package/dist/eco/npm/npm/parse-lockfile.js +184 -210
  124. package/dist/eco/npm/parse-package-json.js +71 -102
  125. package/dist/eco/npm/pnpm/detect-pnpm-version.js +22 -43
  126. package/dist/eco/npm/pnpm/exec.js +51 -62
  127. package/dist/eco/npm/pnpm/flags.js +75 -68
  128. package/dist/eco/npm/pnpm/lockfile-format.js +19 -36
  129. package/dist/eco/npm/pnpm/parse-lockfile.js +235 -259
  130. package/dist/eco/npm/pnpm/parse-pnpm-package-id-v5.js +37 -47
  131. package/dist/eco/npm/pnpm/parse-pnpm-package-id-v6-v9.js +36 -49
  132. package/dist/eco/npm/script.js +82 -90
  133. package/dist/eco/npm/vlt/exec.js +24 -32
  134. package/dist/eco/npm/yarnpkg/yarn/exec.js +60 -59
  135. package/dist/eco/npm/yarnpkg/yarn/lockfile-format.js +20 -36
  136. package/dist/eco/npm/yarnpkg/yarn/parse-lockfile.js +194 -242
  137. package/dist/eco/npm/yarnpkg/yarn/parse-yarn-descriptor.js +37 -61
  138. package/dist/eco/purl.js +50 -60
  139. package/dist/eco/types.js +1 -17
  140. package/dist/effects/pulse-frames.js +64 -65
  141. package/dist/effects/shimmer-keyframes.js +71 -52
  142. package/dist/effects/shimmer-terminal.js +81 -50
  143. package/dist/effects/shimmer.js +290 -153
  144. package/dist/env/boolean.js +42 -43
  145. package/dist/env/case-insensitive.js +54 -39
  146. package/dist/env/ci.js +29 -31
  147. package/dist/env/debug.js +28 -31
  148. package/dist/env/github.js +144 -59
  149. package/dist/env/home.js +38 -31
  150. package/dist/env/locale.js +59 -39
  151. package/dist/env/node-auth-token.js +28 -31
  152. package/dist/env/node-env.js +28 -31
  153. package/dist/env/npm.js +94 -47
  154. package/dist/env/number.js +50 -51
  155. package/dist/env/package-manager.js +95 -83
  156. package/dist/env/path.js +28 -31
  157. package/dist/env/pre-commit.js +30 -32
  158. package/dist/env/proxy.js +121 -122
  159. package/dist/env/rewire.js +204 -96
  160. package/dist/env/shell.js +28 -31
  161. package/dist/env/socket-cli.js +233 -81
  162. package/dist/env/socket.js +521 -156
  163. package/dist/env/string.js +43 -44
  164. package/dist/env/temp-dir.js +59 -39
  165. package/dist/env/term.js +28 -31
  166. package/dist/env/test.js +65 -43
  167. package/dist/env/types.js +1 -17
  168. package/dist/env/windows.js +78 -43
  169. package/dist/env/xdg.js +62 -39
  170. package/dist/errors/message.js +40 -46
  171. package/dist/errors/predicates.js +61 -49
  172. package/dist/errors/stack.js +24 -36
  173. package/dist/events/exit/_internal.js +86 -103
  174. package/dist/events/exit/handler.js +48 -55
  175. package/dist/events/exit/intercept.js +49 -70
  176. package/dist/events/exit/lifecycle.js +92 -101
  177. package/dist/events/exit/signals.js +25 -31
  178. package/dist/events/exit/types.js +1 -17
  179. package/dist/events/warning/handler.js +43 -40
  180. package/dist/events/warning/suppress.js +111 -90
  181. package/dist/external/@npmcli/package-json/lib/read-package.js +132 -153
  182. package/dist/external/@npmcli/package-json/lib/sort.js +73 -105
  183. package/dist/external/@npmcli/package-json.js +12705 -15140
  184. package/dist/external/@npmcli/promise-spawn.js +451 -472
  185. package/dist/external/@sinclair/typebox/value.js +7443 -9002
  186. package/dist/external/@sinclair/typebox.js +7516 -7885
  187. package/dist/external/@socketregistry/is-unicode-supported.js +31 -39
  188. package/dist/external/@socketregistry/packageurl-js.js +6127 -7369
  189. package/dist/external/@socketregistry/yocto-spinner.js +394 -455
  190. package/dist/external/@yarnpkg/extensions.js +435 -1022
  191. package/dist/external/adm-zip.js +2313 -2673
  192. package/dist/external/debug.js +700 -687
  193. package/dist/external/external-pack.js +2658 -3171
  194. package/dist/external/fast-sort.js +124 -138
  195. package/dist/external/get-east-asian-width.js +70 -64
  196. package/dist/external/libnpmexec.js +28 -31
  197. package/dist/external/npm-pack.js +43617 -50137
  198. package/dist/external/p-map.js +198 -222
  199. package/dist/external/pico-pack.js +6735 -7304
  200. package/dist/external/pony-cause.js +143 -139
  201. package/dist/external/shell-quote.js +226 -0
  202. package/dist/external/spdx-pack.js +1283 -1403
  203. package/dist/external/streaming-iterables.js +835 -1052
  204. package/dist/external/tar-fs.js +2769 -3048
  205. package/dist/external/which.js +267 -251
  206. package/dist/external/yargs-parser.js +851 -1074
  207. package/dist/external-tools/bazel/asset-names.js +98 -90
  208. package/dist/external-tools/bazel/from-download.js +52 -46
  209. package/dist/external-tools/bazel/from-path.js +27 -38
  210. package/dist/external-tools/bazel/read-bazel-version-file.js +35 -57
  211. package/dist/external-tools/bazel/resolve-asset-url.js +24 -39
  212. package/dist/external-tools/bazel/resolve-bazel-version.js +34 -56
  213. package/dist/external-tools/bazel/resolve.js +44 -58
  214. package/dist/external-tools/bazel/types.js +1 -17
  215. package/dist/external-tools/cdxgen/asset-names.js +59 -66
  216. package/dist/external-tools/cdxgen/from-download.js +52 -80
  217. package/dist/external-tools/cdxgen/from-path.js +19 -37
  218. package/dist/external-tools/cdxgen/from-vfs.js +22 -43
  219. package/dist/external-tools/cdxgen/resolve.js +48 -63
  220. package/dist/external-tools/cdxgen/types.js +1 -17
  221. package/dist/external-tools/from-download.js +107 -67
  222. package/dist/external-tools/janus/asset-names.js +44 -51
  223. package/dist/external-tools/janus/from-download.js +45 -70
  224. package/dist/external-tools/janus/from-path.js +19 -37
  225. package/dist/external-tools/janus/from-vfs.js +22 -43
  226. package/dist/external-tools/janus/resolve.js +45 -63
  227. package/dist/external-tools/janus/types.js +1 -17
  228. package/dist/external-tools/jre/asset-names.js +109 -82
  229. package/dist/external-tools/jre/detect-platform-arch.js +25 -49
  230. package/dist/external-tools/jre/from-download.js +71 -67
  231. package/dist/external-tools/jre/from-java-home.js +27 -54
  232. package/dist/external-tools/jre/from-path.js +27 -49
  233. package/dist/external-tools/jre/from-vfs.js +39 -60
  234. package/dist/external-tools/jre/resolve.js +55 -68
  235. package/dist/external-tools/jre/types.js +1 -17
  236. package/dist/external-tools/manifest.js +130 -150
  237. package/dist/external-tools/opengrep/asset-names.js +60 -72
  238. package/dist/external-tools/opengrep/from-download.js +58 -80
  239. package/dist/external-tools/opengrep/from-path.js +19 -37
  240. package/dist/external-tools/opengrep/from-vfs.js +23 -43
  241. package/dist/external-tools/opengrep/resolve.js +43 -63
  242. package/dist/external-tools/opengrep/types.js +1 -17
  243. package/dist/external-tools/sbt/asset-names.js +21 -30
  244. package/dist/external-tools/sbt/from-download.js +50 -61
  245. package/dist/external-tools/sbt/from-path.js +23 -38
  246. package/dist/external-tools/sbt/from-vfs.js +30 -44
  247. package/dist/external-tools/sbt/resolve.js +45 -63
  248. package/dist/external-tools/sbt/types.js +1 -17
  249. package/dist/external-tools/synp/asset-names.js +11 -29
  250. package/dist/external-tools/synp/from-download.js +24 -41
  251. package/dist/external-tools/synp/from-path.js +19 -37
  252. package/dist/external-tools/synp/from-vfs.js +22 -43
  253. package/dist/external-tools/synp/resolve.js +43 -62
  254. package/dist/external-tools/synp/types.js +1 -17
  255. package/dist/external-tools/trivy/asset-names.js +51 -62
  256. package/dist/external-tools/trivy/from-download.js +42 -64
  257. package/dist/external-tools/trivy/from-path.js +19 -37
  258. package/dist/external-tools/trivy/from-vfs.js +22 -43
  259. package/dist/external-tools/trivy/resolve.js +43 -63
  260. package/dist/external-tools/trivy/types.js +1 -17
  261. package/dist/external-tools/trufflehog/asset-names.js +54 -66
  262. package/dist/external-tools/trufflehog/from-download.js +44 -62
  263. package/dist/external-tools/trufflehog/from-path.js +21 -37
  264. package/dist/external-tools/trufflehog/from-vfs.js +26 -43
  265. package/dist/external-tools/trufflehog/resolve.js +43 -63
  266. package/dist/external-tools/trufflehog/types.js +1 -17
  267. package/dist/external-tools/uv/asset-names.js +64 -74
  268. package/dist/external-tools/uv/from-download.js +44 -65
  269. package/dist/external-tools/uv/from-path.js +19 -37
  270. package/dist/external-tools/uv/from-vfs.js +22 -43
  271. package/dist/external-tools/uv/resolve.js +42 -63
  272. package/dist/external-tools/uv/types.js +1 -17
  273. package/dist/fs/_internal.js +40 -42
  274. package/dist/fs/access.d.ts +32 -0
  275. package/dist/fs/access.js +66 -0
  276. package/dist/fs/encoding.js +80 -97
  277. package/dist/fs/find-up.js +126 -147
  278. package/dist/fs/inspect.js +168 -99
  279. package/dist/fs/path-cache.js +31 -32
  280. package/dist/fs/read-dir.js +102 -79
  281. package/dist/fs/read-file.js +177 -118
  282. package/dist/fs/read-json-cache.js +150 -134
  283. package/dist/fs/read-json.js +172 -187
  284. package/dist/fs/resolve-module.d.ts +57 -0
  285. package/dist/fs/resolve-module.js +40 -0
  286. package/dist/fs/safe.js +278 -169
  287. package/dist/fs/types.js +1 -17
  288. package/dist/fs/unique.js +52 -48
  289. package/dist/fs/validate.js +56 -43
  290. package/dist/fs/write-json.js +109 -75
  291. package/dist/git/_internal.js +251 -216
  292. package/dist/git/changed.js +191 -74
  293. package/dist/git/repo.js +118 -104
  294. package/dist/git/staged.js +172 -62
  295. package/dist/git/types.js +1 -17
  296. package/dist/git/unstaged.js +175 -62
  297. package/dist/github/constants.js +25 -33
  298. package/dist/github/errors.js +46 -38
  299. package/dist/github/fetch.js +137 -82
  300. package/dist/github/ghsa.js +217 -151
  301. package/dist/github/refs-cache.js +54 -43
  302. package/dist/github/refs-graphql.js +97 -89
  303. package/dist/github/refs-rest.js +70 -101
  304. package/dist/github/refs.js +105 -64
  305. package/dist/github/token.js +96 -48
  306. package/dist/github/types.js +1 -17
  307. package/dist/globs/_internal.js +73 -82
  308. package/dist/globs/defaults.js +40 -59
  309. package/dist/globs/match.js +93 -77
  310. package/dist/globs/matcher.js +104 -92
  311. package/dist/globs/stream.js +43 -55
  312. package/dist/globs/types.js +1 -17
  313. package/dist/http-request/_internal.js +11 -38
  314. package/dist/http-request/browser-fetch.js +19 -29
  315. package/dist/http-request/browser.js +188 -206
  316. package/dist/http-request/checksums.js +101 -65
  317. package/dist/http-request/download-types.js +1 -17
  318. package/dist/http-request/download.js +195 -196
  319. package/dist/http-request/errors.js +39 -47
  320. package/dist/http-request/headers.js +95 -80
  321. package/dist/http-request/http-request.js +10 -35
  322. package/dist/http-request/node.js +71 -97
  323. package/dist/http-request/request-attempt.js +232 -285
  324. package/dist/http-request/request-types.js +1 -17
  325. package/dist/http-request/request.js +106 -108
  326. package/dist/http-request/response-reader.js +47 -51
  327. package/dist/http-request/response-types.js +22 -38
  328. package/dist/http-request/user-agent.js +73 -55
  329. package/dist/integrity.js +105 -106
  330. package/dist/ipc/_internal.js +34 -48
  331. package/dist/ipc/directory.js +55 -63
  332. package/dist/ipc/paths.js +52 -45
  333. package/dist/ipc/types.js +1 -17
  334. package/dist/ipc/write.js +81 -74
  335. package/dist/ipc-cli/get.js +29 -56
  336. package/dist/ipc-cli/types.js +1 -17
  337. package/dist/json/edit.js +182 -242
  338. package/dist/json/format.js +202 -103
  339. package/dist/json/parse.js +206 -109
  340. package/dist/json/types.js +1 -17
  341. package/dist/links/create.js +93 -60
  342. package/dist/links/types.js +1 -17
  343. package/dist/logger/_internal.js +109 -73
  344. package/dist/logger/browser.js +45 -56
  345. package/dist/logger/colors.js +31 -49
  346. package/dist/logger/console.js +89 -112
  347. package/dist/logger/default.js +19 -33
  348. package/dist/logger/logger.js +5 -29
  349. package/dist/logger/node.js +794 -854
  350. package/dist/logger/symbols-builder.js +54 -56
  351. package/dist/logger/symbols.js +135 -118
  352. package/dist/logger/types.js +1 -17
  353. package/dist/memo/_internal.js +39 -49
  354. package/dist/memo/async.js +133 -117
  355. package/dist/memo/clear.js +25 -34
  356. package/dist/memo/decorator.js +43 -37
  357. package/dist/memo/memoize.js +97 -88
  358. package/dist/memo/once.js +42 -41
  359. package/dist/memo/types.js +1 -17
  360. package/dist/memo/weak.js +45 -41
  361. package/dist/node/async-hooks.js +9 -30
  362. package/dist/node/child-process.js +9 -30
  363. package/dist/node/crypto.js +9 -30
  364. package/dist/node/events.js +9 -30
  365. package/dist/node/fs-promises.js +9 -30
  366. package/dist/node/fs.js +9 -30
  367. package/dist/node/http.js +9 -30
  368. package/dist/node/https.js +9 -30
  369. package/dist/node/module.js +20 -34
  370. package/dist/node/os.js +9 -30
  371. package/dist/node/path.js +9 -30
  372. package/dist/node/timers-promises.js +9 -30
  373. package/dist/node/url.js +9 -30
  374. package/dist/node/util.js +9 -30
  375. package/dist/objects/getters.js +185 -126
  376. package/dist/objects/inspect.js +85 -52
  377. package/dist/objects/mutate.js +96 -76
  378. package/dist/objects/predicates.js +112 -59
  379. package/dist/objects/sort.js +120 -76
  380. package/dist/objects/types.js +1 -17
  381. package/dist/packages/edit-class.js +198 -265
  382. package/dist/packages/edit.js +79 -86
  383. package/dist/packages/exports.js +146 -157
  384. package/dist/packages/isolation.js +159 -209
  385. package/dist/packages/licenses.js +207 -189
  386. package/dist/packages/manifest.js +134 -172
  387. package/dist/packages/normalize.js +91 -102
  388. package/dist/packages/operations.d.ts +2 -0
  389. package/dist/packages/operations.js +283 -254
  390. package/dist/packages/provenance.js +195 -245
  391. package/dist/packages/specs.js +94 -84
  392. package/dist/packages/types.js +1 -17
  393. package/dist/packages/validation.js +49 -50
  394. package/dist/paths/_internal.js +82 -86
  395. package/dist/paths/conversion.js +112 -65
  396. package/dist/paths/dirnames.js +17 -42
  397. package/dist/paths/exts.js +23 -54
  398. package/dist/paths/filenames.js +21 -50
  399. package/dist/paths/globs.js +15 -38
  400. package/dist/paths/normalize.js +215 -236
  401. package/dist/paths/packages.js +34 -49
  402. package/dist/paths/predicates.js +184 -106
  403. package/dist/paths/resolve.js +146 -128
  404. package/dist/paths/rewire.js +108 -72
  405. package/dist/paths/socket.js +252 -132
  406. package/dist/paths/walk.d.ts +40 -0
  407. package/dist/paths/walk.js +58 -0
  408. package/dist/perf/_internal.js +10 -28
  409. package/dist/perf/enabled.js +21 -30
  410. package/dist/perf/metrics.js +81 -67
  411. package/dist/perf/report.js +79 -80
  412. package/dist/perf/timer.js +180 -126
  413. package/dist/perf/types.js +1 -17
  414. package/dist/pkg-ext/data.js +29 -82
  415. package/dist/pkg-ext/types.js +1 -17
  416. package/dist/primordials/array.js +120 -198
  417. package/dist/primordials/buffer.js +28 -51
  418. package/dist/primordials/date.js +26 -51
  419. package/dist/primordials/error.js +33 -59
  420. package/dist/primordials/function.js +21 -41
  421. package/dist/primordials/globals.js +25 -48
  422. package/dist/primordials/json.js +14 -30
  423. package/dist/primordials/map-set.js +88 -152
  424. package/dist/primordials/math.js +59 -116
  425. package/dist/primordials/number.js +41 -76
  426. package/dist/primordials/object.js +56 -116
  427. package/dist/primordials/promise.js +28 -52
  428. package/dist/primordials/reflect.js +24 -52
  429. package/dist/primordials/regexp.js +25 -47
  430. package/dist/primordials/string.js +114 -167
  431. package/dist/primordials/symbol.js +40 -72
  432. package/dist/primordials/uncurry.js +38 -55
  433. package/dist/primordials/url.js +27 -66
  434. package/dist/process/_internal.js +7 -32
  435. package/dist/process/abort.js +29 -35
  436. package/dist/process/lock-instance.js +26 -30
  437. package/dist/process/lock-manager.js +279 -307
  438. package/dist/process/lock-types.js +1 -17
  439. package/dist/process/spawn/_internal.js +43 -55
  440. package/dist/process/spawn/child.js +172 -211
  441. package/dist/process/spawn/errors.js +116 -113
  442. package/dist/process/spawn/stdio.js +51 -35
  443. package/dist/process/spawn/types.js +1 -17
  444. package/dist/process/transient.js +49 -66
  445. package/dist/promises/_internal.d.ts +8 -2
  446. package/dist/promises/_internal.js +31 -38
  447. package/dist/promises/iterate.js +238 -102
  448. package/dist/promises/options.js +123 -101
  449. package/dist/promises/queue.js +115 -136
  450. package/dist/promises/resolvers.js +77 -46
  451. package/dist/promises/retry.js +156 -101
  452. package/dist/promises/types.js +1 -17
  453. package/dist/regexps/escape.js +32 -30
  454. package/dist/regexps/hex.js +16 -33
  455. package/dist/regexps/spec.js +53 -81
  456. package/dist/releases/github-archives.js +127 -118
  457. package/dist/releases/github-asset-url.js +162 -155
  458. package/dist/releases/github-assets.js +37 -49
  459. package/dist/releases/github-auth.js +32 -48
  460. package/dist/releases/github-downloads.js +118 -138
  461. package/dist/releases/github-listing.js +175 -154
  462. package/dist/releases/github-retry-config.d.ts +31 -0
  463. package/dist/releases/github-retry-config.js +46 -0
  464. package/dist/releases/github-types.js +1 -17
  465. package/dist/releases/socket-btm.js +273 -192
  466. package/dist/schema/parse.js +35 -36
  467. package/dist/schema/types.js +1 -17
  468. package/dist/schema/validate.js +118 -99
  469. package/dist/sea/detect.js +57 -52
  470. package/dist/secrets/_internal.js +86 -67
  471. package/dist/secrets/find.js +96 -77
  472. package/dist/secrets/keychain.js +315 -309
  473. package/dist/secrets/linux.js +133 -135
  474. package/dist/secrets/macos.js +151 -147
  475. package/dist/secrets/rc.js +182 -181
  476. package/dist/secrets/socket-api-token.js +28 -43
  477. package/dist/secrets/types.js +1 -17
  478. package/dist/secrets/windows.js +184 -242
  479. package/dist/shadow/skip.js +51 -70
  480. package/dist/shadow/types.js +1 -17
  481. package/dist/shell/parse.d.ts +26 -0
  482. package/dist/shell/parse.js +35 -0
  483. package/dist/shell/quote.d.ts +19 -0
  484. package/dist/shell/quote.js +30 -0
  485. package/dist/smol/detect.js +67 -43
  486. package/dist/smol/http.js +33 -37
  487. package/dist/smol/https.js +31 -37
  488. package/dist/smol/manifest.js +33 -37
  489. package/dist/smol/path.d.ts +51 -0
  490. package/dist/smol/path.js +38 -0
  491. package/dist/smol/primordial.js +35 -37
  492. package/dist/smol/purl.js +34 -37
  493. package/dist/smol/versions.js +31 -37
  494. package/dist/smol/vfs.js +46 -38
  495. package/dist/sorts/_internal.js +14 -40
  496. package/dist/sorts/natural.js +57 -64
  497. package/dist/sorts/semver.js +33 -43
  498. package/dist/sorts/strings.js +24 -30
  499. package/dist/sorts/types.js +1 -17
  500. package/dist/spinner/default.js +72 -63
  501. package/dist/spinner/format.js +86 -71
  502. package/dist/spinner/spinner.js +749 -797
  503. package/dist/spinner/types.js +1 -17
  504. package/dist/spinner/with.js +193 -137
  505. package/dist/ssri/convert.js +64 -47
  506. package/dist/ssri/parse.js +38 -37
  507. package/dist/ssri/validate.js +51 -34
  508. package/dist/stdio/_internal.js +50 -46
  509. package/dist/stdio/clear.js +208 -86
  510. package/dist/stdio/divider.js +170 -97
  511. package/dist/stdio/footer.js +116 -110
  512. package/dist/stdio/header.js +117 -90
  513. package/dist/stdio/progress.js +189 -218
  514. package/dist/stdio/prompts.js +244 -168
  515. package/dist/stdio/stderr.js +173 -78
  516. package/dist/stdio/stdout.js +177 -94
  517. package/dist/streams/parallel.js +58 -50
  518. package/dist/streams/transform.js +36 -45
  519. package/dist/strings/format.js +145 -63
  520. package/dist/strings/predicates.js +56 -34
  521. package/dist/strings/search.js +52 -42
  522. package/dist/strings/transform.js +113 -72
  523. package/dist/strings/types.js +1 -17
  524. package/dist/strings/width.js +89 -82
  525. package/dist/tables/bordered.js +81 -81
  526. package/dist/tables/padding.js +36 -46
  527. package/dist/tables/simple.js +62 -70
  528. package/dist/tables/types.js +1 -17
  529. package/dist/temporal/instant.js +72 -81
  530. package/dist/temporal/now.js +40 -31
  531. package/dist/temporal/slots.js +42 -36
  532. package/dist/temporal/system.js +36 -36
  533. package/dist/temporal/temporal.js +11 -41
  534. package/dist/themes/context.js +131 -69
  535. package/dist/themes/resolve.js +207 -132
  536. package/dist/themes/themes.js +225 -194
  537. package/dist/themes/types.js +1 -17
  538. package/dist/url/parse.js +48 -51
  539. package/dist/url/predicates.js +24 -31
  540. package/dist/url/search-params.js +133 -101
  541. package/dist/url/types.js +1 -17
  542. package/dist/versions/_internal.js +31 -33
  543. package/dist/versions/compare.js +80 -58
  544. package/dist/versions/modify.js +41 -39
  545. package/dist/versions/parse.js +88 -64
  546. package/dist/versions/range.js +58 -41
  547. package/dist/versions/types.js +1 -17
  548. package/dist/words/article.js +22 -30
  549. package/dist/words/capitalize.js +25 -34
  550. package/dist/words/pluralize.js +23 -31
  551. package/dist/words/types.js +1 -17
  552. package/package.json +42 -5
@@ -1,224 +1,198 @@
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
- addToIndex: () => addToIndex,
24
- buildPackageRef: () => buildPackageRef,
25
- jsParsePackageLock: () => jsParsePackageLock,
26
- parsePackageLock: () => parsePackageLock,
27
- parseV1: () => parseV1,
28
- parseV2V3: () => parseV2V3,
29
- resolveDepType: () => resolveDepType
30
- });
31
- module.exports = __toCommonJS(parse_lockfile_exports);
32
- var import_manifest_error = require("../../manifest/manifest-error");
33
- var import_message = require("../../../errors/message");
34
- var import_array = require("../../../primordials/array");
35
- var import_error = require("../../../primordials/error");
36
- var import_json = require("../../../primordials/json");
37
- var import_map_set = require("../../../primordials/map-set");
38
- var import_object = require("../../../primordials/object");
39
- var import_manifest = require("../../../smol/manifest");
40
- var import_extract_package_name_from_path = require("./extract-package-name-from-path");
41
- var import_parse_git_url = require("./parse-git-url");
42
- var import_string = require("../../../primordials/string");
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+ const require_primordials_error = require('../../../primordials/error.js');
5
+ const require_primordials_string = require('../../../primordials/string.js');
6
+ const require_primordials_array = require('../../../primordials/array.js');
7
+ const require_primordials_map_set = require('../../../primordials/map-set.js');
8
+ const require_primordials_object = require('../../../primordials/object.js');
9
+ const require_primordials_json = require('../../../primordials/json.js');
10
+ const require_errors_message = require('../../../errors/message.js');
11
+ const require_smol_manifest = require('../../../smol/manifest.js');
12
+ const require_eco_manifest_manifest_error = require('../../manifest/manifest-error.js');
13
+ const require_eco_npm_npm_extract_package_name_from_path = require('./extract-package-name-from-path.js');
14
+ const require_eco_npm_npm_parse_git_url = require('./parse-git-url.js');
15
+
16
+ //#region src/eco/npm/npm/parse-lockfile.ts
17
+ /**
18
+ * @file `parsePackageLock(content)` — parses an npm `package-lock.json` /
19
+ * `npm-shrinkwrap.json` (v1/v2/v3) into a `ParsedLockfile`. On socket-btm's
20
+ * smol Node binary this routes to `node:smol-manifest`'s native
21
+ * `parseLockfile(content, 'npm', 'npm')`; on stock Node it runs the JS impl
22
+ * below. Throws:
23
+ *
24
+ * - `ManifestError(ERR_INVALID_JSON)` JSON.parse failure
25
+ * - `RangeError` v1 nested-deps exceed `MAX_LOCKFILE_DEPTH = 64`, surfaces
26
+ * malformed input rather than blowing the JS stack v2/v3 uses the flat
27
+ * `packages` key; v1 uses recursive `dependencies`. The two paths converge
28
+ * on the same `ParsedLockfile` shape so downstream consumers don't branch
29
+ * on `lockVersion`. Source material (in lock-step order, newest → oldest):
30
+ *
31
+ * 1. **C++ native parser** in socket-btm/node-smol-builder:
32
+ * additions/source-patched/src/socketsecurity/manifest/parser_npm.cc Same
33
+ * algorithm, same fixes — keep the two in lock-step.
34
+ * 2. **socket-sdxgen** algorithm oracle, broader production exposure:
35
+ * socket-sdxgen/src/parsers/npm/package-lock-v1.mts
36
+ * socket-sdxgen/src/parsers/npm/package-lock-v2.mts
37
+ * socket-sdxgen/src/parsers/npm/npm-shrinkwrap.mts
38
+ * 3. **cdxgen** (pinned v11.11.0) — sdxgen's upstream baseline:
39
+ * https://github.com/CycloneDX/cdxgen/blob/v11.11.0/lib/parsers/js.js
40
+ * (parseLockFile / parsePkgLock)
41
+ * 4. **npm lockfile specs**: v1 (legacy):
42
+ * https://docs.npmjs.com/cli/v6/configuring-npm/package-lock-json v2/v3:
43
+ * https://docs.npmjs.com/cli/v10/configuring-npm/package-lock-json
44
+ * arborist (canonical reader/writer):
45
+ * https://github.com/npm/cli/tree/latest/workspaces/arborist Bug fixes
46
+ * implemented here (and in the native parser):
47
+ *
48
+ * - Fix 1 v1 alias extraction. `version: "npm:<real>@<ver>"` surfaces the real
49
+ * registry identity on the PackageRef; `_index` keeps the original alias
50
+ * key for lookups.
51
+ * - Fix 2a v2/v3 workspace path entries prefer `pkg.name` over path-derived
52
+ * fallback (workspace paths like `packages/ui` lack the `node_modules/`
53
+ * prefix).
54
+ * - Fix 2b v2/v3 aliased installs (`node_modules/<alias>` with `name: "<real>"`
55
+ * field) prefer `pkg.name`. Same code path as Fix 2a. Regression fixtures
56
+ * live under socket-btm's test/fixtures/ sdxgen-bug-regressions/ — every
57
+ * shipped fix has a matching fixture directory there.
58
+ */
43
59
  const MAX_LOCKFILE_DEPTH = 64;
44
60
  function addToIndex(packageIndex, name, idx) {
45
- const existing = packageIndex[name];
46
- if (existing === void 0) {
47
- packageIndex[name] = idx;
48
- } else if (typeof existing === "number") {
49
- packageIndex[name] = [existing, idx];
50
- } else {
51
- (0, import_array.ArrayPrototypePush)(existing, idx);
52
- }
61
+ const existing = packageIndex[name];
62
+ if (existing === void 0) packageIndex[name] = idx;
63
+ else if (typeof existing === "number") packageIndex[name] = [existing, idx];
64
+ else require_primordials_array.ArrayPrototypePush(existing, idx);
53
65
  }
54
66
  function buildPackageRef(name, pkg) {
55
- let vcsUrl;
56
- let vcsCommit;
57
- if (typeof pkg.resolved === "string") {
58
- const gitMatch = (0, import_parse_git_url.parseGitUrl)(pkg.resolved);
59
- if (gitMatch) {
60
- vcsUrl = gitMatch.url;
61
- vcsCommit = gitMatch.commit;
62
- }
63
- }
64
- const depsKey = pkg.dependencies ?? pkg.requires;
65
- const dependencies = depsKey && typeof depsKey === "object" ? (0, import_object.ObjectKeys)(depsKey) : [];
66
- let effectiveName = name;
67
- let version = typeof pkg.version === "string" ? pkg.version : "0.0.0";
68
- if ((0, import_string.StringPrototypeStartsWith)(version, "npm:")) {
69
- const rest = (0, import_string.StringPrototypeSlice)(version, "npm:".length);
70
- const atIdx = (0, import_string.StringPrototypeLastIndexOf)(rest, "@");
71
- if (atIdx > 0) {
72
- effectiveName = (0, import_string.StringPrototypeSlice)(rest, 0, atIdx);
73
- version = (0, import_string.StringPrototypeSlice)(rest, atIdx + 1);
74
- }
75
- }
76
- return (0, import_object.ObjectFreeze)({
77
- __proto__: null,
78
- name: effectiveName,
79
- version,
80
- resolved: typeof pkg.resolved === "string" ? pkg.resolved : void 0,
81
- integrity: typeof pkg.integrity === "string" ? pkg.integrity : void 0,
82
- ecosystem: "npm",
83
- depType: resolveDepType(pkg),
84
- isDev: !!pkg.dev,
85
- isOptional: !!pkg.optional,
86
- isPeer: !!pkg.peer,
87
- isBundled: !!pkg.inBundle,
88
- license: typeof pkg.license === "string" ? pkg.license : void 0,
89
- vcsUrl,
90
- vcsCommit,
91
- dependencies
92
- });
67
+ let vcsUrl;
68
+ let vcsCommit;
69
+ if (typeof pkg.resolved === "string") {
70
+ const gitMatch = require_eco_npm_npm_parse_git_url.parseGitUrl(pkg.resolved);
71
+ if (gitMatch) {
72
+ vcsUrl = gitMatch.url;
73
+ vcsCommit = gitMatch.commit;
74
+ }
75
+ }
76
+ const depsKey = pkg.dependencies ?? pkg.requires;
77
+ const dependencies = depsKey && typeof depsKey === "object" ? require_primordials_object.ObjectKeys(depsKey) : [];
78
+ let effectiveName = name;
79
+ let version = typeof pkg.version === "string" ? pkg.version : "0.0.0";
80
+ if (require_primordials_string.StringPrototypeStartsWith(version, "npm:")) {
81
+ const rest = require_primordials_string.StringPrototypeSlice(version, 4);
82
+ const atIdx = require_primordials_string.StringPrototypeLastIndexOf(rest, "@");
83
+ if (atIdx > 0) {
84
+ effectiveName = require_primordials_string.StringPrototypeSlice(rest, 0, atIdx);
85
+ version = require_primordials_string.StringPrototypeSlice(rest, atIdx + 1);
86
+ }
87
+ }
88
+ return require_primordials_object.ObjectFreeze({
89
+ __proto__: null,
90
+ name: effectiveName,
91
+ version,
92
+ resolved: typeof pkg.resolved === "string" ? pkg.resolved : void 0,
93
+ integrity: typeof pkg.integrity === "string" ? pkg.integrity : void 0,
94
+ ecosystem: "npm",
95
+ depType: resolveDepType(pkg),
96
+ isDev: !!pkg.dev,
97
+ isOptional: !!pkg.optional,
98
+ isPeer: !!pkg.peer,
99
+ isBundled: !!pkg.inBundle,
100
+ license: typeof pkg.license === "string" ? pkg.license : void 0,
101
+ vcsUrl,
102
+ vcsCommit,
103
+ dependencies
104
+ });
93
105
  }
94
106
  function jsParsePackageLock(content) {
95
- let data;
96
- try {
97
- data = (0, import_json.JSONParse)(content);
98
- } catch (e) {
99
- throw new import_manifest_error.ManifestError(
100
- `Invalid JSON: ${(0, import_message.errorMessage)(e)}`,
101
- "ERR_INVALID_JSON"
102
- );
103
- }
104
- if (data.packages) {
105
- return parseV2V3(data, data.packages);
106
- }
107
- if (data.dependencies) {
108
- return parseV1(data, data.dependencies);
109
- }
110
- return (0, import_object.ObjectFreeze)({
111
- __proto__: null,
112
- type: "lockfile",
113
- lockVersion: String(data.lockfileVersion ?? 1),
114
- ecosystem: "npm",
115
- packages: (0, import_object.ObjectFreeze)([]),
116
- _index: { __proto__: null }
117
- });
107
+ let data;
108
+ try {
109
+ data = require_primordials_json.JSONParse(content);
110
+ } catch (e) {
111
+ throw new require_eco_manifest_manifest_error.ManifestError(`Invalid JSON: ${require_errors_message.errorMessage(e)}`, "ERR_INVALID_JSON");
112
+ }
113
+ if (data.packages) return parseV2V3(data, data.packages);
114
+ if (data.dependencies) return parseV1(data, data.dependencies);
115
+ return require_primordials_object.ObjectFreeze({
116
+ __proto__: null,
117
+ type: "lockfile",
118
+ lockVersion: String(data.lockfileVersion ?? 1),
119
+ ecosystem: "npm",
120
+ packages: require_primordials_object.ObjectFreeze([]),
121
+ _index: { __proto__: null }
122
+ });
118
123
  }
119
124
  function parseV1(data, rootDeps) {
120
- const packageIndex = {
121
- __proto__: null
122
- };
123
- const packages = [];
124
- const visited = new import_map_set.SetCtor();
125
- const flatten = (deps, parentPath, depth) => {
126
- if (depth > MAX_LOCKFILE_DEPTH) {
127
- throw new import_error.RangeErrorCtor(
128
- `Lockfile dependency nesting exceeds ${MAX_LOCKFILE_DEPTH} levels at ${parentPath}`
129
- );
130
- }
131
- const depKeys = (0, import_object.ObjectKeys)(deps);
132
- for (let di = 0, { length } = depKeys; di < length; di++) {
133
- const name = depKeys[di];
134
- const pkg = deps[name];
135
- const version = typeof pkg.version === "string" ? pkg.version : "0.0.0";
136
- const key = `${name}@${version}`;
137
- if (visited.has(key)) {
138
- continue;
139
- }
140
- if (packageIndex[name] === void 0) {
141
- const ref = buildPackageRef(name, pkg);
142
- (0, import_array.ArrayPrototypePush)(packages, ref);
143
- packageIndex[name] = packages.length - 1;
144
- }
145
- if (pkg.dependencies && typeof pkg.dependencies === "object") {
146
- visited.add(key);
147
- flatten(
148
- pkg.dependencies,
149
- `${parentPath}/${name}`,
150
- depth + 1
151
- );
152
- visited.delete(key);
153
- }
154
- }
155
- };
156
- flatten(rootDeps, "", 0);
157
- return (0, import_object.ObjectFreeze)({
158
- __proto__: null,
159
- type: "lockfile",
160
- lockVersion: String(data.lockfileVersion ?? 1),
161
- ecosystem: "npm",
162
- packages: (0, import_object.ObjectFreeze)(packages),
163
- _index: packageIndex
164
- });
125
+ const packageIndex = { __proto__: null };
126
+ const packages = [];
127
+ const visited = new require_primordials_map_set.SetCtor();
128
+ const flatten = (deps, parentPath, depth) => {
129
+ if (depth > MAX_LOCKFILE_DEPTH) throw new require_primordials_error.RangeErrorCtor(`Lockfile dependency nesting exceeds ${MAX_LOCKFILE_DEPTH} levels at ${parentPath}`);
130
+ const depKeys = require_primordials_object.ObjectKeys(deps);
131
+ for (let di = 0, { length } = depKeys; di < length; di++) {
132
+ const name = depKeys[di];
133
+ const pkg = deps[name];
134
+ const key = `${name}@${typeof pkg.version === "string" ? pkg.version : "0.0.0"}`;
135
+ if (visited.has(key)) continue;
136
+ if (packageIndex[name] === void 0) {
137
+ require_primordials_array.ArrayPrototypePush(packages, buildPackageRef(name, pkg));
138
+ packageIndex[name] = packages.length - 1;
139
+ }
140
+ if (pkg.dependencies && typeof pkg.dependencies === "object") {
141
+ visited.add(key);
142
+ flatten(pkg.dependencies, `${parentPath}/${name}`, depth + 1);
143
+ visited.delete(key);
144
+ }
145
+ }
146
+ };
147
+ flatten(rootDeps, "", 0);
148
+ return require_primordials_object.ObjectFreeze({
149
+ __proto__: null,
150
+ type: "lockfile",
151
+ lockVersion: String(data.lockfileVersion ?? 1),
152
+ ecosystem: "npm",
153
+ packages: require_primordials_object.ObjectFreeze(packages),
154
+ _index: packageIndex
155
+ });
165
156
  }
166
157
  function parseV2V3(data, rawPackages) {
167
- const packageIndex = {
168
- __proto__: null
169
- };
170
- const pkgKeys = (0, import_object.ObjectKeys)(rawPackages);
171
- const packages = (0, import_array.ArrayFrom)({
172
- length: rawPackages[""] !== void 0 ? pkgKeys.length - 1 : pkgKeys.length
173
- });
174
- let pkgCount = 0;
175
- for (let ki = 0, { length } = pkgKeys; ki < length; ki++) {
176
- const pkgPath = pkgKeys[ki];
177
- if (pkgPath === "") {
178
- continue;
179
- }
180
- const pkg = rawPackages[pkgPath];
181
- const nameFromPath = (0, import_extract_package_name_from_path.extractPackageNameFromPath)(pkgPath);
182
- const name = typeof pkg.name === "string" && pkg.name.length > 0 ? pkg.name : nameFromPath;
183
- const ref = buildPackageRef(name, pkg);
184
- packages[pkgCount] = ref;
185
- addToIndex(packageIndex, name, pkgCount);
186
- pkgCount++;
187
- }
188
- packages.length = pkgCount;
189
- return (0, import_object.ObjectFreeze)({
190
- __proto__: null,
191
- type: "lockfile",
192
- lockVersion: String(data.lockfileVersion ?? 1),
193
- ecosystem: "npm",
194
- packages: (0, import_object.ObjectFreeze)(packages),
195
- _index: packageIndex
196
- });
158
+ const packageIndex = { __proto__: null };
159
+ const pkgKeys = require_primordials_object.ObjectKeys(rawPackages);
160
+ const packages = require_primordials_array.ArrayFrom({ length: rawPackages[""] !== void 0 ? pkgKeys.length - 1 : pkgKeys.length });
161
+ let pkgCount = 0;
162
+ for (let ki = 0, { length } = pkgKeys; ki < length; ki++) {
163
+ const pkgPath = pkgKeys[ki];
164
+ if (pkgPath === "") continue;
165
+ const pkg = rawPackages[pkgPath];
166
+ const nameFromPath = require_eco_npm_npm_extract_package_name_from_path.extractPackageNameFromPath(pkgPath);
167
+ const name = typeof pkg.name === "string" && pkg.name.length > 0 ? pkg.name : nameFromPath;
168
+ packages[pkgCount] = buildPackageRef(name, pkg);
169
+ addToIndex(packageIndex, name, pkgCount);
170
+ pkgCount++;
171
+ }
172
+ packages.length = pkgCount;
173
+ return require_primordials_object.ObjectFreeze({
174
+ __proto__: null,
175
+ type: "lockfile",
176
+ lockVersion: String(data.lockfileVersion ?? 1),
177
+ ecosystem: "npm",
178
+ packages: require_primordials_object.ObjectFreeze(packages),
179
+ _index: packageIndex
180
+ });
197
181
  }
198
182
  function resolveDepType(pkg) {
199
- if (pkg.dev) {
200
- return "dev";
201
- }
202
- if (pkg.optional) {
203
- return "optional";
204
- }
205
- if (pkg.peer) {
206
- return "peer";
207
- }
208
- return "prod";
183
+ if (pkg.dev) return "dev";
184
+ if (pkg.optional) return "optional";
185
+ if (pkg.peer) return "peer";
186
+ return "prod";
209
187
  }
210
- const _smol = (0, import_manifest.getSmolManifest)();
211
- const parsePackageLock = _smol ? (
212
- /* c8 ignore next 2 - smol Node binary only. */
213
- (content) => _smol.parseLockfile(content, "npm", "npm")
214
- ) : jsParsePackageLock;
215
- // Annotate the CommonJS export names for ESM import in node:
216
- 0 && (module.exports = {
217
- addToIndex,
218
- buildPackageRef,
219
- jsParsePackageLock,
220
- parsePackageLock,
221
- parseV1,
222
- parseV2V3,
223
- resolveDepType
224
- });
188
+ const _smol = /* @__PURE__ */ require_smol_manifest.getSmolManifest();
189
+ const parsePackageLock = _smol ? (content) => _smol.parseLockfile(content, "npm", "npm") : jsParsePackageLock;
190
+
191
+ //#endregion
192
+ exports.addToIndex = addToIndex;
193
+ exports.buildPackageRef = buildPackageRef;
194
+ exports.jsParsePackageLock = jsParsePackageLock;
195
+ exports.parsePackageLock = parsePackageLock;
196
+ exports.parseV1 = parseV1;
197
+ exports.parseV2V3 = parseV2V3;
198
+ exports.resolveDepType = resolveDepType;
@@ -1,115 +1,84 @@
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_package_json_exports = {};
22
- __export(parse_package_json_exports, {
23
- addDeps: () => addDeps,
24
- asOptionalString: () => asOptionalString,
25
- jsParsePackageJson: () => jsParsePackageJson,
26
- parsePackageJson: () => parsePackageJson,
27
- resolveRepository: () => resolveRepository
28
- });
29
- module.exports = __toCommonJS(parse_package_json_exports);
30
- var import_manifest_error = require("../manifest/manifest-error");
31
- var import_message = require("../../errors/message");
32
- var import_array = require("../../primordials/array");
33
- var import_json = require("../../primordials/json");
34
- var import_object = require("../../primordials/object");
35
- var import_manifest = require("../../smol/manifest");
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+ const require_primordials_array = require('../../primordials/array.js');
5
+ const require_primordials_object = require('../../primordials/object.js');
6
+ const require_primordials_json = require('../../primordials/json.js');
7
+ const require_errors_message = require('../../errors/message.js');
8
+ const require_smol_manifest = require('../../smol/manifest.js');
9
+ const require_eco_manifest_manifest_error = require('../manifest/manifest-error.js');
10
+
11
+ //#region src/eco/npm/parse-package-json.ts
12
+ /**
13
+ * @file `parsePackageJson(content)` parses a `package.json` string into a
14
+ * `ParsedManifest`. On socket-btm's smol Node binary this routes to
15
+ * `node:smol-manifest`'s native `parseManifest(content, 'npm')`; on stock
16
+ * Node it runs the JS impl below. Both return byte-equivalent frozen shapes.
17
+ * Throws `ManifestError` with code `ERR_INVALID_JSON` on JSON parse failure.
18
+ * Anything else is non-throwing: missing/extra fields, weird types in
19
+ * dep-record values, etc. are accepted — `package.json` in the wild is messy,
20
+ * and downstream consumers can re-validate if they care.
21
+ */
36
22
  const PROD = "prod";
37
23
  const DEV = "dev";
38
24
  const OPTIONAL = "optional";
39
25
  const PEER = "peer";
40
26
  function addDeps(dependencies, obj, type) {
41
- if (!obj || typeof obj !== "object") {
42
- return;
43
- }
44
- const record = obj;
45
- const keys = (0, import_object.ObjectKeys)(record);
46
- for (let i = 0, { length } = keys; i < length; i++) {
47
- const name = keys[i];
48
- const range = record[name];
49
- (0, import_array.ArrayPrototypePush)(
50
- dependencies,
51
- (0, import_object.ObjectFreeze)({
52
- __proto__: null,
53
- name,
54
- versionRange: typeof range === "string" ? range : String(range ?? ""),
55
- type,
56
- optional: type === OPTIONAL
57
- })
58
- );
59
- }
27
+ if (!obj || typeof obj !== "object") return;
28
+ const record = obj;
29
+ const keys = require_primordials_object.ObjectKeys(record);
30
+ for (let i = 0, { length } = keys; i < length; i++) {
31
+ const name = keys[i];
32
+ const range = record[name];
33
+ require_primordials_array.ArrayPrototypePush(dependencies, require_primordials_object.ObjectFreeze({
34
+ __proto__: null,
35
+ name,
36
+ versionRange: typeof range === "string" ? range : String(range ?? ""),
37
+ type,
38
+ optional: type === OPTIONAL
39
+ }));
40
+ }
60
41
  }
61
42
  function asOptionalString(value) {
62
- return typeof value === "string" && value.length > 0 ? value : void 0;
43
+ return typeof value === "string" && value.length > 0 ? value : void 0;
63
44
  }
64
45
  function jsParsePackageJson(content) {
65
- let data;
66
- try {
67
- data = (0, import_json.JSONParse)(content);
68
- } catch (e) {
69
- throw new import_manifest_error.ManifestError(
70
- `Invalid JSON: ${(0, import_message.errorMessage)(e)}`,
71
- "ERR_INVALID_JSON"
72
- );
73
- }
74
- const dependencies = [];
75
- addDeps(dependencies, data.dependencies, PROD);
76
- addDeps(dependencies, data.devDependencies, DEV);
77
- addDeps(dependencies, data.peerDependencies, PEER);
78
- addDeps(dependencies, data.optionalDependencies, OPTIONAL);
79
- return (0, import_object.ObjectFreeze)({
80
- __proto__: null,
81
- type: "manifest",
82
- name: asOptionalString(data.name),
83
- version: asOptionalString(data.version),
84
- description: asOptionalString(data.description),
85
- license: asOptionalString(data.license),
86
- repository: resolveRepository(data.repository),
87
- dependencies: (0, import_object.ObjectFreeze)(dependencies),
88
- ecosystem: "npm"
89
- });
46
+ let data;
47
+ try {
48
+ data = require_primordials_json.JSONParse(content);
49
+ } catch (e) {
50
+ throw new require_eco_manifest_manifest_error.ManifestError(`Invalid JSON: ${require_errors_message.errorMessage(e)}`, "ERR_INVALID_JSON");
51
+ }
52
+ const dependencies = [];
53
+ addDeps(dependencies, data.dependencies, PROD);
54
+ addDeps(dependencies, data.devDependencies, DEV);
55
+ addDeps(dependencies, data.peerDependencies, PEER);
56
+ addDeps(dependencies, data.optionalDependencies, OPTIONAL);
57
+ return require_primordials_object.ObjectFreeze({
58
+ __proto__: null,
59
+ type: "manifest",
60
+ name: asOptionalString(data.name),
61
+ version: asOptionalString(data.version),
62
+ description: asOptionalString(data.description),
63
+ license: asOptionalString(data.license),
64
+ repository: resolveRepository(data.repository),
65
+ dependencies: require_primordials_object.ObjectFreeze(dependencies),
66
+ ecosystem: "npm"
67
+ });
90
68
  }
91
69
  function resolveRepository(value) {
92
- if (typeof value === "string") {
93
- return value.length > 0 ? value : void 0;
94
- }
95
- if (value && typeof value === "object") {
96
- const url = value.url;
97
- if (typeof url === "string" && url.length > 0) {
98
- return url;
99
- }
100
- }
101
- return void 0;
70
+ if (typeof value === "string") return value.length > 0 ? value : void 0;
71
+ if (value && typeof value === "object") {
72
+ const url = value.url;
73
+ if (typeof url === "string" && url.length > 0) return url;
74
+ }
102
75
  }
103
- const _smol = (0, import_manifest.getSmolManifest)();
104
- const parsePackageJson = _smol ? (
105
- /* c8 ignore next 1 - smol Node binary only. */
106
- (content) => _smol.parseManifest(content, "npm")
107
- ) : jsParsePackageJson;
108
- // Annotate the CommonJS export names for ESM import in node:
109
- 0 && (module.exports = {
110
- addDeps,
111
- asOptionalString,
112
- jsParsePackageJson,
113
- parsePackageJson,
114
- resolveRepository
115
- });
76
+ const _smol = /* @__PURE__ */ require_smol_manifest.getSmolManifest();
77
+ const parsePackageJson = _smol ? (content) => _smol.parseManifest(content, "npm") : jsParsePackageJson;
78
+
79
+ //#endregion
80
+ exports.addDeps = addDeps;
81
+ exports.asOptionalString = asOptionalString;
82
+ exports.jsParsePackageJson = jsParsePackageJson;
83
+ exports.parsePackageJson = parsePackageJson;
84
+ exports.resolveRepository = resolveRepository;