@blamejs/blamejs-shop 0.0.44

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 (1220) hide show
  1. package/CHANGELOG.md +87 -0
  2. package/LICENSE +17 -0
  3. package/README.md +117 -0
  4. package/SECURITY.md +139 -0
  5. package/lib/admin.js +952 -0
  6. package/lib/analytics.js +267 -0
  7. package/lib/cart.js +279 -0
  8. package/lib/catalog-import.js +344 -0
  9. package/lib/catalog.js +769 -0
  10. package/lib/checkout.js +320 -0
  11. package/lib/config.js +151 -0
  12. package/lib/customers.js +322 -0
  13. package/lib/email.js +242 -0
  14. package/lib/externaldb-d1.js +283 -0
  15. package/lib/index.js +57 -0
  16. package/lib/inventory-alerts.js +198 -0
  17. package/lib/newsletter.js +142 -0
  18. package/lib/order.js +380 -0
  19. package/lib/payment.js +318 -0
  20. package/lib/pricing.js +185 -0
  21. package/lib/r2-bridge.js +169 -0
  22. package/lib/shipping.js +185 -0
  23. package/lib/storefront.js +2160 -0
  24. package/lib/subscriptions.js +410 -0
  25. package/lib/tax.js +161 -0
  26. package/lib/theme.js +194 -0
  27. package/lib/vendor/MANIFEST.json +19 -0
  28. package/lib/vendor/blamejs/.clusterfuzzlite/Dockerfile +23 -0
  29. package/lib/vendor/blamejs/.clusterfuzzlite/build.sh +34 -0
  30. package/lib/vendor/blamejs/.clusterfuzzlite/project.yaml +16 -0
  31. package/lib/vendor/blamejs/.dockerignore +45 -0
  32. package/lib/vendor/blamejs/.gitattributes +42 -0
  33. package/lib/vendor/blamejs/.github/CODEOWNERS +4 -0
  34. package/lib/vendor/blamejs/.github/FUNDING.yml +2 -0
  35. package/lib/vendor/blamejs/.github/ISSUE_TEMPLATE/bug_report.md +58 -0
  36. package/lib/vendor/blamejs/.github/ISSUE_TEMPLATE/config.yml +8 -0
  37. package/lib/vendor/blamejs/.github/ISSUE_TEMPLATE/feature_request.md +99 -0
  38. package/lib/vendor/blamejs/.github/PULL_REQUEST_TEMPLATE.md +77 -0
  39. package/lib/vendor/blamejs/.github/dependabot.yml +37 -0
  40. package/lib/vendor/blamejs/.github/workflows/actions-lint.yml +148 -0
  41. package/lib/vendor/blamejs/.github/workflows/cflite_batch.yml +107 -0
  42. package/lib/vendor/blamejs/.github/workflows/cflite_pr.yml +122 -0
  43. package/lib/vendor/blamejs/.github/workflows/ci.yml +511 -0
  44. package/lib/vendor/blamejs/.github/workflows/codeql.yml +50 -0
  45. package/lib/vendor/blamejs/.github/workflows/npm-publish.yml +655 -0
  46. package/lib/vendor/blamejs/.github/workflows/release-container.yml +406 -0
  47. package/lib/vendor/blamejs/.github/workflows/scorecard.yml +101 -0
  48. package/lib/vendor/blamejs/.github/workflows/sha-to-tag-verify.yml +134 -0
  49. package/lib/vendor/blamejs/.gitignore +102 -0
  50. package/lib/vendor/blamejs/.gitleaks.toml +166 -0
  51. package/lib/vendor/blamejs/.hadolint.yaml +18 -0
  52. package/lib/vendor/blamejs/.npmrc +5 -0
  53. package/lib/vendor/blamejs/.pinact.yaml +17 -0
  54. package/lib/vendor/blamejs/ARCHITECTURE.md +158 -0
  55. package/lib/vendor/blamejs/CHANGELOG.md +1351 -0
  56. package/lib/vendor/blamejs/CODE_OF_CONDUCT.md +86 -0
  57. package/lib/vendor/blamejs/CONTRIBUTING.md +156 -0
  58. package/lib/vendor/blamejs/GOVERNANCE.md +201 -0
  59. package/lib/vendor/blamejs/LICENSE +201 -0
  60. package/lib/vendor/blamejs/LTS-CALENDAR.md +29 -0
  61. package/lib/vendor/blamejs/MIGRATING.md +29 -0
  62. package/lib/vendor/blamejs/NOTICE +81 -0
  63. package/lib/vendor/blamejs/README.md +304 -0
  64. package/lib/vendor/blamejs/SECURITY.md +432 -0
  65. package/lib/vendor/blamejs/api-snapshot.json +48709 -0
  66. package/lib/vendor/blamejs/assets/BlameJS_Logo.png +0 -0
  67. package/lib/vendor/blamejs/assets/BlameJS_Logo.svg +129 -0
  68. package/lib/vendor/blamejs/bench/README.md +77 -0
  69. package/lib/vendor/blamejs/bench/_helpers.js +70 -0
  70. package/lib/vendor/blamejs/bench/baseline.json +183 -0
  71. package/lib/vendor/blamejs/bench/crypto-hash.bench.js +19 -0
  72. package/lib/vendor/blamejs/bench/crypto-symmetric.bench.js +28 -0
  73. package/lib/vendor/blamejs/bench/run.js +140 -0
  74. package/lib/vendor/blamejs/bench/safe-json.bench.js +31 -0
  75. package/lib/vendor/blamejs/bin/blamejs.js +13 -0
  76. package/lib/vendor/blamejs/docker/caddy/Caddyfile +46 -0
  77. package/lib/vendor/blamejs/docker/coredns/Corefile +37 -0
  78. package/lib/vendor/blamejs/docker/haproxy/haproxy.cfg +52 -0
  79. package/lib/vendor/blamejs/docker/init/generate-certs.sh +118 -0
  80. package/lib/vendor/blamejs/docker/keycloak/realm-blamejs-test.json +87 -0
  81. package/lib/vendor/blamejs/docker/mitmproxy/config.yaml +16 -0
  82. package/lib/vendor/blamejs/docker/mongo/init-tls.sh +17 -0
  83. package/lib/vendor/blamejs/docker/mysql/my.cnf +12 -0
  84. package/lib/vendor/blamejs/docker/nats/nats.conf +33 -0
  85. package/lib/vendor/blamejs/docker/postgres/init-tls.sh +17 -0
  86. package/lib/vendor/blamejs/docker/postgres/postgresql.conf +18 -0
  87. package/lib/vendor/blamejs/docker/rabbitmq/rabbitmq.conf +18 -0
  88. package/lib/vendor/blamejs/docker/redis/redis.conf +15 -0
  89. package/lib/vendor/blamejs/docker/squid/squid.conf +24 -0
  90. package/lib/vendor/blamejs/docker/syslog/syslog-ng.conf +34 -0
  91. package/lib/vendor/blamejs/docker-compose.test.yml +545 -0
  92. package/lib/vendor/blamejs/docs/cis-postgres-crosswalk.md +102 -0
  93. package/lib/vendor/blamejs/docs/cis-sqlite-equivalent.md +92 -0
  94. package/lib/vendor/blamejs/eslint.config.mjs +204 -0
  95. package/lib/vendor/blamejs/examples/wiki/Caddyfile +40 -0
  96. package/lib/vendor/blamejs/examples/wiki/DEPLOY.md +218 -0
  97. package/lib/vendor/blamejs/examples/wiki/Dockerfile +120 -0
  98. package/lib/vendor/blamejs/examples/wiki/README.md +157 -0
  99. package/lib/vendor/blamejs/examples/wiki/cli-snapshot.json +250 -0
  100. package/lib/vendor/blamejs/examples/wiki/docker-compose.prod.yml +231 -0
  101. package/lib/vendor/blamejs/examples/wiki/docker-compose.yml +166 -0
  102. package/lib/vendor/blamejs/examples/wiki/env-snapshot.json +217 -0
  103. package/lib/vendor/blamejs/examples/wiki/lib/auto-site-entries.js +139 -0
  104. package/lib/vendor/blamejs/examples/wiki/lib/build-app.js +555 -0
  105. package/lib/vendor/blamejs/examples/wiki/lib/harvest-cli.js +507 -0
  106. package/lib/vendor/blamejs/examples/wiki/lib/harvest-env-vars.js +435 -0
  107. package/lib/vendor/blamejs/examples/wiki/lib/harvest-errors.js +282 -0
  108. package/lib/vendor/blamejs/examples/wiki/lib/harvest-vendored-deps.js +321 -0
  109. package/lib/vendor/blamejs/examples/wiki/lib/nav.js +15 -0
  110. package/lib/vendor/blamejs/examples/wiki/lib/opts-resolver.js +75 -0
  111. package/lib/vendor/blamejs/examples/wiki/lib/page-generator.js +508 -0
  112. package/lib/vendor/blamejs/examples/wiki/lib/section.js +276 -0
  113. package/lib/vendor/blamejs/examples/wiki/lib/source-comment-block-validator.js +587 -0
  114. package/lib/vendor/blamejs/examples/wiki/lib/source-doc-parser.js +318 -0
  115. package/lib/vendor/blamejs/examples/wiki/lib/symbol-index.js +122 -0
  116. package/lib/vendor/blamejs/examples/wiki/migrations/0001-pages-schema.js +74 -0
  117. package/lib/vendor/blamejs/examples/wiki/package.json +18 -0
  118. package/lib/vendor/blamejs/examples/wiki/public/img/blamejs-logo.png +0 -0
  119. package/lib/vendor/blamejs/examples/wiki/public/img/blamejs-logo.svg +129 -0
  120. package/lib/vendor/blamejs/examples/wiki/public/robots.txt +5 -0
  121. package/lib/vendor/blamejs/examples/wiki/public/vendor/MANIFEST.json +30 -0
  122. package/lib/vendor/blamejs/examples/wiki/public/vendor/prism.css +1 -0
  123. package/lib/vendor/blamejs/examples/wiki/public/vendor/prism.js +15 -0
  124. package/lib/vendor/blamejs/examples/wiki/public/wiki.css +1250 -0
  125. package/lib/vendor/blamejs/examples/wiki/routes/admin.js +366 -0
  126. package/lib/vendor/blamejs/examples/wiki/routes/integration.js +230 -0
  127. package/lib/vendor/blamejs/examples/wiki/routes/pages.js +266 -0
  128. package/lib/vendor/blamejs/examples/wiki/scripts/backfill-module-metadata.js +214 -0
  129. package/lib/vendor/blamejs/examples/wiki/seeders/prod/0001-default-pages.js +35 -0
  130. package/lib/vendor/blamejs/examples/wiki/seeders/prod/pages/_index.js +34 -0
  131. package/lib/vendor/blamejs/examples/wiki/seeders/prod/pages/api.js +76 -0
  132. package/lib/vendor/blamejs/examples/wiki/server.js +129 -0
  133. package/lib/vendor/blamejs/examples/wiki/site.config.js +197 -0
  134. package/lib/vendor/blamejs/examples/wiki/snippets/README.md +38 -0
  135. package/lib/vendor/blamejs/examples/wiki/snippets/auth/password-hash.example.js +15 -0
  136. package/lib/vendor/blamejs/examples/wiki/src/editor.js +103 -0
  137. package/lib/vendor/blamejs/examples/wiki/src/wiki.js +349 -0
  138. package/lib/vendor/blamejs/examples/wiki/test/AUDIT.md +155 -0
  139. package/lib/vendor/blamejs/examples/wiki/test/codebase-patterns.test.js +594 -0
  140. package/lib/vendor/blamejs/examples/wiki/test/e2e.js +741 -0
  141. package/lib/vendor/blamejs/examples/wiki/test/find-missing-pages.js +254 -0
  142. package/lib/vendor/blamejs/examples/wiki/test/integration.js +391 -0
  143. package/lib/vendor/blamejs/examples/wiki/test/validate-cli-snapshot.js +379 -0
  144. package/lib/vendor/blamejs/examples/wiki/test/validate-env-snapshot.js +346 -0
  145. package/lib/vendor/blamejs/examples/wiki/test/validate-nav-coverage.js +212 -0
  146. package/lib/vendor/blamejs/examples/wiki/test/validate-site-coverage.js +252 -0
  147. package/lib/vendor/blamejs/examples/wiki/test/validate-source-comment-blocks.js +107 -0
  148. package/lib/vendor/blamejs/examples/wiki/views/_layout.html +115 -0
  149. package/lib/vendor/blamejs/examples/wiki/views/admin/api-keys.html +51 -0
  150. package/lib/vendor/blamejs/examples/wiki/views/admin/dashboard.html +22 -0
  151. package/lib/vendor/blamejs/examples/wiki/views/admin/edit.html +17 -0
  152. package/lib/vendor/blamejs/examples/wiki/views/home.html +85 -0
  153. package/lib/vendor/blamejs/examples/wiki/views/login.html +18 -0
  154. package/lib/vendor/blamejs/examples/wiki/views/page.html +5 -0
  155. package/lib/vendor/blamejs/examples/wiki/views/partials/nav.html +13 -0
  156. package/lib/vendor/blamejs/examples/wiki/views/search.html +19 -0
  157. package/lib/vendor/blamejs/examples/wiki/wiki.config.js +15 -0
  158. package/lib/vendor/blamejs/fuzz/README.md +137 -0
  159. package/lib/vendor/blamejs/fuzz/_expected.js +35 -0
  160. package/lib/vendor/blamejs/fuzz/guard-agent-registry.fuzz.js +22 -0
  161. package/lib/vendor/blamejs/fuzz/guard-csv.fuzz.js +16 -0
  162. package/lib/vendor/blamejs/fuzz/guard-csv_seed_corpus/01-basic.csv +3 -0
  163. package/lib/vendor/blamejs/fuzz/guard-csv_seed_corpus/02-formula.csv +1 -0
  164. package/lib/vendor/blamejs/fuzz/guard-csv_seed_corpus/03-hyperlink.csv +1 -0
  165. package/lib/vendor/blamejs/fuzz/guard-dsn.fuzz.js +22 -0
  166. package/lib/vendor/blamejs/fuzz/guard-email.fuzz.js +16 -0
  167. package/lib/vendor/blamejs/fuzz/guard-email_seed_corpus/01-basic.eml +5 -0
  168. package/lib/vendor/blamejs/fuzz/guard-envelope.fuzz.js +24 -0
  169. package/lib/vendor/blamejs/fuzz/guard-event-bus-payload.fuzz.js +24 -0
  170. package/lib/vendor/blamejs/fuzz/guard-event-bus-topic.fuzz.js +20 -0
  171. package/lib/vendor/blamejs/fuzz/guard-html.fuzz.js +16 -0
  172. package/lib/vendor/blamejs/fuzz/guard-html_seed_corpus/01-basic.html +1 -0
  173. package/lib/vendor/blamejs/fuzz/guard-html_seed_corpus/02-script.html +1 -0
  174. package/lib/vendor/blamejs/fuzz/guard-html_seed_corpus/03-event.html +1 -0
  175. package/lib/vendor/blamejs/fuzz/guard-html_seed_corpus/04-jsurl.html +1 -0
  176. package/lib/vendor/blamejs/fuzz/guard-idempotency-key.fuzz.js +20 -0
  177. package/lib/vendor/blamejs/fuzz/guard-imap-command.fuzz.js +35 -0
  178. package/lib/vendor/blamejs/fuzz/guard-jmap.fuzz.js +41 -0
  179. package/lib/vendor/blamejs/fuzz/guard-json.fuzz.js +16 -0
  180. package/lib/vendor/blamejs/fuzz/guard-json_seed_corpus/01-basic.json +1 -0
  181. package/lib/vendor/blamejs/fuzz/guard-json_seed_corpus/02-proto.json +1 -0
  182. package/lib/vendor/blamejs/fuzz/guard-json_seed_corpus/03-dupkey.json +1 -0
  183. package/lib/vendor/blamejs/fuzz/guard-json_seed_corpus/04-nan.json +1 -0
  184. package/lib/vendor/blamejs/fuzz/guard-json_seed_corpus/05-bom.json +1 -0
  185. package/lib/vendor/blamejs/fuzz/guard-list-id.fuzz.js +21 -0
  186. package/lib/vendor/blamejs/fuzz/guard-list-unsubscribe.fuzz.js +25 -0
  187. package/lib/vendor/blamejs/fuzz/guard-mail-compose.fuzz.js +22 -0
  188. package/lib/vendor/blamejs/fuzz/guard-mail-move.fuzz.js +22 -0
  189. package/lib/vendor/blamejs/fuzz/guard-mail-query.fuzz.js +27 -0
  190. package/lib/vendor/blamejs/fuzz/guard-mail-reply.fuzz.js +23 -0
  191. package/lib/vendor/blamejs/fuzz/guard-mail-sieve.fuzz.js +36 -0
  192. package/lib/vendor/blamejs/fuzz/guard-managesieve-command.fuzz.js +26 -0
  193. package/lib/vendor/blamejs/fuzz/guard-markdown.fuzz.js +16 -0
  194. package/lib/vendor/blamejs/fuzz/guard-markdown_seed_corpus/01-basic.md +2 -0
  195. package/lib/vendor/blamejs/fuzz/guard-markdown_seed_corpus/02-jsurl.md +1 -0
  196. package/lib/vendor/blamejs/fuzz/guard-markdown_seed_corpus/03-jsimg.md +1 -0
  197. package/lib/vendor/blamejs/fuzz/guard-message-id.fuzz.js +26 -0
  198. package/lib/vendor/blamejs/fuzz/guard-pop3-command.fuzz.js +23 -0
  199. package/lib/vendor/blamejs/fuzz/guard-posture-chain.fuzz.js +22 -0
  200. package/lib/vendor/blamejs/fuzz/guard-saga-config.fuzz.js +32 -0
  201. package/lib/vendor/blamejs/fuzz/guard-smtp-command.fuzz.js +27 -0
  202. package/lib/vendor/blamejs/fuzz/guard-snapshot-envelope.fuzz.js +22 -0
  203. package/lib/vendor/blamejs/fuzz/guard-stream-args.fuzz.js +22 -0
  204. package/lib/vendor/blamejs/fuzz/guard-svg.fuzz.js +16 -0
  205. package/lib/vendor/blamejs/fuzz/guard-svg_seed_corpus/01-basic.svg +1 -0
  206. package/lib/vendor/blamejs/fuzz/guard-svg_seed_corpus/02-script.svg +1 -0
  207. package/lib/vendor/blamejs/fuzz/guard-tenant-id.fuzz.js +20 -0
  208. package/lib/vendor/blamejs/fuzz/guard-trace-context.fuzz.js +30 -0
  209. package/lib/vendor/blamejs/fuzz/guard-xml.fuzz.js +16 -0
  210. package/lib/vendor/blamejs/fuzz/guard-xml_seed_corpus/01-basic.xml +1 -0
  211. package/lib/vendor/blamejs/fuzz/guard-xml_seed_corpus/02-xxe.xml +1 -0
  212. package/lib/vendor/blamejs/fuzz/guard-yaml.fuzz.js +16 -0
  213. package/lib/vendor/blamejs/fuzz/guard-yaml_seed_corpus/01-basic.yaml +2 -0
  214. package/lib/vendor/blamejs/fuzz/guard-yaml_seed_corpus/02-anchor.yaml +2 -0
  215. package/lib/vendor/blamejs/fuzz/guard-yaml_seed_corpus/03-norway.yaml +1 -0
  216. package/lib/vendor/blamejs/fuzz/guard-yaml_seed_corpus/04-multidoc.yaml +4 -0
  217. package/lib/vendor/blamejs/fuzz/parsers__safe-ini.fuzz.js +16 -0
  218. package/lib/vendor/blamejs/fuzz/parsers__safe-ini_seed_corpus/01-basic.ini +2 -0
  219. package/lib/vendor/blamejs/fuzz/parsers__safe-toml.fuzz.js +16 -0
  220. package/lib/vendor/blamejs/fuzz/parsers__safe-toml_seed_corpus/01-basic.toml +4 -0
  221. package/lib/vendor/blamejs/fuzz/parsers__safe-xml.fuzz.js +16 -0
  222. package/lib/vendor/blamejs/fuzz/parsers__safe-xml_seed_corpus/01-basic.xml +1 -0
  223. package/lib/vendor/blamejs/fuzz/parsers__safe-yaml.fuzz.js +16 -0
  224. package/lib/vendor/blamejs/fuzz/parsers__safe-yaml_seed_corpus/01-basic.yaml +4 -0
  225. package/lib/vendor/blamejs/fuzz/safe-decompress.fuzz.js +49 -0
  226. package/lib/vendor/blamejs/fuzz/safe-dns.fuzz.js +29 -0
  227. package/lib/vendor/blamejs/fuzz/safe-ical.fuzz.js +16 -0
  228. package/lib/vendor/blamejs/fuzz/safe-icap.fuzz.js +42 -0
  229. package/lib/vendor/blamejs/fuzz/safe-json.fuzz.js +25 -0
  230. package/lib/vendor/blamejs/fuzz/safe-json_seed_corpus/01-object.txt +1 -0
  231. package/lib/vendor/blamejs/fuzz/safe-json_seed_corpus/02-array.txt +1 -0
  232. package/lib/vendor/blamejs/fuzz/safe-json_seed_corpus/03-string.txt +1 -0
  233. package/lib/vendor/blamejs/fuzz/safe-json_seed_corpus/04-proto.txt +1 -0
  234. package/lib/vendor/blamejs/fuzz/safe-json_seed_corpus/05-deep.txt +1 -0
  235. package/lib/vendor/blamejs/fuzz/safe-jsonpath.fuzz.js +16 -0
  236. package/lib/vendor/blamejs/fuzz/safe-jsonpath_seed_corpus/01-basic.txt +1 -0
  237. package/lib/vendor/blamejs/fuzz/safe-jsonpath_seed_corpus/02-filter.txt +1 -0
  238. package/lib/vendor/blamejs/fuzz/safe-jsonpath_seed_corpus/03-deepscan.txt +1 -0
  239. package/lib/vendor/blamejs/fuzz/safe-jsonpath_seed_corpus/04-slice.txt +1 -0
  240. package/lib/vendor/blamejs/fuzz/safe-mime.fuzz.js +27 -0
  241. package/lib/vendor/blamejs/fuzz/safe-mount-info.fuzz.js +33 -0
  242. package/lib/vendor/blamejs/fuzz/safe-sieve.fuzz.js +28 -0
  243. package/lib/vendor/blamejs/fuzz/safe-smtp.fuzz.js +64 -0
  244. package/lib/vendor/blamejs/fuzz/safe-url.fuzz.js +16 -0
  245. package/lib/vendor/blamejs/fuzz/safe-url_seed_corpus/01-basic.txt +1 -0
  246. package/lib/vendor/blamejs/fuzz/safe-url_seed_corpus/02-userinfo.txt +1 -0
  247. package/lib/vendor/blamejs/fuzz/safe-url_seed_corpus/03-dangerous.txt +1 -0
  248. package/lib/vendor/blamejs/fuzz/safe-url_seed_corpus/04-data.txt +1 -0
  249. package/lib/vendor/blamejs/fuzz/safe-url_seed_corpus/05-ipv6.txt +1 -0
  250. package/lib/vendor/blamejs/fuzz/safe-url_seed_corpus/06-idn.txt +1 -0
  251. package/lib/vendor/blamejs/fuzz/safe-vcard.fuzz.js +16 -0
  252. package/lib/vendor/blamejs/index.js +678 -0
  253. package/lib/vendor/blamejs/keys/release-pqc-pub.json +7 -0
  254. package/lib/vendor/blamejs/lib/_test/crypto-fixtures.js +67 -0
  255. package/lib/vendor/blamejs/lib/a2a-tasks.js +598 -0
  256. package/lib/vendor/blamejs/lib/a2a.js +407 -0
  257. package/lib/vendor/blamejs/lib/acme.js +1448 -0
  258. package/lib/vendor/blamejs/lib/agent-audit.js +45 -0
  259. package/lib/vendor/blamejs/lib/agent-event-bus.js +382 -0
  260. package/lib/vendor/blamejs/lib/agent-idempotency.js +497 -0
  261. package/lib/vendor/blamejs/lib/agent-orchestrator.js +717 -0
  262. package/lib/vendor/blamejs/lib/agent-posture-chain.js +366 -0
  263. package/lib/vendor/blamejs/lib/agent-saga.js +321 -0
  264. package/lib/vendor/blamejs/lib/agent-snapshot.js +676 -0
  265. package/lib/vendor/blamejs/lib/agent-stream.js +269 -0
  266. package/lib/vendor/blamejs/lib/agent-tenant.js +632 -0
  267. package/lib/vendor/blamejs/lib/agent-trace.js +281 -0
  268. package/lib/vendor/blamejs/lib/ai-adverse-decision.js +184 -0
  269. package/lib/vendor/blamejs/lib/ai-content-detect.js +268 -0
  270. package/lib/vendor/blamejs/lib/ai-input.js +201 -0
  271. package/lib/vendor/blamejs/lib/ai-model-manifest.js +363 -0
  272. package/lib/vendor/blamejs/lib/ai-pref.js +340 -0
  273. package/lib/vendor/blamejs/lib/api-key.js +721 -0
  274. package/lib/vendor/blamejs/lib/api-snapshot.js +458 -0
  275. package/lib/vendor/blamejs/lib/app-shutdown.js +557 -0
  276. package/lib/vendor/blamejs/lib/app.js +365 -0
  277. package/lib/vendor/blamejs/lib/archive.js +547 -0
  278. package/lib/vendor/blamejs/lib/arg-parser.js +697 -0
  279. package/lib/vendor/blamejs/lib/argon2-builtin.js +173 -0
  280. package/lib/vendor/blamejs/lib/asn1-der.js +424 -0
  281. package/lib/vendor/blamejs/lib/asyncapi-bindings.js +160 -0
  282. package/lib/vendor/blamejs/lib/asyncapi-traits.js +143 -0
  283. package/lib/vendor/blamejs/lib/asyncapi.js +575 -0
  284. package/lib/vendor/blamejs/lib/atomic-file.js +1023 -0
  285. package/lib/vendor/blamejs/lib/audit-chain.js +266 -0
  286. package/lib/vendor/blamejs/lib/audit-daily-review.js +389 -0
  287. package/lib/vendor/blamejs/lib/audit-sign.js +751 -0
  288. package/lib/vendor/blamejs/lib/audit-tools.js +1113 -0
  289. package/lib/vendor/blamejs/lib/audit.js +1671 -0
  290. package/lib/vendor/blamejs/lib/auth/aal.js +169 -0
  291. package/lib/vendor/blamejs/lib/auth/access-lock.js +220 -0
  292. package/lib/vendor/blamejs/lib/auth/acr-vocabulary.js +265 -0
  293. package/lib/vendor/blamejs/lib/auth/ato-kill-switch.js +112 -0
  294. package/lib/vendor/blamejs/lib/auth/auth-time-tracker.js +111 -0
  295. package/lib/vendor/blamejs/lib/auth/bot-challenge.js +573 -0
  296. package/lib/vendor/blamejs/lib/auth/ciba.js +637 -0
  297. package/lib/vendor/blamejs/lib/auth/dpop.js +516 -0
  298. package/lib/vendor/blamejs/lib/auth/elevation-grant.js +306 -0
  299. package/lib/vendor/blamejs/lib/auth/fal.js +229 -0
  300. package/lib/vendor/blamejs/lib/auth/fido-mds3.js +681 -0
  301. package/lib/vendor/blamejs/lib/auth/jwt-external.js +519 -0
  302. package/lib/vendor/blamejs/lib/auth/jwt.js +430 -0
  303. package/lib/vendor/blamejs/lib/auth/lockout.js +449 -0
  304. package/lib/vendor/blamejs/lib/auth/oauth.js +2141 -0
  305. package/lib/vendor/blamejs/lib/auth/oid4vci.js +657 -0
  306. package/lib/vendor/blamejs/lib/auth/oid4vp.js +531 -0
  307. package/lib/vendor/blamejs/lib/auth/openid-federation.js +600 -0
  308. package/lib/vendor/blamejs/lib/auth/passkey.js +676 -0
  309. package/lib/vendor/blamejs/lib/auth/password.js +693 -0
  310. package/lib/vendor/blamejs/lib/auth/saml.js +2109 -0
  311. package/lib/vendor/blamejs/lib/auth/sd-jwt-vc-disclosure.js +95 -0
  312. package/lib/vendor/blamejs/lib/auth/sd-jwt-vc-holder.js +225 -0
  313. package/lib/vendor/blamejs/lib/auth/sd-jwt-vc-issuer.js +197 -0
  314. package/lib/vendor/blamejs/lib/auth/sd-jwt-vc.js +728 -0
  315. package/lib/vendor/blamejs/lib/auth/status-list.js +272 -0
  316. package/lib/vendor/blamejs/lib/auth/step-up-policy.js +335 -0
  317. package/lib/vendor/blamejs/lib/auth/step-up.js +454 -0
  318. package/lib/vendor/blamejs/lib/auth-bot-challenge.js +505 -0
  319. package/lib/vendor/blamejs/lib/auth-header.js +148 -0
  320. package/lib/vendor/blamejs/lib/backup/bundle.js +265 -0
  321. package/lib/vendor/blamejs/lib/backup/crypto.js +176 -0
  322. package/lib/vendor/blamejs/lib/backup/index.js +1001 -0
  323. package/lib/vendor/blamejs/lib/backup/manifest.js +443 -0
  324. package/lib/vendor/blamejs/lib/boot-gates.js +174 -0
  325. package/lib/vendor/blamejs/lib/breach-deadline.js +272 -0
  326. package/lib/vendor/blamejs/lib/break-glass.js +1753 -0
  327. package/lib/vendor/blamejs/lib/budr.js +205 -0
  328. package/lib/vendor/blamejs/lib/bundler.js +461 -0
  329. package/lib/vendor/blamejs/lib/cache-redis.js +256 -0
  330. package/lib/vendor/blamejs/lib/cache-status.js +288 -0
  331. package/lib/vendor/blamejs/lib/cache.js +1331 -0
  332. package/lib/vendor/blamejs/lib/calendar.js +1240 -0
  333. package/lib/vendor/blamejs/lib/canonical-json.js +143 -0
  334. package/lib/vendor/blamejs/lib/cdn-cache-control.js +473 -0
  335. package/lib/vendor/blamejs/lib/cert.js +763 -0
  336. package/lib/vendor/blamejs/lib/chain-writer.js +259 -0
  337. package/lib/vendor/blamejs/lib/circuit-breaker.js +101 -0
  338. package/lib/vendor/blamejs/lib/cli-helpers.js +237 -0
  339. package/lib/vendor/blamejs/lib/cli.js +2328 -0
  340. package/lib/vendor/blamejs/lib/client-hints.js +318 -0
  341. package/lib/vendor/blamejs/lib/cloud-events.js +277 -0
  342. package/lib/vendor/blamejs/lib/cluster-provider-db.js +317 -0
  343. package/lib/vendor/blamejs/lib/cluster-storage.js +351 -0
  344. package/lib/vendor/blamejs/lib/cluster.js +1017 -0
  345. package/lib/vendor/blamejs/lib/cms-codec.js +826 -0
  346. package/lib/vendor/blamejs/lib/codepoint-class.js +262 -0
  347. package/lib/vendor/blamejs/lib/compliance-ai-act-logging.js +190 -0
  348. package/lib/vendor/blamejs/lib/compliance-ai-act-prohibited.js +205 -0
  349. package/lib/vendor/blamejs/lib/compliance-ai-act-risk.js +189 -0
  350. package/lib/vendor/blamejs/lib/compliance-ai-act-transparency.js +200 -0
  351. package/lib/vendor/blamejs/lib/compliance-ai-act.js +821 -0
  352. package/lib/vendor/blamejs/lib/compliance-eaa.js +204 -0
  353. package/lib/vendor/blamejs/lib/compliance-sanctions-aliases.js +167 -0
  354. package/lib/vendor/blamejs/lib/compliance-sanctions-fetcher.js +206 -0
  355. package/lib/vendor/blamejs/lib/compliance-sanctions-fuzzy.js +297 -0
  356. package/lib/vendor/blamejs/lib/compliance-sanctions.js +569 -0
  357. package/lib/vendor/blamejs/lib/compliance.js +1558 -0
  358. package/lib/vendor/blamejs/lib/config-drift.js +426 -0
  359. package/lib/vendor/blamejs/lib/config.js +446 -0
  360. package/lib/vendor/blamejs/lib/consent.js +369 -0
  361. package/lib/vendor/blamejs/lib/constants.js +209 -0
  362. package/lib/vendor/blamejs/lib/content-credentials.js +704 -0
  363. package/lib/vendor/blamejs/lib/cookies.js +560 -0
  364. package/lib/vendor/blamejs/lib/cra-report.js +299 -0
  365. package/lib/vendor/blamejs/lib/credential-hash.js +394 -0
  366. package/lib/vendor/blamejs/lib/crypto-field.js +1017 -0
  367. package/lib/vendor/blamejs/lib/crypto-hpke-pq.js +187 -0
  368. package/lib/vendor/blamejs/lib/crypto-hpke.js +256 -0
  369. package/lib/vendor/blamejs/lib/crypto.js +1908 -0
  370. package/lib/vendor/blamejs/lib/csp.js +271 -0
  371. package/lib/vendor/blamejs/lib/csv.js +418 -0
  372. package/lib/vendor/blamejs/lib/daemon.js +481 -0
  373. package/lib/vendor/blamejs/lib/dark-patterns.js +488 -0
  374. package/lib/vendor/blamejs/lib/data-act.js +328 -0
  375. package/lib/vendor/blamejs/lib/db-collection.js +587 -0
  376. package/lib/vendor/blamejs/lib/db-declare-row-policy.js +267 -0
  377. package/lib/vendor/blamejs/lib/db-declare-view.js +420 -0
  378. package/lib/vendor/blamejs/lib/db-file-lifecycle.js +333 -0
  379. package/lib/vendor/blamejs/lib/db-query.js +802 -0
  380. package/lib/vendor/blamejs/lib/db-role-context.js +50 -0
  381. package/lib/vendor/blamejs/lib/db-schema.js +322 -0
  382. package/lib/vendor/blamejs/lib/db.js +3111 -0
  383. package/lib/vendor/blamejs/lib/dbsc.js +299 -0
  384. package/lib/vendor/blamejs/lib/ddl-change-control.js +523 -0
  385. package/lib/vendor/blamejs/lib/deprecate.js +377 -0
  386. package/lib/vendor/blamejs/lib/dev.js +405 -0
  387. package/lib/vendor/blamejs/lib/dora.js +402 -0
  388. package/lib/vendor/blamejs/lib/dr-runbook.js +368 -0
  389. package/lib/vendor/blamejs/lib/dsr.js +1188 -0
  390. package/lib/vendor/blamejs/lib/dual-control.js +526 -0
  391. package/lib/vendor/blamejs/lib/early-hints.js +212 -0
  392. package/lib/vendor/blamejs/lib/error-page.js +420 -0
  393. package/lib/vendor/blamejs/lib/events.js +214 -0
  394. package/lib/vendor/blamejs/lib/external-db-migrate.js +659 -0
  395. package/lib/vendor/blamejs/lib/external-db.js +1877 -0
  396. package/lib/vendor/blamejs/lib/fapi2.js +394 -0
  397. package/lib/vendor/blamejs/lib/fda-21cfr11.js +395 -0
  398. package/lib/vendor/blamejs/lib/fdx.js +370 -0
  399. package/lib/vendor/blamejs/lib/fedcm.js +264 -0
  400. package/lib/vendor/blamejs/lib/file-type.js +360 -0
  401. package/lib/vendor/blamejs/lib/file-upload.js +1256 -0
  402. package/lib/vendor/blamejs/lib/flag-cache.js +136 -0
  403. package/lib/vendor/blamejs/lib/flag-evaluation-context.js +135 -0
  404. package/lib/vendor/blamejs/lib/flag-providers.js +279 -0
  405. package/lib/vendor/blamejs/lib/flag-targeting.js +210 -0
  406. package/lib/vendor/blamejs/lib/flag.js +346 -0
  407. package/lib/vendor/blamejs/lib/forms.js +525 -0
  408. package/lib/vendor/blamejs/lib/framework-error.js +724 -0
  409. package/lib/vendor/blamejs/lib/framework-schema.js +845 -0
  410. package/lib/vendor/blamejs/lib/framework-sha1-hibp.js +34 -0
  411. package/lib/vendor/blamejs/lib/fsm.js +469 -0
  412. package/lib/vendor/blamejs/lib/gate-contract.js +1661 -0
  413. package/lib/vendor/blamejs/lib/gdpr-ropa.js +261 -0
  414. package/lib/vendor/blamejs/lib/graphql-federation.js +234 -0
  415. package/lib/vendor/blamejs/lib/guard-agent-registry.js +179 -0
  416. package/lib/vendor/blamejs/lib/guard-all.js +555 -0
  417. package/lib/vendor/blamejs/lib/guard-archive.js +901 -0
  418. package/lib/vendor/blamejs/lib/guard-auth.js +451 -0
  419. package/lib/vendor/blamejs/lib/guard-cidr.js +676 -0
  420. package/lib/vendor/blamejs/lib/guard-csv.js +1176 -0
  421. package/lib/vendor/blamejs/lib/guard-domain.js +814 -0
  422. package/lib/vendor/blamejs/lib/guard-dsn.js +382 -0
  423. package/lib/vendor/blamejs/lib/guard-email.js +951 -0
  424. package/lib/vendor/blamejs/lib/guard-envelope.js +294 -0
  425. package/lib/vendor/blamejs/lib/guard-event-bus-payload.js +217 -0
  426. package/lib/vendor/blamejs/lib/guard-event-bus-topic.js +150 -0
  427. package/lib/vendor/blamejs/lib/guard-filename.js +956 -0
  428. package/lib/vendor/blamejs/lib/guard-graphql.js +731 -0
  429. package/lib/vendor/blamejs/lib/guard-html-wcag-aria.js +164 -0
  430. package/lib/vendor/blamejs/lib/guard-html-wcag-forms.js +144 -0
  431. package/lib/vendor/blamejs/lib/guard-html-wcag-tables.js +154 -0
  432. package/lib/vendor/blamejs/lib/guard-html-wcag-tagwalk.js +44 -0
  433. package/lib/vendor/blamejs/lib/guard-html-wcag.js +470 -0
  434. package/lib/vendor/blamejs/lib/guard-html.js +1209 -0
  435. package/lib/vendor/blamejs/lib/guard-idempotency-key.js +151 -0
  436. package/lib/vendor/blamejs/lib/guard-image.js +584 -0
  437. package/lib/vendor/blamejs/lib/guard-imap-command.js +337 -0
  438. package/lib/vendor/blamejs/lib/guard-jmap.js +321 -0
  439. package/lib/vendor/blamejs/lib/guard-json.js +935 -0
  440. package/lib/vendor/blamejs/lib/guard-jsonpath.js +512 -0
  441. package/lib/vendor/blamejs/lib/guard-jwt.js +772 -0
  442. package/lib/vendor/blamejs/lib/guard-list-id.js +318 -0
  443. package/lib/vendor/blamejs/lib/guard-list-unsubscribe.js +412 -0
  444. package/lib/vendor/blamejs/lib/guard-mail-compose.js +282 -0
  445. package/lib/vendor/blamejs/lib/guard-mail-move.js +202 -0
  446. package/lib/vendor/blamejs/lib/guard-mail-query.js +310 -0
  447. package/lib/vendor/blamejs/lib/guard-mail-reply.js +172 -0
  448. package/lib/vendor/blamejs/lib/guard-mail-sieve.js +207 -0
  449. package/lib/vendor/blamejs/lib/guard-managesieve-command.js +566 -0
  450. package/lib/vendor/blamejs/lib/guard-markdown.js +768 -0
  451. package/lib/vendor/blamejs/lib/guard-message-id.js +267 -0
  452. package/lib/vendor/blamejs/lib/guard-mime.js +609 -0
  453. package/lib/vendor/blamejs/lib/guard-oauth.js +650 -0
  454. package/lib/vendor/blamejs/lib/guard-pdf.js +569 -0
  455. package/lib/vendor/blamejs/lib/guard-pop3-command.js +317 -0
  456. package/lib/vendor/blamejs/lib/guard-posture-chain.js +201 -0
  457. package/lib/vendor/blamejs/lib/guard-regex.js +632 -0
  458. package/lib/vendor/blamejs/lib/guard-saga-config.js +157 -0
  459. package/lib/vendor/blamejs/lib/guard-shell.js +522 -0
  460. package/lib/vendor/blamejs/lib/guard-smtp-command.js +594 -0
  461. package/lib/vendor/blamejs/lib/guard-snapshot-envelope.js +168 -0
  462. package/lib/vendor/blamejs/lib/guard-stream-args.js +166 -0
  463. package/lib/vendor/blamejs/lib/guard-svg.js +1163 -0
  464. package/lib/vendor/blamejs/lib/guard-template.js +490 -0
  465. package/lib/vendor/blamejs/lib/guard-tenant-id.js +138 -0
  466. package/lib/vendor/blamejs/lib/guard-time.js +586 -0
  467. package/lib/vendor/blamejs/lib/guard-trace-context.js +172 -0
  468. package/lib/vendor/blamejs/lib/guard-uuid.js +548 -0
  469. package/lib/vendor/blamejs/lib/guard-xml.js +666 -0
  470. package/lib/vendor/blamejs/lib/guard-yaml.js +726 -0
  471. package/lib/vendor/blamejs/lib/hal.js +125 -0
  472. package/lib/vendor/blamejs/lib/handlers.js +350 -0
  473. package/lib/vendor/blamejs/lib/honeytoken.js +168 -0
  474. package/lib/vendor/blamejs/lib/html-balance.js +347 -0
  475. package/lib/vendor/blamejs/lib/http-client-cache.js +923 -0
  476. package/lib/vendor/blamejs/lib/http-client-cookie-jar.js +519 -0
  477. package/lib/vendor/blamejs/lib/http-client.js +2152 -0
  478. package/lib/vendor/blamejs/lib/http-message-signature.js +589 -0
  479. package/lib/vendor/blamejs/lib/http2-teardown.js +34 -0
  480. package/lib/vendor/blamejs/lib/i18n-messageformat.js +398 -0
  481. package/lib/vendor/blamejs/lib/i18n.js +931 -0
  482. package/lib/vendor/blamejs/lib/iab-mspa.js +257 -0
  483. package/lib/vendor/blamejs/lib/iab-tcf.js +461 -0
  484. package/lib/vendor/blamejs/lib/importmap-integrity.js +90 -0
  485. package/lib/vendor/blamejs/lib/inbox.js +435 -0
  486. package/lib/vendor/blamejs/lib/incident-report.js +314 -0
  487. package/lib/vendor/blamejs/lib/ip-utils.js +102 -0
  488. package/lib/vendor/blamejs/lib/jobs.js +185 -0
  489. package/lib/vendor/blamejs/lib/jose-jwe-experimental.js +228 -0
  490. package/lib/vendor/blamejs/lib/jsonapi.js +230 -0
  491. package/lib/vendor/blamejs/lib/keychain.js +865 -0
  492. package/lib/vendor/blamejs/lib/lazy-require.js +48 -0
  493. package/lib/vendor/blamejs/lib/legal-hold.js +374 -0
  494. package/lib/vendor/blamejs/lib/local-db-thin.js +321 -0
  495. package/lib/vendor/blamejs/lib/log-stream-cloudwatch.js +369 -0
  496. package/lib/vendor/blamejs/lib/log-stream-local.js +146 -0
  497. package/lib/vendor/blamejs/lib/log-stream-otlp-grpc.js +410 -0
  498. package/lib/vendor/blamejs/lib/log-stream-otlp.js +286 -0
  499. package/lib/vendor/blamejs/lib/log-stream-syslog.js +310 -0
  500. package/lib/vendor/blamejs/lib/log-stream-webhook.js +199 -0
  501. package/lib/vendor/blamejs/lib/log-stream.js +584 -0
  502. package/lib/vendor/blamejs/lib/log.js +625 -0
  503. package/lib/vendor/blamejs/lib/lro.js +200 -0
  504. package/lib/vendor/blamejs/lib/mail-agent.js +786 -0
  505. package/lib/vendor/blamejs/lib/mail-arc-sign.js +417 -0
  506. package/lib/vendor/blamejs/lib/mail-arf.js +343 -0
  507. package/lib/vendor/blamejs/lib/mail-auth.js +2144 -0
  508. package/lib/vendor/blamejs/lib/mail-bimi.js +1047 -0
  509. package/lib/vendor/blamejs/lib/mail-bounce.js +955 -0
  510. package/lib/vendor/blamejs/lib/mail-crypto-pgp.js +1286 -0
  511. package/lib/vendor/blamejs/lib/mail-crypto-smime.js +789 -0
  512. package/lib/vendor/blamejs/lib/mail-crypto.js +108 -0
  513. package/lib/vendor/blamejs/lib/mail-dav.js +1224 -0
  514. package/lib/vendor/blamejs/lib/mail-deploy.js +1119 -0
  515. package/lib/vendor/blamejs/lib/mail-dkim.js +1250 -0
  516. package/lib/vendor/blamejs/lib/mail-greylist.js +448 -0
  517. package/lib/vendor/blamejs/lib/mail-helo.js +473 -0
  518. package/lib/vendor/blamejs/lib/mail-journal.js +435 -0
  519. package/lib/vendor/blamejs/lib/mail-mdn.js +424 -0
  520. package/lib/vendor/blamejs/lib/mail-rbl.js +392 -0
  521. package/lib/vendor/blamejs/lib/mail-require-tls.js +198 -0
  522. package/lib/vendor/blamejs/lib/mail-scan.js +502 -0
  523. package/lib/vendor/blamejs/lib/mail-send-deliver.js +629 -0
  524. package/lib/vendor/blamejs/lib/mail-server-imap.js +1858 -0
  525. package/lib/vendor/blamejs/lib/mail-server-jmap.js +1565 -0
  526. package/lib/vendor/blamejs/lib/mail-server-managesieve.js +908 -0
  527. package/lib/vendor/blamejs/lib/mail-server-mx.js +969 -0
  528. package/lib/vendor/blamejs/lib/mail-server-pop3.js +915 -0
  529. package/lib/vendor/blamejs/lib/mail-server-rate-limit.js +315 -0
  530. package/lib/vendor/blamejs/lib/mail-server-registry.js +378 -0
  531. package/lib/vendor/blamejs/lib/mail-server-submission.js +1396 -0
  532. package/lib/vendor/blamejs/lib/mail-server-tls.js +445 -0
  533. package/lib/vendor/blamejs/lib/mail-sieve.js +557 -0
  534. package/lib/vendor/blamejs/lib/mail-spam-score.js +284 -0
  535. package/lib/vendor/blamejs/lib/mail-srs.js +248 -0
  536. package/lib/vendor/blamejs/lib/mail-store-fts.js +394 -0
  537. package/lib/vendor/blamejs/lib/mail-store.js +929 -0
  538. package/lib/vendor/blamejs/lib/mail-unsubscribe.js +400 -0
  539. package/lib/vendor/blamejs/lib/mail.js +1971 -0
  540. package/lib/vendor/blamejs/lib/mcp-tool-registry.js +473 -0
  541. package/lib/vendor/blamejs/lib/mcp.js +950 -0
  542. package/lib/vendor/blamejs/lib/metrics.js +1503 -0
  543. package/lib/vendor/blamejs/lib/middleware/age-gate.js +177 -0
  544. package/lib/vendor/blamejs/lib/middleware/ai-act-disclosure.js +203 -0
  545. package/lib/vendor/blamejs/lib/middleware/api-encrypt.js +981 -0
  546. package/lib/vendor/blamejs/lib/middleware/assetlinks.js +137 -0
  547. package/lib/vendor/blamejs/lib/middleware/asyncapi-serve.js +171 -0
  548. package/lib/vendor/blamejs/lib/middleware/attach-user.js +220 -0
  549. package/lib/vendor/blamejs/lib/middleware/bearer-auth.js +293 -0
  550. package/lib/vendor/blamejs/lib/middleware/body-parser.js +1519 -0
  551. package/lib/vendor/blamejs/lib/middleware/bot-disclose.js +183 -0
  552. package/lib/vendor/blamejs/lib/middleware/bot-guard.js +217 -0
  553. package/lib/vendor/blamejs/lib/middleware/clear-site-data.js +122 -0
  554. package/lib/vendor/blamejs/lib/middleware/compose-pipeline.js +355 -0
  555. package/lib/vendor/blamejs/lib/middleware/compression.js +489 -0
  556. package/lib/vendor/blamejs/lib/middleware/cookies.js +130 -0
  557. package/lib/vendor/blamejs/lib/middleware/cors.js +386 -0
  558. package/lib/vendor/blamejs/lib/middleware/csp-nonce.js +388 -0
  559. package/lib/vendor/blamejs/lib/middleware/csp-report.js +167 -0
  560. package/lib/vendor/blamejs/lib/middleware/csrf-protect.js +499 -0
  561. package/lib/vendor/blamejs/lib/middleware/daily-byte-quota.js +243 -0
  562. package/lib/vendor/blamejs/lib/middleware/db-role-for.js +304 -0
  563. package/lib/vendor/blamejs/lib/middleware/dpop.js +402 -0
  564. package/lib/vendor/blamejs/lib/middleware/error-handler.js +69 -0
  565. package/lib/vendor/blamejs/lib/middleware/fetch-metadata.js +168 -0
  566. package/lib/vendor/blamejs/lib/middleware/flag-context.js +110 -0
  567. package/lib/vendor/blamejs/lib/middleware/gpc.js +153 -0
  568. package/lib/vendor/blamejs/lib/middleware/headers.js +242 -0
  569. package/lib/vendor/blamejs/lib/middleware/health.js +438 -0
  570. package/lib/vendor/blamejs/lib/middleware/host-allowlist.js +189 -0
  571. package/lib/vendor/blamejs/lib/middleware/idempotency-key.js +964 -0
  572. package/lib/vendor/blamejs/lib/middleware/index.js +183 -0
  573. package/lib/vendor/blamejs/lib/middleware/nel.js +214 -0
  574. package/lib/vendor/blamejs/lib/middleware/network-allowlist.js +237 -0
  575. package/lib/vendor/blamejs/lib/middleware/no-cache.js +106 -0
  576. package/lib/vendor/blamejs/lib/middleware/openapi-serve.js +177 -0
  577. package/lib/vendor/blamejs/lib/middleware/protected-resource-metadata.js +277 -0
  578. package/lib/vendor/blamejs/lib/middleware/rate-limit.js +556 -0
  579. package/lib/vendor/blamejs/lib/middleware/request-id.js +79 -0
  580. package/lib/vendor/blamejs/lib/middleware/request-log.js +205 -0
  581. package/lib/vendor/blamejs/lib/middleware/require-aal.js +138 -0
  582. package/lib/vendor/blamejs/lib/middleware/require-auth.js +144 -0
  583. package/lib/vendor/blamejs/lib/middleware/require-bound-key.js +290 -0
  584. package/lib/vendor/blamejs/lib/middleware/require-content-type.js +113 -0
  585. package/lib/vendor/blamejs/lib/middleware/require-methods.js +97 -0
  586. package/lib/vendor/blamejs/lib/middleware/require-mtls.js +212 -0
  587. package/lib/vendor/blamejs/lib/middleware/require-step-up.js +226 -0
  588. package/lib/vendor/blamejs/lib/middleware/scim-server.js +375 -0
  589. package/lib/vendor/blamejs/lib/middleware/security-headers.js +285 -0
  590. package/lib/vendor/blamejs/lib/middleware/security-txt.js +170 -0
  591. package/lib/vendor/blamejs/lib/middleware/span-http-server.js +280 -0
  592. package/lib/vendor/blamejs/lib/middleware/speculation-rules.js +323 -0
  593. package/lib/vendor/blamejs/lib/middleware/sse.js +200 -0
  594. package/lib/vendor/blamejs/lib/middleware/trace-log-correlation.js +167 -0
  595. package/lib/vendor/blamejs/lib/middleware/trace-propagate.js +148 -0
  596. package/lib/vendor/blamejs/lib/middleware/tus-upload.js +749 -0
  597. package/lib/vendor/blamejs/lib/middleware/web-app-manifest.js +164 -0
  598. package/lib/vendor/blamejs/lib/migration-files.js +37 -0
  599. package/lib/vendor/blamejs/lib/migrations.js +385 -0
  600. package/lib/vendor/blamejs/lib/mime-parse.js +198 -0
  601. package/lib/vendor/blamejs/lib/money.js +699 -0
  602. package/lib/vendor/blamejs/lib/mtls-ca.js +572 -0
  603. package/lib/vendor/blamejs/lib/mtls-engine-default.js +501 -0
  604. package/lib/vendor/blamejs/lib/network-byte-quota.js +308 -0
  605. package/lib/vendor/blamejs/lib/network-dns-resolver.js +533 -0
  606. package/lib/vendor/blamejs/lib/network-dns.js +1930 -0
  607. package/lib/vendor/blamejs/lib/network-heartbeat.js +425 -0
  608. package/lib/vendor/blamejs/lib/network-nts.js +574 -0
  609. package/lib/vendor/blamejs/lib/network-proxy.js +265 -0
  610. package/lib/vendor/blamejs/lib/network-smtp-policy.js +836 -0
  611. package/lib/vendor/blamejs/lib/network-tls.js +3126 -0
  612. package/lib/vendor/blamejs/lib/network.js +346 -0
  613. package/lib/vendor/blamejs/lib/nis2-report.js +181 -0
  614. package/lib/vendor/blamejs/lib/nist-crosswalk.js +293 -0
  615. package/lib/vendor/blamejs/lib/nonce-store.js +177 -0
  616. package/lib/vendor/blamejs/lib/notify.js +683 -0
  617. package/lib/vendor/blamejs/lib/ntp-check.js +458 -0
  618. package/lib/vendor/blamejs/lib/numeric-bounds.js +111 -0
  619. package/lib/vendor/blamejs/lib/numeric-checks.js +40 -0
  620. package/lib/vendor/blamejs/lib/object-store/azure-blob-bucket-ops.js +349 -0
  621. package/lib/vendor/blamejs/lib/object-store/azure-blob.js +488 -0
  622. package/lib/vendor/blamejs/lib/object-store/gcs-bucket-ops.js +351 -0
  623. package/lib/vendor/blamejs/lib/object-store/gcs.js +515 -0
  624. package/lib/vendor/blamejs/lib/object-store/http-put.js +153 -0
  625. package/lib/vendor/blamejs/lib/object-store/http-request.js +38 -0
  626. package/lib/vendor/blamejs/lib/object-store/index.js +197 -0
  627. package/lib/vendor/blamejs/lib/object-store/local.js +163 -0
  628. package/lib/vendor/blamejs/lib/object-store/sigv4-bucket-ops.js +1133 -0
  629. package/lib/vendor/blamejs/lib/object-store/sigv4.js +957 -0
  630. package/lib/vendor/blamejs/lib/observability-otlp-exporter.js +420 -0
  631. package/lib/vendor/blamejs/lib/observability-tracer.js +395 -0
  632. package/lib/vendor/blamejs/lib/observability.js +720 -0
  633. package/lib/vendor/blamejs/lib/openapi-paths-builder.js +248 -0
  634. package/lib/vendor/blamejs/lib/openapi-schema-walk.js +192 -0
  635. package/lib/vendor/blamejs/lib/openapi-security.js +169 -0
  636. package/lib/vendor/blamejs/lib/openapi-yaml.js +154 -0
  637. package/lib/vendor/blamejs/lib/openapi.js +489 -0
  638. package/lib/vendor/blamejs/lib/otel-export.js +278 -0
  639. package/lib/vendor/blamejs/lib/outbox.js +547 -0
  640. package/lib/vendor/blamejs/lib/pagination.js +542 -0
  641. package/lib/vendor/blamejs/lib/parsers/index.js +91 -0
  642. package/lib/vendor/blamejs/lib/parsers/safe-env.js +642 -0
  643. package/lib/vendor/blamejs/lib/parsers/safe-ini.js +293 -0
  644. package/lib/vendor/blamejs/lib/parsers/safe-toml.js +784 -0
  645. package/lib/vendor/blamejs/lib/parsers/safe-xml.js +390 -0
  646. package/lib/vendor/blamejs/lib/parsers/safe-yaml.js +1015 -0
  647. package/lib/vendor/blamejs/lib/permissions.js +793 -0
  648. package/lib/vendor/blamejs/lib/pick.js +105 -0
  649. package/lib/vendor/blamejs/lib/pqc-agent.js +351 -0
  650. package/lib/vendor/blamejs/lib/pqc-gate.js +279 -0
  651. package/lib/vendor/blamejs/lib/pqc-software.js +271 -0
  652. package/lib/vendor/blamejs/lib/problem-details.js +482 -0
  653. package/lib/vendor/blamejs/lib/process-spawn.js +196 -0
  654. package/lib/vendor/blamejs/lib/promise-pool.js +162 -0
  655. package/lib/vendor/blamejs/lib/protobuf-encoder.js +190 -0
  656. package/lib/vendor/blamejs/lib/protocol-dispatcher.js +161 -0
  657. package/lib/vendor/blamejs/lib/public-suffix.js +403 -0
  658. package/lib/vendor/blamejs/lib/pubsub-cluster.js +154 -0
  659. package/lib/vendor/blamejs/lib/pubsub-redis.js +167 -0
  660. package/lib/vendor/blamejs/lib/pubsub.js +463 -0
  661. package/lib/vendor/blamejs/lib/queue-local.js +476 -0
  662. package/lib/vendor/blamejs/lib/queue-redis.js +745 -0
  663. package/lib/vendor/blamejs/lib/queue-sqs.js +319 -0
  664. package/lib/vendor/blamejs/lib/queue.js +1016 -0
  665. package/lib/vendor/blamejs/lib/redact.js +1007 -0
  666. package/lib/vendor/blamejs/lib/redis-client.js +520 -0
  667. package/lib/vendor/blamejs/lib/render.js +285 -0
  668. package/lib/vendor/blamejs/lib/request-helpers.js +767 -0
  669. package/lib/vendor/blamejs/lib/resource-access-lock.js +116 -0
  670. package/lib/vendor/blamejs/lib/restore-bundle.js +340 -0
  671. package/lib/vendor/blamejs/lib/restore-rollback.js +365 -0
  672. package/lib/vendor/blamejs/lib/restore.js +409 -0
  673. package/lib/vendor/blamejs/lib/retention.js +640 -0
  674. package/lib/vendor/blamejs/lib/retry.js +523 -0
  675. package/lib/vendor/blamejs/lib/router.js +1289 -0
  676. package/lib/vendor/blamejs/lib/safe-async.js +1184 -0
  677. package/lib/vendor/blamejs/lib/safe-buffer.js +562 -0
  678. package/lib/vendor/blamejs/lib/safe-decompress.js +297 -0
  679. package/lib/vendor/blamejs/lib/safe-dns.js +665 -0
  680. package/lib/vendor/blamejs/lib/safe-ical.js +634 -0
  681. package/lib/vendor/blamejs/lib/safe-icap.js +502 -0
  682. package/lib/vendor/blamejs/lib/safe-json.js +946 -0
  683. package/lib/vendor/blamejs/lib/safe-jsonpath.js +285 -0
  684. package/lib/vendor/blamejs/lib/safe-mime.js +831 -0
  685. package/lib/vendor/blamejs/lib/safe-mount-info.js +306 -0
  686. package/lib/vendor/blamejs/lib/safe-path.js +254 -0
  687. package/lib/vendor/blamejs/lib/safe-redirect.js +106 -0
  688. package/lib/vendor/blamejs/lib/safe-schema.js +1810 -0
  689. package/lib/vendor/blamejs/lib/safe-sieve.js +684 -0
  690. package/lib/vendor/blamejs/lib/safe-smtp.js +185 -0
  691. package/lib/vendor/blamejs/lib/safe-sql.js +363 -0
  692. package/lib/vendor/blamejs/lib/safe-url.js +428 -0
  693. package/lib/vendor/blamejs/lib/safe-vcard.js +473 -0
  694. package/lib/vendor/blamejs/lib/sandbox-worker.js +135 -0
  695. package/lib/vendor/blamejs/lib/sandbox.js +358 -0
  696. package/lib/vendor/blamejs/lib/scheduler.js +827 -0
  697. package/lib/vendor/blamejs/lib/sd-notify.js +269 -0
  698. package/lib/vendor/blamejs/lib/sec-cyber.js +214 -0
  699. package/lib/vendor/blamejs/lib/security-assert.js +395 -0
  700. package/lib/vendor/blamejs/lib/seeders.js +620 -0
  701. package/lib/vendor/blamejs/lib/self-update-standalone-verifier.js +309 -0
  702. package/lib/vendor/blamejs/lib/self-update.js +804 -0
  703. package/lib/vendor/blamejs/lib/server-timing.js +174 -0
  704. package/lib/vendor/blamejs/lib/session-device-binding.js +431 -0
  705. package/lib/vendor/blamejs/lib/session-stores.js +138 -0
  706. package/lib/vendor/blamejs/lib/session.js +1162 -0
  707. package/lib/vendor/blamejs/lib/slug.js +381 -0
  708. package/lib/vendor/blamejs/lib/sse.js +349 -0
  709. package/lib/vendor/blamejs/lib/ssrf-guard.js +792 -0
  710. package/lib/vendor/blamejs/lib/standard-webhooks.js +183 -0
  711. package/lib/vendor/blamejs/lib/static.js +1249 -0
  712. package/lib/vendor/blamejs/lib/storage.js +1272 -0
  713. package/lib/vendor/blamejs/lib/stream-throttle.js +235 -0
  714. package/lib/vendor/blamejs/lib/structured-fields.js +244 -0
  715. package/lib/vendor/blamejs/lib/subject.js +667 -0
  716. package/lib/vendor/blamejs/lib/tcpa-10dlc.js +175 -0
  717. package/lib/vendor/blamejs/lib/template.js +931 -0
  718. package/lib/vendor/blamejs/lib/tenant-quota.js +545 -0
  719. package/lib/vendor/blamejs/lib/test-harness.js +275 -0
  720. package/lib/vendor/blamejs/lib/testing.js +1185 -0
  721. package/lib/vendor/blamejs/lib/time.js +578 -0
  722. package/lib/vendor/blamejs/lib/tls-exporter.js +239 -0
  723. package/lib/vendor/blamejs/lib/totp.js +318 -0
  724. package/lib/vendor/blamejs/lib/tracing.js +546 -0
  725. package/lib/vendor/blamejs/lib/uuid.js +207 -0
  726. package/lib/vendor/blamejs/lib/validate-opts.js +381 -0
  727. package/lib/vendor/blamejs/lib/vault/index.js +638 -0
  728. package/lib/vendor/blamejs/lib/vault/passphrase-ops.js +311 -0
  729. package/lib/vendor/blamejs/lib/vault/passphrase-source.js +198 -0
  730. package/lib/vendor/blamejs/lib/vault/rotate.js +803 -0
  731. package/lib/vendor/blamejs/lib/vault/seal-pem-file.js +471 -0
  732. package/lib/vendor/blamejs/lib/vault/wrap.js +296 -0
  733. package/lib/vendor/blamejs/lib/vault-aad.js +259 -0
  734. package/lib/vendor/blamejs/lib/vendor/.vendor-data-pubkey +4 -0
  735. package/lib/vendor/blamejs/lib/vendor/MANIFEST.json +161 -0
  736. package/lib/vendor/blamejs/lib/vendor/bimi-trust-anchors.data.js +68 -0
  737. package/lib/vendor/blamejs/lib/vendor/bimi-trust-anchors.pem +33 -0
  738. package/lib/vendor/blamejs/lib/vendor/common-passwords-top-10000.data.js +1325 -0
  739. package/lib/vendor/blamejs/lib/vendor/common-passwords-top-10000.txt +10002 -0
  740. package/lib/vendor/blamejs/lib/vendor/noble-ciphers.cjs +9 -0
  741. package/lib/vendor/blamejs/lib/vendor/noble-post-quantum.cjs +18 -0
  742. package/lib/vendor/blamejs/lib/vendor/pki.cjs +181 -0
  743. package/lib/vendor/blamejs/lib/vendor/public-suffix-list.dat +16382 -0
  744. package/lib/vendor/blamejs/lib/vendor/public-suffix-list.data.js +5881 -0
  745. package/lib/vendor/blamejs/lib/vendor/simplewebauthn-server.cjs +328 -0
  746. package/lib/vendor/blamejs/lib/vendor/vendor-data-pubkey.js +16 -0
  747. package/lib/vendor/blamejs/lib/vendor-data.js +520 -0
  748. package/lib/vendor/blamejs/lib/vex.js +630 -0
  749. package/lib/vendor/blamejs/lib/watcher.js +608 -0
  750. package/lib/vendor/blamejs/lib/web-push-vapid.js +322 -0
  751. package/lib/vendor/blamejs/lib/webhook.js +977 -0
  752. package/lib/vendor/blamejs/lib/websocket-channels.js +327 -0
  753. package/lib/vendor/blamejs/lib/websocket.js +1561 -0
  754. package/lib/vendor/blamejs/lib/wiki-concepts.js +338 -0
  755. package/lib/vendor/blamejs/lib/worker-pool.js +464 -0
  756. package/lib/vendor/blamejs/lib/ws-client.js +978 -0
  757. package/lib/vendor/blamejs/lib/xml-c14n.js +506 -0
  758. package/lib/vendor/blamejs/memory/specs/node-26-map-getorinsert-migration.md +164 -0
  759. package/lib/vendor/blamejs/oss-fuzz/projects/blamejs/Dockerfile +19 -0
  760. package/lib/vendor/blamejs/oss-fuzz/projects/blamejs/README.md +88 -0
  761. package/lib/vendor/blamejs/oss-fuzz/projects/blamejs/build.sh +26 -0
  762. package/lib/vendor/blamejs/oss-fuzz/projects/blamejs/project.yaml +28 -0
  763. package/lib/vendor/blamejs/package.json +81 -0
  764. package/lib/vendor/blamejs/release-notes/v0.0.x.json +310 -0
  765. package/lib/vendor/blamejs/release-notes/v0.1.x.json +1798 -0
  766. package/lib/vendor/blamejs/release-notes/v0.10.x.json +1288 -0
  767. package/lib/vendor/blamejs/release-notes/v0.11.x.json +2551 -0
  768. package/lib/vendor/blamejs/release-notes/v0.12.0.json +64 -0
  769. package/lib/vendor/blamejs/release-notes/v0.12.1.json +32 -0
  770. package/lib/vendor/blamejs/release-notes/v0.12.2.json +45 -0
  771. package/lib/vendor/blamejs/release-notes/v0.2.x.json +706 -0
  772. package/lib/vendor/blamejs/release-notes/v0.3.x.json +786 -0
  773. package/lib/vendor/blamejs/release-notes/v0.4.x.json +588 -0
  774. package/lib/vendor/blamejs/release-notes/v0.5.x.json +390 -0
  775. package/lib/vendor/blamejs/release-notes/v0.6.x.json +1947 -0
  776. package/lib/vendor/blamejs/release-notes/v0.7.x.json +3811 -0
  777. package/lib/vendor/blamejs/release-notes/v0.8.x.json +3318 -0
  778. package/lib/vendor/blamejs/release-notes/v0.9.x.json +2257 -0
  779. package/lib/vendor/blamejs/scripts/build-vendored-sbom.js +325 -0
  780. package/lib/vendor/blamejs/scripts/check-api-snapshot.js +62 -0
  781. package/lib/vendor/blamejs/scripts/check-changelog-extract.js +108 -0
  782. package/lib/vendor/blamejs/scripts/check-pack-against-gitignore.js +83 -0
  783. package/lib/vendor/blamejs/scripts/check-services.js +483 -0
  784. package/lib/vendor/blamejs/scripts/check-vendor-currency.js +349 -0
  785. package/lib/vendor/blamejs/scripts/consolidate-release-notes.js +216 -0
  786. package/lib/vendor/blamejs/scripts/gen-migrating.js +275 -0
  787. package/lib/vendor/blamejs/scripts/generate-changelog-entry.js +577 -0
  788. package/lib/vendor/blamejs/scripts/generate-release-signing-key.js +79 -0
  789. package/lib/vendor/blamejs/scripts/publish-dep-confusion-placeholder.sh +101 -0
  790. package/lib/vendor/blamejs/scripts/refresh-api-snapshot.js +31 -0
  791. package/lib/vendor/blamejs/scripts/refresh-vendor-manifest.js +132 -0
  792. package/lib/vendor/blamejs/scripts/release.js +652 -0
  793. package/lib/vendor/blamejs/scripts/sha3-digest.js +62 -0
  794. package/lib/vendor/blamejs/scripts/sign-release-artifact.js +92 -0
  795. package/lib/vendor/blamejs/scripts/test-integration.js +181 -0
  796. package/lib/vendor/blamejs/scripts/test-wiki-integration.js +126 -0
  797. package/lib/vendor/blamejs/scripts/validate-source-comment-blocks.js +77 -0
  798. package/lib/vendor/blamejs/scripts/vendor-data-gen.js +186 -0
  799. package/lib/vendor/blamejs/scripts/vendor-data-keygen.js +101 -0
  800. package/lib/vendor/blamejs/scripts/vendor-update.sh +278 -0
  801. package/lib/vendor/blamejs/test/00-primitives.js +19075 -0
  802. package/lib/vendor/blamejs/test/10-state.js +622 -0
  803. package/lib/vendor/blamejs/test/20-db.js +561 -0
  804. package/lib/vendor/blamejs/test/30-chain.js +2110 -0
  805. package/lib/vendor/blamejs/test/40-consumers.js +2453 -0
  806. package/lib/vendor/blamejs/test/50-integration.js +486 -0
  807. package/lib/vendor/blamejs/test/_helpers.js +10 -0
  808. package/lib/vendor/blamejs/test/_smoke-worker.js +69 -0
  809. package/lib/vendor/blamejs/test/fixtures/exploit-corpus/corpus.json +368 -0
  810. package/lib/vendor/blamejs/test/fixtures/http-client-stream-payload.txt +2 -0
  811. package/lib/vendor/blamejs/test/fixtures/worker-pool/echo.js +52 -0
  812. package/lib/vendor/blamejs/test/helpers/_codebase-shingle-worker.js +24 -0
  813. package/lib/vendor/blamejs/test/helpers/_codebase-shingle.js +203 -0
  814. package/lib/vendor/blamejs/test/helpers/_shape-match.js +513 -0
  815. package/lib/vendor/blamejs/test/helpers/check.js +36 -0
  816. package/lib/vendor/blamejs/test/helpers/cluster.js +70 -0
  817. package/lib/vendor/blamejs/test/helpers/db.js +143 -0
  818. package/lib/vendor/blamejs/test/helpers/drivers.js +207 -0
  819. package/lib/vendor/blamejs/test/helpers/fs-watch.js +101 -0
  820. package/lib/vendor/blamejs/test/helpers/http.js +14 -0
  821. package/lib/vendor/blamejs/test/helpers/index.js +93 -0
  822. package/lib/vendor/blamejs/test/helpers/json-round-trip.js +120 -0
  823. package/lib/vendor/blamejs/test/helpers/mocks.js +20 -0
  824. package/lib/vendor/blamejs/test/helpers/otel.js +13 -0
  825. package/lib/vendor/blamejs/test/helpers/services.js +380 -0
  826. package/lib/vendor/blamejs/test/helpers/wait.js +206 -0
  827. package/lib/vendor/blamejs/test/integration/cache.test.js +235 -0
  828. package/lib/vendor/blamejs/test/integration/cluster-provider-mysql.test.js +174 -0
  829. package/lib/vendor/blamejs/test/integration/federation-auth.test.js +611 -0
  830. package/lib/vendor/blamejs/test/integration/http-client.test.js +129 -0
  831. package/lib/vendor/blamejs/test/integration/log-stream.test.js +219 -0
  832. package/lib/vendor/blamejs/test/integration/mail-crypto-smime.test.js +181 -0
  833. package/lib/vendor/blamejs/test/integration/mail-dkim.test.js +152 -0
  834. package/lib/vendor/blamejs/test/integration/mail-smtp.test.js +161 -0
  835. package/lib/vendor/blamejs/test/integration/mtls-ca.test.js +289 -0
  836. package/lib/vendor/blamejs/test/integration/network-dns.test.js +123 -0
  837. package/lib/vendor/blamejs/test/integration/network-heartbeat.test.js +101 -0
  838. package/lib/vendor/blamejs/test/integration/ntp-check.test.js +89 -0
  839. package/lib/vendor/blamejs/test/integration/object-store-sigv4.test.js +403 -0
  840. package/lib/vendor/blamejs/test/integration/pqc-pkcs8-forward-compat.test.js +271 -0
  841. package/lib/vendor/blamejs/test/integration/pubsub.test.js +137 -0
  842. package/lib/vendor/blamejs/test/integration/queue-redis.test.js +352 -0
  843. package/lib/vendor/blamejs/test/integration/redis-client-tls.test.js +96 -0
  844. package/lib/vendor/blamejs/test/integration/ssrf-guard.test.js +98 -0
  845. package/lib/vendor/blamejs/test/integration/websocket-permessage-deflate.test.js +261 -0
  846. package/lib/vendor/blamejs/test/integration/ws-client-roundtrip.test.js +230 -0
  847. package/lib/vendor/blamejs/test/layer-0-primitives/a2a-tasks.test.js +211 -0
  848. package/lib/vendor/blamejs/test/layer-0-primitives/a2a.test.js +59 -0
  849. package/lib/vendor/blamejs/test/layer-0-primitives/access-lock.test.js +136 -0
  850. package/lib/vendor/blamejs/test/layer-0-primitives/acme.test.js +219 -0
  851. package/lib/vendor/blamejs/test/layer-0-primitives/age-gate.test.js +69 -0
  852. package/lib/vendor/blamejs/test/layer-0-primitives/agent-event-bus.test.js +266 -0
  853. package/lib/vendor/blamejs/test/layer-0-primitives/agent-idempotency.test.js +262 -0
  854. package/lib/vendor/blamejs/test/layer-0-primitives/agent-orchestrator.test.js +390 -0
  855. package/lib/vendor/blamejs/test/layer-0-primitives/agent-posture-chain.test.js +174 -0
  856. package/lib/vendor/blamejs/test/layer-0-primitives/agent-saga.test.js +279 -0
  857. package/lib/vendor/blamejs/test/layer-0-primitives/agent-snapshot.test.js +322 -0
  858. package/lib/vendor/blamejs/test/layer-0-primitives/agent-stream.test.js +227 -0
  859. package/lib/vendor/blamejs/test/layer-0-primitives/agent-tenant.test.js +302 -0
  860. package/lib/vendor/blamejs/test/layer-0-primitives/agent-trace.test.js +150 -0
  861. package/lib/vendor/blamejs/test/layer-0-primitives/ai-adverse-decision.test.js +44 -0
  862. package/lib/vendor/blamejs/test/layer-0-primitives/ai-content-detect.test.js +150 -0
  863. package/lib/vendor/blamejs/test/layer-0-primitives/ai-input.test.js +50 -0
  864. package/lib/vendor/blamejs/test/layer-0-primitives/ai-model-manifest.test.js +96 -0
  865. package/lib/vendor/blamejs/test/layer-0-primitives/ai-pref.test.js +76 -0
  866. package/lib/vendor/blamejs/test/layer-0-primitives/api-encrypt.test.js +1080 -0
  867. package/lib/vendor/blamejs/test/layer-0-primitives/app-shutdown.test.js +311 -0
  868. package/lib/vendor/blamejs/test/layer-0-primitives/archive-zip-stream.test.js +291 -0
  869. package/lib/vendor/blamejs/test/layer-0-primitives/archive.test.js +140 -0
  870. package/lib/vendor/blamejs/test/layer-0-primitives/arg-parser.test.js +267 -0
  871. package/lib/vendor/blamejs/test/layer-0-primitives/asn1-der.test.js +108 -0
  872. package/lib/vendor/blamejs/test/layer-0-primitives/asyncapi.test.js +929 -0
  873. package/lib/vendor/blamejs/test/layer-0-primitives/atomic-file-conflict-path.test.js +80 -0
  874. package/lib/vendor/blamejs/test/layer-0-primitives/audit-cve-defensive.test.js +176 -0
  875. package/lib/vendor/blamejs/test/layer-0-primitives/audit-daily-review.test.js +132 -0
  876. package/lib/vendor/blamejs/test/layer-0-primitives/audit-export-cadf.test.js +97 -0
  877. package/lib/vendor/blamejs/test/layer-0-primitives/audit-framework-namespaces.test.js +141 -0
  878. package/lib/vendor/blamejs/test/layer-0-primitives/audit-segregation.test.js +115 -0
  879. package/lib/vendor/blamejs/test/layer-0-primitives/audit-sign-ml-dsa-65.test.js +163 -0
  880. package/lib/vendor/blamejs/test/layer-0-primitives/audit-use-store.test.js +246 -0
  881. package/lib/vendor/blamejs/test/layer-0-primitives/auth-bot-challenge-verifier.test.js +485 -0
  882. package/lib/vendor/blamejs/test/layer-0-primitives/auth-bot-challenge.test.js +331 -0
  883. package/lib/vendor/blamejs/test/layer-0-primitives/auth-jwt-defenses.test.js +352 -0
  884. package/lib/vendor/blamejs/test/layer-0-primitives/auth-lockout.test.js +572 -0
  885. package/lib/vendor/blamejs/test/layer-0-primitives/auth-password-audit.test.js +61 -0
  886. package/lib/vendor/blamejs/test/layer-0-primitives/azure-blob-bucket-ops.test.js +258 -0
  887. package/lib/vendor/blamejs/test/layer-0-primitives/backup-manifest-signature.test.js +105 -0
  888. package/lib/vendor/blamejs/test/layer-0-primitives/backup-worker.test.js +34 -0
  889. package/lib/vendor/blamejs/test/layer-0-primitives/bearer-auth.test.js +107 -0
  890. package/lib/vendor/blamejs/test/layer-0-primitives/body-parser-chunked-malformed.test.js +131 -0
  891. package/lib/vendor/blamejs/test/layer-0-primitives/body-parser-smuggling.test.js +118 -0
  892. package/lib/vendor/blamejs/test/layer-0-primitives/boot-gates.test.js +85 -0
  893. package/lib/vendor/blamejs/test/layer-0-primitives/breach-deadline.test.js +38 -0
  894. package/lib/vendor/blamejs/test/layer-0-primitives/break-glass.test.js +861 -0
  895. package/lib/vendor/blamejs/test/layer-0-primitives/budr.test.js +55 -0
  896. package/lib/vendor/blamejs/test/layer-0-primitives/bundler-engine.test.js +209 -0
  897. package/lib/vendor/blamejs/test/layer-0-primitives/cache-status.test.js +129 -0
  898. package/lib/vendor/blamejs/test/layer-0-primitives/cache.test.js +871 -0
  899. package/lib/vendor/blamejs/test/layer-0-primitives/calendar.test.js +891 -0
  900. package/lib/vendor/blamejs/test/layer-0-primitives/canonical-json-jcs.test.js +43 -0
  901. package/lib/vendor/blamejs/test/layer-0-primitives/cdn-cache-control.test.js +243 -0
  902. package/lib/vendor/blamejs/test/layer-0-primitives/cert.test.js +550 -0
  903. package/lib/vendor/blamejs/test/layer-0-primitives/clear-site-data.test.js +107 -0
  904. package/lib/vendor/blamejs/test/layer-0-primitives/cli-api-key.test.js +147 -0
  905. package/lib/vendor/blamejs/test/layer-0-primitives/cli-audit-verify-chain.test.js +104 -0
  906. package/lib/vendor/blamejs/test/layer-0-primitives/cli-backup.test.js +135 -0
  907. package/lib/vendor/blamejs/test/layer-0-primitives/cli-config-drift.test.js +67 -0
  908. package/lib/vendor/blamejs/test/layer-0-primitives/cli-erase.test.js +75 -0
  909. package/lib/vendor/blamejs/test/layer-0-primitives/cli-file-type.test.js +98 -0
  910. package/lib/vendor/blamejs/test/layer-0-primitives/cli-helpers.test.js +145 -0
  911. package/lib/vendor/blamejs/test/layer-0-primitives/cli-mtls.test.js +133 -0
  912. package/lib/vendor/blamejs/test/layer-0-primitives/cli-password.test.js +97 -0
  913. package/lib/vendor/blamejs/test/layer-0-primitives/cli-restore.test.js +160 -0
  914. package/lib/vendor/blamejs/test/layer-0-primitives/cli-retention.test.js +84 -0
  915. package/lib/vendor/blamejs/test/layer-0-primitives/cli-security.test.js +69 -0
  916. package/lib/vendor/blamejs/test/layer-0-primitives/cli-vault.test.js +142 -0
  917. package/lib/vendor/blamejs/test/layer-0-primitives/client-hints.test.js +133 -0
  918. package/lib/vendor/blamejs/test/layer-0-primitives/cms-codec.test.js +237 -0
  919. package/lib/vendor/blamejs/test/layer-0-primitives/codebase-patterns.test.js +9600 -0
  920. package/lib/vendor/blamejs/test/layer-0-primitives/compliance-ai-act.test.js +575 -0
  921. package/lib/vendor/blamejs/test/layer-0-primitives/compliance-cascade.test.js +89 -0
  922. package/lib/vendor/blamejs/test/layer-0-primitives/compliance-eaa.test.js +36 -0
  923. package/lib/vendor/blamejs/test/layer-0-primitives/compliance-sanctions.test.js +712 -0
  924. package/lib/vendor/blamejs/test/layer-0-primitives/compliance.test.js +278 -0
  925. package/lib/vendor/blamejs/test/layer-0-primitives/config-drift.test.js +97 -0
  926. package/lib/vendor/blamejs/test/layer-0-primitives/config.test.js +424 -0
  927. package/lib/vendor/blamejs/test/layer-0-primitives/content-credentials.test.js +94 -0
  928. package/lib/vendor/blamejs/test/layer-0-primitives/cors.test.js +357 -0
  929. package/lib/vendor/blamejs/test/layer-0-primitives/cra-report.test.js +31 -0
  930. package/lib/vendor/blamejs/test/layer-0-primitives/credential-hash.test.js +226 -0
  931. package/lib/vendor/blamejs/test/layer-0-primitives/crypto-base64url.test.js +86 -0
  932. package/lib/vendor/blamejs/test/layer-0-primitives/crypto-envelope.test.js +85 -0
  933. package/lib/vendor/blamejs/test/layer-0-primitives/crypto-hash-files-parallel.test.js +193 -0
  934. package/lib/vendor/blamejs/test/layer-0-primitives/crypto-hash-stream.test.js +98 -0
  935. package/lib/vendor/blamejs/test/layer-0-primitives/crypto-hpke-pq.test.js +132 -0
  936. package/lib/vendor/blamejs/test/layer-0-primitives/crypto-hpke.test.js +155 -0
  937. package/lib/vendor/blamejs/test/layer-0-primitives/crypto-mlkem768-x25519.test.js +129 -0
  938. package/lib/vendor/blamejs/test/layer-0-primitives/crypto-namespace-hash.test.js +0 -0
  939. package/lib/vendor/blamejs/test/layer-0-primitives/crypto-random-int.test.js +72 -0
  940. package/lib/vendor/blamejs/test/layer-0-primitives/csp-builder.test.js +96 -0
  941. package/lib/vendor/blamejs/test/layer-0-primitives/csp-nonce.test.js +401 -0
  942. package/lib/vendor/blamejs/test/layer-0-primitives/csp-report.test.js +34 -0
  943. package/lib/vendor/blamejs/test/layer-0-primitives/csv.test.js +180 -0
  944. package/lib/vendor/blamejs/test/layer-0-primitives/daemon.test.js +210 -0
  945. package/lib/vendor/blamejs/test/layer-0-primitives/daily-byte-quota.test.js +153 -0
  946. package/lib/vendor/blamejs/test/layer-0-primitives/dark-patterns.test.js +66 -0
  947. package/lib/vendor/blamejs/test/layer-0-primitives/data-act.test.js +74 -0
  948. package/lib/vendor/blamejs/test/layer-0-primitives/db-collection-extensions.test.js +226 -0
  949. package/lib/vendor/blamejs/test/layer-0-primitives/db-collection.test.js +136 -0
  950. package/lib/vendor/blamejs/test/layer-0-primitives/db-init-extensions.test.js +165 -0
  951. package/lib/vendor/blamejs/test/layer-0-primitives/db-query-cross-schema.test.js +150 -0
  952. package/lib/vendor/blamejs/test/layer-0-primitives/db-query-extensions.test.js +191 -0
  953. package/lib/vendor/blamejs/test/layer-0-primitives/db-role-for.test.js +228 -0
  954. package/lib/vendor/blamejs/test/layer-0-primitives/db-vacuum.test.js +55 -0
  955. package/lib/vendor/blamejs/test/layer-0-primitives/db-worm.test.js +89 -0
  956. package/lib/vendor/blamejs/test/layer-0-primitives/ddl-change-control.test.js +184 -0
  957. package/lib/vendor/blamejs/test/layer-0-primitives/declare-row-policy.test.js +203 -0
  958. package/lib/vendor/blamejs/test/layer-0-primitives/declare-view.test.js +303 -0
  959. package/lib/vendor/blamejs/test/layer-0-primitives/dns-dnssec-algorithm.test.js +163 -0
  960. package/lib/vendor/blamejs/test/layer-0-primitives/dns-null-mx.test.js +39 -0
  961. package/lib/vendor/blamejs/test/layer-0-primitives/dora.test.js +165 -0
  962. package/lib/vendor/blamejs/test/layer-0-primitives/dr-runbook.test.js +59 -0
  963. package/lib/vendor/blamejs/test/layer-0-primitives/dsr-state-rules.test.js +55 -0
  964. package/lib/vendor/blamejs/test/layer-0-primitives/dsr.test.js +786 -0
  965. package/lib/vendor/blamejs/test/layer-0-primitives/dual-control.test.js +105 -0
  966. package/lib/vendor/blamejs/test/layer-0-primitives/early-hints.test.js +147 -0
  967. package/lib/vendor/blamejs/test/layer-0-primitives/events.test.js +105 -0
  968. package/lib/vendor/blamejs/test/layer-0-primitives/exploit-replay.test.js +243 -0
  969. package/lib/vendor/blamejs/test/layer-0-primitives/external-db-hardening.test.js +181 -0
  970. package/lib/vendor/blamejs/test/layer-0-primitives/external-db-migrate.test.js +190 -0
  971. package/lib/vendor/blamejs/test/layer-0-primitives/external-db-routing.test.js +531 -0
  972. package/lib/vendor/blamejs/test/layer-0-primitives/fal.test.js +118 -0
  973. package/lib/vendor/blamejs/test/layer-0-primitives/fapi2.test.js +89 -0
  974. package/lib/vendor/blamejs/test/layer-0-primitives/fda-21cfr11.test.js +156 -0
  975. package/lib/vendor/blamejs/test/layer-0-primitives/fdx.test.js +79 -0
  976. package/lib/vendor/blamejs/test/layer-0-primitives/fedcm-dbsc.test.js +216 -0
  977. package/lib/vendor/blamejs/test/layer-0-primitives/federation-vc-suite.test.js +434 -0
  978. package/lib/vendor/blamejs/test/layer-0-primitives/fido-mds3.test.js +432 -0
  979. package/lib/vendor/blamejs/test/layer-0-primitives/file-type.test.js +81 -0
  980. package/lib/vendor/blamejs/test/layer-0-primitives/flag.test.js +887 -0
  981. package/lib/vendor/blamejs/test/layer-0-primitives/forensic-snapshot.test.js +51 -0
  982. package/lib/vendor/blamejs/test/layer-0-primitives/fsm.test.js +375 -0
  983. package/lib/vendor/blamejs/test/layer-0-primitives/gcs-bucket-ops.test.js +321 -0
  984. package/lib/vendor/blamejs/test/layer-0-primitives/gdpr-ropa.test.js +41 -0
  985. package/lib/vendor/blamejs/test/layer-0-primitives/graphql-federation.test.js +32 -0
  986. package/lib/vendor/blamejs/test/layer-0-primitives/guard-agent-registry.test.js +87 -0
  987. package/lib/vendor/blamejs/test/layer-0-primitives/guard-all.test.js +328 -0
  988. package/lib/vendor/blamejs/test/layer-0-primitives/guard-archive.test.js +339 -0
  989. package/lib/vendor/blamejs/test/layer-0-primitives/guard-csv.test.js +694 -0
  990. package/lib/vendor/blamejs/test/layer-0-primitives/guard-dsn.test.js +296 -0
  991. package/lib/vendor/blamejs/test/layer-0-primitives/guard-email.test.js +234 -0
  992. package/lib/vendor/blamejs/test/layer-0-primitives/guard-envelope.test.js +192 -0
  993. package/lib/vendor/blamejs/test/layer-0-primitives/guard-event-bus-payload.test.js +89 -0
  994. package/lib/vendor/blamejs/test/layer-0-primitives/guard-event-bus-topic.test.js +71 -0
  995. package/lib/vendor/blamejs/test/layer-0-primitives/guard-filename.test.js +386 -0
  996. package/lib/vendor/blamejs/test/layer-0-primitives/guard-html-wcag.test.js +859 -0
  997. package/lib/vendor/blamejs/test/layer-0-primitives/guard-html.test.js +357 -0
  998. package/lib/vendor/blamejs/test/layer-0-primitives/guard-idempotency-key.test.js +92 -0
  999. package/lib/vendor/blamejs/test/layer-0-primitives/guard-imap-command.test.js +0 -0
  1000. package/lib/vendor/blamejs/test/layer-0-primitives/guard-jmap.test.js +174 -0
  1001. package/lib/vendor/blamejs/test/layer-0-primitives/guard-json.test.js +317 -0
  1002. package/lib/vendor/blamejs/test/layer-0-primitives/guard-list-id.test.js +199 -0
  1003. package/lib/vendor/blamejs/test/layer-0-primitives/guard-list-unsubscribe.test.js +214 -0
  1004. package/lib/vendor/blamejs/test/layer-0-primitives/guard-mail-compose.test.js +111 -0
  1005. package/lib/vendor/blamejs/test/layer-0-primitives/guard-mail-move.test.js +110 -0
  1006. package/lib/vendor/blamejs/test/layer-0-primitives/guard-mail-query.test.js +112 -0
  1007. package/lib/vendor/blamejs/test/layer-0-primitives/guard-mail-reply.test.js +86 -0
  1008. package/lib/vendor/blamejs/test/layer-0-primitives/guard-mail-sieve.test.js +92 -0
  1009. package/lib/vendor/blamejs/test/layer-0-primitives/guard-managesieve-command.test.js +301 -0
  1010. package/lib/vendor/blamejs/test/layer-0-primitives/guard-markdown.test.js +265 -0
  1011. package/lib/vendor/blamejs/test/layer-0-primitives/guard-message-id.test.js +0 -0
  1012. package/lib/vendor/blamejs/test/layer-0-primitives/guard-pop3-command.test.js +161 -0
  1013. package/lib/vendor/blamejs/test/layer-0-primitives/guard-posture-chain.test.js +100 -0
  1014. package/lib/vendor/blamejs/test/layer-0-primitives/guard-saga-config.test.js +79 -0
  1015. package/lib/vendor/blamejs/test/layer-0-primitives/guard-smtp-command.test.js +269 -0
  1016. package/lib/vendor/blamejs/test/layer-0-primitives/guard-snapshot-envelope.test.js +89 -0
  1017. package/lib/vendor/blamejs/test/layer-0-primitives/guard-stream-args.test.js +78 -0
  1018. package/lib/vendor/blamejs/test/layer-0-primitives/guard-svg.test.js +288 -0
  1019. package/lib/vendor/blamejs/test/layer-0-primitives/guard-tenant-id.test.js +69 -0
  1020. package/lib/vendor/blamejs/test/layer-0-primitives/guard-trace-context.test.js +102 -0
  1021. package/lib/vendor/blamejs/test/layer-0-primitives/guard-xml.test.js +202 -0
  1022. package/lib/vendor/blamejs/test/layer-0-primitives/guard-yaml.test.js +203 -0
  1023. package/lib/vendor/blamejs/test/layer-0-primitives/hal.test.js +51 -0
  1024. package/lib/vendor/blamejs/test/layer-0-primitives/honeytoken.test.js +50 -0
  1025. package/lib/vendor/blamejs/test/layer-0-primitives/html-balance.test.js +37 -0
  1026. package/lib/vendor/blamejs/test/layer-0-primitives/http-client-cache.test.js +692 -0
  1027. package/lib/vendor/blamejs/test/layer-0-primitives/http-client-stream.test.js +280 -0
  1028. package/lib/vendor/blamejs/test/layer-0-primitives/http-message-signature.test.js +225 -0
  1029. package/lib/vendor/blamejs/test/layer-0-primitives/i18n-messageformat.test.js +203 -0
  1030. package/lib/vendor/blamejs/test/layer-0-primitives/i18n.test.js +991 -0
  1031. package/lib/vendor/blamejs/test/layer-0-primitives/iab-mspa.test.js +63 -0
  1032. package/lib/vendor/blamejs/test/layer-0-primitives/iab-tcf.test.js +73 -0
  1033. package/lib/vendor/blamejs/test/layer-0-primitives/idempotency-key.test.js +612 -0
  1034. package/lib/vendor/blamejs/test/layer-0-primitives/importmap-integrity.test.js +56 -0
  1035. package/lib/vendor/blamejs/test/layer-0-primitives/inbox.test.js +166 -0
  1036. package/lib/vendor/blamejs/test/layer-0-primitives/incident-report.test.js +29 -0
  1037. package/lib/vendor/blamejs/test/layer-0-primitives/jose-jwe-experimental.test.js +121 -0
  1038. package/lib/vendor/blamejs/test/layer-0-primitives/json-api.test.js +58 -0
  1039. package/lib/vendor/blamejs/test/layer-0-primitives/json-round-trip-helper.test.js +110 -0
  1040. package/lib/vendor/blamejs/test/layer-0-primitives/jwt-external.test.js +159 -0
  1041. package/lib/vendor/blamejs/test/layer-0-primitives/keychain.test.js +0 -0
  1042. package/lib/vendor/blamejs/test/layer-0-primitives/legal-hold.test.js +118 -0
  1043. package/lib/vendor/blamejs/test/layer-0-primitives/local-db-thin.test.js +150 -0
  1044. package/lib/vendor/blamejs/test/layer-0-primitives/log-stream-cloudwatch.test.js +489 -0
  1045. package/lib/vendor/blamejs/test/layer-0-primitives/log-stream-otlp-grpc.test.js +207 -0
  1046. package/lib/vendor/blamejs/test/layer-0-primitives/log-stream-otlp.test.js +283 -0
  1047. package/lib/vendor/blamejs/test/layer-0-primitives/lro.test.js +65 -0
  1048. package/lib/vendor/blamejs/test/layer-0-primitives/mail-agent.test.js +417 -0
  1049. package/lib/vendor/blamejs/test/layer-0-primitives/mail-arf.test.js +208 -0
  1050. package/lib/vendor/blamejs/test/layer-0-primitives/mail-auth.test.js +910 -0
  1051. package/lib/vendor/blamejs/test/layer-0-primitives/mail-bimi.test.js +502 -0
  1052. package/lib/vendor/blamejs/test/layer-0-primitives/mail-bounce.test.js +680 -0
  1053. package/lib/vendor/blamejs/test/layer-0-primitives/mail-canspam.test.js +128 -0
  1054. package/lib/vendor/blamejs/test/layer-0-primitives/mail-crypto-pgp-experimental.test.js +149 -0
  1055. package/lib/vendor/blamejs/test/layer-0-primitives/mail-crypto-pgp.test.js +323 -0
  1056. package/lib/vendor/blamejs/test/layer-0-primitives/mail-crypto-smime.test.js +297 -0
  1057. package/lib/vendor/blamejs/test/layer-0-primitives/mail-dav.test.js +514 -0
  1058. package/lib/vendor/blamejs/test/layer-0-primitives/mail-deploy-tlsrpt.test.js +369 -0
  1059. package/lib/vendor/blamejs/test/layer-0-primitives/mail-deploy.test.js +199 -0
  1060. package/lib/vendor/blamejs/test/layer-0-primitives/mail-dkim.test.js +627 -0
  1061. package/lib/vendor/blamejs/test/layer-0-primitives/mail-feedback-id.test.js +56 -0
  1062. package/lib/vendor/blamejs/test/layer-0-primitives/mail-greylist.test.js +217 -0
  1063. package/lib/vendor/blamejs/test/layer-0-primitives/mail-helo.test.js +283 -0
  1064. package/lib/vendor/blamejs/test/layer-0-primitives/mail-journal.test.js +217 -0
  1065. package/lib/vendor/blamejs/test/layer-0-primitives/mail-mdn.test.js +334 -0
  1066. package/lib/vendor/blamejs/test/layer-0-primitives/mail-rbl.test.js +271 -0
  1067. package/lib/vendor/blamejs/test/layer-0-primitives/mail-require-tls.test.js +128 -0
  1068. package/lib/vendor/blamejs/test/layer-0-primitives/mail-scan.test.js +215 -0
  1069. package/lib/vendor/blamejs/test/layer-0-primitives/mail-send-deliver.test.js +336 -0
  1070. package/lib/vendor/blamejs/test/layer-0-primitives/mail-server-imap.test.js +732 -0
  1071. package/lib/vendor/blamejs/test/layer-0-primitives/mail-server-jmap.test.js +840 -0
  1072. package/lib/vendor/blamejs/test/layer-0-primitives/mail-server-managesieve.test.js +130 -0
  1073. package/lib/vendor/blamejs/test/layer-0-primitives/mail-server-mx.test.js +285 -0
  1074. package/lib/vendor/blamejs/test/layer-0-primitives/mail-server-pop3.test.js +74 -0
  1075. package/lib/vendor/blamejs/test/layer-0-primitives/mail-server-rate-limit.test.js +112 -0
  1076. package/lib/vendor/blamejs/test/layer-0-primitives/mail-server-registry.test.js +229 -0
  1077. package/lib/vendor/blamejs/test/layer-0-primitives/mail-server-submission.test.js +394 -0
  1078. package/lib/vendor/blamejs/test/layer-0-primitives/mail-server-tls.test.js +147 -0
  1079. package/lib/vendor/blamejs/test/layer-0-primitives/mail-sieve.test.js +151 -0
  1080. package/lib/vendor/blamejs/test/layer-0-primitives/mail-spam-score.test.js +204 -0
  1081. package/lib/vendor/blamejs/test/layer-0-primitives/mail-srs.test.js +152 -0
  1082. package/lib/vendor/blamejs/test/layer-0-primitives/mail-store-fts.test.js +279 -0
  1083. package/lib/vendor/blamejs/test/layer-0-primitives/mail-store.test.js +323 -0
  1084. package/lib/vendor/blamejs/test/layer-0-primitives/mail-unsubscribe.test.js +165 -0
  1085. package/lib/vendor/blamejs/test/layer-0-primitives/mail.test.js +439 -0
  1086. package/lib/vendor/blamejs/test/layer-0-primitives/mcp-tool-registry.test.js +202 -0
  1087. package/lib/vendor/blamejs/test/layer-0-primitives/mcp.test.js +155 -0
  1088. package/lib/vendor/blamejs/test/layer-0-primitives/metrics-shadow-registry.test.js +112 -0
  1089. package/lib/vendor/blamejs/test/layer-0-primitives/metrics-snapshot.test.js +224 -0
  1090. package/lib/vendor/blamejs/test/layer-0-primitives/middleware-compose-pipeline.test.js +278 -0
  1091. package/lib/vendor/blamejs/test/layer-0-primitives/money.test.js +376 -0
  1092. package/lib/vendor/blamejs/test/layer-0-primitives/mtls-ca-paths.test.js +89 -0
  1093. package/lib/vendor/blamejs/test/layer-0-primitives/nel.test.js +200 -0
  1094. package/lib/vendor/blamejs/test/layer-0-primitives/network-allowlist.test.js +106 -0
  1095. package/lib/vendor/blamejs/test/layer-0-primitives/network-byte-quota.test.js +133 -0
  1096. package/lib/vendor/blamejs/test/layer-0-primitives/network-dns-resolver.test.js +372 -0
  1097. package/lib/vendor/blamejs/test/layer-0-primitives/network-dns.test.js +635 -0
  1098. package/lib/vendor/blamejs/test/layer-0-primitives/network-heartbeat-passive.test.js +128 -0
  1099. package/lib/vendor/blamejs/test/layer-0-primitives/network-tls-build-options.test.js +130 -0
  1100. package/lib/vendor/blamejs/test/layer-0-primitives/network-tls-ct-inclusion.test.js +179 -0
  1101. package/lib/vendor/blamejs/test/layer-0-primitives/network-tls.test.js +447 -0
  1102. package/lib/vendor/blamejs/test/layer-0-primitives/network.test.js +369 -0
  1103. package/lib/vendor/blamejs/test/layer-0-primitives/nis2-report.test.js +21 -0
  1104. package/lib/vendor/blamejs/test/layer-0-primitives/nist-crosswalk.test.js +42 -0
  1105. package/lib/vendor/blamejs/test/layer-0-primitives/no-cache.test.js +98 -0
  1106. package/lib/vendor/blamejs/test/layer-0-primitives/notify.test.js +707 -0
  1107. package/lib/vendor/blamejs/test/layer-0-primitives/numeric-bounds.test.js +142 -0
  1108. package/lib/vendor/blamejs/test/layer-0-primitives/oauth-callback.test.js +72 -0
  1109. package/lib/vendor/blamejs/test/layer-0-primitives/observability-tracing.test.js +597 -0
  1110. package/lib/vendor/blamejs/test/layer-0-primitives/observability.test.js +190 -0
  1111. package/lib/vendor/blamejs/test/layer-0-primitives/openapi.test.js +877 -0
  1112. package/lib/vendor/blamejs/test/layer-0-primitives/otel-export.test.js +257 -0
  1113. package/lib/vendor/blamejs/test/layer-0-primitives/pagination.test.js +522 -0
  1114. package/lib/vendor/blamejs/test/layer-0-primitives/parsers-standalone.test.js +216 -0
  1115. package/lib/vendor/blamejs/test/layer-0-primitives/passkey.test.js +324 -0
  1116. package/lib/vendor/blamejs/test/layer-0-primitives/permissions.test.js +546 -0
  1117. package/lib/vendor/blamejs/test/layer-0-primitives/pqc-agent-curve.test.js +153 -0
  1118. package/lib/vendor/blamejs/test/layer-0-primitives/pqc-software.test.js +94 -0
  1119. package/lib/vendor/blamejs/test/layer-0-primitives/problem-details.test.js +195 -0
  1120. package/lib/vendor/blamejs/test/layer-0-primitives/process-spawn.test.js +62 -0
  1121. package/lib/vendor/blamejs/test/layer-0-primitives/promise-pool.test.js +93 -0
  1122. package/lib/vendor/blamejs/test/layer-0-primitives/protected-resource-metadata.test.js +68 -0
  1123. package/lib/vendor/blamejs/test/layer-0-primitives/protobuf-encoder.test.js +138 -0
  1124. package/lib/vendor/blamejs/test/layer-0-primitives/protocol-dispatcher.test.js +174 -0
  1125. package/lib/vendor/blamejs/test/layer-0-primitives/public-suffix.test.js +197 -0
  1126. package/lib/vendor/blamejs/test/layer-0-primitives/pubsub.test.js +232 -0
  1127. package/lib/vendor/blamejs/test/layer-0-primitives/queue-dlq-extend-lease.test.js +178 -0
  1128. package/lib/vendor/blamejs/test/layer-0-primitives/queue-flow-repeat.test.js +322 -0
  1129. package/lib/vendor/blamejs/test/layer-0-primitives/queue-priority-rate-progress.test.js +266 -0
  1130. package/lib/vendor/blamejs/test/layer-0-primitives/queue-sqs.test.js +300 -0
  1131. package/lib/vendor/blamejs/test/layer-0-primitives/rate-limit-cluster.test.js +338 -0
  1132. package/lib/vendor/blamejs/test/layer-0-primitives/rate-limit-registry.test.js +75 -0
  1133. package/lib/vendor/blamejs/test/layer-0-primitives/redact-dlp.test.js +246 -0
  1134. package/lib/vendor/blamejs/test/layer-0-primitives/redis-client.test.js +130 -0
  1135. package/lib/vendor/blamejs/test/layer-0-primitives/request-helpers.test.js +335 -0
  1136. package/lib/vendor/blamejs/test/layer-0-primitives/request-log.test.js +170 -0
  1137. package/lib/vendor/blamejs/test/layer-0-primitives/require-auth-cache-control.test.js +93 -0
  1138. package/lib/vendor/blamejs/test/layer-0-primitives/require-mtls.test.js +34 -0
  1139. package/lib/vendor/blamejs/test/layer-0-primitives/resource-access-lock.test.js +52 -0
  1140. package/lib/vendor/blamejs/test/layer-0-primitives/retention-floor.test.js +67 -0
  1141. package/lib/vendor/blamejs/test/layer-0-primitives/retry.test.js +535 -0
  1142. package/lib/vendor/blamejs/test/layer-0-primitives/router-cross-origin-redirect.test.js +0 -0
  1143. package/lib/vendor/blamejs/test/layer-0-primitives/router-tls0rtt.test.js +128 -0
  1144. package/lib/vendor/blamejs/test/layer-0-primitives/safe-async-loops.test.js +163 -0
  1145. package/lib/vendor/blamejs/test/layer-0-primitives/safe-async-parallel.test.js +170 -0
  1146. package/lib/vendor/blamejs/test/layer-0-primitives/safe-decompress.test.js +248 -0
  1147. package/lib/vendor/blamejs/test/layer-0-primitives/safe-dns.test.js +451 -0
  1148. package/lib/vendor/blamejs/test/layer-0-primitives/safe-ical.test.js +289 -0
  1149. package/lib/vendor/blamejs/test/layer-0-primitives/safe-icap.test.js +206 -0
  1150. package/lib/vendor/blamejs/test/layer-0-primitives/safe-jsonpath.test.js +104 -0
  1151. package/lib/vendor/blamejs/test/layer-0-primitives/safe-mime.test.js +339 -0
  1152. package/lib/vendor/blamejs/test/layer-0-primitives/safe-mount-info.test.js +180 -0
  1153. package/lib/vendor/blamejs/test/layer-0-primitives/safe-path.test.js +78 -0
  1154. package/lib/vendor/blamejs/test/layer-0-primitives/safe-sieve.test.js +123 -0
  1155. package/lib/vendor/blamejs/test/layer-0-primitives/safe-smtp.test.js +95 -0
  1156. package/lib/vendor/blamejs/test/layer-0-primitives/safe-url-idn-homograph.test.js +77 -0
  1157. package/lib/vendor/blamejs/test/layer-0-primitives/safe-vcard.test.js +257 -0
  1158. package/lib/vendor/blamejs/test/layer-0-primitives/saml-slo.test.js +249 -0
  1159. package/lib/vendor/blamejs/test/layer-0-primitives/sandbox.test.js +228 -0
  1160. package/lib/vendor/blamejs/test/layer-0-primitives/scheduler-exactly-once.test.js +238 -0
  1161. package/lib/vendor/blamejs/test/layer-0-primitives/scim-server.test.js +92 -0
  1162. package/lib/vendor/blamejs/test/layer-0-primitives/sd-jwt-vc.test.js +700 -0
  1163. package/lib/vendor/blamejs/test/layer-0-primitives/sd-notify.test.js +67 -0
  1164. package/lib/vendor/blamejs/test/layer-0-primitives/sec-cyber.test.js +85 -0
  1165. package/lib/vendor/blamejs/test/layer-0-primitives/security-assert.test.js +107 -0
  1166. package/lib/vendor/blamejs/test/layer-0-primitives/security-headers.test.js +175 -0
  1167. package/lib/vendor/blamejs/test/layer-0-primitives/seeders.test.js +816 -0
  1168. package/lib/vendor/blamejs/test/layer-0-primitives/self-update-standalone-verifier.test.js +168 -0
  1169. package/lib/vendor/blamejs/test/layer-0-primitives/self-update.test.js +302 -0
  1170. package/lib/vendor/blamejs/test/layer-0-primitives/server-timing.test.js +93 -0
  1171. package/lib/vendor/blamejs/test/layer-0-primitives/session-device-binding.test.js +247 -0
  1172. package/lib/vendor/blamejs/test/layer-0-primitives/session-extensions.test.js +295 -0
  1173. package/lib/vendor/blamejs/test/layer-0-primitives/shape-match.test.js +142 -0
  1174. package/lib/vendor/blamejs/test/layer-0-primitives/sigv4-bucket-ops.test.js +952 -0
  1175. package/lib/vendor/blamejs/test/layer-0-primitives/sigv4-multipart-sse.test.js +441 -0
  1176. package/lib/vendor/blamejs/test/layer-0-primitives/slug.test.js +330 -0
  1177. package/lib/vendor/blamejs/test/layer-0-primitives/smtp-policy.test.js +233 -0
  1178. package/lib/vendor/blamejs/test/layer-0-primitives/source-comment-blocks.test.js +105 -0
  1179. package/lib/vendor/blamejs/test/layer-0-primitives/speculation-rules.test.js +319 -0
  1180. package/lib/vendor/blamejs/test/layer-0-primitives/sse.test.js +148 -0
  1181. package/lib/vendor/blamejs/test/layer-0-primitives/ssrf-guard.test.js +283 -0
  1182. package/lib/vendor/blamejs/test/layer-0-primitives/standard-webhooks.test.js +67 -0
  1183. package/lib/vendor/blamejs/test/layer-0-primitives/static.test.js +266 -0
  1184. package/lib/vendor/blamejs/test/layer-0-primitives/step-up.test.js +487 -0
  1185. package/lib/vendor/blamejs/test/layer-0-primitives/storage-chunk-scratch.test.js +0 -0
  1186. package/lib/vendor/blamejs/test/layer-0-primitives/storage-presigned-url.test.js +773 -0
  1187. package/lib/vendor/blamejs/test/layer-0-primitives/stream-throttle.test.js +173 -0
  1188. package/lib/vendor/blamejs/test/layer-0-primitives/structured-fields.test.js +180 -0
  1189. package/lib/vendor/blamejs/test/layer-0-primitives/tcpa-10dlc.test.js +66 -0
  1190. package/lib/vendor/blamejs/test/layer-0-primitives/tenant-quota.test.js +89 -0
  1191. package/lib/vendor/blamejs/test/layer-0-primitives/test-coverage.test.js +571 -0
  1192. package/lib/vendor/blamejs/test/layer-0-primitives/test-harness.test.js +190 -0
  1193. package/lib/vendor/blamejs/test/layer-0-primitives/testing-request.test.js +119 -0
  1194. package/lib/vendor/blamejs/test/layer-0-primitives/testing.test.js +522 -0
  1195. package/lib/vendor/blamejs/test/layer-0-primitives/time.test.js +151 -0
  1196. package/lib/vendor/blamejs/test/layer-0-primitives/tls-exporter.test.js +168 -0
  1197. package/lib/vendor/blamejs/test/layer-0-primitives/tls-ocsp-ct.test.js +275 -0
  1198. package/lib/vendor/blamejs/test/layer-0-primitives/tls-ocsp-verify.test.js +105 -0
  1199. package/lib/vendor/blamejs/test/layer-0-primitives/tls-pinset-drift.test.js +35 -0
  1200. package/lib/vendor/blamejs/test/layer-0-primitives/tls-preferred-groups.test.js +81 -0
  1201. package/lib/vendor/blamejs/test/layer-0-primitives/tracing.test.js +280 -0
  1202. package/lib/vendor/blamejs/test/layer-0-primitives/uuid.test.js +93 -0
  1203. package/lib/vendor/blamejs/test/layer-0-primitives/vault-aad.test.js +277 -0
  1204. package/lib/vendor/blamejs/test/layer-0-primitives/vault-seal-pem-file.test.js +252 -0
  1205. package/lib/vendor/blamejs/test/layer-0-primitives/vendor-data.test.js +149 -0
  1206. package/lib/vendor/blamejs/test/layer-0-primitives/vendor-manifest.test.js +92 -0
  1207. package/lib/vendor/blamejs/test/layer-0-primitives/vex.test.js +661 -0
  1208. package/lib/vendor/blamejs/test/layer-0-primitives/watcher.test.js +308 -0
  1209. package/lib/vendor/blamejs/test/layer-0-primitives/web-push-vapid.test.js +144 -0
  1210. package/lib/vendor/blamejs/test/layer-0-primitives/webhook.test.js +674 -0
  1211. package/lib/vendor/blamejs/test/layer-0-primitives/websocket-channels.test.js +360 -0
  1212. package/lib/vendor/blamejs/test/layer-0-primitives/worker-pool.test.js +302 -0
  1213. package/lib/vendor/blamejs/test/layer-0-primitives/ws-client.test.js +349 -0
  1214. package/lib/vendor/blamejs/test/layer-1-state/api-key.test.js +717 -0
  1215. package/lib/vendor/blamejs/test/layer-5-integration/bundler-output.test.js +444 -0
  1216. package/lib/vendor/blamejs/test/layer-5-integration/guard-host-integration.test.js +597 -0
  1217. package/lib/vendor/blamejs/test/layer-5-integration/security-chaos.test.js +308 -0
  1218. package/lib/vendor/blamejs/test/smoke.js +431 -0
  1219. package/lib/webhooks.js +305 -0
  1220. package/package.json +43 -0
@@ -0,0 +1,1047 @@
1
+ "use strict";
2
+ /**
3
+ * @module b.mail.bimi
4
+ * @nav Mail
5
+ * @title BIMI
6
+ *
7
+ * @intro
8
+ * Brand Indicators for Message Identification — RFC 9091. BIMI
9
+ * records publish a sender's brand-logo URL in DNS so receiving
10
+ * MTAs can render it next to the message in supported clients
11
+ * (Gmail, Yahoo, Apple Mail). The TXT record format is:
12
+ *
13
+ * default._bimi.<domain> IN TXT "v=BIMI1; l=https://...; a=https://..."
14
+ *
15
+ * - `l=` URL to the SVG logo file (Tiny PS Profile per RFC 9091 §5)
16
+ * - `a=` URL to the Verified Mark Certificate (VMC / CMC) — §6
17
+ *
18
+ * BIMI is layered on a passing DMARC posture (the receiver requires
19
+ * DMARC at quarantine or reject). No-op for senders without DMARC
20
+ * enforcement.
21
+ *
22
+ * Surface:
23
+ *
24
+ * b.mail.bimi.recordShape({ logoUrl, vmcUrl?, selector? }) -> string
25
+ * b.mail.bimi.fetchPolicy(domain, opts?) -> record | null
26
+ * b.mail.bimi.parseRecord(text) -> record | null
27
+ * b.mail.bimi.fetchAndVerifyMark({ domain, vmcUrl, ... }) -> verified mark
28
+ * b.mail.bimi.validateTinyPsSvg(svgBytes) -> { ok, violations }
29
+ *
30
+ * `fetchAndVerifyMark` fetches a VMC / CMC over HTTPS via b.httpClient,
31
+ * parses it as X.509, validates the chain against the BIMI Group
32
+ * trust anchors (vendored at lib/vendor/bimi-trust-anchors.pem,
33
+ * operator-overridable via `trustAnchorsPem`), confirms the cert's
34
+ * subjectAltName URI matches the BIMI domain, and confirms the
35
+ * cert carries the BIMI mark-verification policy OID
36
+ * (1.3.6.1.5.5.7.3.31). The verified mark is returned as
37
+ * { svg, evidenceDocument } pulled from RFC 3709 logotype extension
38
+ * when present.
39
+ *
40
+ * `validateTinyPsSvg` enforces the AuthIndicators-WG Tiny PS subset:
41
+ * single root <svg>, version="1.2", baseProfile="tiny-ps", viewBox
42
+ * present, no script / style / foreignObject / animate / filter /
43
+ * image, no external href / xlink:href references (only #fragment
44
+ * permitted), bounded byte size (32 KiB cap).
45
+ *
46
+ * @card
47
+ * RFC 9091 BIMI policy lookup, VMC + CMC fetch + chain validation, and Tiny-PS SVG profile enforcement for inbox brand-mark rendering.
48
+ */
49
+
50
+ var dns = require("node:dns");
51
+ var nodeCrypto = require("node:crypto");
52
+ var dnsPromises = dns.promises;
53
+
54
+ var asn1 = require("./asn1-der");
55
+ var C = require("./constants");
56
+ var httpClient = require("./http-client");
57
+ var lazyRequire = require("./lazy-require");
58
+ var safeBuffer = require("./safe-buffer");
59
+ var safeUrl = require("./safe-url");
60
+ var validateOpts = require("./validate-opts");
61
+ var { defineClass, MailBimiError } = require("./framework-error");
62
+
63
+ // Audit emitter — lazy to avoid pulling the audit dispatcher into the
64
+ // module load graph until the first verify call. fetchAndVerifyMark is
65
+ // the only path that emits.
66
+ var audit = lazyRequire(function () { return require("./audit"); });
67
+
68
+ // Pre-existing BimiError covered DNS / record-shape failures. Kept for
69
+ // backwards-compatibility on the existing surface (recordShape /
70
+ // parseRecord / fetchPolicy). The new fetchAndVerifyMark / Tiny-PS
71
+ // surface uses MailBimiError so chain / policy / SVG failures route
72
+ // to a domain-shared class with the documented `bimi/...` codes.
73
+ var BimiError = defineClass("BimiError", { alwaysPermanent: true });
74
+
75
+ var BIMI_VERSION = "BIMI1";
76
+ var BIMI_DEFAULT_SELECTOR = "default";
77
+ var BIMI_RECORD_MAX_BYTES = C.BYTES.kib(2);
78
+
79
+ // AuthIndicators-WG Tiny-PS profile cap (32 KiB). Larger SVGs are
80
+ // refused at validate-time before any tokenization.
81
+ var TINY_PS_MAX_BYTES = C.BYTES.kib(32);
82
+
83
+ // VMC / CMC fetch cap. Production VMCs are typically ~10-20 KiB;
84
+ // 256 KiB is a generous ceiling that still bounds the download against
85
+ // pathological responses. Operators with a stricter posture pass
86
+ // `maxResponseBytes` to override.
87
+ var VMC_DEFAULT_MAX_BYTES = C.BYTES.kib(256);
88
+
89
+ // HTTP timeout for the VMC / CMC fetch. Operators pass `timeoutMs` to
90
+ // override.
91
+ var VMC_DEFAULT_TIMEOUT_MS = C.TIME.seconds(15);
92
+
93
+ // RFC 9091 6.1.1 — the BIMI mark-verification ExtendedKeyUsage OID.
94
+ // A valid VMC / CMC MUST list this OID under id-ce-extKeyUsage
95
+ // (2.5.29.37). The OID is identical for both certificate types; the
96
+ // distinction between VMC and CMC is conveyed by the cert's policyOIDs
97
+ // (id-ce-certificatePolicies, 2.5.29.32):
98
+ //
99
+ // 1.3.6.1.5.5.7.3.31 - id-kp-bimi (Mark Verification)
100
+ // 1.3.6.1.4.1.53087.1.1 - VMC policy (registered trademark)
101
+ // 1.3.6.1.4.1.53087.1.2 - CMC policy (common mark, prior-use)
102
+ //
103
+ // The framework verifies the EKU OID is present; the policy OIDs are
104
+ // surfaced on the result so operators can branch their UI on
105
+ // VMC-vs-CMC if their inbox renders them differently.
106
+ var BIMI_EKU_MARK_VERIFICATION = "1.3.6.1.5.5.7.3.31";
107
+ var VMC_POLICY_OID = "1.3.6.1.4.1.53087.1.1";
108
+ var CMC_POLICY_OID = "1.3.6.1.4.1.53087.1.2";
109
+
110
+ // RFC 3709 4.2 — the logotype extension OID.
111
+ var ID_PE_LOGOTYPE = "1.3.6.1.5.5.7.1.12";
112
+
113
+ // Vendored BIMI Group trust anchors. Loaded via b.vendorData which
114
+ // dual-hash + SLH-DSA-SHAKE-256f-signature-verifies before returning
115
+ // the bytes. The vendor file may be empty-of-PEM in source trees
116
+ // (operators populate via the documented refresh procedure);
117
+ // fetchAndVerifyMark refuses to validate if both the vendored bundle
118
+ // is empty and the call-site `trustAnchorsPem` opt is absent.
119
+ var vendorData = require("./vendor-data");
120
+ var _vendoredTrustAnchorsPem = "";
121
+ try {
122
+ _vendoredTrustAnchorsPem = vendorData.getAsString("bimi-trust-anchors");
123
+ } catch (_e) {
124
+ _vendoredTrustAnchorsPem = "";
125
+ }
126
+
127
+ function _validateUrl(url, label) {
128
+ // RFC 9091 4.2 — `l=` and `a=` MUST be HTTPS URLs.
129
+ try {
130
+ safeUrl.parse(url, { allowedProtocols: ["https:"] });
131
+ } catch (e) {
132
+ throw new BimiError("mail-bimi/bad-" + label,
133
+ "bimi: " + label + " must be an https:// URL - got '" + url + "': " +
134
+ ((e && e.message) || String(e)));
135
+ }
136
+ }
137
+
138
+ /**
139
+ * @primitive b.mail.bimi.recordShape
140
+ * @signature b.mail.bimi.recordShape(opts)
141
+ * @since 0.7.0
142
+ * @status stable
143
+ * @related b.mail.bimi.parseRecord, b.mail.bimi.fetchPolicy
144
+ *
145
+ * Builds the canonical RFC 9091 BIMI TXT-record string from a logo
146
+ * URL and optional VMC URL. Throws on missing or non-https URLs and
147
+ * on control / record-separator characters in the URLs. Operators
148
+ * publish the returned string at `default._bimi.<domain>` (or the
149
+ * selector subdomain if they're using non-default selectors).
150
+ *
151
+ * @opts
152
+ * {
153
+ * logoUrl: string, // required - https:// URL to Tiny-PS SVG
154
+ * vmcUrl: string?, // optional - https:// URL to VMC / CMC PEM
155
+ * selector: string?, // unused at record-shape time; reserved
156
+ * // for future per-selector behavior
157
+ * }
158
+ *
159
+ * @example
160
+ * var rec = b.mail.bimi.recordShape({
161
+ * logoUrl: "https://example.com/bimi/logo.svg",
162
+ * vmcUrl: "https://example.com/bimi/cert.pem",
163
+ * });
164
+ * // -> "v=BIMI1; l=https://example.com/bimi/logo.svg; a=https://example.com/bimi/cert.pem"
165
+ */
166
+ function recordShape(opts) {
167
+ validateOpts.requireObject(opts, "bimi.recordShape", BimiError);
168
+ validateOpts(opts, ["logoUrl", "vmcUrl", "selector"], "bimi.recordShape");
169
+ validateOpts.requireNonEmptyString(opts.logoUrl,
170
+ "bimi.recordShape: logoUrl", BimiError, "mail-bimi/no-logo");
171
+ _validateUrl(opts.logoUrl, "logoUrl");
172
+ if (opts.vmcUrl !== undefined && opts.vmcUrl !== null) {
173
+ validateOpts.requireNonEmptyString(opts.vmcUrl,
174
+ "bimi.recordShape: vmcUrl", BimiError, "mail-bimi/bad-vmc");
175
+ _validateUrl(opts.vmcUrl, "vmcUrl");
176
+ }
177
+ // No CR/LF/NUL/semicolon - defense-in-depth so a hostile URL can't
178
+ // inject a record-separator sequence into the published TXT.
179
+ if (/[\r\n\0;]/.test(opts.logoUrl)) {
180
+ throw new BimiError("mail-bimi/bad-logo",
181
+ "bimi.recordShape: logoUrl contains forbidden control / record-separator characters");
182
+ }
183
+ if (opts.vmcUrl && /[\r\n\0;]/.test(opts.vmcUrl)) {
184
+ throw new BimiError("mail-bimi/bad-vmc",
185
+ "bimi.recordShape: vmcUrl contains forbidden control / record-separator characters");
186
+ }
187
+
188
+ var fields = ["v=" + BIMI_VERSION, "l=" + opts.logoUrl];
189
+ if (opts.vmcUrl) fields.push("a=" + opts.vmcUrl);
190
+ return fields.join("; ");
191
+ }
192
+
193
+ /**
194
+ * @primitive b.mail.bimi.parseRecord
195
+ * @signature b.mail.bimi.parseRecord(text)
196
+ * @since 0.7.0
197
+ * @status stable
198
+ * @related b.mail.bimi.fetchPolicy
199
+ *
200
+ * Parses a BIMI TXT record into `{ v, l, a }`. Returns null when the
201
+ * text is not a v=BIMI1 record, the `l=` URL is missing, or the
202
+ * total bytes exceed the 2 KiB sanity cap. Use this when the operator
203
+ * already has the TXT bytes in hand (e.g. an inbound auth-results
204
+ * pipeline carrying the resolved record).
205
+ *
206
+ * @example
207
+ * var rv = b.mail.bimi.parseRecord("v=BIMI1; l=https://example.com/logo.svg");
208
+ * // -> { v: "BIMI1", l: "https://example.com/logo.svg", a: null }
209
+ */
210
+ function parseRecord(text) {
211
+ if (typeof text !== "string" || text.length === 0) return null;
212
+ if (text.length > BIMI_RECORD_MAX_BYTES) return null;
213
+ // RFC 9091 4 - semicolon-separated, key=value, leading "v=BIMI1".
214
+ var parts = text.split(";");
215
+ var rv = { v: null, l: null, a: null };
216
+ for (var i = 0; i < parts.length; i += 1) {
217
+ var p = parts[i].trim();
218
+ if (p.length === 0) continue;
219
+ var eq = p.indexOf("=");
220
+ if (eq === -1) continue;
221
+ var k = p.slice(0, eq).trim().toLowerCase();
222
+ var v = p.slice(eq + 1).trim();
223
+ if (k === "v" || k === "l" || k === "a") rv[k] = v;
224
+ }
225
+ if (rv.v !== BIMI_VERSION || !rv.l) return null;
226
+ return rv;
227
+ }
228
+
229
+ /**
230
+ * @primitive b.mail.bimi.fetchPolicy
231
+ * @signature b.mail.bimi.fetchPolicy(domain, opts?)
232
+ * @since 0.7.0
233
+ * @status stable
234
+ * @related b.mail.bimi.fetchAndVerifyMark
235
+ *
236
+ * Resolves `default._bimi.<domain>` (or `<selector>._bimi.<domain>`
237
+ * if `opts.selector` is set) and returns the parsed `{ v, l, a }`.
238
+ * Returns null when no TXT record exists or no record on the
239
+ * resolved name parses as v=BIMI1. Operators feed the returned
240
+ * `l=` / `a=` URLs into `fetchAndVerifyMark` to retrieve the
241
+ * verified mark.
242
+ *
243
+ * @opts
244
+ * {
245
+ * selector: string?, // default "default"
246
+ * dnsLookup: async (qname, type) => rows?, // operator-supplied resolver
247
+ * // (DoH / cache / fixture);
248
+ * // default: node:dns.resolveTxt
249
+ * }
250
+ *
251
+ * @example
252
+ * var pol = await b.mail.bimi.fetchPolicy("example.com");
253
+ * if (pol && pol.a) {
254
+ * var verified = await b.mail.bimi.fetchAndVerifyMark({
255
+ * domain: "example.com",
256
+ * vmcUrl: pol.a,
257
+ * });
258
+ * }
259
+ */
260
+ async function fetchPolicy(domain, opts) {
261
+ validateOpts.requireNonEmptyString(domain,
262
+ "bimi.fetchPolicy: domain", BimiError, "mail-bimi/bad-domain");
263
+ opts = opts || {};
264
+ var selector = opts.selector || BIMI_DEFAULT_SELECTOR;
265
+ var qname = selector + "._bimi." + domain;
266
+ var records;
267
+ try {
268
+ if (opts.dnsLookup) records = await opts.dnsLookup(qname, "TXT");
269
+ else records = await dnsPromises.resolveTxt(qname);
270
+ } catch (e) {
271
+ if (e && (e.code === "ENOTFOUND" || e.code === "ENODATA")) return null;
272
+ throw new BimiError("mail-bimi/lookup-failed",
273
+ "bimi.fetchPolicy: TXT lookup for " + qname + " failed: " +
274
+ ((e && e.message) || String(e)));
275
+ }
276
+ // RFC 9091 4.1 - a TXT lookup may return multiple chunks; pick
277
+ // the first record that begins with v=BIMI1.
278
+ for (var i = 0; i < (records || []).length; i += 1) {
279
+ var rec = records[i];
280
+ var s = Array.isArray(rec) ? rec.join("") : String(rec);
281
+ var parsed = parseRecord(s);
282
+ if (parsed) return parsed;
283
+ }
284
+ return null;
285
+ }
286
+
287
+ // ---- Tiny-PS SVG validation ----
288
+
289
+ // AuthIndicators-WG Tiny PS Profile 3 - refused element list. Each
290
+ // element here is an unconditional refuse: <script> enables JS
291
+ // execution, <style> carries CSS that can fetch external resources,
292
+ // <foreignObject> tunnels arbitrary HTML / XML, animation elements
293
+ // trigger time-based DOM changes (security + battery), <filter>
294
+ // requires a non-trivial renderer, <image> re-fetches arbitrary URLs
295
+ // (SSRF vector inside the inbox preview pipeline).
296
+ var TINY_PS_FORBIDDEN_TAGS = {
297
+ "script": true,
298
+ "style": true,
299
+ "foreignobject": true,
300
+ "animate": true,
301
+ "animatetransform": true,
302
+ "animatemotion": true,
303
+ "set": true,
304
+ "filter": true,
305
+ "image": true,
306
+ };
307
+
308
+ /**
309
+ * @primitive b.mail.bimi.validateTinyPsSvg
310
+ * @signature b.mail.bimi.validateTinyPsSvg(svgBytes)
311
+ * @since 0.8.53
312
+ * @status stable
313
+ * @related b.mail.bimi.fetchAndVerifyMark, b.guardSvg
314
+ *
315
+ * Validates a brand-mark SVG against the AuthIndicators-WG Tiny PS
316
+ * profile (RFC 9091 5). Tiny-PS is a strict subset of SVG 1.2:
317
+ * single <svg> root with `version="1.2"` and `baseProfile="tiny-ps"`,
318
+ * `viewBox` required, byte size up to 32 KiB, no scripts / styles /
319
+ * foreign content / animation / filters / external image refs, no
320
+ * external references in `href` / `xlink:href` attributes (only
321
+ * `#fragment` permitted), no `<!DOCTYPE>` / `<!ENTITY>` / processing
322
+ * instructions other than the XML prolog. Returns
323
+ * `{ ok, violations }` where each violation is `{ code, message }`.
324
+ * Throws `MailBimiError` (`bimi/svg-too-large`) when the input
325
+ * exceeds the byte cap; throws (`bimi/svg-tiny-ps-violation` with
326
+ * `parse-failed`) on tokenizer failure.
327
+ *
328
+ * @opts
329
+ * svgBytes: Buffer | string
330
+ *
331
+ * @example
332
+ * var rv = b.mail.bimi.validateTinyPsSvg('<svg version="1.2" baseProfile="tiny-ps" viewBox="0 0 1 1" xmlns="http://www.w3.org/2000/svg"></svg>');
333
+ * // -> { ok: true, violations: [] }
334
+ */
335
+ function validateTinyPsSvg(svgBytes) {
336
+ var s;
337
+ if (Buffer.isBuffer(svgBytes) || svgBytes instanceof Uint8Array) {
338
+ if (svgBytes.length > TINY_PS_MAX_BYTES) {
339
+ throw new MailBimiError("bimi/svg-too-large",
340
+ "bimi.validateTinyPsSvg: input " + svgBytes.length + " bytes exceeds Tiny-PS cap " + TINY_PS_MAX_BYTES);
341
+ }
342
+ s = safeBuffer.normalizeText(Buffer.from(svgBytes), {
343
+ maxBytes: TINY_PS_MAX_BYTES,
344
+ errorClass: MailBimiError,
345
+ typeCode: "bimi/svg-tiny-ps-violation",
346
+ sizeCode: "bimi/svg-too-large",
347
+ typeMessage: "bimi.validateTinyPsSvg: input must be Buffer / Uint8Array / string",
348
+ sizeMessage: "bimi.validateTinyPsSvg: input exceeds Tiny-PS cap " + TINY_PS_MAX_BYTES + " bytes",
349
+ });
350
+ } else if (typeof svgBytes === "string") {
351
+ if (Buffer.byteLength(svgBytes, "utf8") > TINY_PS_MAX_BYTES) {
352
+ throw new MailBimiError("bimi/svg-too-large",
353
+ "bimi.validateTinyPsSvg: input " + Buffer.byteLength(svgBytes, "utf8") + " bytes exceeds Tiny-PS cap " + TINY_PS_MAX_BYTES);
354
+ }
355
+ s = svgBytes;
356
+ } else {
357
+ throw new MailBimiError("bimi/svg-tiny-ps-violation",
358
+ "bimi.validateTinyPsSvg: input must be Buffer / Uint8Array / string");
359
+ }
360
+
361
+ var violations = [];
362
+ function _vio(code, message) { violations.push({ code: code, message: message }); }
363
+
364
+ var tokens;
365
+ try { tokens = _tokenizeTinyPsSvg(s); }
366
+ catch (e) {
367
+ throw new MailBimiError("bimi/svg-tiny-ps-violation",
368
+ "bimi.validateTinyPsSvg: parse-failed: " + ((e && e.message) || String(e)));
369
+ }
370
+
371
+ var rootSvg = null;
372
+ var depth = 0;
373
+ var sawSecondRoot = false;
374
+ for (var i = 0; i < tokens.length; i += 1) {
375
+ var t = tokens[i];
376
+
377
+ if (t.type === "doctype") {
378
+ _vio("doctype-forbidden", "<!DOCTYPE> is forbidden in Tiny-PS (entity-expansion / DTD class)");
379
+ continue;
380
+ }
381
+ if (t.type === "declaration") {
382
+ _vio("declaration-forbidden",
383
+ "<!" + (t.raw || "").slice(2, 30) + "...> declaration is forbidden in Tiny-PS");
384
+ continue;
385
+ }
386
+ if (t.type === "processingInstruction") {
387
+ var pir = (t.raw || "").trim();
388
+ if (!/^<\?xml\b/i.test(pir)) {
389
+ _vio("pi-forbidden", "processing instruction is forbidden in Tiny-PS: " + pir.slice(0, 40)) /* allow:raw-byte-literal — display truncation chars, not bytes */;
390
+ }
391
+ continue;
392
+ }
393
+ if (t.type === "comment" || t.type === "text" || t.type === "cdata") continue;
394
+
395
+ if (t.type === "endTag") {
396
+ depth -= 1;
397
+ continue;
398
+ }
399
+
400
+ if (t.type === "tag") {
401
+ var name = t.name;
402
+ if (TINY_PS_FORBIDDEN_TAGS[name]) {
403
+ _vio("element-forbidden",
404
+ "<" + name + "> is forbidden in Tiny-PS (script / style / animation / filter / image / foreign-content class)");
405
+ }
406
+ // Any element name starting with "animate" is animation (covers
407
+ // future SMIL extensions not in the static list above).
408
+ if (name.indexOf("animate") === 0 && !TINY_PS_FORBIDDEN_TAGS[name]) {
409
+ _vio("element-forbidden",
410
+ "<" + name + "> animation element is forbidden in Tiny-PS");
411
+ }
412
+
413
+ // Top-level root tracking. The root <svg> MUST be at depth 0; any
414
+ // second top-level element is a multi-root violation.
415
+ if (depth === 0) {
416
+ if (rootSvg === null) {
417
+ if (name !== "svg") {
418
+ _vio("root-not-svg",
419
+ "Tiny-PS root element must be <svg> - got <" + name + ">");
420
+ }
421
+ rootSvg = t;
422
+ } else if (!sawSecondRoot) {
423
+ _vio("multiple-root-elements",
424
+ "Tiny-PS document must have exactly one root <svg> element");
425
+ sawSecondRoot = true;
426
+ }
427
+ }
428
+
429
+ var attrs = t.attrs || {};
430
+ for (var aname in attrs) {
431
+ if (!Object.prototype.hasOwnProperty.call(attrs, aname)) continue;
432
+ var aval = String(attrs[aname]);
433
+ var lname = aname.toLowerCase();
434
+
435
+ // Event-handler attrs (onload / onclick / on*) - universally
436
+ // forbidden; same JS-execution class as <script>.
437
+ if (lname.indexOf("on") === 0 && lname.length > 2) {
438
+ _vio("event-handler-forbidden",
439
+ "event-handler attribute `" + aname + "` is forbidden in Tiny-PS");
440
+ }
441
+
442
+ // href / xlink:href - only #fragment refs allowed.
443
+ if (lname === "href" || lname === "xlink:href") {
444
+ if (aval.length > 0 && aval.charAt(0) !== "#") {
445
+ _vio("external-ref-forbidden",
446
+ "external reference in `" + aname + "='" + aval.slice(0, 60) /* allow:raw-time-literal — display truncation chars, not seconds */ + "...'` " +
447
+ "is forbidden in Tiny-PS (only `#fragment` permitted)");
448
+ }
449
+ }
450
+
451
+ // style attribute - Tiny-PS forbids <style>; the style attribute
452
+ // is treated as the same risk surface (CSS @import / url() class).
453
+ if (lname === "style") {
454
+ _vio("style-attr-forbidden",
455
+ "`style` attribute is forbidden in Tiny-PS (CSS @import / url() class)");
456
+ }
457
+ }
458
+
459
+ if (!t.selfClosing) depth += 1;
460
+ }
461
+ }
462
+
463
+ if (rootSvg !== null) {
464
+ var rootAttrs = rootSvg.attrs || {};
465
+ if (rootAttrs.version !== "1.2") {
466
+ _vio("bad-version",
467
+ "Tiny-PS requires version=\"1.2\" on root <svg> - got `" +
468
+ (rootAttrs.version === undefined ? "(missing)" : rootAttrs.version) + "`");
469
+ }
470
+ if (rootAttrs.baseProfile !== "tiny-ps" && rootAttrs.baseprofile !== "tiny-ps") {
471
+ _vio("bad-base-profile",
472
+ "Tiny-PS requires baseProfile=\"tiny-ps\" on root <svg> - got `" +
473
+ (rootAttrs.baseProfile || rootAttrs.baseprofile || "(missing)") + "`");
474
+ }
475
+ if (!rootAttrs.viewBox && !rootAttrs.viewbox) {
476
+ _vio("missing-viewbox",
477
+ "Tiny-PS requires viewBox attribute on root <svg>");
478
+ }
479
+ }
480
+
481
+ return { ok: violations.length === 0, violations: violations };
482
+ }
483
+
484
+ // _tokenizeTinyPsSvg - minimal SVG tokenizer for Tiny-PS profile checks.
485
+ // Same shape as guard-svg's tokenizer but tighter (Tiny-PS only needs
486
+ // element / attribute / declaration shapes; no sanitization output).
487
+ function _tokenizeTinyPsSvg(s) {
488
+ var tokens = [];
489
+ var len = s.length;
490
+ var pos = 0;
491
+
492
+ while (pos < len) {
493
+ var lt = s.indexOf("<", pos);
494
+ if (lt === -1) {
495
+ if (pos < len) tokens.push({ type: "text", raw: s.slice(pos, len) });
496
+ break;
497
+ }
498
+ if (lt > pos) tokens.push({ type: "text", raw: s.slice(pos, lt) });
499
+
500
+ if (s.startsWith("<!--", lt)) {
501
+ var endC = s.indexOf("-->", lt + 4);
502
+ if (endC === -1) throw new Error("unterminated comment"); // allow:bare-error-throw — caught by outer try/catch and re-thrown as MailBimiError("bimi/svg-tiny-ps-violation")
503
+ tokens.push({ type: "comment", raw: s.slice(lt, endC + 3) });
504
+ pos = endC + 3;
505
+ continue;
506
+ }
507
+ if (s.startsWith("<![CDATA[", lt)) {
508
+ var endX = s.indexOf("]]>", lt + 9);
509
+ if (endX === -1) throw new Error("unterminated CDATA"); // allow:bare-error-throw — caught by outer try/catch and re-thrown as MailBimiError("bimi/svg-tiny-ps-violation")
510
+ tokens.push({ type: "cdata", raw: s.slice(lt, endX + 3) });
511
+ pos = endX + 3;
512
+ continue;
513
+ }
514
+ if (s.startsWith("<!DOCTYPE", lt) || s.startsWith("<!doctype", lt)) {
515
+ var endD = s.indexOf(">", lt);
516
+ if (endD === -1) throw new Error("unterminated doctype"); // allow:bare-error-throw — caught by outer try/catch and re-thrown as MailBimiError("bimi/svg-tiny-ps-violation")
517
+ tokens.push({ type: "doctype", raw: s.slice(lt, endD + 1) });
518
+ pos = endD + 1;
519
+ continue;
520
+ }
521
+ if (s.charAt(lt + 1) === "?") {
522
+ var endP = s.indexOf("?>", lt + 2);
523
+ if (endP === -1) throw new Error("unterminated processing instruction"); // allow:bare-error-throw — caught by outer try/catch and re-thrown as MailBimiError("bimi/svg-tiny-ps-violation")
524
+ tokens.push({ type: "processingInstruction", raw: s.slice(lt, endP + 2) });
525
+ pos = endP + 2;
526
+ continue;
527
+ }
528
+ if (s.charAt(lt + 1) === "!") {
529
+ var endDecl = s.indexOf(">", lt);
530
+ if (endDecl === -1) throw new Error("unterminated declaration"); // allow:bare-error-throw — caught by outer try/catch and re-thrown as MailBimiError("bimi/svg-tiny-ps-violation")
531
+ tokens.push({ type: "declaration", raw: s.slice(lt, endDecl + 1) });
532
+ pos = endDecl + 1;
533
+ continue;
534
+ }
535
+ if (s.charAt(lt + 1) === "/") {
536
+ var endE = s.indexOf(">", lt);
537
+ if (endE === -1) throw new Error("unterminated end tag"); // allow:bare-error-throw — caught by outer try/catch and re-thrown as MailBimiError("bimi/svg-tiny-ps-violation")
538
+ var ename = s.slice(lt + 2, endE).trim().toLowerCase().split(/\s/)[0];
539
+ tokens.push({ type: "endTag", name: ename });
540
+ pos = endE + 1;
541
+ continue;
542
+ }
543
+
544
+ var pp = lt + 1;
545
+ var inQuote = "";
546
+ while (pp < len) {
547
+ var ch = s.charAt(pp);
548
+ if (inQuote) {
549
+ if (ch === inQuote) inQuote = "";
550
+ } else {
551
+ if (ch === '"' || ch === "'") inQuote = ch;
552
+ else if (ch === ">") break;
553
+ }
554
+ pp += 1;
555
+ }
556
+ if (pp >= len) throw new Error("unterminated start tag"); // allow:bare-error-throw — caught by outer try/catch and re-thrown as MailBimiError("bimi/svg-tiny-ps-violation")
557
+ var raw = s.slice(lt, pp + 1);
558
+ var inner = raw.slice(1, raw.length - 1);
559
+ var selfClosing = inner.endsWith("/");
560
+ if (selfClosing) inner = inner.slice(0, inner.length - 1);
561
+
562
+ var nameMatch = inner.match(/^([A-Za-z][A-Za-z0-9:_-]*)/);
563
+ var tagName = nameMatch ? nameMatch[1].toLowerCase() : "";
564
+ var attrSrc = nameMatch ? inner.slice(nameMatch[0].length) : "";
565
+
566
+ tokens.push({
567
+ type: "tag",
568
+ name: tagName,
569
+ attrs: _parseTinyPsAttrs(attrSrc),
570
+ raw: raw,
571
+ selfClosing: selfClosing,
572
+ });
573
+ pos = pp + 1;
574
+ }
575
+ return tokens;
576
+ }
577
+
578
+ // _parseTinyPsAttrs - quoted-only attribute parser. Tiny-PS values are
579
+ // typically quoted in well-formed XML; bare-token / single-quoted
580
+ // values are still accepted (the SVG profile is permissive on quoting).
581
+ function _parseTinyPsAttrs(src) {
582
+ var attrs = {};
583
+ var re = /([A-Za-z_:][A-Za-z0-9:._-]*)\s*=\s*("([^"]*)"|'([^']*)'|([^\s>]+))/g;
584
+ var m;
585
+ while ((m = re.exec(src)) !== null) {
586
+ var name = m[1];
587
+ var value = m[3] !== undefined ? m[3] : (m[4] !== undefined ? m[4] : (m[5] || ""));
588
+ attrs[name] = value;
589
+ }
590
+ return attrs;
591
+ }
592
+
593
+ // ---- VMC / CMC fetch + chain validation ----
594
+
595
+ /**
596
+ * @primitive b.mail.bimi.fetchAndVerifyMark
597
+ * @signature b.mail.bimi.fetchAndVerifyMark(opts)
598
+ * @since 0.8.53
599
+ * @status stable
600
+ * @related b.mail.bimi.fetchPolicy, b.mail.bimi.validateTinyPsSvg
601
+ *
602
+ * Fetches a VMC / CMC PEM from `opts.vmcUrl` (or `opts.cmcUrl`) over
603
+ * HTTPS, parses it as X.509, validates the chain against the BIMI
604
+ * Group trust anchors (vendored at lib/vendor/bimi-trust-anchors.pem,
605
+ * operator-overridable via `trustAnchorsPem`), confirms the cert's
606
+ * subjectAltName URI matches the BIMI domain, and confirms the cert
607
+ * carries the BIMI mark-verification ExtendedKeyUsage OID
608
+ * (1.3.6.1.5.5.7.3.31). Returns
609
+ * `{ ok, mark, certificate, vmcType }` where `vmcType` is `"vmc"`
610
+ * or `"cmc"` derived from the cert's policyOIDs, and `mark` carries
611
+ * the SVG bytes when the cert's RFC 3709 logotype extension is
612
+ * present (or null when not). Throws `MailBimiError` with one of
613
+ * the documented codes on any failure.
614
+ *
615
+ * @opts
616
+ * {
617
+ * domain: string, // required - BIMI domain to assert
618
+ * // matches subjectAltName URI
619
+ * vmcUrl: string?, // VMC PEM URL (https://); operator
620
+ * // passes one of vmcUrl / cmcUrl
621
+ * cmcUrl: string?, // CMC PEM URL (https://); same
622
+ * trustAnchorsPem: string?, // operator-supplied PEM bundle;
623
+ * // defaults to the vendored
624
+ * // bimi-trust-anchors.pem
625
+ * timeoutMs: number?, // default 15s
626
+ * maxResponseBytes: number?, // default 256 KiB
627
+ * audit: { safeEmit }, // operator-supplied audit dispatcher
628
+ * httpClient: object?, // default b.httpClient - test-only
629
+ * // override for unit tests that
630
+ * // want to stub the network call
631
+ * evidenceDocument: string?, // operator-supplied trademark
632
+ * // evidence URL; surfaced on
633
+ * // the result for audit logging
634
+ * }
635
+ *
636
+ * @example
637
+ * var rv = await b.mail.bimi.fetchAndVerifyMark({
638
+ * domain: "example.com",
639
+ * vmcUrl: "https://example.com/bimi/cert.pem",
640
+ * trustAnchorsPem: "-----BEGIN CERTIFICATE-----\n...",
641
+ * });
642
+ * // -> { ok, mark: { svg, evidenceDocument }, certificate, vmcType: "vmc" }
643
+ */
644
+ async function fetchAndVerifyMark(opts) {
645
+ validateOpts.requireObject(opts, "bimi.fetchAndVerifyMark", MailBimiError, "bimi/bad-opts");
646
+ validateOpts(opts, [
647
+ "domain", "vmcUrl", "cmcUrl",
648
+ "trustAnchorsPem", "timeoutMs", "maxResponseBytes",
649
+ "audit", "httpClient", "evidenceDocument",
650
+ ], "bimi.fetchAndVerifyMark");
651
+ validateOpts.requireNonEmptyString(opts.domain,
652
+ "bimi.fetchAndVerifyMark: domain", MailBimiError, "bimi/bad-opts");
653
+
654
+ var url = opts.vmcUrl || opts.cmcUrl;
655
+ if (typeof url !== "string" || url.length === 0) {
656
+ throw new MailBimiError("bimi/bad-opts",
657
+ "bimi.fetchAndVerifyMark: one of vmcUrl / cmcUrl is required");
658
+ }
659
+ // RFC 9091 6 - cert URL MUST be https.
660
+ try { safeUrl.parse(url, { allowedProtocols: ["https:"] }); }
661
+ catch (e) {
662
+ throw new MailBimiError("bimi/bad-opts",
663
+ "bimi.fetchAndVerifyMark: cert URL must be https - got `" + url + "`: " +
664
+ ((e && e.message) || String(e)));
665
+ }
666
+
667
+ var timeoutMs = opts.timeoutMs !== undefined ? opts.timeoutMs : VMC_DEFAULT_TIMEOUT_MS;
668
+ var maxBytes = opts.maxResponseBytes !== undefined ? opts.maxResponseBytes : VMC_DEFAULT_MAX_BYTES;
669
+
670
+ var hc = opts.httpClient || httpClient;
671
+
672
+ var rsp;
673
+ try {
674
+ rsp = await hc.request({
675
+ method: "GET",
676
+ url: url,
677
+ timeoutMs: timeoutMs,
678
+ maxResponseBytes: maxBytes,
679
+ allowedProtocols: ["https:"],
680
+ headers: { "Accept": "application/x-pem-file, application/pem-certificate-chain, text/plain" },
681
+ errorClass: MailBimiError,
682
+ });
683
+ } catch (e) {
684
+ _emitAudit(opts, "mail.bimi.vmc.fetched", "failure",
685
+ { url: url, domain: opts.domain, reason: (e && e.message) || String(e) });
686
+ throw new MailBimiError("bimi/vmc-fetch-failed",
687
+ "bimi.fetchAndVerifyMark: GET " + url + " failed: " + ((e && e.message) || String(e)));
688
+ }
689
+ if (rsp.statusCode !== 200) {
690
+ _emitAudit(opts, "mail.bimi.vmc.fetched", "failure",
691
+ { url: url, domain: opts.domain, status: rsp.statusCode });
692
+ throw new MailBimiError("bimi/vmc-fetch-failed",
693
+ "bimi.fetchAndVerifyMark: GET " + url + " returned status " + rsp.statusCode);
694
+ }
695
+ var pemBytes = Buffer.isBuffer(rsp.body) ? rsp.body.toString("utf8") : String(rsp.body || "");
696
+ if (pemBytes.indexOf("-----BEGIN CERTIFICATE-----") === -1) {
697
+ _emitAudit(opts, "mail.bimi.vmc.fetched", "failure",
698
+ { url: url, domain: opts.domain, reason: "no-pem" });
699
+ throw new MailBimiError("bimi/vmc-fetch-failed",
700
+ "bimi.fetchAndVerifyMark: response body is not a PEM-encoded CERTIFICATE chain");
701
+ }
702
+
703
+ var certPems = _splitPemChain(pemBytes);
704
+ if (certPems.length === 0) {
705
+ throw new MailBimiError("bimi/vmc-fetch-failed",
706
+ "bimi.fetchAndVerifyMark: no CERTIFICATE blocks in PEM body");
707
+ }
708
+ var leaf;
709
+ var intermediates = [];
710
+ try {
711
+ leaf = new nodeCrypto.X509Certificate(certPems[0]);
712
+ for (var i = 1; i < certPems.length; i += 1) {
713
+ intermediates.push(new nodeCrypto.X509Certificate(certPems[i]));
714
+ }
715
+ } catch (e) {
716
+ throw new MailBimiError("bimi/vmc-chain-invalid",
717
+ "bimi.fetchAndVerifyMark: X.509 parse failed: " + ((e && e.message) || String(e)));
718
+ }
719
+
720
+ var trustAnchorsPem = typeof opts.trustAnchorsPem === "string" && opts.trustAnchorsPem.length > 0
721
+ ? opts.trustAnchorsPem
722
+ : _vendoredTrustAnchorsPem;
723
+ var anchorPems = _splitPemChain(trustAnchorsPem);
724
+ if (anchorPems.length === 0) {
725
+ throw new MailBimiError("bimi/vmc-chain-invalid",
726
+ "bimi.fetchAndVerifyMark: no trust anchors configured - populate " +
727
+ "lib/vendor/bimi-trust-anchors.pem or pass `trustAnchorsPem` " +
728
+ "(see RFC 9091 6 / BIMI Group VMC issuer list)");
729
+ }
730
+ var anchors;
731
+ try {
732
+ anchors = anchorPems.map(function (p) { return new nodeCrypto.X509Certificate(p); });
733
+ } catch (e) {
734
+ throw new MailBimiError("bimi/vmc-chain-invalid",
735
+ "bimi.fetchAndVerifyMark: trust-anchor PEM parse failed: " + ((e && e.message) || String(e)));
736
+ }
737
+ var chainOk = _verifyCertChain(leaf, intermediates, anchors);
738
+ if (!chainOk.ok) {
739
+ _emitAudit(opts, "mail.bimi.vmc.verified", "failure",
740
+ { url: url, domain: opts.domain, reason: chainOk.reason });
741
+ throw new MailBimiError("bimi/vmc-chain-invalid",
742
+ "bimi.fetchAndVerifyMark: chain validation failed: " + chainOk.reason);
743
+ }
744
+
745
+ var sanMatch = _subjectAltNameMatchesDomain(leaf, opts.domain);
746
+ if (!sanMatch.ok) {
747
+ _emitAudit(opts, "mail.bimi.vmc.verified", "failure",
748
+ { url: url, domain: opts.domain, reason: "san-mismatch", san: sanMatch.found });
749
+ throw new MailBimiError("bimi/vmc-domain-mismatch",
750
+ "bimi.fetchAndVerifyMark: subjectAltName does not include BIMI domain `" +
751
+ opts.domain + "` - found: " + (sanMatch.found.length === 0 ? "(none)" : sanMatch.found.join(", ")));
752
+ }
753
+
754
+ var policyInfo = _extractBimiCertPolicy(leaf);
755
+ if (!policyInfo.hasMarkVerificationEku) {
756
+ _emitAudit(opts, "mail.bimi.vmc.verified", "failure",
757
+ { url: url, domain: opts.domain, reason: "missing-eku" });
758
+ throw new MailBimiError("bimi/vmc-policy-oid-missing",
759
+ "bimi.fetchAndVerifyMark: certificate is missing the BIMI mark-verification " +
760
+ "ExtendedKeyUsage OID (" + BIMI_EKU_MARK_VERIFICATION + ") - RFC 9091 6.1.1");
761
+ }
762
+
763
+ var vmcType = "vmc";
764
+ if (policyInfo.policyOids.indexOf(CMC_POLICY_OID) !== -1 &&
765
+ policyInfo.policyOids.indexOf(VMC_POLICY_OID) === -1) {
766
+ vmcType = "cmc";
767
+ }
768
+
769
+ var mark = {
770
+ svg: policyInfo.logoSvg,
771
+ evidenceDocument: typeof opts.evidenceDocument === "string" ? opts.evidenceDocument : null,
772
+ };
773
+
774
+ _emitAudit(opts, "mail.bimi.vmc.verified", "success", {
775
+ url: url,
776
+ domain: opts.domain,
777
+ vmcType: vmcType,
778
+ issuer: leaf.issuer,
779
+ subject: leaf.subject,
780
+ notAfter: leaf.validTo,
781
+ });
782
+
783
+ return {
784
+ ok: true,
785
+ mark: mark,
786
+ certificate: {
787
+ issuer: leaf.issuer,
788
+ subject: leaf.subject,
789
+ notAfter: leaf.validTo,
790
+ notBefore: leaf.validFrom,
791
+ policyOids: policyInfo.policyOids.slice(),
792
+ },
793
+ vmcType: vmcType,
794
+ };
795
+ }
796
+
797
+ // ---- helpers (chain validation, PEM parsing, ASN.1 OID walks) ----
798
+
799
+ function _splitPemChain(pemText) {
800
+ if (typeof pemText !== "string") return [];
801
+ var out = [];
802
+ var re = /-----BEGIN CERTIFICATE-----[\s\S]*?-----END CERTIFICATE-----/g;
803
+ var m;
804
+ while ((m = re.exec(pemText)) !== null) out.push(m[0]);
805
+ return out;
806
+ }
807
+
808
+ // _verifyCertChain - best-effort path validation using node:crypto
809
+ // X509Certificate.verify(publicKey) for signature verification, plus
810
+ // checkIssued() for issuer-DN matching and notBefore / notAfter for
811
+ // validity windows.
812
+ function _verifyCertChain(leaf, intermediates, anchors) {
813
+ var now = Date.now();
814
+ var current = leaf;
815
+ var depth = 0;
816
+ // Realistic VMC chains are leaf -> intermediate -> root (depth 2).
817
+ // 8 is a generous upper bound that prevents pathological loops.
818
+ var MAX_DEPTH = 8;
819
+
820
+ while (depth < MAX_DEPTH) {
821
+ var notBefore = Date.parse(current.validFrom);
822
+ var notAfter = Date.parse(current.validTo);
823
+ if (isFinite(notBefore) && now < notBefore) {
824
+ return { ok: false, reason: "cert not-yet-valid (notBefore=" + current.validFrom + ")" };
825
+ }
826
+ if (isFinite(notAfter) && now > notAfter) {
827
+ return { ok: false, reason: "cert expired (notAfter=" + current.validTo + ")" };
828
+ }
829
+
830
+ for (var ai = 0; ai < anchors.length; ai += 1) {
831
+ var anchor = anchors[ai];
832
+ if (current.checkIssued(anchor)) {
833
+ try {
834
+ if (current.verify(anchor.publicKey)) return { ok: true };
835
+ } catch (_e) { /* fall through to next anchor */ }
836
+ }
837
+ }
838
+ if (current.checkIssued(current)) {
839
+ return { ok: false, reason: "self-signed root not in trust-anchor bundle" };
840
+ }
841
+
842
+ var nextIssuer = null;
843
+ for (var ii = 0; ii < intermediates.length; ii += 1) {
844
+ var cand = intermediates[ii];
845
+ if (cand === current) continue;
846
+ if (current.checkIssued(cand)) {
847
+ try {
848
+ if (current.verify(cand.publicKey)) {
849
+ nextIssuer = cand;
850
+ break;
851
+ }
852
+ } catch (_e) { /* fall through */ }
853
+ }
854
+ }
855
+ if (nextIssuer === null) {
856
+ return { ok: false, reason: "no issuer found for `" + current.subject + "` in chain or trust anchors" };
857
+ }
858
+ current = nextIssuer;
859
+ depth += 1;
860
+ }
861
+ return { ok: false, reason: "chain depth exceeded " + MAX_DEPTH };
862
+ }
863
+
864
+ // _subjectAltNameMatchesDomain - RFC 9091 6 mandates a URI-form SAN
865
+ // pointing at the BIMI domain. Node's X509Certificate.subjectAltName
866
+ // is a comma-separated string like "URI:https://example.com, DNS:example.com";
867
+ // accept either a URI:* matching the domain's hostname OR a DNS:*
868
+ // exact match (compat - some VMC profiles emit DNS instead of URI).
869
+ function _subjectAltNameMatchesDomain(cert, domain) {
870
+ var raw = cert.subjectAltName || "";
871
+ var parts = raw.split(",").map(function (s) { return s.trim(); }).filter(Boolean);
872
+ var found = parts.slice();
873
+ var dom = domain.toLowerCase();
874
+ for (var i = 0; i < parts.length; i += 1) {
875
+ var p = parts[i];
876
+ var lp = p.toLowerCase();
877
+ if (lp.indexOf("dns:") === 0) {
878
+ var dns2 = lp.slice(4);
879
+ if (dns2 === dom) return { ok: true, found: found };
880
+ }
881
+ if (lp.indexOf("uri:") === 0) {
882
+ var uri = p.slice(4);
883
+ try {
884
+ var u = safeUrl.parse(uri, { allowedProtocols: ["https:", "http:"] });
885
+ if ((u.hostname || "").toLowerCase() === dom) return { ok: true, found: found };
886
+ } catch (_e) {
887
+ if (lp.indexOf(dom) !== -1) return { ok: true, found: found };
888
+ }
889
+ }
890
+ }
891
+ return { ok: false, found: found };
892
+ }
893
+
894
+ // _extractBimiCertPolicy - walks the X.509 raw DER to find:
895
+ // - extKeyUsage (id-ce-extKeyUsage 2.5.29.37) - confirms BIMI EKU OID
896
+ // - certificatePolicies (id-ce-certificatePolicies 2.5.29.32) - list
897
+ // - id-pe-logotype (1.3.6.1.5.5.7.1.12) - RFC 3709 SVG payload
898
+ function _extractBimiCertPolicy(cert) {
899
+ var rv = { hasMarkVerificationEku: false, policyOids: [], logoSvg: null };
900
+ var rawDer = cert.raw;
901
+ if (!rawDer || rawDer.length === 0) return rv;
902
+
903
+ var outer;
904
+ try { outer = asn1.readNode(rawDer, 0); }
905
+ catch (_e) { return rv; }
906
+ if (!outer || !outer.constructed) return rv;
907
+ var topChildren;
908
+ try { topChildren = asn1.readSequence(outer.value); }
909
+ catch (_e) { return rv; }
910
+ if (!topChildren || topChildren.length < 1) return rv;
911
+ var tbs = topChildren[0];
912
+ if (!tbs || !tbs.constructed) return rv;
913
+ var tbsChildren;
914
+ try { tbsChildren = asn1.readSequence(tbs.value); }
915
+ catch (_e) { return rv; }
916
+ // tbsCertificate has extensions [3] EXPLICIT - find the
917
+ // context-specific [3] tag (tagClass=2, tag=3).
918
+ var extsNode = null;
919
+ for (var ti = 0; ti < tbsChildren.length; ti += 1) {
920
+ var n = tbsChildren[ti];
921
+ if (n.tagClass === 2 && n.tag === 3) { extsNode = n; break; }
922
+ }
923
+ if (!extsNode) return rv;
924
+ var seqNode;
925
+ try { seqNode = asn1.readNode(extsNode.value, 0); }
926
+ catch (_e) { return rv; }
927
+ if (!seqNode || !seqNode.constructed) return rv;
928
+ var extList;
929
+ try { extList = asn1.readSequence(seqNode.value); }
930
+ catch (_e) { return rv; }
931
+ for (var ei = 0; ei < extList.length; ei += 1) {
932
+ var ext = extList[ei];
933
+ if (!ext.constructed) continue;
934
+ var extChildren;
935
+ try { extChildren = asn1.readSequence(ext.value); }
936
+ catch (_e) { continue; }
937
+ if (!extChildren || extChildren.length < 2) continue;
938
+ var oid;
939
+ try { oid = asn1.readOid(extChildren[0]); }
940
+ catch (_e) { continue; }
941
+ var octet = extChildren[extChildren.length - 1];
942
+ var inner;
943
+ try { inner = asn1.readNode(octet.value, 0); }
944
+ catch (_e) { continue; }
945
+
946
+ if (oid === "2.5.29.37") {
947
+ // ExtendedKeyUsage ::= SEQUENCE OF KeyPurposeId (KeyPurposeId ::= OBJECT IDENTIFIER)
948
+ if (!inner || !inner.constructed) continue;
949
+ var ekuList;
950
+ try { ekuList = asn1.readSequence(inner.value); }
951
+ catch (_e) { continue; }
952
+ for (var ek = 0; ek < ekuList.length; ek += 1) {
953
+ var ekuOid;
954
+ try { ekuOid = asn1.readOid(ekuList[ek]); }
955
+ catch (_e) { continue; }
956
+ if (ekuOid === BIMI_EKU_MARK_VERIFICATION) rv.hasMarkVerificationEku = true;
957
+ }
958
+ } else if (oid === "2.5.29.32") {
959
+ // certificatePolicies ::= SEQUENCE OF PolicyInformation
960
+ // PolicyInformation ::= SEQUENCE { policyIdentifier OID, ... }
961
+ if (!inner || !inner.constructed) continue;
962
+ var polList;
963
+ try { polList = asn1.readSequence(inner.value); }
964
+ catch (_e) { continue; }
965
+ for (var pi = 0; pi < polList.length; pi += 1) {
966
+ var polItem = polList[pi];
967
+ if (!polItem.constructed) continue;
968
+ var polChildren;
969
+ try { polChildren = asn1.readSequence(polItem.value); }
970
+ catch (_e) { continue; }
971
+ if (polChildren.length === 0) continue;
972
+ try {
973
+ var polOid = asn1.readOid(polChildren[0]);
974
+ if (polOid) rv.policyOids.push(polOid);
975
+ } catch (_e) { /* skip */ }
976
+ }
977
+ } else if (oid === ID_PE_LOGOTYPE) {
978
+ // RFC 3709 4.1 - LogotypeExtn carries SubjectLogo (best-effort
979
+ // SVG extraction; full RFC 3709 unpack requires walking nested
980
+ // SEQUENCEs to LogotypeImageData).
981
+ var found = _scanForEmbeddedSvg(inner, 8); /* allow:raw-byte-literal — string-prefix length for magic-bytes match, not bytes */
982
+ if (found) rv.logoSvg = found;
983
+ }
984
+ }
985
+ return rv;
986
+ }
987
+
988
+ function _scanForEmbeddedSvg(node, depthBudget) {
989
+ if (!node) return null;
990
+ if (depthBudget < 0) return null;
991
+
992
+ if (!node.constructed) {
993
+ if (!node.value || node.value.length < 4) return null;
994
+ var prefix = node.value.slice(0, Math.min(node.value.length, 64)).toString("utf8"); /* allow:raw-byte-literal — display truncation length, not bytes */
995
+ if (prefix.indexOf("<svg") !== -1 || /<\?xml[\s\S]*<svg/.test(prefix)) {
996
+ return node.value.toString("utf8");
997
+ }
998
+ return null;
999
+ }
1000
+
1001
+ var children;
1002
+ try { children = asn1.readSequence(node.value); }
1003
+ catch (_e) {
1004
+ try {
1005
+ var sub = asn1.readNode(node.value, 0);
1006
+ return _scanForEmbeddedSvg(sub, depthBudget - 1);
1007
+ } catch (_ee) { return null; }
1008
+ }
1009
+ for (var i = 0; i < children.length; i += 1) {
1010
+ var f = _scanForEmbeddedSvg(children[i], depthBudget - 1);
1011
+ if (f) return f;
1012
+ }
1013
+ return null;
1014
+ }
1015
+
1016
+ function _emitAudit(opts, action, outcome, metadata) {
1017
+ var sink = opts && opts.audit;
1018
+ try {
1019
+ if (sink && typeof sink.safeEmit === "function") {
1020
+ sink.safeEmit({ action: action, outcome: outcome, metadata: metadata });
1021
+ return;
1022
+ }
1023
+ var defaultSink = audit();
1024
+ if (defaultSink && typeof defaultSink.safeEmit === "function") {
1025
+ defaultSink.safeEmit({ action: action, outcome: outcome, metadata: metadata });
1026
+ }
1027
+ } catch (_e) {
1028
+ // drop-silent - by design. Audit failure must not break the
1029
+ // BIMI-verify hot path; observability counter takes care of the
1030
+ // signal upstream.
1031
+ }
1032
+ }
1033
+
1034
+ module.exports = {
1035
+ recordShape: recordShape,
1036
+ parseRecord: parseRecord,
1037
+ fetchPolicy: fetchPolicy,
1038
+ fetchAndVerifyMark: fetchAndVerifyMark,
1039
+ validateTinyPsSvg: validateTinyPsSvg,
1040
+ BIMI_VERSION: BIMI_VERSION,
1041
+ BIMI_EKU_MARK_VERIFICATION: BIMI_EKU_MARK_VERIFICATION,
1042
+ VMC_POLICY_OID: VMC_POLICY_OID,
1043
+ CMC_POLICY_OID: CMC_POLICY_OID,
1044
+ TINY_PS_MAX_BYTES: TINY_PS_MAX_BYTES,
1045
+ BimiError: BimiError,
1046
+ MailBimiError: MailBimiError,
1047
+ };