@socketsecurity/lib 6.0.2 → 6.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (552) hide show
  1. package/CHANGELOG.md +34 -0
  2. package/dist/_virtual/_rolldown/runtime.js +45 -0
  3. package/dist/abort/signal.js +53 -59
  4. package/dist/ai/discover.js +110 -110
  5. package/dist/ai/profiles.d.mts +48 -25
  6. package/dist/ai/profiles.js +95 -59
  7. package/dist/ai/spawn.d.mts +2 -2
  8. package/dist/ai/spawn.js +172 -194
  9. package/dist/ai/types.d.mts +3 -3
  10. package/dist/ai/types.js +1 -17
  11. package/dist/ai/worktree.d.mts +2 -2
  12. package/dist/ai/worktree.js +160 -183
  13. package/dist/ansi/constants.js +16 -38
  14. package/dist/ansi/strip.js +44 -41
  15. package/dist/archives/_internal.js +64 -73
  16. package/dist/archives/detect.js +30 -43
  17. package/dist/archives/extract.js +43 -50
  18. package/dist/archives/tar.js +197 -228
  19. package/dist/archives/types.js +1 -17
  20. package/dist/archives/zip.js +85 -121
  21. package/dist/argv/flag-predicates.js +203 -101
  22. package/dist/argv/flag-types.js +96 -113
  23. package/dist/argv/parse-args-string.d.ts +16 -14
  24. package/dist/argv/parse-args-string.js +42 -39
  25. package/dist/argv/parse.js +145 -163
  26. package/dist/arrays/_internal.js +65 -48
  27. package/dist/arrays/chunk.js +51 -40
  28. package/dist/arrays/join.js +87 -35
  29. package/dist/arrays/predicates.js +46 -28
  30. package/dist/arrays/unique.js +45 -31
  31. package/dist/bin/_internal.js +34 -42
  32. package/dist/bin/check-primordials.js +175 -233
  33. package/dist/bin/check.js +51 -72
  34. package/dist/bin/exec.js +70 -74
  35. package/dist/bin/find.js +151 -134
  36. package/dist/bin/resolve.js +180 -246
  37. package/dist/bin/shadow.js +24 -33
  38. package/dist/bin/socket-lib.js +51 -73
  39. package/dist/bin/types.js +1 -17
  40. package/dist/bin/which.js +211 -146
  41. package/dist/cacache/_internal.js +25 -40
  42. package/dist/cacache/clear.js +79 -72
  43. package/dist/cacache/read.js +48 -46
  44. package/dist/cacache/tmp.js +29 -36
  45. package/dist/cacache/types.js +1 -17
  46. package/dist/cacache/write.js +43 -48
  47. package/dist/cache/ttl/store.js +232 -288
  48. package/dist/cache/ttl/types.js +1 -17
  49. package/dist/checks/primordials-defaults.js +83 -89
  50. package/dist/checks/primordials.js +225 -277
  51. package/dist/colors/convert.js +45 -37
  52. package/dist/colors/palette.js +88 -45
  53. package/dist/colors/socket-palette.js +74 -84
  54. package/dist/colors/types.js +1 -17
  55. package/dist/compression/_internal.js +57 -72
  56. package/dist/compression/brotli.js +94 -127
  57. package/dist/compression/gzip.js +95 -121
  58. package/dist/compression/types.js +1 -17
  59. package/dist/constants/agents.js +61 -113
  60. package/dist/constants/encoding.js +19 -42
  61. package/dist/constants/github.js +12 -30
  62. package/dist/constants/licenses.js +48 -63
  63. package/dist/constants/lifecycle-script-names.js +31 -45
  64. package/dist/constants/maintained-node-versions.js +22 -37
  65. package/dist/constants/node.js +226 -167
  66. package/dist/constants/package-default-node-range.js +16 -41
  67. package/dist/constants/package-default-socket-categories.js +12 -30
  68. package/dist/constants/packages.js +77 -126
  69. package/dist/constants/platform.js +27 -49
  70. package/dist/constants/sentinels.js +23 -48
  71. package/dist/constants/socket.js +42 -87
  72. package/dist/constants/testing.js +15 -34
  73. package/dist/constants/time.js +16 -36
  74. package/dist/constants/typescript.js +32 -52
  75. package/dist/cover/code.js +111 -142
  76. package/dist/cover/formatters.js +118 -101
  77. package/dist/cover/type.js +50 -76
  78. package/dist/cover/types.js +1 -17
  79. package/dist/crypto/hash.js +54 -46
  80. package/dist/debug/_internal.js +62 -71
  81. package/dist/debug/caller-info.js +53 -64
  82. package/dist/debug/namespace.js +80 -90
  83. package/dist/debug/output.js +172 -188
  84. package/dist/debug/types.js +1 -17
  85. package/dist/dlx/_internal.js +24 -43
  86. package/dist/dlx/arborist.js +162 -160
  87. package/dist/dlx/binary-cache.js +228 -200
  88. package/dist/dlx/binary-download.js +172 -211
  89. package/dist/dlx/binary-resolution.js +165 -157
  90. package/dist/dlx/binary-types.js +1 -17
  91. package/dist/dlx/binary.js +149 -189
  92. package/dist/dlx/cache.js +45 -30
  93. package/dist/dlx/detect.js +245 -167
  94. package/dist/dlx/dir.js +67 -51
  95. package/dist/dlx/firewall.js +62 -100
  96. package/dist/dlx/lockfile.js +122 -127
  97. package/dist/dlx/manifest.js +264 -274
  98. package/dist/dlx/package.js +241 -244
  99. package/dist/dlx/packages.js +99 -96
  100. package/dist/dlx/paths.js +73 -59
  101. package/dist/dlx/spec.js +52 -60
  102. package/dist/dlx/types.js +1 -17
  103. package/dist/eco/cargo/lockfile-format.js +19 -36
  104. package/dist/eco/cargo/manifest-format.js +17 -35
  105. package/dist/eco/cargo/parse-lockfile.js +210 -237
  106. package/dist/eco/manifest/analyze-lockfile.js +46 -63
  107. package/dist/eco/manifest/detect-format.js +66 -90
  108. package/dist/eco/manifest/find-packages.js +39 -64
  109. package/dist/eco/manifest/get-package-versions.js +27 -48
  110. package/dist/eco/manifest/get-package.js +21 -40
  111. package/dist/eco/manifest/manifest-error.js +14 -35
  112. package/dist/eco/manifest/parse-lockfile.js +40 -86
  113. package/dist/eco/manifest/parse-manifest.js +26 -43
  114. package/dist/eco/manifest/parse.js +26 -47
  115. package/dist/eco/manifest/types.js +1 -17
  116. package/dist/eco/npm/bun/exec.js +23 -32
  117. package/dist/eco/npm/manifest-format.js +21 -35
  118. package/dist/eco/npm/npm/exec.js +51 -61
  119. package/dist/eco/npm/npm/extract-package-name-from-path.js +28 -50
  120. package/dist/eco/npm/npm/flags.js +80 -52
  121. package/dist/eco/npm/npm/lockfile-format.js +21 -40
  122. package/dist/eco/npm/npm/parse-git-url.js +26 -40
  123. package/dist/eco/npm/npm/parse-lockfile.js +184 -210
  124. package/dist/eco/npm/parse-package-json.js +71 -102
  125. package/dist/eco/npm/pnpm/detect-pnpm-version.js +22 -43
  126. package/dist/eco/npm/pnpm/exec.js +51 -62
  127. package/dist/eco/npm/pnpm/flags.js +75 -68
  128. package/dist/eco/npm/pnpm/lockfile-format.js +19 -36
  129. package/dist/eco/npm/pnpm/parse-lockfile.js +235 -259
  130. package/dist/eco/npm/pnpm/parse-pnpm-package-id-v5.js +37 -47
  131. package/dist/eco/npm/pnpm/parse-pnpm-package-id-v6-v9.js +36 -49
  132. package/dist/eco/npm/script.js +82 -90
  133. package/dist/eco/npm/vlt/exec.js +24 -32
  134. package/dist/eco/npm/yarnpkg/yarn/exec.js +60 -59
  135. package/dist/eco/npm/yarnpkg/yarn/lockfile-format.js +20 -36
  136. package/dist/eco/npm/yarnpkg/yarn/parse-lockfile.js +194 -242
  137. package/dist/eco/npm/yarnpkg/yarn/parse-yarn-descriptor.js +37 -61
  138. package/dist/eco/purl.js +50 -60
  139. package/dist/eco/types.js +1 -17
  140. package/dist/effects/pulse-frames.js +64 -65
  141. package/dist/effects/shimmer-keyframes.js +71 -52
  142. package/dist/effects/shimmer-terminal.js +81 -50
  143. package/dist/effects/shimmer.js +290 -153
  144. package/dist/env/boolean.js +42 -43
  145. package/dist/env/case-insensitive.js +54 -39
  146. package/dist/env/ci.js +29 -31
  147. package/dist/env/debug.js +28 -31
  148. package/dist/env/github.js +144 -59
  149. package/dist/env/home.js +38 -31
  150. package/dist/env/locale.js +59 -39
  151. package/dist/env/node-auth-token.js +28 -31
  152. package/dist/env/node-env.js +28 -31
  153. package/dist/env/npm.js +94 -47
  154. package/dist/env/number.js +50 -51
  155. package/dist/env/package-manager.js +95 -83
  156. package/dist/env/path.js +28 -31
  157. package/dist/env/pre-commit.js +30 -32
  158. package/dist/env/proxy.js +121 -122
  159. package/dist/env/rewire.js +204 -96
  160. package/dist/env/shell.js +28 -31
  161. package/dist/env/socket-cli.js +233 -81
  162. package/dist/env/socket.js +521 -156
  163. package/dist/env/string.js +43 -44
  164. package/dist/env/temp-dir.js +59 -39
  165. package/dist/env/term.js +28 -31
  166. package/dist/env/test.js +65 -43
  167. package/dist/env/types.js +1 -17
  168. package/dist/env/windows.js +78 -43
  169. package/dist/env/xdg.js +62 -39
  170. package/dist/errors/message.js +40 -46
  171. package/dist/errors/predicates.js +61 -49
  172. package/dist/errors/stack.js +24 -36
  173. package/dist/events/exit/_internal.js +86 -103
  174. package/dist/events/exit/handler.js +48 -55
  175. package/dist/events/exit/intercept.js +49 -70
  176. package/dist/events/exit/lifecycle.js +92 -101
  177. package/dist/events/exit/signals.js +25 -31
  178. package/dist/events/exit/types.js +1 -17
  179. package/dist/events/warning/handler.js +43 -40
  180. package/dist/events/warning/suppress.js +111 -90
  181. package/dist/external/@npmcli/package-json/lib/read-package.js +132 -153
  182. package/dist/external/@npmcli/package-json/lib/sort.js +73 -105
  183. package/dist/external/@npmcli/package-json.js +12705 -15140
  184. package/dist/external/@npmcli/promise-spawn.js +451 -472
  185. package/dist/external/@sinclair/typebox/value.js +7443 -9002
  186. package/dist/external/@sinclair/typebox.js +7516 -7885
  187. package/dist/external/@socketregistry/is-unicode-supported.js +31 -39
  188. package/dist/external/@socketregistry/packageurl-js.js +6127 -7369
  189. package/dist/external/@socketregistry/yocto-spinner.js +394 -455
  190. package/dist/external/@yarnpkg/extensions.js +435 -1022
  191. package/dist/external/adm-zip.js +2313 -2673
  192. package/dist/external/debug.js +700 -687
  193. package/dist/external/external-pack.js +2658 -3171
  194. package/dist/external/fast-sort.js +124 -138
  195. package/dist/external/get-east-asian-width.js +70 -64
  196. package/dist/external/libnpmexec.js +28 -31
  197. package/dist/external/npm-pack.js +43617 -50137
  198. package/dist/external/p-map.js +198 -222
  199. package/dist/external/pico-pack.js +6735 -7304
  200. package/dist/external/pony-cause.js +143 -139
  201. package/dist/external/shell-quote.js +226 -0
  202. package/dist/external/spdx-pack.js +1283 -1403
  203. package/dist/external/streaming-iterables.js +835 -1052
  204. package/dist/external/tar-fs.js +2769 -3048
  205. package/dist/external/which.js +267 -251
  206. package/dist/external/yargs-parser.js +851 -1074
  207. package/dist/external-tools/bazel/asset-names.js +98 -90
  208. package/dist/external-tools/bazel/from-download.js +52 -46
  209. package/dist/external-tools/bazel/from-path.js +27 -38
  210. package/dist/external-tools/bazel/read-bazel-version-file.js +35 -57
  211. package/dist/external-tools/bazel/resolve-asset-url.js +24 -39
  212. package/dist/external-tools/bazel/resolve-bazel-version.js +34 -56
  213. package/dist/external-tools/bazel/resolve.js +44 -58
  214. package/dist/external-tools/bazel/types.js +1 -17
  215. package/dist/external-tools/cdxgen/asset-names.js +59 -66
  216. package/dist/external-tools/cdxgen/from-download.js +52 -80
  217. package/dist/external-tools/cdxgen/from-path.js +19 -37
  218. package/dist/external-tools/cdxgen/from-vfs.js +22 -43
  219. package/dist/external-tools/cdxgen/resolve.js +48 -63
  220. package/dist/external-tools/cdxgen/types.js +1 -17
  221. package/dist/external-tools/from-download.js +107 -67
  222. package/dist/external-tools/janus/asset-names.js +44 -51
  223. package/dist/external-tools/janus/from-download.js +45 -70
  224. package/dist/external-tools/janus/from-path.js +19 -37
  225. package/dist/external-tools/janus/from-vfs.js +22 -43
  226. package/dist/external-tools/janus/resolve.js +45 -63
  227. package/dist/external-tools/janus/types.js +1 -17
  228. package/dist/external-tools/jre/asset-names.js +109 -82
  229. package/dist/external-tools/jre/detect-platform-arch.js +25 -49
  230. package/dist/external-tools/jre/from-download.js +71 -67
  231. package/dist/external-tools/jre/from-java-home.js +27 -54
  232. package/dist/external-tools/jre/from-path.js +27 -49
  233. package/dist/external-tools/jre/from-vfs.js +39 -60
  234. package/dist/external-tools/jre/resolve.js +55 -68
  235. package/dist/external-tools/jre/types.js +1 -17
  236. package/dist/external-tools/manifest.js +130 -150
  237. package/dist/external-tools/opengrep/asset-names.js +60 -72
  238. package/dist/external-tools/opengrep/from-download.js +58 -80
  239. package/dist/external-tools/opengrep/from-path.js +19 -37
  240. package/dist/external-tools/opengrep/from-vfs.js +23 -43
  241. package/dist/external-tools/opengrep/resolve.js +43 -63
  242. package/dist/external-tools/opengrep/types.js +1 -17
  243. package/dist/external-tools/sbt/asset-names.js +21 -30
  244. package/dist/external-tools/sbt/from-download.js +50 -61
  245. package/dist/external-tools/sbt/from-path.js +23 -38
  246. package/dist/external-tools/sbt/from-vfs.js +30 -44
  247. package/dist/external-tools/sbt/resolve.js +45 -63
  248. package/dist/external-tools/sbt/types.js +1 -17
  249. package/dist/external-tools/synp/asset-names.js +11 -29
  250. package/dist/external-tools/synp/from-download.js +24 -41
  251. package/dist/external-tools/synp/from-path.js +19 -37
  252. package/dist/external-tools/synp/from-vfs.js +22 -43
  253. package/dist/external-tools/synp/resolve.js +43 -62
  254. package/dist/external-tools/synp/types.js +1 -17
  255. package/dist/external-tools/trivy/asset-names.js +51 -62
  256. package/dist/external-tools/trivy/from-download.js +42 -64
  257. package/dist/external-tools/trivy/from-path.js +19 -37
  258. package/dist/external-tools/trivy/from-vfs.js +22 -43
  259. package/dist/external-tools/trivy/resolve.js +43 -63
  260. package/dist/external-tools/trivy/types.js +1 -17
  261. package/dist/external-tools/trufflehog/asset-names.js +54 -66
  262. package/dist/external-tools/trufflehog/from-download.js +44 -62
  263. package/dist/external-tools/trufflehog/from-path.js +21 -37
  264. package/dist/external-tools/trufflehog/from-vfs.js +26 -43
  265. package/dist/external-tools/trufflehog/resolve.js +43 -63
  266. package/dist/external-tools/trufflehog/types.js +1 -17
  267. package/dist/external-tools/uv/asset-names.js +64 -74
  268. package/dist/external-tools/uv/from-download.js +44 -65
  269. package/dist/external-tools/uv/from-path.js +19 -37
  270. package/dist/external-tools/uv/from-vfs.js +22 -43
  271. package/dist/external-tools/uv/resolve.js +42 -63
  272. package/dist/external-tools/uv/types.js +1 -17
  273. package/dist/fs/_internal.js +40 -42
  274. package/dist/fs/access.d.ts +32 -0
  275. package/dist/fs/access.js +66 -0
  276. package/dist/fs/encoding.js +80 -97
  277. package/dist/fs/find-up.js +126 -147
  278. package/dist/fs/inspect.js +168 -99
  279. package/dist/fs/path-cache.js +31 -32
  280. package/dist/fs/read-dir.js +102 -79
  281. package/dist/fs/read-file.js +177 -118
  282. package/dist/fs/read-json-cache.js +150 -134
  283. package/dist/fs/read-json.js +172 -187
  284. package/dist/fs/resolve-module.d.ts +57 -0
  285. package/dist/fs/resolve-module.js +40 -0
  286. package/dist/fs/safe.js +278 -169
  287. package/dist/fs/types.js +1 -17
  288. package/dist/fs/unique.js +52 -48
  289. package/dist/fs/validate.js +56 -43
  290. package/dist/fs/write-json.js +109 -75
  291. package/dist/git/_internal.js +251 -216
  292. package/dist/git/changed.js +191 -74
  293. package/dist/git/repo.js +118 -104
  294. package/dist/git/staged.js +172 -62
  295. package/dist/git/types.js +1 -17
  296. package/dist/git/unstaged.js +175 -62
  297. package/dist/github/constants.js +25 -33
  298. package/dist/github/errors.js +46 -38
  299. package/dist/github/fetch.js +137 -82
  300. package/dist/github/ghsa.js +217 -151
  301. package/dist/github/refs-cache.js +54 -43
  302. package/dist/github/refs-graphql.js +97 -89
  303. package/dist/github/refs-rest.js +70 -101
  304. package/dist/github/refs.js +105 -64
  305. package/dist/github/token.js +96 -48
  306. package/dist/github/types.js +1 -17
  307. package/dist/globs/_internal.js +73 -82
  308. package/dist/globs/defaults.js +40 -59
  309. package/dist/globs/match.js +93 -77
  310. package/dist/globs/matcher.js +104 -92
  311. package/dist/globs/stream.js +43 -55
  312. package/dist/globs/types.js +1 -17
  313. package/dist/http-request/_internal.js +11 -38
  314. package/dist/http-request/browser-fetch.js +19 -29
  315. package/dist/http-request/browser.js +188 -206
  316. package/dist/http-request/checksums.js +101 -65
  317. package/dist/http-request/download-types.js +1 -17
  318. package/dist/http-request/download.js +195 -196
  319. package/dist/http-request/errors.js +39 -47
  320. package/dist/http-request/headers.js +95 -80
  321. package/dist/http-request/http-request.js +10 -35
  322. package/dist/http-request/node.js +71 -97
  323. package/dist/http-request/request-attempt.js +232 -285
  324. package/dist/http-request/request-types.js +1 -17
  325. package/dist/http-request/request.js +106 -108
  326. package/dist/http-request/response-reader.js +47 -51
  327. package/dist/http-request/response-types.js +22 -38
  328. package/dist/http-request/user-agent.js +73 -55
  329. package/dist/integrity.js +105 -106
  330. package/dist/ipc/_internal.js +34 -48
  331. package/dist/ipc/directory.js +55 -63
  332. package/dist/ipc/paths.js +52 -45
  333. package/dist/ipc/types.js +1 -17
  334. package/dist/ipc/write.js +81 -74
  335. package/dist/ipc-cli/get.js +29 -56
  336. package/dist/ipc-cli/types.js +1 -17
  337. package/dist/json/edit.js +182 -242
  338. package/dist/json/format.js +202 -103
  339. package/dist/json/parse.js +206 -109
  340. package/dist/json/types.js +1 -17
  341. package/dist/links/create.js +93 -60
  342. package/dist/links/types.js +1 -17
  343. package/dist/logger/_internal.js +109 -73
  344. package/dist/logger/browser.js +45 -56
  345. package/dist/logger/colors.js +31 -49
  346. package/dist/logger/console.js +89 -112
  347. package/dist/logger/default.js +19 -33
  348. package/dist/logger/logger.js +5 -29
  349. package/dist/logger/node.js +794 -854
  350. package/dist/logger/symbols-builder.js +54 -56
  351. package/dist/logger/symbols.js +135 -118
  352. package/dist/logger/types.js +1 -17
  353. package/dist/memo/_internal.js +39 -49
  354. package/dist/memo/async.js +133 -117
  355. package/dist/memo/clear.js +25 -34
  356. package/dist/memo/decorator.js +43 -37
  357. package/dist/memo/memoize.js +97 -88
  358. package/dist/memo/once.js +42 -41
  359. package/dist/memo/types.js +1 -17
  360. package/dist/memo/weak.js +45 -41
  361. package/dist/node/async-hooks.js +9 -30
  362. package/dist/node/child-process.js +9 -30
  363. package/dist/node/crypto.js +9 -30
  364. package/dist/node/events.js +9 -30
  365. package/dist/node/fs-promises.js +9 -30
  366. package/dist/node/fs.js +9 -30
  367. package/dist/node/http.js +9 -30
  368. package/dist/node/https.js +9 -30
  369. package/dist/node/module.js +20 -34
  370. package/dist/node/os.js +9 -30
  371. package/dist/node/path.js +9 -30
  372. package/dist/node/timers-promises.js +9 -30
  373. package/dist/node/url.js +9 -30
  374. package/dist/node/util.js +9 -30
  375. package/dist/objects/getters.js +185 -126
  376. package/dist/objects/inspect.js +85 -52
  377. package/dist/objects/mutate.js +96 -76
  378. package/dist/objects/predicates.js +112 -59
  379. package/dist/objects/sort.js +120 -76
  380. package/dist/objects/types.js +1 -17
  381. package/dist/packages/edit-class.js +198 -265
  382. package/dist/packages/edit.js +79 -86
  383. package/dist/packages/exports.js +146 -157
  384. package/dist/packages/isolation.js +159 -209
  385. package/dist/packages/licenses.js +207 -189
  386. package/dist/packages/manifest.js +134 -172
  387. package/dist/packages/normalize.js +91 -102
  388. package/dist/packages/operations.d.ts +2 -0
  389. package/dist/packages/operations.js +283 -254
  390. package/dist/packages/provenance.js +195 -245
  391. package/dist/packages/specs.js +94 -84
  392. package/dist/packages/types.js +1 -17
  393. package/dist/packages/validation.js +49 -50
  394. package/dist/paths/_internal.js +82 -86
  395. package/dist/paths/conversion.js +112 -65
  396. package/dist/paths/dirnames.js +17 -42
  397. package/dist/paths/exts.js +23 -54
  398. package/dist/paths/filenames.js +21 -50
  399. package/dist/paths/globs.js +15 -38
  400. package/dist/paths/normalize.js +215 -236
  401. package/dist/paths/packages.js +34 -49
  402. package/dist/paths/predicates.js +184 -106
  403. package/dist/paths/resolve.js +146 -128
  404. package/dist/paths/rewire.js +108 -72
  405. package/dist/paths/socket.js +252 -132
  406. package/dist/paths/walk.d.ts +40 -0
  407. package/dist/paths/walk.js +58 -0
  408. package/dist/perf/_internal.js +10 -28
  409. package/dist/perf/enabled.js +21 -30
  410. package/dist/perf/metrics.js +81 -67
  411. package/dist/perf/report.js +79 -80
  412. package/dist/perf/timer.js +180 -126
  413. package/dist/perf/types.js +1 -17
  414. package/dist/pkg-ext/data.js +29 -82
  415. package/dist/pkg-ext/types.js +1 -17
  416. package/dist/primordials/array.js +120 -198
  417. package/dist/primordials/buffer.js +28 -51
  418. package/dist/primordials/date.js +26 -51
  419. package/dist/primordials/error.js +33 -59
  420. package/dist/primordials/function.js +21 -41
  421. package/dist/primordials/globals.js +25 -48
  422. package/dist/primordials/json.js +14 -30
  423. package/dist/primordials/map-set.js +88 -152
  424. package/dist/primordials/math.js +59 -116
  425. package/dist/primordials/number.js +41 -76
  426. package/dist/primordials/object.js +56 -116
  427. package/dist/primordials/promise.js +28 -52
  428. package/dist/primordials/reflect.js +24 -52
  429. package/dist/primordials/regexp.js +25 -47
  430. package/dist/primordials/string.js +114 -167
  431. package/dist/primordials/symbol.js +40 -72
  432. package/dist/primordials/uncurry.js +38 -55
  433. package/dist/primordials/url.js +27 -66
  434. package/dist/process/_internal.js +7 -32
  435. package/dist/process/abort.js +29 -35
  436. package/dist/process/lock-instance.js +26 -30
  437. package/dist/process/lock-manager.js +279 -307
  438. package/dist/process/lock-types.js +1 -17
  439. package/dist/process/spawn/_internal.js +43 -55
  440. package/dist/process/spawn/child.js +172 -211
  441. package/dist/process/spawn/errors.js +116 -113
  442. package/dist/process/spawn/stdio.js +51 -35
  443. package/dist/process/spawn/types.js +1 -17
  444. package/dist/process/transient.js +49 -66
  445. package/dist/promises/_internal.d.ts +8 -2
  446. package/dist/promises/_internal.js +31 -38
  447. package/dist/promises/iterate.js +238 -102
  448. package/dist/promises/options.js +123 -101
  449. package/dist/promises/queue.js +115 -136
  450. package/dist/promises/resolvers.js +77 -46
  451. package/dist/promises/retry.js +156 -101
  452. package/dist/promises/types.js +1 -17
  453. package/dist/regexps/escape.js +32 -30
  454. package/dist/regexps/hex.js +16 -33
  455. package/dist/regexps/spec.js +53 -81
  456. package/dist/releases/github-archives.js +127 -118
  457. package/dist/releases/github-asset-url.js +162 -155
  458. package/dist/releases/github-assets.js +37 -49
  459. package/dist/releases/github-auth.js +32 -48
  460. package/dist/releases/github-downloads.js +118 -138
  461. package/dist/releases/github-listing.js +175 -154
  462. package/dist/releases/github-retry-config.d.ts +31 -0
  463. package/dist/releases/github-retry-config.js +46 -0
  464. package/dist/releases/github-types.js +1 -17
  465. package/dist/releases/socket-btm.js +273 -192
  466. package/dist/schema/parse.js +35 -36
  467. package/dist/schema/types.js +1 -17
  468. package/dist/schema/validate.js +118 -99
  469. package/dist/sea/detect.js +57 -52
  470. package/dist/secrets/_internal.js +86 -67
  471. package/dist/secrets/find.js +96 -77
  472. package/dist/secrets/keychain.js +315 -309
  473. package/dist/secrets/linux.js +133 -135
  474. package/dist/secrets/macos.js +151 -147
  475. package/dist/secrets/rc.js +182 -181
  476. package/dist/secrets/socket-api-token.js +28 -43
  477. package/dist/secrets/types.js +1 -17
  478. package/dist/secrets/windows.js +184 -242
  479. package/dist/shadow/skip.js +51 -70
  480. package/dist/shadow/types.js +1 -17
  481. package/dist/shell/parse.d.ts +26 -0
  482. package/dist/shell/parse.js +35 -0
  483. package/dist/shell/quote.d.ts +19 -0
  484. package/dist/shell/quote.js +30 -0
  485. package/dist/smol/detect.js +67 -43
  486. package/dist/smol/http.js +33 -37
  487. package/dist/smol/https.js +31 -37
  488. package/dist/smol/manifest.js +33 -37
  489. package/dist/smol/path.d.ts +51 -0
  490. package/dist/smol/path.js +38 -0
  491. package/dist/smol/primordial.js +35 -37
  492. package/dist/smol/purl.js +34 -37
  493. package/dist/smol/versions.js +31 -37
  494. package/dist/smol/vfs.js +46 -38
  495. package/dist/sorts/_internal.js +14 -40
  496. package/dist/sorts/natural.js +57 -64
  497. package/dist/sorts/semver.js +33 -43
  498. package/dist/sorts/strings.js +24 -30
  499. package/dist/sorts/types.js +1 -17
  500. package/dist/spinner/default.js +72 -63
  501. package/dist/spinner/format.js +86 -71
  502. package/dist/spinner/spinner.js +749 -797
  503. package/dist/spinner/types.js +1 -17
  504. package/dist/spinner/with.js +193 -137
  505. package/dist/ssri/convert.js +64 -47
  506. package/dist/ssri/parse.js +38 -37
  507. package/dist/ssri/validate.js +51 -34
  508. package/dist/stdio/_internal.js +50 -46
  509. package/dist/stdio/clear.js +208 -86
  510. package/dist/stdio/divider.js +170 -97
  511. package/dist/stdio/footer.js +116 -110
  512. package/dist/stdio/header.js +117 -90
  513. package/dist/stdio/progress.js +189 -218
  514. package/dist/stdio/prompts.js +244 -168
  515. package/dist/stdio/stderr.js +173 -78
  516. package/dist/stdio/stdout.js +177 -94
  517. package/dist/streams/parallel.js +58 -50
  518. package/dist/streams/transform.js +36 -45
  519. package/dist/strings/format.js +145 -63
  520. package/dist/strings/predicates.js +56 -34
  521. package/dist/strings/search.js +52 -42
  522. package/dist/strings/transform.js +113 -72
  523. package/dist/strings/types.js +1 -17
  524. package/dist/strings/width.js +89 -82
  525. package/dist/tables/bordered.js +81 -81
  526. package/dist/tables/padding.js +36 -46
  527. package/dist/tables/simple.js +62 -70
  528. package/dist/tables/types.js +1 -17
  529. package/dist/temporal/instant.js +72 -81
  530. package/dist/temporal/now.js +40 -31
  531. package/dist/temporal/slots.js +42 -36
  532. package/dist/temporal/system.js +36 -36
  533. package/dist/temporal/temporal.js +11 -41
  534. package/dist/themes/context.js +131 -69
  535. package/dist/themes/resolve.js +207 -132
  536. package/dist/themes/themes.js +225 -194
  537. package/dist/themes/types.js +1 -17
  538. package/dist/url/parse.js +48 -51
  539. package/dist/url/predicates.js +24 -31
  540. package/dist/url/search-params.js +133 -101
  541. package/dist/url/types.js +1 -17
  542. package/dist/versions/_internal.js +31 -33
  543. package/dist/versions/compare.js +80 -58
  544. package/dist/versions/modify.js +41 -39
  545. package/dist/versions/parse.js +88 -64
  546. package/dist/versions/range.js +58 -41
  547. package/dist/versions/types.js +1 -17
  548. package/dist/words/article.js +22 -30
  549. package/dist/words/capitalize.js +25 -34
  550. package/dist/words/pluralize.js +23 -31
  551. package/dist/words/types.js +1 -17
  552. package/package.json +42 -5
@@ -1,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,53 +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_object = require("../primordials/object");
35
- var import_string = require("../primordials/string");
36
- var import_github_assets = require("./github-assets");
37
- var import_github_auth = require("./github-auth");
38
- const RETRY_CONFIG = (0, import_object.ObjectFreeze)({
39
- __proto__: null,
40
- // Exponential backoff: delay doubles with each retry (5s, 10s, 20s).
41
- backoffFactor: 2,
42
- // Initial delay before first retry.
43
- baseDelayMs: 5e3,
44
- // Maximum number of retry attempts (excluding initial request).
45
- retries: 2
46
- });
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
+ */
47
50
  async function fetchReleasesViaGraphQL(owner, repo) {
48
- const response = await (0, import_request.httpRequest)("https://api.github.com/graphql", {
49
- body: (0, import_json.JSONStringify)({
50
- 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!) {
51
54
  repository(owner: $owner, name: $repo) {
52
55
  releases(first: 100, orderBy: {field: CREATED_AT, direction: DESC}) {
53
56
  nodes {
@@ -58,114 +61,132 @@ async function fetchReleasesViaGraphQL(owner, repo) {
58
61
  }
59
62
  }
60
63
  }`,
61
- variables: { owner, repo }
62
- }),
63
- headers: { ...(0, import_github_auth.getAuthHeaders)(), "Content-Type": "application/json" },
64
- method: "POST"
65
- });
66
- if (!response.ok) {
67
- throw new import_error.ErrorCtor(
68
- `Failed to fetch ${owner}/${repo} releases (GraphQL): ${response.status}`
69
- );
70
- }
71
- let parsed;
72
- try {
73
- parsed = (0, import_json.JSONParse)(response.body.toString("utf8"));
74
- } catch (cause) {
75
- throw new import_error.ErrorCtor(
76
- `Failed to parse GitHub GraphQL response for ${owner}/${repo} releases`,
77
- { cause }
78
- );
79
- }
80
- if (parsed.errors?.length) {
81
- throw new import_error.ErrorCtor(
82
- `GraphQL repository.releases(${owner}/${repo}) returned errors: ${parsed.errors.map((e) => e.message).join("; ")}`
83
- );
84
- }
85
- return (parsed.data?.repository?.releases?.nodes ?? []).map((n) => ({
86
- tag_name: n.tagName,
87
- published_at: n.publishedAt,
88
- assets: n.releaseAssets?.nodes ?? []
89
- }));
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 */
90
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
+ */
91
115
  async function fetchReleasesViaRest(owner, repo) {
92
- const response = await (0, import_request.httpRequest)(
93
- `https://api.github.com/repos/${owner}/${repo}/releases?per_page=100`,
94
- { headers: (0, import_github_auth.getAuthHeaders)() }
95
- );
96
- if (!response.ok) {
97
- throw new import_error.ErrorCtor(
98
- `Failed to fetch ${owner}/${repo} releases: ${response.status}`
99
- );
100
- }
101
- const text = response.body.toString("utf8");
102
- if (text.length === 0) {
103
- return [];
104
- }
105
- let parsed;
106
- try {
107
- parsed = (0, import_json.JSONParse)(text);
108
- } catch (cause) {
109
- throw new import_error.ErrorCtor(`Failed to parse ${owner}/${repo} releases response`, {
110
- cause
111
- });
112
- }
113
- 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 */
114
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
+ */
115
156
  async function getLatestRelease(toolPrefix, repoConfig, options = {}) {
116
- const { assetPattern, nothrow = false } = options;
117
- const { owner, repo } = repoConfig;
118
- const isMatch = assetPattern ? (0, import_github_assets.createAssetMatcher)(assetPattern) : void 0;
119
- return await (0, import_retry.pRetry)(async () => {
120
- let releases = await fetchReleasesViaRest(owner, repo);
121
- if (releases.length === 0) {
122
- let graphqlReleases;
123
- try {
124
- graphqlReleases = await fetchReleasesViaGraphQL(owner, repo);
125
- } catch (cause) {
126
- if (nothrow) {
127
- return void 0;
128
- }
129
- throw new import_error.ErrorCtor(
130
- `Failed to list ${owner}/${repo} releases: both REST and GraphQL backends degraded`,
131
- { cause }
132
- );
133
- }
134
- if (graphqlReleases.length > 0) {
135
- releases = graphqlReleases;
136
- }
137
- }
138
- const matchingReleases = releases.filter((release) => {
139
- const { assets, tag_name: tag } = release;
140
- if (!(0, import_string.StringPrototypeStartsWith)(tag, toolPrefix)) {
141
- return false;
142
- }
143
- if (!assets || assets.length === 0) {
144
- return false;
145
- }
146
- if (isMatch) {
147
- const hasMatchingAsset = assets.some(
148
- (a) => isMatch(a.name)
149
- );
150
- if (!hasMatchingAsset) {
151
- return false;
152
- }
153
- }
154
- return true;
155
- });
156
- if (matchingReleases.length === 0) {
157
- return void 0;
158
- }
159
- matchingReleases.sort(
160
- (a, b) => (0, import_date.DateParse)(b.published_at) - (0, import_date.DateParse)(a.published_at)
161
- );
162
- const latestRelease = matchingReleases[0];
163
- return latestRelease.tag_name;
164
- }, 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;
165
187
  }
166
- // Annotate the CommonJS export names for ESM import in node:
167
- 0 && (module.exports = {
168
- fetchReleasesViaGraphQL,
169
- fetchReleasesViaRest,
170
- getLatestRelease
171
- });
188
+
189
+ //#endregion
190
+ exports.fetchReleasesViaGraphQL = fetchReleasesViaGraphQL;
191
+ exports.fetchReleasesViaRest = fetchReleasesViaRest;
192
+ exports.getLatestRelease = getLatestRelease;
@@ -0,0 +1,31 @@
1
+ /**
2
+ * @file Shared retry configuration for the GitHub release helpers
3
+ * (`github-listing`, `github-asset-url`). Exponential backoff over the
4
+ * transient-failure / rate-limit surface. `baseDelayMs` is overridable via
5
+ * `SOCKET_GITHUB_RETRY_BASE_DELAY_MS` — set it to `0` for near-instant
6
+ * retries. Tests set it so the backoff sleep (5s + 10s of real wallclock)
7
+ * doesn't run: pRetry's delay goes through `node:timers/promises`, which
8
+ * `vi.useFakeTimers()` doesn't reliably intercept, so a zero base delay is
9
+ * the robust, fake-timer-independent way to keep these tests fast. CI can
10
+ * also dial it down. Default stays 5000ms for production resilience.
11
+ */
12
+ /**
13
+ * Default base delay (ms) before the first retry when the env override is unset
14
+ * or non-numeric.
15
+ */
16
+ export declare const DEFAULT_BASE_DELAY_MS = 5000;
17
+ /**
18
+ * Resolve the retry base delay from `SOCKET_GITHUB_RETRY_BASE_DELAY_MS`,
19
+ * falling back to {@link DEFAULT_BASE_DELAY_MS}. Read live (not memoized) so
20
+ * it's unit-testable by mutating the env — and so a long-lived process that has
21
+ * the env changed under it picks up the new value on next read.
22
+ *
23
+ * @returns The configured base delay in milliseconds.
24
+ */
25
+ export declare function resolveBaseDelayMs(): number;
26
+ export declare const GITHUB_RETRY_CONFIG: Readonly<{
27
+ __proto__: null;
28
+ backoffFactor: 2;
29
+ baseDelayMs: number;
30
+ retries: 2;
31
+ }>;