@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.
- package/CHANGELOG.md +35 -0
- package/__tests__/jwt-interop.test.ts +13 -10
- package/dist/classes/Aegis.d.ts +13 -20
- package/dist/classes/Aegis.d.ts.map +1 -1
- package/dist/classes/Aegis.js +33 -119
- package/dist/classes/Aegis.js.map +1 -1
- package/dist/classes/JweKit.d.ts +1 -0
- package/dist/classes/JweKit.d.ts.map +1 -1
- package/dist/classes/JweKit.js +59 -12
- package/dist/classes/JweKit.js.map +1 -1
- package/dist/classes/JwsKit.d.ts +1 -0
- package/dist/classes/JwsKit.d.ts.map +1 -1
- package/dist/classes/JwsKit.js +54 -14
- package/dist/classes/JwsKit.js.map +1 -1
- package/dist/classes/JwtKit.d.ts +2 -0
- package/dist/classes/JwtKit.d.ts.map +1 -1
- package/dist/classes/JwtKit.js +90 -17
- package/dist/classes/JwtKit.js.map +1 -1
- package/dist/classes/SignatureKit.d.ts.map +1 -1
- package/dist/classes/SignatureKit.js +3 -0
- package/dist/classes/SignatureKit.js.map +1 -1
- package/dist/classes/index.d.ts +0 -3
- package/dist/classes/index.d.ts.map +1 -1
- package/dist/classes/index.js +0 -3
- package/dist/classes/index.js.map +1 -1
- package/dist/constants/token-type.d.ts +6 -0
- package/dist/constants/token-type.d.ts.map +1 -0
- package/dist/constants/token-type.js +20 -0
- package/dist/constants/token-type.js.map +1 -0
- package/dist/errors/index.d.ts +0 -3
- package/dist/errors/index.d.ts.map +1 -1
- package/dist/errors/index.js +0 -3
- package/dist/errors/index.js.map +1 -1
- package/dist/guards/index.d.ts +3 -0
- package/dist/guards/index.d.ts.map +1 -0
- package/dist/{types/cws → guards}/index.js +2 -4
- package/dist/guards/index.js.map +1 -0
- package/dist/guards/is-parsed-jws.d.ts +3 -0
- package/dist/guards/is-parsed-jws.d.ts.map +1 -0
- package/dist/guards/is-parsed-jws.js +6 -0
- package/dist/guards/is-parsed-jws.js.map +1 -0
- package/dist/guards/is-parsed-jwt.d.ts +3 -0
- package/dist/guards/is-parsed-jwt.d.ts.map +1 -0
- package/dist/guards/is-parsed-jwt.js +6 -0
- package/dist/guards/is-parsed-jwt.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/interfaces/Aegis.d.ts +8 -22
- package/dist/interfaces/Aegis.d.ts.map +1 -1
- package/dist/interfaces/index.d.ts +0 -3
- package/dist/interfaces/index.d.ts.map +1 -1
- package/dist/interfaces/index.js +0 -3
- package/dist/interfaces/index.js.map +1 -1
- package/dist/internal/constants/aegis-profile-keys.d.ts +2 -0
- package/dist/internal/constants/aegis-profile-keys.d.ts.map +1 -0
- package/dist/internal/constants/aegis-profile-keys.js +37 -0
- package/dist/internal/constants/aegis-profile-keys.js.map +1 -0
- package/dist/internal/constants/header.d.ts +2 -2
- package/dist/internal/constants/header.d.ts.map +1 -1
- package/dist/internal/constants/header.js +1 -4
- package/dist/internal/constants/header.js.map +1 -1
- package/dist/internal/utils/compute-jwk-thumbprint.d.ts +4 -0
- package/dist/internal/utils/compute-jwk-thumbprint.d.ts.map +1 -0
- package/dist/internal/utils/compute-jwk-thumbprint.js +25 -0
- package/dist/internal/utils/compute-jwk-thumbprint.js.map +1 -0
- package/dist/internal/utils/compute-typ-header.d.ts +7 -0
- package/dist/internal/utils/compute-typ-header.d.ts.map +1 -0
- package/dist/internal/utils/compute-typ-header.js +68 -0
- package/dist/internal/utils/compute-typ-header.js.map +1 -0
- package/dist/internal/utils/extract-aegis-profile.d.ts +7 -0
- package/dist/internal/utils/extract-aegis-profile.d.ts.map +1 -0
- package/dist/internal/utils/extract-aegis-profile.js +34 -0
- package/dist/internal/utils/extract-aegis-profile.js.map +1 -0
- package/dist/internal/utils/extract-claims.d.ts +15 -0
- package/dist/internal/utils/extract-claims.d.ts.map +1 -0
- package/dist/internal/utils/extract-claims.js +201 -0
- package/dist/internal/utils/extract-claims.js.map +1 -0
- package/dist/internal/utils/extract-token-delegation.d.ts +6 -0
- package/dist/internal/utils/extract-token-delegation.d.ts.map +1 -0
- package/dist/internal/utils/extract-token-delegation.js +28 -0
- package/dist/internal/utils/extract-token-delegation.js.map +1 -0
- package/dist/internal/utils/generate-token-id.d.ts +2 -0
- package/dist/internal/utils/generate-token-id.d.ts.map +1 -0
- package/dist/internal/utils/generate-token-id.js +9 -0
- package/dist/internal/utils/generate-token-id.js.map +1 -0
- package/dist/internal/utils/jose-header.d.ts +2 -2
- package/dist/internal/utils/jose-header.d.ts.map +1 -1
- package/dist/internal/utils/jose-header.js +5 -5
- package/dist/internal/utils/jose-header.js.map +1 -1
- package/dist/internal/utils/jwt-payload.d.ts.map +1 -1
- package/dist/internal/utils/jwt-payload.js +50 -43
- package/dist/internal/utils/jwt-payload.js.map +1 -1
- package/dist/internal/utils/jwt-verify.d.ts.map +1 -1
- package/dist/internal/utils/jwt-verify.js +30 -6
- package/dist/internal/utils/jwt-verify.js.map +1 -1
- package/dist/internal/utils/parse-introspection.d.ts +7 -0
- package/dist/internal/utils/parse-introspection.d.ts.map +1 -0
- package/dist/internal/utils/parse-introspection.js +28 -0
- package/dist/internal/utils/parse-introspection.js.map +1 -0
- package/dist/internal/utils/parse-userinfo.d.ts +5 -0
- package/dist/internal/utils/parse-userinfo.d.ts.map +1 -0
- package/dist/internal/utils/parse-userinfo.js +26 -0
- package/dist/internal/utils/parse-userinfo.js.map +1 -0
- package/dist/internal/utils/resolve-cert-binding.d.ts +4 -0
- package/dist/internal/utils/resolve-cert-binding.d.ts.map +1 -0
- package/dist/internal/utils/resolve-cert-binding.js +30 -0
- package/dist/internal/utils/resolve-cert-binding.js.map +1 -0
- package/dist/internal/utils/token-header.d.ts +2 -2
- package/dist/internal/utils/token-header.d.ts.map +1 -1
- package/dist/internal/utils/token-header.js +5 -16
- package/dist/internal/utils/token-header.js.map +1 -1
- package/dist/internal/utils/validate-actor.d.ts +3 -0
- package/dist/internal/utils/validate-actor.d.ts.map +1 -0
- package/dist/internal/utils/validate-actor.js +27 -0
- package/dist/internal/utils/validate-actor.js.map +1 -0
- package/dist/internal/utils/validate-crit.d.ts +4 -0
- package/dist/internal/utils/validate-crit.d.ts.map +1 -0
- package/dist/internal/utils/validate-crit.js +55 -0
- package/dist/internal/utils/validate-crit.js.map +1 -0
- package/dist/internal/utils/verify-cert-binding.d.ts +14 -0
- package/dist/internal/utils/verify-cert-binding.d.ts.map +1 -0
- package/dist/internal/utils/verify-cert-binding.js +25 -0
- package/dist/internal/utils/verify-cert-binding.js.map +1 -0
- package/dist/internal/utils/verify-dpop-proof.d.ts +10 -0
- package/dist/internal/utils/verify-dpop-proof.d.ts.map +1 -0
- package/dist/internal/utils/verify-dpop-proof.js +76 -0
- package/dist/internal/utils/verify-dpop-proof.js.map +1 -0
- package/dist/mocks/create-mock-aegis.d.ts +2 -1
- package/dist/mocks/create-mock-aegis.d.ts.map +1 -1
- package/dist/mocks/create-mock-aegis.js +49 -75
- package/dist/mocks/create-mock-aegis.js.map +1 -1
- package/dist/mocks/index.d.ts +1 -1
- package/dist/mocks/index.d.ts.map +1 -1
- package/dist/mocks/index.js +3 -15
- package/dist/mocks/index.js.map +1 -1
- package/dist/types/aegis.d.ts +3 -0
- package/dist/types/aegis.d.ts.map +1 -1
- package/dist/types/claims/act-claim.d.ts +8 -0
- package/dist/types/claims/act-claim.d.ts.map +1 -0
- package/dist/{interfaces/CwtKit.js → types/claims/act-claim.js} +1 -1
- package/dist/types/claims/act-claim.js.map +1 -0
- package/dist/types/claims/aegis-introspection.d.ts +16 -0
- package/dist/types/claims/aegis-introspection.d.ts.map +1 -0
- package/dist/types/claims/aegis-introspection.js +3 -0
- package/dist/types/claims/aegis-introspection.js.map +1 -0
- package/dist/types/claims/aegis-profile.d.ts +44 -0
- package/dist/types/claims/aegis-profile.d.ts.map +1 -0
- package/dist/types/claims/aegis-profile.js +3 -0
- package/dist/types/claims/aegis-profile.js.map +1 -0
- package/dist/types/claims/aegis-userinfo.d.ts +5 -0
- package/dist/types/claims/aegis-userinfo.d.ts.map +1 -0
- package/dist/types/claims/aegis-userinfo.js +3 -0
- package/dist/types/claims/aegis-userinfo.js.map +1 -0
- package/dist/types/claims/confirmation-claim.d.ts +9 -0
- package/dist/types/claims/confirmation-claim.d.ts.map +1 -0
- package/dist/types/claims/confirmation-claim.js +3 -0
- package/dist/types/claims/confirmation-claim.js.map +1 -0
- package/dist/types/claims/delegation-claims.d.ts +6 -0
- package/dist/types/claims/delegation-claims.d.ts.map +1 -0
- package/dist/types/claims/delegation-claims.js +3 -0
- package/dist/types/claims/delegation-claims.js.map +1 -0
- package/dist/types/claims/index.d.ts +13 -0
- package/dist/types/claims/index.d.ts.map +1 -0
- package/dist/types/{cwt → claims}/index.js +12 -7
- package/dist/types/claims/index.js.map +1 -0
- package/dist/types/claims/jwt/act-claim-wire.d.ts +8 -0
- package/dist/types/claims/jwt/act-claim-wire.d.ts.map +1 -0
- package/dist/types/claims/jwt/act-claim-wire.js +3 -0
- package/dist/types/claims/jwt/act-claim-wire.js.map +1 -0
- package/dist/types/claims/jwt/confirmation-claim-wire.d.ts +9 -0
- package/dist/types/claims/jwt/confirmation-claim-wire.d.ts.map +1 -0
- package/dist/types/claims/jwt/confirmation-claim-wire.js +3 -0
- package/dist/types/claims/jwt/confirmation-claim-wire.js.map +1 -0
- package/dist/types/claims/jwt/delegation-claims-wire.d.ts +6 -0
- package/dist/types/claims/jwt/delegation-claims-wire.d.ts.map +1 -0
- package/dist/types/claims/jwt/delegation-claims-wire.js +3 -0
- package/dist/types/claims/jwt/delegation-claims-wire.js.map +1 -0
- package/dist/types/claims/jwt/index.d.ts +10 -0
- package/dist/types/claims/jwt/index.d.ts.map +1 -0
- package/dist/types/{cwe → claims/jwt}/index.js +9 -4
- package/dist/types/claims/jwt/index.js.map +1 -0
- package/dist/types/claims/jwt/jwt-claims.d.ts +8 -0
- package/dist/types/claims/jwt/jwt-claims.d.ts.map +1 -0
- package/dist/types/claims/jwt/jwt-claims.js.map +1 -0
- package/dist/types/claims/jwt/lindorm-claims-wire.d.ts +16 -0
- package/dist/types/claims/jwt/lindorm-claims-wire.d.ts.map +1 -0
- package/dist/types/claims/jwt/lindorm-claims-wire.js +3 -0
- package/dist/types/claims/jwt/lindorm-claims-wire.js.map +1 -0
- package/dist/types/claims/jwt/oauth-claims-wire.d.ts +6 -0
- package/dist/types/claims/jwt/oauth-claims-wire.d.ts.map +1 -0
- package/dist/types/claims/jwt/oauth-claims-wire.js +3 -0
- package/dist/types/claims/jwt/oauth-claims-wire.js.map +1 -0
- package/dist/types/claims/jwt/oidc-claims-wire.d.ts +11 -0
- package/dist/types/claims/jwt/oidc-claims-wire.d.ts.map +1 -0
- package/dist/types/claims/jwt/oidc-claims-wire.js +3 -0
- package/dist/types/claims/jwt/oidc-claims-wire.js.map +1 -0
- package/dist/types/claims/jwt/pop-claims-wire.d.ts +5 -0
- package/dist/types/claims/jwt/pop-claims-wire.d.ts.map +1 -0
- package/dist/types/claims/jwt/pop-claims-wire.js +3 -0
- package/dist/types/claims/jwt/pop-claims-wire.js.map +1 -0
- package/dist/types/claims/jwt/std-claims-wire.d.ts +10 -0
- package/dist/types/claims/jwt/std-claims-wire.d.ts.map +1 -0
- package/dist/types/claims/jwt/std-claims-wire.js +3 -0
- package/dist/types/claims/jwt/std-claims-wire.js.map +1 -0
- package/dist/types/claims/lindorm-claims.d.ts +18 -0
- package/dist/types/claims/lindorm-claims.d.ts.map +1 -0
- package/dist/types/claims/lindorm-claims.js +3 -0
- package/dist/types/claims/lindorm-claims.js.map +1 -0
- package/dist/types/claims/oauth-claims.d.ts +6 -0
- package/dist/types/claims/oauth-claims.d.ts.map +1 -0
- package/dist/types/claims/oauth-claims.js +3 -0
- package/dist/types/claims/oauth-claims.js.map +1 -0
- package/dist/types/claims/oidc-claims.d.ts +11 -0
- package/dist/types/claims/oidc-claims.d.ts.map +1 -0
- package/dist/types/{cose-target.js → claims/oidc-claims.js} +1 -1
- package/dist/types/claims/oidc-claims.js.map +1 -0
- package/dist/types/claims/pop-claims.d.ts +5 -0
- package/dist/types/claims/pop-claims.d.ts.map +1 -0
- package/dist/types/{cwe/cwe-decode.js → claims/pop-claims.js} +1 -1
- package/dist/types/claims/pop-claims.js.map +1 -0
- package/dist/types/claims/std-claims.d.ts +10 -0
- package/dist/types/claims/std-claims.d.ts.map +1 -0
- package/dist/types/claims/std-claims.js +3 -0
- package/dist/types/claims/std-claims.js.map +1 -0
- package/dist/types/header.d.ts +15 -8
- package/dist/types/header.d.ts.map +1 -1
- package/dist/types/index.d.ts +2 -4
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +2 -4
- package/dist/types/index.js.map +1 -1
- package/dist/types/jwe/jwe-decrypt.d.ts +2 -4
- package/dist/types/jwe/jwe-decrypt.d.ts.map +1 -1
- package/dist/types/jwe/jwe-encrypt.d.ts +4 -1
- package/dist/types/jwe/jwe-encrypt.d.ts.map +1 -1
- package/dist/types/jwe/jwe-kit.d.ts +2 -7
- package/dist/types/jwe/jwe-kit.d.ts.map +1 -1
- package/dist/types/jws/jws-kit.d.ts +2 -6
- package/dist/types/jws/jws-kit.d.ts.map +1 -1
- package/dist/types/jws/jws-parse.d.ts +2 -5
- package/dist/types/jws/jws-parse.d.ts.map +1 -1
- package/dist/types/jws/jws-sign.d.ts +5 -2
- package/dist/types/jws/jws-sign.d.ts.map +1 -1
- package/dist/types/jwt/index.d.ts +3 -1
- package/dist/types/jwt/index.d.ts.map +1 -1
- package/dist/types/jwt/index.js +3 -1
- package/dist/types/jwt/index.js.map +1 -1
- package/dist/types/jwt/jwt-claim-matchers.d.ts +28 -0
- package/dist/types/jwt/jwt-claim-matchers.d.ts.map +1 -0
- package/dist/types/jwt/jwt-claim-matchers.js +3 -0
- package/dist/types/jwt/jwt-claim-matchers.js.map +1 -0
- package/dist/types/jwt/jwt-decode.d.ts +1 -1
- package/dist/types/jwt/jwt-decode.d.ts.map +1 -1
- package/dist/types/jwt/jwt-delegation.d.ts +7 -0
- package/dist/types/jwt/jwt-delegation.d.ts.map +1 -0
- package/dist/types/jwt/jwt-delegation.js +3 -0
- package/dist/types/jwt/jwt-delegation.js.map +1 -0
- package/dist/types/jwt/jwt-dpop.d.ts +10 -0
- package/dist/types/jwt/jwt-dpop.d.ts.map +1 -0
- package/dist/{interfaces/CwsKit.js → types/jwt/jwt-dpop.js} +1 -1
- package/dist/types/jwt/jwt-dpop.js.map +1 -0
- package/dist/types/jwt/jwt-kit.d.ts +3 -5
- package/dist/types/jwt/jwt-kit.d.ts.map +1 -1
- package/dist/types/jwt/jwt-parse.d.ts +11 -27
- package/dist/types/jwt/jwt-parse.d.ts.map +1 -1
- package/dist/types/jwt/jwt-sign.d.ts +6 -23
- package/dist/types/jwt/jwt-sign.d.ts.map +1 -1
- package/dist/types/jwt/jwt-validate.d.ts +2 -23
- package/dist/types/jwt/jwt-validate.d.ts.map +1 -1
- package/dist/types/jwt/jwt-verify.d.ts +13 -25
- package/dist/types/jwt/jwt-verify.d.ts.map +1 -1
- package/dist/types/kit.d.ts +12 -0
- package/dist/types/kit.d.ts.map +1 -0
- package/dist/{interfaces/CweKit.js → types/kit.js} +1 -1
- package/dist/types/kit.js.map +1 -0
- package/dist/types/level-of-assurance.d.ts +1 -1
- package/dist/types/level-of-assurance.d.ts.map +1 -1
- package/package.json +20 -21
- package/tsconfig.interop.json +1 -5
- package/__tests__/cose-interop.test.ts +0 -1127
- package/dist/classes/CweKit.d.ts +0 -14
- package/dist/classes/CweKit.d.ts.map +0 -1
- package/dist/classes/CweKit.js +0 -151
- package/dist/classes/CweKit.js.map +0 -1
- package/dist/classes/CwsKit.d.ts +0 -13
- package/dist/classes/CwsKit.d.ts.map +0 -1
- package/dist/classes/CwsKit.js +0 -139
- package/dist/classes/CwsKit.js.map +0 -1
- package/dist/classes/CwtKit.d.ts +0 -17
- package/dist/classes/CwtKit.d.ts.map +0 -1
- package/dist/classes/CwtKit.js +0 -166
- package/dist/classes/CwtKit.js.map +0 -1
- package/dist/errors/CoseEncryptError.d.ts +0 -4
- package/dist/errors/CoseEncryptError.d.ts.map +0 -1
- package/dist/errors/CoseEncryptError.js +0 -8
- package/dist/errors/CoseEncryptError.js.map +0 -1
- package/dist/errors/CoseSignError.d.ts +0 -4
- package/dist/errors/CoseSignError.d.ts.map +0 -1
- package/dist/errors/CoseSignError.js +0 -8
- package/dist/errors/CoseSignError.js.map +0 -1
- package/dist/errors/CwtError.d.ts +0 -4
- package/dist/errors/CwtError.d.ts.map +0 -1
- package/dist/errors/CwtError.js +0 -8
- package/dist/errors/CwtError.js.map +0 -1
- package/dist/interfaces/CweKit.d.ts +0 -6
- package/dist/interfaces/CweKit.d.ts.map +0 -1
- package/dist/interfaces/CweKit.js.map +0 -1
- package/dist/interfaces/CwsKit.d.ts +0 -6
- package/dist/interfaces/CwsKit.d.ts.map +0 -1
- package/dist/interfaces/CwsKit.js.map +0 -1
- package/dist/interfaces/CwtKit.d.ts +0 -7
- package/dist/interfaces/CwtKit.d.ts.map +0 -1
- package/dist/interfaces/CwtKit.js.map +0 -1
- package/dist/internal/constants/cose.d.ts +0 -19
- package/dist/internal/constants/cose.d.ts.map +0 -1
- package/dist/internal/constants/cose.js +0 -116
- package/dist/internal/constants/cose.js.map +0 -1
- package/dist/internal/utils/auth-tag-length.d.ts +0 -3
- package/dist/internal/utils/auth-tag-length.d.ts.map +0 -1
- package/dist/internal/utils/auth-tag-length.js +0 -21
- package/dist/internal/utils/auth-tag-length.js.map +0 -1
- package/dist/internal/utils/cose/bstr.d.ts +0 -4
- package/dist/internal/utils/cose/bstr.d.ts.map +0 -1
- package/dist/internal/utils/cose/bstr.js +0 -18
- package/dist/internal/utils/cose/bstr.js.map +0 -1
- package/dist/internal/utils/cose/claims.d.ts +0 -5
- package/dist/internal/utils/cose/claims.d.ts.map +0 -1
- package/dist/internal/utils/cose/claims.js +0 -57
- package/dist/internal/utils/cose/claims.js.map +0 -1
- package/dist/internal/utils/cose/crit.d.ts +0 -3
- package/dist/internal/utils/cose/crit.d.ts.map +0 -1
- package/dist/internal/utils/cose/crit.js +0 -43
- package/dist/internal/utils/cose/crit.js.map +0 -1
- package/dist/internal/utils/cose/find.d.ts +0 -5
- package/dist/internal/utils/cose/find.d.ts.map +0 -1
- package/dist/internal/utils/cose/find.js +0 -37
- package/dist/internal/utils/cose/find.js.map +0 -1
- package/dist/internal/utils/cose/header.d.ts +0 -5
- package/dist/internal/utils/cose/header.d.ts.map +0 -1
- package/dist/internal/utils/cose/header.js +0 -81
- package/dist/internal/utils/cose/header.js.map +0 -1
- package/dist/internal/utils/cose/key.d.ts +0 -4
- package/dist/internal/utils/cose/key.d.ts.map +0 -1
- package/dist/internal/utils/cose/key.js +0 -86
- package/dist/internal/utils/cose/key.js.map +0 -1
- package/dist/internal/utils/cose-sign-token.d.ts +0 -9
- package/dist/internal/utils/cose-sign-token.d.ts.map +0 -1
- package/dist/internal/utils/cose-sign-token.js +0 -12
- package/dist/internal/utils/cose-sign-token.js.map +0 -1
- package/dist/internal/utils/cose-signature.d.ts +0 -16
- package/dist/internal/utils/cose-signature.d.ts.map +0 -1
- package/dist/internal/utils/cose-signature.js +0 -17
- package/dist/internal/utils/cose-signature.js.map +0 -1
- package/dist/types/cose-target.d.ts +0 -2
- package/dist/types/cose-target.d.ts.map +0 -1
- package/dist/types/cose-target.js.map +0 -1
- package/dist/types/cwe/cwe-decode.d.ts +0 -18
- package/dist/types/cwe/cwe-decode.d.ts.map +0 -1
- package/dist/types/cwe/cwe-decode.js.map +0 -1
- package/dist/types/cwe/cwe-decrypt.d.ts +0 -15
- package/dist/types/cwe/cwe-decrypt.d.ts.map +0 -1
- package/dist/types/cwe/cwe-decrypt.js +0 -3
- package/dist/types/cwe/cwe-decrypt.js.map +0 -1
- package/dist/types/cwe/cwe-encrypt.d.ts +0 -12
- package/dist/types/cwe/cwe-encrypt.d.ts.map +0 -1
- package/dist/types/cwe/cwe-encrypt.js +0 -3
- package/dist/types/cwe/cwe-encrypt.js.map +0 -1
- package/dist/types/cwe/cwe-kit.d.ts +0 -9
- package/dist/types/cwe/cwe-kit.d.ts.map +0 -1
- package/dist/types/cwe/cwe-kit.js +0 -3
- package/dist/types/cwe/cwe-kit.js.map +0 -1
- package/dist/types/cwe/index.d.ts +0 -5
- package/dist/types/cwe/index.d.ts.map +0 -1
- package/dist/types/cwe/index.js.map +0 -1
- package/dist/types/cws/cws-decode.d.ts +0 -9
- package/dist/types/cws/cws-decode.d.ts.map +0 -1
- package/dist/types/cws/cws-decode.js +0 -3
- package/dist/types/cws/cws-decode.js.map +0 -1
- package/dist/types/cws/cws-kit.d.ts +0 -8
- package/dist/types/cws/cws-kit.d.ts.map +0 -1
- package/dist/types/cws/cws-kit.js +0 -3
- package/dist/types/cws/cws-kit.js.map +0 -1
- package/dist/types/cws/cws-parse.d.ts +0 -14
- package/dist/types/cws/cws-parse.d.ts.map +0 -1
- package/dist/types/cws/cws-parse.js +0 -3
- package/dist/types/cws/cws-parse.js.map +0 -1
- package/dist/types/cws/cws-sign.d.ts +0 -14
- package/dist/types/cws/cws-sign.d.ts.map +0 -1
- package/dist/types/cws/cws-sign.js +0 -3
- package/dist/types/cws/cws-sign.js.map +0 -1
- package/dist/types/cws/index.d.ts +0 -5
- package/dist/types/cws/index.d.ts.map +0 -1
- package/dist/types/cws/index.js.map +0 -1
- package/dist/types/cwt/cwt-claims.d.ts +0 -3
- package/dist/types/cwt/cwt-claims.d.ts.map +0 -1
- package/dist/types/cwt/cwt-claims.js +0 -3
- package/dist/types/cwt/cwt-claims.js.map +0 -1
- package/dist/types/cwt/cwt-decode.d.ts +0 -10
- package/dist/types/cwt/cwt-decode.d.ts.map +0 -1
- package/dist/types/cwt/cwt-decode.js +0 -3
- package/dist/types/cwt/cwt-decode.js.map +0 -1
- package/dist/types/cwt/cwt-kit.d.ts +0 -3
- package/dist/types/cwt/cwt-kit.d.ts.map +0 -1
- package/dist/types/cwt/cwt-kit.js +0 -3
- package/dist/types/cwt/cwt-kit.js.map +0 -1
- package/dist/types/cwt/cwt-parse.d.ts +0 -15
- package/dist/types/cwt/cwt-parse.d.ts.map +0 -1
- package/dist/types/cwt/cwt-parse.js +0 -3
- package/dist/types/cwt/cwt-parse.js.map +0 -1
- package/dist/types/cwt/cwt-sign.d.ts +0 -17
- package/dist/types/cwt/cwt-sign.d.ts.map +0 -1
- package/dist/types/cwt/cwt-sign.js +0 -3
- package/dist/types/cwt/cwt-sign.js.map +0 -1
- package/dist/types/cwt/cwt-validate.d.ts +0 -3
- package/dist/types/cwt/cwt-validate.d.ts.map +0 -1
- package/dist/types/cwt/cwt-validate.js +0 -3
- package/dist/types/cwt/cwt-validate.js.map +0 -1
- package/dist/types/cwt/cwt-verify.d.ts +0 -3
- package/dist/types/cwt/cwt-verify.d.ts.map +0 -1
- package/dist/types/cwt/cwt-verify.js +0 -3
- package/dist/types/cwt/cwt-verify.js.map +0 -1
- package/dist/types/cwt/index.d.ts +0 -8
- package/dist/types/cwt/index.d.ts.map +0 -1
- package/dist/types/cwt/index.js.map +0 -1
- package/dist/types/jwt/jwt-claims.d.ts +0 -38
- package/dist/types/jwt/jwt-claims.d.ts.map +0 -1
- package/dist/types/jwt/jwt-claims.js.map +0 -1
- /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 @@
|
|
|
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,
|
|
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,
|
|
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":"
|
|
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,
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
69
|
-
|
|
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
|
-
|
|
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
|
|
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 {
|
|
101
|
-
const
|
|
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
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
authMethods:
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
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,
|
|
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;
|
|
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 "
|
|
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 "
|
|
44
|
+
return "permissions";
|
|
41
45
|
case "roles":
|
|
42
|
-
return "
|
|
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 "
|
|
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
|
}
|