@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,1209 @@
1
+ "use strict";
2
+ /**
3
+ * @module b.guardHtml
4
+ * @nav Guards
5
+ * @title Guard Html
6
+ *
7
+ * @intro
8
+ * HTML / XSS defense — DOM-clobbering, mXSS, and entity-encoding
9
+ * bypasses. Tag and attribute allowlists; URL-scheme allowlist on
10
+ * every URL-bearing attribute; bidi / control / zero-width
11
+ * stripping. Threat catalog grounded in 2026 sanitizer research
12
+ * (DOMPurify CVE series, OWASP XSS / DOM-Clobbering / HTML5
13
+ * Security cheat sheets, PortSwigger / Sonar / trace37 mXSS
14
+ * write-ups, html5sec.org).
15
+ *
16
+ * Three profiles ship — `strict` / `balanced` / `permissive` —
17
+ * plus four compliance postures (`hipaa` / `pci-dss` / `gdpr` /
18
+ * `soc2`) that compose on top via the strictest-wins rule.
19
+ * `b.guardHtml.gate(opts)` returns a guard descriptor that plugs
20
+ * into `b.fileUpload.contentSafety` / `b.staticServe.contentSafety`
21
+ * / `b.guardAll`.
22
+ *
23
+ * Threat catalog covered:
24
+ *
25
+ * 1. Dangerous tags — script / style / link / meta / base /
26
+ * iframe / object / embed / applet / form / input / button /
27
+ * textarea / select / isindex / marquee / blink / layer /
28
+ * ilayer / plaintext / listing / xmp / audio / video / source
29
+ * / track / math / svg / template / noscript / noembed /
30
+ * noframes / portal / dialog / keygen / menuitem / command /
31
+ * frame / frameset.
32
+ * 2. on* event-handler attributes — every attribute matching
33
+ * /^on[a-z]/ is denied unconditionally.
34
+ * 3. Form-override attributes — formaction / formmethod /
35
+ * formenctype / formtarget / formnovalidate (CWE-1021).
36
+ * 4. Iframe inline-HTML — srcdoc on iframe always denied.
37
+ * 5. Custom-element registration — `is="..."` always denied.
38
+ * 6. CSP-bypass-shaped attributes — nonce / integrity /
39
+ * crossorigin stripped from sanitized output.
40
+ * 7. URL scheme validation on URL-bearing attributes — href /
41
+ * src / action / cite / longdesc / manifest / archive /
42
+ * codebase / data / classid / code / profile / ping / dynsrc
43
+ * / lowsrc / background / poster / icon / xlink:href.
44
+ * Per-profile allowlist; denied schemes (always):
45
+ * javascript / vbscript / livescript / mocha / data (outside
46
+ * image context) / file / mhtml / jar / intent / view-source.
47
+ * 8. CSS-injection inside style="..." values — expression( (IE),
48
+ * behavior: (IE), -moz-binding (Firefox legacy), javascript: /
49
+ * vbscript: / livescript: inside url(), @import, @namespace.
50
+ * 9. DOM clobbering — id and name attributes whose values match
51
+ * a well-known JS global (document / window / location /
52
+ * cookie / __proto__ / constructor / ...) on clobber-prone
53
+ * elements (form / input / button / a / img / iframe /
54
+ * object / embed / select / textarea).
55
+ * 10. mXSS hint detection — namespace-context-shift parents
56
+ * (svg / math), CDATA inside HTML mode, template content
57
+ * fragments with entity-encoded payloads.
58
+ * 11. Unicode bidi (CVE-2021-42574 Trojan Source) inside text
59
+ * and attribute values.
60
+ * 12. C0 control characters, null bytes, zero-width chars —
61
+ * strip-or-reject per profile.
62
+ * 13. IE conditional comments — <!--[if ...]>...<![endif]-->
63
+ * refused in strict, stripped in balanced.
64
+ * 14. <base href> / <base target> — silently redirects every
65
+ * relative URL on the page; always denied.
66
+ * 15. <meta http-equiv> with refresh / Set-Cookie / X-XSS-
67
+ * Protection — silent navigation + cookie injection.
68
+ * 16. ARIA spoofing — flagged for audit when role mismatches
69
+ * the semantic tag.
70
+ * 17. Image-context data: URLs — sanitize allows data:image/png
71
+ * / jpeg / gif / webp; svg+xml requires explicit opt-in.
72
+ * 18. Total-document size cap, per-attribute-value size cap,
73
+ * max-tag-depth (anti-recursion), max-attribute-count-per-
74
+ * tag.
75
+ *
76
+ * Threat-detection regex literals are composed PROGRAMMATICALLY
77
+ * from numeric codepoint range tables (BIDI_RANGES /
78
+ * C0_CTRL_RANGES / ZERO_WIDTH_RANGES). The source file never
79
+ * embeds the attack characters themselves.
80
+ *
81
+ * Sanitize discipline: this module ships a token-level rewriter
82
+ * that preserves the allowlisted tag set and strips the rest.
83
+ * For HOSTILE sources, the documented correct response is
84
+ * validate + reject — not sanitize. mXSS bypasses against any
85
+ * non-DOM sanitizer are a known arms-race; the gate's `refuse`
86
+ * path is the one with strong invariants. Operators with
87
+ * display-of-untrusted-html requirements should additionally
88
+ * serve content under a strict CSP (default-src 'none' or
89
+ * sandboxed iframe).
90
+ *
91
+ * @card
92
+ * HTML / XSS defense — DOM-clobbering, mXSS, and entity-encoding bypasses.
93
+ */
94
+
95
+ var codepointClass = require("./codepoint-class");
96
+ var guardHtmlWcag = require("./guard-html-wcag");
97
+ var lazyRequire = require("./lazy-require");
98
+ var gateContract = require("./gate-contract");
99
+ var C = require("./constants");
100
+ var numericBounds = require("./numeric-bounds");
101
+ var safeUrl = require("./safe-url");
102
+ var { GuardHtmlError } = require("./framework-error");
103
+
104
+ var observability = lazyRequire(function () { return require("./observability"); });
105
+ void observability;
106
+
107
+ var _err = GuardHtmlError.factory;
108
+ var HEX_RADIX = 16; // allow:raw-byte-literal — base-16 radix, not byte size
109
+
110
+ // ---- Codepoint catalog (shared via lib/codepoint-class) ----
111
+
112
+ var C0_CTRL_RE_G = codepointClass.C0_CTRL_RE_G;
113
+ var ZW_RE_G = codepointClass.ZW_RE_G;
114
+
115
+ // ---- Tag denylists / allowlists ----
116
+
117
+ // Always-dangerous tags. Active scripts, plugin embeds, form elements,
118
+ // frames, foreign-content (svg/math), template (mxss vector), legacy
119
+ // parser-mode-shift tags, HTML5 newer-attack-surface elements.
120
+ var DANGEROUS_TAGS = Object.freeze([
121
+ "script", "style", "link", "meta", "base", "frame", "frameset",
122
+ "iframe", "object", "embed", "applet", "form", "input", "button",
123
+ "textarea", "select", "option", "optgroup", "fieldset", "legend",
124
+ "datalist", "isindex", "marquee", "blink", "layer", "ilayer",
125
+ "plaintext", "listing", "xmp", "audio", "video", "source", "track",
126
+ "math", "svg", "template", "noscript", "noembed", "noframes",
127
+ "portal", "dialog", "keygen", "menuitem", "command",
128
+ ]);
129
+
130
+ // Strict text-formatting allowlist.
131
+ var STRICT_ALLOWED_TAGS = Object.freeze([
132
+ "p", "br", "hr", "b", "i", "u", "s", "em", "strong", "code", "pre",
133
+ "h1", "h2", "h3", "h4", "h5", "h6", "ul", "ol", "li", "blockquote",
134
+ "span", "div",
135
+ ]);
136
+
137
+ // Balanced — adds links, images, tables, semantic markup.
138
+ var BALANCED_ALLOWED_TAGS = Object.freeze(STRICT_ALLOWED_TAGS.concat([
139
+ "a", "img", "table", "thead", "tbody", "tfoot", "tr", "td", "th",
140
+ "caption", "colgroup", "col", "dl", "dt", "dd", "del", "ins",
141
+ "sub", "sup", "small", "abbr", "cite", "q", "kbd", "mark",
142
+ "figure", "figcaption", "address", "time",
143
+ ]));
144
+
145
+ // Permissive — every tag NOT in DANGEROUS_TAGS.
146
+ function _permissiveAllowed() {
147
+ var deny = Object.create(null);
148
+ DANGEROUS_TAGS.forEach(function (t) { deny[t] = true; });
149
+ // Common allowed set as the universe for the permissive list.
150
+ var universe = [
151
+ "html", "body", "head", "title", "main", "header", "footer",
152
+ "nav", "section", "article", "aside", "details", "summary",
153
+ "menu", "dir", "center", "font", "big", "tt", "strike",
154
+ "var", "samp", "i", "b", "u", "s", "em", "strong", "code", "pre",
155
+ "p", "br", "hr", "h1", "h2", "h3", "h4", "h5", "h6",
156
+ "ul", "ol", "li", "blockquote", "span", "div", "a", "img",
157
+ "table", "thead", "tbody", "tfoot", "tr", "td", "th", "caption",
158
+ "colgroup", "col", "dl", "dt", "dd", "del", "ins", "sub", "sup",
159
+ "small", "abbr", "cite", "q", "kbd", "mark", "figure", "figcaption",
160
+ "address", "time", "picture", "ruby", "rt", "rp", "wbr", "data",
161
+ "output", "progress", "meter", "bdo", "bdi",
162
+ ];
163
+ return Object.freeze(universe.filter(function (t) { return !deny[t]; }));
164
+ }
165
+ var PERMISSIVE_ALLOWED_TAGS = _permissiveAllowed();
166
+
167
+ // Form-override + dangerous attributes (excluding on*).
168
+ var DANGEROUS_ATTRS = Object.freeze([
169
+ "formaction", "formmethod", "formenctype", "formtarget", "formnovalidate",
170
+ "srcdoc", "is", "integrity", "nonce", "crossorigin",
171
+ "http-equiv", "manifest",
172
+ ]);
173
+
174
+ // URL-bearing attributes — values get scheme-validated.
175
+ var URL_ATTRS = Object.freeze([
176
+ "href", "src", "action", "cite", "longdesc", "manifest", "archive",
177
+ "codebase", "data", "classid", "code", "profile", "ping", "dynsrc",
178
+ "lowsrc", "background", "poster", "icon", "xlink:href",
179
+ ]);
180
+
181
+ // Always-allowed schemes (every profile).
182
+ var SAFE_SCHEMES = Object.freeze(["http", "https", "mailto", "tel"]);
183
+
184
+ // Schemes denied by default. `data` is dangerous globally except in
185
+ // image context (data:image/*) which is the only data: payload that
186
+ // can't directly script the page; the per-attribute check below honours
187
+ // that exception when allowImageData=true and the host tag is <img>.
188
+ var DANGEROUS_SCHEMES = Object.freeze([
189
+ "javascript", "vbscript", "livescript", "mocha", "ecmascript",
190
+ "file", "mhtml", "jar", "intent", "view-source", "feed", "data",
191
+ ]);
192
+
193
+ // CSS dangerous tokens — case-insensitive match against attribute
194
+ // value content.
195
+ var CSS_DANGEROUS_PATTERNS = Object.freeze([
196
+ /expression\s*\(/i,
197
+ /behavior\s*:/i,
198
+ /-moz-binding/i,
199
+ /javascript\s*:/i,
200
+ /vbscript\s*:/i,
201
+ /livescript\s*:/i,
202
+ /@import/i,
203
+ /@namespace/i,
204
+ ]);
205
+
206
+ // DOM-clobbering global-name targets. Element id/name matching one of
207
+ // these on a clobber-prone tag (form / input / button / a / img /
208
+ // iframe / object) overshadows the global access path.
209
+ var CLOBBER_GLOBALS = Object.freeze([
210
+ "document", "window", "location", "cookie", "top", "parent", "self",
211
+ "frames", "navigator", "history", "screen", "localStorage",
212
+ "sessionStorage", "indexedDB", "fetch", "XMLHttpRequest",
213
+ "atob", "btoa", "eval", "Function",
214
+ "constructor", "prototype", "__proto__", "innerHTML", "outerHTML",
215
+ "src", "href", "action", "form", "body", "head", "html",
216
+ "addEventListener", "removeEventListener", "postMessage",
217
+ "globalThis", "this", "import",
218
+ ]);
219
+
220
+ var CLOBBER_PRONE_TAGS = Object.freeze([
221
+ "form", "input", "button", "a", "img", "iframe", "object",
222
+ "embed", "select", "textarea",
223
+ ]);
224
+
225
+ var EVENT_HANDLER_RE = /^on[a-z]/i;
226
+
227
+ // ---- Profile presets ----
228
+
229
+ var PROFILES = Object.freeze({
230
+ "strict": {
231
+ allowedTags: STRICT_ALLOWED_TAGS,
232
+ allowedAttrs: Object.freeze(["class", "title", "lang", "dir"]),
233
+ urlSchemes: SAFE_SCHEMES,
234
+ allowImageData: false,
235
+ allowComments: false,
236
+ bidiPolicy: "reject",
237
+ controlPolicy: "reject",
238
+ nullBytePolicy: "reject",
239
+ zeroWidthPolicy: "strip",
240
+ cssPolicy: "reject",
241
+ domClobberPolicy: "reject",
242
+ mxssHintPolicy: "reject",
243
+ maxBytes: C.BYTES.mib(2),
244
+ maxAttrValueBytes: C.BYTES.kib(8),
245
+ maxTagDepth: 128, // allow:raw-byte-literal — tag-nesting depth count, not bytes
246
+ maxAttrsPerTag: 64, // allow:raw-byte-literal — attribute count per tag, not bytes
247
+ },
248
+ "balanced": {
249
+ allowedTags: BALANCED_ALLOWED_TAGS,
250
+ allowedAttrs: Object.freeze([
251
+ "class", "title", "lang", "dir", "alt", "href", "src", "width",
252
+ "height", "rel", "target", "colspan", "rowspan", "scope",
253
+ "datetime", "cite", "id",
254
+ ]),
255
+ urlSchemes: Object.freeze(SAFE_SCHEMES.concat(["ftp"])),
256
+ allowImageData: true,
257
+ allowComments: false,
258
+ bidiPolicy: "strip",
259
+ controlPolicy: "strip",
260
+ nullBytePolicy: "strip",
261
+ zeroWidthPolicy: "strip",
262
+ cssPolicy: "strip",
263
+ domClobberPolicy: "strip",
264
+ mxssHintPolicy: "audit",
265
+ maxBytes: C.BYTES.mib(8),
266
+ maxAttrValueBytes: C.BYTES.kib(32),
267
+ maxTagDepth: 256, // allow:raw-byte-literal — tag-nesting depth count, not bytes
268
+ maxAttrsPerTag: 128, // allow:raw-byte-literal — attribute count per tag, not bytes
269
+ },
270
+ "permissive": {
271
+ allowedTags: PERMISSIVE_ALLOWED_TAGS,
272
+ allowedAttrs: Object.freeze([
273
+ "class", "title", "lang", "dir", "alt", "href", "src", "width",
274
+ "height", "rel", "target", "colspan", "rowspan", "scope",
275
+ "datetime", "cite", "id", "tabindex", "accesskey",
276
+ ]),
277
+ urlSchemes: Object.freeze(SAFE_SCHEMES.concat(["ftp", "sftp", "ws", "wss"])),
278
+ allowImageData: true,
279
+ allowComments: true,
280
+ bidiPolicy: "audit",
281
+ controlPolicy: "strip",
282
+ nullBytePolicy: "strip",
283
+ zeroWidthPolicy: "strip",
284
+ cssPolicy: "audit",
285
+ domClobberPolicy: "audit",
286
+ mxssHintPolicy: "audit",
287
+ maxBytes: C.BYTES.mib(32),
288
+ maxAttrValueBytes: C.BYTES.kib(64),
289
+ maxTagDepth: 512, // allow:raw-byte-literal — tag-nesting depth count, not bytes
290
+ maxAttrsPerTag: 256, // allow:raw-byte-literal — attribute count per tag, not bytes
291
+ },
292
+ });
293
+
294
+ var DEFAULTS = Object.freeze(Object.assign({}, PROFILES["strict"], {
295
+ mode: "enforce",
296
+ maxRuntimeMs: C.TIME.seconds(30),
297
+ }));
298
+
299
+ var COMPLIANCE_POSTURES = Object.freeze({
300
+ "hipaa": {
301
+ allowedTags: STRICT_ALLOWED_TAGS,
302
+ bidiPolicy: "reject",
303
+ controlPolicy: "reject",
304
+ nullBytePolicy: "reject",
305
+ cssPolicy: "reject",
306
+ domClobberPolicy: "reject",
307
+ mxssHintPolicy: "reject",
308
+ forensicSnippetBytes: C.BYTES.bytes(256),
309
+ },
310
+ "pci-dss": {
311
+ allowedTags: STRICT_ALLOWED_TAGS,
312
+ bidiPolicy: "reject",
313
+ controlPolicy: "reject",
314
+ nullBytePolicy: "reject",
315
+ cssPolicy: "reject",
316
+ domClobberPolicy: "reject",
317
+ mxssHintPolicy: "reject",
318
+ urlSchemes: SAFE_SCHEMES,
319
+ forensicSnippetBytes: C.BYTES.bytes(256),
320
+ },
321
+ "gdpr": {
322
+ allowedTags: BALANCED_ALLOWED_TAGS,
323
+ bidiPolicy: "strip",
324
+ controlPolicy: "strip",
325
+ cssPolicy: "strip",
326
+ domClobberPolicy: "strip",
327
+ mxssHintPolicy: "audit",
328
+ forensicSnippetBytes: C.BYTES.bytes(128),
329
+ },
330
+ "soc2": {
331
+ allowedTags: STRICT_ALLOWED_TAGS,
332
+ bidiPolicy: "reject",
333
+ controlPolicy: "reject",
334
+ nullBytePolicy: "reject",
335
+ cssPolicy: "reject",
336
+ domClobberPolicy: "reject",
337
+ mxssHintPolicy: "reject",
338
+ forensicSnippetBytes: C.BYTES.bytes(512),
339
+ },
340
+ });
341
+
342
+ // ---- Internal helpers ----
343
+
344
+ function _resolveOpts(opts) {
345
+ return gateContract.resolveProfileAndPosture(opts, {
346
+ profiles: PROFILES,
347
+ compliancePostures: COMPLIANCE_POSTURES,
348
+ defaults: DEFAULTS,
349
+ errorClass: GuardHtmlError,
350
+ errCodePrefix: "html",
351
+ });
352
+ }
353
+
354
+ /**
355
+ * @primitive b.guardHtml.escapeText
356
+ * @signature b.guardHtml.escapeText(value)
357
+ * @since 0.7.6
358
+ * @related b.guardHtml.escapeAttr, b.guardHtml.sanitize
359
+ *
360
+ * HTML entity-escape for text-content context. Encodes the five
361
+ * core characters `&` `<` `>` `"` `'` so the result is safe to
362
+ * embed inside an element's text body. `null` / `undefined` coerce
363
+ * to an empty string. Use this for plain interpolation of
364
+ * untrusted strings into rendered HTML.
365
+ *
366
+ * @example
367
+ * var html = b.guardHtml.escapeText("<oops>");
368
+ * // → "&lt;oops&gt;"
369
+ *
370
+ * var blank = b.guardHtml.escapeText(null);
371
+ * // → ""
372
+ */
373
+ function escapeText(value) {
374
+ var s = value == null ? "" : String(value);
375
+ return s
376
+ .replace(/&/g, "&amp;")
377
+ .replace(/</g, "&lt;")
378
+ .replace(/>/g, "&gt;")
379
+ .replace(/"/g, "&quot;")
380
+ .replace(/'/g, "&#39;");
381
+ }
382
+
383
+ /**
384
+ * @primitive b.guardHtml.escapeAttr
385
+ * @signature b.guardHtml.escapeAttr(value)
386
+ * @since 0.7.6
387
+ * @related b.guardHtml.escapeText, b.guardHtml.sanitize
388
+ *
389
+ * HTML entity-escape for attribute-value context. Same five
390
+ * characters as `escapeText` plus backtick (legacy IE attribute
391
+ * terminator) and `=` (unquoted-attribute edge). Use this when
392
+ * interpolating an untrusted string between double-quoted attribute
393
+ * delimiters.
394
+ *
395
+ * @example
396
+ * var attr = b.guardHtml.escapeAttr('say "hi"');
397
+ * // → "say &quot;hi&quot;"
398
+ *
399
+ * var ie = b.guardHtml.escapeAttr("a`b=c");
400
+ * // → "a&#96;b&#61;c"
401
+ */
402
+ function escapeAttr(value) {
403
+ var s = value == null ? "" : String(value);
404
+ return s
405
+ .replace(/&/g, "&amp;")
406
+ .replace(/</g, "&lt;")
407
+ .replace(/>/g, "&gt;")
408
+ .replace(/"/g, "&quot;")
409
+ .replace(/'/g, "&#39;")
410
+ .replace(/`/g, "&#96;")
411
+ .replace(/=/g, "&#61;");
412
+ }
413
+
414
+ // HTML5 named entities that decode to ASCII codepoints — focused on
415
+ // the entries browsers honor inside URL contexts (whitespace, control
416
+ // chars, scheme-significant punctuation). The full WHATWG named-
417
+ // character-reference table is ~2,231 entries; this is the
418
+ // security-load-bearing subset documented in scheme-bypass writeups
419
+ // (CVE-2026-30838 class). High-codepoint named entities (e.g. mathematical
420
+ // symbols) don't affect URL scheme parsing, so they're omitted.
421
+ var NAMED_ENTITY_ASCII = {
422
+ // Whitespace + control chars browsers strip inside URL schemes
423
+ Tab: "\t", NewLine: "\n",
424
+ // Scheme-significant punctuation
425
+ colon: ":", semi: ";", period: ".", sol: "/", bsol: "\\",
426
+ num: "#", excl: "!", quest: "?", lpar: "(", rpar: ")",
427
+ lsqb: "[", rsqb: "]", lcub: "{", rcub: "}",
428
+ // Quotes / brackets
429
+ quot: "\"", apos: "'", lt: "<", gt: ">",
430
+ // Misc ASCII
431
+ amp: "&", commat: "@", dollar: "$", percnt: "%",
432
+ ast: "*", plus: "+", lowbar: "_", hyphen: "-",
433
+ // Whitespace markers (codepoints in the ASCII / Latin-1 range that
434
+ // browsers treat as URL-strippable)
435
+ nbsp: " ",
436
+ };
437
+
438
+ // _normalizeUrl — peel off entity-encoded leading whitespace and
439
+ // HTML/URL-encoded scheme prefix tricks, then return the lowercased
440
+ // scheme. Returns "" if no scheme.
441
+ function _extractScheme(rawUrl) {
442
+ var s = String(rawUrl || "").trim();
443
+ // Decode HTML numeric entities just enough to expose hidden schemes
444
+ // like &#x6A;avascript:... or &#106;avascript:...
445
+ s = s.replace(/&#x([0-9a-f]+);/gi, function (_m, h) {
446
+ return String.fromCharCode(parseInt(h, HEX_RADIX));
447
+ });
448
+ s = s.replace(/&#(\d+);/g, function (_m, d) {
449
+ return String.fromCharCode(parseInt(d, 10));
450
+ });
451
+ // Decode HTML5 named entities that browsers honor inside URL
452
+ // contexts. Without this, payloads like `java&Tab;script:alert(1)`
453
+ // bypass the scheme allowlist (the literal `&Tab;` between `java`
454
+ // and `script:` doesn't match any denied scheme; the browser then
455
+ // decodes the entity, strips the tab, and executes javascript:).
456
+ s = s.replace(/&([A-Za-z][A-Za-z0-9]+);/g, function (m, name) {
457
+ if (Object.prototype.hasOwnProperty.call(NAMED_ENTITY_ASCII, name)) {
458
+ return NAMED_ENTITY_ASCII[name];
459
+ }
460
+ return m;
461
+ });
462
+ // Strip embedded whitespace + control chars + zero-widths the
463
+ // URL parser would tolerate.
464
+ s = s.replace(C0_CTRL_RE_G, "").replace(ZW_RE_G, "");
465
+ var m = s.match(/^([A-Za-z][A-Za-z0-9+.-]*):/);
466
+ return m ? m[1].toLowerCase() : "";
467
+ }
468
+
469
+ function _isImageDataUrl(rawUrl) {
470
+ var s = String(rawUrl || "").trim();
471
+ return /^data:image\/(png|jpeg|jpg|gif|webp);/i.test(s);
472
+ }
473
+
474
+ function _isUrlAttr(name) {
475
+ var n = name.toLowerCase();
476
+ for (var i = 0; i < URL_ATTRS.length; i += 1) {
477
+ if (URL_ATTRS[i] === n) return true;
478
+ }
479
+ return false;
480
+ }
481
+
482
+ function _isClobberProne(tag) {
483
+ var t = tag.toLowerCase();
484
+ for (var i = 0; i < CLOBBER_PRONE_TAGS.length; i += 1) {
485
+ if (CLOBBER_PRONE_TAGS[i] === t) return true;
486
+ }
487
+ return false;
488
+ }
489
+
490
+ function _isClobberGlobal(name) {
491
+ for (var i = 0; i < CLOBBER_GLOBALS.length; i += 1) {
492
+ if (CLOBBER_GLOBALS[i] === name) return true;
493
+ }
494
+ return false;
495
+ }
496
+
497
+ function _isCssDangerous(value) {
498
+ for (var i = 0; i < CSS_DANGEROUS_PATTERNS.length; i += 1) {
499
+ if (CSS_DANGEROUS_PATTERNS[i].test(value)) return true;
500
+ }
501
+ return false;
502
+ }
503
+
504
+ // ---- Tokenizer ----
505
+ //
506
+ // Pure-JS HTML scanner. NOT a full DOM parser — designed for threat
507
+ // detection and conservative tag/attr filtering. The output is a list
508
+ // of tokens: { type: "tag" | "endTag" | "comment" | "text" | "doctype",
509
+ // name, attrs, raw, start, end }. Sanitization re-walks this list and
510
+ // emits a filtered HTML string.
511
+
512
+ function _tokenize(input, maxBytes) {
513
+ var s = String(input || "");
514
+ if (s.length > maxBytes) {
515
+ throw _err("html.too-large",
516
+ "input " + s.length + " bytes exceeds maxBytes " + maxBytes);
517
+ }
518
+ var tokens = [];
519
+ var len = s.length;
520
+ var pos = 0;
521
+
522
+ while (pos < len) {
523
+ var lt = s.indexOf("<", pos);
524
+ if (lt === -1) {
525
+ tokens.push({ type: "text", raw: s.slice(pos), start: pos, end: len });
526
+ break;
527
+ }
528
+ if (lt > pos) {
529
+ tokens.push({ type: "text", raw: s.slice(pos, lt), start: pos, end: lt });
530
+ }
531
+
532
+ // Comment / CDATA / doctype
533
+ if (s.startsWith("<!--", lt)) {
534
+ var endC = s.indexOf("-->", lt + 4);
535
+ if (endC === -1) endC = len;
536
+ else endC += 3;
537
+ tokens.push({ type: "comment", raw: s.slice(lt, endC), start: lt, end: endC });
538
+ pos = endC; continue;
539
+ }
540
+ if (s.startsWith("<![CDATA[", lt)) {
541
+ var endX = s.indexOf("]]>", lt + 9);
542
+ if (endX === -1) endX = len;
543
+ else endX += 3;
544
+ tokens.push({ type: "cdata", raw: s.slice(lt, endX), start: lt, end: endX });
545
+ pos = endX; continue;
546
+ }
547
+ if (s.charAt(lt + 1) === "!") {
548
+ var endD = s.indexOf(">", lt);
549
+ if (endD === -1) endD = len;
550
+ else endD += 1;
551
+ tokens.push({ type: "doctype", raw: s.slice(lt, endD), start: lt, end: endD });
552
+ pos = endD; continue;
553
+ }
554
+
555
+ // End tag
556
+ if (s.charAt(lt + 1) === "/") {
557
+ var endE = s.indexOf(">", lt);
558
+ if (endE === -1) endE = len;
559
+ else endE += 1;
560
+ var endName = s.slice(lt + 2, endE - 1).trim().toLowerCase().split(/\s/)[0];
561
+ tokens.push({
562
+ type: "endTag", name: endName,
563
+ raw: s.slice(lt, endE), start: lt, end: endE,
564
+ });
565
+ pos = endE; continue;
566
+ }
567
+
568
+ // Start tag — find the matching `>`, but skip over `>` inside
569
+ // quoted attribute values.
570
+ var p = lt + 1;
571
+ var inQuote = "";
572
+ while (p < len) {
573
+ var ch = s.charAt(p);
574
+ if (inQuote) {
575
+ if (ch === inQuote) inQuote = "";
576
+ } else {
577
+ if (ch === '"' || ch === "'") inQuote = ch;
578
+ else if (ch === ">") break;
579
+ }
580
+ p += 1;
581
+ }
582
+ var endT = p < len ? p + 1 : len;
583
+ var raw = s.slice(lt, endT);
584
+ var inner = raw.slice(1, raw.charAt(raw.length - 1) === ">" ? raw.length - 1 : raw.length);
585
+ if (inner.endsWith("/")) inner = inner.slice(0, inner.length - 1);
586
+
587
+ var nameMatch = inner.match(/^([A-Za-z][A-Za-z0-9:-]*)/);
588
+ var tagName = nameMatch ? nameMatch[1].toLowerCase() : "";
589
+ var attrSrc = nameMatch ? inner.slice(nameMatch[0].length) : "";
590
+
591
+ var attrs = _parseAttrs(attrSrc);
592
+ tokens.push({
593
+ type: "tag", name: tagName, attrs: attrs,
594
+ raw: raw, start: lt, end: endT,
595
+ selfClosing: raw.charAt(raw.length - 2) === "/",
596
+ });
597
+ pos = endT;
598
+ }
599
+ return tokens;
600
+ }
601
+
602
+ function _parseAttrs(src) {
603
+ // Returns array of { name, value, raw } in source order. Preserves
604
+ // original casing of attribute names; consumers lowercase as needed.
605
+ var attrs = [];
606
+ var s = src.trim();
607
+ var len = s.length;
608
+ var p = 0;
609
+ while (p < len) {
610
+ while (p < len && /\s/.test(s.charAt(p))) p += 1;
611
+ if (p >= len) break;
612
+ var nameStart = p;
613
+ while (p < len && !/[\s=>/]/.test(s.charAt(p))) p += 1;
614
+ var attrName = s.slice(nameStart, p);
615
+ if (!attrName) break;
616
+ while (p < len && /\s/.test(s.charAt(p))) p += 1;
617
+ var attrValue = "";
618
+ var raw = attrName;
619
+ if (p < len && s.charAt(p) === "=") {
620
+ p += 1;
621
+ while (p < len && /\s/.test(s.charAt(p))) p += 1;
622
+ var q = s.charAt(p);
623
+ if (q === '"' || q === "'") {
624
+ var endQ = s.indexOf(q, p + 1);
625
+ if (endQ === -1) endQ = len;
626
+ attrValue = s.slice(p + 1, endQ);
627
+ raw = attrName + "=" + s.slice(p, endQ + 1);
628
+ p = endQ + 1;
629
+ } else {
630
+ var valStart = p;
631
+ while (p < len && !/[\s>]/.test(s.charAt(p))) p += 1;
632
+ attrValue = s.slice(valStart, p);
633
+ raw = attrName + "=" + attrValue;
634
+ }
635
+ }
636
+ attrs.push({ name: attrName, value: attrValue, raw: raw });
637
+ }
638
+ return attrs;
639
+ }
640
+
641
+ // ---- Detection pass ----
642
+
643
+ function _detectIssues(input, opts) {
644
+ var s = String(input || "");
645
+ // 1. Whole-input bidi / null-byte / control char threats.
646
+ var issues = codepointClass.detectCharThreats(s, opts, "html");
647
+
648
+ var tokens;
649
+ try { tokens = _tokenize(s, opts.maxBytes); }
650
+ catch (e) {
651
+ issues.push({
652
+ kind: "tokenize-failed", severity: "high", ruleId: "html.tokenize",
653
+ snippet: e && e.message,
654
+ });
655
+ return issues;
656
+ }
657
+
658
+ var allowedTags = Object.create(null);
659
+ (opts.allowedTags || []).forEach(function (t) { allowedTags[t.toLowerCase()] = true; });
660
+ var dangerousTags = Object.create(null);
661
+ DANGEROUS_TAGS.forEach(function (t) { dangerousTags[t] = true; });
662
+
663
+ var depth = 0;
664
+ for (var i = 0; i < tokens.length; i += 1) {
665
+ var tok = tokens[i];
666
+
667
+ if (tok.type === "comment") {
668
+ // IE conditional comments — `<!--[if ...]>` family.
669
+ if (/<!--\s*\[\s*if/i.test(tok.raw) && opts.allowComments !== true) {
670
+ issues.push({
671
+ kind: "ie-conditional-comment", severity: "high",
672
+ ruleId: "html.ie-conditional",
673
+ location: tok.start,
674
+ snippet: "IE conditional comment",
675
+ });
676
+ }
677
+ continue;
678
+ }
679
+
680
+ if (tok.type === "tag") {
681
+ depth += 1;
682
+ if (depth > opts.maxTagDepth) {
683
+ issues.push({
684
+ kind: "depth-cap", severity: "high", ruleId: "html.depth",
685
+ location: tok.start,
686
+ snippet: "tag nesting depth " + depth + " exceeds maxTagDepth " + opts.maxTagDepth,
687
+ });
688
+ }
689
+ if (Array.isArray(tok.attrs) && tok.attrs.length > opts.maxAttrsPerTag) {
690
+ issues.push({
691
+ kind: "attr-count-cap", severity: "high", ruleId: "html.attr-count",
692
+ location: tok.start,
693
+ snippet: "attribute count " + tok.attrs.length + " exceeds maxAttrsPerTag",
694
+ });
695
+ }
696
+ if (dangerousTags[tok.name]) {
697
+ issues.push({
698
+ kind: "dangerous-tag", severity: "critical", ruleId: "html.tag",
699
+ location: tok.start,
700
+ snippet: "dangerous tag <" + tok.name + ">",
701
+ });
702
+ } else if (Object.keys(allowedTags).length > 0 && !allowedTags[tok.name]) {
703
+ issues.push({
704
+ kind: "non-allowlisted-tag", severity: "high", ruleId: "html.tag",
705
+ location: tok.start,
706
+ snippet: "tag <" + tok.name + "> not in allowedTags",
707
+ });
708
+ }
709
+
710
+ // Per-attribute checks.
711
+ var attrs = tok.attrs || [];
712
+ for (var ai = 0; ai < attrs.length; ai += 1) {
713
+ var a = attrs[ai];
714
+ var an = a.name.toLowerCase();
715
+ if (a.value && a.value.length > opts.maxAttrValueBytes) {
716
+ issues.push({
717
+ kind: "attr-value-too-large", severity: "high",
718
+ ruleId: "html.attr-size",
719
+ location: tok.start,
720
+ snippet: "attribute " + JSON.stringify(an) + " value exceeds maxAttrValueBytes",
721
+ });
722
+ }
723
+ if (EVENT_HANDLER_RE.test(an)) { // allow:regex-no-length-cap — `an` is an attribute name from the tokenizer, length-bounded by HTML naming rules
724
+ issues.push({
725
+ kind: "event-handler", severity: "critical",
726
+ ruleId: "html.event-handler",
727
+ location: tok.start,
728
+ snippet: "event-handler attribute " + JSON.stringify(an),
729
+ });
730
+ continue;
731
+ }
732
+ if (DANGEROUS_ATTRS.indexOf(an) !== -1) {
733
+ issues.push({
734
+ kind: "dangerous-attr", severity: "critical",
735
+ ruleId: "html.attr",
736
+ location: tok.start,
737
+ snippet: "dangerous attribute " + JSON.stringify(an),
738
+ });
739
+ }
740
+ if (_isUrlAttr(an)) {
741
+ var scheme = _extractScheme(a.value);
742
+ if (scheme === "" && a.value && a.value.charAt(0) !== "#" &&
743
+ a.value.charAt(0) !== "/" && a.value.charAt(0) !== "?") {
744
+ // Relative URL — allowed.
745
+ } else if (scheme && DANGEROUS_SCHEMES.indexOf(scheme) !== -1) {
746
+ // Image-context data: special-case.
747
+ if (scheme === "data" && opts.allowImageData &&
748
+ tok.name === "img" && _isImageDataUrl(a.value)) {
749
+ // Allowed image data URL.
750
+ } else {
751
+ issues.push({
752
+ kind: "dangerous-url-scheme", severity: "critical",
753
+ ruleId: "html.url-scheme",
754
+ location: tok.start,
755
+ snippet: "dangerous URL scheme " + JSON.stringify(scheme) +
756
+ " in attribute " + JSON.stringify(an),
757
+ });
758
+ }
759
+ } else if (scheme && opts.urlSchemes &&
760
+ opts.urlSchemes.indexOf(scheme) === -1) {
761
+ if (!(scheme === "data" && opts.allowImageData &&
762
+ tok.name === "img" && _isImageDataUrl(a.value))) {
763
+ issues.push({
764
+ kind: "non-allowlisted-url-scheme", severity: "high",
765
+ ruleId: "html.url-scheme",
766
+ location: tok.start,
767
+ snippet: "URL scheme " + JSON.stringify(scheme) +
768
+ " not in profile allowlist",
769
+ });
770
+ }
771
+ }
772
+ }
773
+ if (an === "style" && opts.cssPolicy !== "allow") {
774
+ if (_isCssDangerous(a.value)) {
775
+ issues.push({
776
+ kind: "css-injection", severity: "critical",
777
+ ruleId: "html.css",
778
+ location: tok.start,
779
+ snippet: "dangerous CSS token in style attribute",
780
+ });
781
+ }
782
+ }
783
+ if ((an === "id" || an === "name") && _isClobberProne(tok.name) &&
784
+ opts.domClobberPolicy !== "allow" &&
785
+ _isClobberGlobal(a.value)) {
786
+ issues.push({
787
+ kind: "dom-clobber", severity: "critical",
788
+ ruleId: "html.dom-clobber",
789
+ location: tok.start,
790
+ snippet: "DOM-clobbering " + an + "=" + JSON.stringify(a.value) +
791
+ " on <" + tok.name + ">",
792
+ });
793
+ }
794
+ }
795
+
796
+ // mXSS hint — namespace-context-shift tags carrying nested HTML.
797
+ if ((tok.name === "svg" || tok.name === "math") &&
798
+ opts.mxssHintPolicy !== "allow") {
799
+ issues.push({
800
+ kind: "mxss-hint", severity: "high", ruleId: "html.mxss",
801
+ location: tok.start,
802
+ snippet: "<" + tok.name + "> namespace-context-shift parent (mXSS vector)",
803
+ });
804
+ }
805
+ } else if (tok.type === "endTag") {
806
+ depth = Math.max(0, depth - 1);
807
+ }
808
+ }
809
+
810
+ return issues;
811
+ }
812
+
813
+ // ---- Sanitize pass ----
814
+
815
+ function _sanitize(input, opts) {
816
+ var s = String(input || "");
817
+ if (s.length > opts.maxBytes) {
818
+ throw _err("html.too-large",
819
+ "input " + s.length + " bytes exceeds maxBytes " + opts.maxBytes);
820
+ }
821
+ codepointClass.assertNoCharThreats(s, opts, _err, "html");
822
+ s = codepointClass.applyCharStripPolicies(s, opts);
823
+
824
+ var tokens;
825
+ try { tokens = _tokenize(s, opts.maxBytes); }
826
+ catch (e) {
827
+ throw _err("html.tokenize-failed", "tokenizer failed: " + (e && e.message));
828
+ }
829
+
830
+ var allowedTags = Object.create(null);
831
+ (opts.allowedTags || []).forEach(function (t) { allowedTags[t.toLowerCase()] = true; });
832
+ var allowedAttrs = Object.create(null);
833
+ (opts.allowedAttrs || []).forEach(function (a) { allowedAttrs[a.toLowerCase()] = true; });
834
+ var dangerousTags = Object.create(null);
835
+ DANGEROUS_TAGS.forEach(function (t) { dangerousTags[t] = true; });
836
+
837
+ // Tags whose text content is itself executable in the host parser
838
+ // (script body = JS, style body = CSS). When we strip the open tag,
839
+ // also skip every token until the matching close tag so the body
840
+ // doesn't leak into output as visible text.
841
+ var BODY_DROP_TAGS = { "script": true, "style": true, "noscript": true,
842
+ "noembed": true, "noframes": true, "iframe": true,
843
+ "object": true, "embed": true, "applet": true,
844
+ "template": true, "math": true, "svg": true };
845
+
846
+ var out = [];
847
+ for (var i = 0; i < tokens.length; i += 1) {
848
+ var tok = tokens[i];
849
+ if (tok.type === "text") { out.push(tok.raw); continue; }
850
+ if (tok.type === "doctype") { continue; } // strip doctypes
851
+ if (tok.type === "cdata") { continue; } // strip cdata blocks
852
+ if (tok.type === "comment") {
853
+ if (opts.allowComments) out.push(tok.raw);
854
+ continue;
855
+ }
856
+ if (tok.type === "endTag") {
857
+ if (allowedTags[tok.name]) out.push("</" + tok.name + ">");
858
+ continue;
859
+ }
860
+ // Start tag.
861
+ if (dangerousTags[tok.name] || !allowedTags[tok.name]) {
862
+ // For tags whose body is parsed as code (script/style/etc.), skip
863
+ // forward to the matching close so the body doesn't surface as
864
+ // visible text content in sanitized output.
865
+ if (BODY_DROP_TAGS[tok.name] && !tok.selfClosing) {
866
+ var depth2 = 1;
867
+ var j = i + 1;
868
+ while (j < tokens.length && depth2 > 0) {
869
+ var t2 = tokens[j];
870
+ if (t2.type === "tag" && t2.name === tok.name && !t2.selfClosing) depth2 += 1;
871
+ else if (t2.type === "endTag" && t2.name === tok.name) depth2 -= 1;
872
+ j += 1;
873
+ }
874
+ i = j - 1;
875
+ }
876
+ continue;
877
+ }
878
+
879
+ var attrParts = [];
880
+ var attrs = tok.attrs || [];
881
+ for (var ai = 0; ai < attrs.length; ai += 1) {
882
+ var a = attrs[ai];
883
+ var an = a.name.toLowerCase();
884
+ if (EVENT_HANDLER_RE.test(an)) continue;
885
+ if (DANGEROUS_ATTRS.indexOf(an) !== -1) continue;
886
+ if (Object.keys(allowedAttrs).length > 0 && !allowedAttrs[an]) continue;
887
+ if (a.value && a.value.length > opts.maxAttrValueBytes) continue;
888
+ if (_isUrlAttr(an)) {
889
+ var scheme = _extractScheme(a.value);
890
+ if (scheme && DANGEROUS_SCHEMES.indexOf(scheme) !== -1) {
891
+ if (!(scheme === "data" && opts.allowImageData &&
892
+ tok.name === "img" && _isImageDataUrl(a.value))) {
893
+ continue;
894
+ }
895
+ } else if (scheme && opts.urlSchemes &&
896
+ opts.urlSchemes.indexOf(scheme) === -1) {
897
+ if (!(scheme === "data" && opts.allowImageData &&
898
+ tok.name === "img" && _isImageDataUrl(a.value))) {
899
+ continue;
900
+ }
901
+ }
902
+ }
903
+ if (an === "style" && _isCssDangerous(a.value)) continue;
904
+ if ((an === "id" || an === "name") && _isClobberProne(tok.name) &&
905
+ _isClobberGlobal(a.value)) continue;
906
+ attrParts.push(an + "=\"" + escapeAttr(a.value) + "\"");
907
+ }
908
+ var open = "<" + tok.name + (attrParts.length ? " " + attrParts.join(" ") : "") +
909
+ (tok.selfClosing ? " />" : ">");
910
+ out.push(open);
911
+ }
912
+ return out.join("");
913
+ }
914
+
915
+ // ---- Public surface ----
916
+
917
+ /**
918
+ * @primitive b.guardHtml.validate
919
+ * @signature b.guardHtml.validate(input, opts?)
920
+ * @since 0.7.6
921
+ * @related b.guardHtml.sanitize, b.guardHtml.gate
922
+ *
923
+ * Tokenize `input` (string or Buffer of HTML) and walk every
924
+ * element / attribute against the resolved profile. Returns
925
+ * `{ ok, issues }` where `issues` is an array of
926
+ * `{ kind, severity, ruleId, location, snippet }` records.
927
+ * Never modifies the input — call `sanitize` for that. Anti-DoS
928
+ * caps (`maxBytes` / `maxAttrValueBytes` / `maxTagDepth` /
929
+ * `maxAttrsPerTag`) are validated as positive finite integers;
930
+ * passing `Infinity` throws.
931
+ *
932
+ * @opts
933
+ * profile: string, // "strict" | "balanced" | "permissive"
934
+ * compliancePosture: string, // "hipaa" | "pci-dss" | "gdpr" | "soc2"
935
+ * allowedTags: Array<string>,
936
+ * allowedAttrs: Array<string>,
937
+ * urlSchemes: Array<string>,
938
+ * allowImageData: boolean,
939
+ * allowComments: boolean,
940
+ * bidiPolicy: string, // "reject" | "strip" | "audit"
941
+ * controlPolicy: string,
942
+ * nullBytePolicy: string,
943
+ * zeroWidthPolicy: string,
944
+ * cssPolicy: string,
945
+ * domClobberPolicy: string,
946
+ * mxssHintPolicy: string,
947
+ * maxBytes: number,
948
+ * maxAttrValueBytes: number,
949
+ * maxTagDepth: number,
950
+ * maxAttrsPerTag: number,
951
+ *
952
+ * @example
953
+ * var rv = b.guardHtml.validate("<p>hi</p><script>alert(1)</script>",
954
+ * { profile: "strict" });
955
+ * rv.ok; // → false
956
+ * rv.issues[0].kind; // → "dangerous-tag"
957
+ * rv.issues[0].severity; // → "critical"
958
+ *
959
+ * var clean = b.guardHtml.validate("<p>just text</p>",
960
+ * { profile: "strict" });
961
+ * clean.ok; // → true
962
+ * clean.issues.length; // → 0
963
+ */
964
+ function validate(input, opts) {
965
+ opts = _resolveOpts(opts);
966
+ numericBounds.requireAllPositiveFiniteIntIfPresent(opts,
967
+ ["maxBytes", "maxAttrValueBytes", "maxTagDepth", "maxAttrsPerTag"],
968
+ "guardHtml.validate", GuardHtmlError, "html.bad-opt");
969
+
970
+ return gateContract.runIssueValidator(input, opts, _detectIssues);
971
+ }
972
+
973
+ /**
974
+ * @primitive b.guardHtml.sanitize
975
+ * @signature b.guardHtml.sanitize(input, opts?)
976
+ * @since 0.7.6
977
+ * @related b.guardHtml.validate, b.guardHtml.gate
978
+ *
979
+ * Token-level rewriter that drops every tag NOT in the resolved
980
+ * profile's `allowedTags`, every attribute NOT in `allowedAttrs`,
981
+ * every URL whose scheme falls outside the profile allowlist,
982
+ * every event-handler / form-override / clobbering attribute, and
983
+ * every body of a body-drop tag (script / style / template / svg
984
+ * / math / iframe / object / embed / applet). For HOSTILE
985
+ * sources, prefer `validate` + `refuse` — `sanitize` is best
986
+ * effort against the documented arms-race.
987
+ *
988
+ * @opts
989
+ * profile: string, // "strict" | "balanced" | "permissive"
990
+ * compliancePosture: string, // "hipaa" | "pci-dss" | "gdpr" | "soc2"
991
+ * allowedTags: Array<string>,
992
+ * allowedAttrs: Array<string>,
993
+ * urlSchemes: Array<string>,
994
+ * allowImageData: boolean,
995
+ * allowComments: boolean,
996
+ * maxBytes: number,
997
+ * maxAttrValueBytes: number,
998
+ * maxTagDepth: number,
999
+ * maxAttrsPerTag: number,
1000
+ *
1001
+ * @example
1002
+ * var clean = b.guardHtml.sanitize(
1003
+ * "<p>hi</p><script>alert(1)</script>",
1004
+ * { profile: "balanced" });
1005
+ * // → "<p>hi</p>"
1006
+ *
1007
+ * // Event-handler attribute is stripped, text content preserved.
1008
+ * var stripped = b.guardHtml.sanitize(
1009
+ * '<a href="https://example.com" onclick="alert(1)">go</a>',
1010
+ * { profile: "balanced" });
1011
+ * // → '<a href="https://example.com">go</a>'
1012
+ */
1013
+ function sanitize(input, opts) {
1014
+ opts = _resolveOpts(opts);
1015
+ var text = typeof input === "string"
1016
+ ? input
1017
+ : (Buffer.isBuffer(input) ? input.toString("utf8") : null);
1018
+ if (text == null) {
1019
+ throw _err("html.bad-input", "sanitize requires string or Buffer input");
1020
+ }
1021
+ return _sanitize(text, opts);
1022
+ }
1023
+
1024
+ /**
1025
+ * @primitive b.guardHtml.gate
1026
+ * @signature b.guardHtml.gate(opts?)
1027
+ * @since 0.7.6
1028
+ * @related b.guardHtml.validate, b.guardHtml.sanitize, b.guardAll
1029
+ *
1030
+ * Returns a guard descriptor that plugs into the framework's
1031
+ * content-safety wiring (`b.fileUpload.contentSafety` /
1032
+ * `b.staticServe.contentSafety` / `b.guardAll`). The descriptor's
1033
+ * `inspect(ctx)` resolves to one of four actions: `serve` (no
1034
+ * issues), `audit-only` (low-severity issues observed), `sanitize`
1035
+ * (sanitized buffer attached when no policy is "reject"), or
1036
+ * `refuse` (critical issue with at least one reject-policy active).
1037
+ *
1038
+ * @opts
1039
+ * name: string,
1040
+ * profile: string, // "strict" | "balanced" | "permissive"
1041
+ * compliancePosture: string, // "hipaa" | "pci-dss" | "gdpr" | "soc2"
1042
+ * mode: string, // "enforce" | "observe"
1043
+ * allowedTags: Array<string>,
1044
+ * allowedAttrs: Array<string>,
1045
+ * urlSchemes: Array<string>,
1046
+ * bidiPolicy: string,
1047
+ * controlPolicy: string,
1048
+ * cssPolicy: string,
1049
+ * domClobberPolicy: string,
1050
+ * mxssHintPolicy: string,
1051
+ * maxBytes: number,
1052
+ * maxRuntimeMs: number,
1053
+ *
1054
+ * @example
1055
+ * var g = b.guardHtml.gate({ profile: "strict" });
1056
+ * g.name; // → "guardHtml:strict"
1057
+ *
1058
+ * // Refuse on tag-budget exceeded — strict profile rejects <script>.
1059
+ * var hostileBuf = Buffer.from("<p>hi</p><script>alert(1)</script>", "utf8");
1060
+ * var rv = await g.inspect({ bytes: hostileBuf, contentType: "text/html" });
1061
+ * rv.ok; // → false
1062
+ * rv.action; // → "refuse"
1063
+ */
1064
+ function gate(opts) {
1065
+ opts = _resolveOpts(opts);
1066
+ return gateContract.buildGuardGate(
1067
+ opts.name || "guardHtml:" + (opts.profile || "default"),
1068
+ opts,
1069
+ async function (ctx) {
1070
+ var text = gateContract.extractBytesAsText(ctx);
1071
+ if (!text) return { ok: true, action: "serve" };
1072
+ var rv = validate(text, opts);
1073
+ if (rv.issues.length === 0) return { ok: true, action: "serve" };
1074
+ var hasCritical = rv.issues.some(function (i) {
1075
+ return i.severity === "critical" || i.severity === "high";
1076
+ });
1077
+ if (!hasCritical) return { ok: true, action: "audit-only", issues: rv.issues };
1078
+
1079
+ // Sanitize attempt — only when no policy says reject.
1080
+ if (opts.bidiPolicy !== "reject" &&
1081
+ opts.controlPolicy !== "reject" &&
1082
+ opts.nullBytePolicy !== "reject" &&
1083
+ opts.cssPolicy !== "reject" &&
1084
+ opts.domClobberPolicy !== "reject" &&
1085
+ opts.mxssHintPolicy !== "reject") {
1086
+ try {
1087
+ var clean = sanitize(text, opts);
1088
+ return {
1089
+ ok: true, action: "sanitize",
1090
+ sanitized: Buffer.from(clean, "utf8"),
1091
+ issues: rv.issues,
1092
+ };
1093
+ } catch (_e) { /* fall through */ }
1094
+ }
1095
+ return { ok: false, action: "refuse", issues: rv.issues };
1096
+ });
1097
+ }
1098
+
1099
+ /**
1100
+ * @primitive b.guardHtml.buildProfile
1101
+ * @signature b.guardHtml.buildProfile(opts)
1102
+ * @since 0.7.6
1103
+ * @related b.guardHtml.compliancePosture, b.guardHtml.gate
1104
+ *
1105
+ * Resolve a named profile against `PROFILES` and return the merged
1106
+ * options bag. Operators introspecting the active limits (without
1107
+ * calling `validate` / `sanitize` / `gate`) call this. Throws
1108
+ * `GuardHtmlError` with code `html.bad-profile` when the name
1109
+ * doesn't appear in the profile catalog.
1110
+ *
1111
+ * @opts
1112
+ * profile: string, // "strict" | "balanced" | "permissive"
1113
+ *
1114
+ * @example
1115
+ * var resolved = b.guardHtml.buildProfile({ profile: "strict" });
1116
+ * resolved.maxBytes; // → 2097152 (2 MiB)
1117
+ * resolved.maxAttrValueBytes; // → 8192 (8 KiB)
1118
+ */
1119
+ var buildProfile = gateContract.makeProfileBuilder(PROFILES);
1120
+
1121
+ /**
1122
+ * @primitive b.guardHtml.compliancePosture
1123
+ * @signature b.guardHtml.compliancePosture(name)
1124
+ * @since 0.7.6
1125
+ * @related b.guardHtml.buildProfile, b.guardHtml.gate
1126
+ *
1127
+ * Return the option overlay for a named compliance posture
1128
+ * (`hipaa` / `pci-dss` / `gdpr` / `soc2`). Operators compose this
1129
+ * over a base profile to harden the default per regulatory regime.
1130
+ * Throws `GuardHtmlError` with code `html.bad-posture` on unknown
1131
+ * names.
1132
+ *
1133
+ * @example
1134
+ * var hipaa = b.guardHtml.compliancePosture("hipaa");
1135
+ * hipaa.bidiPolicy; // → "reject"
1136
+ * hipaa.cssPolicy; // → "reject"
1137
+ * hipaa.mxssHintPolicy; // → "reject"
1138
+ */
1139
+ function compliancePosture(name) {
1140
+ return gateContract.lookupCompliancePosture(name, COMPLIANCE_POSTURES, _err, "html");
1141
+ }
1142
+
1143
+ /**
1144
+ * @primitive b.guardHtml.loadRulePack
1145
+ * @signature b.guardHtml.loadRulePack(pack)
1146
+ * @since 0.7.6
1147
+ * @related b.guardHtml.gate, b.guardHtml.buildProfile
1148
+ *
1149
+ * Register an operator-supplied rule pack (a versioned bundle of
1150
+ * extra tag / attribute / scheme overrides) into the guard's
1151
+ * private store. Subsequent `gate` calls referencing the pack by
1152
+ * its `id` overlay these rules on top of the resolved profile.
1153
+ * Validates pack shape and throws `GuardHtmlError` on malformed
1154
+ * input.
1155
+ *
1156
+ * @example
1157
+ * b.guardHtml.loadRulePack({
1158
+ * id: "kb-2026-html",
1159
+ * version: "1.0.0",
1160
+ * extraDangerousTags: ["custom-element"],
1161
+ * });
1162
+ */
1163
+ var _htmlRulePacks = gateContract.makeRulePackLoader(GuardHtmlError, "html");
1164
+ var loadRulePack = _htmlRulePacks.load;
1165
+
1166
+ void safeUrl; // reserved for future scheme-allowlist composition
1167
+
1168
+ module.exports = {
1169
+ // ---- guard-* family registry exports ----
1170
+ NAME: "html",
1171
+ KIND: "content",
1172
+ MIME_TYPES: Object.freeze(["text/html", "application/xhtml+xml"]),
1173
+ EXTENSIONS: Object.freeze([".html", ".htm", ".xhtml"]),
1174
+ INTEGRATION_FIXTURES: Object.freeze({
1175
+ kind: "content",
1176
+ contentType: "text/html",
1177
+ extension: ".html",
1178
+ benignBytes: Buffer.from("<p>hello world</p>", "utf8"),
1179
+ // Hostile: <script> tag is in the dangerous-tag denylist; refused
1180
+ // unconditionally regardless of profile.
1181
+ hostileBytes: Buffer.from('<p>hi</p><script>alert(1)</script>', "utf8"),
1182
+ }),
1183
+ // ---- primitive surface ----
1184
+ validate: validate,
1185
+ sanitize: sanitize,
1186
+ escapeText: escapeText,
1187
+ escapeAttr: escapeAttr,
1188
+ gate: gate,
1189
+ buildProfile: buildProfile,
1190
+ compliancePosture: compliancePosture,
1191
+ loadRulePack: loadRulePack,
1192
+ PROFILES: PROFILES,
1193
+ DEFAULTS: DEFAULTS,
1194
+ COMPLIANCE_POSTURES: COMPLIANCE_POSTURES,
1195
+ DANGEROUS_TAGS: DANGEROUS_TAGS,
1196
+ STRICT_ALLOWED_TAGS: STRICT_ALLOWED_TAGS,
1197
+ BALANCED_ALLOWED_TAGS: BALANCED_ALLOWED_TAGS,
1198
+ PERMISSIVE_ALLOWED_TAGS: PERMISSIVE_ALLOWED_TAGS,
1199
+ DANGEROUS_ATTRS: DANGEROUS_ATTRS,
1200
+ URL_ATTRS: URL_ATTRS,
1201
+ SAFE_SCHEMES: SAFE_SCHEMES,
1202
+ DANGEROUS_SCHEMES: DANGEROUS_SCHEMES,
1203
+ CLOBBER_GLOBALS: CLOBBER_GLOBALS,
1204
+ CLOBBER_PRONE_TAGS: CLOBBER_PRONE_TAGS,
1205
+ // WCAG 2.2 audit-only mode (b.guardHtml.wcag.audit) — accessibility
1206
+ // scanner that emits violations without modifying HTML.
1207
+ wcag: guardHtmlWcag,
1208
+ GuardHtmlError: GuardHtmlError,
1209
+ };