@atcute/oauth-types 0.1.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/LICENSE +14 -0
- package/README.md +48 -0
- package/dist/build-client-metadata.d.ts +168 -0
- package/dist/build-client-metadata.d.ts.map +1 -0
- package/dist/build-client-metadata.js +53 -0
- package/dist/build-client-metadata.js.map +1 -0
- package/dist/constants.d.ts +5 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +5 -0
- package/dist/constants.js.map +1 -0
- package/dist/index.d.ts +31 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +37 -0
- package/dist/index.js.map +1 -0
- package/dist/schemas/atcute-confidential-client-metadata.d.ts +21 -0
- package/dist/schemas/atcute-confidential-client-metadata.d.ts.map +1 -0
- package/dist/schemas/atcute-confidential-client-metadata.js +112 -0
- package/dist/schemas/atcute-confidential-client-metadata.js.map +1 -0
- package/dist/schemas/atproto-authorization-server-metadata.d.ts +55 -0
- package/dist/schemas/atproto-authorization-server-metadata.d.ts.map +1 -0
- package/dist/schemas/atproto-authorization-server-metadata.js +25 -0
- package/dist/schemas/atproto-authorization-server-metadata.js.map +1 -0
- package/dist/schemas/atproto-oauth-scope.d.ts +8 -0
- package/dist/schemas/atproto-oauth-scope.d.ts.map +1 -0
- package/dist/schemas/atproto-oauth-scope.js +12 -0
- package/dist/schemas/atproto-oauth-scope.js.map +1 -0
- package/dist/schemas/atproto-oauth-token-response.d.ts +19 -0
- package/dist/schemas/atproto-oauth-token-response.d.ts.map +1 -0
- package/dist/schemas/atproto-oauth-token-response.js +16 -0
- package/dist/schemas/atproto-oauth-token-response.js.map +1 -0
- package/dist/schemas/atproto-protected-resource-metadata.d.ts +21 -0
- package/dist/schemas/atproto-protected-resource-metadata.d.ts.map +1 -0
- package/dist/schemas/atproto-protected-resource-metadata.js +18 -0
- package/dist/schemas/atproto-protected-resource-metadata.js.map +1 -0
- package/dist/schemas/jwk.d.ts +241 -0
- package/dist/schemas/jwk.d.ts.map +1 -0
- package/dist/schemas/jwk.js +138 -0
- package/dist/schemas/jwk.js.map +1 -0
- package/dist/schemas/jwks.d.ts +242 -0
- package/dist/schemas/jwks.d.ts.map +1 -0
- package/dist/schemas/jwks.js +34 -0
- package/dist/schemas/jwks.js.map +1 -0
- package/dist/schemas/oauth-authorization-details.d.ts +64 -0
- package/dist/schemas/oauth-authorization-details.d.ts.map +1 -0
- package/dist/schemas/oauth-authorization-details.js +37 -0
- package/dist/schemas/oauth-authorization-details.js.map +1 -0
- package/dist/schemas/oauth-authorization-server-metadata.d.ts +96 -0
- package/dist/schemas/oauth-authorization-server-metadata.d.ts.map +1 -0
- package/dist/schemas/oauth-authorization-server-metadata.js +81 -0
- package/dist/schemas/oauth-authorization-server-metadata.js.map +1 -0
- package/dist/schemas/oauth-client-id-discoverable.d.ts +6 -0
- package/dist/schemas/oauth-client-id-discoverable.d.ts.map +1 -0
- package/dist/schemas/oauth-client-id-discoverable.js +43 -0
- package/dist/schemas/oauth-client-id-discoverable.js.map +1 -0
- package/dist/schemas/oauth-client-id.d.ts +5 -0
- package/dist/schemas/oauth-client-id.d.ts.map +1 -0
- package/dist/schemas/oauth-client-id.js +4 -0
- package/dist/schemas/oauth-client-id.js.map +1 -0
- package/dist/schemas/oauth-client-metadata.d.ts +164 -0
- package/dist/schemas/oauth-client-metadata.d.ts.map +1 -0
- package/dist/schemas/oauth-client-metadata.js +74 -0
- package/dist/schemas/oauth-client-metadata.js.map +1 -0
- package/dist/schemas/oauth-code-challenge-method.d.ts +4 -0
- package/dist/schemas/oauth-code-challenge-method.d.ts.map +1 -0
- package/dist/schemas/oauth-code-challenge-method.js +3 -0
- package/dist/schemas/oauth-code-challenge-method.js.map +1 -0
- package/dist/schemas/oauth-endpoint-auth-method.d.ts +4 -0
- package/dist/schemas/oauth-endpoint-auth-method.d.ts.map +1 -0
- package/dist/schemas/oauth-endpoint-auth-method.js +3 -0
- package/dist/schemas/oauth-endpoint-auth-method.js.map +1 -0
- package/dist/schemas/oauth-grant-type.d.ts +4 -0
- package/dist/schemas/oauth-grant-type.d.ts.map +1 -0
- package/dist/schemas/oauth-grant-type.js +4 -0
- package/dist/schemas/oauth-grant-type.js.map +1 -0
- package/dist/schemas/oauth-issuer-identifier.d.ts +4 -0
- package/dist/schemas/oauth-issuer-identifier.d.ts.map +1 -0
- package/dist/schemas/oauth-issuer-identifier.js +21 -0
- package/dist/schemas/oauth-issuer-identifier.js.map +1 -0
- package/dist/schemas/oauth-par-response.d.ts +7 -0
- package/dist/schemas/oauth-par-response.d.ts.map +1 -0
- package/dist/schemas/oauth-par-response.js +7 -0
- package/dist/schemas/oauth-par-response.js.map +1 -0
- package/dist/schemas/oauth-prompt.d.ts +13 -0
- package/dist/schemas/oauth-prompt.d.ts.map +1 -0
- package/dist/schemas/oauth-prompt.js +12 -0
- package/dist/schemas/oauth-prompt.js.map +1 -0
- package/dist/schemas/oauth-protected-resource-metadata.d.ts +66 -0
- package/dist/schemas/oauth-protected-resource-metadata.d.ts.map +1 -0
- package/dist/schemas/oauth-protected-resource-metadata.js +71 -0
- package/dist/schemas/oauth-protected-resource-metadata.js.map +1 -0
- package/dist/schemas/oauth-redirect-uri.d.ts +20 -0
- package/dist/schemas/oauth-redirect-uri.d.ts.map +1 -0
- package/dist/schemas/oauth-redirect-uri.js +32 -0
- package/dist/schemas/oauth-redirect-uri.js.map +1 -0
- package/dist/schemas/oauth-response-mode.d.ts +4 -0
- package/dist/schemas/oauth-response-mode.d.ts.map +1 -0
- package/dist/schemas/oauth-response-mode.js +3 -0
- package/dist/schemas/oauth-response-mode.js.map +1 -0
- package/dist/schemas/oauth-response-type.d.ts +4 -0
- package/dist/schemas/oauth-response-type.d.ts.map +1 -0
- package/dist/schemas/oauth-response-type.js +8 -0
- package/dist/schemas/oauth-response-type.js.map +1 -0
- package/dist/schemas/oauth-scope.d.ts +12 -0
- package/dist/schemas/oauth-scope.d.ts.map +1 -0
- package/dist/schemas/oauth-scope.js +14 -0
- package/dist/schemas/oauth-scope.js.map +1 -0
- package/dist/schemas/oauth-token-response.d.ts +22 -0
- package/dist/schemas/oauth-token-response.d.ts.map +1 -0
- package/dist/schemas/oauth-token-response.js +19 -0
- package/dist/schemas/oauth-token-response.js.map +1 -0
- package/dist/schemas/oauth-token-type.d.ts +5 -0
- package/dist/schemas/oauth-token-type.d.ts.map +1 -0
- package/dist/schemas/oauth-token-type.js +13 -0
- package/dist/schemas/oauth-token-type.js.map +1 -0
- package/dist/schemas/uri.d.ts +18 -0
- package/dist/schemas/uri.d.ts.map +1 -0
- package/dist/schemas/uri.js +81 -0
- package/dist/schemas/uri.js.map +1 -0
- package/dist/schemas/utils.d.ts +32 -0
- package/dist/schemas/utils.d.ts.map +1 -0
- package/dist/schemas/utils.js +94 -0
- package/dist/schemas/utils.js.map +1 -0
- package/dist/scope.d.ts +84 -0
- package/dist/scope.d.ts.map +1 -0
- package/dist/scope.js +102 -0
- package/dist/scope.js.map +1 -0
- package/lib/build-client-metadata.ts +72 -0
- package/lib/constants.ts +5 -0
- package/lib/index.ts +116 -0
- package/lib/schemas/atcute-confidential-client-metadata.ts +139 -0
- package/lib/schemas/atproto-authorization-server-metadata.ts +32 -0
- package/lib/schemas/atproto-oauth-scope.ts +18 -0
- package/lib/schemas/atproto-oauth-token-response.ts +20 -0
- package/lib/schemas/atproto-protected-resource-metadata.ts +24 -0
- package/lib/schemas/jwk.ts +189 -0
- package/lib/schemas/jwks.ts +45 -0
- package/lib/schemas/oauth-authorization-details.ts +43 -0
- package/lib/schemas/oauth-authorization-server-metadata.ts +101 -0
- package/lib/schemas/oauth-client-id-discoverable.ts +53 -0
- package/lib/schemas/oauth-client-id.ts +6 -0
- package/lib/schemas/oauth-client-metadata.ts +83 -0
- package/lib/schemas/oauth-code-challenge-method.ts +5 -0
- package/lib/schemas/oauth-endpoint-auth-method.ts +13 -0
- package/lib/schemas/oauth-grant-type.ts +13 -0
- package/lib/schemas/oauth-issuer-identifier.ts +30 -0
- package/lib/schemas/oauth-par-response.ts +10 -0
- package/lib/schemas/oauth-prompt.ts +20 -0
- package/lib/schemas/oauth-protected-resource-metadata.ts +89 -0
- package/lib/schemas/oauth-redirect-uri.ts +42 -0
- package/lib/schemas/oauth-response-mode.ts +9 -0
- package/lib/schemas/oauth-response-type.ts +17 -0
- package/lib/schemas/oauth-scope.ts +18 -0
- package/lib/schemas/oauth-token-response.ts +22 -0
- package/lib/schemas/oauth-token-type.ts +15 -0
- package/lib/schemas/uri.ts +100 -0
- package/lib/schemas/utils.ts +113 -0
- package/lib/scope.ts +187 -0
- package/package.json +38 -0
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import * as v from '@badrap/valita';
|
|
2
|
+
export declare const ATPROTO_SCOPE_VALUE = "atproto";
|
|
3
|
+
/** atproto OAuth scope (must include "atproto") */
|
|
4
|
+
export declare const atprotoOAuthScopeSchema: v.Type<string>;
|
|
5
|
+
export type AtprotoOAuthScope = v.Infer<typeof atprotoOAuthScopeSchema>;
|
|
6
|
+
/** default scope is for reading identity (did) only */
|
|
7
|
+
export declare const DEFAULT_ATPROTO_OAUTH_SCOPE: AtprotoOAuthScope;
|
|
8
|
+
//# sourceMappingURL=atproto-oauth-scope.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"atproto-oauth-scope.d.ts","sourceRoot":"","sources":["../../lib/schemas/atproto-oauth-scope.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AAKpC,eAAO,MAAM,mBAAmB,YAAY,CAAC;AAM7C,mDAAmD;AACnD,eAAO,MAAM,uBAAuB,gBAAwE,CAAC;AAE7G,MAAM,MAAM,iBAAiB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,uBAAuB,CAAC,CAAC;AAExE,uDAAuD;AACvD,eAAO,MAAM,2BAA2B,EAAE,iBAAuC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import * as v from '@badrap/valita';
|
|
2
|
+
import { isOAuthScope } from './oauth-scope.js';
|
|
3
|
+
import { isSpaceSeparatedValue } from './utils.js';
|
|
4
|
+
export const ATPROTO_SCOPE_VALUE = 'atproto';
|
|
5
|
+
const isAtprotoOAuthScope = (input) => {
|
|
6
|
+
return isOAuthScope(input) && isSpaceSeparatedValue(ATPROTO_SCOPE_VALUE, input);
|
|
7
|
+
};
|
|
8
|
+
/** atproto OAuth scope (must include "atproto") */
|
|
9
|
+
export const atprotoOAuthScopeSchema = v.string().assert(isAtprotoOAuthScope, `invalid atproto OAuth scope`);
|
|
10
|
+
/** default scope is for reading identity (did) only */
|
|
11
|
+
export const DEFAULT_ATPROTO_OAUTH_SCOPE = ATPROTO_SCOPE_VALUE;
|
|
12
|
+
//# sourceMappingURL=atproto-oauth-scope.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"atproto-oauth-scope.js","sourceRoot":"","sources":["../../lib/schemas/atproto-oauth-scope.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AAEpC,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAEnD,MAAM,CAAC,MAAM,mBAAmB,GAAG,SAAS,CAAC;AAE7C,MAAM,mBAAmB,GAAG,CAAC,KAAa,EAAW,EAAE,CAAC;IACvD,OAAO,YAAY,CAAC,KAAK,CAAC,IAAI,qBAAqB,CAAC,mBAAmB,EAAE,KAAK,CAAC,CAAC;AAAA,CAChF,CAAC;AAEF,mDAAmD;AACnD,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,mBAAmB,EAAE,6BAA6B,CAAC,CAAC;AAI7G,uDAAuD;AACvD,MAAM,CAAC,MAAM,2BAA2B,GAAsB,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import * as v from '@badrap/valita';
|
|
2
|
+
export declare const atprotoOAuthTokenResponseSchema: v.ObjectType<{
|
|
3
|
+
access_token: v.Type<string>;
|
|
4
|
+
token_type: v.Type<"DPoP">;
|
|
5
|
+
sub: v.Type<`did:plc:${string}` | `did:web:${string}`>;
|
|
6
|
+
scope: v.Type<string>;
|
|
7
|
+
refresh_token: v.Optional<string>;
|
|
8
|
+
expires_in: v.Optional<number>;
|
|
9
|
+
authorization_details: v.Optional<{
|
|
10
|
+
type: string;
|
|
11
|
+
locations?: string[] | undefined;
|
|
12
|
+
actions?: string[] | undefined;
|
|
13
|
+
datatypes?: string[] | undefined;
|
|
14
|
+
identifier?: string | undefined;
|
|
15
|
+
privileges?: string[] | undefined;
|
|
16
|
+
}[]>;
|
|
17
|
+
}, undefined>;
|
|
18
|
+
export type AtprotoOAuthTokenResponse = v.Infer<typeof atprotoOAuthTokenResponseSchema>;
|
|
19
|
+
//# sourceMappingURL=atproto-oauth-token-response.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"atproto-oauth-token-response.d.ts","sourceRoot":"","sources":["../../lib/schemas/atproto-oauth-token-response.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AAKpC,eAAO,MAAM,+BAA+B;;;;;;;;;;;;;;;aAU1C,CAAC;AAEH,MAAM,MAAM,yBAAyB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,+BAA+B,CAAC,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { isAtprotoDid } from '@atcute/identity';
|
|
2
|
+
import * as v from '@badrap/valita';
|
|
3
|
+
import { atprotoOAuthScopeSchema } from './atproto-oauth-scope.js';
|
|
4
|
+
import { oauthAuthorizationDetailsSchema } from './oauth-authorization-details.js';
|
|
5
|
+
export const atprotoOAuthTokenResponseSchema = v.object({
|
|
6
|
+
access_token: v.string(),
|
|
7
|
+
token_type: v.literal('DPoP'),
|
|
8
|
+
sub: v.string().assert(isAtprotoDid, `must be a did:plc or did:web`),
|
|
9
|
+
scope: atprotoOAuthScopeSchema,
|
|
10
|
+
refresh_token: v.string().optional(),
|
|
11
|
+
expires_in: v.number().optional(),
|
|
12
|
+
// https://datatracker.ietf.org/doc/html/rfc9396#name-enriched-authorization-deta
|
|
13
|
+
authorization_details: oauthAuthorizationDetailsSchema.optional(),
|
|
14
|
+
// OpenID is not compatible with atproto identities
|
|
15
|
+
});
|
|
16
|
+
//# sourceMappingURL=atproto-oauth-token-response.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"atproto-oauth-token-response.js","sourceRoot":"","sources":["../../lib/schemas/atproto-oauth-token-response.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAEhD,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AAEpC,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAE,+BAA+B,EAAE,MAAM,kCAAkC,CAAC;AAEnF,MAAM,CAAC,MAAM,+BAA+B,GAAG,CAAC,CAAC,MAAM,CAAC;IACvD,YAAY,EAAE,CAAC,CAAC,MAAM,EAAE;IACxB,UAAU,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC;IAC7B,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,YAAY,EAAE,8BAA8B,CAAC;IACpE,KAAK,EAAE,uBAAuB;IAC9B,aAAa,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACpC,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACjC,iFAAiF;IACjF,qBAAqB,EAAE,+BAA+B,CAAC,QAAQ,EAAE;IACjE,mDAAmD;CACnD,CAAC,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import * as v from '@badrap/valita';
|
|
2
|
+
/**
|
|
3
|
+
* AT Protocol protected resource metadata with required fields.
|
|
4
|
+
*
|
|
5
|
+
* @see {@link https://atproto.com/specs/oauth}
|
|
6
|
+
*/
|
|
7
|
+
export declare const atprotoProtectedResourceMetadataValidator: v.Type<{
|
|
8
|
+
resource: string;
|
|
9
|
+
authorization_servers?: string[] | undefined;
|
|
10
|
+
jwks_uri?: string | undefined;
|
|
11
|
+
scopes_supported?: string[] | undefined;
|
|
12
|
+
bearer_methods_supported?: ("body" | "header" | "query")[] | undefined;
|
|
13
|
+
resource_signing_alg_values_supported?: string[] | undefined;
|
|
14
|
+
resource_documentation?: string | undefined;
|
|
15
|
+
resource_policy_uri?: string | undefined;
|
|
16
|
+
resource_tos_uri?: string | undefined;
|
|
17
|
+
} & {
|
|
18
|
+
authorization_servers: [string];
|
|
19
|
+
}>;
|
|
20
|
+
export type AtprotoProtectedResourceMetadata = v.Infer<typeof atprotoProtectedResourceMetadataValidator>;
|
|
21
|
+
//# sourceMappingURL=atproto-protected-resource-metadata.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"atproto-protected-resource-metadata.d.ts","sourceRoot":"","sources":["../../lib/schemas/atproto-protected-resource-metadata.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AAIpC;;;;GAIG;AACH,eAAO,MAAM,yCAAyC;;;;;;;;;;;;EAYrD,CAAC;AAEF,MAAM,MAAM,gCAAgC,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,yCAAyC,CAAC,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import * as v from '@badrap/valita';
|
|
2
|
+
import { oauthProtectedResourceMetadataValidator } from './oauth-protected-resource-metadata.js';
|
|
3
|
+
/**
|
|
4
|
+
* AT Protocol protected resource metadata with required fields.
|
|
5
|
+
*
|
|
6
|
+
* @see {@link https://atproto.com/specs/oauth}
|
|
7
|
+
*/
|
|
8
|
+
export const atprotoProtectedResourceMetadataValidator = oauthProtectedResourceMetadataValidator.chain((data) => {
|
|
9
|
+
// atproto requires exactly one authorization server
|
|
10
|
+
if (data.authorization_servers?.length !== 1) {
|
|
11
|
+
return v.err({
|
|
12
|
+
message: `atproto requires exactly one authorization server`,
|
|
13
|
+
path: ['authorization_servers'],
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
return v.ok(data);
|
|
17
|
+
});
|
|
18
|
+
//# sourceMappingURL=atproto-protected-resource-metadata.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"atproto-protected-resource-metadata.js","sourceRoot":"","sources":["../../lib/schemas/atproto-protected-resource-metadata.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AAEpC,OAAO,EAAE,uCAAuC,EAAE,MAAM,wCAAwC,CAAC;AAEjG;;;;GAIG;AACH,MAAM,CAAC,MAAM,yCAAyC,GAAG,uCAAuC,CAAC,KAAK,CACrG,CAAC,IAAI,EAAE,EAAE,CAAC;IACT,oDAAoD;IACpD,IAAI,IAAI,CAAC,qBAAqB,EAAE,MAAM,KAAK,CAAC,EAAE,CAAC;QAC9C,OAAO,CAAC,CAAC,GAAG,CAAC;YACZ,OAAO,EAAE,mDAAmD;YAC5D,IAAI,EAAE,CAAC,uBAAuB,CAAC;SAC/B,CAAC,CAAC;IACJ,CAAC;IAED,OAAO,CAAC,CAAC,EAAE,CAAC,IAAyD,CAAC,CAAC;AAAA,CACvE,CACD,CAAC"}
|
|
@@ -0,0 +1,241 @@
|
|
|
1
|
+
import * as v from '@badrap/valita';
|
|
2
|
+
export declare const keyUsageSchema: v.UnionType<[v.Type<"verify">, v.Type<"encrypt">, v.Type<"wrapKey">, v.Type<"sign">, v.Type<"decrypt">, v.Type<"unwrapKey">, v.Type<"deriveKey">, v.Type<"deriveBits">]>;
|
|
3
|
+
export declare const publicKeyUsageSchema: v.UnionType<[v.Type<"verify">, v.Type<"encrypt">, v.Type<"wrapKey">]>;
|
|
4
|
+
/** JWK schema for known key types */
|
|
5
|
+
export declare const jwkSchema: v.Type<{
|
|
6
|
+
kid?: string | undefined;
|
|
7
|
+
use?: "enc" | "sig" | undefined;
|
|
8
|
+
key_ops?: ("decrypt" | "deriveBits" | "deriveKey" | "encrypt" | "sign" | "unwrapKey" | "verify" | "wrapKey")[] | undefined;
|
|
9
|
+
x5c?: string[] | undefined;
|
|
10
|
+
x5t?: string | undefined;
|
|
11
|
+
'x5t#S256'?: string | undefined;
|
|
12
|
+
x5u?: string | undefined;
|
|
13
|
+
ext?: boolean | undefined;
|
|
14
|
+
iat?: number | undefined;
|
|
15
|
+
exp?: number | undefined;
|
|
16
|
+
nbf?: number | undefined;
|
|
17
|
+
revoked?: {
|
|
18
|
+
revoked_at: number;
|
|
19
|
+
reason?: string | undefined;
|
|
20
|
+
} | undefined;
|
|
21
|
+
kty: "RSA";
|
|
22
|
+
alg?: "PS256" | "PS384" | "PS512" | "RS256" | "RS384" | "RS512" | undefined;
|
|
23
|
+
n: string;
|
|
24
|
+
e: string;
|
|
25
|
+
d?: string | undefined;
|
|
26
|
+
p?: string | undefined;
|
|
27
|
+
q?: string | undefined;
|
|
28
|
+
dp?: string | undefined;
|
|
29
|
+
dq?: string | undefined;
|
|
30
|
+
qi?: string | undefined;
|
|
31
|
+
oth?: {
|
|
32
|
+
r?: string | undefined;
|
|
33
|
+
d?: string | undefined;
|
|
34
|
+
t?: string | undefined;
|
|
35
|
+
}[] | undefined;
|
|
36
|
+
} | {
|
|
37
|
+
kid?: string | undefined;
|
|
38
|
+
use?: "enc" | "sig" | undefined;
|
|
39
|
+
key_ops?: ("decrypt" | "deriveBits" | "deriveKey" | "encrypt" | "sign" | "unwrapKey" | "verify" | "wrapKey")[] | undefined;
|
|
40
|
+
x5c?: string[] | undefined;
|
|
41
|
+
x5t?: string | undefined;
|
|
42
|
+
'x5t#S256'?: string | undefined;
|
|
43
|
+
x5u?: string | undefined;
|
|
44
|
+
ext?: boolean | undefined;
|
|
45
|
+
iat?: number | undefined;
|
|
46
|
+
exp?: number | undefined;
|
|
47
|
+
nbf?: number | undefined;
|
|
48
|
+
revoked?: {
|
|
49
|
+
revoked_at: number;
|
|
50
|
+
reason?: string | undefined;
|
|
51
|
+
} | undefined;
|
|
52
|
+
kty: "EC";
|
|
53
|
+
alg?: "ES256" | "ES384" | "ES512" | undefined;
|
|
54
|
+
crv: "P-256" | "P-384" | "P-521";
|
|
55
|
+
x: string;
|
|
56
|
+
y: string;
|
|
57
|
+
d?: string | undefined;
|
|
58
|
+
} | {
|
|
59
|
+
kid?: string | undefined;
|
|
60
|
+
use?: "enc" | "sig" | undefined;
|
|
61
|
+
key_ops?: ("decrypt" | "deriveBits" | "deriveKey" | "encrypt" | "sign" | "unwrapKey" | "verify" | "wrapKey")[] | undefined;
|
|
62
|
+
x5c?: string[] | undefined;
|
|
63
|
+
x5t?: string | undefined;
|
|
64
|
+
'x5t#S256'?: string | undefined;
|
|
65
|
+
x5u?: string | undefined;
|
|
66
|
+
ext?: boolean | undefined;
|
|
67
|
+
iat?: number | undefined;
|
|
68
|
+
exp?: number | undefined;
|
|
69
|
+
nbf?: number | undefined;
|
|
70
|
+
revoked?: {
|
|
71
|
+
revoked_at: number;
|
|
72
|
+
reason?: string | undefined;
|
|
73
|
+
} | undefined;
|
|
74
|
+
kty: "EC";
|
|
75
|
+
alg?: "ES256K" | undefined;
|
|
76
|
+
crv: "secp256k1";
|
|
77
|
+
x: string;
|
|
78
|
+
y: string;
|
|
79
|
+
d?: string | undefined;
|
|
80
|
+
} | {
|
|
81
|
+
kid?: string | undefined;
|
|
82
|
+
use?: "enc" | "sig" | undefined;
|
|
83
|
+
key_ops?: ("decrypt" | "deriveBits" | "deriveKey" | "encrypt" | "sign" | "unwrapKey" | "verify" | "wrapKey")[] | undefined;
|
|
84
|
+
x5c?: string[] | undefined;
|
|
85
|
+
x5t?: string | undefined;
|
|
86
|
+
'x5t#S256'?: string | undefined;
|
|
87
|
+
x5u?: string | undefined;
|
|
88
|
+
ext?: boolean | undefined;
|
|
89
|
+
iat?: number | undefined;
|
|
90
|
+
exp?: number | undefined;
|
|
91
|
+
nbf?: number | undefined;
|
|
92
|
+
revoked?: {
|
|
93
|
+
revoked_at: number;
|
|
94
|
+
reason?: string | undefined;
|
|
95
|
+
} | undefined;
|
|
96
|
+
kty: "OKP";
|
|
97
|
+
alg?: "EdDSA" | undefined;
|
|
98
|
+
crv: "Ed25519" | "Ed448";
|
|
99
|
+
x: string;
|
|
100
|
+
d?: string | undefined;
|
|
101
|
+
} | {
|
|
102
|
+
kid?: string | undefined;
|
|
103
|
+
use?: "enc" | "sig" | undefined;
|
|
104
|
+
key_ops?: ("decrypt" | "deriveBits" | "deriveKey" | "encrypt" | "sign" | "unwrapKey" | "verify" | "wrapKey")[] | undefined;
|
|
105
|
+
x5c?: string[] | undefined;
|
|
106
|
+
x5t?: string | undefined;
|
|
107
|
+
'x5t#S256'?: string | undefined;
|
|
108
|
+
x5u?: string | undefined;
|
|
109
|
+
ext?: boolean | undefined;
|
|
110
|
+
iat?: number | undefined;
|
|
111
|
+
exp?: number | undefined;
|
|
112
|
+
nbf?: number | undefined;
|
|
113
|
+
revoked?: {
|
|
114
|
+
revoked_at: number;
|
|
115
|
+
reason?: string | undefined;
|
|
116
|
+
} | undefined;
|
|
117
|
+
kty: "oct";
|
|
118
|
+
alg?: "HS256" | "HS384" | "HS512" | undefined;
|
|
119
|
+
k: string;
|
|
120
|
+
}>;
|
|
121
|
+
/** public JWK schema (kid required, no private keys) */
|
|
122
|
+
export declare const jwkPubSchema: v.Type<{
|
|
123
|
+
kid?: string | undefined;
|
|
124
|
+
use?: "enc" | "sig" | undefined;
|
|
125
|
+
key_ops?: ("decrypt" | "deriveBits" | "deriveKey" | "encrypt" | "sign" | "unwrapKey" | "verify" | "wrapKey")[] | undefined;
|
|
126
|
+
x5c?: string[] | undefined;
|
|
127
|
+
x5t?: string | undefined;
|
|
128
|
+
'x5t#S256'?: string | undefined;
|
|
129
|
+
x5u?: string | undefined;
|
|
130
|
+
ext?: boolean | undefined;
|
|
131
|
+
iat?: number | undefined;
|
|
132
|
+
exp?: number | undefined;
|
|
133
|
+
nbf?: number | undefined;
|
|
134
|
+
revoked?: {
|
|
135
|
+
revoked_at: number;
|
|
136
|
+
reason?: string | undefined;
|
|
137
|
+
} | undefined;
|
|
138
|
+
kty: "RSA";
|
|
139
|
+
alg?: "PS256" | "PS384" | "PS512" | "RS256" | "RS384" | "RS512" | undefined;
|
|
140
|
+
n: string;
|
|
141
|
+
e: string;
|
|
142
|
+
d?: string | undefined;
|
|
143
|
+
p?: string | undefined;
|
|
144
|
+
q?: string | undefined;
|
|
145
|
+
dp?: string | undefined;
|
|
146
|
+
dq?: string | undefined;
|
|
147
|
+
qi?: string | undefined;
|
|
148
|
+
oth?: {
|
|
149
|
+
r?: string | undefined;
|
|
150
|
+
d?: string | undefined;
|
|
151
|
+
t?: string | undefined;
|
|
152
|
+
}[] | undefined;
|
|
153
|
+
} | {
|
|
154
|
+
kid?: string | undefined;
|
|
155
|
+
use?: "enc" | "sig" | undefined;
|
|
156
|
+
key_ops?: ("decrypt" | "deriveBits" | "deriveKey" | "encrypt" | "sign" | "unwrapKey" | "verify" | "wrapKey")[] | undefined;
|
|
157
|
+
x5c?: string[] | undefined;
|
|
158
|
+
x5t?: string | undefined;
|
|
159
|
+
'x5t#S256'?: string | undefined;
|
|
160
|
+
x5u?: string | undefined;
|
|
161
|
+
ext?: boolean | undefined;
|
|
162
|
+
iat?: number | undefined;
|
|
163
|
+
exp?: number | undefined;
|
|
164
|
+
nbf?: number | undefined;
|
|
165
|
+
revoked?: {
|
|
166
|
+
revoked_at: number;
|
|
167
|
+
reason?: string | undefined;
|
|
168
|
+
} | undefined;
|
|
169
|
+
kty: "EC";
|
|
170
|
+
alg?: "ES256" | "ES384" | "ES512" | undefined;
|
|
171
|
+
crv: "P-256" | "P-384" | "P-521";
|
|
172
|
+
x: string;
|
|
173
|
+
y: string;
|
|
174
|
+
d?: string | undefined;
|
|
175
|
+
} | {
|
|
176
|
+
kid?: string | undefined;
|
|
177
|
+
use?: "enc" | "sig" | undefined;
|
|
178
|
+
key_ops?: ("decrypt" | "deriveBits" | "deriveKey" | "encrypt" | "sign" | "unwrapKey" | "verify" | "wrapKey")[] | undefined;
|
|
179
|
+
x5c?: string[] | undefined;
|
|
180
|
+
x5t?: string | undefined;
|
|
181
|
+
'x5t#S256'?: string | undefined;
|
|
182
|
+
x5u?: string | undefined;
|
|
183
|
+
ext?: boolean | undefined;
|
|
184
|
+
iat?: number | undefined;
|
|
185
|
+
exp?: number | undefined;
|
|
186
|
+
nbf?: number | undefined;
|
|
187
|
+
revoked?: {
|
|
188
|
+
revoked_at: number;
|
|
189
|
+
reason?: string | undefined;
|
|
190
|
+
} | undefined;
|
|
191
|
+
kty: "EC";
|
|
192
|
+
alg?: "ES256K" | undefined;
|
|
193
|
+
crv: "secp256k1";
|
|
194
|
+
x: string;
|
|
195
|
+
y: string;
|
|
196
|
+
d?: string | undefined;
|
|
197
|
+
} | {
|
|
198
|
+
kid?: string | undefined;
|
|
199
|
+
use?: "enc" | "sig" | undefined;
|
|
200
|
+
key_ops?: ("decrypt" | "deriveBits" | "deriveKey" | "encrypt" | "sign" | "unwrapKey" | "verify" | "wrapKey")[] | undefined;
|
|
201
|
+
x5c?: string[] | undefined;
|
|
202
|
+
x5t?: string | undefined;
|
|
203
|
+
'x5t#S256'?: string | undefined;
|
|
204
|
+
x5u?: string | undefined;
|
|
205
|
+
ext?: boolean | undefined;
|
|
206
|
+
iat?: number | undefined;
|
|
207
|
+
exp?: number | undefined;
|
|
208
|
+
nbf?: number | undefined;
|
|
209
|
+
revoked?: {
|
|
210
|
+
revoked_at: number;
|
|
211
|
+
reason?: string | undefined;
|
|
212
|
+
} | undefined;
|
|
213
|
+
kty: "OKP";
|
|
214
|
+
alg?: "EdDSA" | undefined;
|
|
215
|
+
crv: "Ed25519" | "Ed448";
|
|
216
|
+
x: string;
|
|
217
|
+
d?: string | undefined;
|
|
218
|
+
} | {
|
|
219
|
+
kid?: string | undefined;
|
|
220
|
+
use?: "enc" | "sig" | undefined;
|
|
221
|
+
key_ops?: ("decrypt" | "deriveBits" | "deriveKey" | "encrypt" | "sign" | "unwrapKey" | "verify" | "wrapKey")[] | undefined;
|
|
222
|
+
x5c?: string[] | undefined;
|
|
223
|
+
x5t?: string | undefined;
|
|
224
|
+
'x5t#S256'?: string | undefined;
|
|
225
|
+
x5u?: string | undefined;
|
|
226
|
+
ext?: boolean | undefined;
|
|
227
|
+
iat?: number | undefined;
|
|
228
|
+
exp?: number | undefined;
|
|
229
|
+
nbf?: number | undefined;
|
|
230
|
+
revoked?: {
|
|
231
|
+
revoked_at: number;
|
|
232
|
+
reason?: string | undefined;
|
|
233
|
+
} | undefined;
|
|
234
|
+
kty: "oct";
|
|
235
|
+
alg?: "HS256" | "HS384" | "HS512" | undefined;
|
|
236
|
+
k: string;
|
|
237
|
+
}>;
|
|
238
|
+
export type KeyUsage = v.Infer<typeof keyUsageSchema>;
|
|
239
|
+
export type Jwk = v.Infer<typeof jwkSchema>;
|
|
240
|
+
export type JwkPub = v.Infer<typeof jwkPubSchema>;
|
|
241
|
+
//# sourceMappingURL=jwk.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jwk.d.ts","sourceRoot":"","sources":["../../lib/schemas/jwk.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AAsBpC,eAAO,MAAM,cAAc,0KAS1B,CAAC;AAEF,eAAO,MAAM,oBAAoB,uEAA2E,CAAC;AAqG7G,qCAAqC;AACrC,eAAO,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA6BnB,CAAC;AAEJ,wDAAwD;AACxD,eAAO,MAAM,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAiBvB,CAAC;AAEH,MAAM,MAAM,QAAQ,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,cAAc,CAAC,CAAC;AACtD,MAAM,MAAM,GAAG,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,SAAS,CAAC,CAAC;AAC5C,MAAM,MAAM,MAAM,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,YAAY,CAAC,CAAC"}
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import * as v from '@badrap/valita';
|
|
2
|
+
import { isLastOccurrence } from './utils.js';
|
|
3
|
+
// key usage constants
|
|
4
|
+
const PUBLIC_KEY_USAGE = ['verify', 'encrypt', 'wrapKey'];
|
|
5
|
+
const PRIVATE_KEY_USAGE = ['sign', 'decrypt', 'unwrapKey', 'deriveKey', 'deriveBits'];
|
|
6
|
+
const KEY_USAGE = [...PRIVATE_KEY_USAGE, ...PUBLIC_KEY_USAGE];
|
|
7
|
+
const isPublicKeyUsage = (usage) => {
|
|
8
|
+
return PUBLIC_KEY_USAGE.includes(usage);
|
|
9
|
+
};
|
|
10
|
+
const isPrivateKeyUsage = (usage) => {
|
|
11
|
+
return PRIVATE_KEY_USAGE.includes(usage);
|
|
12
|
+
};
|
|
13
|
+
const isSigKeyUsage = (v) => v === 'verify';
|
|
14
|
+
const isEncKeyUsage = (v) => v === 'encrypt' || v === 'wrapKey';
|
|
15
|
+
export const keyUsageSchema = v.union(v.literal('verify'), v.literal('encrypt'), v.literal('wrapKey'), v.literal('sign'), v.literal('decrypt'), v.literal('unwrapKey'), v.literal('deriveKey'), v.literal('deriveBits'));
|
|
16
|
+
export const publicKeyUsageSchema = v.union(v.literal('verify'), v.literal('encrypt'), v.literal('wrapKey'));
|
|
17
|
+
const jwkBaseSchema = v.object({
|
|
18
|
+
kty: v.string(),
|
|
19
|
+
alg: v.string().optional(),
|
|
20
|
+
kid: v.string().optional(),
|
|
21
|
+
use: v.union(v.literal('sig'), v.literal('enc')).optional(),
|
|
22
|
+
key_ops: v.array(keyUsageSchema).optional(),
|
|
23
|
+
// X.509
|
|
24
|
+
x5c: v.array(v.string()).optional(),
|
|
25
|
+
x5t: v.string().optional(),
|
|
26
|
+
'x5t#S256': v.string().optional(),
|
|
27
|
+
x5u: v.string().optional(),
|
|
28
|
+
// WebCrypto
|
|
29
|
+
ext: v.boolean().optional(),
|
|
30
|
+
// Federation Historical Keys Response
|
|
31
|
+
iat: v.number().optional(),
|
|
32
|
+
exp: v.number().optional(),
|
|
33
|
+
nbf: v.number().optional(),
|
|
34
|
+
revoked: v
|
|
35
|
+
.object({
|
|
36
|
+
revoked_at: v.number(),
|
|
37
|
+
reason: v.string().optional(),
|
|
38
|
+
})
|
|
39
|
+
.optional(),
|
|
40
|
+
});
|
|
41
|
+
const jwkRsaKeySchema = jwkBaseSchema.extend({
|
|
42
|
+
kty: v.literal('RSA'),
|
|
43
|
+
alg: v
|
|
44
|
+
.union(v.literal('RS256'), v.literal('RS384'), v.literal('RS512'), v.literal('PS256'), v.literal('PS384'), v.literal('PS512'))
|
|
45
|
+
.optional(),
|
|
46
|
+
n: v.string(),
|
|
47
|
+
e: v.string(),
|
|
48
|
+
d: v.string().optional(),
|
|
49
|
+
p: v.string().optional(),
|
|
50
|
+
q: v.string().optional(),
|
|
51
|
+
dp: v.string().optional(),
|
|
52
|
+
dq: v.string().optional(),
|
|
53
|
+
qi: v.string().optional(),
|
|
54
|
+
oth: v
|
|
55
|
+
.array(v.object({
|
|
56
|
+
r: v.string().optional(),
|
|
57
|
+
d: v.string().optional(),
|
|
58
|
+
t: v.string().optional(),
|
|
59
|
+
}))
|
|
60
|
+
.optional(),
|
|
61
|
+
});
|
|
62
|
+
const jwkEcKeySchema = jwkBaseSchema.extend({
|
|
63
|
+
kty: v.literal('EC'),
|
|
64
|
+
alg: v.union(v.literal('ES256'), v.literal('ES384'), v.literal('ES512')).optional(),
|
|
65
|
+
crv: v.union(v.literal('P-256'), v.literal('P-384'), v.literal('P-521')),
|
|
66
|
+
x: v.string(),
|
|
67
|
+
y: v.string(),
|
|
68
|
+
d: v.string().optional(),
|
|
69
|
+
});
|
|
70
|
+
const jwkEcSecp256k1KeySchema = jwkBaseSchema.extend({
|
|
71
|
+
kty: v.literal('EC'),
|
|
72
|
+
alg: v.literal('ES256K').optional(),
|
|
73
|
+
crv: v.literal('secp256k1'),
|
|
74
|
+
x: v.string(),
|
|
75
|
+
y: v.string(),
|
|
76
|
+
d: v.string().optional(),
|
|
77
|
+
});
|
|
78
|
+
const jwkOkpKeySchema = jwkBaseSchema.extend({
|
|
79
|
+
kty: v.literal('OKP'),
|
|
80
|
+
alg: v.literal('EdDSA').optional(),
|
|
81
|
+
crv: v.union(v.literal('Ed25519'), v.literal('Ed448')),
|
|
82
|
+
x: v.string(),
|
|
83
|
+
d: v.string().optional(),
|
|
84
|
+
});
|
|
85
|
+
const jwkSymKeySchema = jwkBaseSchema.extend({
|
|
86
|
+
kty: v.literal('oct'),
|
|
87
|
+
alg: v.union(v.literal('HS256'), v.literal('HS384'), v.literal('HS512')).optional(),
|
|
88
|
+
k: v.string(),
|
|
89
|
+
});
|
|
90
|
+
const hasPrivateSecret = (jwk) => {
|
|
91
|
+
return ('d' in jwk && jwk.d != null) || ('k' in jwk && jwk.k != null);
|
|
92
|
+
};
|
|
93
|
+
const isPublicJwk = (jwk) => {
|
|
94
|
+
return !hasPrivateSecret(jwk);
|
|
95
|
+
};
|
|
96
|
+
/** JWK schema for known key types */
|
|
97
|
+
export const jwkSchema = v
|
|
98
|
+
.union(jwkRsaKeySchema, jwkEcKeySchema, jwkEcSecp256k1KeySchema, jwkOkpKeySchema, jwkSymKeySchema)
|
|
99
|
+
.chain((k) => {
|
|
100
|
+
// "use" can only be used with public keys
|
|
101
|
+
if (k.use != null && !isPublicJwk(k)) {
|
|
102
|
+
return v.err({ message: `"use" can only be used with public keys`, path: ['use'] });
|
|
103
|
+
}
|
|
104
|
+
// private key usage not allowed for public keys
|
|
105
|
+
if (k.key_ops?.some(isPrivateKeyUsage) && isPublicJwk(k)) {
|
|
106
|
+
return v.err({ message: `private key usage not allowed for public keys`, path: ['key_ops'] });
|
|
107
|
+
}
|
|
108
|
+
// key_ops must not contain duplicates
|
|
109
|
+
if (k.key_ops && !k.key_ops.every(isLastOccurrence)) {
|
|
110
|
+
return v.err({ message: `key_ops must not contain duplicates`, path: ['key_ops'] });
|
|
111
|
+
}
|
|
112
|
+
// "use" and "key_ops" must be consistent
|
|
113
|
+
if (k.use != null && k.key_ops != null) {
|
|
114
|
+
const consistent = (k.use === 'sig' && k.key_ops.every(isSigKeyUsage)) ||
|
|
115
|
+
(k.use === 'enc' && k.key_ops.every(isEncKeyUsage));
|
|
116
|
+
if (!consistent) {
|
|
117
|
+
return v.err({ message: `"key_ops" must be consistent with "use"`, path: ['key_ops'] });
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
return v.ok(k);
|
|
121
|
+
});
|
|
122
|
+
/** public JWK schema (kid required, no private keys) */
|
|
123
|
+
export const jwkPubSchema = jwkSchema.chain((k) => {
|
|
124
|
+
if (k.kid == null) {
|
|
125
|
+
return v.err({ message: `"kid" is required`, path: ['kid'] });
|
|
126
|
+
}
|
|
127
|
+
if (!isPublicJwk(k)) {
|
|
128
|
+
return v.err({ message: `private key not allowed` });
|
|
129
|
+
}
|
|
130
|
+
if (k.key_ops && !k.key_ops.every(isPublicKeyUsage)) {
|
|
131
|
+
return v.err({
|
|
132
|
+
message: `"key_ops" must not contain private key usage for public keys`,
|
|
133
|
+
path: ['key_ops'],
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
return v.ok(k);
|
|
137
|
+
});
|
|
138
|
+
//# sourceMappingURL=jwk.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jwk.js","sourceRoot":"","sources":["../../lib/schemas/jwk.ts"],"names":[],"mappings":"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"}
|