@lindorm/aegis 0.8.1 → 0.10.0

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 (348) hide show
  1. package/README.md +84 -5
  2. package/dist/classes/Aegis.d.ts +20 -5
  3. package/dist/classes/Aegis.d.ts.map +1 -1
  4. package/dist/classes/Aegis.js +259 -45
  5. package/dist/classes/Aegis.js.map +1 -1
  6. package/dist/classes/CoseKit.d.ts +31 -0
  7. package/dist/classes/CoseKit.d.ts.map +1 -0
  8. package/dist/classes/CoseKit.js +64 -0
  9. package/dist/classes/CoseKit.js.map +1 -0
  10. package/dist/classes/CweKit.d.ts +24 -0
  11. package/dist/classes/CweKit.d.ts.map +1 -0
  12. package/dist/classes/CweKit.js +73 -0
  13. package/dist/classes/CweKit.js.map +1 -0
  14. package/dist/classes/CwmKit.d.ts +22 -0
  15. package/dist/classes/CwmKit.d.ts.map +1 -0
  16. package/dist/classes/CwmKit.js +54 -0
  17. package/dist/classes/CwmKit.js.map +1 -0
  18. package/dist/classes/CwsKit.d.ts +24 -0
  19. package/dist/classes/CwsKit.d.ts.map +1 -0
  20. package/dist/classes/CwsKit.js +60 -0
  21. package/dist/classes/CwsKit.js.map +1 -0
  22. package/dist/classes/CwtKit.d.ts +31 -0
  23. package/dist/classes/CwtKit.d.ts.map +1 -0
  24. package/dist/classes/CwtKit.js +65 -0
  25. package/dist/classes/CwtKit.js.map +1 -0
  26. package/dist/classes/JoseKit.d.ts +32 -0
  27. package/dist/classes/JoseKit.d.ts.map +1 -0
  28. package/dist/classes/JoseKit.js +66 -0
  29. package/dist/classes/JoseKit.js.map +1 -0
  30. package/dist/classes/JweKit.d.ts.map +1 -1
  31. package/dist/classes/JweKit.js +31 -3
  32. package/dist/classes/JweKit.js.map +1 -1
  33. package/dist/classes/JwsKit.d.ts.map +1 -1
  34. package/dist/classes/JwsKit.js +19 -3
  35. package/dist/classes/JwsKit.js.map +1 -1
  36. package/dist/classes/JwtKit.d.ts +4 -1
  37. package/dist/classes/JwtKit.d.ts.map +1 -1
  38. package/dist/classes/JwtKit.js +100 -20
  39. package/dist/classes/JwtKit.js.map +1 -1
  40. package/dist/classes/SignatureKit.d.ts.map +1 -1
  41. package/dist/classes/SignatureKit.js +5 -1
  42. package/dist/classes/SignatureKit.js.map +1 -1
  43. package/dist/constants/token-type.d.ts +1 -1
  44. package/dist/constants/token-type.d.ts.map +1 -1
  45. package/dist/constants/token-type.js +2 -0
  46. package/dist/constants/token-type.js.map +1 -1
  47. package/dist/errors/AegisError.d.ts +1 -0
  48. package/dist/errors/AegisError.d.ts.map +1 -1
  49. package/dist/errors/AegisError.js +1 -0
  50. package/dist/errors/AegisError.js.map +1 -1
  51. package/dist/errors/JweError.d.ts +1 -0
  52. package/dist/errors/JweError.d.ts.map +1 -1
  53. package/dist/errors/JweError.js +1 -0
  54. package/dist/errors/JweError.js.map +1 -1
  55. package/dist/errors/JwsError.d.ts +1 -0
  56. package/dist/errors/JwsError.d.ts.map +1 -1
  57. package/dist/errors/JwsError.js +1 -0
  58. package/dist/errors/JwsError.js.map +1 -1
  59. package/dist/errors/JwtError.d.ts +1 -0
  60. package/dist/errors/JwtError.d.ts.map +1 -1
  61. package/dist/errors/JwtError.js +1 -0
  62. package/dist/errors/JwtError.js.map +1 -1
  63. package/dist/interfaces/Aegis.d.ts +6 -1
  64. package/dist/interfaces/Aegis.d.ts.map +1 -1
  65. package/dist/internal/claims/events.d.ts +5 -0
  66. package/dist/internal/claims/events.d.ts.map +1 -0
  67. package/dist/internal/claims/events.js +3 -0
  68. package/dist/internal/claims/events.js.map +1 -0
  69. package/dist/internal/claims/registry.d.ts +13 -0
  70. package/dist/internal/claims/registry.d.ts.map +1 -0
  71. package/dist/internal/claims/registry.js +58 -0
  72. package/dist/internal/claims/registry.js.map +1 -0
  73. package/dist/internal/claims/sub-id.d.ts +7 -0
  74. package/dist/internal/claims/sub-id.d.ts.map +1 -0
  75. package/dist/internal/claims/sub-id.js +11 -0
  76. package/dist/internal/claims/sub-id.js.map +1 -0
  77. package/dist/internal/cose/act-claim.d.ts +4 -0
  78. package/dist/internal/cose/act-claim.d.ts.map +1 -0
  79. package/dist/internal/cose/act-claim.js +8 -0
  80. package/dist/internal/cose/act-claim.js.map +1 -0
  81. package/dist/internal/cose/alg-labels.d.ts +4 -0
  82. package/dist/internal/cose/alg-labels.d.ts.map +1 -0
  83. package/dist/internal/cose/alg-labels.js +42 -0
  84. package/dist/internal/cose/alg-labels.js.map +1 -0
  85. package/dist/internal/cose/cbor.d.ts +11 -0
  86. package/dist/internal/cose/cbor.d.ts.map +1 -0
  87. package/dist/internal/cose/cbor.js +37 -0
  88. package/dist/internal/cose/cbor.js.map +1 -0
  89. package/dist/internal/cose/compact-map.d.ts +11 -0
  90. package/dist/internal/cose/compact-map.d.ts.map +1 -0
  91. package/dist/internal/cose/compact-map.js +43 -0
  92. package/dist/internal/cose/compact-map.js.map +1 -0
  93. package/dist/internal/cose/cose-key-thumbprint.d.ts +5 -0
  94. package/dist/internal/cose/cose-key-thumbprint.d.ts.map +1 -0
  95. package/dist/internal/cose/cose-key-thumbprint.js +60 -0
  96. package/dist/internal/cose/cose-key-thumbprint.js.map +1 -0
  97. package/dist/internal/cose/cose-key.d.ts +8 -0
  98. package/dist/internal/cose/cose-key.d.ts.map +1 -0
  99. package/dist/internal/cose/cose-key.js +98 -0
  100. package/dist/internal/cose/cose-key.js.map +1 -0
  101. package/dist/internal/cose/cose-typ.d.ts +2 -0
  102. package/dist/internal/cose/cose-typ.d.ts.map +1 -0
  103. package/dist/internal/cose/cose-typ.js +8 -0
  104. package/dist/internal/cose/cose-typ.js.map +1 -0
  105. package/dist/internal/cose/cwt-claims.d.ts +7 -0
  106. package/dist/internal/cose/cwt-claims.d.ts.map +1 -0
  107. package/dist/internal/cose/cwt-claims.js +94 -0
  108. package/dist/internal/cose/cwt-claims.js.map +1 -0
  109. package/dist/internal/cose/enc-labels.d.ts +5 -0
  110. package/dist/internal/cose/enc-labels.d.ts.map +1 -0
  111. package/dist/internal/cose/enc-labels.js +47 -0
  112. package/dist/internal/cose/enc-labels.js.map +1 -0
  113. package/dist/internal/cose/structures.d.ts +20 -0
  114. package/dist/internal/cose/structures.d.ts.map +1 -0
  115. package/dist/internal/cose/structures.js +22 -0
  116. package/dist/internal/cose/structures.js.map +1 -0
  117. package/dist/internal/cose/sub-id-claim.d.ts +4 -0
  118. package/dist/internal/cose/sub-id-claim.d.ts.map +1 -0
  119. package/dist/internal/cose/sub-id-claim.js +18 -0
  120. package/dist/internal/cose/sub-id-claim.js.map +1 -0
  121. package/dist/internal/profiles/definitions/access-token.d.ts +3 -0
  122. package/dist/internal/profiles/definitions/access-token.d.ts.map +1 -0
  123. package/dist/internal/profiles/definitions/access-token.js +31 -0
  124. package/dist/internal/profiles/definitions/access-token.js.map +1 -0
  125. package/dist/internal/profiles/definitions/client-assertion.d.ts +3 -0
  126. package/dist/internal/profiles/definitions/client-assertion.d.ts.map +1 -0
  127. package/dist/internal/profiles/definitions/client-assertion.js +18 -0
  128. package/dist/internal/profiles/definitions/client-assertion.js.map +1 -0
  129. package/dist/internal/profiles/definitions/default.d.ts +3 -0
  130. package/dist/internal/profiles/definitions/default.d.ts.map +1 -0
  131. package/dist/internal/profiles/definitions/default.js +14 -0
  132. package/dist/internal/profiles/definitions/default.js.map +1 -0
  133. package/dist/internal/profiles/definitions/delegation.d.ts +3 -0
  134. package/dist/internal/profiles/definitions/delegation.d.ts.map +1 -0
  135. package/dist/internal/profiles/definitions/delegation.js +19 -0
  136. package/dist/internal/profiles/definitions/delegation.js.map +1 -0
  137. package/dist/internal/profiles/definitions/erasure-token.d.ts +3 -0
  138. package/dist/internal/profiles/definitions/erasure-token.d.ts.map +1 -0
  139. package/dist/internal/profiles/definitions/erasure-token.js +28 -0
  140. package/dist/internal/profiles/definitions/erasure-token.js.map +1 -0
  141. package/dist/internal/profiles/definitions/id-token.d.ts +3 -0
  142. package/dist/internal/profiles/definitions/id-token.d.ts.map +1 -0
  143. package/dist/internal/profiles/definitions/id-token.js +26 -0
  144. package/dist/internal/profiles/definitions/id-token.js.map +1 -0
  145. package/dist/internal/profiles/definitions/introspection.d.ts +3 -0
  146. package/dist/internal/profiles/definitions/introspection.d.ts.map +1 -0
  147. package/dist/internal/profiles/definitions/introspection.js +18 -0
  148. package/dist/internal/profiles/definitions/introspection.js.map +1 -0
  149. package/dist/internal/profiles/definitions/jarm.d.ts +3 -0
  150. package/dist/internal/profiles/definitions/jarm.d.ts.map +1 -0
  151. package/dist/internal/profiles/definitions/jarm.js +19 -0
  152. package/dist/internal/profiles/definitions/jarm.js.map +1 -0
  153. package/dist/internal/profiles/definitions/logout-token.d.ts +3 -0
  154. package/dist/internal/profiles/definitions/logout-token.d.ts.map +1 -0
  155. package/dist/internal/profiles/definitions/logout-token.js +20 -0
  156. package/dist/internal/profiles/definitions/logout-token.js.map +1 -0
  157. package/dist/internal/profiles/definitions/security-event.d.ts +3 -0
  158. package/dist/internal/profiles/definitions/security-event.d.ts.map +1 -0
  159. package/dist/internal/profiles/definitions/security-event.js +20 -0
  160. package/dist/internal/profiles/definitions/security-event.js.map +1 -0
  161. package/dist/internal/profiles/definitions/userinfo.d.ts +3 -0
  162. package/dist/internal/profiles/definitions/userinfo.d.ts.map +1 -0
  163. package/dist/internal/profiles/definitions/userinfo.js +18 -0
  164. package/dist/internal/profiles/definitions/userinfo.js.map +1 -0
  165. package/dist/internal/profiles/registry.d.ts +4 -0
  166. package/dist/internal/profiles/registry.d.ts.map +1 -0
  167. package/dist/internal/profiles/registry.js +41 -0
  168. package/dist/internal/profiles/registry.js.map +1 -0
  169. package/dist/internal/utils/assemble-common-claims.d.ts +12 -0
  170. package/dist/internal/utils/assemble-common-claims.d.ts.map +1 -0
  171. package/dist/internal/utils/assemble-common-claims.js +66 -0
  172. package/dist/internal/utils/assemble-common-claims.js.map +1 -0
  173. package/dist/internal/utils/build-profile-claims.d.ts +14 -0
  174. package/dist/internal/utils/build-profile-claims.d.ts.map +1 -0
  175. package/dist/internal/utils/build-profile-claims.js +75 -0
  176. package/dist/internal/utils/build-profile-claims.js.map +1 -0
  177. package/dist/internal/utils/compute-jwk-thumbprint.js +8 -1
  178. package/dist/internal/utils/compute-jwk-thumbprint.js.map +1 -1
  179. package/dist/internal/utils/compute-typ-header.d.ts.map +1 -1
  180. package/dist/internal/utils/compute-typ-header.js +20 -5
  181. package/dist/internal/utils/compute-typ-header.js.map +1 -1
  182. package/dist/internal/utils/create-hash.d.ts.map +1 -1
  183. package/dist/internal/utils/create-hash.js +7 -7
  184. package/dist/internal/utils/create-hash.js.map +1 -1
  185. package/dist/internal/utils/enforce-verify-floor.d.ts +12 -0
  186. package/dist/internal/utils/enforce-verify-floor.d.ts.map +1 -0
  187. package/dist/internal/utils/enforce-verify-floor.js +43 -0
  188. package/dist/internal/utils/enforce-verify-floor.js.map +1 -0
  189. package/dist/internal/utils/extract-claims.d.ts +2 -1
  190. package/dist/internal/utils/extract-claims.d.ts.map +1 -1
  191. package/dist/internal/utils/extract-claims.js +25 -4
  192. package/dist/internal/utils/extract-claims.js.map +1 -1
  193. package/dist/internal/utils/jose-header.d.ts.map +1 -1
  194. package/dist/internal/utils/jose-header.js +38 -7
  195. package/dist/internal/utils/jose-header.js.map +1 -1
  196. package/dist/internal/utils/jwt-payload.d.ts +8 -6
  197. package/dist/internal/utils/jwt-payload.d.ts.map +1 -1
  198. package/dist/internal/utils/jwt-payload.js +32 -96
  199. package/dist/internal/utils/jwt-payload.js.map +1 -1
  200. package/dist/internal/utils/jwt-validate.d.ts.map +1 -1
  201. package/dist/internal/utils/jwt-validate.js +7 -1
  202. package/dist/internal/utils/jwt-validate.js.map +1 -1
  203. package/dist/internal/utils/jwt-verify.d.ts.map +1 -1
  204. package/dist/internal/utils/jwt-verify.js +17 -4
  205. package/dist/internal/utils/jwt-verify.js.map +1 -1
  206. package/dist/internal/utils/map-content-to-claims.d.ts +8 -0
  207. package/dist/internal/utils/map-content-to-claims.d.ts.map +1 -0
  208. package/dist/internal/utils/map-content-to-claims.js +98 -0
  209. package/dist/internal/utils/map-content-to-claims.js.map +1 -0
  210. package/dist/internal/utils/parse-introspection.d.ts.map +1 -1
  211. package/dist/internal/utils/parse-introspection.js +5 -1
  212. package/dist/internal/utils/parse-introspection.js.map +1 -1
  213. package/dist/internal/utils/parse-userinfo.d.ts.map +1 -1
  214. package/dist/internal/utils/parse-userinfo.js +5 -1
  215. package/dist/internal/utils/parse-userinfo.js.map +1 -1
  216. package/dist/internal/utils/resolve-cert-binding.d.ts.map +1 -1
  217. package/dist/internal/utils/resolve-cert-binding.js +3 -0
  218. package/dist/internal/utils/resolve-cert-binding.js.map +1 -1
  219. package/dist/internal/utils/rules/act-chain-shape.d.ts +4 -0
  220. package/dist/internal/utils/rules/act-chain-shape.d.ts.map +1 -0
  221. package/dist/internal/utils/rules/act-chain-shape.js +52 -0
  222. package/dist/internal/utils/rules/act-chain-shape.js.map +1 -0
  223. package/dist/internal/utils/rules/alg-permitted.d.ts +6 -0
  224. package/dist/internal/utils/rules/alg-permitted.d.ts.map +1 -0
  225. package/dist/internal/utils/rules/alg-permitted.js +35 -0
  226. package/dist/internal/utils/rules/alg-permitted.js.map +1 -0
  227. package/dist/internal/utils/rules/at-least-one-of.d.ts +4 -0
  228. package/dist/internal/utils/rules/at-least-one-of.d.ts.map +1 -0
  229. package/dist/internal/utils/rules/at-least-one-of.js +13 -0
  230. package/dist/internal/utils/rules/at-least-one-of.js.map +1 -0
  231. package/dist/internal/utils/rules/aud-single-resource.d.ts +4 -0
  232. package/dist/internal/utils/rules/aud-single-resource.d.ts.map +1 -0
  233. package/dist/internal/utils/rules/aud-single-resource.js +18 -0
  234. package/dist/internal/utils/rules/aud-single-resource.js.map +1 -0
  235. package/dist/internal/utils/rules/cnf-shape.d.ts +4 -0
  236. package/dist/internal/utils/rules/cnf-shape.d.ts.map +1 -0
  237. package/dist/internal/utils/rules/cnf-shape.js +55 -0
  238. package/dist/internal/utils/rules/cnf-shape.js.map +1 -0
  239. package/dist/internal/utils/rules/cross-field.d.ts +4 -0
  240. package/dist/internal/utils/rules/cross-field.d.ts.map +1 -0
  241. package/dist/internal/utils/rules/cross-field.js +21 -0
  242. package/dist/internal/utils/rules/cross-field.js.map +1 -0
  243. package/dist/internal/utils/rules/events-shape.d.ts +4 -0
  244. package/dist/internal/utils/rules/events-shape.d.ts.map +1 -0
  245. package/dist/internal/utils/rules/events-shape.js +33 -0
  246. package/dist/internal/utils/rules/events-shape.js.map +1 -0
  247. package/dist/internal/utils/rules/every-element-has-key.d.ts +4 -0
  248. package/dist/internal/utils/rules/every-element-has-key.d.ts.map +1 -0
  249. package/dist/internal/utils/rules/every-element-has-key.js +20 -0
  250. package/dist/internal/utils/rules/every-element-has-key.js.map +1 -0
  251. package/dist/internal/utils/rules/forbid-present.d.ts +4 -0
  252. package/dist/internal/utils/rules/forbid-present.d.ts.map +1 -0
  253. package/dist/internal/utils/rules/forbid-present.js +10 -0
  254. package/dist/internal/utils/rules/forbid-present.js.map +1 -0
  255. package/dist/internal/utils/rules/index.d.ts +14 -0
  256. package/dist/internal/utils/rules/index.d.ts.map +1 -0
  257. package/dist/internal/utils/rules/index.js +14 -0
  258. package/dist/internal/utils/rules/index.js.map +1 -0
  259. package/dist/internal/utils/rules/iss-uri.d.ts +4 -0
  260. package/dist/internal/utils/rules/iss-uri.d.ts.map +1 -0
  261. package/dist/internal/utils/rules/iss-uri.js +11 -0
  262. package/dist/internal/utils/rules/iss-uri.js.map +1 -0
  263. package/dist/internal/utils/rules/require-present.d.ts +4 -0
  264. package/dist/internal/utils/rules/require-present.d.ts.map +1 -0
  265. package/dist/internal/utils/rules/require-present.js +10 -0
  266. package/dist/internal/utils/rules/require-present.js.map +1 -0
  267. package/dist/internal/utils/rules/required-when.d.ts +8 -0
  268. package/dist/internal/utils/rules/required-when.d.ts.map +1 -0
  269. package/dist/internal/utils/rules/required-when.js +13 -0
  270. package/dist/internal/utils/rules/required-when.js.map +1 -0
  271. package/dist/internal/utils/rules/sub-id-shape.d.ts +4 -0
  272. package/dist/internal/utils/rules/sub-id-shape.d.ts.map +1 -0
  273. package/dist/internal/utils/rules/sub-id-shape.js +26 -0
  274. package/dist/internal/utils/rules/sub-id-shape.js.map +1 -0
  275. package/dist/internal/utils/select-encoder.d.ts +6 -0
  276. package/dist/internal/utils/select-encoder.d.ts.map +1 -0
  277. package/dist/internal/utils/select-encoder.js +4 -0
  278. package/dist/internal/utils/select-encoder.js.map +1 -0
  279. package/dist/internal/utils/validate-actor.d.ts +8 -1
  280. package/dist/internal/utils/validate-actor.d.ts.map +1 -1
  281. package/dist/internal/utils/validate-actor.js +9 -7
  282. package/dist/internal/utils/validate-actor.js.map +1 -1
  283. package/dist/internal/utils/validate-profile-claims.d.ts +8 -0
  284. package/dist/internal/utils/validate-profile-claims.d.ts.map +1 -0
  285. package/dist/internal/utils/validate-profile-claims.js +45 -0
  286. package/dist/internal/utils/validate-profile-claims.js.map +1 -0
  287. package/dist/internal/utils/validate.d.ts.map +1 -1
  288. package/dist/internal/utils/validate.js +8 -1
  289. package/dist/internal/utils/validate.js.map +1 -1
  290. package/dist/internal/utils/verify-cert-binding.d.ts.map +1 -1
  291. package/dist/internal/utils/verify-cert-binding.js +9 -1
  292. package/dist/internal/utils/verify-cert-binding.js.map +1 -1
  293. package/dist/internal/utils/verify-dpop-proof.d.ts.map +1 -1
  294. package/dist/internal/utils/verify-dpop-proof.js +41 -7
  295. package/dist/internal/utils/verify-dpop-proof.js.map +1 -1
  296. package/dist/types/claims/aegis-introspection.d.ts +2 -1
  297. package/dist/types/claims/aegis-introspection.d.ts.map +1 -1
  298. package/dist/types/claims/index.d.ts +2 -0
  299. package/dist/types/claims/index.d.ts.map +1 -1
  300. package/dist/types/claims/index.js +2 -0
  301. package/dist/types/claims/index.js.map +1 -1
  302. package/dist/types/claims/jwt/index.d.ts +2 -0
  303. package/dist/types/claims/jwt/index.d.ts.map +1 -1
  304. package/dist/types/claims/jwt/index.js +2 -0
  305. package/dist/types/claims/jwt/index.js.map +1 -1
  306. package/dist/types/claims/jwt/jwt-claims.d.ts +3 -1
  307. package/dist/types/claims/jwt/jwt-claims.d.ts.map +1 -1
  308. package/dist/types/claims/jwt/lindorm-claims-wire.d.ts +4 -2
  309. package/dist/types/claims/jwt/lindorm-claims-wire.d.ts.map +1 -1
  310. package/dist/types/claims/jwt/oidc-claims-wire.d.ts +2 -0
  311. package/dist/types/claims/jwt/oidc-claims-wire.d.ts.map +1 -1
  312. package/dist/types/claims/jwt/rar-claims-wire.d.ts +5 -0
  313. package/dist/types/claims/jwt/rar-claims-wire.d.ts.map +1 -0
  314. package/dist/types/claims/jwt/rar-claims-wire.js +2 -0
  315. package/dist/types/claims/jwt/rar-claims-wire.js.map +1 -0
  316. package/dist/types/claims/jwt/set-claims-wire.d.ts +9 -0
  317. package/dist/types/claims/jwt/set-claims-wire.d.ts.map +1 -0
  318. package/dist/types/claims/jwt/set-claims-wire.js +2 -0
  319. package/dist/types/claims/jwt/set-claims-wire.js.map +1 -0
  320. package/dist/types/claims/lindorm-claims.d.ts +4 -2
  321. package/dist/types/claims/lindorm-claims.d.ts.map +1 -1
  322. package/dist/types/claims/oidc-claims.d.ts +2 -0
  323. package/dist/types/claims/oidc-claims.d.ts.map +1 -1
  324. package/dist/types/claims/rar-claims.d.ts +5 -0
  325. package/dist/types/claims/rar-claims.d.ts.map +1 -0
  326. package/dist/types/claims/rar-claims.js +2 -0
  327. package/dist/types/claims/rar-claims.js.map +1 -0
  328. package/dist/types/claims/set-claims.d.ts +8 -0
  329. package/dist/types/claims/set-claims.d.ts.map +1 -0
  330. package/dist/types/claims/set-claims.js +2 -0
  331. package/dist/types/claims/set-claims.js.map +1 -0
  332. package/dist/types/jwt/index.d.ts +1 -0
  333. package/dist/types/jwt/index.d.ts.map +1 -1
  334. package/dist/types/jwt/index.js +1 -0
  335. package/dist/types/jwt/index.js.map +1 -1
  336. package/dist/types/jwt/jwt-claim-matchers.d.ts +2 -1
  337. package/dist/types/jwt/jwt-claim-matchers.d.ts.map +1 -1
  338. package/dist/types/jwt/jwt-parse.d.ts +2 -2
  339. package/dist/types/jwt/jwt-parse.d.ts.map +1 -1
  340. package/dist/types/jwt/jwt-sign.d.ts +8 -6
  341. package/dist/types/jwt/jwt-sign.d.ts.map +1 -1
  342. package/dist/types/jwt/profile.d.ts +99 -0
  343. package/dist/types/jwt/profile.d.ts.map +1 -0
  344. package/dist/types/jwt/profile.js +2 -0
  345. package/dist/types/jwt/profile.js.map +1 -0
  346. package/dist/types/level-of-assurance.d.ts +4 -2
  347. package/dist/types/level-of-assurance.d.ts.map +1 -1
  348. package/package.json +19 -18
@@ -1 +1 @@
1
- {"version":3,"file":"jwt-verify.js","sourceRoot":"","sources":["../../../src/internal/utils/jwt-verify.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"jwt-verify.js","sourceRoot":"","sources":["../../../src/internal/utils/jwt-verify.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import type { KryptosAlgorithm } from "@lindorm/kryptos";
2
+ import type { Dict } from "@lindorm/types";
3
+ import type { JwtClaims, SignJwtContent, SignJwtOptions } from "../../types/index.js";
4
+ export type MapContentContext = {
5
+ algorithm: KryptosAlgorithm;
6
+ };
7
+ export declare const mapContentToClaims: <C extends Dict = Dict>(ctx: MapContentContext, content: SignJwtContent<C>, options?: SignJwtOptions) => JwtClaims;
8
+ //# sourceMappingURL=map-content-to-claims.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"map-content-to-claims.d.ts","sourceRoot":"","sources":["../../../src/internal/utils/map-content-to-claims.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACzD,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAI3C,OAAO,KAAK,EAGV,SAAS,EACT,cAAc,EACd,cAAc,EACf,MAAM,sBAAsB,CAAC;AAS9B,MAAM,MAAM,iBAAiB,GAAG;IAC9B,SAAS,EAAE,gBAAgB,CAAC;CAC7B,CAAC;AAwBF,eAAO,MAAM,kBAAkB,GAAI,CAAC,SAAS,IAAI,GAAG,IAAI,EACtD,KAAK,iBAAiB,EACtB,SAAS,cAAc,CAAC,CAAC,CAAC,EAC1B,UAAS,cAAmB,KAC3B,SAyFF,CAAC"}
@@ -0,0 +1,98 @@
1
+ import { expires } from "@lindorm/date";
2
+ import { isArray, isDate, isFinite, isObject, isString } from "@lindorm/is";
3
+ import { getUnixTime } from "@lindorm/date";
4
+ import { removeUndefined } from "@lindorm/utils";
5
+ import { JwtError } from "../../errors/index.js";
6
+ import { createAccessTokenHash, createCodeHash, createStateHash } from "./create-hash.js";
7
+ const actClaimToWire = (claim) => removeUndefined({
8
+ sub: claim.subject,
9
+ iss: claim.issuer,
10
+ aud: claim.audience,
11
+ client_id: claim.clientId,
12
+ act: isObject(claim.act) ? actClaimToWire(claim.act) : undefined,
13
+ });
14
+ export const mapContentToClaims = (ctx, content, options = {}) => {
15
+ if (!isString(ctx.algorithm)) {
16
+ throw new JwtError("Algorithm is required", {
17
+ code: "jwt_algorithm_required",
18
+ title: "JWT Algorithm Required",
19
+ details: "No signing algorithm was supplied, so claim hashes cannot be computed.",
20
+ });
21
+ }
22
+ const exp = content.expires ? expires(content.expires).expiresOn : undefined;
23
+ const at_hash = isString(options.accessTokenHash)
24
+ ? options.accessTokenHash
25
+ : isString(content.accessToken)
26
+ ? createAccessTokenHash(ctx.algorithm, content.accessToken)
27
+ : undefined;
28
+ const c_hash = isString(options.codeHash)
29
+ ? options.codeHash
30
+ : isString(content.authCode)
31
+ ? createCodeHash(ctx.algorithm, content.authCode)
32
+ : undefined;
33
+ const s_hash = isString(options.stateHash)
34
+ ? options.stateHash
35
+ : isString(content.authState)
36
+ ? createStateHash(ctx.algorithm, content.authState)
37
+ : undefined;
38
+ const cnf = isObject(content.confirmation)
39
+ ? removeUndefined({
40
+ jkt: content.confirmation.thumbprint,
41
+ "x5t#S256": content.confirmation.mtlsCertThumbprint,
42
+ jwk: content.confirmation.key,
43
+ kid: content.confirmation.keyId,
44
+ jku: content.confirmation.jwkSetUri,
45
+ })
46
+ : undefined;
47
+ return removeUndefined({
48
+ aal: isFinite(content.authenticatorAssuranceLevel)
49
+ ? content.authenticatorAssuranceLevel
50
+ : undefined,
51
+ acr: isString(content.authContextClass) ? content.authContextClass : undefined,
52
+ act: isObject(content.act) ? actClaimToWire(content.act) : undefined,
53
+ afr: isArray(content.authFactor) ? content.authFactor : undefined,
54
+ amr: isArray(content.authMethods) ? content.authMethods : undefined,
55
+ at_hash,
56
+ aud: isArray(content.audience) ? content.audience : undefined,
57
+ authorization_details: isArray(content.authorizationDetails)
58
+ ? content.authorizationDetails
59
+ : undefined,
60
+ auth_time: isDate(content.authTime) ? getUnixTime(content.authTime) : undefined,
61
+ azp: isString(content.authorizedParty) ? content.authorizedParty : undefined,
62
+ c_hash,
63
+ client_id: isString(content.clientId) ? content.clientId : undefined,
64
+ cnf: cnf && Object.keys(cnf).length > 0 ? cnf : undefined,
65
+ entitlements: isArray(content.entitlements) ? content.entitlements : undefined,
66
+ events: isObject(content.events) ? content.events : undefined,
67
+ exp,
68
+ fal: isFinite(content.federationAssuranceLevel)
69
+ ? content.federationAssuranceLevel
70
+ : undefined,
71
+ groups: isArray(content.groups) ? content.groups : undefined,
72
+ gty: isString(content.grantType) ? content.grantType : undefined,
73
+ ial: isFinite(content.identityAssuranceLevel)
74
+ ? content.identityAssuranceLevel
75
+ : undefined,
76
+ may_act: isObject(content.mayAct) ? actClaimToWire(content.mayAct) : undefined,
77
+ iat: isDate(options.issuedAt) ? getUnixTime(options.issuedAt) : undefined,
78
+ iss: isString(content.issuer) ? content.issuer : undefined,
79
+ jti: isString(options.tokenId) ? options.tokenId : undefined,
80
+ loa: isFinite(content.levelOfAssurance) ? content.levelOfAssurance : undefined,
81
+ nbf: isDate(content.notBefore) ? getUnixTime(content.notBefore) : undefined,
82
+ nonce: isString(content.nonce) ? content.nonce : undefined,
83
+ permissions: isArray(content.permissions) ? content.permissions : undefined,
84
+ roles: isArray(content.roles) ? content.roles : undefined,
85
+ s_hash,
86
+ scope: isArray(content.scope) ? content.scope : undefined,
87
+ sid: isString(content.sessionId) ? content.sessionId : undefined,
88
+ sih: isString(content.sessionHint) ? content.sessionHint : undefined,
89
+ sub: isString(content.subject) ? content.subject : undefined,
90
+ sub_id: isObject(content.subjectId) ? content.subjectId : undefined,
91
+ suh: isString(content.subjectHint) ? content.subjectHint : undefined,
92
+ tenant_id: isString(content.tenantId) ? content.tenantId : undefined,
93
+ txn: isString(content.transactionId) ? content.transactionId : undefined,
94
+ vot: isString(content.vectorOfTrust) ? content.vectorOfTrust : undefined,
95
+ vtm: isString(content.vectorTrustMark) ? content.vectorTrustMark : undefined,
96
+ });
97
+ };
98
+ //# sourceMappingURL=map-content-to-claims.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"map-content-to-claims.js","sourceRoot":"","sources":["../../../src/internal/utils/map-content-to-claims.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"parse-introspection.d.ts","sourceRoot":"","sources":["../../../src/internal/utils/parse-introspection.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAG3C,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAO/D,MAAM,MAAM,qBAAqB,GAAG,IAAI,GAAG;IACzC,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB,CAAC;AAEF,eAAO,MAAM,kBAAkB,GAAI,MAAM,qBAAqB,KAAG,kBAqBhE,CAAC"}
1
+ {"version":3,"file":"parse-introspection.d.ts","sourceRoot":"","sources":["../../../src/internal/utils/parse-introspection.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAG3C,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAO/D,MAAM,MAAM,qBAAqB,GAAG,IAAI,GAAG;IACzC,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB,CAAC;AAEF,eAAO,MAAM,kBAAkB,GAAI,MAAM,qBAAqB,KAAG,kBA0BhE,CAAC"}
@@ -4,7 +4,11 @@ import { AegisError } from "../../errors/index.js";
4
4
  import { extractDomainClaims } from "./extract-claims.js";
5
5
  export const parseIntrospection = (data) => {
6
6
  if (!isBoolean(data.active)) {
7
- throw new AegisError("Missing active claim");
7
+ throw new AegisError("Missing active claim", {
8
+ code: "introspection_missing_active",
9
+ title: "Introspection Missing Active",
10
+ details: "An OAuth 2.0 introspection response must include a boolean active field, which was missing or non-boolean.",
11
+ });
8
12
  }
9
13
  if (!data.active) {
10
14
  return { active: false };
@@ -1 +1 @@
1
- {"version":3,"file":"parse-introspection.js","sourceRoot":"","sources":["../../../src/internal/utils/parse-introspection.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAElD,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAEnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAU1D,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,IAA2B,EAAsB,EAAE;IACpF,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,UAAU,CAAC,sBAAsB,CAAC,CAAC;IAC/C,CAAC;IAED,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;QACjB,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;IAC3B,CAAC;IAED,MAAM,EAAE,MAAM,EAAE,GAAG,mBAAmB,CAAC,IAAI,CAAC,CAAC;IAE7C,OAAO,eAAe,CAAC;QACrB,GAAG,MAAM;QACT,MAAM,EAAE,IAAa;QACrB,SAAS,EAAE,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC;YACjC,CAAC,CAAC,IAAI,CAAC,SAAS;YAChB,CAAC,CAAC,QAAQ,CAAE,IAAa,CAAC,UAAU,CAAC;gBACnC,CAAC,CAAG,IAAa,CAAC,UAAqB;gBACvC,CAAC,CAAC,SAAS;QACf,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;KAC9D,CAAC,CAAC;AACL,CAAC,CAAC"}
1
+ {"version":3,"file":"parse-introspection.js","sourceRoot":"","sources":["../../../src/internal/utils/parse-introspection.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAElD,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAEnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAU1D,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,IAA2B,EAAsB,EAAE;IACpF,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,UAAU,CAAC,sBAAsB,EAAE;YAC3C,IAAI,EAAE,8BAA8B;YACpC,KAAK,EAAE,8BAA8B;YACrC,OAAO,EACL,4GAA4G;SAC/G,CAAC,CAAC;IACL,CAAC;IAED,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;QACjB,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;IAC3B,CAAC;IAED,MAAM,EAAE,MAAM,EAAE,GAAG,mBAAmB,CAAC,IAAI,CAAC,CAAC;IAE7C,OAAO,eAAe,CAAC;QACrB,GAAG,MAAM;QACT,MAAM,EAAE,IAAa;QACrB,SAAS,EAAE,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC;YACjC,CAAC,CAAC,IAAI,CAAC,SAAS;YAChB,CAAC,CAAC,QAAQ,CAAE,IAAa,CAAC,UAAU,CAAC;gBACnC,CAAC,CAAG,IAAa,CAAC,UAAqB;gBACvC,CAAC,CAAC,SAAS;QACf,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;KAC9D,CAAC,CAAC;AACL,CAAC,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"parse-userinfo.d.ts","sourceRoot":"","sources":["../../../src/internal/utils/parse-userinfo.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,KAAK,EAAgB,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAOxE,MAAM,MAAM,mBAAmB,GAAG,IAAI,CAAC;AAEvC,eAAO,MAAM,aAAa,GAAI,MAAM,mBAAmB,KAAG,aAyBzD,CAAC"}
1
+ {"version":3,"file":"parse-userinfo.d.ts","sourceRoot":"","sources":["../../../src/internal/utils/parse-userinfo.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,KAAK,EAAgB,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAOxE,MAAM,MAAM,mBAAmB,GAAG,IAAI,CAAC;AAEvC,eAAO,MAAM,aAAa,GAAI,MAAM,mBAAmB,KAAG,aA8BzD,CAAC"}
@@ -12,7 +12,11 @@ export const parseUserinfo = (data) => {
12
12
  const { profile: extractedProfile } = extractAegisProfile(rest);
13
13
  const profile = preExtractedProfile ?? extractedProfile;
14
14
  if (!isString(claims.subject)) {
15
- throw new AegisError("Missing subject claim");
15
+ throw new AegisError("Missing subject claim", {
16
+ code: "userinfo_missing_subject",
17
+ title: "Userinfo Missing Subject",
18
+ details: "An OIDC userinfo response must include a string sub claim, which was missing or non-string.",
19
+ });
16
20
  }
17
21
  return {
18
22
  ...(profile ?? {}),
@@ -1 +1 @@
1
- {"version":3,"file":"parse-userinfo.js","sourceRoot":"","sources":["../../../src/internal/utils/parse-userinfo.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEjD,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAEnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAO1D,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,IAAyB,EAAiB,EAAE;IACxE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,mBAAmB,CAAC,IAAI,CAAC,CAAC;IAMnD,MAAM,mBAAmB,GACvB,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC;QAC/C,CAAC,CAAE,IAAI,CAAC,OAAwB;QAChC,CAAC,CAAC,SAAS,CAAC;IAEhB,IAAI,mBAAmB;QAAE,OAAO,IAAI,CAAC,OAAO,CAAC;IAE7C,MAAM,EAAE,OAAO,EAAE,gBAAgB,EAAE,GAAG,mBAAmB,CAAC,IAAI,CAAC,CAAC;IAChE,MAAM,OAAO,GAAG,mBAAmB,IAAI,gBAAgB,CAAC;IAExD,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;QAC9B,MAAM,IAAI,UAAU,CAAC,uBAAuB,CAAC,CAAC;IAChD,CAAC;IAED,OAAO;QACL,GAAG,CAAC,OAAO,IAAI,EAAE,CAAC;QAClB,OAAO,EAAE,MAAM,CAAC,OAAO;KACxB,CAAC;AACJ,CAAC,CAAC"}
1
+ {"version":3,"file":"parse-userinfo.js","sourceRoot":"","sources":["../../../src/internal/utils/parse-userinfo.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEjD,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAEnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAO1D,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,IAAyB,EAAiB,EAAE;IACxE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,mBAAmB,CAAC,IAAI,CAAC,CAAC;IAMnD,MAAM,mBAAmB,GACvB,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC;QAC/C,CAAC,CAAE,IAAI,CAAC,OAAwB;QAChC,CAAC,CAAC,SAAS,CAAC;IAEhB,IAAI,mBAAmB;QAAE,OAAO,IAAI,CAAC,OAAO,CAAC;IAE7C,MAAM,EAAE,OAAO,EAAE,gBAAgB,EAAE,GAAG,mBAAmB,CAAC,IAAI,CAAC,CAAC;IAChE,MAAM,OAAO,GAAG,mBAAmB,IAAI,gBAAgB,CAAC;IAExD,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;QAC9B,MAAM,IAAI,UAAU,CAAC,uBAAuB,EAAE;YAC5C,IAAI,EAAE,0BAA0B;YAChC,KAAK,EAAE,0BAA0B;YACjC,OAAO,EACL,6FAA6F;SAChG,CAAC,CAAC;IACL,CAAC;IAED,OAAO;QACL,GAAG,CAAC,OAAO,IAAI,EAAE,CAAC;QAClB,OAAO,EAAE,MAAM,CAAC,OAAO;KACxB,CAAC;AACJ,CAAC,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"resolve-cert-binding.d.ts","sourceRoot":"","sources":["../../../src/internal/utils/resolve-cert-binding.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAEjD,OAAO,KAAK,EAAE,mBAAmB,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;AAEzF,eAAO,MAAM,kBAAkB,GAC7B,SAAS,QAAQ,EACjB,MAAM,mBAAmB,GAAG,SAAS,KACpC,uBAAuB,GAAG,SA4B5B,CAAC"}
1
+ {"version":3,"file":"resolve-cert-binding.d.ts","sourceRoot":"","sources":["../../../src/internal/utils/resolve-cert-binding.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAEjD,OAAO,KAAK,EAAE,mBAAmB,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;AAEzF,eAAO,MAAM,kBAAkB,GAC7B,SAAS,QAAQ,EACjB,MAAM,mBAAmB,GAAG,SAAS,KACpC,uBAAuB,GAAG,SAgC5B,CAAC"}
@@ -11,7 +11,10 @@ export const resolveCertBinding = (kryptos, mode) => {
11
11
  return undefined;
12
12
  if (!kryptos.hasCertificate) {
13
13
  throw new AegisError("bindCertificate requires kryptos with certificateChain", {
14
+ code: "cert_binding_chain_required",
14
15
  debug: { kryptosId: kryptos.id, mode },
16
+ title: "Cert Binding Chain Required",
17
+ details: "Certificate binding was requested, but the signing kryptos has no certificateChain to derive an x5t#S256 thumbprint from.",
15
18
  });
16
19
  }
17
20
  const fields = {
@@ -1 +1 @@
1
- {"version":3,"file":"resolve-cert-binding.js","sourceRoot":"","sources":["../../../src/internal/utils/resolve-cert-binding.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAGnD,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAChC,OAAiB,EACjB,IAAqC,EACA,EAAE;IACvC,MAAM,QAAQ,GACZ,IAAI,KAAK,MAAM;QACb,CAAC,CAAC,MAAM;QACR,CAAC,CAAC,IAAI,KAAK,SAAS;YAClB,CAAC,CAAC,OAAO,CAAC,cAAc;gBACtB,CAAC,CAAC,YAAY;gBACd,CAAC,CAAC,MAAM;YACV,CAAC,CAAC,IAAI,CAAC;IAEb,IAAI,QAAQ,KAAK,MAAM;QAAE,OAAO,SAAS,CAAC;IAE1C,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;QAC5B,MAAM,IAAI,UAAU,CAAC,wDAAwD,EAAE;YAC7E,KAAK,EAAE,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE,EAAE,IAAI,EAAE;SACvC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,MAAM,GAA4B;QACtC,OAAO,EAAE,OAAO,CAAC,qBAAqB,IAAI,SAAS;KACpD,CAAC;IAEF,IAAI,QAAQ,KAAK,OAAO,EAAE,CAAC;QACzB,MAAM,CAAC,GAAG;YACR,OAAO,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS,CAAC;IAC/E,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC"}
1
+ {"version":3,"file":"resolve-cert-binding.js","sourceRoot":"","sources":["../../../src/internal/utils/resolve-cert-binding.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAGnD,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAChC,OAAiB,EACjB,IAAqC,EACA,EAAE;IACvC,MAAM,QAAQ,GACZ,IAAI,KAAK,MAAM;QACb,CAAC,CAAC,MAAM;QACR,CAAC,CAAC,IAAI,KAAK,SAAS;YAClB,CAAC,CAAC,OAAO,CAAC,cAAc;gBACtB,CAAC,CAAC,YAAY;gBACd,CAAC,CAAC,MAAM;YACV,CAAC,CAAC,IAAI,CAAC;IAEb,IAAI,QAAQ,KAAK,MAAM;QAAE,OAAO,SAAS,CAAC;IAE1C,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;QAC5B,MAAM,IAAI,UAAU,CAAC,wDAAwD,EAAE;YAC7E,IAAI,EAAE,6BAA6B;YACnC,KAAK,EAAE,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE,EAAE,IAAI,EAAE;YACtC,KAAK,EAAE,6BAA6B;YACpC,OAAO,EACL,2HAA2H;SAC9H,CAAC,CAAC;IACL,CAAC;IAED,MAAM,MAAM,GAA4B;QACtC,OAAO,EAAE,OAAO,CAAC,qBAAqB,IAAI,SAAS;KACpD,CAAC;IAEF,IAAI,QAAQ,KAAK,OAAO,EAAE,CAAC;QACzB,MAAM,CAAC,GAAG;YACR,OAAO,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS,CAAC;IAC/E,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { Dict } from "@lindorm/types";
2
+ import type { InvalidEntry } from "../../../types/index.js";
3
+ export declare const actChainShape: (claims: Dict) => Array<InvalidEntry>;
4
+ //# sourceMappingURL=act-chain-shape.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"act-chain-shape.d.ts","sourceRoot":"","sources":["../../../../src/internal/utils/rules/act-chain-shape.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AA+D5D,eAAO,MAAM,aAAa,GAAI,QAAQ,IAAI,KAAG,KAAK,CAAC,YAAY,CAO9D,CAAC"}
@@ -0,0 +1,52 @@
1
+ import { isObject, isArray, isString } from "@lindorm/is";
2
+ const PERMITTED_MEMBERS = new Set(["subject", "issuer", "audience", "clientId", "act"]);
3
+ const validateActor = (actor, path, invalid) => {
4
+ if (!isObject(actor)) {
5
+ invalid.push({ key: path, message: `"${path}" must be an object` });
6
+ return;
7
+ }
8
+ const node = actor;
9
+ for (const key of Object.keys(node)) {
10
+ if (!PERMITTED_MEMBERS.has(key)) {
11
+ invalid.push({
12
+ key: `${path}.${key}`,
13
+ message: `Unknown member "${key}" in "${path}"`,
14
+ });
15
+ }
16
+ }
17
+ if (node.subject !== undefined && !isString(node.subject)) {
18
+ invalid.push({
19
+ key: `${path}.subject`,
20
+ message: `"${path}.subject" must be a string`,
21
+ });
22
+ }
23
+ if (node.issuer !== undefined && !isString(node.issuer)) {
24
+ invalid.push({ key: `${path}.issuer`, message: `"${path}.issuer" must be a string` });
25
+ }
26
+ if (node.clientId !== undefined && !isString(node.clientId)) {
27
+ invalid.push({
28
+ key: `${path}.clientId`,
29
+ message: `"${path}.clientId" must be a string`,
30
+ });
31
+ }
32
+ if (node.audience !== undefined &&
33
+ !isArray(node.audience) &&
34
+ !isString(node.audience)) {
35
+ invalid.push({
36
+ key: `${path}.audience`,
37
+ message: `"${path}.audience" must be a string or array of strings`,
38
+ });
39
+ }
40
+ if (node.act !== undefined) {
41
+ validateActor(node.act, `${path}.act`, invalid);
42
+ }
43
+ };
44
+ export const actChainShape = (claims) => {
45
+ const invalid = [];
46
+ if (claims.act !== undefined)
47
+ validateActor(claims.act, "act", invalid);
48
+ if (claims.mayAct !== undefined)
49
+ validateActor(claims.mayAct, "mayAct", invalid);
50
+ return invalid;
51
+ };
52
+ //# sourceMappingURL=act-chain-shape.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"act-chain-shape.js","sourceRoot":"","sources":["../../../../src/internal/utils/rules/act-chain-shape.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAM1D,MAAM,iBAAiB,GAAG,IAAI,GAAG,CAAC,CAAC,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC,CAAC;AAExF,MAAM,aAAa,GAAG,CACpB,KAAc,EACd,IAAY,EACZ,OAA4B,EACtB,EAAE;IACR,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;QACrB,OAAO,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,IAAI,qBAAqB,EAAE,CAAC,CAAC;QACpE,OAAO;IACT,CAAC;IAED,MAAM,IAAI,GAAG,KAAK,CAAC;IAEnB,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QACpC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;YAChC,OAAO,CAAC,IAAI,CAAC;gBACX,GAAG,EAAE,GAAG,IAAI,IAAI,GAAG,EAAE;gBACrB,OAAO,EAAE,mBAAmB,GAAG,SAAS,IAAI,GAAG;aAChD,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;QAC1D,OAAO,CAAC,IAAI,CAAC;YACX,GAAG,EAAE,GAAG,IAAI,UAAU;YACtB,OAAO,EAAE,IAAI,IAAI,4BAA4B;SAC9C,CAAC,CAAC;IACL,CAAC;IACD,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;QACxD,OAAO,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,GAAG,IAAI,SAAS,EAAE,OAAO,EAAE,IAAI,IAAI,2BAA2B,EAAE,CAAC,CAAC;IACxF,CAAC;IACD,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC5D,OAAO,CAAC,IAAI,CAAC;YACX,GAAG,EAAE,GAAG,IAAI,WAAW;YACvB,OAAO,EAAE,IAAI,IAAI,6BAA6B;SAC/C,CAAC,CAAC;IACL,CAAC;IACD,IACE,IAAI,CAAC,QAAQ,KAAK,SAAS;QAC3B,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC;QACvB,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,EACxB,CAAC;QACD,OAAO,CAAC,IAAI,CAAC;YACX,GAAG,EAAE,GAAG,IAAI,WAAW;YACvB,OAAO,EAAE,IAAI,IAAI,iDAAiD;SACnE,CAAC,CAAC;IACL,CAAC;IAED,IAAI,IAAI,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;QAC3B,aAAa,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,MAAM,EAAE,OAAO,CAAC,CAAC;IAClD,CAAC;AACH,CAAC,CAAC;AAOF,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,MAAY,EAAuB,EAAE;IACjE,MAAM,OAAO,GAAwB,EAAE,CAAC;IAExC,IAAI,MAAM,CAAC,GAAG,KAAK,SAAS;QAAE,aAAa,CAAC,MAAM,CAAC,GAAG,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;IACxE,IAAI,MAAM,CAAC,MAAM,KAAK,SAAS;QAAE,aAAa,CAAC,MAAM,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;IAEjF,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC"}
@@ -0,0 +1,6 @@
1
+ import type { KryptosSigAlgorithm } from "@lindorm/kryptos";
2
+ import type { InvalidEntry } from "../../../types/index.js";
3
+ export type AlgClass = "asymmetric" | "asymmetric-recommended" | "confidential" | "fapi";
4
+ export declare const algAdvisory: (algorithm: KryptosSigAlgorithm | "none" | undefined, algClass: AlgClass) => string | undefined;
5
+ export declare const algPermitted: (algorithm: KryptosSigAlgorithm | "none" | undefined, algClass: AlgClass) => Array<InvalidEntry>;
6
+ //# sourceMappingURL=alg-permitted.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alg-permitted.d.ts","sourceRoot":"","sources":["../../../../src/internal/utils/rules/alg-permitted.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAC5D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAgB5D,MAAM,MAAM,QAAQ,GAAG,YAAY,GAAG,wBAAwB,GAAG,cAAc,GAAG,MAAM,CAAC;AAczF,eAAO,MAAM,WAAW,GACtB,WAAW,mBAAmB,GAAG,MAAM,GAAG,SAAS,EACnD,UAAU,QAAQ,KACjB,MAAM,GAAG,SAKX,CAAC;AAOF,eAAO,MAAM,YAAY,GACvB,WAAW,mBAAmB,GAAG,MAAM,GAAG,SAAS,EACnD,UAAU,QAAQ,KACjB,KAAK,CAAC,YAAY,CA2BpB,CAAC"}
@@ -0,0 +1,35 @@
1
+ const SYMMETRIC = new Set(["HS256", "HS384", "HS512"]);
2
+ const FAPI_ALLOWLIST = new Set(["PS256", "ES256", "EdDSA"]);
3
+ const isSymmetric = (algorithm) => SYMMETRIC.has(algorithm);
4
+ export const algAdvisory = (algorithm, algClass) => {
5
+ if (algClass === "asymmetric-recommended" && algorithm && isSymmetric(algorithm)) {
6
+ return `symmetric alg "${algorithm}" is permitted but asymmetric is RECOMMENDED for this artifact (RFC 9068 §2.1): a shared MAC secret lets any holder of it forge tokens`;
7
+ }
8
+ return undefined;
9
+ };
10
+ export const algPermitted = (algorithm, algClass) => {
11
+ if (algorithm === undefined || algorithm === "none") {
12
+ return [{ key: "alg", message: "alg: none is never permitted" }];
13
+ }
14
+ if (algClass === "fapi") {
15
+ if (!FAPI_ALLOWLIST.has(algorithm)) {
16
+ return [
17
+ {
18
+ key: "alg",
19
+ message: `alg "${algorithm}" is not in the FAPI allowlist (PS256, ES256, EdDSA)`,
20
+ },
21
+ ];
22
+ }
23
+ return [];
24
+ }
25
+ if (algClass === "asymmetric" && isSymmetric(algorithm)) {
26
+ return [
27
+ {
28
+ key: "alg",
29
+ message: `symmetric alg "${algorithm}" is not permitted for this artifact (asymmetric only)`,
30
+ },
31
+ ];
32
+ }
33
+ return [];
34
+ };
35
+ //# sourceMappingURL=alg-permitted.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alg-permitted.js","sourceRoot":"","sources":["../../../../src/internal/utils/rules/alg-permitted.ts"],"names":[],"mappings":"AAmBA,MAAM,SAAS,GAAG,IAAI,GAAG,CAAS,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;AAE/D,MAAM,cAAc,GAAG,IAAI,GAAG,CAAS,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;AAEpE,MAAM,WAAW,GAAG,CAAC,SAAiB,EAAW,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;AAQ7E,MAAM,CAAC,MAAM,WAAW,GAAG,CACzB,SAAmD,EACnD,QAAkB,EACE,EAAE;IACtB,IAAI,QAAQ,KAAK,wBAAwB,IAAI,SAAS,IAAI,WAAW,CAAC,SAAS,CAAC,EAAE,CAAC;QACjF,OAAO,kBAAkB,SAAS,wIAAwI,CAAC;IAC7K,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC;AAOF,MAAM,CAAC,MAAM,YAAY,GAAG,CAC1B,SAAmD,EACnD,QAAkB,EACG,EAAE;IACvB,IAAI,SAAS,KAAK,SAAS,IAAI,SAAS,KAAM,MAAiB,EAAE,CAAC;QAChE,OAAO,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,8BAA8B,EAAE,CAAC,CAAC;IACnE,CAAC;IAED,IAAI,QAAQ,KAAK,MAAM,EAAE,CAAC;QACxB,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;YACnC,OAAO;gBACL;oBACE,GAAG,EAAE,KAAK;oBACV,OAAO,EAAE,QAAQ,SAAS,sDAAsD;iBACjF;aACF,CAAC;QACJ,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,IAAI,QAAQ,KAAK,YAAY,IAAI,WAAW,CAAC,SAAS,CAAC,EAAE,CAAC;QACxD,OAAO;YACL;gBACE,GAAG,EAAE,KAAK;gBACV,OAAO,EAAE,kBAAkB,SAAS,wDAAwD;aAC7F;SACF,CAAC;IACJ,CAAC;IAED,OAAO,EAAE,CAAC;AACZ,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { Dict } from "@lindorm/types";
2
+ import type { InvalidEntry } from "../../../types/index.js";
3
+ export declare const atLeastOneOf: (claims: Dict, groups: Array<Array<string>>) => Array<InvalidEntry>;
4
+ //# sourceMappingURL=at-least-one-of.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"at-least-one-of.d.ts","sourceRoot":"","sources":["../../../../src/internal/utils/rules/at-least-one-of.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAM5D,eAAO,MAAM,YAAY,GACvB,QAAQ,IAAI,EACZ,QAAQ,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,KAC3B,KAAK,CAAC,YAAY,CAapB,CAAC"}
@@ -0,0 +1,13 @@
1
+ export const atLeastOneOf = (claims, groups) => {
2
+ const invalid = [];
3
+ for (const group of groups) {
4
+ if (!group.some((key) => claims[key] !== undefined)) {
5
+ invalid.push({
6
+ key: group.join("|"),
7
+ message: `At least one of [${group.join(", ")}] is required`,
8
+ });
9
+ }
10
+ }
11
+ return invalid;
12
+ };
13
+ //# sourceMappingURL=at-least-one-of.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"at-least-one-of.js","sourceRoot":"","sources":["../../../../src/internal/utils/rules/at-least-one-of.ts"],"names":[],"mappings":"AAOA,MAAM,CAAC,MAAM,YAAY,GAAG,CAC1B,MAAY,EACZ,MAA4B,EACP,EAAE;IACvB,MAAM,OAAO,GAAwB,EAAE,CAAC;IAExC,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QAC3B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,SAAS,CAAC,EAAE,CAAC;YACpD,OAAO,CAAC,IAAI,CAAC;gBACX,GAAG,EAAE,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC;gBACpB,OAAO,EAAE,oBAAoB,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe;aAC7D,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { Dict } from "@lindorm/types";
2
+ import type { InvalidEntry } from "../../../types/index.js";
3
+ export declare const audSingleResource: (claims: Dict) => Array<InvalidEntry>;
4
+ //# sourceMappingURL=aud-single-resource.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"aud-single-resource.d.ts","sourceRoot":"","sources":["../../../../src/internal/utils/rules/aud-single-resource.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAO5D,eAAO,MAAM,iBAAiB,GAAI,QAAQ,IAAI,KAAG,KAAK,CAAC,YAAY,CAiBlE,CAAC"}
@@ -0,0 +1,18 @@
1
+ import { isArray, isString } from "@lindorm/is";
2
+ export const audSingleResource = (claims) => {
3
+ const aud = claims.audience;
4
+ if (aud === undefined)
5
+ return [];
6
+ if (isString(aud))
7
+ return [];
8
+ if (!isArray(aud) || aud.length !== 1) {
9
+ return [
10
+ {
11
+ key: "aud",
12
+ message: "Access token aud must resolve to exactly one resource",
13
+ },
14
+ ];
15
+ }
16
+ return [];
17
+ };
18
+ //# sourceMappingURL=aud-single-resource.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"aud-single-resource.js","sourceRoot":"","sources":["../../../../src/internal/utils/rules/aud-single-resource.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAShD,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,MAAY,EAAuB,EAAE;IACrE,MAAM,GAAG,GAAG,MAAM,CAAC,QAAQ,CAAC;IAE5B,IAAI,GAAG,KAAK,SAAS;QAAE,OAAO,EAAE,CAAC;IAEjC,IAAI,QAAQ,CAAC,GAAG,CAAC;QAAE,OAAO,EAAE,CAAC;IAE7B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACtC,OAAO;YACL;gBACE,GAAG,EAAE,KAAK;gBACV,OAAO,EAAE,uDAAuD;aACjE;SACF,CAAC;IACJ,CAAC;IAED,OAAO,EAAE,CAAC;AACZ,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { Dict } from "@lindorm/types";
2
+ import type { InvalidEntry } from "../../../types/index.js";
3
+ export declare const cnfShape: (claims: Dict) => Array<InvalidEntry>;
4
+ //# sourceMappingURL=cnf-shape.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cnf-shape.d.ts","sourceRoot":"","sources":["../../../../src/internal/utils/rules/cnf-shape.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAqB5D,eAAO,MAAM,QAAQ,GAAI,QAAQ,IAAI,KAAG,KAAK,CAAC,YAAY,CA8CzD,CAAC"}
@@ -0,0 +1,55 @@
1
+ import { B64 } from "@lindorm/b64";
2
+ import { isObject, isString } from "@lindorm/is";
3
+ import { B64U } from "../../constants/format.js";
4
+ const PERMITTED_MEMBERS = new Set([
5
+ "thumbprint",
6
+ "mtlsCertThumbprint",
7
+ "key",
8
+ "keyId",
9
+ "jwkSetUri",
10
+ ]);
11
+ const JKT_BYTE_LENGTH = 32;
12
+ export const cnfShape = (claims) => {
13
+ const value = claims.confirmation;
14
+ if (value === undefined)
15
+ return [];
16
+ if (!isObject(value)) {
17
+ return [{ key: "confirmation", message: "confirmation (cnf) must be an object" }];
18
+ }
19
+ const cnf = value;
20
+ const invalid = [];
21
+ for (const key of Object.keys(cnf)) {
22
+ if (!PERMITTED_MEMBERS.has(key)) {
23
+ invalid.push({
24
+ key: `confirmation.${key}`,
25
+ message: `Unknown confirmation member "${key}"`,
26
+ });
27
+ }
28
+ }
29
+ if (cnf.thumbprint !== undefined) {
30
+ if (!isString(cnf.thumbprint)) {
31
+ invalid.push({
32
+ key: "confirmation.thumbprint",
33
+ message: "confirmation.thumbprint (cnf.jkt) must be a string",
34
+ });
35
+ }
36
+ else {
37
+ try {
38
+ if (B64.toBuffer(cnf.thumbprint, B64U).length !== JKT_BYTE_LENGTH) {
39
+ invalid.push({
40
+ key: "confirmation.thumbprint",
41
+ message: "confirmation.thumbprint (cnf.jkt) must be a base64url SHA-256 (32-byte) thumbprint",
42
+ });
43
+ }
44
+ }
45
+ catch {
46
+ invalid.push({
47
+ key: "confirmation.thumbprint",
48
+ message: "confirmation.thumbprint (cnf.jkt) must be valid base64url",
49
+ });
50
+ }
51
+ }
52
+ }
53
+ return invalid;
54
+ };
55
+ //# sourceMappingURL=cnf-shape.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cnf-shape.js","sourceRoot":"","sources":["../../../../src/internal/utils/rules/cnf-shape.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,cAAc,CAAC;AACnC,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEjD,OAAO,EAAE,IAAI,EAAE,MAAM,2BAA2B,CAAC;AAMjD,MAAM,iBAAiB,GAAG,IAAI,GAAG,CAAC;IAChC,YAAY;IACZ,oBAAoB;IACpB,KAAK;IACL,OAAO;IACP,WAAW;CACZ,CAAC,CAAC;AAGH,MAAM,eAAe,GAAG,EAAE,CAAC;AAO3B,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,MAAY,EAAuB,EAAE;IAC5D,MAAM,KAAK,GAAG,MAAM,CAAC,YAAY,CAAC;IAElC,IAAI,KAAK,KAAK,SAAS;QAAE,OAAO,EAAE,CAAC;IAEnC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;QACrB,OAAO,CAAC,EAAE,GAAG,EAAE,cAAc,EAAE,OAAO,EAAE,sCAAsC,EAAE,CAAC,CAAC;IACpF,CAAC;IAED,MAAM,GAAG,GAAG,KAAK,CAAC;IAClB,MAAM,OAAO,GAAwB,EAAE,CAAC;IAExC,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QACnC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;YAChC,OAAO,CAAC,IAAI,CAAC;gBACX,GAAG,EAAE,gBAAgB,GAAG,EAAE;gBAC1B,OAAO,EAAE,gCAAgC,GAAG,GAAG;aAChD,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,IAAI,GAAG,CAAC,UAAU,KAAK,SAAS,EAAE,CAAC;QACjC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC;YAC9B,OAAO,CAAC,IAAI,CAAC;gBACX,GAAG,EAAE,yBAAyB;gBAC9B,OAAO,EAAE,oDAAoD;aAC9D,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,IAAI,CAAC;gBACH,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC,MAAM,KAAK,eAAe,EAAE,CAAC;oBAClE,OAAO,CAAC,IAAI,CAAC;wBACX,GAAG,EAAE,yBAAyB;wBAC9B,OAAO,EACL,oFAAoF;qBACvF,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;YAAC,MAAM,CAAC;gBACP,OAAO,CAAC,IAAI,CAAC;oBACX,GAAG,EAAE,yBAAyB;oBAC9B,OAAO,EAAE,2DAA2D;iBACrE,CAAC,CAAC;YACL,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { Dict } from "@lindorm/types";
2
+ import type { InvalidEntry } from "../../../types/index.js";
3
+ export declare const crossField: (claims: Dict) => Array<InvalidEntry>;
4
+ //# sourceMappingURL=cross-field.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cross-field.d.ts","sourceRoot":"","sources":["../../../../src/internal/utils/rules/cross-field.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAY5D,eAAO,MAAM,UAAU,GAAI,QAAQ,IAAI,KAAG,KAAK,CAAC,YAAY,CAsB3D,CAAC"}
@@ -0,0 +1,21 @@
1
+ import { isDate } from "@lindorm/is";
2
+ export const crossField = (claims) => {
3
+ const invalid = [];
4
+ const exp = claims.expiresAt;
5
+ const iat = claims.issuedAt;
6
+ const nbf = claims.notBefore;
7
+ if (isDate(exp) && isDate(iat) && exp.getTime() <= iat.getTime()) {
8
+ invalid.push({
9
+ key: "expiresAt",
10
+ message: "expiresAt (exp) must be after issuedAt (iat)",
11
+ });
12
+ }
13
+ if (isDate(nbf) && isDate(exp) && nbf.getTime() > exp.getTime()) {
14
+ invalid.push({
15
+ key: "notBefore",
16
+ message: "notBefore (nbf) must be at or before expiresAt (exp)",
17
+ });
18
+ }
19
+ return invalid;
20
+ };
21
+ //# sourceMappingURL=cross-field.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cross-field.js","sourceRoot":"","sources":["../../../../src/internal/utils/rules/cross-field.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAcrC,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,MAAY,EAAuB,EAAE;IAC9D,MAAM,OAAO,GAAwB,EAAE,CAAC;IAExC,MAAM,GAAG,GAAG,MAAM,CAAC,SAAS,CAAC;IAC7B,MAAM,GAAG,GAAG,MAAM,CAAC,QAAQ,CAAC;IAC5B,MAAM,GAAG,GAAG,MAAM,CAAC,SAAS,CAAC;IAE7B,IAAI,MAAM,CAAC,GAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,OAAO,EAAE,IAAI,GAAG,CAAC,OAAO,EAAE,EAAE,CAAC;QACjE,OAAO,CAAC,IAAI,CAAC;YACX,GAAG,EAAE,WAAW;YAChB,OAAO,EAAE,8CAA8C;SACxD,CAAC,CAAC;IACL,CAAC;IAED,IAAI,MAAM,CAAC,GAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,OAAO,EAAE,GAAG,GAAG,CAAC,OAAO,EAAE,EAAE,CAAC;QAChE,OAAO,CAAC,IAAI,CAAC;YACX,GAAG,EAAE,WAAW;YAChB,OAAO,EAAE,sDAAsD;SAChE,CAAC,CAAC;IACL,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { Dict } from "@lindorm/types";
2
+ import type { InvalidEntry } from "../../../types/index.js";
3
+ export declare const eventsShape: (claims: Dict) => Array<InvalidEntry>;
4
+ //# sourceMappingURL=events-shape.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"events-shape.d.ts","sourceRoot":"","sources":["../../../../src/internal/utils/rules/events-shape.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAY5D,eAAO,MAAM,WAAW,GAAI,QAAQ,IAAI,KAAG,KAAK,CAAC,YAAY,CAkC5D,CAAC"}
@@ -0,0 +1,33 @@
1
+ import { isObject } from "@lindorm/is";
2
+ import { isUrlLike } from "@lindorm/is";
3
+ const isEventTypeUri = (key) => isUrlLike(key) || /^urn:[a-z0-9][a-z0-9-]{0,31}:\S+$/i.test(key);
4
+ export const eventsShape = (claims) => {
5
+ const value = claims.events;
6
+ if (value === undefined)
7
+ return [];
8
+ if (!isObject(value)) {
9
+ return [{ key: "events", message: "events must be an object" }];
10
+ }
11
+ const events = value;
12
+ const keys = Object.keys(events);
13
+ if (keys.length === 0) {
14
+ return [{ key: "events", message: "events must contain at least one event type" }];
15
+ }
16
+ const invalid = [];
17
+ for (const key of keys) {
18
+ if (!isEventTypeUri(key)) {
19
+ invalid.push({
20
+ key: `events.${key}`,
21
+ message: `event type "${key}" must be a URI`,
22
+ });
23
+ }
24
+ if (!isObject(events[key])) {
25
+ invalid.push({
26
+ key: `events.${key}`,
27
+ message: `event "${key}" payload must be an object`,
28
+ });
29
+ }
30
+ }
31
+ return invalid;
32
+ };
33
+ //# sourceMappingURL=events-shape.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"events-shape.js","sourceRoot":"","sources":["../../../../src/internal/utils/rules/events-shape.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAMxC,MAAM,cAAc,GAAG,CAAC,GAAW,EAAW,EAAE,CAC9C,SAAS,CAAC,GAAG,CAAC,IAAI,oCAAoC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAOnE,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,MAAY,EAAuB,EAAE;IAC/D,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC;IAE5B,IAAI,KAAK,KAAK,SAAS;QAAE,OAAO,EAAE,CAAC;IAEnC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;QACrB,OAAO,CAAC,EAAE,GAAG,EAAE,QAAQ,EAAE,OAAO,EAAE,0BAA0B,EAAE,CAAC,CAAC;IAClE,CAAC;IAED,MAAM,MAAM,GAAG,KAAK,CAAC;IACrB,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAEjC,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACtB,OAAO,CAAC,EAAE,GAAG,EAAE,QAAQ,EAAE,OAAO,EAAE,6CAA6C,EAAE,CAAC,CAAC;IACrF,CAAC;IAED,MAAM,OAAO,GAAwB,EAAE,CAAC;IAExC,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC;YACzB,OAAO,CAAC,IAAI,CAAC;gBACX,GAAG,EAAE,UAAU,GAAG,EAAE;gBACpB,OAAO,EAAE,eAAe,GAAG,iBAAiB;aAC7C,CAAC,CAAC;QACL,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;YAC3B,OAAO,CAAC,IAAI,CAAC;gBACX,GAAG,EAAE,UAAU,GAAG,EAAE;gBACpB,OAAO,EAAE,UAAU,GAAG,6BAA6B;aACpD,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { Dict } from "@lindorm/types";
2
+ import type { InvalidEntry } from "../../../types/index.js";
3
+ export declare const everyElementHasKey: (claims: Dict, claim: string, member: string) => Array<InvalidEntry>;
4
+ //# sourceMappingURL=every-element-has-key.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"every-element-has-key.d.ts","sourceRoot":"","sources":["../../../../src/internal/utils/rules/every-element-has-key.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAO5D,eAAO,MAAM,kBAAkB,GAC7B,QAAQ,IAAI,EACZ,OAAO,MAAM,EACb,QAAQ,MAAM,KACb,KAAK,CAAC,YAAY,CAqBpB,CAAC"}
@@ -0,0 +1,20 @@
1
+ import { isArray, isObject } from "@lindorm/is";
2
+ export const everyElementHasKey = (claims, claim, member) => {
3
+ const value = claims[claim];
4
+ if (value === undefined)
5
+ return [];
6
+ if (!isArray(value)) {
7
+ return [{ key: claim, message: `Claim "${claim}" must be an array` }];
8
+ }
9
+ const invalid = [];
10
+ value.forEach((element, index) => {
11
+ if (!isObject(element) || typeof element[member] !== "string") {
12
+ invalid.push({
13
+ key: `${claim}[${index}]`,
14
+ message: `Each "${claim}" element must be an object with a "${member}" string member`,
15
+ });
16
+ }
17
+ });
18
+ return invalid;
19
+ };
20
+ //# sourceMappingURL=every-element-has-key.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"every-element-has-key.js","sourceRoot":"","sources":["../../../../src/internal/utils/rules/every-element-has-key.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAShD,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAChC,MAAY,EACZ,KAAa,EACb,MAAc,EACO,EAAE;IACvB,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAE5B,IAAI,KAAK,KAAK,SAAS;QAAE,OAAO,EAAE,CAAC;IAEnC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QACpB,OAAO,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,KAAK,oBAAoB,EAAE,CAAC,CAAC;IACxE,CAAC;IAED,MAAM,OAAO,GAAwB,EAAE,CAAC;IAExC,KAAK,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE;QAC/B,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,OAAO,OAAO,CAAC,MAAM,CAAC,KAAK,QAAQ,EAAE,CAAC;YAC9D,OAAO,CAAC,IAAI,CAAC;gBACX,GAAG,EAAE,GAAG,KAAK,IAAI,KAAK,GAAG;gBACzB,OAAO,EAAE,SAAS,KAAK,uCAAuC,MAAM,iBAAiB;aACtF,CAAC,CAAC;QACL,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC"}