@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,273 +1,223 @@
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 provenance_exports = {};
32
- __export(provenance_exports, {
33
- TRUST_LEVELS: () => TRUST_LEVELS,
34
- compareTrust: () => compareTrust,
35
- didTrustDecrease: () => didTrustDecrease,
36
- fetchPackageProvenance: () => fetchPackageProvenance,
37
- findProvenance: () => findProvenance,
38
- getAttestations: () => getAttestations,
39
- getFetcher: () => getFetcher,
40
- getProvenanceDetails: () => getProvenanceDetails,
41
- getTrustLevel: () => getTrustLevel,
42
- getTrustLevelName: () => getTrustLevelName,
43
- getTrustStatus: () => getTrustStatus,
44
- isTrustedPublisher: () => isTrustedPublisher
45
- });
46
- module.exports = __toCommonJS(provenance_exports);
47
- var import_agents = require("../constants/agents");
48
- var import_packages = require("../constants/packages");
49
- var import_make_fetch_happen = __toESM(require("../external/make-fetch-happen"));
50
- var import_signal = require("../abort/signal");
51
- var import_parse = require("../url/parse");
52
- var import_predicates = require("../objects/predicates");
53
- var import_array = require("../primordials/array");
54
- var import_buffer = require("../primordials/buffer");
55
- var import_json = require("../primordials/json");
56
- var import_object = require("../primordials/object");
57
- var import_string = require("../primordials/string");
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_buffer = require('../primordials/buffer.js');
6
+ const require_primordials_string = require('../primordials/string.js');
7
+ const require_abort_signal = require('../abort/signal.js');
8
+ const require_primordials_array = require('../primordials/array.js');
9
+ const require_primordials_object = require('../primordials/object.js');
10
+ const require_primordials_json = require('../primordials/json.js');
11
+ const require_objects_predicates = require('../objects/predicates.js');
12
+ const require_constants_agents = require('../constants/agents.js');
13
+ const require_constants_packages = require('../constants/packages.js');
14
+ const require_url_parse = require('../url/parse.js');
15
+ let src_external_make_fetch_happen = require("../external/make-fetch-happen");
16
+ src_external_make_fetch_happen = require_runtime.__toESM(src_external_make_fetch_happen);
17
+
18
+ //#region src/packages/provenance.ts
19
+ /**
20
+ * @file Package provenance and attestation verification utilities.
21
+ */
58
22
  const SLSA_PROVENANCE_V0_2 = "https://slsa.dev/provenance/v0.2";
59
23
  const SLSA_PROVENANCE_V1_0 = "https://slsa.dev/provenance/v1";
60
24
  let _fetcher;
25
+ /**
26
+ * Comparator ordering two trust statuses by ascending trust level. Sorts an
27
+ * array of statuses lowest-trust-first; negate for highest-first.
28
+ */
61
29
  function compareTrust(a, b) {
62
- const levelA = getTrustLevel(a);
63
- const levelB = getTrustLevel(b);
64
- if (levelA < levelB) {
65
- return -1;
66
- }
67
- if (levelA > levelB) {
68
- return 1;
69
- }
70
- return 0;
30
+ const levelA = getTrustLevel(a);
31
+ const levelB = getTrustLevel(b);
32
+ if (levelA < levelB) return -1;
33
+ if (levelA > levelB) return 1;
34
+ return 0;
71
35
  }
36
+ /**
37
+ * Whether `next` sits at a lower trust level than `prev` — i.e. a release
38
+ * regressed its supply-chain posture. Drives the post-publish provenance
39
+ * reminder: a version that drops from trustedPublisher back to bare provenance
40
+ * is a red flag worth surfacing.
41
+ */
72
42
  function didTrustDecrease(prev, next) {
73
- return getTrustLevel(next) < getTrustLevel(prev);
43
+ return getTrustLevel(next) < getTrustLevel(prev);
74
44
  }
75
- // @__NO_SIDE_EFFECTS__
45
+ /**
46
+ * Fetch package provenance information from npm registry.
47
+ *
48
+ * @example
49
+ * ;```typescript
50
+ * const provenance = await fetchPackageProvenance('lodash', '4.17.21')
51
+ * ```
52
+ */
53
+ /* @__NO_SIDE_EFFECTS__ */
76
54
  async function fetchPackageProvenance(pkgName, pkgVersion, options) {
77
- const { signal, timeout = 1e4 } = {
78
- __proto__: null,
79
- ...options
80
- };
81
- if (signal?.aborted) {
82
- return void 0;
83
- }
84
- const timeoutSignal = (0, import_signal.createTimeoutSignal)(timeout);
85
- const compositeSignal = (0, import_signal.createCompositeAbortSignal)(signal, timeoutSignal);
86
- const fetcher = /* @__PURE__ */ getFetcher();
87
- try {
88
- const response = await fetcher(
89
- // The npm registry attestations API endpoint.
90
- `${import_agents.NPM_REGISTRY_URL}/-/npm/v1/attestations/${encodeURIComponent(pkgName)}@${encodeURIComponent(pkgVersion)}`,
91
- {
92
- method: "GET",
93
- signal: compositeSignal,
94
- headers: {
95
- "User-Agent": "socket-registry"
96
- }
97
- }
98
- );
99
- if (response.ok) {
100
- return getProvenanceDetails(await response.json());
101
- }
102
- } catch {
103
- }
104
- return void 0;
55
+ const { signal, timeout = 1e4 } = {
56
+ __proto__: null,
57
+ ...options
58
+ };
59
+ if (signal?.aborted) return;
60
+ const compositeSignal = require_abort_signal.createCompositeAbortSignal(signal, require_abort_signal.createTimeoutSignal(timeout));
61
+ const fetcher = /* @__PURE__ */ getFetcher();
62
+ try {
63
+ const response = await fetcher(`${require_constants_agents.NPM_REGISTRY_URL}/-/npm/v1/attestations/${encodeURIComponent(pkgName)}@${encodeURIComponent(pkgVersion)}`, {
64
+ method: "GET",
65
+ signal: compositeSignal,
66
+ headers: { "User-Agent": "socket-registry" }
67
+ });
68
+ if (response.ok) return getProvenanceDetails(await response.json());
69
+ } catch {}
105
70
  }
71
+ /**
72
+ * Find the first attestation with valid provenance data.
73
+ */
106
74
  function findProvenance(attestations) {
107
- for (const attestation of attestations) {
108
- const att = attestation;
109
- try {
110
- let predicate = att.predicate;
111
- if (!predicate && att.bundle?.dsseEnvelope?.payload) {
112
- try {
113
- const decodedPayload = (0, import_buffer.BufferFrom)(
114
- att.bundle.dsseEnvelope.payload,
115
- "base64"
116
- ).toString("utf8");
117
- const statement = (0, import_json.JSONParse)(decodedPayload);
118
- predicate = statement.predicate;
119
- } catch {
120
- continue;
121
- }
122
- }
123
- const predicateData = predicate;
124
- if (predicateData?.buildDefinition?.externalParameters) {
125
- return {
126
- predicate,
127
- externalParameters: predicateData.buildDefinition.externalParameters
128
- };
129
- }
130
- } catch {
131
- }
132
- }
133
- return void 0;
75
+ for (const attestation of attestations) {
76
+ const att = attestation;
77
+ try {
78
+ let predicate = att.predicate;
79
+ if (!predicate && att.bundle?.dsseEnvelope?.payload) try {
80
+ predicate = require_primordials_json.JSONParse(require_primordials_buffer.BufferFrom(att.bundle.dsseEnvelope.payload, "base64").toString("utf8")).predicate;
81
+ } catch {
82
+ continue;
83
+ }
84
+ const predicateData = predicate;
85
+ if (predicateData?.buildDefinition?.externalParameters) return {
86
+ predicate,
87
+ externalParameters: predicateData.buildDefinition.externalParameters
88
+ };
89
+ } catch {}
90
+ }
134
91
  }
92
+ /**
93
+ * Extract and filter SLSA provenance attestations from attestation data.
94
+ */
135
95
  function getAttestations(attestationData) {
136
- const data = attestationData;
137
- if (!data.attestations || !(0, import_array.ArrayIsArray)(data.attestations)) {
138
- return [];
139
- }
140
- return data.attestations.filter((attestation) => {
141
- const att = attestation;
142
- return att.predicateType === SLSA_PROVENANCE_V0_2 || att.predicateType === SLSA_PROVENANCE_V1_0;
143
- });
96
+ const data = attestationData;
97
+ if (!data.attestations || !require_primordials_array.ArrayIsArray(data.attestations)) return [];
98
+ return data.attestations.filter((attestation) => {
99
+ const att = attestation;
100
+ return att.predicateType === SLSA_PROVENANCE_V0_2 || att.predicateType === SLSA_PROVENANCE_V1_0;
101
+ });
144
102
  }
145
- // @__NO_SIDE_EFFECTS__
103
+ /* @__NO_SIDE_EFFECTS__ */
146
104
  function getFetcher() {
147
- if (_fetcher === void 0) {
148
- _fetcher = import_make_fetch_happen.default.defaults({
149
- cachePath: (0, import_packages.getPacoteCachePath)(),
150
- // Prefer-offline: Staleness checks for cached data will be bypassed, but
151
- // missing data will be requested from the server.
152
- // https://github.com/npm/make-fetch-happen?tab=readme-ov-file#--optscache
153
- cache: "force-cache"
154
- });
155
- }
156
- return _fetcher;
105
+ if (_fetcher === void 0) _fetcher = src_external_make_fetch_happen.default.defaults({
106
+ cachePath: /* @__PURE__ */ require_constants_packages.getPacoteCachePath(),
107
+ cache: "force-cache"
108
+ });
109
+ return _fetcher;
157
110
  }
111
+ /**
112
+ * Convert raw attestation data to user-friendly provenance details.
113
+ *
114
+ * @example
115
+ * ;```typescript
116
+ * const details = getProvenanceDetails(attestationData)
117
+ * // { level: 'trusted', repository: '...', commitSha: '...' }
118
+ * ```
119
+ */
158
120
  function getProvenanceDetails(attestationData) {
159
- const attestations = getAttestations(attestationData);
160
- if (!attestations.length) {
161
- return void 0;
162
- }
163
- const provenance = findProvenance(attestations);
164
- if (!provenance) {
165
- return { level: "attested" };
166
- }
167
- const provenanceData = provenance;
168
- const { externalParameters, predicate } = provenanceData;
169
- const def = predicate?.buildDefinition;
170
- const workflow = externalParameters?.workflow;
171
- const workflowRef = workflow?.ref || externalParameters?.workflow_ref;
172
- const workflowUrl = externalParameters?.context;
173
- const workflowPlatform = def?.buildType;
174
- const repository = workflow?.repository || externalParameters?.repository;
175
- const gitRef = externalParameters?.ref || workflow?.ref;
176
- const commitSha = externalParameters?.sha;
177
- const workflowRunId = externalParameters?.run_id;
178
- const trusted = isTrustedPublisher(workflowRef) || isTrustedPublisher(workflowUrl) || isTrustedPublisher(workflowPlatform) || isTrustedPublisher(repository);
179
- return {
180
- commitSha,
181
- gitRef,
182
- level: trusted ? "trusted" : "attested",
183
- repository,
184
- workflowRef,
185
- workflowUrl,
186
- workflowPlatform,
187
- workflowRunId
188
- };
121
+ const attestations = getAttestations(attestationData);
122
+ if (!attestations.length) return;
123
+ const provenance = findProvenance(attestations);
124
+ if (!provenance) return { level: "attested" };
125
+ const { externalParameters, predicate } = provenance;
126
+ const def = predicate?.buildDefinition;
127
+ const workflow = externalParameters?.workflow;
128
+ const workflowRef = workflow?.ref || externalParameters?.workflow_ref;
129
+ const workflowUrl = externalParameters?.context;
130
+ const workflowPlatform = def?.buildType;
131
+ const repository = workflow?.repository || externalParameters?.repository;
132
+ const gitRef = externalParameters?.ref || workflow?.ref;
133
+ const commitSha = externalParameters?.sha;
134
+ const workflowRunId = externalParameters?.run_id;
135
+ return {
136
+ commitSha,
137
+ gitRef,
138
+ level: isTrustedPublisher(workflowRef) || isTrustedPublisher(workflowUrl) || isTrustedPublisher(workflowPlatform) || isTrustedPublisher(repository) ? "trusted" : "attested",
139
+ repository,
140
+ workflowRef,
141
+ workflowUrl,
142
+ workflowPlatform,
143
+ workflowRunId
144
+ };
189
145
  }
146
+ /**
147
+ * Map a trust status to its 0..3 ladder level.
148
+ */
190
149
  function getTrustLevel(status) {
191
- if (status.stagedPublish) {
192
- return 3;
193
- }
194
- if (status.trustedPublisher && status.provenance) {
195
- return 2;
196
- }
197
- if (status.provenance) {
198
- return 1;
199
- }
200
- return 0;
150
+ if (status.stagedPublish) return 3;
151
+ if (status.trustedPublisher && status.provenance) return 2;
152
+ if (status.provenance) return 1;
153
+ return 0;
201
154
  }
155
+ /**
156
+ * Map a trust status to its human-readable level name.
157
+ */
202
158
  function getTrustLevelName(status) {
203
- return TRUST_LEVELS[getTrustLevel(status)];
159
+ return TRUST_LEVELS[getTrustLevel(status)];
204
160
  }
161
+ /**
162
+ * Extract provenance / trusted-publisher / staged-publish flags from a registry
163
+ * version document.
164
+ */
205
165
  function getTrustStatus(meta) {
206
- const status = {
207
- provenance: false,
208
- trustedPublisher: false,
209
- // Reserved: the npm registry does not yet expose a staged-publish flag, so
210
- // this stays false until a registry signal exists to set it.
211
- stagedPublish: false
212
- };
213
- if (!(0, import_predicates.isObject)(meta)) {
214
- return status;
215
- }
216
- const npmUser = (0, import_object.ObjectHasOwn)(meta, "_npmUser") ? meta["_npmUser"] : void 0;
217
- if ((0, import_predicates.isObject)(npmUser) && (0, import_object.ObjectHasOwn)(npmUser, "trustedPublisher") && npmUser["trustedPublisher"]) {
218
- status.trustedPublisher = true;
219
- }
220
- const dist = (0, import_object.ObjectHasOwn)(meta, "dist") ? meta["dist"] : void 0;
221
- const attestations = (0, import_predicates.isObject)(dist) && (0, import_object.ObjectHasOwn)(dist, "attestations") ? dist["attestations"] : void 0;
222
- if ((0, import_predicates.isObject)(attestations) && (0, import_object.ObjectHasOwn)(attestations, "provenance") && attestations["provenance"]) {
223
- status.provenance = true;
224
- }
225
- return status;
166
+ const status = {
167
+ provenance: false,
168
+ trustedPublisher: false,
169
+ stagedPublish: false
170
+ };
171
+ if (!/* @__PURE__ */ require_objects_predicates.isObject(meta)) return status;
172
+ const npmUser = require_primordials_object.ObjectHasOwn(meta, "_npmUser") ? meta["_npmUser"] : void 0;
173
+ if (/* @__PURE__ */ require_objects_predicates.isObject(npmUser) && require_primordials_object.ObjectHasOwn(npmUser, "trustedPublisher") && npmUser["trustedPublisher"]) status.trustedPublisher = true;
174
+ const dist = require_primordials_object.ObjectHasOwn(meta, "dist") ? meta["dist"] : void 0;
175
+ const attestations = /* @__PURE__ */ require_objects_predicates.isObject(dist) && require_primordials_object.ObjectHasOwn(dist, "attestations") ? dist["attestations"] : void 0;
176
+ if (/* @__PURE__ */ require_objects_predicates.isObject(attestations) && require_primordials_object.ObjectHasOwn(attestations, "provenance") && attestations["provenance"]) status.provenance = true;
177
+ return status;
226
178
  }
179
+ /**
180
+ * Check if a value indicates a trusted publisher (GitHub or GitLab).
181
+ */
227
182
  function isTrustedPublisher(value) {
228
- if (typeof value !== "string" || !value) {
229
- return false;
230
- }
231
- let url = (0, import_parse.parseUrl)(value);
232
- let hostname = url?.hostname;
233
- if (!url && (0, import_string.StringPrototypeIncludes)(value, "@")) {
234
- const firstPart = (0, import_string.StringPrototypeSplit)(value, "@")[0];
235
- if (firstPart) {
236
- url = (0, import_parse.parseUrl)(firstPart);
237
- }
238
- if (url) {
239
- hostname = url.hostname;
240
- }
241
- }
242
- if (!url) {
243
- const httpsUrl = (0, import_parse.parseUrl)(`https://${value}`);
244
- if (httpsUrl) {
245
- hostname = httpsUrl.hostname;
246
- }
247
- }
248
- if (hostname) {
249
- return hostname === "github.com" || (0, import_string.StringPrototypeEndsWith)(hostname, ".github.com") || hostname === "gitlab.com" || (0, import_string.StringPrototypeEndsWith)(hostname, ".gitlab.com");
250
- }
251
- return (0, import_string.StringPrototypeIncludes)(value, "github") || (0, import_string.StringPrototypeIncludes)(value, "gitlab");
183
+ if (typeof value !== "string" || !value) return false;
184
+ let url = /* @__PURE__ */ require_url_parse.parseUrl(value);
185
+ let hostname = url?.hostname;
186
+ if (!url && require_primordials_string.StringPrototypeIncludes(value, "@")) {
187
+ const firstPart = require_primordials_string.StringPrototypeSplit(value, "@")[0];
188
+ if (firstPart) url = /* @__PURE__ */ require_url_parse.parseUrl(firstPart);
189
+ if (url) hostname = url.hostname;
190
+ }
191
+ if (!url) {
192
+ const httpsUrl = /* @__PURE__ */ require_url_parse.parseUrl(`https://${value}`);
193
+ if (httpsUrl) hostname = httpsUrl.hostname;
194
+ }
195
+ if (hostname) return hostname === "github.com" || require_primordials_string.StringPrototypeEndsWith(hostname, ".github.com") || hostname === "gitlab.com" || require_primordials_string.StringPrototypeEndsWith(hostname, ".gitlab.com");
196
+ return require_primordials_string.StringPrototypeIncludes(value, "github") || require_primordials_string.StringPrototypeIncludes(value, "gitlab");
252
197
  }
198
+ /**
199
+ * Trust ladder, low → high. The index IS the level (0..3), so a single array
200
+ * maps both directions: `TRUST_LEVELS[level]` → name, and
201
+ * `TRUST_LEVELS.indexOf(name)` → level. One source of truth, no parallel Record
202
+ * to keep in sync.
203
+ */
253
204
  const TRUST_LEVELS = [
254
- "none",
255
- "provenance",
256
- "trustedPublisher",
257
- "stagedPublish"
205
+ "none",
206
+ "provenance",
207
+ "trustedPublisher",
208
+ "stagedPublish"
258
209
  ];
259
- // Annotate the CommonJS export names for ESM import in node:
260
- 0 && (module.exports = {
261
- TRUST_LEVELS,
262
- compareTrust,
263
- didTrustDecrease,
264
- fetchPackageProvenance,
265
- findProvenance,
266
- getAttestations,
267
- getFetcher,
268
- getProvenanceDetails,
269
- getTrustLevel,
270
- getTrustLevelName,
271
- getTrustStatus,
272
- isTrustedPublisher
273
- });
210
+
211
+ //#endregion
212
+ exports.TRUST_LEVELS = TRUST_LEVELS;
213
+ exports.compareTrust = compareTrust;
214
+ exports.didTrustDecrease = didTrustDecrease;
215
+ exports.fetchPackageProvenance = fetchPackageProvenance;
216
+ exports.findProvenance = findProvenance;
217
+ exports.getAttestations = getAttestations;
218
+ exports.getFetcher = getFetcher;
219
+ exports.getProvenanceDetails = getProvenanceDetails;
220
+ exports.getTrustLevel = getTrustLevel;
221
+ exports.getTrustLevelName = getTrustLevelName;
222
+ exports.getTrustStatus = getTrustStatus;
223
+ exports.isTrustedPublisher = isTrustedPublisher;