@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.
Files changed (158) hide show
  1. package/LICENSE +14 -0
  2. package/README.md +48 -0
  3. package/dist/build-client-metadata.d.ts +168 -0
  4. package/dist/build-client-metadata.d.ts.map +1 -0
  5. package/dist/build-client-metadata.js +53 -0
  6. package/dist/build-client-metadata.js.map +1 -0
  7. package/dist/constants.d.ts +5 -0
  8. package/dist/constants.d.ts.map +1 -0
  9. package/dist/constants.js +5 -0
  10. package/dist/constants.js.map +1 -0
  11. package/dist/index.d.ts +31 -0
  12. package/dist/index.d.ts.map +1 -0
  13. package/dist/index.js +37 -0
  14. package/dist/index.js.map +1 -0
  15. package/dist/schemas/atcute-confidential-client-metadata.d.ts +21 -0
  16. package/dist/schemas/atcute-confidential-client-metadata.d.ts.map +1 -0
  17. package/dist/schemas/atcute-confidential-client-metadata.js +112 -0
  18. package/dist/schemas/atcute-confidential-client-metadata.js.map +1 -0
  19. package/dist/schemas/atproto-authorization-server-metadata.d.ts +55 -0
  20. package/dist/schemas/atproto-authorization-server-metadata.d.ts.map +1 -0
  21. package/dist/schemas/atproto-authorization-server-metadata.js +25 -0
  22. package/dist/schemas/atproto-authorization-server-metadata.js.map +1 -0
  23. package/dist/schemas/atproto-oauth-scope.d.ts +8 -0
  24. package/dist/schemas/atproto-oauth-scope.d.ts.map +1 -0
  25. package/dist/schemas/atproto-oauth-scope.js +12 -0
  26. package/dist/schemas/atproto-oauth-scope.js.map +1 -0
  27. package/dist/schemas/atproto-oauth-token-response.d.ts +19 -0
  28. package/dist/schemas/atproto-oauth-token-response.d.ts.map +1 -0
  29. package/dist/schemas/atproto-oauth-token-response.js +16 -0
  30. package/dist/schemas/atproto-oauth-token-response.js.map +1 -0
  31. package/dist/schemas/atproto-protected-resource-metadata.d.ts +21 -0
  32. package/dist/schemas/atproto-protected-resource-metadata.d.ts.map +1 -0
  33. package/dist/schemas/atproto-protected-resource-metadata.js +18 -0
  34. package/dist/schemas/atproto-protected-resource-metadata.js.map +1 -0
  35. package/dist/schemas/jwk.d.ts +241 -0
  36. package/dist/schemas/jwk.d.ts.map +1 -0
  37. package/dist/schemas/jwk.js +138 -0
  38. package/dist/schemas/jwk.js.map +1 -0
  39. package/dist/schemas/jwks.d.ts +242 -0
  40. package/dist/schemas/jwks.d.ts.map +1 -0
  41. package/dist/schemas/jwks.js +34 -0
  42. package/dist/schemas/jwks.js.map +1 -0
  43. package/dist/schemas/oauth-authorization-details.d.ts +64 -0
  44. package/dist/schemas/oauth-authorization-details.d.ts.map +1 -0
  45. package/dist/schemas/oauth-authorization-details.js +37 -0
  46. package/dist/schemas/oauth-authorization-details.js.map +1 -0
  47. package/dist/schemas/oauth-authorization-server-metadata.d.ts +96 -0
  48. package/dist/schemas/oauth-authorization-server-metadata.d.ts.map +1 -0
  49. package/dist/schemas/oauth-authorization-server-metadata.js +81 -0
  50. package/dist/schemas/oauth-authorization-server-metadata.js.map +1 -0
  51. package/dist/schemas/oauth-client-id-discoverable.d.ts +6 -0
  52. package/dist/schemas/oauth-client-id-discoverable.d.ts.map +1 -0
  53. package/dist/schemas/oauth-client-id-discoverable.js +43 -0
  54. package/dist/schemas/oauth-client-id-discoverable.js.map +1 -0
  55. package/dist/schemas/oauth-client-id.d.ts +5 -0
  56. package/dist/schemas/oauth-client-id.d.ts.map +1 -0
  57. package/dist/schemas/oauth-client-id.js +4 -0
  58. package/dist/schemas/oauth-client-id.js.map +1 -0
  59. package/dist/schemas/oauth-client-metadata.d.ts +164 -0
  60. package/dist/schemas/oauth-client-metadata.d.ts.map +1 -0
  61. package/dist/schemas/oauth-client-metadata.js +74 -0
  62. package/dist/schemas/oauth-client-metadata.js.map +1 -0
  63. package/dist/schemas/oauth-code-challenge-method.d.ts +4 -0
  64. package/dist/schemas/oauth-code-challenge-method.d.ts.map +1 -0
  65. package/dist/schemas/oauth-code-challenge-method.js +3 -0
  66. package/dist/schemas/oauth-code-challenge-method.js.map +1 -0
  67. package/dist/schemas/oauth-endpoint-auth-method.d.ts +4 -0
  68. package/dist/schemas/oauth-endpoint-auth-method.d.ts.map +1 -0
  69. package/dist/schemas/oauth-endpoint-auth-method.js +3 -0
  70. package/dist/schemas/oauth-endpoint-auth-method.js.map +1 -0
  71. package/dist/schemas/oauth-grant-type.d.ts +4 -0
  72. package/dist/schemas/oauth-grant-type.d.ts.map +1 -0
  73. package/dist/schemas/oauth-grant-type.js +4 -0
  74. package/dist/schemas/oauth-grant-type.js.map +1 -0
  75. package/dist/schemas/oauth-issuer-identifier.d.ts +4 -0
  76. package/dist/schemas/oauth-issuer-identifier.d.ts.map +1 -0
  77. package/dist/schemas/oauth-issuer-identifier.js +21 -0
  78. package/dist/schemas/oauth-issuer-identifier.js.map +1 -0
  79. package/dist/schemas/oauth-par-response.d.ts +7 -0
  80. package/dist/schemas/oauth-par-response.d.ts.map +1 -0
  81. package/dist/schemas/oauth-par-response.js +7 -0
  82. package/dist/schemas/oauth-par-response.js.map +1 -0
  83. package/dist/schemas/oauth-prompt.d.ts +13 -0
  84. package/dist/schemas/oauth-prompt.d.ts.map +1 -0
  85. package/dist/schemas/oauth-prompt.js +12 -0
  86. package/dist/schemas/oauth-prompt.js.map +1 -0
  87. package/dist/schemas/oauth-protected-resource-metadata.d.ts +66 -0
  88. package/dist/schemas/oauth-protected-resource-metadata.d.ts.map +1 -0
  89. package/dist/schemas/oauth-protected-resource-metadata.js +71 -0
  90. package/dist/schemas/oauth-protected-resource-metadata.js.map +1 -0
  91. package/dist/schemas/oauth-redirect-uri.d.ts +20 -0
  92. package/dist/schemas/oauth-redirect-uri.d.ts.map +1 -0
  93. package/dist/schemas/oauth-redirect-uri.js +32 -0
  94. package/dist/schemas/oauth-redirect-uri.js.map +1 -0
  95. package/dist/schemas/oauth-response-mode.d.ts +4 -0
  96. package/dist/schemas/oauth-response-mode.d.ts.map +1 -0
  97. package/dist/schemas/oauth-response-mode.js +3 -0
  98. package/dist/schemas/oauth-response-mode.js.map +1 -0
  99. package/dist/schemas/oauth-response-type.d.ts +4 -0
  100. package/dist/schemas/oauth-response-type.d.ts.map +1 -0
  101. package/dist/schemas/oauth-response-type.js +8 -0
  102. package/dist/schemas/oauth-response-type.js.map +1 -0
  103. package/dist/schemas/oauth-scope.d.ts +12 -0
  104. package/dist/schemas/oauth-scope.d.ts.map +1 -0
  105. package/dist/schemas/oauth-scope.js +14 -0
  106. package/dist/schemas/oauth-scope.js.map +1 -0
  107. package/dist/schemas/oauth-token-response.d.ts +22 -0
  108. package/dist/schemas/oauth-token-response.d.ts.map +1 -0
  109. package/dist/schemas/oauth-token-response.js +19 -0
  110. package/dist/schemas/oauth-token-response.js.map +1 -0
  111. package/dist/schemas/oauth-token-type.d.ts +5 -0
  112. package/dist/schemas/oauth-token-type.d.ts.map +1 -0
  113. package/dist/schemas/oauth-token-type.js +13 -0
  114. package/dist/schemas/oauth-token-type.js.map +1 -0
  115. package/dist/schemas/uri.d.ts +18 -0
  116. package/dist/schemas/uri.d.ts.map +1 -0
  117. package/dist/schemas/uri.js +81 -0
  118. package/dist/schemas/uri.js.map +1 -0
  119. package/dist/schemas/utils.d.ts +32 -0
  120. package/dist/schemas/utils.d.ts.map +1 -0
  121. package/dist/schemas/utils.js +94 -0
  122. package/dist/schemas/utils.js.map +1 -0
  123. package/dist/scope.d.ts +84 -0
  124. package/dist/scope.d.ts.map +1 -0
  125. package/dist/scope.js +102 -0
  126. package/dist/scope.js.map +1 -0
  127. package/lib/build-client-metadata.ts +72 -0
  128. package/lib/constants.ts +5 -0
  129. package/lib/index.ts +116 -0
  130. package/lib/schemas/atcute-confidential-client-metadata.ts +139 -0
  131. package/lib/schemas/atproto-authorization-server-metadata.ts +32 -0
  132. package/lib/schemas/atproto-oauth-scope.ts +18 -0
  133. package/lib/schemas/atproto-oauth-token-response.ts +20 -0
  134. package/lib/schemas/atproto-protected-resource-metadata.ts +24 -0
  135. package/lib/schemas/jwk.ts +189 -0
  136. package/lib/schemas/jwks.ts +45 -0
  137. package/lib/schemas/oauth-authorization-details.ts +43 -0
  138. package/lib/schemas/oauth-authorization-server-metadata.ts +101 -0
  139. package/lib/schemas/oauth-client-id-discoverable.ts +53 -0
  140. package/lib/schemas/oauth-client-id.ts +6 -0
  141. package/lib/schemas/oauth-client-metadata.ts +83 -0
  142. package/lib/schemas/oauth-code-challenge-method.ts +5 -0
  143. package/lib/schemas/oauth-endpoint-auth-method.ts +13 -0
  144. package/lib/schemas/oauth-grant-type.ts +13 -0
  145. package/lib/schemas/oauth-issuer-identifier.ts +30 -0
  146. package/lib/schemas/oauth-par-response.ts +10 -0
  147. package/lib/schemas/oauth-prompt.ts +20 -0
  148. package/lib/schemas/oauth-protected-resource-metadata.ts +89 -0
  149. package/lib/schemas/oauth-redirect-uri.ts +42 -0
  150. package/lib/schemas/oauth-response-mode.ts +9 -0
  151. package/lib/schemas/oauth-response-type.ts +17 -0
  152. package/lib/schemas/oauth-scope.ts +18 -0
  153. package/lib/schemas/oauth-token-response.ts +22 -0
  154. package/lib/schemas/oauth-token-type.ts +15 -0
  155. package/lib/schemas/uri.ts +100 -0
  156. package/lib/schemas/utils.ts +113 -0
  157. package/lib/scope.ts +187 -0
  158. 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":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAC;AAEpC,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAE9C,sBAAsB;AACtB,MAAM,gBAAgB,GAAG,CAAC,QAAQ,EAAE,SAAS,EAAE,SAAS,CAAU,CAAC;AACnE,MAAM,iBAAiB,GAAG,CAAC,MAAM,EAAE,SAAS,EAAE,WAAW,EAAE,WAAW,EAAE,YAAY,CAAU,CAAC;AAC/F,MAAM,SAAS,GAAG,CAAC,GAAG,iBAAiB,EAAE,GAAG,gBAAgB,CAAU,CAAC;AAIvE,MAAM,gBAAgB,GAAG,CAAC,KAAc,EAA8C,EAAE,CAAC;IACxF,OAAQ,gBAAuC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;AAAA,CAChE,CAAC;AAEF,MAAM,iBAAiB,GAAG,CAAC,KAAc,EAA+C,EAAE,CAAC;IAC1F,OAAQ,iBAAwC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;AAAA,CACjE,CAAC;AAEF,MAAM,aAAa,GAAG,CAAC,CAAmB,EAAW,EAAE,CAAC,CAAC,KAAK,QAAQ,CAAC;AACvE,MAAM,aAAa,GAAG,CAAC,CAAmB,EAAW,EAAE,CAAC,CAAC,KAAK,SAAS,IAAI,CAAC,KAAK,SAAS,CAAC;AAE3F,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,CAAC,KAAK,CACpC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,EACnB,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,EACpB,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,EACpB,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,EACjB,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,EACpB,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,EACtB,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,EACtB,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CACvB,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC;AAE7G,MAAM,aAAa,GAAG,CAAC,CAAC,MAAM,CAAC;IAC9B,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE;IACf,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC1B,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC1B,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,EAAE;IAC3D,OAAO,EAAE,CAAC,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,QAAQ,EAAE;IAE3C,QAAQ;IACR,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE;IACnC,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC1B,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACjC,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAE1B,YAAY;IACZ,GAAG,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE;IAE3B,sCAAsC;IACtC,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC1B,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC1B,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC1B,OAAO,EAAE,CAAC;SACR,MAAM,CAAC;QACP,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE;QACtB,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;KAC7B,CAAC;SACD,QAAQ,EAAE;CACZ,CAAC,CAAC;AAEH,MAAM,eAAe,GAAG,aAAa,CAAC,MAAM,CAAC;IAC5C,GAAG,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;IACrB,GAAG,EAAE,CAAC;SACJ,KAAK,CACL,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAClB,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAClB,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAClB,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAClB,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAClB,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAClB;SACA,QAAQ,EAAE;IACZ,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE;IACb,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE;IACb,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACxB,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACxB,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACxB,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACzB,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACzB,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACzB,GAAG,EAAE,CAAC;SACJ,KAAK,CACL,CAAC,CAAC,MAAM,CAAC;QACR,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;QACxB,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;QACxB,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;KACxB,CAAC,CACF;SACA,QAAQ,EAAE;CACZ,CAAC,CAAC;AAEH,MAAM,cAAc,GAAG,aAAa,CAAC,MAAM,CAAC;IAC3C,GAAG,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC;IACpB,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,EAAE;IACnF,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IACxE,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE;IACb,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE;IACb,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACxB,CAAC,CAAC;AAEH,MAAM,uBAAuB,GAAG,aAAa,CAAC,MAAM,CAAC;IACpD,GAAG,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC;IACpB,GAAG,EAAE,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,EAAE;IACnC,GAAG,EAAE,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC;IAC3B,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE;IACb,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE;IACb,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACxB,CAAC,CAAC;AAEH,MAAM,eAAe,GAAG,aAAa,CAAC,MAAM,CAAC;IAC5C,GAAG,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;IACrB,GAAG,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE;IAClC,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IACtD,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE;IACb,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACxB,CAAC,CAAC;AAEH,MAAM,eAAe,GAAG,aAAa,CAAC,MAAM,CAAC;IAC5C,GAAG,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;IACrB,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,EAAE;IACnF,CAAC,EAAE,CAAC,CAAC,MAAM,EAAE;CACb,CAAC,CAAC;AAEH,MAAM,gBAAgB,GAAG,CAAmB,GAAM,EAAW,EAAE,CAAC;IAC/D,OAAO,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC;AAAA,CACtE,CAAC;AAEF,MAAM,WAAW,GAAG,CAAmB,GAAM,EAAW,EAAE,CAAC;IAC1D,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;AAAA,CAC9B,CAAC;AAEF,qCAAqC;AACrC,MAAM,CAAC,MAAM,SAAS,GAAG,CAAC;KACxB,KAAK,CAAC,eAAe,EAAE,cAAc,EAAE,uBAAuB,EAAE,eAAe,EAAE,eAAe,CAAC;KACjG,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;IACb,0CAA0C;IAC1C,IAAI,CAAC,CAAC,GAAG,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC;QACtC,OAAO,CAAC,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,yCAAyC,EAAE,IAAI,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IACrF,CAAC;IAED,gDAAgD;IAChD,IAAI,CAAC,CAAC,OAAO,EAAE,IAAI,CAAC,iBAAiB,CAAC,IAAI,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC;QAC1D,OAAO,CAAC,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,+CAA+C,EAAE,IAAI,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;IAC/F,CAAC;IAED,sCAAsC;IACtC,IAAI,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,gBAAgB,CAAC,EAAE,CAAC;QACrD,OAAO,CAAC,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,qCAAqC,EAAE,IAAI,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;IACrF,CAAC;IAED,yCAAyC;IACzC,IAAI,CAAC,CAAC,GAAG,IAAI,IAAI,IAAI,CAAC,CAAC,OAAO,IAAI,IAAI,EAAE,CAAC;QACxC,MAAM,UAAU,GACf,CAAC,CAAC,CAAC,GAAG,KAAK,KAAK,IAAI,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;YACnD,CAAC,CAAC,CAAC,GAAG,KAAK,KAAK,IAAI,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC;QACrD,IAAI,CAAC,UAAU,EAAE,CAAC;YACjB,OAAO,CAAC,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,yCAAyC,EAAE,IAAI,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;QACzF,CAAC;IACF,CAAC;IAED,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAAA,CACf,CAAC,CAAC;AAEJ,wDAAwD;AACxD,MAAM,CAAC,MAAM,YAAY,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;IAClD,IAAI,CAAC,CAAC,GAAG,IAAI,IAAI,EAAE,CAAC;QACnB,OAAO,CAAC,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,mBAAmB,EAAE,IAAI,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IAC/D,CAAC;IAED,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC;QACrB,OAAO,CAAC,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,yBAAyB,EAAE,CAAC,CAAC;IACtD,CAAC;IAED,IAAI,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,gBAAgB,CAAC,EAAE,CAAC;QACrD,OAAO,CAAC,CAAC,GAAG,CAAC;YACZ,OAAO,EAAE,8DAA8D;YACvE,IAAI,EAAE,CAAC,SAAS,CAAC;SACjB,CAAC,CAAC;IACJ,CAAC;IAED,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAAA,CACf,CAAC,CAAC"}