@lindorm/aegis 0.4.4 → 0.6.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 (429) hide show
  1. package/CHANGELOG.md +35 -0
  2. package/__tests__/jwt-interop.test.ts +13 -10
  3. package/dist/classes/Aegis.d.ts +13 -20
  4. package/dist/classes/Aegis.d.ts.map +1 -1
  5. package/dist/classes/Aegis.js +33 -119
  6. package/dist/classes/Aegis.js.map +1 -1
  7. package/dist/classes/JweKit.d.ts +1 -0
  8. package/dist/classes/JweKit.d.ts.map +1 -1
  9. package/dist/classes/JweKit.js +59 -12
  10. package/dist/classes/JweKit.js.map +1 -1
  11. package/dist/classes/JwsKit.d.ts +1 -0
  12. package/dist/classes/JwsKit.d.ts.map +1 -1
  13. package/dist/classes/JwsKit.js +54 -14
  14. package/dist/classes/JwsKit.js.map +1 -1
  15. package/dist/classes/JwtKit.d.ts +2 -0
  16. package/dist/classes/JwtKit.d.ts.map +1 -1
  17. package/dist/classes/JwtKit.js +90 -17
  18. package/dist/classes/JwtKit.js.map +1 -1
  19. package/dist/classes/SignatureKit.d.ts.map +1 -1
  20. package/dist/classes/SignatureKit.js +3 -0
  21. package/dist/classes/SignatureKit.js.map +1 -1
  22. package/dist/classes/index.d.ts +0 -3
  23. package/dist/classes/index.d.ts.map +1 -1
  24. package/dist/classes/index.js +0 -3
  25. package/dist/classes/index.js.map +1 -1
  26. package/dist/constants/token-type.d.ts +6 -0
  27. package/dist/constants/token-type.d.ts.map +1 -0
  28. package/dist/constants/token-type.js +20 -0
  29. package/dist/constants/token-type.js.map +1 -0
  30. package/dist/errors/index.d.ts +0 -3
  31. package/dist/errors/index.d.ts.map +1 -1
  32. package/dist/errors/index.js +0 -3
  33. package/dist/errors/index.js.map +1 -1
  34. package/dist/guards/index.d.ts +3 -0
  35. package/dist/guards/index.d.ts.map +1 -0
  36. package/dist/{types/cws → guards}/index.js +2 -4
  37. package/dist/guards/index.js.map +1 -0
  38. package/dist/guards/is-parsed-jws.d.ts +3 -0
  39. package/dist/guards/is-parsed-jws.d.ts.map +1 -0
  40. package/dist/guards/is-parsed-jws.js +6 -0
  41. package/dist/guards/is-parsed-jws.js.map +1 -0
  42. package/dist/guards/is-parsed-jwt.d.ts +3 -0
  43. package/dist/guards/is-parsed-jwt.d.ts.map +1 -0
  44. package/dist/guards/is-parsed-jwt.js +6 -0
  45. package/dist/guards/is-parsed-jwt.js.map +1 -0
  46. package/dist/index.d.ts +2 -0
  47. package/dist/index.d.ts.map +1 -1
  48. package/dist/index.js +1 -0
  49. package/dist/index.js.map +1 -1
  50. package/dist/interfaces/Aegis.d.ts +8 -22
  51. package/dist/interfaces/Aegis.d.ts.map +1 -1
  52. package/dist/interfaces/index.d.ts +0 -3
  53. package/dist/interfaces/index.d.ts.map +1 -1
  54. package/dist/interfaces/index.js +0 -3
  55. package/dist/interfaces/index.js.map +1 -1
  56. package/dist/internal/constants/aegis-profile-keys.d.ts +2 -0
  57. package/dist/internal/constants/aegis-profile-keys.d.ts.map +1 -0
  58. package/dist/internal/constants/aegis-profile-keys.js +37 -0
  59. package/dist/internal/constants/aegis-profile-keys.js.map +1 -0
  60. package/dist/internal/constants/header.d.ts +2 -2
  61. package/dist/internal/constants/header.d.ts.map +1 -1
  62. package/dist/internal/constants/header.js +1 -4
  63. package/dist/internal/constants/header.js.map +1 -1
  64. package/dist/internal/utils/compute-jwk-thumbprint.d.ts +4 -0
  65. package/dist/internal/utils/compute-jwk-thumbprint.d.ts.map +1 -0
  66. package/dist/internal/utils/compute-jwk-thumbprint.js +25 -0
  67. package/dist/internal/utils/compute-jwk-thumbprint.js.map +1 -0
  68. package/dist/internal/utils/compute-typ-header.d.ts +7 -0
  69. package/dist/internal/utils/compute-typ-header.d.ts.map +1 -0
  70. package/dist/internal/utils/compute-typ-header.js +68 -0
  71. package/dist/internal/utils/compute-typ-header.js.map +1 -0
  72. package/dist/internal/utils/extract-aegis-profile.d.ts +7 -0
  73. package/dist/internal/utils/extract-aegis-profile.d.ts.map +1 -0
  74. package/dist/internal/utils/extract-aegis-profile.js +34 -0
  75. package/dist/internal/utils/extract-aegis-profile.js.map +1 -0
  76. package/dist/internal/utils/extract-claims.d.ts +15 -0
  77. package/dist/internal/utils/extract-claims.d.ts.map +1 -0
  78. package/dist/internal/utils/extract-claims.js +201 -0
  79. package/dist/internal/utils/extract-claims.js.map +1 -0
  80. package/dist/internal/utils/extract-token-delegation.d.ts +6 -0
  81. package/dist/internal/utils/extract-token-delegation.d.ts.map +1 -0
  82. package/dist/internal/utils/extract-token-delegation.js +28 -0
  83. package/dist/internal/utils/extract-token-delegation.js.map +1 -0
  84. package/dist/internal/utils/generate-token-id.d.ts +2 -0
  85. package/dist/internal/utils/generate-token-id.d.ts.map +1 -0
  86. package/dist/internal/utils/generate-token-id.js +9 -0
  87. package/dist/internal/utils/generate-token-id.js.map +1 -0
  88. package/dist/internal/utils/jose-header.d.ts +2 -2
  89. package/dist/internal/utils/jose-header.d.ts.map +1 -1
  90. package/dist/internal/utils/jose-header.js +5 -5
  91. package/dist/internal/utils/jose-header.js.map +1 -1
  92. package/dist/internal/utils/jwt-payload.d.ts.map +1 -1
  93. package/dist/internal/utils/jwt-payload.js +50 -43
  94. package/dist/internal/utils/jwt-payload.js.map +1 -1
  95. package/dist/internal/utils/jwt-verify.d.ts.map +1 -1
  96. package/dist/internal/utils/jwt-verify.js +30 -6
  97. package/dist/internal/utils/jwt-verify.js.map +1 -1
  98. package/dist/internal/utils/parse-introspection.d.ts +7 -0
  99. package/dist/internal/utils/parse-introspection.d.ts.map +1 -0
  100. package/dist/internal/utils/parse-introspection.js +28 -0
  101. package/dist/internal/utils/parse-introspection.js.map +1 -0
  102. package/dist/internal/utils/parse-userinfo.d.ts +5 -0
  103. package/dist/internal/utils/parse-userinfo.d.ts.map +1 -0
  104. package/dist/internal/utils/parse-userinfo.js +26 -0
  105. package/dist/internal/utils/parse-userinfo.js.map +1 -0
  106. package/dist/internal/utils/resolve-cert-binding.d.ts +4 -0
  107. package/dist/internal/utils/resolve-cert-binding.d.ts.map +1 -0
  108. package/dist/internal/utils/resolve-cert-binding.js +30 -0
  109. package/dist/internal/utils/resolve-cert-binding.js.map +1 -0
  110. package/dist/internal/utils/token-header.d.ts +2 -2
  111. package/dist/internal/utils/token-header.d.ts.map +1 -1
  112. package/dist/internal/utils/token-header.js +5 -16
  113. package/dist/internal/utils/token-header.js.map +1 -1
  114. package/dist/internal/utils/validate-actor.d.ts +3 -0
  115. package/dist/internal/utils/validate-actor.d.ts.map +1 -0
  116. package/dist/internal/utils/validate-actor.js +27 -0
  117. package/dist/internal/utils/validate-actor.js.map +1 -0
  118. package/dist/internal/utils/validate-crit.d.ts +4 -0
  119. package/dist/internal/utils/validate-crit.d.ts.map +1 -0
  120. package/dist/internal/utils/validate-crit.js +55 -0
  121. package/dist/internal/utils/validate-crit.js.map +1 -0
  122. package/dist/internal/utils/verify-cert-binding.d.ts +14 -0
  123. package/dist/internal/utils/verify-cert-binding.d.ts.map +1 -0
  124. package/dist/internal/utils/verify-cert-binding.js +25 -0
  125. package/dist/internal/utils/verify-cert-binding.js.map +1 -0
  126. package/dist/internal/utils/verify-dpop-proof.d.ts +10 -0
  127. package/dist/internal/utils/verify-dpop-proof.d.ts.map +1 -0
  128. package/dist/internal/utils/verify-dpop-proof.js +76 -0
  129. package/dist/internal/utils/verify-dpop-proof.js.map +1 -0
  130. package/dist/mocks/create-mock-aegis.d.ts +2 -1
  131. package/dist/mocks/create-mock-aegis.d.ts.map +1 -1
  132. package/dist/mocks/create-mock-aegis.js +49 -75
  133. package/dist/mocks/create-mock-aegis.js.map +1 -1
  134. package/dist/mocks/index.d.ts +1 -1
  135. package/dist/mocks/index.d.ts.map +1 -1
  136. package/dist/mocks/index.js +3 -15
  137. package/dist/mocks/index.js.map +1 -1
  138. package/dist/types/aegis.d.ts +3 -0
  139. package/dist/types/aegis.d.ts.map +1 -1
  140. package/dist/types/claims/act-claim.d.ts +8 -0
  141. package/dist/types/claims/act-claim.d.ts.map +1 -0
  142. package/dist/{interfaces/CwtKit.js → types/claims/act-claim.js} +1 -1
  143. package/dist/types/claims/act-claim.js.map +1 -0
  144. package/dist/types/claims/aegis-introspection.d.ts +16 -0
  145. package/dist/types/claims/aegis-introspection.d.ts.map +1 -0
  146. package/dist/types/claims/aegis-introspection.js +3 -0
  147. package/dist/types/claims/aegis-introspection.js.map +1 -0
  148. package/dist/types/claims/aegis-profile.d.ts +44 -0
  149. package/dist/types/claims/aegis-profile.d.ts.map +1 -0
  150. package/dist/types/claims/aegis-profile.js +3 -0
  151. package/dist/types/claims/aegis-profile.js.map +1 -0
  152. package/dist/types/claims/aegis-userinfo.d.ts +5 -0
  153. package/dist/types/claims/aegis-userinfo.d.ts.map +1 -0
  154. package/dist/types/claims/aegis-userinfo.js +3 -0
  155. package/dist/types/claims/aegis-userinfo.js.map +1 -0
  156. package/dist/types/claims/confirmation-claim.d.ts +9 -0
  157. package/dist/types/claims/confirmation-claim.d.ts.map +1 -0
  158. package/dist/types/claims/confirmation-claim.js +3 -0
  159. package/dist/types/claims/confirmation-claim.js.map +1 -0
  160. package/dist/types/claims/delegation-claims.d.ts +6 -0
  161. package/dist/types/claims/delegation-claims.d.ts.map +1 -0
  162. package/dist/types/claims/delegation-claims.js +3 -0
  163. package/dist/types/claims/delegation-claims.js.map +1 -0
  164. package/dist/types/claims/index.d.ts +13 -0
  165. package/dist/types/claims/index.d.ts.map +1 -0
  166. package/dist/types/{cwt → claims}/index.js +12 -7
  167. package/dist/types/claims/index.js.map +1 -0
  168. package/dist/types/claims/jwt/act-claim-wire.d.ts +8 -0
  169. package/dist/types/claims/jwt/act-claim-wire.d.ts.map +1 -0
  170. package/dist/types/claims/jwt/act-claim-wire.js +3 -0
  171. package/dist/types/claims/jwt/act-claim-wire.js.map +1 -0
  172. package/dist/types/claims/jwt/confirmation-claim-wire.d.ts +9 -0
  173. package/dist/types/claims/jwt/confirmation-claim-wire.d.ts.map +1 -0
  174. package/dist/types/claims/jwt/confirmation-claim-wire.js +3 -0
  175. package/dist/types/claims/jwt/confirmation-claim-wire.js.map +1 -0
  176. package/dist/types/claims/jwt/delegation-claims-wire.d.ts +6 -0
  177. package/dist/types/claims/jwt/delegation-claims-wire.d.ts.map +1 -0
  178. package/dist/types/claims/jwt/delegation-claims-wire.js +3 -0
  179. package/dist/types/claims/jwt/delegation-claims-wire.js.map +1 -0
  180. package/dist/types/claims/jwt/index.d.ts +10 -0
  181. package/dist/types/claims/jwt/index.d.ts.map +1 -0
  182. package/dist/types/{cwe → claims/jwt}/index.js +9 -4
  183. package/dist/types/claims/jwt/index.js.map +1 -0
  184. package/dist/types/claims/jwt/jwt-claims.d.ts +8 -0
  185. package/dist/types/claims/jwt/jwt-claims.d.ts.map +1 -0
  186. package/dist/types/claims/jwt/jwt-claims.js.map +1 -0
  187. package/dist/types/claims/jwt/lindorm-claims-wire.d.ts +16 -0
  188. package/dist/types/claims/jwt/lindorm-claims-wire.d.ts.map +1 -0
  189. package/dist/types/claims/jwt/lindorm-claims-wire.js +3 -0
  190. package/dist/types/claims/jwt/lindorm-claims-wire.js.map +1 -0
  191. package/dist/types/claims/jwt/oauth-claims-wire.d.ts +6 -0
  192. package/dist/types/claims/jwt/oauth-claims-wire.d.ts.map +1 -0
  193. package/dist/types/claims/jwt/oauth-claims-wire.js +3 -0
  194. package/dist/types/claims/jwt/oauth-claims-wire.js.map +1 -0
  195. package/dist/types/claims/jwt/oidc-claims-wire.d.ts +11 -0
  196. package/dist/types/claims/jwt/oidc-claims-wire.d.ts.map +1 -0
  197. package/dist/types/claims/jwt/oidc-claims-wire.js +3 -0
  198. package/dist/types/claims/jwt/oidc-claims-wire.js.map +1 -0
  199. package/dist/types/claims/jwt/pop-claims-wire.d.ts +5 -0
  200. package/dist/types/claims/jwt/pop-claims-wire.d.ts.map +1 -0
  201. package/dist/types/claims/jwt/pop-claims-wire.js +3 -0
  202. package/dist/types/claims/jwt/pop-claims-wire.js.map +1 -0
  203. package/dist/types/claims/jwt/std-claims-wire.d.ts +10 -0
  204. package/dist/types/claims/jwt/std-claims-wire.d.ts.map +1 -0
  205. package/dist/types/claims/jwt/std-claims-wire.js +3 -0
  206. package/dist/types/claims/jwt/std-claims-wire.js.map +1 -0
  207. package/dist/types/claims/lindorm-claims.d.ts +18 -0
  208. package/dist/types/claims/lindorm-claims.d.ts.map +1 -0
  209. package/dist/types/claims/lindorm-claims.js +3 -0
  210. package/dist/types/claims/lindorm-claims.js.map +1 -0
  211. package/dist/types/claims/oauth-claims.d.ts +6 -0
  212. package/dist/types/claims/oauth-claims.d.ts.map +1 -0
  213. package/dist/types/claims/oauth-claims.js +3 -0
  214. package/dist/types/claims/oauth-claims.js.map +1 -0
  215. package/dist/types/claims/oidc-claims.d.ts +11 -0
  216. package/dist/types/claims/oidc-claims.d.ts.map +1 -0
  217. package/dist/types/{cose-target.js → claims/oidc-claims.js} +1 -1
  218. package/dist/types/claims/oidc-claims.js.map +1 -0
  219. package/dist/types/claims/pop-claims.d.ts +5 -0
  220. package/dist/types/claims/pop-claims.d.ts.map +1 -0
  221. package/dist/types/{cwe/cwe-decode.js → claims/pop-claims.js} +1 -1
  222. package/dist/types/claims/pop-claims.js.map +1 -0
  223. package/dist/types/claims/std-claims.d.ts +10 -0
  224. package/dist/types/claims/std-claims.d.ts.map +1 -0
  225. package/dist/types/claims/std-claims.js +3 -0
  226. package/dist/types/claims/std-claims.js.map +1 -0
  227. package/dist/types/header.d.ts +15 -8
  228. package/dist/types/header.d.ts.map +1 -1
  229. package/dist/types/index.d.ts +2 -4
  230. package/dist/types/index.d.ts.map +1 -1
  231. package/dist/types/index.js +2 -4
  232. package/dist/types/index.js.map +1 -1
  233. package/dist/types/jwe/jwe-decrypt.d.ts +2 -4
  234. package/dist/types/jwe/jwe-decrypt.d.ts.map +1 -1
  235. package/dist/types/jwe/jwe-encrypt.d.ts +4 -1
  236. package/dist/types/jwe/jwe-encrypt.d.ts.map +1 -1
  237. package/dist/types/jwe/jwe-kit.d.ts +2 -7
  238. package/dist/types/jwe/jwe-kit.d.ts.map +1 -1
  239. package/dist/types/jws/jws-kit.d.ts +2 -6
  240. package/dist/types/jws/jws-kit.d.ts.map +1 -1
  241. package/dist/types/jws/jws-parse.d.ts +2 -5
  242. package/dist/types/jws/jws-parse.d.ts.map +1 -1
  243. package/dist/types/jws/jws-sign.d.ts +5 -2
  244. package/dist/types/jws/jws-sign.d.ts.map +1 -1
  245. package/dist/types/jwt/index.d.ts +3 -1
  246. package/dist/types/jwt/index.d.ts.map +1 -1
  247. package/dist/types/jwt/index.js +3 -1
  248. package/dist/types/jwt/index.js.map +1 -1
  249. package/dist/types/jwt/jwt-claim-matchers.d.ts +28 -0
  250. package/dist/types/jwt/jwt-claim-matchers.d.ts.map +1 -0
  251. package/dist/types/jwt/jwt-claim-matchers.js +3 -0
  252. package/dist/types/jwt/jwt-claim-matchers.js.map +1 -0
  253. package/dist/types/jwt/jwt-decode.d.ts +1 -1
  254. package/dist/types/jwt/jwt-decode.d.ts.map +1 -1
  255. package/dist/types/jwt/jwt-delegation.d.ts +7 -0
  256. package/dist/types/jwt/jwt-delegation.d.ts.map +1 -0
  257. package/dist/types/jwt/jwt-delegation.js +3 -0
  258. package/dist/types/jwt/jwt-delegation.js.map +1 -0
  259. package/dist/types/jwt/jwt-dpop.d.ts +10 -0
  260. package/dist/types/jwt/jwt-dpop.d.ts.map +1 -0
  261. package/dist/{interfaces/CwsKit.js → types/jwt/jwt-dpop.js} +1 -1
  262. package/dist/types/jwt/jwt-dpop.js.map +1 -0
  263. package/dist/types/jwt/jwt-kit.d.ts +3 -5
  264. package/dist/types/jwt/jwt-kit.d.ts.map +1 -1
  265. package/dist/types/jwt/jwt-parse.d.ts +11 -27
  266. package/dist/types/jwt/jwt-parse.d.ts.map +1 -1
  267. package/dist/types/jwt/jwt-sign.d.ts +6 -23
  268. package/dist/types/jwt/jwt-sign.d.ts.map +1 -1
  269. package/dist/types/jwt/jwt-validate.d.ts +2 -23
  270. package/dist/types/jwt/jwt-validate.d.ts.map +1 -1
  271. package/dist/types/jwt/jwt-verify.d.ts +13 -25
  272. package/dist/types/jwt/jwt-verify.d.ts.map +1 -1
  273. package/dist/types/kit.d.ts +12 -0
  274. package/dist/types/kit.d.ts.map +1 -0
  275. package/dist/{interfaces/CweKit.js → types/kit.js} +1 -1
  276. package/dist/types/kit.js.map +1 -0
  277. package/dist/types/level-of-assurance.d.ts +1 -1
  278. package/dist/types/level-of-assurance.d.ts.map +1 -1
  279. package/package.json +20 -21
  280. package/tsconfig.interop.json +1 -5
  281. package/__tests__/cose-interop.test.ts +0 -1127
  282. package/dist/classes/CweKit.d.ts +0 -14
  283. package/dist/classes/CweKit.d.ts.map +0 -1
  284. package/dist/classes/CweKit.js +0 -151
  285. package/dist/classes/CweKit.js.map +0 -1
  286. package/dist/classes/CwsKit.d.ts +0 -13
  287. package/dist/classes/CwsKit.d.ts.map +0 -1
  288. package/dist/classes/CwsKit.js +0 -139
  289. package/dist/classes/CwsKit.js.map +0 -1
  290. package/dist/classes/CwtKit.d.ts +0 -17
  291. package/dist/classes/CwtKit.d.ts.map +0 -1
  292. package/dist/classes/CwtKit.js +0 -166
  293. package/dist/classes/CwtKit.js.map +0 -1
  294. package/dist/errors/CoseEncryptError.d.ts +0 -4
  295. package/dist/errors/CoseEncryptError.d.ts.map +0 -1
  296. package/dist/errors/CoseEncryptError.js +0 -8
  297. package/dist/errors/CoseEncryptError.js.map +0 -1
  298. package/dist/errors/CoseSignError.d.ts +0 -4
  299. package/dist/errors/CoseSignError.d.ts.map +0 -1
  300. package/dist/errors/CoseSignError.js +0 -8
  301. package/dist/errors/CoseSignError.js.map +0 -1
  302. package/dist/errors/CwtError.d.ts +0 -4
  303. package/dist/errors/CwtError.d.ts.map +0 -1
  304. package/dist/errors/CwtError.js +0 -8
  305. package/dist/errors/CwtError.js.map +0 -1
  306. package/dist/interfaces/CweKit.d.ts +0 -6
  307. package/dist/interfaces/CweKit.d.ts.map +0 -1
  308. package/dist/interfaces/CweKit.js.map +0 -1
  309. package/dist/interfaces/CwsKit.d.ts +0 -6
  310. package/dist/interfaces/CwsKit.d.ts.map +0 -1
  311. package/dist/interfaces/CwsKit.js.map +0 -1
  312. package/dist/interfaces/CwtKit.d.ts +0 -7
  313. package/dist/interfaces/CwtKit.d.ts.map +0 -1
  314. package/dist/interfaces/CwtKit.js.map +0 -1
  315. package/dist/internal/constants/cose.d.ts +0 -19
  316. package/dist/internal/constants/cose.d.ts.map +0 -1
  317. package/dist/internal/constants/cose.js +0 -116
  318. package/dist/internal/constants/cose.js.map +0 -1
  319. package/dist/internal/utils/auth-tag-length.d.ts +0 -3
  320. package/dist/internal/utils/auth-tag-length.d.ts.map +0 -1
  321. package/dist/internal/utils/auth-tag-length.js +0 -21
  322. package/dist/internal/utils/auth-tag-length.js.map +0 -1
  323. package/dist/internal/utils/cose/bstr.d.ts +0 -4
  324. package/dist/internal/utils/cose/bstr.d.ts.map +0 -1
  325. package/dist/internal/utils/cose/bstr.js +0 -18
  326. package/dist/internal/utils/cose/bstr.js.map +0 -1
  327. package/dist/internal/utils/cose/claims.d.ts +0 -5
  328. package/dist/internal/utils/cose/claims.d.ts.map +0 -1
  329. package/dist/internal/utils/cose/claims.js +0 -57
  330. package/dist/internal/utils/cose/claims.js.map +0 -1
  331. package/dist/internal/utils/cose/crit.d.ts +0 -3
  332. package/dist/internal/utils/cose/crit.d.ts.map +0 -1
  333. package/dist/internal/utils/cose/crit.js +0 -43
  334. package/dist/internal/utils/cose/crit.js.map +0 -1
  335. package/dist/internal/utils/cose/find.d.ts +0 -5
  336. package/dist/internal/utils/cose/find.d.ts.map +0 -1
  337. package/dist/internal/utils/cose/find.js +0 -37
  338. package/dist/internal/utils/cose/find.js.map +0 -1
  339. package/dist/internal/utils/cose/header.d.ts +0 -5
  340. package/dist/internal/utils/cose/header.d.ts.map +0 -1
  341. package/dist/internal/utils/cose/header.js +0 -81
  342. package/dist/internal/utils/cose/header.js.map +0 -1
  343. package/dist/internal/utils/cose/key.d.ts +0 -4
  344. package/dist/internal/utils/cose/key.d.ts.map +0 -1
  345. package/dist/internal/utils/cose/key.js +0 -86
  346. package/dist/internal/utils/cose/key.js.map +0 -1
  347. package/dist/internal/utils/cose-sign-token.d.ts +0 -9
  348. package/dist/internal/utils/cose-sign-token.d.ts.map +0 -1
  349. package/dist/internal/utils/cose-sign-token.js +0 -12
  350. package/dist/internal/utils/cose-sign-token.js.map +0 -1
  351. package/dist/internal/utils/cose-signature.d.ts +0 -16
  352. package/dist/internal/utils/cose-signature.d.ts.map +0 -1
  353. package/dist/internal/utils/cose-signature.js +0 -17
  354. package/dist/internal/utils/cose-signature.js.map +0 -1
  355. package/dist/types/cose-target.d.ts +0 -2
  356. package/dist/types/cose-target.d.ts.map +0 -1
  357. package/dist/types/cose-target.js.map +0 -1
  358. package/dist/types/cwe/cwe-decode.d.ts +0 -18
  359. package/dist/types/cwe/cwe-decode.d.ts.map +0 -1
  360. package/dist/types/cwe/cwe-decode.js.map +0 -1
  361. package/dist/types/cwe/cwe-decrypt.d.ts +0 -15
  362. package/dist/types/cwe/cwe-decrypt.d.ts.map +0 -1
  363. package/dist/types/cwe/cwe-decrypt.js +0 -3
  364. package/dist/types/cwe/cwe-decrypt.js.map +0 -1
  365. package/dist/types/cwe/cwe-encrypt.d.ts +0 -12
  366. package/dist/types/cwe/cwe-encrypt.d.ts.map +0 -1
  367. package/dist/types/cwe/cwe-encrypt.js +0 -3
  368. package/dist/types/cwe/cwe-encrypt.js.map +0 -1
  369. package/dist/types/cwe/cwe-kit.d.ts +0 -9
  370. package/dist/types/cwe/cwe-kit.d.ts.map +0 -1
  371. package/dist/types/cwe/cwe-kit.js +0 -3
  372. package/dist/types/cwe/cwe-kit.js.map +0 -1
  373. package/dist/types/cwe/index.d.ts +0 -5
  374. package/dist/types/cwe/index.d.ts.map +0 -1
  375. package/dist/types/cwe/index.js.map +0 -1
  376. package/dist/types/cws/cws-decode.d.ts +0 -9
  377. package/dist/types/cws/cws-decode.d.ts.map +0 -1
  378. package/dist/types/cws/cws-decode.js +0 -3
  379. package/dist/types/cws/cws-decode.js.map +0 -1
  380. package/dist/types/cws/cws-kit.d.ts +0 -8
  381. package/dist/types/cws/cws-kit.d.ts.map +0 -1
  382. package/dist/types/cws/cws-kit.js +0 -3
  383. package/dist/types/cws/cws-kit.js.map +0 -1
  384. package/dist/types/cws/cws-parse.d.ts +0 -14
  385. package/dist/types/cws/cws-parse.d.ts.map +0 -1
  386. package/dist/types/cws/cws-parse.js +0 -3
  387. package/dist/types/cws/cws-parse.js.map +0 -1
  388. package/dist/types/cws/cws-sign.d.ts +0 -14
  389. package/dist/types/cws/cws-sign.d.ts.map +0 -1
  390. package/dist/types/cws/cws-sign.js +0 -3
  391. package/dist/types/cws/cws-sign.js.map +0 -1
  392. package/dist/types/cws/index.d.ts +0 -5
  393. package/dist/types/cws/index.d.ts.map +0 -1
  394. package/dist/types/cws/index.js.map +0 -1
  395. package/dist/types/cwt/cwt-claims.d.ts +0 -3
  396. package/dist/types/cwt/cwt-claims.d.ts.map +0 -1
  397. package/dist/types/cwt/cwt-claims.js +0 -3
  398. package/dist/types/cwt/cwt-claims.js.map +0 -1
  399. package/dist/types/cwt/cwt-decode.d.ts +0 -10
  400. package/dist/types/cwt/cwt-decode.d.ts.map +0 -1
  401. package/dist/types/cwt/cwt-decode.js +0 -3
  402. package/dist/types/cwt/cwt-decode.js.map +0 -1
  403. package/dist/types/cwt/cwt-kit.d.ts +0 -3
  404. package/dist/types/cwt/cwt-kit.d.ts.map +0 -1
  405. package/dist/types/cwt/cwt-kit.js +0 -3
  406. package/dist/types/cwt/cwt-kit.js.map +0 -1
  407. package/dist/types/cwt/cwt-parse.d.ts +0 -15
  408. package/dist/types/cwt/cwt-parse.d.ts.map +0 -1
  409. package/dist/types/cwt/cwt-parse.js +0 -3
  410. package/dist/types/cwt/cwt-parse.js.map +0 -1
  411. package/dist/types/cwt/cwt-sign.d.ts +0 -17
  412. package/dist/types/cwt/cwt-sign.d.ts.map +0 -1
  413. package/dist/types/cwt/cwt-sign.js +0 -3
  414. package/dist/types/cwt/cwt-sign.js.map +0 -1
  415. package/dist/types/cwt/cwt-validate.d.ts +0 -3
  416. package/dist/types/cwt/cwt-validate.d.ts.map +0 -1
  417. package/dist/types/cwt/cwt-validate.js +0 -3
  418. package/dist/types/cwt/cwt-validate.js.map +0 -1
  419. package/dist/types/cwt/cwt-verify.d.ts +0 -3
  420. package/dist/types/cwt/cwt-verify.d.ts.map +0 -1
  421. package/dist/types/cwt/cwt-verify.js +0 -3
  422. package/dist/types/cwt/cwt-verify.js.map +0 -1
  423. package/dist/types/cwt/index.d.ts +0 -8
  424. package/dist/types/cwt/index.d.ts.map +0 -1
  425. package/dist/types/cwt/index.js.map +0 -1
  426. package/dist/types/jwt/jwt-claims.d.ts +0 -38
  427. package/dist/types/jwt/jwt-claims.d.ts.map +0 -1
  428. package/dist/types/jwt/jwt-claims.js.map +0 -1
  429. /package/dist/types/{jwt → claims/jwt}/jwt-claims.js +0 -0
@@ -0,0 +1,201 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DOMAIN_CLAIM_KEYS = exports.extractDomainClaims = void 0;
4
+ const is_1 = require("@lindorm/is");
5
+ const utils_1 = require("@lindorm/utils");
6
+ const FIELD_KEYS = {
7
+ subject: ["subject", "sub"],
8
+ expiresAt: ["expiresAt", "exp"],
9
+ issuedAt: ["issuedAt", "iat"],
10
+ notBefore: ["notBefore", "nbf"],
11
+ issuer: ["issuer", "iss"],
12
+ audience: ["audience", "aud"],
13
+ tokenId: ["tokenId", "jti"],
14
+ accessTokenHash: ["accessTokenHash", "at_hash"],
15
+ authContextClass: ["authContextClass", "acr"],
16
+ authMethods: ["authMethods", "amr"],
17
+ authorizedParty: ["authorizedParty", "azp"],
18
+ authTime: ["authTime", "auth_time"],
19
+ codeHash: ["codeHash", "c_hash"],
20
+ nonce: ["nonce"],
21
+ stateHash: ["stateHash", "s_hash"],
22
+ entitlements: ["entitlements"],
23
+ groups: ["groups"],
24
+ roles: ["roles"],
25
+ adjustedAccessLevel: ["adjustedAccessLevel", "aal"],
26
+ authFactor: ["authFactor", "afr"],
27
+ clientId: ["clientId", "client_id"],
28
+ grantType: ["grantType", "gty"],
29
+ levelOfAssurance: ["levelOfAssurance", "loa"],
30
+ permissions: ["permissions"],
31
+ scope: ["scope"],
32
+ sessionHint: ["sessionHint", "sih"],
33
+ sessionId: ["sessionId", "sid"],
34
+ subjectHint: ["subjectHint", "suh"],
35
+ tenantId: ["tenantId", "tenant_id"],
36
+ };
37
+ const RFC8693_KEYS = {
38
+ act: ["act"],
39
+ mayAct: ["mayAct", "may_act"],
40
+ };
41
+ const POP_KEYS = {
42
+ confirmation: ["confirmation", "cnf"],
43
+ };
44
+ const toDate = (value) => {
45
+ if (value instanceof Date)
46
+ return value;
47
+ if ((0, is_1.isFinite)(value))
48
+ return new Date(value * 1000);
49
+ return undefined;
50
+ };
51
+ const toStringArray = (value) => {
52
+ if ((0, is_1.isArray)(value))
53
+ return value;
54
+ if ((0, is_1.isString)(value))
55
+ return value.split(" ").filter(Boolean);
56
+ return undefined;
57
+ };
58
+ const toAudience = (value) => {
59
+ if ((0, is_1.isArray)(value))
60
+ return value;
61
+ if ((0, is_1.isString)(value))
62
+ return [value];
63
+ return undefined;
64
+ };
65
+ const toActClaim = (value) => {
66
+ if (!(0, is_1.isObject)(value))
67
+ return undefined;
68
+ const v = value;
69
+ const result = (0, utils_1.removeUndefined)({
70
+ subject: (0, is_1.isString)(v.subject) ? v.subject : (0, is_1.isString)(v.sub) ? v.sub : undefined,
71
+ issuer: (0, is_1.isString)(v.issuer) ? v.issuer : (0, is_1.isString)(v.iss) ? v.iss : undefined,
72
+ audience: toAudience(v.audience ?? v.aud),
73
+ clientId: (0, is_1.isString)(v.clientId)
74
+ ? v.clientId
75
+ : (0, is_1.isString)(v.client_id)
76
+ ? v.client_id
77
+ : undefined,
78
+ act: toActClaim(v.act),
79
+ });
80
+ return Object.keys(result).length > 0 ? result : undefined;
81
+ };
82
+ const toConfirmation = (value) => {
83
+ if (!(0, is_1.isObject)(value))
84
+ return undefined;
85
+ const v = value;
86
+ const result = (0, utils_1.removeUndefined)({
87
+ thumbprint: (0, is_1.isString)(v.thumbprint)
88
+ ? v.thumbprint
89
+ : (0, is_1.isString)(v.jkt)
90
+ ? v.jkt
91
+ : undefined,
92
+ mtlsCertThumbprint: (0, is_1.isString)(v.mtlsCertThumbprint)
93
+ ? v.mtlsCertThumbprint
94
+ : (0, is_1.isString)(v["x5t#S256"])
95
+ ? v["x5t#S256"]
96
+ : undefined,
97
+ key: (0, is_1.isObject)(v.key)
98
+ ? v.key
99
+ : (0, is_1.isObject)(v.jwk)
100
+ ? v.jwk
101
+ : undefined,
102
+ keyId: (0, is_1.isString)(v.keyId) ? v.keyId : (0, is_1.isString)(v.kid) ? v.kid : undefined,
103
+ jwkSetUri: (0, is_1.isString)(v.jwkSetUri) ? v.jwkSetUri : (0, is_1.isString)(v.jku) ? v.jku : undefined,
104
+ });
105
+ return Object.keys(result).length > 0 ? result : undefined;
106
+ };
107
+ const extractDomainClaims = (input) => {
108
+ const consumed = new Set();
109
+ const consume = (keys) => {
110
+ for (const key of keys) {
111
+ if (key in input) {
112
+ consumed.add(key);
113
+ return input[key];
114
+ }
115
+ }
116
+ return undefined;
117
+ };
118
+ const subject = consume(FIELD_KEYS.subject);
119
+ const expiresAt = consume(FIELD_KEYS.expiresAt);
120
+ const issuedAt = consume(FIELD_KEYS.issuedAt);
121
+ const notBefore = consume(FIELD_KEYS.notBefore);
122
+ const issuer = consume(FIELD_KEYS.issuer);
123
+ const audience = consume(FIELD_KEYS.audience);
124
+ const tokenId = consume(FIELD_KEYS.tokenId);
125
+ const accessTokenHash = consume(FIELD_KEYS.accessTokenHash);
126
+ const authContextClass = consume(FIELD_KEYS.authContextClass);
127
+ const authMethods = consume(FIELD_KEYS.authMethods);
128
+ const authorizedParty = consume(FIELD_KEYS.authorizedParty);
129
+ const authTime = consume(FIELD_KEYS.authTime);
130
+ const codeHash = consume(FIELD_KEYS.codeHash);
131
+ const nonce = consume(FIELD_KEYS.nonce);
132
+ const stateHash = consume(FIELD_KEYS.stateHash);
133
+ const entitlements = consume(FIELD_KEYS.entitlements);
134
+ const groups = consume(FIELD_KEYS.groups);
135
+ const roles = consume(FIELD_KEYS.roles);
136
+ const adjustedAccessLevel = consume(FIELD_KEYS.adjustedAccessLevel);
137
+ const authFactor = consume(FIELD_KEYS.authFactor);
138
+ const clientId = consume(FIELD_KEYS.clientId);
139
+ const grantType = consume(FIELD_KEYS.grantType);
140
+ const levelOfAssurance = consume(FIELD_KEYS.levelOfAssurance);
141
+ const permissions = consume(FIELD_KEYS.permissions);
142
+ const scope = consume(FIELD_KEYS.scope);
143
+ const sessionHint = consume(FIELD_KEYS.sessionHint);
144
+ const sessionId = consume(FIELD_KEYS.sessionId);
145
+ const subjectHint = consume(FIELD_KEYS.subjectHint);
146
+ const tenantId = consume(FIELD_KEYS.tenantId);
147
+ const act = consume(RFC8693_KEYS.act);
148
+ const mayAct = consume(RFC8693_KEYS.mayAct);
149
+ const confirmation = consume(POP_KEYS.confirmation);
150
+ const claims = (0, utils_1.removeUndefined)({
151
+ subject: (0, is_1.isString)(subject) ? subject : undefined,
152
+ expiresAt: toDate(expiresAt),
153
+ issuedAt: toDate(issuedAt),
154
+ notBefore: toDate(notBefore),
155
+ issuer: (0, is_1.isString)(issuer) ? issuer : undefined,
156
+ audience: toAudience(audience),
157
+ tokenId: (0, is_1.isString)(tokenId) ? tokenId : undefined,
158
+ accessTokenHash: (0, is_1.isString)(accessTokenHash) ? accessTokenHash : undefined,
159
+ authContextClass: (0, is_1.isString)(authContextClass) ? authContextClass : undefined,
160
+ authMethods: (0, is_1.isArray)(authMethods) ? authMethods : undefined,
161
+ authorizedParty: (0, is_1.isString)(authorizedParty) ? authorizedParty : undefined,
162
+ authTime: toDate(authTime),
163
+ codeHash: (0, is_1.isString)(codeHash) ? codeHash : undefined,
164
+ nonce: (0, is_1.isString)(nonce) ? nonce : undefined,
165
+ stateHash: (0, is_1.isString)(stateHash) ? stateHash : undefined,
166
+ confirmation: toConfirmation(confirmation),
167
+ act: toActClaim(act),
168
+ mayAct: toActClaim(mayAct),
169
+ entitlements: (0, is_1.isArray)(entitlements) ? entitlements : undefined,
170
+ groups: (0, is_1.isArray)(groups) ? groups : undefined,
171
+ roles: toStringArray(roles),
172
+ adjustedAccessLevel: (0, is_1.isFinite)(adjustedAccessLevel)
173
+ ? adjustedAccessLevel
174
+ : undefined,
175
+ authFactor: (0, is_1.isArray)(authFactor) ? authFactor : undefined,
176
+ clientId: (0, is_1.isString)(clientId) ? clientId : undefined,
177
+ grantType: (0, is_1.isString)(grantType) ? grantType : undefined,
178
+ levelOfAssurance: (0, is_1.isFinite)(levelOfAssurance)
179
+ ? levelOfAssurance
180
+ : undefined,
181
+ permissions: toStringArray(permissions),
182
+ scope: toStringArray(scope),
183
+ sessionHint: (0, is_1.isString)(sessionHint) ? sessionHint : undefined,
184
+ sessionId: (0, is_1.isString)(sessionId) ? sessionId : undefined,
185
+ subjectHint: (0, is_1.isString)(subjectHint) ? subjectHint : undefined,
186
+ tenantId: (0, is_1.isString)(tenantId) ? tenantId : undefined,
187
+ });
188
+ const rest = {};
189
+ for (const key of Object.keys(input)) {
190
+ if (!consumed.has(key))
191
+ rest[key] = input[key];
192
+ }
193
+ return { claims, rest };
194
+ };
195
+ exports.extractDomainClaims = extractDomainClaims;
196
+ exports.DOMAIN_CLAIM_KEYS = {
197
+ ...FIELD_KEYS,
198
+ ...RFC8693_KEYS,
199
+ ...POP_KEYS,
200
+ };
201
+ //# sourceMappingURL=extract-claims.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extract-claims.js","sourceRoot":"","sources":["../../../src/internal/utils/extract-claims.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import { ActClaimWire } from "../../types/claims/jwt/act-claim-wire";
2
+ import { TokenDelegation } from "../../types/jwt/jwt-delegation";
3
+ export declare const extractTokenDelegation: (payload: {
4
+ act?: ActClaimWire;
5
+ }) => TokenDelegation;
6
+ //# sourceMappingURL=extract-token-delegation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extract-token-delegation.d.ts","sourceRoot":"","sources":["../../../src/internal/utils/extract-token-delegation.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,uCAAuC,CAAC;AACrE,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AAmBjE,eAAO,MAAM,sBAAsB,GAAI,SAAS;IAC9C,GAAG,CAAC,EAAE,YAAY,CAAC;CACpB,KAAG,eAOH,CAAC"}
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.extractTokenDelegation = void 0;
4
+ const utils_1 = require("@lindorm/utils");
5
+ const walkActChain = (act) => {
6
+ const chain = [];
7
+ let current = act;
8
+ while (current) {
9
+ chain.push((0, utils_1.removeUndefined)({
10
+ subject: current.sub,
11
+ issuer: current.iss,
12
+ audience: current.aud,
13
+ clientId: current.client_id,
14
+ }));
15
+ current = current.act;
16
+ }
17
+ return chain;
18
+ };
19
+ const extractTokenDelegation = (payload) => {
20
+ const actorChain = walkActChain(payload.act);
21
+ return {
22
+ currentActor: actorChain[0]?.subject,
23
+ actorChain,
24
+ isDelegated: actorChain.length > 0,
25
+ };
26
+ };
27
+ exports.extractTokenDelegation = extractTokenDelegation;
28
+ //# sourceMappingURL=extract-token-delegation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extract-token-delegation.js","sourceRoot":"","sources":["../../../src/internal/utils/extract-token-delegation.ts"],"names":[],"mappings":";;;AAAA,0CAAiD;AAKjD,MAAM,YAAY,GAAG,CAAC,GAA6B,EAAmB,EAAE;IACtE,MAAM,KAAK,GAAoB,EAAE,CAAC;IAClC,IAAI,OAAO,GAAG,GAAG,CAAC;IAClB,OAAO,OAAO,EAAE,CAAC;QACf,KAAK,CAAC,IAAI,CACR,IAAA,uBAAe,EAAC;YACd,OAAO,EAAE,OAAO,CAAC,GAAG;YACpB,MAAM,EAAE,OAAO,CAAC,GAAG;YACnB,QAAQ,EAAE,OAAO,CAAC,GAAG;YACrB,QAAQ,EAAE,OAAO,CAAC,SAAS;SAC5B,CAAC,CACH,CAAC;QACF,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC;IACxB,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAEK,MAAM,sBAAsB,GAAG,CAAC,OAEtC,EAAmB,EAAE;IACpB,MAAM,UAAU,GAAG,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IAC7C,OAAO;QACL,YAAY,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,OAAO;QACpC,UAAU;QACV,WAAW,EAAE,UAAU,CAAC,MAAM,GAAG,CAAC;KACnC,CAAC;AACJ,CAAC,CAAC;AATW,QAAA,sBAAsB,0BASjC"}
@@ -0,0 +1,2 @@
1
+ export declare const generateTokenId: () => string;
2
+ //# sourceMappingURL=generate-token-id.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-token-id.d.ts","sourceRoot":"","sources":["../../../src/internal/utils/generate-token-id.ts"],"names":[],"mappings":"AA+BA,eAAO,MAAM,eAAe,QAAO,MAA2C,CAAC"}
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.generateTokenId = void 0;
4
+ const b64_1 = require("@lindorm/b64");
5
+ const crypto_1 = require("crypto");
6
+ const format_1 = require("../constants/format");
7
+ const generateTokenId = () => b64_1.B64.encode((0, crypto_1.randomBytes)(15), format_1.B64U);
8
+ exports.generateTokenId = generateTokenId;
9
+ //# sourceMappingURL=generate-token-id.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-token-id.js","sourceRoot":"","sources":["../../../src/internal/utils/generate-token-id.ts"],"names":[],"mappings":";;;AAAA,sCAAmC;AACnC,mCAAqC;AACrC,gDAA2C;AA6BpC,MAAM,eAAe,GAAG,GAAW,EAAE,CAAC,SAAG,CAAC,MAAM,CAAC,IAAA,oBAAW,EAAC,EAAE,CAAC,EAAE,aAAI,CAAC,CAAC;AAAlE,QAAA,eAAe,mBAAmD"}
@@ -1,4 +1,4 @@
1
- import { DecodedTokenHeader, TokenHeaderOptions } from "../../types";
2
- export declare const encodeJoseHeader: (options: TokenHeaderOptions) => string;
1
+ import { CertificateHeaderFields, DecodedTokenHeader, TokenHeaderOptions } from "../../types";
2
+ export declare const encodeJoseHeader: (options: TokenHeaderOptions, cert?: CertificateHeaderFields) => string;
3
3
  export declare const decodeJoseHeader: (header: string) => DecodedTokenHeader;
4
4
  //# sourceMappingURL=jose-header.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"jose-header.d.ts","sourceRoot":"","sources":["../../../src/internal/utils/jose-header.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,kBAAkB,EAAqB,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAGxF,eAAO,MAAM,gBAAgB,GAAI,SAAS,kBAAkB,KAAG,MAgC9D,CAAC;AAEF,eAAO,MAAM,gBAAgB,GAAI,QAAQ,MAAM,KAAG,kBAcjD,CAAC"}
1
+ {"version":3,"file":"jose-header.d.ts","sourceRoot":"","sources":["../../../src/internal/utils/jose-header.ts"],"names":[],"mappings":"AAGA,OAAO,EACL,uBAAuB,EACvB,kBAAkB,EAElB,kBAAkB,EACnB,MAAM,aAAa,CAAC;AAGrB,eAAO,MAAM,gBAAgB,GAC3B,SAAS,kBAAkB,EAC3B,OAAO,uBAAuB,KAC7B,MA6BF,CAAC;AAEF,eAAO,MAAM,gBAAgB,GAAI,QAAQ,MAAM,KAAG,kBAsBjD,CAAC"}
@@ -5,7 +5,7 @@ const b64_1 = require("@lindorm/b64");
5
5
  const format_1 = require("../constants/format");
6
6
  const header_1 = require("../constants/header");
7
7
  const token_header_1 = require("./token-header");
8
- const encodeJoseHeader = (options) => {
8
+ const encodeJoseHeader = (options, cert) => {
9
9
  if (!options.algorithm) {
10
10
  throw new Error("Algorithm is required");
11
11
  }
@@ -15,13 +15,10 @@ const encodeJoseHeader = (options) => {
15
15
  if (!options.headerType) {
16
16
  throw new Error("Header type is required");
17
17
  }
18
- if (!header_1.TOKEN_HEADER_TYPES.includes(options.headerType)) {
19
- throw new Error(`Invalid header type: ${options.headerType}`);
20
- }
21
18
  if (!options.keyId) {
22
19
  throw new Error("Key ID is required");
23
20
  }
24
- const raw = (0, token_header_1.mapTokenHeader)(options);
21
+ const raw = (0, token_header_1.mapTokenHeader)(options, cert);
25
22
  const claims = {
26
23
  ...raw,
27
24
  alg: options.algorithm,
@@ -38,6 +35,9 @@ const decodeJoseHeader = (header) => {
38
35
  if (!json.alg || typeof json.alg !== "string") {
39
36
  throw new Error("Missing or invalid token header: alg");
40
37
  }
38
+ if (!header_1.TOKEN_HEADER_ALGORITHMS.includes(json.alg)) {
39
+ throw new Error(`Unsupported algorithm: ${json.alg}`);
40
+ }
41
41
  if (json.typ !== undefined && typeof json.typ !== "string") {
42
42
  throw new Error("Invalid token header: typ must be a string");
43
43
  }
@@ -1 +1 @@
1
- {"version":3,"file":"jose-header.js","sourceRoot":"","sources":["../../../src/internal/utils/jose-header.ts"],"names":[],"mappings":";;;AAAA,sCAAmC;AACnC,gDAA2C;AAC3C,gDAAkF;AAElF,iDAAgD;AAEzC,MAAM,gBAAgB,GAAG,CAAC,OAA2B,EAAU,EAAE;IACtE,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;QACvB,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;IAC3C,CAAC;IACD,IAAI,CAAC,gCAAuB,CAAC,QAAQ,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;QACzD,MAAM,IAAI,KAAK,CAAC,sBAAsB,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC;IAC7D,CAAC;IACD,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC;QACxB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IACD,IAAI,CAAC,2BAAkB,CAAC,QAAQ,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC;QACrD,MAAM,IAAI,KAAK,CAAC,wBAAwB,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC;IAChE,CAAC;IACD,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACnB,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;IACxC,CAAC;IAED,MAAM,GAAG,GAAG,IAAA,6BAAc,EAAC,OAAO,CAAC,CAAC;IAMpC,MAAM,MAAM,GAAsB;QAChC,GAAG,GAAG;QACN,GAAG,EAAE,OAAO,CAAC,SAAS;QACtB,EAAE,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,SAAG,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,EAAE,aAAI,CAAC,CAAC,CAAC,CAAC,SAAS;QACjD,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,SAAG,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,aAAI,CAAC,CAAC,CAAC,CAAC,SAAS;QACpD,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,SAAG,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,aAAI,CAAC,CAAC,CAAC,CAAC,SAAS;KACrD,CAAC;IAEF,OAAO,SAAG,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,aAAI,CAAC,CAAC;AAClD,CAAC,CAAC;AAhCW,QAAA,gBAAgB,oBAgC3B;AAEK,MAAM,gBAAgB,GAAG,CAAC,MAAc,EAAsB,EAAE;IACrE,MAAM,MAAM,GAAG,SAAG,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IACpC,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAA+B,CAAC;IAE9D,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,OAAO,IAAI,CAAC,GAAG,KAAK,QAAQ,EAAE,CAAC;QAC9C,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;IAC1D,CAAC;IAED,IAAI,IAAI,CAAC,GAAG,KAAK,SAAS,IAAI,OAAO,IAAI,CAAC,GAAG,KAAK,QAAQ,EAAE,CAAC;QAC3D,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;IAChE,CAAC;IAGD,OAAO,IAA0B,CAAC;AACpC,CAAC,CAAC;AAdW,QAAA,gBAAgB,oBAc3B"}
1
+ {"version":3,"file":"jose-header.js","sourceRoot":"","sources":["../../../src/internal/utils/jose-header.ts"],"names":[],"mappings":";;;AAAA,sCAAmC;AACnC,gDAA2C;AAC3C,gDAA8D;AAO9D,iDAAgD;AAEzC,MAAM,gBAAgB,GAAG,CAC9B,OAA2B,EAC3B,IAA8B,EACtB,EAAE;IACV,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;QACvB,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;IAC3C,CAAC;IACD,IAAI,CAAC,gCAAuB,CAAC,QAAQ,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;QACzD,MAAM,IAAI,KAAK,CAAC,sBAAsB,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC;IAC7D,CAAC;IACD,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC;QACxB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IACD,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACnB,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;IACxC,CAAC;IAED,MAAM,GAAG,GAAG,IAAA,6BAAc,EAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IAM1C,MAAM,MAAM,GAAsB;QAChC,GAAG,GAAG;QACN,GAAG,EAAE,OAAO,CAAC,SAAS;QACtB,EAAE,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,SAAG,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,EAAE,aAAI,CAAC,CAAC,CAAC,CAAC,SAAS;QACjD,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,SAAG,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,aAAI,CAAC,CAAC,CAAC,CAAC,SAAS;QACpD,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,SAAG,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,aAAI,CAAC,CAAC,CAAC,CAAC,SAAS;KACrD,CAAC;IAEF,OAAO,SAAG,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,aAAI,CAAC,CAAC;AAClD,CAAC,CAAC;AAhCW,QAAA,gBAAgB,oBAgC3B;AAEK,MAAM,gBAAgB,GAAG,CAAC,MAAc,EAAsB,EAAE;IACrE,MAAM,MAAM,GAAG,SAAG,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IACpC,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAA+B,CAAC;IAE9D,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,OAAO,IAAI,CAAC,GAAG,KAAK,QAAQ,EAAE,CAAC;QAC9C,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;IAC1D,CAAC;IAMD,IAAI,CAAE,gCAAiD,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QAC3E,MAAM,IAAI,KAAK,CAAC,0BAA0B,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;IACxD,CAAC;IAED,IAAI,IAAI,CAAC,GAAG,KAAK,SAAS,IAAI,OAAO,IAAI,CAAC,GAAG,KAAK,QAAQ,EAAE,CAAC;QAC3D,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;IAChE,CAAC;IAGD,OAAO,IAA0B,CAAC;AACpC,CAAC,CAAC;AAtBW,QAAA,gBAAgB,oBAsB3B"}
@@ -1 +1 @@
1
- {"version":3,"file":"jwt-payload.d.ts","sourceRoot":"","sources":["../../../src/internal/utils/jwt-payload.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAKtC,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAG1F,KAAK,MAAM,GAAG;IACZ,SAAS,EAAE,gBAAgB,CAAC;IAC5B,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,KAAK,YAAY,CAAC,CAAC,SAAS,IAAI,GAAG,IAAI,IAAI,SAAS,GAAG,CAAC,CAAC;AAEzD,KAAK,MAAM,GAAG;IACZ,SAAS,EAAE,IAAI,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,eAAO,MAAM,qBAAqB,GAAI,CAAC,SAAS,IAAI,GAAG,IAAI,EACzD,QAAQ,MAAM,EACd,SAAS,cAAc,CAAC,CAAC,CAAC,EAC1B,SAAS,cAAc,KACtB,SAyEF,CAAC;AAEF,eAAO,MAAM,gBAAgB,GAAI,CAAC,SAAS,IAAI,GAAG,IAAI,EACpD,QAAQ,MAAM,EACd,SAAS,cAAc,CAAC,CAAC,CAAC,EAC1B,SAAS,cAAc,KACtB,MAUF,CAAC;AAEF,eAAO,MAAM,gBAAgB,GAAI,CAAC,SAAS,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,EAC3D,SAAS,MAAM,KACd,YAAY,CAAC,CAAC,CAAyD,CAAC;AAE3E,eAAO,MAAM,iBAAiB,GAAI,CAAC,SAAS,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,EAC5D,SAAS,YAAY,CAAC,CAAC,CAAC,KACvB,gBAAgB,CAAC,CAAC,CA4EpB,CAAC"}
1
+ {"version":3,"file":"jwt-payload.d.ts","sourceRoot":"","sources":["../../../src/internal/utils/jwt-payload.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAItC,OAAO,EAGL,SAAS,EACT,gBAAgB,EAChB,cAAc,EACd,cAAc,EACf,MAAM,aAAa,CAAC;AAMrB,KAAK,MAAM,GAAG;IACZ,SAAS,EAAE,gBAAgB,CAAC;IAC5B,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,KAAK,YAAY,CAAC,CAAC,SAAS,IAAI,GAAG,IAAI,IAAI,SAAS,GAAG,CAAC,CAAC;AAEzD,KAAK,MAAM,GAAG;IACZ,SAAS,EAAE,IAAI,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAWF,eAAO,MAAM,qBAAqB,GAAI,CAAC,SAAS,IAAI,GAAG,IAAI,EACzD,QAAQ,MAAM,EACd,SAAS,cAAc,CAAC,CAAC,CAAC,EAC1B,SAAS,cAAc,KACtB,SAoFF,CAAC;AAEF,eAAO,MAAM,gBAAgB,GAAI,CAAC,SAAS,IAAI,GAAG,IAAI,EACpD,QAAQ,MAAM,EACd,SAAS,cAAc,CAAC,CAAC,CAAC,EAC1B,SAAS,cAAc,KACtB,MAgBF,CAAC;AAEF,eAAO,MAAM,gBAAgB,GAAI,CAAC,SAAS,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,EAC3D,SAAS,MAAM,KACd,YAAY,CAAC,CAAC,CAAyD,CAAC;AAE3E,eAAO,MAAM,iBAAiB,GAAI,CAAC,SAAS,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,EAC5D,SAAS,YAAY,CAAC,CAAC,CAAC,KACvB,gBAAgB,CAAC,CAAC,CAoCpB,CAAC"}
@@ -2,13 +2,23 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.parseTokenPayload = exports.decodeJwtPayload = exports.encodeJwtPayload = exports.mapJwtContentToClaims = void 0;
4
4
  const b64_1 = require("@lindorm/b64");
5
+ const case_1 = require("@lindorm/case");
5
6
  const date_1 = require("@lindorm/date");
6
7
  const is_1 = require("@lindorm/is");
7
8
  const utils_1 = require("@lindorm/utils");
8
- const crypto_1 = require("crypto");
9
9
  const format_1 = require("../constants/format");
10
10
  const errors_1 = require("../../errors");
11
11
  const create_hash_1 = require("./create-hash");
12
+ const extract_aegis_profile_1 = require("./extract-aegis-profile");
13
+ const extract_claims_1 = require("./extract-claims");
14
+ const generate_token_id_1 = require("./generate-token-id");
15
+ const actClaimToWire = (claim) => (0, utils_1.removeUndefined)({
16
+ sub: claim.subject,
17
+ iss: claim.issuer,
18
+ aud: claim.audience,
19
+ client_id: claim.clientId,
20
+ act: (0, is_1.isObject)(claim.act) ? actClaimToWire(claim.act) : undefined,
21
+ });
12
22
  const mapJwtContentToClaims = (config, content, options) => {
13
23
  if (!(0, is_1.isString)(config.algorithm)) {
14
24
  throw new errors_1.JwtError("Algorithm is required");
@@ -22,9 +32,6 @@ const mapJwtContentToClaims = (config, content, options) => {
22
32
  if (!(0, is_1.isString)(content.subject)) {
23
33
  throw new errors_1.JwtError("Subject is required");
24
34
  }
25
- if (!(0, is_1.isString)(content.tokenType)) {
26
- throw new errors_1.JwtError("Token type is required");
27
- }
28
35
  const { expiresOn } = (0, date_1.expires)(content.expires);
29
36
  const at_hash = (0, is_1.isString)(options.accessTokenHash)
30
37
  ? options.accessTokenHash
@@ -41,20 +48,34 @@ const mapJwtContentToClaims = (config, content, options) => {
41
48
  : (0, is_1.isString)(content.authState)
42
49
  ? (0, create_hash_1.createStateHash)(config.algorithm, content.authState)
43
50
  : undefined;
44
- const tokenId = (0, is_1.isString)(options.tokenId) ? options.tokenId : (0, crypto_1.randomUUID)();
51
+ const tokenId = (0, is_1.isString)(options.tokenId) ? options.tokenId : (0, generate_token_id_1.generateTokenId)();
52
+ const cnf = (0, is_1.isObject)(content.confirmation)
53
+ ? (0, utils_1.removeUndefined)({
54
+ jkt: content.confirmation.thumbprint,
55
+ "x5t#S256": content.confirmation.mtlsCertThumbprint,
56
+ jwk: content.confirmation.key,
57
+ kid: content.confirmation.keyId,
58
+ jku: content.confirmation.jwkSetUri,
59
+ })
60
+ : undefined;
45
61
  return (0, utils_1.removeUndefined)({
46
62
  aal: (0, is_1.isFinite)(content.adjustedAccessLevel) ? content.adjustedAccessLevel : undefined,
47
63
  acr: (0, is_1.isString)(content.authContextClass) ? content.authContextClass : undefined,
48
- afr: (0, is_1.isString)(content.authFactor) ? content.authFactor : undefined,
64
+ act: (0, is_1.isObject)(content.act) ? actClaimToWire(content.act) : undefined,
65
+ afr: (0, is_1.isArray)(content.authFactor) ? content.authFactor : undefined,
49
66
  amr: (0, is_1.isArray)(content.authMethods) ? content.authMethods : undefined,
50
67
  at_hash,
51
68
  aud: (0, is_1.isArray)(content.audience) ? content.audience : undefined,
52
69
  auth_time: (0, is_1.isDate)(content.authTime) ? (0, date_1.getUnixTime)(content.authTime) : undefined,
53
70
  azp: (0, is_1.isString)(content.authorizedParty) ? content.authorizedParty : undefined,
54
71
  c_hash,
55
- cid: (0, is_1.isString)(content.clientId) ? content.clientId : undefined,
72
+ client_id: (0, is_1.isString)(content.clientId) ? content.clientId : undefined,
73
+ cnf: cnf && Object.keys(cnf).length > 0 ? cnf : undefined,
74
+ entitlements: (0, is_1.isArray)(content.entitlements) ? content.entitlements : undefined,
56
75
  exp: expiresOn,
76
+ groups: (0, is_1.isArray)(content.groups) ? content.groups : undefined,
57
77
  gty: (0, is_1.isString)(content.grantType) ? content.grantType : undefined,
78
+ may_act: (0, is_1.isObject)(content.mayAct) ? actClaimToWire(content.mayAct) : undefined,
58
79
  iat: (0, is_1.isDate)(options.issuedAt)
59
80
  ? (0, date_1.getUnixTime)(options.issuedAt)
60
81
  : (0, date_1.getUnixTime)(new Date()),
@@ -65,23 +86,23 @@ const mapJwtContentToClaims = (config, content, options) => {
65
86
  ? (0, date_1.getUnixTime)(content.notBefore)
66
87
  : (0, date_1.getUnixTime)(new Date()),
67
88
  nonce: (0, is_1.isString)(content.nonce) ? content.nonce : undefined,
68
- per: (0, is_1.isArray)(content.permissions) ? content.permissions : undefined,
69
- rls: (0, is_1.isArray)(content.roles) ? content.roles : undefined,
89
+ permissions: (0, is_1.isArray)(content.permissions) ? content.permissions : undefined,
90
+ roles: (0, is_1.isArray)(content.roles) ? content.roles : undefined,
70
91
  s_hash,
71
92
  scope: (0, is_1.isArray)(content.scope) ? content.scope : undefined,
72
93
  sid: (0, is_1.isString)(content.sessionId) ? content.sessionId : undefined,
73
94
  sih: (0, is_1.isString)(content.sessionHint) ? content.sessionHint : undefined,
74
95
  sub: content.subject,
75
96
  suh: (0, is_1.isString)(content.subjectHint) ? content.subjectHint : undefined,
76
- tid: (0, is_1.isString)(content.tenantId) ? content.tenantId : undefined,
77
- token_type: content.tokenType,
97
+ tenant_id: (0, is_1.isString)(content.tenantId) ? content.tenantId : undefined,
78
98
  });
79
99
  };
80
100
  exports.mapJwtContentToClaims = mapJwtContentToClaims;
81
101
  const encodeJwtPayload = (config, content, options) => {
82
102
  const claims = (0, exports.mapJwtContentToClaims)(config, content, options);
83
103
  const { expiresAt, expiresIn, expiresOn } = (0, date_1.expires)(content.expires);
84
- const payload = b64_1.B64.encode(JSON.stringify({ ...claims, ...(content.claims ?? {}) }), format_1.B64U);
104
+ const profileWire = (0, is_1.isObject)(content.profile) ? (0, case_1.snakeKeys)(content.profile) : {};
105
+ const payload = b64_1.B64.encode(JSON.stringify({ ...claims, ...profileWire, ...(content.claims ?? {}) }), format_1.B64U);
85
106
  return { expiresAt, expiresIn, expiresOn, payload, tokenId: claims.jti };
86
107
  };
87
108
  exports.encodeJwtPayload = encodeJwtPayload;
@@ -97,38 +118,24 @@ const parseTokenPayload = (decoded) => {
97
118
  if (!(0, is_1.isString)(decoded.iss)) {
98
119
  throw new errors_1.JwtError("Missing claim: iss");
99
120
  }
100
- const { aal, acr, afr, amr, at_hash, aud, auth_time, azp, c_hash, cid, exp, gty, iat, iss, jti, loa, nbf, nonce, per, rls, s_hash, scope, sid, sih, sub, suh, tid, token_type, ...rest } = decoded;
101
- const claims = ((0, is_1.isObject)(rest) ? rest : {});
121
+ const { claims: domain, rest } = (0, extract_claims_1.extractDomainClaims)(decoded);
122
+ const { profile, rest: customClaims } = (0, extract_aegis_profile_1.extractAegisProfile)(rest);
102
123
  return (0, utils_1.removeUndefined)({
103
- accessTokenHash: at_hash,
104
- adjustedAccessLevel: aal,
105
- audience: aud ?? [],
106
- authContextClass: acr,
107
- authFactor: afr,
108
- authMethods: amr ?? [],
109
- authorizedParty: azp,
110
- authTime: auth_time ? new Date(auth_time * 1000) : undefined,
111
- clientId: cid,
112
- codeHash: c_hash,
113
- expiresAt: exp ? new Date(exp * 1000) : undefined,
114
- grantType: gty,
115
- issuedAt: iat ? new Date(iat * 1000) : undefined,
116
- issuer: iss,
117
- levelOfAssurance: loa,
118
- nonce,
119
- notBefore: nbf ? new Date(nbf * 1000) : undefined,
120
- permissions: (0, is_1.isArray)(per) ? per : (0, is_1.isString)(per) ? [per] : [],
121
- roles: (0, is_1.isArray)(rls) ? rls : (0, is_1.isString)(rls) ? [rls] : [],
122
- scope: (0, is_1.isArray)(scope) ? scope : (0, is_1.isString)(scope) ? [scope] : [],
123
- sessionHint: sih,
124
- sessionId: sid,
125
- stateHash: s_hash,
126
- subject: sub ? sub : "unknown",
127
- subjectHint: suh,
128
- tenantId: tid,
129
- tokenId: jti ? jti : "unknown",
130
- tokenType: token_type ? token_type : "unknown",
131
- claims,
124
+ ...domain,
125
+ issuer: domain.issuer,
126
+ expiresAt: domain.expiresAt,
127
+ issuedAt: domain.issuedAt,
128
+ audience: domain.audience ?? [],
129
+ authMethods: domain.authMethods ?? [],
130
+ entitlements: domain.entitlements ?? [],
131
+ groups: domain.groups ?? [],
132
+ permissions: domain.permissions ?? [],
133
+ roles: domain.roles ?? [],
134
+ scope: domain.scope ?? [],
135
+ subject: domain.subject ?? "unknown",
136
+ tokenId: domain.tokenId ?? "unknown",
137
+ profile,
138
+ claims: customClaims,
132
139
  });
133
140
  };
134
141
  exports.parseTokenPayload = parseTokenPayload;
@@ -1 +1 @@
1
- {"version":3,"file":"jwt-payload.js","sourceRoot":"","sources":["../../../src/internal/utils/jwt-payload.ts"],"names":[],"mappings":";;;AAAA,sCAAmC;AACnC,wCAAqD;AACrD,oCAAuF;AAGvF,0CAAiD;AACjD,mCAAoC;AACpC,gDAA2C;AAC3C,yCAAwC;AAExC,+CAAuF;AAiBhF,MAAM,qBAAqB,GAAG,CACnC,MAAc,EACd,OAA0B,EAC1B,OAAuB,EACZ,EAAE;IACb,IAAI,CAAC,IAAA,aAAQ,EAAC,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC;QAChC,MAAM,IAAI,iBAAQ,CAAC,uBAAuB,CAAC,CAAC;IAC9C,CAAC;IACD,IAAI,CAAC,IAAA,cAAS,EAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC;QAC9B,MAAM,IAAI,iBAAQ,CAAC,oBAAoB,CAAC,CAAC;IAC3C,CAAC;IACD,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;QACrB,MAAM,IAAI,iBAAQ,CAAC,qBAAqB,CAAC,CAAC;IAC5C,CAAC;IACD,IAAI,CAAC,IAAA,aAAQ,EAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;QAC/B,MAAM,IAAI,iBAAQ,CAAC,qBAAqB,CAAC,CAAC;IAC5C,CAAC;IACD,IAAI,CAAC,IAAA,aAAQ,EAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;QACjC,MAAM,IAAI,iBAAQ,CAAC,wBAAwB,CAAC,CAAC;IAC/C,CAAC;IAED,MAAM,EAAE,SAAS,EAAE,GAAG,IAAA,cAAO,EAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IAE/C,MAAM,OAAO,GAAG,IAAA,aAAQ,EAAC,OAAO,CAAC,eAAe,CAAC;QAC/C,CAAC,CAAC,OAAO,CAAC,eAAe;QACzB,CAAC,CAAC,IAAA,aAAQ,EAAC,OAAO,CAAC,WAAW,CAAC;YAC7B,CAAC,CAAC,IAAA,mCAAqB,EAAC,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC,WAAW,CAAC;YAC9D,CAAC,CAAC,SAAS,CAAC;IAEhB,MAAM,MAAM,GAAG,IAAA,aAAQ,EAAC,OAAO,CAAC,QAAQ,CAAC;QACvC,CAAC,CAAC,OAAO,CAAC,QAAQ;QAClB,CAAC,CAAC,IAAA,aAAQ,EAAC,OAAO,CAAC,QAAQ,CAAC;YAC1B,CAAC,CAAC,IAAA,4BAAc,EAAC,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC,QAAQ,CAAC;YACpD,CAAC,CAAC,SAAS,CAAC;IAEhB,MAAM,MAAM,GAAG,IAAA,aAAQ,EAAC,OAAO,CAAC,SAAS,CAAC;QACxC,CAAC,CAAC,OAAO,CAAC,SAAS;QACnB,CAAC,CAAC,IAAA,aAAQ,EAAC,OAAO,CAAC,SAAS,CAAC;YAC3B,CAAC,CAAC,IAAA,6BAAe,EAAC,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC,SAAS,CAAC;YACtD,CAAC,CAAC,SAAS,CAAC;IAEhB,MAAM,OAAO,GAAG,IAAA,aAAQ,EAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,IAAA,mBAAU,GAAE,CAAC;IAE3E,OAAO,IAAA,uBAAe,EAAC;QACrB,GAAG,EAAE,IAAA,aAAQ,EAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC,CAAC,SAAS;QACpF,GAAG,EAAE,IAAA,aAAQ,EAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS;QAC9E,GAAG,EAAE,IAAA,aAAQ,EAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS;QAClE,GAAG,EAAE,IAAA,YAAO,EAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS;QACnE,OAAO;QACP,GAAG,EAAE,IAAA,YAAO,EAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;QAC7D,SAAS,EAAE,IAAA,WAAM,EAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAA,kBAAW,EAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS;QAC/E,GAAG,EAAE,IAAA,aAAQ,EAAC,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC,SAAS;QAC5E,MAAM;QACN,GAAG,EAAE,IAAA,aAAQ,EAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;QAC9D,GAAG,EAAE,SAAS;QACd,GAAG,EAAE,IAAA,aAAQ,EAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS;QAChE,GAAG,EAAE,IAAA,WAAM,EAAC,OAAO,CAAC,QAAQ,CAAC;YAC3B,CAAC,CAAC,IAAA,kBAAW,EAAC,OAAO,CAAC,QAAQ,CAAC;YAC/B,CAAC,CAAC,IAAA,kBAAW,EAAC,IAAI,IAAI,EAAE,CAAC;QAC3B,GAAG,EAAE,MAAM,CAAC,MAAM;QAClB,GAAG,EAAE,OAAO;QACZ,GAAG,EAAE,IAAA,aAAQ,EAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS;QAC9E,GAAG,EAAE,IAAA,WAAM,EAAC,OAAO,CAAC,SAAS,CAAC;YAC5B,CAAC,CAAC,IAAA,kBAAW,EAAC,OAAO,CAAC,SAAS,CAAC;YAChC,CAAC,CAAC,IAAA,kBAAW,EAAC,IAAI,IAAI,EAAE,CAAC;QAC3B,KAAK,EAAE,IAAA,aAAQ,EAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS;QAC1D,GAAG,EAAE,IAAA,YAAO,EAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS;QACnE,GAAG,EAAE,IAAA,YAAO,EAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS;QACvD,MAAM;QACN,KAAK,EAAE,IAAA,YAAO,EAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS;QACzD,GAAG,EAAE,IAAA,aAAQ,EAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS;QAChE,GAAG,EAAE,IAAA,aAAQ,EAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS;QACpE,GAAG,EAAE,OAAO,CAAC,OAAO;QACpB,GAAG,EAAE,IAAA,aAAQ,EAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS;QACpE,GAAG,EAAE,IAAA,aAAQ,EAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;QAC9D,UAAU,EAAE,OAAO,CAAC,SAAS;KAC9B,CAAC,CAAC;AACL,CAAC,CAAC;AA7EW,QAAA,qBAAqB,yBA6EhC;AAEK,MAAM,gBAAgB,GAAG,CAC9B,MAAc,EACd,OAA0B,EAC1B,OAAuB,EACf,EAAE;IACV,MAAM,MAAM,GAAG,IAAA,6BAAqB,EAAC,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;IAC/D,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,IAAA,cAAO,EAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IAErE,MAAM,OAAO,GAAG,SAAG,CAAC,MAAM,CACxB,IAAI,CAAC,SAAS,CAAC,EAAE,GAAG,MAAM,EAAE,GAAG,CAAC,OAAO,CAAC,MAAM,IAAI,EAAE,CAAC,EAAE,CAAC,EACxD,aAAI,CACL,CAAC;IAEF,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,CAAC,GAAI,EAAE,CAAC;AAC5E,CAAC,CAAC;AAdW,QAAA,gBAAgB,oBAc3B;AAEK,MAAM,gBAAgB,GAAG,CAC9B,OAAe,EACE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,SAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAoB,CAAC;AAF9D,QAAA,gBAAgB,oBAE8C;AAEpE,MAAM,iBAAiB,GAAG,CAC/B,OAAwB,EACH,EAAE;IACvB,IAAI,CAAC,IAAA,aAAQ,EAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;QAC3B,MAAM,IAAI,iBAAQ,CAAC,oBAAoB,CAAC,CAAC;IAC3C,CAAC;IACD,IAAI,CAAC,IAAA,aAAQ,EAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;QAC3B,MAAM,IAAI,iBAAQ,CAAC,oBAAoB,CAAC,CAAC;IAC3C,CAAC;IACD,IAAI,CAAC,IAAA,aAAQ,EAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;QAC3B,MAAM,IAAI,iBAAQ,CAAC,oBAAoB,CAAC,CAAC;IAC3C,CAAC;IAED,MAAM,EACJ,GAAG,EACH,GAAG,EACH,GAAG,EACH,GAAG,EACH,OAAO,EACP,GAAG,EACH,SAAS,EACT,GAAG,EACH,MAAM,EACN,GAAG,EACH,GAAG,EACH,GAAG,EACH,GAAG,EACH,GAAG,EACH,GAAG,EACH,GAAG,EACH,GAAG,EACH,KAAK,EACL,GAAG,EACH,GAAG,EACH,MAAM,EACN,KAAK,EACL,GAAG,EACH,GAAG,EACH,GAAG,EACH,GAAG,EACH,GAAG,EACH,UAAU,EACV,GAAG,IAAI,EACR,GAAG,OAAO,CAAC;IAEZ,MAAM,MAAM,GAAG,CAAC,IAAA,aAAQ,EAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAM,CAAC;IAEjD,OAAO,IAAA,uBAAe,EAAC;QACrB,eAAe,EAAE,OAAO;QACxB,mBAAmB,EAAE,GAAG;QACxB,QAAQ,EAAE,GAAG,IAAI,EAAE;QACnB,gBAAgB,EAAE,GAAG;QACrB,UAAU,EAAE,GAAG;QACf,WAAW,EAAE,GAAG,IAAI,EAAE;QACtB,eAAe,EAAE,GAAG;QACpB,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS;QAC5D,QAAQ,EAAE,GAAG;QACb,QAAQ,EAAE,MAAM;QAChB,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS;QACjD,SAAS,EAAE,GAAG;QACd,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS;QAChD,MAAM,EAAE,GAAG;QACX,gBAAgB,EAAE,GAAG;QACrB,KAAK;QACL,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS;QACjD,WAAW,EAAE,IAAA,YAAO,EAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAA,aAAQ,EAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;QAC5D,KAAK,EAAE,IAAA,YAAO,EAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAA,aAAQ,EAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;QACtD,KAAK,EAAE,IAAA,YAAO,EAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAA,aAAQ,EAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;QAC9D,WAAW,EAAE,GAAG;QAChB,SAAS,EAAE,GAAG;QACd,SAAS,EAAE,MAAM;QACjB,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS;QAC9B,WAAW,EAAE,GAAG;QAChB,QAAQ,EAAE,GAAG;QACb,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS;QAC9B,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS;QAC9C,MAAM;KACP,CAAC,CAAC;AACL,CAAC,CAAC;AA9EW,QAAA,iBAAiB,qBA8E5B"}
1
+ {"version":3,"file":"jwt-payload.js","sourceRoot":"","sources":["../../../src/internal/utils/jwt-payload.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"jwt-verify.d.ts","sourceRoot":"","sources":["../../../src/internal/utils/jwt-verify.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAE,IAAI,EAAE,SAAS,EAAqB,MAAM,gBAAgB,CAAC;AACpE,OAAO,EAAa,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAwD1D,eAAO,MAAM,eAAe,GAC1B,WAAW,gBAAgB,EAC3B,QAAQ,gBAAgB,EACxB,gBAAgB,MAAM,KACrB,SAAS,CAAC,IAAI,CAoDhB,CAAC"}
1
+ {"version":3,"file":"jwt-verify.d.ts","sourceRoot":"","sources":["../../../src/internal/utils/jwt-verify.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAE,IAAI,EAAE,SAAS,EAAqB,MAAM,gBAAgB,CAAC;AACpE,OAAO,EAAa,gBAAgB,EAAE,MAAM,aAAa,CAAC;AA0D1D,eAAO,MAAM,eAAe,GAC1B,WAAW,gBAAgB,EAC3B,QAAQ,gBAAgB,EACxB,gBAAgB,MAAM,KACrB,SAAS,CAAC,IAAI,CAkFhB,CAAC"}
@@ -27,9 +27,13 @@ const mapVerify = (key) => {
27
27
  case "authTime":
28
28
  return "auth_time";
29
29
  case "clientId":
30
- return "cid";
30
+ return "client_id";
31
+ case "entitlements":
32
+ return "entitlements";
31
33
  case "grantType":
32
34
  return "gty";
35
+ case "groups":
36
+ return "groups";
33
37
  case "issuer":
34
38
  return "iss";
35
39
  case "levelOfAssurance":
@@ -37,9 +41,9 @@ const mapVerify = (key) => {
37
41
  case "nonce":
38
42
  return "nonce";
39
43
  case "permissions":
40
- return "per";
44
+ return "permissions";
41
45
  case "roles":
42
- return "rls";
46
+ return "roles";
43
47
  case "scope":
44
48
  return "scope";
45
49
  case "sessionHint":
@@ -49,9 +53,7 @@ const mapVerify = (key) => {
49
53
  case "subjectHint":
50
54
  return "suh";
51
55
  case "tenantId":
52
- return "tid";
53
- case "tokenType":
54
- return "token_type";
56
+ return "tenant_id";
55
57
  default:
56
58
  throw new Error(`Unsupported key: ${key} for JWT verification`);
57
59
  }
@@ -71,7 +73,25 @@ const createJwtVerify = (algorithm, verify, clockTolerance) => {
71
73
  $or: [{ $exists: false }, { $lte: (0, date_1.addSeconds)(new Date(), clockTolerance) }],
72
74
  },
73
75
  };
76
+ const ARRAY_CLAIM_KEYS = new Set([
77
+ "aud",
78
+ "amr",
79
+ "afr",
80
+ "scope",
81
+ "roles",
82
+ "permissions",
83
+ "groups",
84
+ "entitlements",
85
+ ]);
74
86
  for (const [key, value] of Object.entries(verify)) {
87
+ if (key === "tokenType")
88
+ continue;
89
+ if (key === "actor")
90
+ continue;
91
+ if (key === "dpopProof")
92
+ continue;
93
+ if (key === "trustBoundThumbprint")
94
+ continue;
75
95
  const mapped = mapVerify(key);
76
96
  if (mapped === "at_hash" && (0, is_1.isString)(value)) {
77
97
  predicate[mapped] = { $eq: (0, create_hash_1.createAccessTokenHash)(algorithm, value) };
@@ -94,6 +114,10 @@ const createJwtVerify = (algorithm, verify, clockTolerance) => {
94
114
  continue;
95
115
  }
96
116
  if ((0, is_1.isString)(value)) {
117
+ if (ARRAY_CLAIM_KEYS.has(mapped)) {
118
+ predicate[mapped] = { $all: [value] };
119
+ continue;
120
+ }
97
121
  predicate[mapped] = { $eq: value };
98
122
  continue;
99
123
  }