@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,143 +1,123 @@
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 github_downloads_exports = {};
32
- __export(github_downloads_exports, {
33
- downloadGitHubRelease: () => downloadGitHubRelease,
34
- downloadReleaseAsset: () => downloadReleaseAsset
35
- });
36
- module.exports = __toCommonJS(github_downloads_exports);
37
- var import_node_process = __toESM(require("node:process"));
38
- var import_safe = require("../fs/safe");
39
- var import_download = require("../http-request/download");
40
- var import_default = require("../logger/default");
41
- var import_error = require("../primordials/error");
42
- var import_string = require("../primordials/string");
43
- var import_child = require("../process/spawn/child");
44
- var import_github_asset_url = require("./github-asset-url");
45
- var import_github_listing = require("./github-listing");
46
- var import_fs = require("../node/fs");
47
- var import_path = require("../node/path");
48
- const logger = (0, import_default.getDefaultLogger)();
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_error = require('../primordials/error.js');
6
+ const require_primordials_string = require('../primordials/string.js');
7
+ const require_node_fs = require('../node/fs.js');
8
+ const require_node_path = require('../node/path.js');
9
+ const require_logger_default = require('../logger/default.js');
10
+ const require_process_spawn_child = require('../process/spawn/child.js');
11
+ const require_fs_safe = require('../fs/safe.js');
12
+ const require_http_request_download = require('../http-request/download.js');
13
+ const require_releases_github_asset_url = require('./github-asset-url.js');
14
+ const require_releases_github_listing = require('./github-listing.js');
15
+ let node_process = require("node:process");
16
+ node_process = require_runtime.__toESM(node_process);
17
+
18
+ //#region src/releases/github-downloads.ts
19
+ /**
20
+ * @file GitHub release asset downloads.
21
+ */
22
+ const logger = require_logger_default.getDefaultLogger();
23
+ /**
24
+ * Download a binary from any GitHub repository with version caching.
25
+ *
26
+ * @example
27
+ * ;```typescript
28
+ * const binaryPath = await downloadGitHubRelease({
29
+ * owner: 'SocketDev',
30
+ * repo: 'socket-btm',
31
+ * toolName: 'lief',
32
+ * toolPrefix: 'lief-',
33
+ * assetName: 'lief-linux-x64',
34
+ * binaryName: 'lief',
35
+ * platformArch: 'linux-x64',
36
+ * })
37
+ * ```
38
+ *
39
+ * @param config - Download configuration.
40
+ *
41
+ * @returns Path to the downloaded binary
42
+ */
49
43
  async function downloadGitHubRelease(config) {
50
- const {
51
- assetName,
52
- binaryName,
53
- cwd = import_node_process.default.cwd(),
54
- downloadDir = "build/downloaded",
55
- owner,
56
- platformArch,
57
- quiet = false,
58
- removeMacOSQuarantine = true,
59
- repo,
60
- tag: explicitTag,
61
- toolName,
62
- toolPrefix
63
- } = config;
64
- let tag;
65
- if (explicitTag) {
66
- tag = explicitTag;
67
- } else if (toolPrefix) {
68
- const latestTag = await (0, import_github_listing.getLatestRelease)(toolPrefix, { owner, repo });
69
- if (!latestTag) {
70
- throw new import_error.ErrorCtor(`No ${toolPrefix} release found in ${owner}/${repo}`);
71
- }
72
- tag = latestTag;
73
- } else {
74
- throw new import_error.ErrorCtor("Either toolPrefix or tag must be provided");
75
- }
76
- const path = (0, import_path.getNodePath)();
77
- const resolvedDownloadDir = path.isAbsolute(downloadDir) ? downloadDir : path.join(cwd, downloadDir);
78
- const binaryDir = resolvedDownloadDir;
79
- const binaryPath = path.join(binaryDir, binaryName);
80
- const versionPath = path.join(binaryDir, ".version");
81
- const fs = (0, import_fs.getNodeFs)();
82
- if (fs.existsSync(versionPath) && fs.existsSync(binaryPath)) {
83
- const cachedVersion = (await fs.promises.readFile(versionPath, "utf8")).trim();
84
- if (cachedVersion === tag && fs.existsSync(binaryPath)) {
85
- if (!quiet) {
86
- logger.info(`Using cached ${toolName} (${platformArch}): ${binaryPath}`);
87
- }
88
- return binaryPath;
89
- }
90
- }
91
- if (!quiet) {
92
- logger.info(`Downloading ${toolName} for ${platformArch}...`);
93
- }
94
- await downloadReleaseAsset(
95
- tag,
96
- assetName,
97
- binaryPath,
98
- { owner, repo },
99
- { quiet }
100
- );
101
- const isWindows = (0, import_string.StringPrototypeEndsWith)(binaryName, ".exe");
102
- if (!isWindows) {
103
- fs.chmodSync(binaryPath, 493);
104
- if (removeMacOSQuarantine && import_node_process.default.platform === "darwin" && (0, import_string.StringPrototypeStartsWith)(platformArch, "darwin")) {
105
- try {
106
- await (0, import_child.spawn)("xattr", ["-d", "com.apple.quarantine", binaryPath], {
107
- stdio: "ignore"
108
- });
109
- } catch {
110
- }
111
- }
112
- }
113
- await fs.promises.writeFile(versionPath, tag, "utf8");
114
- if (!quiet) {
115
- logger.info(`Downloaded ${toolName} to ${binaryPath}`);
116
- }
117
- return binaryPath;
44
+ const { assetName, binaryName, cwd = node_process.default.cwd(), downloadDir = "build/downloaded", owner, platformArch, quiet = false, removeMacOSQuarantine = true, repo, tag: explicitTag, toolName, toolPrefix } = config;
45
+ let tag;
46
+ if (explicitTag) tag = explicitTag;
47
+ else if (toolPrefix) {
48
+ const latestTag = await require_releases_github_listing.getLatestRelease(toolPrefix, {
49
+ owner,
50
+ repo
51
+ });
52
+ if (!latestTag) throw new require_primordials_error.ErrorCtor(`No ${toolPrefix} release found in ${owner}/${repo}`);
53
+ tag = latestTag;
54
+ } else throw new require_primordials_error.ErrorCtor("Either toolPrefix or tag must be provided");
55
+ const path = /* @__PURE__ */ require_node_path.getNodePath();
56
+ const binaryDir = path.isAbsolute(downloadDir) ? downloadDir : path.join(cwd, downloadDir);
57
+ const binaryPath = path.join(binaryDir, binaryName);
58
+ const versionPath = path.join(binaryDir, ".version");
59
+ const fs = /* @__PURE__ */ require_node_fs.getNodeFs();
60
+ if (fs.existsSync(versionPath) && fs.existsSync(binaryPath)) {
61
+ if ((await fs.promises.readFile(versionPath, "utf8")).trim() === tag && fs.existsSync(binaryPath)) {
62
+ if (!quiet) logger.info(`Using cached ${toolName} (${platformArch}): ${binaryPath}`);
63
+ return binaryPath;
64
+ }
65
+ }
66
+ if (!quiet) logger.info(`Downloading ${toolName} for ${platformArch}...`);
67
+ await downloadReleaseAsset(tag, assetName, binaryPath, {
68
+ owner,
69
+ repo
70
+ }, { quiet });
71
+ if (!require_primordials_string.StringPrototypeEndsWith(binaryName, ".exe")) {
72
+ fs.chmodSync(binaryPath, 493);
73
+ if (removeMacOSQuarantine && node_process.default.platform === "darwin" && require_primordials_string.StringPrototypeStartsWith(platformArch, "darwin")) try {
74
+ await require_process_spawn_child.spawn("xattr", [
75
+ "-d",
76
+ "com.apple.quarantine",
77
+ binaryPath
78
+ ], { stdio: "ignore" });
79
+ } catch {}
80
+ }
81
+ await fs.promises.writeFile(versionPath, tag, "utf8");
82
+ if (!quiet) logger.info(`Downloaded ${toolName} to ${binaryPath}`);
83
+ return binaryPath;
118
84
  }
85
+ /**
86
+ * Download a specific release asset. Supports pattern matching for dynamic
87
+ * asset discovery.
88
+ *
89
+ * @example
90
+ * ;```typescript
91
+ * await downloadReleaseAsset('v1.0.0', 'tool-linux-x64', '/tmp/tool', {
92
+ * owner: 'SocketDev',
93
+ * repo: 'socket-btm',
94
+ * })
95
+ * ```
96
+ *
97
+ * @param tag - Release tag name.
98
+ * @param assetPattern - Asset name or pattern (glob string, prefix/suffix
99
+ * object, or RegExp)
100
+ * @param outputPath - Path to write the downloaded file.
101
+ * @param repoConfig - Repository configuration (owner/repo)
102
+ * @param options - Additional options.
103
+ */
119
104
  async function downloadReleaseAsset(tag, assetPattern, outputPath, repoConfig, options = {}) {
120
- const { owner, repo } = repoConfig;
121
- const { quiet = false } = options;
122
- const downloadUrl = await (0, import_github_asset_url.getReleaseAssetUrl)(tag, assetPattern, {
123
- owner,
124
- repo
125
- });
126
- if (!downloadUrl) {
127
- const patternDesc = typeof assetPattern === "string" ? assetPattern : "matching pattern";
128
- throw new import_error.ErrorCtor(`Asset ${patternDesc} not found in release ${tag}`);
129
- }
130
- const path = (0, import_path.getNodePath)();
131
- await (0, import_safe.safeMkdir)(path.dirname(outputPath));
132
- await (0, import_download.httpDownload)(downloadUrl, outputPath, {
133
- logger: quiet ? void 0 : logger,
134
- progressInterval: 10,
135
- retries: 2,
136
- retryDelay: 5e3
137
- });
105
+ const { owner, repo } = repoConfig;
106
+ const { quiet = false } = options;
107
+ const downloadUrl = await require_releases_github_asset_url.getReleaseAssetUrl(tag, assetPattern, {
108
+ owner,
109
+ repo
110
+ });
111
+ if (!downloadUrl) throw new require_primordials_error.ErrorCtor(`Asset ${typeof assetPattern === "string" ? assetPattern : "matching pattern"} not found in release ${tag}`);
112
+ await require_fs_safe.safeMkdir((/* @__PURE__ */ require_node_path.getNodePath()).dirname(outputPath));
113
+ await require_http_request_download.httpDownload(downloadUrl, outputPath, {
114
+ logger: quiet ? void 0 : logger,
115
+ progressInterval: 10,
116
+ retries: 2,
117
+ retryDelay: 5e3
118
+ });
138
119
  }
139
- // Annotate the CommonJS export names for ESM import in node:
140
- 0 && (module.exports = {
141
- downloadGitHubRelease,
142
- downloadReleaseAsset
143
- });
120
+
121
+ //#endregion
122
+ exports.downloadGitHubRelease = downloadGitHubRelease;
123
+ exports.downloadReleaseAsset = downloadReleaseAsset;
@@ -1,44 +1,56 @@
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 github_listing_exports = {};
22
- __export(github_listing_exports, {
23
- fetchReleasesViaGraphQL: () => fetchReleasesViaGraphQL,
24
- fetchReleasesViaRest: () => fetchReleasesViaRest,
25
- getLatestRelease: () => getLatestRelease
26
- });
27
- module.exports = __toCommonJS(github_listing_exports);
28
- var import_request = require("../http-request/request");
29
- var import_retry = require("../promises/retry");
30
- var import_array = require("../primordials/array");
31
- var import_date = require("../primordials/date");
32
- var import_error = require("../primordials/error");
33
- var import_json = require("../primordials/json");
34
- var import_string = require("../primordials/string");
35
- var import_github_assets = require("./github-assets");
36
- var import_github_auth = require("./github-auth");
37
- var import_github_retry_config = require("./github-retry-config");
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_date = require('../primordials/date.js');
8
+ const require_primordials_json = require('../primordials/json.js');
9
+ const require_promises_retry = require('../promises/retry.js');
10
+ const require_http_request_request = require('../http-request/request.js');
11
+ const require_releases_github_assets = require('./github-assets.js');
12
+ const require_releases_github_auth = require('./github-auth.js');
13
+ const require_releases_github_retry_config = require('./github-retry-config.js');
14
+
15
+ //#region src/releases/github-listing.ts
16
+ /**
17
+ * @file GitHub release listing via REST + GraphQL. Split out of
18
+ * `releases/github-api.ts` for size hygiene. Holds the "list all releases for
19
+ * a repo" path (both transports + the latest-matching-tag picker that
20
+ * composes them):
21
+ *
22
+ * - `fetchReleasesViaRest` — canonical REST `/releases?per_page=100` listing
23
+ * - `fetchReleasesViaGraphQL` GraphQL fallback when REST's ES index is
24
+ * degraded
25
+ * - `getLatestRelease` REST → GraphQL fallback + prefix/asset filter The
26
+ * per-tag asset-URL lookup lives in `./github-asset-url`.
27
+ */
28
+ /**
29
+ * Fetch the latest 100 releases for a repo via GraphQL.
30
+ *
31
+ * Why this exists: `fetchReleasesViaRest` can return `[]` for two reasons (real
32
+ * empty repo vs. GitHub-incident-degraded backend). When REST returns nothing,
33
+ * the caller in `getLatestRelease` calls THIS to disambiguate — if we return >0
34
+ * here, REST was lying.
35
+ *
36
+ * Field shape diffs we normalize: GraphQL returns REST equivalent Why they
37
+ * differ `tagName` `tag_name` camelCase vs. snake_case `publishedAt`
38
+ * `published_at` camelCase vs. snake_case `releaseAssets.nodes` `assets`
39
+ * GraphQL connection wrapper unwrapped.
40
+ *
41
+ * We re-shape inside the `.map(...)` at the bottom so callers downstream can
42
+ * use the SAME code path regardless of which transport ran.
43
+ *
44
+ * Why we hit a different backend: GraphQL queries don't go through the same
45
+ * Elasticsearch index that REST listings rely on. During incidents that drop
46
+ * the ES index (or its connectivity), GraphQL's `repository.releases`
47
+ * connection keeps working because it reads from a different data path inside
48
+ * GitHub. That's the entire reason this fallback exists.
49
+ */
38
50
  async function fetchReleasesViaGraphQL(owner, repo) {
39
- const response = await (0, import_request.httpRequest)("https://api.github.com/graphql", {
40
- body: (0, import_json.JSONStringify)({
41
- query: `query($owner: String!, $repo: String!) {
51
+ const response = await require_http_request_request.httpRequest("https://api.github.com/graphql", {
52
+ body: require_primordials_json.JSONStringify({
53
+ query: `query($owner: String!, $repo: String!) {
42
54
  repository(owner: $owner, name: $repo) {
43
55
  releases(first: 100, orderBy: {field: CREATED_AT, direction: DESC}) {
44
56
  nodes {
@@ -49,114 +61,132 @@ async function fetchReleasesViaGraphQL(owner, repo) {
49
61
  }
50
62
  }
51
63
  }`,
52
- variables: { owner, repo }
53
- }),
54
- headers: { ...(0, import_github_auth.getAuthHeaders)(), "Content-Type": "application/json" },
55
- method: "POST"
56
- });
57
- if (!response.ok) {
58
- throw new import_error.ErrorCtor(
59
- `Failed to fetch ${owner}/${repo} releases (GraphQL): ${response.status}`
60
- );
61
- }
62
- let parsed;
63
- try {
64
- parsed = (0, import_json.JSONParse)(response.body.toString("utf8"));
65
- } catch (cause) {
66
- throw new import_error.ErrorCtor(
67
- `Failed to parse GitHub GraphQL response for ${owner}/${repo} releases`,
68
- { cause }
69
- );
70
- }
71
- if (parsed.errors?.length) {
72
- throw new import_error.ErrorCtor(
73
- `GraphQL repository.releases(${owner}/${repo}) returned errors: ${parsed.errors.map((e) => e.message).join("; ")}`
74
- );
75
- }
76
- return (parsed.data?.repository?.releases?.nodes ?? []).map((n) => ({
77
- tag_name: n.tagName,
78
- published_at: n.publishedAt,
79
- assets: n.releaseAssets?.nodes ?? []
80
- }));
64
+ variables: {
65
+ owner,
66
+ repo
67
+ }
68
+ }),
69
+ headers: {
70
+ ...require_releases_github_auth.getAuthHeaders(),
71
+ "Content-Type": "application/json"
72
+ },
73
+ method: "POST"
74
+ });
75
+ if (!response.ok) throw new require_primordials_error.ErrorCtor(`Failed to fetch ${owner}/${repo} releases (GraphQL): ${response.status}`);
76
+ let parsed;
77
+ try {
78
+ parsed = require_primordials_json.JSONParse(response.body.toString("utf8"));
79
+ } catch (cause) {
80
+ throw new require_primordials_error.ErrorCtor(`Failed to parse GitHub GraphQL response for ${owner}/${repo} releases`, { cause });
81
+ }
82
+ /* c8 ignore start */
83
+ if (parsed.errors?.length) throw new require_primordials_error.ErrorCtor(`GraphQL repository.releases(${owner}/${repo}) returned errors: ${parsed.errors.map((e) => e.message).join("; ")}`);
84
+ return (parsed.data?.repository?.releases?.nodes ?? []).map((n) => ({
85
+ tag_name: n.tagName,
86
+ published_at: n.publishedAt,
87
+ assets: n.releaseAssets?.nodes ?? []
88
+ }));
89
+ /* c8 ignore stop */
81
90
  }
91
+ /**
92
+ * Fetch the latest 100 releases for a repo via REST.
93
+ *
94
+ * Why this returns `[]` on TWO different cases:
95
+ *
96
+ * - HTTP 200 + zero-byte body. This is the documented GitHub "search degraded"
97
+ * incident shape (see status.github.com). The releases listing endpoint
98
+ * shares an Elasticsearch index with search; when that ES is degraded,
99
+ * `/releases` returns a successful 200 OK but with NO BODY. There's no error
100
+ * code, no Retry-After, no rate-limit header — just an empty payload.
101
+ * - HTTP 200 + literal `[]`. This is the _normal_ "the repo has no releases"
102
+ * response — say a brand-new repo with no published versions.
103
+ *
104
+ * Both produce the same `[]` here because the helper can't tell them apart
105
+ * without context. The CALLER (getLatestRelease) does the cross-check: if REST
106
+ * returns `[]`, query GraphQL once. If GraphQL also returns `[]`, the repo
107
+ * really is empty. If it returns >0, REST was lying and we use GraphQL's
108
+ * answer.
109
+ *
110
+ * Why we throw on non-OK status: `pRetry` wraps this call and retries on thrown
111
+ * errors with exponential backoff. A 5xx is transient and worth retrying; we
112
+ * want it to throw so pRetry can do its job. Empty body is NOT thrown because
113
+ * pRetry can't help — a 200 OK is "done" as far as retry policy is concerned.
114
+ */
82
115
  async function fetchReleasesViaRest(owner, repo) {
83
- const response = await (0, import_request.httpRequest)(
84
- `https://api.github.com/repos/${owner}/${repo}/releases?per_page=100`,
85
- { headers: (0, import_github_auth.getAuthHeaders)() }
86
- );
87
- if (!response.ok) {
88
- throw new import_error.ErrorCtor(
89
- `Failed to fetch ${owner}/${repo} releases: ${response.status}`
90
- );
91
- }
92
- const text = response.body.toString("utf8");
93
- if (text.length === 0) {
94
- return [];
95
- }
96
- let parsed;
97
- try {
98
- parsed = (0, import_json.JSONParse)(text);
99
- } catch (cause) {
100
- throw new import_error.ErrorCtor(`Failed to parse ${owner}/${repo} releases response`, {
101
- cause
102
- });
103
- }
104
- return (0, import_array.ArrayIsArray)(parsed) ? parsed : [];
116
+ const response = await require_http_request_request.httpRequest(`https://api.github.com/repos/${owner}/${repo}/releases?per_page=100`, { headers: require_releases_github_auth.getAuthHeaders() });
117
+ if (!response.ok) throw new require_primordials_error.ErrorCtor(`Failed to fetch ${owner}/${repo} releases: ${response.status}`);
118
+ const text = response.body.toString("utf8");
119
+ if (text.length === 0) return [];
120
+ let parsed;
121
+ try {
122
+ parsed = require_primordials_json.JSONParse(text);
123
+ } catch (cause) {
124
+ throw new require_primordials_error.ErrorCtor(`Failed to parse ${owner}/${repo} releases response`, { cause });
125
+ }
126
+ /* c8 ignore start */
127
+ return require_primordials_array.ArrayIsArray(parsed) ? parsed : [];
128
+ /* c8 ignore stop */
105
129
  }
130
+ /**
131
+ * Get latest release tag matching a tool prefix. Optionally filter by releases
132
+ * containing a matching asset.
133
+ *
134
+ * @example
135
+ * ;```typescript
136
+ * const tag = await getLatestRelease('lief-', {
137
+ * owner: 'SocketDev',
138
+ * repo: 'socket-btm',
139
+ * })
140
+ * console.log(tag) // 'lief-2025-01-15-abc1234'
141
+ * ```
142
+ *
143
+ * @param toolPrefix - Tool name prefix to search for (e.g., 'node-smol-')
144
+ * @param repoConfig - Repository configuration (owner/repo)
145
+ * @param options - Additional options.
146
+ * @param options.assetPattern - Optional pattern to filter releases by matching
147
+ * asset.
148
+ * @param options.nothrow - If true, return undefined instead of throwing when
149
+ * both REST and GraphQL backends are degraded. Default: false.
150
+ *
151
+ * @returns Latest release tag or undefined if not found
152
+ *
153
+ * @throws {Error} If both REST and GraphQL backends are degraded and nothrow is
154
+ * false.
155
+ */
106
156
  async function getLatestRelease(toolPrefix, repoConfig, options = {}) {
107
- const { assetPattern, nothrow = false } = options;
108
- const { owner, repo } = repoConfig;
109
- const isMatch = assetPattern ? (0, import_github_assets.createAssetMatcher)(assetPattern) : void 0;
110
- return await (0, import_retry.pRetry)(async () => {
111
- let releases = await fetchReleasesViaRest(owner, repo);
112
- if (releases.length === 0) {
113
- let graphqlReleases;
114
- try {
115
- graphqlReleases = await fetchReleasesViaGraphQL(owner, repo);
116
- } catch (cause) {
117
- if (nothrow) {
118
- return void 0;
119
- }
120
- throw new import_error.ErrorCtor(
121
- `Failed to list ${owner}/${repo} releases: both REST and GraphQL backends degraded`,
122
- { cause }
123
- );
124
- }
125
- if (graphqlReleases.length > 0) {
126
- releases = graphqlReleases;
127
- }
128
- }
129
- const matchingReleases = releases.filter((release) => {
130
- const { assets, tag_name: tag } = release;
131
- if (!(0, import_string.StringPrototypeStartsWith)(tag, toolPrefix)) {
132
- return false;
133
- }
134
- if (!assets || assets.length === 0) {
135
- return false;
136
- }
137
- if (isMatch) {
138
- const hasMatchingAsset = assets.some(
139
- (a) => isMatch(a.name)
140
- );
141
- if (!hasMatchingAsset) {
142
- return false;
143
- }
144
- }
145
- return true;
146
- });
147
- if (matchingReleases.length === 0) {
148
- return void 0;
149
- }
150
- matchingReleases.sort(
151
- (a, b) => (0, import_date.DateParse)(b.published_at) - (0, import_date.DateParse)(a.published_at)
152
- );
153
- const latestRelease = matchingReleases[0];
154
- return latestRelease.tag_name;
155
- }, import_github_retry_config.GITHUB_RETRY_CONFIG) ?? void 0;
157
+ const { assetPattern, nothrow = false } = options;
158
+ const { owner, repo } = repoConfig;
159
+ const isMatch = assetPattern ? require_releases_github_assets.createAssetMatcher(assetPattern) : void 0;
160
+ return await /* @__PURE__ */ require_promises_retry.pRetry(async () => {
161
+ let releases = await fetchReleasesViaRest(owner, repo);
162
+ if (releases.length === 0) {
163
+ let graphqlReleases;
164
+ try {
165
+ graphqlReleases = await fetchReleasesViaGraphQL(owner, repo);
166
+ } catch (cause) {
167
+ /* c8 ignore next 7 - REST + GraphQL both-degraded branch
168
+ requires both real backends to fail simultaneously. */
169
+ if (nothrow) return;
170
+ throw new require_primordials_error.ErrorCtor(`Failed to list ${owner}/${repo} releases: both REST and GraphQL backends degraded`, { cause });
171
+ }
172
+ if (graphqlReleases.length > 0) releases = graphqlReleases;
173
+ }
174
+ const matchingReleases = releases.filter((release) => {
175
+ const { assets, tag_name: tag } = release;
176
+ if (!require_primordials_string.StringPrototypeStartsWith(tag, toolPrefix)) return false;
177
+ if (!assets || assets.length === 0) return false;
178
+ if (isMatch) {
179
+ if (!assets.some((a) => isMatch(a.name))) return false;
180
+ }
181
+ return true;
182
+ });
183
+ if (matchingReleases.length === 0) return;
184
+ matchingReleases.sort((a, b) => require_primordials_date.DateParse(b.published_at) - require_primordials_date.DateParse(a.published_at));
185
+ return matchingReleases[0].tag_name;
186
+ }, require_releases_github_retry_config.GITHUB_RETRY_CONFIG) ?? void 0;
156
187
  }
157
- // Annotate the CommonJS export names for ESM import in node:
158
- 0 && (module.exports = {
159
- fetchReleasesViaGraphQL,
160
- fetchReleasesViaRest,
161
- getLatestRelease
162
- });
188
+
189
+ //#endregion
190
+ exports.fetchReleasesViaGraphQL = fetchReleasesViaGraphQL;
191
+ exports.fetchReleasesViaRest = fetchReleasesViaRest;
192
+ exports.getLatestRelease = getLatestRelease;