@socketsecurity/lib 6.0.3 → 6.0.5

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 +22 -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 +793 -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,275 +1,304 @@
1
1
  "use strict";
2
- /* Socket Lib - Built with esbuild */
3
- "use strict";
4
- var __create = Object.create;
5
- var __defProp = Object.defineProperty;
6
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
7
- var __getOwnPropNames = Object.getOwnPropertyNames;
8
- var __getProtoOf = Object.getPrototypeOf;
9
- var __hasOwnProp = Object.prototype.hasOwnProperty;
10
- var __export = (target, all) => {
11
- for (var name in all)
12
- __defProp(target, name, { get: all[name], enumerable: true });
13
- };
14
- var __copyProps = (to, from, except, desc) => {
15
- if (from && typeof from === "object" || typeof from === "function") {
16
- for (let key of __getOwnPropNames(from))
17
- if (!__hasOwnProp.call(to, key) && key !== except)
18
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
19
- }
20
- return to;
21
- };
22
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
23
- // If the importer is in node compatibility mode or this is not an ESM
24
- // file that has been converted to a CommonJS file using a Babel-
25
- // compatible transform (i.e. "__esModule" has not been set), then set
26
- // "default" to the CommonJS "module.exports" for node compatibility.
27
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
28
- mod
29
- ));
30
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
31
- var operations_exports = {};
32
- __export(operations_exports, {
33
- extractPackage: () => extractPackage,
34
- findPackageExtensions: () => findPackageExtensions,
35
- getReleaseTag: () => getReleaseTag,
36
- packPackage: () => packPackage,
37
- pkgNameToSlug: () => pkgNameToSlug,
38
- readPackageJson: () => readPackageJson,
39
- readPackageJsonSync: () => readPackageJsonSync,
40
- resolveGitHubTgzUrl: () => resolveGitHubTgzUrl,
41
- resolvePackageName: () => resolvePackageName,
42
- resolveRegistryPackageName: () => resolveRegistryPackageName
43
- });
44
- module.exports = __toCommonJS(operations_exports);
45
- var import_packages = require("../constants/packages");
46
- var import_abort = require("../process/abort");
47
- var import_socket = require("../constants/socket");
48
- var import_cacache = __toESM(require("../external/cacache"));
49
- var import_libnpmpack = __toESM(require("../external/libnpmpack"));
50
- var import_make_fetch_happen = __toESM(require("../external/make-fetch-happen"));
51
- var import_npm_package_arg = __toESM(require("../external/npm-package-arg"));
52
- var import_packageurl_js = require("../external/@socketregistry/packageurl-js");
53
- var import_pacote = __toESM(require("../external/pacote"));
54
- var semver = __toESM(require("../external/semver"));
55
- var import_purl = require("../smol/purl");
56
- var import_read_json = require("../fs/read-json");
57
- var import_mutate = require("../objects/mutate");
58
- var import_predicates = require("../objects/predicates");
59
- var import_normalize = require("./normalize");
60
- var import_packages2 = require("../paths/packages");
61
- var import_specs = require("./specs");
62
- var import_edit = require("./edit");
63
- var import_string = require("../primordials/string");
64
- const abortSignal = (0, import_abort.getAbortSignal)();
65
- const packageExtensions = (0, import_packages.getPackageExtensions)();
66
- const packumentCache = (0, import_packages.getPackumentCache)();
67
- const pacoteCachePath = (0, import_packages.getPacoteCachePath)();
68
- const fetcher = import_make_fetch_happen.default.defaults({
69
- cachePath: pacoteCachePath,
70
- // Prefer-offline: Staleness checks for cached data will be bypassed, but
71
- // missing data will be requested from the server.
72
- // https://github.com/npm/make-fetch-happen?tab=readme-ov-file#--optscache
73
- cache: "force-cache"
74
- });
75
- // @__NO_SIDE_EFFECTS__
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+ const require_runtime = require('../_virtual/_rolldown/runtime.js');
5
+ const require_primordials_string = require('../primordials/string.js');
6
+ const require_fs_read_json = require('../fs/read-json.js');
7
+ const require_process_abort = require('../process/abort.js');
8
+ const require_objects_predicates = require('../objects/predicates.js');
9
+ const require_objects_mutate = require('../objects/mutate.js');
10
+ const require_constants_socket = require('../constants/socket.js');
11
+ const require_constants_packages = require('../constants/packages.js');
12
+ const require_smol_purl = require('../smol/purl.js');
13
+ const require_packages_normalize = require('./normalize.js');
14
+ const require_paths_packages = require('../paths/packages.js');
15
+ const require_packages_specs = require('./specs.js');
16
+ const require_packages_edit = require('./edit.js');
17
+ let src_external_cacache = require("../external/cacache");
18
+ src_external_cacache = require_runtime.__toESM(src_external_cacache);
19
+ let src_external_semver = require("../external/semver");
20
+ src_external_semver = require_runtime.__toESM(src_external_semver);
21
+ let src_external_pacote = require("../external/pacote");
22
+ src_external_pacote = require_runtime.__toESM(src_external_pacote);
23
+ let src_external_libnpmpack = require("../external/libnpmpack");
24
+ src_external_libnpmpack = require_runtime.__toESM(src_external_libnpmpack);
25
+ let src_external_make_fetch_happen = require("../external/make-fetch-happen");
26
+ src_external_make_fetch_happen = require_runtime.__toESM(src_external_make_fetch_happen);
27
+ let src_external_npm_package_arg = require("../external/npm-package-arg");
28
+ src_external_npm_package_arg = require_runtime.__toESM(src_external_npm_package_arg);
29
+ let src_external__socketregistry_packageurl_js = require("../external/@socketregistry/packageurl-js");
30
+
31
+ //#region src/packages/operations.ts
32
+ /**
33
+ * @file Package operations including extraction, packing, and I/O.
34
+ */
35
+ const abortSignal = require_process_abort.getAbortSignal();
36
+ const packageExtensions = /* @__PURE__ */ require_constants_packages.getPackageExtensions();
37
+ const packumentCache = /* @__PURE__ */ require_constants_packages.getPackumentCache();
38
+ const pacoteCachePath = /* @__PURE__ */ require_constants_packages.getPacoteCachePath();
39
+ let _fetcher;
40
+ /**
41
+ * Extract a package to a destination directory.
42
+ *
43
+ * @example
44
+ * ;```typescript
45
+ * await extractPackage('lodash@4.17.21', { dest: '/tmp/lodash' })
46
+ * ```
47
+ */
48
+ /* @__NO_SIDE_EFFECTS__ */
76
49
  async function extractPackage(pkgNameOrId, options, callback) {
77
- let actualCallback = callback;
78
- let actualOptions = options;
79
- if (arguments.length === 2 && typeof options === "function") {
80
- actualCallback = options;
81
- actualOptions = void 0;
82
- }
83
- const { dest, tmpPrefix, ...extractOptions_ } = {
84
- __proto__: null,
85
- ...actualOptions
86
- };
87
- const extractOptions = {
88
- packumentCache,
89
- preferOffline: true,
90
- ...extractOptions_
91
- };
92
- if (typeof dest === "string") {
93
- await import_pacote.default.extract(pkgNameOrId, dest, extractOptions);
94
- if (typeof actualCallback === "function") {
95
- await actualCallback(dest);
96
- }
97
- } else {
98
- await import_cacache.default.tmp.withTmp(
99
- pacoteCachePath,
100
- { tmpPrefix },
101
- async (tmpDirPath) => {
102
- await import_pacote.default.extract(pkgNameOrId, tmpDirPath, extractOptions);
103
- if (typeof actualCallback === "function") {
104
- await actualCallback(tmpDirPath);
105
- }
106
- }
107
- );
108
- }
50
+ let actualCallback = callback;
51
+ let actualOptions = options;
52
+ if (arguments.length === 2 && typeof options === "function") {
53
+ actualCallback = options;
54
+ actualOptions = void 0;
55
+ }
56
+ const { dest, tmpPrefix, ...extractOptions_ } = {
57
+ __proto__: null,
58
+ ...actualOptions
59
+ };
60
+ const extractOptions = {
61
+ packumentCache,
62
+ preferOffline: true,
63
+ ...extractOptions_
64
+ };
65
+ /* c8 ignore start - External package registry extraction */
66
+ if (typeof dest === "string") {
67
+ await src_external_pacote.default.extract(pkgNameOrId, dest, extractOptions);
68
+ if (typeof actualCallback === "function") await actualCallback(dest);
69
+ } else await src_external_cacache.default.tmp.withTmp(pacoteCachePath, { tmpPrefix }, async (tmpDirPath) => {
70
+ await src_external_pacote.default.extract(pkgNameOrId, tmpDirPath, extractOptions);
71
+ if (typeof actualCallback === "function") await actualCallback(tmpDirPath);
72
+ });
73
+ /* c8 ignore stop */
109
74
  }
110
- // @__NO_SIDE_EFFECTS__
75
+ /**
76
+ * Find package extensions for a given package.
77
+ *
78
+ * @example
79
+ * ;```typescript
80
+ * const extensions = findPackageExtensions('my-pkg', '1.0.0')
81
+ * ```
82
+ */
83
+ /* @__NO_SIDE_EFFECTS__ */
111
84
  function findPackageExtensions(pkgName, pkgVer) {
112
- let result;
113
- for (const entry of packageExtensions) {
114
- const selector = String(entry[0]);
115
- const ext = entry[1];
116
- const lastAtSignIndex = selector.lastIndexOf("@");
117
- const name = selector.slice(0, lastAtSignIndex);
118
- if (pkgName === name) {
119
- const range = selector.slice(lastAtSignIndex + 1);
120
- if (semver.satisfies(pkgVer, range)) {
121
- if (result === void 0) {
122
- result = {};
123
- }
124
- if (typeof ext === "object" && ext !== null) {
125
- (0, import_mutate.merge)(result, ext);
126
- }
127
- }
128
- }
129
- }
130
- return result;
85
+ let result;
86
+ for (const entry of packageExtensions) {
87
+ const selector = String(entry[0]);
88
+ const ext = entry[1];
89
+ const lastAtSignIndex = selector.lastIndexOf("@");
90
+ if (pkgName === selector.slice(0, lastAtSignIndex)) {
91
+ const range = selector.slice(lastAtSignIndex + 1);
92
+ if (src_external_semver.satisfies(pkgVer, range)) {
93
+ if (result === void 0) result = {};
94
+ if (typeof ext === "object" && ext !== null) /* @__PURE__ */ require_objects_mutate.merge(result, ext);
95
+ }
96
+ }
97
+ }
98
+ return result;
99
+ }
100
+ function getFetcher() {
101
+ if (_fetcher === void 0) _fetcher = src_external_make_fetch_happen.default.defaults({
102
+ cachePath: pacoteCachePath,
103
+ cache: "force-cache"
104
+ });
105
+ return _fetcher;
131
106
  }
132
- // @__NO_SIDE_EFFECTS__
107
+ /**
108
+ * Get the release tag for a version.
109
+ *
110
+ * @example
111
+ * ;```typescript
112
+ * getReleaseTag('lodash@latest') // 'latest'
113
+ * getReleaseTag('@scope/pkg@beta') // 'beta'
114
+ * getReleaseTag('lodash') // ''
115
+ * ```
116
+ */
117
+ /* @__NO_SIDE_EFFECTS__ */
133
118
  function getReleaseTag(spec) {
134
- if (!spec) {
135
- return "";
136
- }
137
- let atIndex = -1;
138
- if ((0, import_string.StringPrototypeStartsWith)(spec, "@")) {
139
- atIndex = (0, import_string.StringPrototypeIndexOf)(spec, "@", 1);
140
- } else {
141
- atIndex = (0, import_string.StringPrototypeIndexOf)(spec, "@");
142
- }
143
- if (atIndex !== -1) {
144
- return (0, import_string.StringPrototypeSlice)(spec, atIndex + 1);
145
- }
146
- return "";
119
+ if (!spec) return "";
120
+ let atIndex = -1;
121
+ if (require_primordials_string.StringPrototypeStartsWith(spec, "@")) atIndex = require_primordials_string.StringPrototypeIndexOf(spec, "@", 1);
122
+ else atIndex = require_primordials_string.StringPrototypeIndexOf(spec, "@");
123
+ if (atIndex !== -1) return require_primordials_string.StringPrototypeSlice(spec, atIndex + 1);
124
+ return "";
147
125
  }
148
- // @__NO_SIDE_EFFECTS__
126
+ /**
127
+ * Pack a package tarball using pacote.
128
+ *
129
+ * @example
130
+ * ;```typescript
131
+ * const tarball = await packPackage('lodash@4.17.21')
132
+ * ```
133
+ */
134
+ /* @__NO_SIDE_EFFECTS__ */
149
135
  async function packPackage(spec, options) {
150
- return await (0, import_libnpmpack.default)(spec, {
151
- __proto__: null,
152
- signal: abortSignal,
153
- ...options,
154
- packumentCache,
155
- preferOffline: true
156
- });
136
+ /* c8 ignore start - External package registry packing */
137
+ return await (0, src_external_libnpmpack.default)(spec, {
138
+ __proto__: null,
139
+ signal: abortSignal,
140
+ ...options,
141
+ packumentCache,
142
+ preferOffline: true
143
+ });
144
+ /* c8 ignore stop */
157
145
  }
158
- // @__NO_SIDE_EFFECTS__
146
+ /**
147
+ * Slugify an npm package name into a hyphenated identifier suitable for
148
+ * User-Agent tokens, log namespaces, file paths, and other contexts where `@`
149
+ * and `/` are not welcome.
150
+ *
151
+ * @example
152
+ * ;```typescript
153
+ * pkgNameToSlug('@socketsecurity/lib') // 'socketsecurity-lib'
154
+ * pkgNameToSlug('@cyclonedx/cdxgen') // 'cyclonedx-cdxgen'
155
+ * pkgNameToSlug('lodash') // 'lodash'
156
+ * ```
157
+ */
158
+ /* @__NO_SIDE_EFFECTS__ */
159
159
  function pkgNameToSlug(pkgName) {
160
- return pkgName.charCodeAt(0) === 64 ? `${pkgName.slice(1).replace("/", "-")}` : pkgName;
160
+ return pkgName.charCodeAt(0) === 64 ? `${pkgName.slice(1).replace("/", "-")}` : pkgName;
161
161
  }
162
- // @__NO_SIDE_EFFECTS__
162
+ /**
163
+ * Read and parse a package.json file asynchronously.
164
+ *
165
+ * @example
166
+ * ;```typescript
167
+ * const pkgJson = await readPackageJson('/tmp/my-project')
168
+ * console.log(pkgJson?.name)
169
+ * ```
170
+ */
171
+ /* @__NO_SIDE_EFFECTS__ */
163
172
  async function readPackageJson(filepath, options) {
164
- const { editable, normalize, throws, ...normalizeOptions } = {
165
- __proto__: null,
166
- ...options
167
- };
168
- const pkgJson = await (0, import_read_json.readJson)((0, import_packages2.resolvePackageJsonPath)(filepath), {
169
- throws
170
- });
171
- if (pkgJson) {
172
- if (editable) {
173
- return await (0, import_edit.toEditablePackageJson)(pkgJson, {
174
- path: filepath,
175
- normalize,
176
- ...normalizeOptions
177
- });
178
- }
179
- return normalize ? (0, import_normalize.normalizePackageJson)(pkgJson, normalizeOptions) : pkgJson;
180
- }
181
- return void 0;
173
+ const { editable, normalize, throws, ...normalizeOptions } = {
174
+ __proto__: null,
175
+ ...options
176
+ };
177
+ const pkgJson = await /* @__PURE__ */ require_fs_read_json.readJson(/* @__PURE__ */ require_paths_packages.resolvePackageJsonPath(filepath), { throws });
178
+ if (pkgJson) {
179
+ if (editable) return await /* @__PURE__ */ require_packages_edit.toEditablePackageJson(pkgJson, {
180
+ path: filepath,
181
+ normalize,
182
+ ...normalizeOptions
183
+ });
184
+ return normalize ? /* @__PURE__ */ require_packages_normalize.normalizePackageJson(pkgJson, normalizeOptions) : pkgJson;
185
+ }
182
186
  }
183
- // @__NO_SIDE_EFFECTS__
187
+ /**
188
+ * Read and parse package.json from a file path synchronously.
189
+ *
190
+ * @example
191
+ * ;```typescript
192
+ * const pkgJson = readPackageJsonSync('/tmp/my-project')
193
+ * console.log(pkgJson?.name)
194
+ * ```
195
+ */
196
+ /* @__NO_SIDE_EFFECTS__ */
184
197
  function readPackageJsonSync(filepath, options) {
185
- const { editable, normalize, throws, ...normalizeOptions } = {
186
- __proto__: null,
187
- ...options
188
- };
189
- const pkgJson = (0, import_read_json.readJsonSync)((0, import_packages2.resolvePackageJsonPath)(filepath), { throws });
190
- if (pkgJson) {
191
- if (editable) {
192
- return (0, import_edit.toEditablePackageJsonSync)(pkgJson, {
193
- path: filepath,
194
- normalize,
195
- ...normalizeOptions
196
- });
197
- }
198
- return normalize ? (0, import_normalize.normalizePackageJson)(pkgJson, normalizeOptions) : pkgJson;
199
- }
200
- return void 0;
198
+ const { editable, normalize, throws, ...normalizeOptions } = {
199
+ __proto__: null,
200
+ ...options
201
+ };
202
+ const pkgJson = /* @__PURE__ */ require_fs_read_json.readJsonSync(/* @__PURE__ */ require_paths_packages.resolvePackageJsonPath(filepath), { throws });
203
+ if (pkgJson) {
204
+ if (editable) return /* @__PURE__ */ require_packages_edit.toEditablePackageJsonSync(pkgJson, {
205
+ path: filepath,
206
+ normalize,
207
+ ...normalizeOptions
208
+ });
209
+ return normalize ? /* @__PURE__ */ require_packages_normalize.normalizePackageJson(pkgJson, normalizeOptions) : pkgJson;
210
+ }
201
211
  }
202
- // @__NO_SIDE_EFFECTS__
212
+ /**
213
+ * Resolve GitHub tarball URL for a package specifier.
214
+ *
215
+ * @example
216
+ * ;```typescript
217
+ * const url = await resolveGitHubTgzUrl('my-pkg@1.0.0', '/tmp/my-project')
218
+ * ```
219
+ */
220
+ /* @__NO_SIDE_EFFECTS__ */
203
221
  async function resolveGitHubTgzUrl(pkgNameOrId, where) {
204
- const whereIsPkgJson = (0, import_predicates.isPlainObject)(where);
205
- const pkgJson = whereIsPkgJson ? where : await /* @__PURE__ */ readPackageJson(where, { normalize: true });
206
- if (!pkgJson) {
207
- return "";
208
- }
209
- const { version } = pkgJson;
210
- const parsedSpec = (0, import_npm_package_arg.default)(
211
- pkgNameOrId,
212
- whereIsPkgJson ? void 0 : where
213
- );
214
- const isTarballUrl = (0, import_specs.isGitHubTgzSpec)(parsedSpec);
215
- if (isTarballUrl) {
216
- return parsedSpec.saveSpec || "";
217
- }
218
- const isGitHubUrl = (0, import_specs.isGitHubUrlSpec)(parsedSpec);
219
- const repository = pkgJson.repository;
220
- const { project, user } = (isGitHubUrl ? parsedSpec.hosted : (0, import_specs.getRepoUrlDetails)(repository?.url)) || { project: "", user: "" };
221
- if (user && project) {
222
- let apiUrl = "";
223
- if (isGitHubUrl) {
224
- apiUrl = (0, import_specs.gitHubTagRefUrl)(user, project, parsedSpec.gitCommittish || "");
225
- } else {
226
- const versionStr = version;
227
- apiUrl = (0, import_specs.gitHubTagRefUrl)(user, project, `v${versionStr}`);
228
- if (!(await fetcher(apiUrl, { method: "head" })).ok) {
229
- apiUrl = (0, import_specs.gitHubTagRefUrl)(user, project, versionStr);
230
- if (!(await fetcher(apiUrl, { method: "head" })).ok) {
231
- apiUrl = "";
232
- }
233
- }
234
- }
235
- if (apiUrl) {
236
- const resp = await fetcher(apiUrl);
237
- let json;
238
- try {
239
- json = await resp.json();
240
- } catch {
241
- json = void 0;
242
- }
243
- const sha = json?.object?.sha;
244
- if (sha) {
245
- return (0, import_specs.gitHubTgzUrl)(user, project, sha);
246
- }
247
- }
248
- }
249
- return "";
222
+ const whereIsPkgJson = /* @__PURE__ */ require_objects_predicates.isPlainObject(where);
223
+ const pkgJson = whereIsPkgJson ? where : await /* @__PURE__ */ readPackageJson(where, { normalize: true });
224
+ if (!pkgJson) return "";
225
+ const { version } = pkgJson;
226
+ const parsedSpec = (0, src_external_npm_package_arg.default)(pkgNameOrId, whereIsPkgJson ? void 0 : where);
227
+ if (/* @__PURE__ */ require_packages_specs.isGitHubTgzSpec(parsedSpec)) return parsedSpec.saveSpec || "";
228
+ const isGitHubUrl = /* @__PURE__ */ require_packages_specs.isGitHubUrlSpec(parsedSpec);
229
+ const repository = pkgJson.repository;
230
+ const { project, user } = (isGitHubUrl ? parsedSpec.hosted : /* @__PURE__ */ require_packages_specs.getRepoUrlDetails(repository?.url)) || {
231
+ project: "",
232
+ user: ""
233
+ };
234
+ /* c8 ignore start - External GitHub API calls */
235
+ if (user && project) {
236
+ const fetcher = getFetcher();
237
+ let apiUrl = "";
238
+ if (isGitHubUrl) apiUrl = /* @__PURE__ */ require_packages_specs.gitHubTagRefUrl(user, project, parsedSpec.gitCommittish || "");
239
+ else {
240
+ const versionStr = version;
241
+ apiUrl = /* @__PURE__ */ require_packages_specs.gitHubTagRefUrl(user, project, `v${versionStr}`);
242
+ if (!(await fetcher(apiUrl, { method: "head" })).ok) {
243
+ apiUrl = /* @__PURE__ */ require_packages_specs.gitHubTagRefUrl(user, project, versionStr);
244
+ if (!(await fetcher(apiUrl, { method: "head" })).ok) apiUrl = "";
245
+ }
246
+ }
247
+ if (apiUrl) {
248
+ const resp = await fetcher(apiUrl);
249
+ let json;
250
+ try {
251
+ json = await resp.json();
252
+ } catch {
253
+ json = void 0;
254
+ }
255
+ const sha = json?.object?.sha;
256
+ if (sha) return /* @__PURE__ */ require_packages_specs.gitHubTgzUrl(user, project, sha);
257
+ }
258
+ }
259
+ /* c8 ignore stop */
260
+ return "";
250
261
  }
251
- // @__NO_SIDE_EFFECTS__
262
+ /**
263
+ * Resolve full package name from a PURL object with custom delimiter.
264
+ *
265
+ * @example
266
+ * ;```typescript
267
+ * resolvePackageName({ name: 'core', namespace: '@babel' }) // '@babel/core'
268
+ * resolvePackageName({ name: 'lodash' }) // 'lodash'
269
+ * ```
270
+ */
271
+ /* @__NO_SIDE_EFFECTS__ */
252
272
  function resolvePackageName(purlObj, delimiter = "/") {
253
- const { name, namespace } = purlObj;
254
- return `${namespace ? `${namespace}${delimiter}` : ""}${name}`;
273
+ const { name, namespace } = purlObj;
274
+ return `${namespace ? `${namespace}${delimiter}` : ""}${name}`;
255
275
  }
256
- // @__NO_SIDE_EFFECTS__
276
+ /**
277
+ * Convert npm package name to Socket registry format with delimiter.
278
+ *
279
+ * @example
280
+ * ;```typescript
281
+ * resolveRegistryPackageName('@babel/core') // 'babel__core'
282
+ * resolveRegistryPackageName('lodash') // 'lodash'
283
+ * ```
284
+ */
285
+ /* @__NO_SIDE_EFFECTS__ */
257
286
  function resolveRegistryPackageName(pkgName) {
258
- const input = `pkg:npm/${pkgName}`;
259
- const smolPurl = (0, import_purl.getSmolPurl)();
260
- const purlObj = smolPurl ? smolPurl.parse(input) : import_packageurl_js.PackageURL.fromString(input);
261
- return purlObj.namespace ? `${purlObj.namespace.slice(1)}${import_socket.REGISTRY_SCOPE_DELIMITER}${purlObj.name}` : pkgName;
287
+ const input = `pkg:npm/${pkgName}`;
288
+ const smolPurl = /* @__PURE__ */ require_smol_purl.getSmolPurl();
289
+ const purlObj = smolPurl ? smolPurl.parse(input) : src_external__socketregistry_packageurl_js.PackageURL.fromString(input);
290
+ return purlObj.namespace ? `${purlObj.namespace.slice(1)}${"__"}${purlObj.name}` : pkgName;
262
291
  }
263
- // Annotate the CommonJS export names for ESM import in node:
264
- 0 && (module.exports = {
265
- extractPackage,
266
- findPackageExtensions,
267
- getReleaseTag,
268
- packPackage,
269
- pkgNameToSlug,
270
- readPackageJson,
271
- readPackageJsonSync,
272
- resolveGitHubTgzUrl,
273
- resolvePackageName,
274
- resolveRegistryPackageName
275
- });
292
+
293
+ //#endregion
294
+ exports.extractPackage = extractPackage;
295
+ exports.findPackageExtensions = findPackageExtensions;
296
+ exports.getFetcher = getFetcher;
297
+ exports.getReleaseTag = getReleaseTag;
298
+ exports.packPackage = packPackage;
299
+ exports.pkgNameToSlug = pkgNameToSlug;
300
+ exports.readPackageJson = readPackageJson;
301
+ exports.readPackageJsonSync = readPackageJsonSync;
302
+ exports.resolveGitHubTgzUrl = resolveGitHubTgzUrl;
303
+ exports.resolvePackageName = resolvePackageName;
304
+ exports.resolveRegistryPackageName = resolveRegistryPackageName;