@lindorm/aegis 0.8.1 → 0.9.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/README.md +84 -5
- package/dist/classes/Aegis.d.ts +20 -5
- package/dist/classes/Aegis.d.ts.map +1 -1
- package/dist/classes/Aegis.js +259 -45
- package/dist/classes/Aegis.js.map +1 -1
- package/dist/classes/CoseKit.d.ts +31 -0
- package/dist/classes/CoseKit.d.ts.map +1 -0
- package/dist/classes/CoseKit.js +64 -0
- package/dist/classes/CoseKit.js.map +1 -0
- package/dist/classes/CweKit.d.ts +24 -0
- package/dist/classes/CweKit.d.ts.map +1 -0
- package/dist/classes/CweKit.js +73 -0
- package/dist/classes/CweKit.js.map +1 -0
- package/dist/classes/CwmKit.d.ts +22 -0
- package/dist/classes/CwmKit.d.ts.map +1 -0
- package/dist/classes/CwmKit.js +54 -0
- package/dist/classes/CwmKit.js.map +1 -0
- package/dist/classes/CwsKit.d.ts +24 -0
- package/dist/classes/CwsKit.d.ts.map +1 -0
- package/dist/classes/CwsKit.js +60 -0
- package/dist/classes/CwsKit.js.map +1 -0
- package/dist/classes/CwtKit.d.ts +31 -0
- package/dist/classes/CwtKit.d.ts.map +1 -0
- package/dist/classes/CwtKit.js +65 -0
- package/dist/classes/CwtKit.js.map +1 -0
- package/dist/classes/JoseKit.d.ts +32 -0
- package/dist/classes/JoseKit.d.ts.map +1 -0
- package/dist/classes/JoseKit.js +66 -0
- package/dist/classes/JoseKit.js.map +1 -0
- package/dist/classes/JweKit.d.ts.map +1 -1
- package/dist/classes/JweKit.js +31 -3
- package/dist/classes/JweKit.js.map +1 -1
- package/dist/classes/JwsKit.d.ts.map +1 -1
- package/dist/classes/JwsKit.js +19 -3
- package/dist/classes/JwsKit.js.map +1 -1
- package/dist/classes/JwtKit.d.ts +4 -1
- package/dist/classes/JwtKit.d.ts.map +1 -1
- package/dist/classes/JwtKit.js +100 -20
- package/dist/classes/JwtKit.js.map +1 -1
- package/dist/classes/SignatureKit.d.ts.map +1 -1
- package/dist/classes/SignatureKit.js +5 -1
- package/dist/classes/SignatureKit.js.map +1 -1
- package/dist/constants/token-type.d.ts +1 -1
- package/dist/constants/token-type.d.ts.map +1 -1
- package/dist/constants/token-type.js +2 -0
- package/dist/constants/token-type.js.map +1 -1
- package/dist/errors/AegisError.d.ts +1 -0
- package/dist/errors/AegisError.d.ts.map +1 -1
- package/dist/errors/AegisError.js +1 -0
- package/dist/errors/AegisError.js.map +1 -1
- package/dist/errors/JweError.d.ts +1 -0
- package/dist/errors/JweError.d.ts.map +1 -1
- package/dist/errors/JweError.js +1 -0
- package/dist/errors/JweError.js.map +1 -1
- package/dist/errors/JwsError.d.ts +1 -0
- package/dist/errors/JwsError.d.ts.map +1 -1
- package/dist/errors/JwsError.js +1 -0
- package/dist/errors/JwsError.js.map +1 -1
- package/dist/errors/JwtError.d.ts +1 -0
- package/dist/errors/JwtError.d.ts.map +1 -1
- package/dist/errors/JwtError.js +1 -0
- package/dist/errors/JwtError.js.map +1 -1
- package/dist/interfaces/Aegis.d.ts +6 -1
- package/dist/interfaces/Aegis.d.ts.map +1 -1
- package/dist/internal/claims/events.d.ts +5 -0
- package/dist/internal/claims/events.d.ts.map +1 -0
- package/dist/internal/claims/events.js +3 -0
- package/dist/internal/claims/events.js.map +1 -0
- package/dist/internal/claims/registry.d.ts +14 -0
- package/dist/internal/claims/registry.d.ts.map +1 -0
- package/dist/internal/claims/registry.js +61 -0
- package/dist/internal/claims/registry.js.map +1 -0
- package/dist/internal/claims/sub-id.d.ts +7 -0
- package/dist/internal/claims/sub-id.d.ts.map +1 -0
- package/dist/internal/claims/sub-id.js +11 -0
- package/dist/internal/claims/sub-id.js.map +1 -0
- package/dist/internal/cose/act-claim.d.ts +4 -0
- package/dist/internal/cose/act-claim.d.ts.map +1 -0
- package/dist/internal/cose/act-claim.js +8 -0
- package/dist/internal/cose/act-claim.js.map +1 -0
- package/dist/internal/cose/alg-labels.d.ts +4 -0
- package/dist/internal/cose/alg-labels.d.ts.map +1 -0
- package/dist/internal/cose/alg-labels.js +42 -0
- package/dist/internal/cose/alg-labels.js.map +1 -0
- package/dist/internal/cose/cbor.d.ts +11 -0
- package/dist/internal/cose/cbor.d.ts.map +1 -0
- package/dist/internal/cose/cbor.js +37 -0
- package/dist/internal/cose/cbor.js.map +1 -0
- package/dist/internal/cose/compact-map.d.ts +11 -0
- package/dist/internal/cose/compact-map.d.ts.map +1 -0
- package/dist/internal/cose/compact-map.js +43 -0
- package/dist/internal/cose/compact-map.js.map +1 -0
- package/dist/internal/cose/cose-key-thumbprint.d.ts +5 -0
- package/dist/internal/cose/cose-key-thumbprint.d.ts.map +1 -0
- package/dist/internal/cose/cose-key-thumbprint.js +60 -0
- package/dist/internal/cose/cose-key-thumbprint.js.map +1 -0
- package/dist/internal/cose/cose-key.d.ts +8 -0
- package/dist/internal/cose/cose-key.d.ts.map +1 -0
- package/dist/internal/cose/cose-key.js +98 -0
- package/dist/internal/cose/cose-key.js.map +1 -0
- package/dist/internal/cose/cose-typ.d.ts +2 -0
- package/dist/internal/cose/cose-typ.d.ts.map +1 -0
- package/dist/internal/cose/cose-typ.js +8 -0
- package/dist/internal/cose/cose-typ.js.map +1 -0
- package/dist/internal/cose/cwt-claims.d.ts +7 -0
- package/dist/internal/cose/cwt-claims.d.ts.map +1 -0
- package/dist/internal/cose/cwt-claims.js +94 -0
- package/dist/internal/cose/cwt-claims.js.map +1 -0
- package/dist/internal/cose/enc-labels.d.ts +5 -0
- package/dist/internal/cose/enc-labels.d.ts.map +1 -0
- package/dist/internal/cose/enc-labels.js +47 -0
- package/dist/internal/cose/enc-labels.js.map +1 -0
- package/dist/internal/cose/structures.d.ts +20 -0
- package/dist/internal/cose/structures.d.ts.map +1 -0
- package/dist/internal/cose/structures.js +22 -0
- package/dist/internal/cose/structures.js.map +1 -0
- package/dist/internal/cose/sub-id-claim.d.ts +4 -0
- package/dist/internal/cose/sub-id-claim.d.ts.map +1 -0
- package/dist/internal/cose/sub-id-claim.js +18 -0
- package/dist/internal/cose/sub-id-claim.js.map +1 -0
- package/dist/internal/profiles/definitions/access-token.d.ts +3 -0
- package/dist/internal/profiles/definitions/access-token.d.ts.map +1 -0
- package/dist/internal/profiles/definitions/access-token.js +31 -0
- package/dist/internal/profiles/definitions/access-token.js.map +1 -0
- package/dist/internal/profiles/definitions/client-assertion.d.ts +3 -0
- package/dist/internal/profiles/definitions/client-assertion.d.ts.map +1 -0
- package/dist/internal/profiles/definitions/client-assertion.js +18 -0
- package/dist/internal/profiles/definitions/client-assertion.js.map +1 -0
- package/dist/internal/profiles/definitions/default.d.ts +3 -0
- package/dist/internal/profiles/definitions/default.d.ts.map +1 -0
- package/dist/internal/profiles/definitions/default.js +14 -0
- package/dist/internal/profiles/definitions/default.js.map +1 -0
- package/dist/internal/profiles/definitions/delegation.d.ts +3 -0
- package/dist/internal/profiles/definitions/delegation.d.ts.map +1 -0
- package/dist/internal/profiles/definitions/delegation.js +19 -0
- package/dist/internal/profiles/definitions/delegation.js.map +1 -0
- package/dist/internal/profiles/definitions/erasure-token.d.ts +3 -0
- package/dist/internal/profiles/definitions/erasure-token.d.ts.map +1 -0
- package/dist/internal/profiles/definitions/erasure-token.js +28 -0
- package/dist/internal/profiles/definitions/erasure-token.js.map +1 -0
- package/dist/internal/profiles/definitions/id-token.d.ts +3 -0
- package/dist/internal/profiles/definitions/id-token.d.ts.map +1 -0
- package/dist/internal/profiles/definitions/id-token.js +26 -0
- package/dist/internal/profiles/definitions/id-token.js.map +1 -0
- package/dist/internal/profiles/definitions/introspection.d.ts +3 -0
- package/dist/internal/profiles/definitions/introspection.d.ts.map +1 -0
- package/dist/internal/profiles/definitions/introspection.js +18 -0
- package/dist/internal/profiles/definitions/introspection.js.map +1 -0
- package/dist/internal/profiles/definitions/jarm.d.ts +3 -0
- package/dist/internal/profiles/definitions/jarm.d.ts.map +1 -0
- package/dist/internal/profiles/definitions/jarm.js +19 -0
- package/dist/internal/profiles/definitions/jarm.js.map +1 -0
- package/dist/internal/profiles/definitions/logout-token.d.ts +3 -0
- package/dist/internal/profiles/definitions/logout-token.d.ts.map +1 -0
- package/dist/internal/profiles/definitions/logout-token.js +20 -0
- package/dist/internal/profiles/definitions/logout-token.js.map +1 -0
- package/dist/internal/profiles/definitions/security-event.d.ts +3 -0
- package/dist/internal/profiles/definitions/security-event.d.ts.map +1 -0
- package/dist/internal/profiles/definitions/security-event.js +20 -0
- package/dist/internal/profiles/definitions/security-event.js.map +1 -0
- package/dist/internal/profiles/definitions/userinfo.d.ts +3 -0
- package/dist/internal/profiles/definitions/userinfo.d.ts.map +1 -0
- package/dist/internal/profiles/definitions/userinfo.js +18 -0
- package/dist/internal/profiles/definitions/userinfo.js.map +1 -0
- package/dist/internal/profiles/registry.d.ts +4 -0
- package/dist/internal/profiles/registry.d.ts.map +1 -0
- package/dist/internal/profiles/registry.js +41 -0
- package/dist/internal/profiles/registry.js.map +1 -0
- package/dist/internal/utils/assemble-common-claims.d.ts +12 -0
- package/dist/internal/utils/assemble-common-claims.d.ts.map +1 -0
- package/dist/internal/utils/assemble-common-claims.js +66 -0
- package/dist/internal/utils/assemble-common-claims.js.map +1 -0
- package/dist/internal/utils/build-profile-claims.d.ts +14 -0
- package/dist/internal/utils/build-profile-claims.d.ts.map +1 -0
- package/dist/internal/utils/build-profile-claims.js +75 -0
- package/dist/internal/utils/build-profile-claims.js.map +1 -0
- package/dist/internal/utils/compute-jwk-thumbprint.js +8 -1
- package/dist/internal/utils/compute-jwk-thumbprint.js.map +1 -1
- package/dist/internal/utils/compute-typ-header.d.ts.map +1 -1
- package/dist/internal/utils/compute-typ-header.js +20 -5
- package/dist/internal/utils/compute-typ-header.js.map +1 -1
- package/dist/internal/utils/create-hash.d.ts.map +1 -1
- package/dist/internal/utils/create-hash.js +7 -7
- package/dist/internal/utils/create-hash.js.map +1 -1
- package/dist/internal/utils/enforce-verify-floor.d.ts +12 -0
- package/dist/internal/utils/enforce-verify-floor.d.ts.map +1 -0
- package/dist/internal/utils/enforce-verify-floor.js +43 -0
- package/dist/internal/utils/enforce-verify-floor.js.map +1 -0
- package/dist/internal/utils/extract-claims.d.ts +2 -1
- package/dist/internal/utils/extract-claims.d.ts.map +1 -1
- package/dist/internal/utils/extract-claims.js +10 -4
- package/dist/internal/utils/extract-claims.js.map +1 -1
- package/dist/internal/utils/jose-header.d.ts.map +1 -1
- package/dist/internal/utils/jose-header.js +38 -7
- package/dist/internal/utils/jose-header.js.map +1 -1
- package/dist/internal/utils/jwt-payload.d.ts +8 -6
- package/dist/internal/utils/jwt-payload.d.ts.map +1 -1
- package/dist/internal/utils/jwt-payload.js +32 -96
- package/dist/internal/utils/jwt-payload.js.map +1 -1
- package/dist/internal/utils/jwt-validate.d.ts.map +1 -1
- package/dist/internal/utils/jwt-validate.js +7 -1
- package/dist/internal/utils/jwt-validate.js.map +1 -1
- package/dist/internal/utils/jwt-verify.d.ts.map +1 -1
- package/dist/internal/utils/jwt-verify.js +17 -4
- package/dist/internal/utils/jwt-verify.js.map +1 -1
- package/dist/internal/utils/map-content-to-claims.d.ts +8 -0
- package/dist/internal/utils/map-content-to-claims.d.ts.map +1 -0
- package/dist/internal/utils/map-content-to-claims.js +89 -0
- package/dist/internal/utils/map-content-to-claims.js.map +1 -0
- package/dist/internal/utils/parse-introspection.d.ts.map +1 -1
- package/dist/internal/utils/parse-introspection.js +5 -1
- package/dist/internal/utils/parse-introspection.js.map +1 -1
- package/dist/internal/utils/parse-userinfo.d.ts.map +1 -1
- package/dist/internal/utils/parse-userinfo.js +5 -1
- package/dist/internal/utils/parse-userinfo.js.map +1 -1
- package/dist/internal/utils/resolve-cert-binding.d.ts.map +1 -1
- package/dist/internal/utils/resolve-cert-binding.js +3 -0
- package/dist/internal/utils/resolve-cert-binding.js.map +1 -1
- package/dist/internal/utils/rules/act-chain-shape.d.ts +4 -0
- package/dist/internal/utils/rules/act-chain-shape.d.ts.map +1 -0
- package/dist/internal/utils/rules/act-chain-shape.js +52 -0
- package/dist/internal/utils/rules/act-chain-shape.js.map +1 -0
- package/dist/internal/utils/rules/alg-permitted.d.ts +6 -0
- package/dist/internal/utils/rules/alg-permitted.d.ts.map +1 -0
- package/dist/internal/utils/rules/alg-permitted.js +35 -0
- package/dist/internal/utils/rules/alg-permitted.js.map +1 -0
- package/dist/internal/utils/rules/at-least-one-of.d.ts +4 -0
- package/dist/internal/utils/rules/at-least-one-of.d.ts.map +1 -0
- package/dist/internal/utils/rules/at-least-one-of.js +13 -0
- package/dist/internal/utils/rules/at-least-one-of.js.map +1 -0
- package/dist/internal/utils/rules/aud-single-resource.d.ts +4 -0
- package/dist/internal/utils/rules/aud-single-resource.d.ts.map +1 -0
- package/dist/internal/utils/rules/aud-single-resource.js +18 -0
- package/dist/internal/utils/rules/aud-single-resource.js.map +1 -0
- package/dist/internal/utils/rules/cnf-shape.d.ts +4 -0
- package/dist/internal/utils/rules/cnf-shape.d.ts.map +1 -0
- package/dist/internal/utils/rules/cnf-shape.js +55 -0
- package/dist/internal/utils/rules/cnf-shape.js.map +1 -0
- package/dist/internal/utils/rules/cross-field.d.ts +4 -0
- package/dist/internal/utils/rules/cross-field.d.ts.map +1 -0
- package/dist/internal/utils/rules/cross-field.js +21 -0
- package/dist/internal/utils/rules/cross-field.js.map +1 -0
- package/dist/internal/utils/rules/events-shape.d.ts +4 -0
- package/dist/internal/utils/rules/events-shape.d.ts.map +1 -0
- package/dist/internal/utils/rules/events-shape.js +33 -0
- package/dist/internal/utils/rules/events-shape.js.map +1 -0
- package/dist/internal/utils/rules/every-element-has-key.d.ts +4 -0
- package/dist/internal/utils/rules/every-element-has-key.d.ts.map +1 -0
- package/dist/internal/utils/rules/every-element-has-key.js +20 -0
- package/dist/internal/utils/rules/every-element-has-key.js.map +1 -0
- package/dist/internal/utils/rules/forbid-present.d.ts +4 -0
- package/dist/internal/utils/rules/forbid-present.d.ts.map +1 -0
- package/dist/internal/utils/rules/forbid-present.js +10 -0
- package/dist/internal/utils/rules/forbid-present.js.map +1 -0
- package/dist/internal/utils/rules/index.d.ts +14 -0
- package/dist/internal/utils/rules/index.d.ts.map +1 -0
- package/dist/internal/utils/rules/index.js +14 -0
- package/dist/internal/utils/rules/index.js.map +1 -0
- package/dist/internal/utils/rules/iss-uri.d.ts +4 -0
- package/dist/internal/utils/rules/iss-uri.d.ts.map +1 -0
- package/dist/internal/utils/rules/iss-uri.js +11 -0
- package/dist/internal/utils/rules/iss-uri.js.map +1 -0
- package/dist/internal/utils/rules/require-present.d.ts +4 -0
- package/dist/internal/utils/rules/require-present.d.ts.map +1 -0
- package/dist/internal/utils/rules/require-present.js +10 -0
- package/dist/internal/utils/rules/require-present.js.map +1 -0
- package/dist/internal/utils/rules/required-when.d.ts +8 -0
- package/dist/internal/utils/rules/required-when.d.ts.map +1 -0
- package/dist/internal/utils/rules/required-when.js +13 -0
- package/dist/internal/utils/rules/required-when.js.map +1 -0
- package/dist/internal/utils/rules/sub-id-shape.d.ts +4 -0
- package/dist/internal/utils/rules/sub-id-shape.d.ts.map +1 -0
- package/dist/internal/utils/rules/sub-id-shape.js +26 -0
- package/dist/internal/utils/rules/sub-id-shape.js.map +1 -0
- package/dist/internal/utils/select-encoder.d.ts +6 -0
- package/dist/internal/utils/select-encoder.d.ts.map +1 -0
- package/dist/internal/utils/select-encoder.js +4 -0
- package/dist/internal/utils/select-encoder.js.map +1 -0
- package/dist/internal/utils/validate-actor.d.ts +8 -1
- package/dist/internal/utils/validate-actor.d.ts.map +1 -1
- package/dist/internal/utils/validate-actor.js +9 -7
- package/dist/internal/utils/validate-actor.js.map +1 -1
- package/dist/internal/utils/validate-profile-claims.d.ts +8 -0
- package/dist/internal/utils/validate-profile-claims.d.ts.map +1 -0
- package/dist/internal/utils/validate-profile-claims.js +45 -0
- package/dist/internal/utils/validate-profile-claims.js.map +1 -0
- package/dist/internal/utils/validate.d.ts.map +1 -1
- package/dist/internal/utils/validate.js +8 -1
- package/dist/internal/utils/validate.js.map +1 -1
- package/dist/internal/utils/verify-cert-binding.d.ts.map +1 -1
- package/dist/internal/utils/verify-cert-binding.js +9 -1
- package/dist/internal/utils/verify-cert-binding.js.map +1 -1
- package/dist/internal/utils/verify-dpop-proof.d.ts.map +1 -1
- package/dist/internal/utils/verify-dpop-proof.js +41 -7
- package/dist/internal/utils/verify-dpop-proof.js.map +1 -1
- package/dist/types/claims/aegis-introspection.d.ts +2 -1
- package/dist/types/claims/aegis-introspection.d.ts.map +1 -1
- package/dist/types/claims/index.d.ts +2 -0
- package/dist/types/claims/index.d.ts.map +1 -1
- package/dist/types/claims/index.js +2 -0
- package/dist/types/claims/index.js.map +1 -1
- package/dist/types/claims/jwt/index.d.ts +2 -0
- package/dist/types/claims/jwt/index.d.ts.map +1 -1
- package/dist/types/claims/jwt/index.js +2 -0
- package/dist/types/claims/jwt/index.js.map +1 -1
- package/dist/types/claims/jwt/jwt-claims.d.ts +3 -1
- package/dist/types/claims/jwt/jwt-claims.d.ts.map +1 -1
- package/dist/types/claims/jwt/lindorm-claims-wire.d.ts +1 -2
- package/dist/types/claims/jwt/lindorm-claims-wire.d.ts.map +1 -1
- package/dist/types/claims/jwt/oidc-claims-wire.d.ts +2 -0
- package/dist/types/claims/jwt/oidc-claims-wire.d.ts.map +1 -1
- package/dist/types/claims/jwt/rar-claims-wire.d.ts +5 -0
- package/dist/types/claims/jwt/rar-claims-wire.d.ts.map +1 -0
- package/dist/types/claims/jwt/rar-claims-wire.js +2 -0
- package/dist/types/claims/jwt/rar-claims-wire.js.map +1 -0
- package/dist/types/claims/jwt/set-claims-wire.d.ts +9 -0
- package/dist/types/claims/jwt/set-claims-wire.d.ts.map +1 -0
- package/dist/types/claims/jwt/set-claims-wire.js +2 -0
- package/dist/types/claims/jwt/set-claims-wire.js.map +1 -0
- package/dist/types/claims/lindorm-claims.d.ts +1 -2
- package/dist/types/claims/lindorm-claims.d.ts.map +1 -1
- package/dist/types/claims/oidc-claims.d.ts +2 -0
- package/dist/types/claims/oidc-claims.d.ts.map +1 -1
- package/dist/types/claims/rar-claims.d.ts +5 -0
- package/dist/types/claims/rar-claims.d.ts.map +1 -0
- package/dist/types/claims/rar-claims.js +2 -0
- package/dist/types/claims/rar-claims.js.map +1 -0
- package/dist/types/claims/set-claims.d.ts +8 -0
- package/dist/types/claims/set-claims.d.ts.map +1 -0
- package/dist/types/claims/set-claims.js +2 -0
- package/dist/types/claims/set-claims.js.map +1 -0
- package/dist/types/jwt/index.d.ts +1 -0
- package/dist/types/jwt/index.d.ts.map +1 -1
- package/dist/types/jwt/index.js +1 -0
- package/dist/types/jwt/index.js.map +1 -1
- package/dist/types/jwt/jwt-claim-matchers.d.ts +2 -1
- package/dist/types/jwt/jwt-claim-matchers.d.ts.map +1 -1
- package/dist/types/jwt/jwt-parse.d.ts +2 -2
- package/dist/types/jwt/jwt-parse.d.ts.map +1 -1
- package/dist/types/jwt/jwt-sign.d.ts +8 -6
- package/dist/types/jwt/jwt-sign.d.ts.map +1 -1
- package/dist/types/jwt/profile.d.ts +99 -0
- package/dist/types/jwt/profile.d.ts.map +1 -0
- package/dist/types/jwt/profile.js +2 -0
- package/dist/types/jwt/profile.js.map +1 -0
- package/dist/types/level-of-assurance.d.ts +0 -1
- package/dist/types/level-of-assurance.d.ts.map +1 -1
- package/package.json +19 -18
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Aegis.js","sourceRoot":"","sources":["../../src/classes/Aegis.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Aegis.js","sourceRoot":"","sources":["../../src/classes/Aegis.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import type { IKryptos, KryptosEncryption } from "@lindorm/kryptos";
|
|
2
|
+
import type { ILogger } from "@lindorm/logger";
|
|
3
|
+
import type { Dict } from "@lindorm/types";
|
|
4
|
+
import { type CoseThumbprintHash } from "../internal/cose/cose-key-thumbprint.js";
|
|
5
|
+
import { type CwtDecoded, type CwtVerifyResult } from "./CwtKit.js";
|
|
6
|
+
export type CoseKitOptions = {
|
|
7
|
+
logger: ILogger;
|
|
8
|
+
};
|
|
9
|
+
export type CoseMintOptions = {
|
|
10
|
+
typ?: string;
|
|
11
|
+
proprietary?: boolean;
|
|
12
|
+
};
|
|
13
|
+
export type CoseEncryptOptions = {
|
|
14
|
+
typ?: string;
|
|
15
|
+
encryption?: KryptosEncryption;
|
|
16
|
+
};
|
|
17
|
+
export declare class CoseKit {
|
|
18
|
+
private readonly logger;
|
|
19
|
+
constructor(options: CoseKitOptions);
|
|
20
|
+
sign(kryptos: IKryptos, common: Dict, options?: CoseMintOptions): Buffer;
|
|
21
|
+
verify(kryptos: IKryptos, token: Buffer): CwtVerifyResult;
|
|
22
|
+
decode(token: Buffer): CwtDecoded;
|
|
23
|
+
encrypt(kryptos: IKryptos, inner: Buffer, options?: CoseEncryptOptions): Buffer;
|
|
24
|
+
isCose(token: Buffer): boolean;
|
|
25
|
+
isEncrypted(token: Buffer): boolean;
|
|
26
|
+
decodeEncryptedKid(token: Buffer): string | undefined;
|
|
27
|
+
decrypt(kryptos: IKryptos, token: Buffer): Buffer;
|
|
28
|
+
static thumbprint(kryptos: IKryptos, hash?: CoseThumbprintHash): Buffer;
|
|
29
|
+
static thumbprintUri(kryptos: IKryptos, hash?: CoseThumbprintHash): string;
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=CoseKit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CoseKit.d.ts","sourceRoot":"","sources":["../../src/classes/CoseKit.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACpE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EACL,KAAK,kBAAkB,EAGxB,MAAM,yCAAyC,CAAC;AAGjD,OAAO,EAAU,KAAK,UAAU,EAAE,KAAK,eAAe,EAAE,MAAM,aAAa,CAAC;AAE5E,MAAM,MAAM,cAAc,GAAG;IAC3B,MAAM,EAAE,OAAO,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAE5B,GAAG,CAAC,EAAE,MAAM,CAAC;IAEb,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAE/B,GAAG,CAAC,EAAE,MAAM,CAAC;IAEb,UAAU,CAAC,EAAE,iBAAiB,CAAC;CAChC,CAAC;AAiBF,qBAAa,OAAO;IAClB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAU;gBAEd,OAAO,EAAE,cAAc;IAKnC,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,GAAE,eAAoB,GAAG,MAAM;IAK5E,MAAM,CAAC,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,GAAG,eAAe;IAKzD,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,UAAU;IAQjC,OAAO,CACZ,OAAO,EAAE,QAAQ,EACjB,KAAK,EAAE,MAAM,EACb,OAAO,GAAE,kBAAuB,GAC/B,MAAM;IAgBF,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;IAU9B,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;IAKnC,kBAAkB,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS;IAUrD,OAAO,CAAC,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM;WAW1C,UAAU,CACtB,OAAO,EAAE,QAAQ,EACjB,IAAI,GAAE,kBAA8B,GACnC,MAAM;WAKK,aAAa,CACzB,OAAO,EAAE,QAAQ,EACjB,IAAI,GAAE,kBAA8B,GACnC,MAAM;CAGV"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { Tag, decodeCbor, encodeCbor } from "../internal/cose/cbor.js";
|
|
2
|
+
import { computeCoseKeyThumbprint, computeCoseKeyThumbprintUri, } from "../internal/cose/cose-key-thumbprint.js";
|
|
3
|
+
import { COSE_HEADER, COSE_TAG } from "../internal/cose/structures.js";
|
|
4
|
+
import { CweKit } from "./CweKit.js";
|
|
5
|
+
import { CwtKit } from "./CwtKit.js";
|
|
6
|
+
const innerCose = (value) => {
|
|
7
|
+
const cose = value instanceof Tag && value.tag === COSE_TAG.cwt ? value.contents : value;
|
|
8
|
+
return cose instanceof Tag ? cose : undefined;
|
|
9
|
+
};
|
|
10
|
+
export class CoseKit {
|
|
11
|
+
logger;
|
|
12
|
+
constructor(options) {
|
|
13
|
+
this.logger = options.logger.child(["CoseKit"]);
|
|
14
|
+
}
|
|
15
|
+
sign(kryptos, common, options = {}) {
|
|
16
|
+
return new CwtKit({ kryptos, logger: this.logger }).sign(common, options);
|
|
17
|
+
}
|
|
18
|
+
verify(kryptos, token) {
|
|
19
|
+
return new CwtKit({ kryptos, logger: this.logger }).verify(token);
|
|
20
|
+
}
|
|
21
|
+
decode(token) {
|
|
22
|
+
return CwtKit.decode(token);
|
|
23
|
+
}
|
|
24
|
+
encrypt(kryptos, inner, options = {}) {
|
|
25
|
+
const encrypt0 = new CweKit({
|
|
26
|
+
kryptos,
|
|
27
|
+
logger: this.logger,
|
|
28
|
+
encryption: options.encryption,
|
|
29
|
+
}).encrypt(inner, { typ: options.typ });
|
|
30
|
+
return Buffer.from(encodeCbor(encrypt0));
|
|
31
|
+
}
|
|
32
|
+
isCose(token) {
|
|
33
|
+
try {
|
|
34
|
+
const tag = innerCose(decodeCbor(token))?.tag;
|
|
35
|
+
return tag === COSE_TAG.sign1 || tag === COSE_TAG.mac0 || tag === COSE_TAG.encrypt0;
|
|
36
|
+
}
|
|
37
|
+
catch {
|
|
38
|
+
return false;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
isEncrypted(token) {
|
|
42
|
+
return innerCose(decodeCbor(token))?.tag === COSE_TAG.encrypt0;
|
|
43
|
+
}
|
|
44
|
+
decodeEncryptedKid(token) {
|
|
45
|
+
const cose = innerCose(decodeCbor(token));
|
|
46
|
+
const unprotected = Array.isArray(cose?.contents)
|
|
47
|
+
? cose.contents[1]
|
|
48
|
+
: undefined;
|
|
49
|
+
const kid = unprotected?.get(COSE_HEADER.kid);
|
|
50
|
+
return kid instanceof Uint8Array ? Buffer.from(kid).toString("utf8") : undefined;
|
|
51
|
+
}
|
|
52
|
+
decrypt(kryptos, token) {
|
|
53
|
+
const cose = innerCose(decodeCbor(token));
|
|
54
|
+
const { payload } = new CweKit({ kryptos, logger: this.logger }).decrypt(cose);
|
|
55
|
+
return payload;
|
|
56
|
+
}
|
|
57
|
+
static thumbprint(kryptos, hash = "sha-256") {
|
|
58
|
+
return computeCoseKeyThumbprint(kryptos.export("jwk"), hash);
|
|
59
|
+
}
|
|
60
|
+
static thumbprintUri(kryptos, hash = "sha-256") {
|
|
61
|
+
return computeCoseKeyThumbprintUri(kryptos.export("jwk"), hash);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=CoseKit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CoseKit.js","sourceRoot":"","sources":["../../src/classes/CoseKit.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { IKryptos, KryptosEncryption } from "@lindorm/kryptos";
|
|
2
|
+
import type { ILogger } from "@lindorm/logger";
|
|
3
|
+
import { Tag } from "../internal/cose/cbor.js";
|
|
4
|
+
export type CweKitOptions = {
|
|
5
|
+
kryptos: IKryptos;
|
|
6
|
+
logger: ILogger;
|
|
7
|
+
encryption?: KryptosEncryption;
|
|
8
|
+
};
|
|
9
|
+
export type CweEncryptOptions = {
|
|
10
|
+
typ?: string;
|
|
11
|
+
};
|
|
12
|
+
export type CweDecryptResult = {
|
|
13
|
+
payload: Buffer;
|
|
14
|
+
protectedHeader: Map<number, unknown>;
|
|
15
|
+
};
|
|
16
|
+
export declare class CweKit {
|
|
17
|
+
private readonly kryptos;
|
|
18
|
+
private readonly logger;
|
|
19
|
+
private readonly encryption;
|
|
20
|
+
constructor(options: CweKitOptions);
|
|
21
|
+
encrypt(payload: Buffer, options?: CweEncryptOptions): Tag;
|
|
22
|
+
decrypt(encrypt0: unknown): CweDecryptResult;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=CweKit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CweKit.d.ts","sourceRoot":"","sources":["../../src/classes/CweKit.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACpE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAE/C,OAAO,EAAE,GAAG,EAAE,MAAM,0BAA0B,CAAC;AAc/C,MAAM,MAAM,aAAa,GAAG;IAC1B,OAAO,EAAE,QAAQ,CAAC;IAClB,MAAM,EAAE,OAAO,CAAC;IAMhB,UAAU,CAAC,EAAE,iBAAiB,CAAC;CAChC,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,GAAG,CAAC,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,eAAe,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACvC,CAAC;AAsBF,qBAAa,MAAM;IACjB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAW;IACnC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAU;IACjC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAgC;gBAExC,OAAO,EAAE,aAAa;IAMlC,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,GAAE,iBAAsB,GAAG,GAAG;IAyB9D,OAAO,CAAC,QAAQ,EAAE,OAAO,GAAG,gBAAgB;CAsCpD"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { AesKit } from "@lindorm/aes";
|
|
2
|
+
import { AegisError } from "../errors/index.js";
|
|
3
|
+
import { Tag } from "../internal/cose/cbor.js";
|
|
4
|
+
import { coseLabelToEnc, encToCoseLabel, tagBytesForEncryption, } from "../internal/cose/enc-labels.js";
|
|
5
|
+
import { COSE_HEADER, COSE_TAG, buildEncStructure, decodeProtectedHeader, encodeProtectedHeader, } from "../internal/cose/structures.js";
|
|
6
|
+
const unwrapEncrypt0 = (value) => {
|
|
7
|
+
const contents = value instanceof Tag && value.tag === COSE_TAG.encrypt0 ? value.contents : value;
|
|
8
|
+
if (!Array.isArray(contents) || contents.length !== 3) {
|
|
9
|
+
throw new AegisError("Malformed COSE_Encrypt0", {
|
|
10
|
+
code: "cose_malformed",
|
|
11
|
+
title: "Malformed COSE_Encrypt0",
|
|
12
|
+
details: "A COSE_Encrypt0 must be a 3-element array [protected, unprotected, ciphertext].",
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
return contents;
|
|
16
|
+
};
|
|
17
|
+
export class CweKit {
|
|
18
|
+
kryptos;
|
|
19
|
+
logger;
|
|
20
|
+
encryption;
|
|
21
|
+
constructor(options) {
|
|
22
|
+
this.kryptos = options.kryptos;
|
|
23
|
+
this.logger = options.logger.child(["CweKit"]);
|
|
24
|
+
this.encryption = options.encryption ?? options.kryptos.encryption ?? undefined;
|
|
25
|
+
}
|
|
26
|
+
encrypt(payload, options = {}) {
|
|
27
|
+
this.logger.debug("Encrypting COSE_Encrypt0", { options });
|
|
28
|
+
const protectedMap = new Map();
|
|
29
|
+
protectedMap.set(COSE_HEADER.alg, encToCoseLabel(this.encryption));
|
|
30
|
+
if (options.typ !== undefined)
|
|
31
|
+
protectedMap.set(COSE_HEADER.typ, options.typ);
|
|
32
|
+
const protectedHeader = encodeProtectedHeader(protectedMap);
|
|
33
|
+
const aad = buildEncStructure(protectedHeader);
|
|
34
|
+
const { ciphertext, iv, tag } = new AesKit({
|
|
35
|
+
kryptos: this.kryptos,
|
|
36
|
+
encryption: this.encryption,
|
|
37
|
+
}).encryptContent(payload, { aad });
|
|
38
|
+
const unprotected = new Map();
|
|
39
|
+
unprotected.set(COSE_HEADER.iv, iv);
|
|
40
|
+
unprotected.set(COSE_HEADER.kid, Buffer.from(this.kryptos.id, "utf8"));
|
|
41
|
+
return new Tag(COSE_TAG.encrypt0, [
|
|
42
|
+
protectedHeader,
|
|
43
|
+
unprotected,
|
|
44
|
+
Buffer.concat([ciphertext, tag]),
|
|
45
|
+
]);
|
|
46
|
+
}
|
|
47
|
+
decrypt(encrypt0) {
|
|
48
|
+
const [protectedHeader, unprotected, coseCiphertext] = unwrapEncrypt0(encrypt0);
|
|
49
|
+
const ivValue = unprotected.get(COSE_HEADER.iv);
|
|
50
|
+
if (!(ivValue instanceof Uint8Array)) {
|
|
51
|
+
throw new AegisError("COSE_Encrypt0 is missing its IV", {
|
|
52
|
+
code: "cose_malformed",
|
|
53
|
+
title: "Malformed COSE_Encrypt0",
|
|
54
|
+
details: "The unprotected header has no IV (label 5).",
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
const decodedProtected = decodeProtectedHeader(protectedHeader);
|
|
58
|
+
const encryption = coseLabelToEnc(decodedProtected.get(COSE_HEADER.alg));
|
|
59
|
+
const ct = Buffer.from(coseCiphertext);
|
|
60
|
+
const tagBytes = tagBytesForEncryption(encryption);
|
|
61
|
+
const ciphertext = ct.subarray(0, ct.length - tagBytes);
|
|
62
|
+
const tag = ct.subarray(ct.length - tagBytes);
|
|
63
|
+
const aad = buildEncStructure(Buffer.from(protectedHeader));
|
|
64
|
+
const payload = new AesKit({ kryptos: this.kryptos, encryption }).decryptContent({
|
|
65
|
+
aad,
|
|
66
|
+
ciphertext,
|
|
67
|
+
iv: Buffer.from(ivValue),
|
|
68
|
+
tag,
|
|
69
|
+
});
|
|
70
|
+
return { payload, protectedHeader: decodedProtected };
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
//# sourceMappingURL=CweKit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CweKit.js","sourceRoot":"","sources":["../../src/classes/CweKit.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { IKryptos } from "@lindorm/kryptos";
|
|
2
|
+
import type { ILogger } from "@lindorm/logger";
|
|
3
|
+
import { Tag } from "../internal/cose/cbor.js";
|
|
4
|
+
export type CwmKitOptions = {
|
|
5
|
+
kryptos: IKryptos;
|
|
6
|
+
logger: ILogger;
|
|
7
|
+
};
|
|
8
|
+
export type CwmTagOptions = {
|
|
9
|
+
typ?: string;
|
|
10
|
+
};
|
|
11
|
+
export type CwmVerifyResult = {
|
|
12
|
+
payload: Buffer;
|
|
13
|
+
protectedHeader: Map<number, unknown>;
|
|
14
|
+
};
|
|
15
|
+
export declare class CwmKit {
|
|
16
|
+
private readonly kryptos;
|
|
17
|
+
private readonly logger;
|
|
18
|
+
constructor(options: CwmKitOptions);
|
|
19
|
+
tag(payload: Buffer, options?: CwmTagOptions): Tag;
|
|
20
|
+
verify(mac0: unknown): CwmVerifyResult;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=CwmKit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CwmKit.d.ts","sourceRoot":"","sources":["../../src/classes/CwmKit.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAG/C,OAAO,EAAE,GAAG,EAAE,MAAM,0BAA0B,CAAC;AAU/C,MAAM,MAAM,aAAa,GAAG;IAC1B,OAAO,EAAE,QAAQ,CAAC;IAClB,MAAM,EAAE,OAAO,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IAC1B,GAAG,CAAC,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC5B,OAAO,EAAE,MAAM,CAAC;IAChB,eAAe,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACvC,CAAC;AAsBF,qBAAa,MAAM;IACjB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAW;IACnC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAU;gBAEd,OAAO,EAAE,aAAa;IAKlC,GAAG,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,GAAE,aAAkB,GAAG,GAAG;IAiBtD,MAAM,CAAC,IAAI,EAAE,OAAO,GAAG,eAAe;CA+B9C"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { AegisError } from "../errors/index.js";
|
|
2
|
+
import { algToCoseLabel } from "../internal/cose/alg-labels.js";
|
|
3
|
+
import { Tag } from "../internal/cose/cbor.js";
|
|
4
|
+
import { COSE_HEADER, COSE_TAG, buildMacStructure, decodeProtectedHeader, encodeProtectedHeader, } from "../internal/cose/structures.js";
|
|
5
|
+
import { SignatureKit } from "./SignatureKit.js";
|
|
6
|
+
const unwrapMac0 = (value) => {
|
|
7
|
+
const contents = value instanceof Tag && value.tag === COSE_TAG.mac0 ? value.contents : value;
|
|
8
|
+
if (!Array.isArray(contents) || contents.length !== 4) {
|
|
9
|
+
throw new AegisError("Malformed COSE_Mac0", {
|
|
10
|
+
code: "cose_malformed",
|
|
11
|
+
title: "Malformed COSE_Mac0",
|
|
12
|
+
details: "A COSE_Mac0 must be a 4-element array [protected, unprotected, payload, tag].",
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
return contents;
|
|
16
|
+
};
|
|
17
|
+
export class CwmKit {
|
|
18
|
+
kryptos;
|
|
19
|
+
logger;
|
|
20
|
+
constructor(options) {
|
|
21
|
+
this.kryptos = options.kryptos;
|
|
22
|
+
this.logger = options.logger.child(["CwmKit"]);
|
|
23
|
+
}
|
|
24
|
+
tag(payload, options = {}) {
|
|
25
|
+
this.logger.debug("MAC'ing COSE_Mac0", { options });
|
|
26
|
+
const protectedMap = new Map();
|
|
27
|
+
protectedMap.set(COSE_HEADER.alg, algToCoseLabel(this.kryptos.algorithm));
|
|
28
|
+
if (options.typ !== undefined)
|
|
29
|
+
protectedMap.set(COSE_HEADER.typ, options.typ);
|
|
30
|
+
const protectedHeader = encodeProtectedHeader(protectedMap);
|
|
31
|
+
const unprotected = new Map();
|
|
32
|
+
unprotected.set(COSE_HEADER.kid, Buffer.from(this.kryptos.id, "utf8"));
|
|
33
|
+
const toBeMaced = buildMacStructure(protectedHeader, payload);
|
|
34
|
+
const tag = new SignatureKit({ kryptos: this.kryptos }).sign(toBeMaced);
|
|
35
|
+
return new Tag(COSE_TAG.mac0, [protectedHeader, unprotected, payload, tag]);
|
|
36
|
+
}
|
|
37
|
+
verify(mac0) {
|
|
38
|
+
const [protectedHeader, , payload, tag] = unwrapMac0(mac0);
|
|
39
|
+
const toBeMaced = buildMacStructure(Buffer.from(protectedHeader), Buffer.from(payload));
|
|
40
|
+
const valid = new SignatureKit({ kryptos: this.kryptos }).verify(toBeMaced, Buffer.from(tag));
|
|
41
|
+
if (!valid) {
|
|
42
|
+
throw new AegisError("Invalid COSE_Mac0 tag", {
|
|
43
|
+
code: "cose_mac_invalid",
|
|
44
|
+
title: "Invalid COSE MAC",
|
|
45
|
+
details: "The COSE_Mac0 authentication tag did not verify against the resolved key.",
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
return {
|
|
49
|
+
payload: Buffer.from(payload),
|
|
50
|
+
protectedHeader: decodeProtectedHeader(protectedHeader),
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
//# sourceMappingURL=CwmKit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CwmKit.js","sourceRoot":"","sources":["../../src/classes/CwmKit.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { IKryptos } from "@lindorm/kryptos";
|
|
2
|
+
import type { ILogger } from "@lindorm/logger";
|
|
3
|
+
import { Tag } from "../internal/cose/cbor.js";
|
|
4
|
+
export type CwsKitOptions = {
|
|
5
|
+
kryptos: IKryptos;
|
|
6
|
+
logger: ILogger;
|
|
7
|
+
};
|
|
8
|
+
export type CwsSignOptions = {
|
|
9
|
+
typ?: string;
|
|
10
|
+
};
|
|
11
|
+
export type CwsVerifyResult = {
|
|
12
|
+
payload: Buffer;
|
|
13
|
+
protectedHeader: Map<number, unknown>;
|
|
14
|
+
unprotected: Map<number, unknown>;
|
|
15
|
+
};
|
|
16
|
+
export declare class CwsKit {
|
|
17
|
+
private readonly kryptos;
|
|
18
|
+
private readonly logger;
|
|
19
|
+
constructor(options: CwsKitOptions);
|
|
20
|
+
sign(payload: Buffer, options?: CwsSignOptions): Tag;
|
|
21
|
+
verify(sign1: unknown): CwsVerifyResult;
|
|
22
|
+
static peekKid(sign1: unknown): string | undefined;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=CwsKit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CwsKit.d.ts","sourceRoot":"","sources":["../../src/classes/CwsKit.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAG/C,OAAO,EAAE,GAAG,EAAE,MAAM,0BAA0B,CAAC;AAU/C,MAAM,MAAM,aAAa,GAAG;IAC1B,OAAO,EAAE,QAAQ,CAAC;IAClB,MAAM,EAAE,OAAO,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG;IAE3B,GAAG,CAAC,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC5B,OAAO,EAAE,MAAM,CAAC;IAChB,eAAe,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACtC,WAAW,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC,CAAC;AA0BF,qBAAa,MAAM;IACjB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAW;IACnC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAU;gBAEd,OAAO,EAAE,aAAa;IAKlC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,GAAE,cAAmB,GAAG,GAAG;IAqBxD,MAAM,CAAC,KAAK,EAAE,OAAO,GAAG,eAAe;WAoChC,OAAO,CAAC,KAAK,EAAE,OAAO,GAAG,MAAM,GAAG,SAAS;CAK1D"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { AegisError } from "../errors/index.js";
|
|
2
|
+
import { algToCoseLabel } from "../internal/cose/alg-labels.js";
|
|
3
|
+
import { Tag } from "../internal/cose/cbor.js";
|
|
4
|
+
import { COSE_HEADER, COSE_TAG, buildSigStructure, decodeProtectedHeader, encodeProtectedHeader, } from "../internal/cose/structures.js";
|
|
5
|
+
import { SignatureKit } from "./SignatureKit.js";
|
|
6
|
+
const unwrapSign1 = (value) => {
|
|
7
|
+
const contents = value instanceof Tag && value.tag === COSE_TAG.sign1 ? value.contents : value;
|
|
8
|
+
if (!Array.isArray(contents) || contents.length !== 4) {
|
|
9
|
+
throw new AegisError("Malformed COSE_Sign1", {
|
|
10
|
+
code: "cose_malformed",
|
|
11
|
+
title: "Malformed COSE_Sign1",
|
|
12
|
+
details: "A COSE_Sign1 must be a 4-element array [protected, unprotected, payload, signature].",
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
return contents;
|
|
16
|
+
};
|
|
17
|
+
export class CwsKit {
|
|
18
|
+
kryptos;
|
|
19
|
+
logger;
|
|
20
|
+
constructor(options) {
|
|
21
|
+
this.kryptos = options.kryptos;
|
|
22
|
+
this.logger = options.logger.child(["CwsKit"]);
|
|
23
|
+
}
|
|
24
|
+
sign(payload, options = {}) {
|
|
25
|
+
this.logger.debug("Signing COSE_Sign1", { options });
|
|
26
|
+
const protectedMap = new Map();
|
|
27
|
+
protectedMap.set(COSE_HEADER.alg, algToCoseLabel(this.kryptos.algorithm));
|
|
28
|
+
if (options.typ !== undefined)
|
|
29
|
+
protectedMap.set(COSE_HEADER.typ, options.typ);
|
|
30
|
+
const protectedHeader = encodeProtectedHeader(protectedMap);
|
|
31
|
+
const unprotected = new Map();
|
|
32
|
+
unprotected.set(COSE_HEADER.kid, Buffer.from(this.kryptos.id, "utf8"));
|
|
33
|
+
const toBeSigned = buildSigStructure(protectedHeader, payload);
|
|
34
|
+
const signature = new SignatureKit({ kryptos: this.kryptos, raw: true }).sign(toBeSigned);
|
|
35
|
+
return new Tag(COSE_TAG.sign1, [protectedHeader, unprotected, payload, signature]);
|
|
36
|
+
}
|
|
37
|
+
verify(sign1) {
|
|
38
|
+
const [protectedHeader, unprotected, payload, signature] = unwrapSign1(sign1);
|
|
39
|
+
const toBeSigned = buildSigStructure(Buffer.from(protectedHeader), Buffer.from(payload));
|
|
40
|
+
const valid = new SignatureKit({ kryptos: this.kryptos, raw: true }).verify(toBeSigned, Buffer.from(signature));
|
|
41
|
+
if (!valid) {
|
|
42
|
+
throw new AegisError("Invalid COSE_Sign1 signature", {
|
|
43
|
+
code: "cose_signature_invalid",
|
|
44
|
+
title: "Invalid COSE Signature",
|
|
45
|
+
details: "The COSE_Sign1 signature did not verify against the resolved key.",
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
return {
|
|
49
|
+
payload: Buffer.from(payload),
|
|
50
|
+
protectedHeader: decodeProtectedHeader(protectedHeader),
|
|
51
|
+
unprotected,
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
static peekKid(sign1) {
|
|
55
|
+
const [, unprotected] = unwrapSign1(sign1);
|
|
56
|
+
const kid = unprotected.get(COSE_HEADER.kid);
|
|
57
|
+
return kid instanceof Uint8Array ? Buffer.from(kid).toString("utf8") : undefined;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=CwsKit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CwsKit.js","sourceRoot":"","sources":["../../src/classes/CwsKit.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import type { IKryptos } from "@lindorm/kryptos";
|
|
2
|
+
import type { ILogger } from "@lindorm/logger";
|
|
3
|
+
import type { Dict } from "@lindorm/types";
|
|
4
|
+
export type CwtKitOptions = {
|
|
5
|
+
kryptos: IKryptos;
|
|
6
|
+
logger: ILogger;
|
|
7
|
+
};
|
|
8
|
+
export type CwtSignOptions = {
|
|
9
|
+
typ?: string;
|
|
10
|
+
proprietary?: boolean;
|
|
11
|
+
};
|
|
12
|
+
export type CwtVerifyResult = {
|
|
13
|
+
claims: Dict;
|
|
14
|
+
protectedHeader: Map<number, unknown>;
|
|
15
|
+
typ: string | undefined;
|
|
16
|
+
};
|
|
17
|
+
export type CwtDecoded = {
|
|
18
|
+
cose: unknown;
|
|
19
|
+
kid: string | undefined;
|
|
20
|
+
algorithm: string | undefined;
|
|
21
|
+
typ: string | undefined;
|
|
22
|
+
};
|
|
23
|
+
export declare class CwtKit {
|
|
24
|
+
private readonly kryptos;
|
|
25
|
+
private readonly logger;
|
|
26
|
+
constructor(options: CwtKitOptions);
|
|
27
|
+
sign(common: Dict, options?: CwtSignOptions): Buffer;
|
|
28
|
+
verify(token: Buffer): CwtVerifyResult;
|
|
29
|
+
static decode(token: Buffer): CwtDecoded;
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=CwtKit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CwtKit.d.ts","sourceRoot":"","sources":["../../src/classes/CwtKit.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAa3C,MAAM,MAAM,aAAa,GAAG;IAC1B,OAAO,EAAE,QAAQ,CAAC;IAClB,MAAM,EAAE,OAAO,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG;IAC3B,GAAG,CAAC,EAAE,MAAM,CAAC;IAEb,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC5B,MAAM,EAAE,IAAI,CAAC;IACb,eAAe,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACtC,GAAG,EAAE,MAAM,GAAG,SAAS,CAAC;CACzB,CAAC;AAEF,MAAM,MAAM,UAAU,GAAG;IAEvB,IAAI,EAAE,OAAO,CAAC;IACd,GAAG,EAAE,MAAM,GAAG,SAAS,CAAC;IACxB,SAAS,EAAE,MAAM,GAAG,SAAS,CAAC;IAC9B,GAAG,EAAE,MAAM,GAAG,SAAS,CAAC;CACzB,CAAC;AAiBF,qBAAa,MAAM;IACjB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAW;IACnC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAU;gBAEd,OAAO,EAAE,aAAa;IAKlC,IAAI,CAAC,MAAM,EAAE,IAAI,EAAE,OAAO,GAAE,cAAmB,GAAG,MAAM;IAiBxD,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,eAAe;WA4B/B,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,UAAU;CA6BhD"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { AegisError } from "../errors/index.js";
|
|
2
|
+
import { coseLabelToAlg } from "../internal/cose/alg-labels.js";
|
|
3
|
+
import { Tag, decodeCbor, encodeCbor } from "../internal/cose/cbor.js";
|
|
4
|
+
import { encodeCwtClaims, decodeCwtClaims } from "../internal/cose/cwt-claims.js";
|
|
5
|
+
import { COSE_HEADER, COSE_TAG, decodeProtectedHeader, } from "../internal/cose/structures.js";
|
|
6
|
+
import { CwmKit } from "./CwmKit.js";
|
|
7
|
+
import { CwsKit } from "./CwsKit.js";
|
|
8
|
+
const unwrapCwt = (value) => value instanceof Tag && value.tag === COSE_TAG.cwt ? value.contents : value;
|
|
9
|
+
export class CwtKit {
|
|
10
|
+
kryptos;
|
|
11
|
+
logger;
|
|
12
|
+
constructor(options) {
|
|
13
|
+
this.kryptos = options.kryptos;
|
|
14
|
+
this.logger = options.logger.child(["CwtKit"]);
|
|
15
|
+
}
|
|
16
|
+
sign(common, options = {}) {
|
|
17
|
+
const mac = this.kryptos.type === "oct";
|
|
18
|
+
this.logger.debug(`Minting CWT (${mac ? "COSE_Mac0" : "COSE_Sign1"})`, { options });
|
|
19
|
+
const payload = encodeCbor(encodeCwtClaims(common, { proprietary: options.proprietary }));
|
|
20
|
+
const kit = { kryptos: this.kryptos, logger: this.logger };
|
|
21
|
+
const cose = mac
|
|
22
|
+
? new CwmKit(kit).tag(payload, { typ: options.typ })
|
|
23
|
+
: new CwsKit(kit).sign(payload, { typ: options.typ });
|
|
24
|
+
return encodeCbor(new Tag(COSE_TAG.cwt, cose));
|
|
25
|
+
}
|
|
26
|
+
verify(token) {
|
|
27
|
+
const cose = unwrapCwt(decodeCbor(token));
|
|
28
|
+
const kit = { kryptos: this.kryptos, logger: this.logger };
|
|
29
|
+
const { payload, protectedHeader } = cose instanceof Tag && cose.tag === COSE_TAG.mac0
|
|
30
|
+
? new CwmKit(kit).verify(cose)
|
|
31
|
+
: new CwsKit(kit).verify(cose);
|
|
32
|
+
const claims = decodeCwtClaims(decodeCbor(payload, { preferMap: false }));
|
|
33
|
+
const typ = protectedHeader.get(COSE_HEADER.typ);
|
|
34
|
+
return {
|
|
35
|
+
claims,
|
|
36
|
+
protectedHeader,
|
|
37
|
+
typ: typeof typ === "string" ? typ : undefined,
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
static decode(token) {
|
|
41
|
+
const cose = unwrapCwt(decodeCbor(token));
|
|
42
|
+
const contents = cose instanceof Tag ? cose.contents : cose;
|
|
43
|
+
if (!Array.isArray(contents) || contents.length < 2) {
|
|
44
|
+
throw new AegisError("Malformed CWT", {
|
|
45
|
+
code: "cose_malformed",
|
|
46
|
+
title: "Malformed CWT",
|
|
47
|
+
details: "The CWT does not contain a recognisable COSE structure.",
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
const [protectedBstr, unprotected] = contents;
|
|
51
|
+
const protectedHeader = decodeProtectedHeader(protectedBstr);
|
|
52
|
+
const kidValue = unprotected.get(COSE_HEADER.kid);
|
|
53
|
+
const algLabel = protectedHeader.get(COSE_HEADER.alg);
|
|
54
|
+
const typ = protectedHeader.get(COSE_HEADER.typ);
|
|
55
|
+
return {
|
|
56
|
+
cose,
|
|
57
|
+
kid: kidValue instanceof Uint8Array
|
|
58
|
+
? Buffer.from(kidValue).toString("utf8")
|
|
59
|
+
: undefined,
|
|
60
|
+
algorithm: typeof algLabel === "number" ? coseLabelToAlg(algLabel) : undefined,
|
|
61
|
+
typ: typeof typ === "string" ? typ : undefined,
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=CwtKit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CwtKit.js","sourceRoot":"","sources":["../../src/classes/CwtKit.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import type { IKryptos, KryptosEncryption } from "@lindorm/kryptos";
|
|
2
|
+
import type { ILogger } from "@lindorm/logger";
|
|
3
|
+
import type { Dict } from "@lindorm/types";
|
|
4
|
+
import type { CertBindingMode, DecryptedJwe, EncryptedJwe, JweEncryptOptions, JwsContent, ParsedJws, ParsedJwt, SignJwsOptions, SignJwtContent, SignJwtOptions, SignedJws, SignedJwt, VerifyJwtOptions } from "../types/index.js";
|
|
5
|
+
export type JoseKitOptions = {
|
|
6
|
+
certBindingMode: CertBindingMode;
|
|
7
|
+
clockTolerance: number;
|
|
8
|
+
dpopMaxSkew: number | undefined;
|
|
9
|
+
encryption: KryptosEncryption;
|
|
10
|
+
issuer: string | undefined;
|
|
11
|
+
logger: ILogger;
|
|
12
|
+
};
|
|
13
|
+
export declare class JoseKit {
|
|
14
|
+
private readonly certBindingMode;
|
|
15
|
+
private readonly clockTolerance;
|
|
16
|
+
private readonly dpopMaxSkew;
|
|
17
|
+
private readonly encryption;
|
|
18
|
+
private readonly issuer;
|
|
19
|
+
private readonly logger;
|
|
20
|
+
constructor(options: JoseKitOptions);
|
|
21
|
+
signJws<T extends JwsContent>(kryptos: IKryptos, data: T, options?: SignJwsOptions): SignedJws;
|
|
22
|
+
verifyJws<T extends JwsContent>(kryptos: IKryptos, jws: string): ParsedJws<T>;
|
|
23
|
+
encryptJwe(kryptos: IKryptos, data: string, options?: JweEncryptOptions): EncryptedJwe;
|
|
24
|
+
decryptJwe(kryptos: IKryptos, jwe: string): DecryptedJwe;
|
|
25
|
+
signJwt<T extends Dict = Dict>(kryptos: IKryptos, content: SignJwtContent<T>, options?: SignJwtOptions): SignedJwt;
|
|
26
|
+
verifyJwt<T extends Dict = Dict>(kryptos: IKryptos, jwt: string, options?: VerifyJwtOptions): ParsedJwt<T>;
|
|
27
|
+
signClaims<C extends Dict = Dict>(kryptos: IKryptos, claims: Dict, content: SignJwtContent<C>, options?: SignJwtOptions): SignedJwt;
|
|
28
|
+
private jws;
|
|
29
|
+
private jwe;
|
|
30
|
+
private jwt;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=JoseKit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"JoseKit.d.ts","sourceRoot":"","sources":["../../src/classes/JoseKit.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACpE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,KAAK,EACV,eAAe,EACf,YAAY,EACZ,YAAY,EACZ,iBAAiB,EACjB,UAAU,EACV,SAAS,EACT,SAAS,EACT,cAAc,EACd,cAAc,EACd,cAAc,EACd,SAAS,EACT,SAAS,EACT,gBAAgB,EACjB,MAAM,mBAAmB,CAAC;AAK3B,MAAM,MAAM,cAAc,GAAG;IAC3B,eAAe,EAAE,eAAe,CAAC;IACjC,cAAc,EAAE,MAAM,CAAC;IACvB,WAAW,EAAE,MAAM,GAAG,SAAS,CAAC;IAChC,UAAU,EAAE,iBAAiB,CAAC;IAC9B,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC;IAC3B,MAAM,EAAE,OAAO,CAAC;CACjB,CAAC;AASF,qBAAa,OAAO;IAClB,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAkB;IAClD,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAS;IACxC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAqB;IACjD,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAoB;IAC/C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAqB;IAC5C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAU;gBAEd,OAAO,EAAE,cAAc;IASnC,OAAO,CAAC,CAAC,SAAS,UAAU,EACjC,OAAO,EAAE,QAAQ,EACjB,IAAI,EAAE,CAAC,EACP,OAAO,GAAE,cAAmB,GAC3B,SAAS;IAIL,SAAS,CAAC,CAAC,SAAS,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,GAAG,SAAS,CAAC,CAAC,CAAC;IAI7E,UAAU,CACf,OAAO,EAAE,QAAQ,EACjB,IAAI,EAAE,MAAM,EACZ,OAAO,GAAE,iBAAsB,GAC9B,YAAY;IAIR,UAAU,CAAC,OAAO,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,GAAG,YAAY;IAIxD,OAAO,CAAC,CAAC,SAAS,IAAI,GAAG,IAAI,EAClC,OAAO,EAAE,QAAQ,EACjB,OAAO,EAAE,cAAc,CAAC,CAAC,CAAC,EAC1B,OAAO,GAAE,cAAmB,GAC3B,SAAS;IAIL,SAAS,CAAC,CAAC,SAAS,IAAI,GAAG,IAAI,EACpC,OAAO,EAAE,QAAQ,EACjB,GAAG,EAAE,MAAM,EACX,OAAO,GAAE,gBAAqB,GAC7B,SAAS,CAAC,CAAC,CAAC;IAIR,UAAU,CAAC,CAAC,SAAS,IAAI,GAAG,IAAI,EACrC,OAAO,EAAE,QAAQ,EACjB,MAAM,EAAE,IAAI,EACZ,OAAO,EAAE,cAAc,CAAC,CAAC,CAAC,EAC1B,OAAO,GAAE,cAAmB,GAC3B,SAAS;IAMZ,OAAO,CAAC,GAAG;IAQX,OAAO,CAAC,GAAG;IASX,OAAO,CAAC,GAAG;CAUZ"}
|