@robelest/convex-auth 0.0.1
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 +6 -0
- package/dist/bin.cjs +27733 -0
- package/dist/client/index.d.ts +49 -0
- package/dist/client/index.d.ts.map +1 -0
- package/dist/client/index.js +283 -0
- package/dist/client/index.js.map +1 -0
- package/dist/component/_generated/api.d.ts +36 -0
- package/dist/component/_generated/api.d.ts.map +1 -0
- package/dist/component/_generated/api.js +31 -0
- package/dist/component/_generated/api.js.map +1 -0
- package/dist/component/_generated/component.d.ts +295 -0
- package/dist/component/_generated/component.d.ts.map +1 -0
- package/dist/component/_generated/component.js +11 -0
- package/dist/component/_generated/component.js.map +1 -0
- package/dist/component/_generated/dataModel.d.ts +46 -0
- package/dist/component/_generated/dataModel.d.ts.map +1 -0
- package/dist/component/_generated/dataModel.js +11 -0
- package/dist/component/_generated/dataModel.js.map +1 -0
- package/dist/component/_generated/server.d.ts +121 -0
- package/dist/component/_generated/server.d.ts.map +1 -0
- package/dist/component/_generated/server.js +78 -0
- package/dist/component/_generated/server.js.map +1 -0
- package/dist/component/convex.config.d.ts +3 -0
- package/dist/component/convex.config.d.ts.map +1 -0
- package/dist/component/convex.config.js +4 -0
- package/dist/component/convex.config.js.map +1 -0
- package/dist/component/index.d.ts +15 -0
- package/dist/component/index.d.ts.map +1 -0
- package/dist/component/index.js +13 -0
- package/dist/component/index.js.map +1 -0
- package/dist/component/public.d.ts +450 -0
- package/dist/component/public.d.ts.map +1 -0
- package/dist/component/public.js +528 -0
- package/dist/component/public.js.map +1 -0
- package/dist/component/schema.d.ts +107 -0
- package/dist/component/schema.d.ts.map +1 -0
- package/dist/component/schema.js +26 -0
- package/dist/component/schema.js.map +1 -0
- package/dist/providers/Anonymous.d.ts +50 -0
- package/dist/providers/Anonymous.d.ts.map +1 -0
- package/dist/providers/Anonymous.js +39 -0
- package/dist/providers/Anonymous.js.map +1 -0
- package/dist/providers/ConvexCredentials.d.ts +88 -0
- package/dist/providers/ConvexCredentials.d.ts.map +1 -0
- package/dist/providers/ConvexCredentials.js +37 -0
- package/dist/providers/ConvexCredentials.js.map +1 -0
- package/dist/providers/Email.d.ts +33 -0
- package/dist/providers/Email.d.ts.map +1 -0
- package/dist/providers/Email.js +50 -0
- package/dist/providers/Email.js.map +1 -0
- package/dist/providers/Password.d.ts +95 -0
- package/dist/providers/Password.d.ts.map +1 -0
- package/dist/providers/Password.js +174 -0
- package/dist/providers/Password.js.map +1 -0
- package/dist/providers/Phone.d.ts +22 -0
- package/dist/providers/Phone.d.ts.map +1 -0
- package/dist/providers/Phone.js +37 -0
- package/dist/providers/Phone.js.map +1 -0
- package/dist/server/convex_types.d.ts +17 -0
- package/dist/server/convex_types.d.ts.map +1 -0
- package/dist/server/convex_types.js +2 -0
- package/dist/server/convex_types.js.map +1 -0
- package/dist/server/cookies.d.ts +35 -0
- package/dist/server/cookies.d.ts.map +1 -0
- package/dist/server/cookies.js +34 -0
- package/dist/server/cookies.js.map +1 -0
- package/dist/server/implementation/db.d.ts +80 -0
- package/dist/server/implementation/db.d.ts.map +1 -0
- package/dist/server/implementation/db.js +59 -0
- package/dist/server/implementation/db.js.map +1 -0
- package/dist/server/implementation/index.d.ts +370 -0
- package/dist/server/implementation/index.d.ts.map +1 -0
- package/dist/server/implementation/index.js +521 -0
- package/dist/server/implementation/index.js.map +1 -0
- package/dist/server/implementation/mutations/createAccountFromCredentials.d.ts +33 -0
- package/dist/server/implementation/mutations/createAccountFromCredentials.d.ts.map +1 -0
- package/dist/server/implementation/mutations/createAccountFromCredentials.js +71 -0
- package/dist/server/implementation/mutations/createAccountFromCredentials.js.map +1 -0
- package/dist/server/implementation/mutations/createVerificationCode.d.ts +25 -0
- package/dist/server/implementation/mutations/createVerificationCode.d.ts.map +1 -0
- package/dist/server/implementation/mutations/createVerificationCode.js +84 -0
- package/dist/server/implementation/mutations/createVerificationCode.js.map +1 -0
- package/dist/server/implementation/mutations/index.d.ts +304 -0
- package/dist/server/implementation/mutations/index.d.ts.map +1 -0
- package/dist/server/implementation/mutations/index.js +108 -0
- package/dist/server/implementation/mutations/index.js.map +1 -0
- package/dist/server/implementation/mutations/invalidateSessions.d.ts +13 -0
- package/dist/server/implementation/mutations/invalidateSessions.d.ts.map +1 -0
- package/dist/server/implementation/mutations/invalidateSessions.js +35 -0
- package/dist/server/implementation/mutations/invalidateSessions.js.map +1 -0
- package/dist/server/implementation/mutations/modifyAccount.d.ts +23 -0
- package/dist/server/implementation/mutations/modifyAccount.d.ts.map +1 -0
- package/dist/server/implementation/mutations/modifyAccount.js +48 -0
- package/dist/server/implementation/mutations/modifyAccount.js.map +1 -0
- package/dist/server/implementation/mutations/refreshSession.d.ts +16 -0
- package/dist/server/implementation/mutations/refreshSession.d.ts.map +1 -0
- package/dist/server/implementation/mutations/refreshSession.js +116 -0
- package/dist/server/implementation/mutations/refreshSession.js.map +1 -0
- package/dist/server/implementation/mutations/retrieveAccountWithCredentials.d.ts +27 -0
- package/dist/server/implementation/mutations/retrieveAccountWithCredentials.d.ts.map +1 -0
- package/dist/server/implementation/mutations/retrieveAccountWithCredentials.js +55 -0
- package/dist/server/implementation/mutations/retrieveAccountWithCredentials.js.map +1 -0
- package/dist/server/implementation/mutations/signIn.d.ts +17 -0
- package/dist/server/implementation/mutations/signIn.d.ts.map +1 -0
- package/dist/server/implementation/mutations/signIn.js +26 -0
- package/dist/server/implementation/mutations/signIn.js.map +1 -0
- package/dist/server/implementation/mutations/signOut.d.ts +11 -0
- package/dist/server/implementation/mutations/signOut.d.ts.map +1 -0
- package/dist/server/implementation/mutations/signOut.js +24 -0
- package/dist/server/implementation/mutations/signOut.js.map +1 -0
- package/dist/server/implementation/mutations/userOAuth.d.ts +19 -0
- package/dist/server/implementation/mutations/userOAuth.d.ts.map +1 -0
- package/dist/server/implementation/mutations/userOAuth.js +84 -0
- package/dist/server/implementation/mutations/userOAuth.js.map +1 -0
- package/dist/server/implementation/mutations/verifier.d.ts +8 -0
- package/dist/server/implementation/mutations/verifier.d.ts.map +1 -0
- package/dist/server/implementation/mutations/verifier.js +19 -0
- package/dist/server/implementation/mutations/verifier.js.map +1 -0
- package/dist/server/implementation/mutations/verifierSignature.d.ts +15 -0
- package/dist/server/implementation/mutations/verifierSignature.d.ts.map +1 -0
- package/dist/server/implementation/mutations/verifierSignature.js +29 -0
- package/dist/server/implementation/mutations/verifierSignature.js.map +1 -0
- package/dist/server/implementation/mutations/verifyCodeAndSignIn.d.ts +21 -0
- package/dist/server/implementation/mutations/verifyCodeAndSignIn.d.ts.map +1 -0
- package/dist/server/implementation/mutations/verifyCodeAndSignIn.js +127 -0
- package/dist/server/implementation/mutations/verifyCodeAndSignIn.js.map +1 -0
- package/dist/server/implementation/provider.d.ts +6 -0
- package/dist/server/implementation/provider.d.ts.map +1 -0
- package/dist/server/implementation/provider.js +21 -0
- package/dist/server/implementation/provider.js.map +1 -0
- package/dist/server/implementation/rateLimit.d.ts +6 -0
- package/dist/server/implementation/rateLimit.d.ts.map +1 -0
- package/dist/server/implementation/rateLimit.js +76 -0
- package/dist/server/implementation/rateLimit.js.map +1 -0
- package/dist/server/implementation/redirects.d.ts +6 -0
- package/dist/server/implementation/redirects.d.ts.map +1 -0
- package/dist/server/implementation/redirects.js +40 -0
- package/dist/server/implementation/redirects.js.map +1 -0
- package/dist/server/implementation/refreshTokens.d.ts +40 -0
- package/dist/server/implementation/refreshTokens.d.ts.map +1 -0
- package/dist/server/implementation/refreshTokens.js +160 -0
- package/dist/server/implementation/refreshTokens.js.map +1 -0
- package/dist/server/implementation/sessions.d.ts +43 -0
- package/dist/server/implementation/sessions.d.ts.map +1 -0
- package/dist/server/implementation/sessions.js +94 -0
- package/dist/server/implementation/sessions.js.map +1 -0
- package/dist/server/implementation/signIn.d.ts +31 -0
- package/dist/server/implementation/signIn.d.ts.map +1 -0
- package/dist/server/implementation/signIn.js +148 -0
- package/dist/server/implementation/signIn.js.map +1 -0
- package/dist/server/implementation/tokens.d.ts +7 -0
- package/dist/server/implementation/tokens.d.ts.map +1 -0
- package/dist/server/implementation/tokens.js +18 -0
- package/dist/server/implementation/tokens.js.map +1 -0
- package/dist/server/implementation/types.d.ts +288 -0
- package/dist/server/implementation/types.d.ts.map +1 -0
- package/dist/server/implementation/types.js +182 -0
- package/dist/server/implementation/types.js.map +1 -0
- package/dist/server/implementation/users.d.ts +27 -0
- package/dist/server/implementation/users.d.ts.map +1 -0
- package/dist/server/implementation/users.js +181 -0
- package/dist/server/implementation/users.js.map +1 -0
- package/dist/server/implementation/utils.d.ts +17 -0
- package/dist/server/implementation/utils.d.ts.map +1 -0
- package/dist/server/implementation/utils.js +72 -0
- package/dist/server/implementation/utils.js.map +1 -0
- package/dist/server/index.d.ts +17 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +54 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/oauth/authorizationUrl.d.ts +13 -0
- package/dist/server/oauth/authorizationUrl.d.ts.map +1 -0
- package/dist/server/oauth/authorizationUrl.js +91 -0
- package/dist/server/oauth/authorizationUrl.js.map +1 -0
- package/dist/server/oauth/callback.d.ts +19 -0
- package/dist/server/oauth/callback.d.ts.map +1 -0
- package/dist/server/oauth/callback.js +173 -0
- package/dist/server/oauth/callback.js.map +1 -0
- package/dist/server/oauth/checks.d.ts +52 -0
- package/dist/server/oauth/checks.d.ts.map +1 -0
- package/dist/server/oauth/checks.js +106 -0
- package/dist/server/oauth/checks.js.map +1 -0
- package/dist/server/oauth/convexAuth.d.ts +12 -0
- package/dist/server/oauth/convexAuth.d.ts.map +1 -0
- package/dist/server/oauth/convexAuth.js +137 -0
- package/dist/server/oauth/convexAuth.js.map +1 -0
- package/dist/server/oauth/lib/utils/customFetch.d.ts +9 -0
- package/dist/server/oauth/lib/utils/customFetch.d.ts.map +1 -0
- package/dist/server/oauth/lib/utils/customFetch.js +11 -0
- package/dist/server/oauth/lib/utils/customFetch.js.map +1 -0
- package/dist/server/oauth/lib/utils/providers.d.ts +3 -0
- package/dist/server/oauth/lib/utils/providers.d.ts.map +1 -0
- package/dist/server/oauth/lib/utils/providers.js +7 -0
- package/dist/server/oauth/lib/utils/providers.js.map +1 -0
- package/dist/server/oauth/providers/oauth.d.ts +43 -0
- package/dist/server/oauth/providers/oauth.d.ts.map +1 -0
- package/dist/server/oauth/providers/oauth.js +3 -0
- package/dist/server/oauth/providers/oauth.js.map +1 -0
- package/dist/server/oauth/types.d.ts +24 -0
- package/dist/server/oauth/types.d.ts.map +1 -0
- package/dist/server/oauth/types.js +5 -0
- package/dist/server/oauth/types.js.map +1 -0
- package/dist/server/provider_utils.d.ts +76 -0
- package/dist/server/provider_utils.d.ts.map +1 -0
- package/dist/server/provider_utils.js +177 -0
- package/dist/server/provider_utils.js.map +1 -0
- package/dist/server/types.d.ts +412 -0
- package/dist/server/types.d.ts.map +1 -0
- package/dist/server/types.js +2 -0
- package/dist/server/types.js.map +1 -0
- package/dist/server/utils.d.ts +3 -0
- package/dist/server/utils.d.ts.map +1 -0
- package/dist/server/utils.js +11 -0
- package/dist/server/utils.js.map +1 -0
- package/package.json +126 -0
- package/providers/Anonymous/package.json +6 -0
- package/providers/ConvexCredentials/package.json +6 -0
- package/providers/Email/package.json +6 -0
- package/providers/Password/package.json +6 -0
- package/providers/Phone/package.json +6 -0
- package/server/package.json +6 -0
- package/src/cli/command.ts +69 -0
- package/src/cli/generateKeys.ts +20 -0
- package/src/cli/index.ts +840 -0
- package/src/client/index.ts +415 -0
- package/src/component/_generated/api.ts +52 -0
- package/src/component/_generated/component.ts +586 -0
- package/src/component/_generated/dataModel.ts +60 -0
- package/src/component/_generated/server.ts +156 -0
- package/src/component/convex.config.ts +5 -0
- package/src/component/index.ts +40 -0
- package/src/component/public.ts +607 -0
- package/src/component/schema.ts +35 -0
- package/src/providers/Anonymous.ts +79 -0
- package/src/providers/ConvexCredentials.ts +108 -0
- package/src/providers/Email.ts +60 -0
- package/src/providers/Password.ts +253 -0
- package/src/providers/Phone.ts +46 -0
- package/src/server/convex_types.ts +55 -0
- package/src/server/cookies.ts +42 -0
- package/src/server/implementation/db.ts +125 -0
- package/src/server/implementation/index.ts +815 -0
- package/src/server/implementation/mutations/createAccountFromCredentials.ts +113 -0
- package/src/server/implementation/mutations/createVerificationCode.ts +139 -0
- package/src/server/implementation/mutations/index.ts +157 -0
- package/src/server/implementation/mutations/invalidateSessions.ts +47 -0
- package/src/server/implementation/mutations/modifyAccount.ts +65 -0
- package/src/server/implementation/mutations/refreshSession.ts +188 -0
- package/src/server/implementation/mutations/retrieveAccountWithCredentials.ts +87 -0
- package/src/server/implementation/mutations/signIn.ts +51 -0
- package/src/server/implementation/mutations/signOut.ts +38 -0
- package/src/server/implementation/mutations/userOAuth.ts +112 -0
- package/src/server/implementation/mutations/verifier.ts +29 -0
- package/src/server/implementation/mutations/verifierSignature.ts +44 -0
- package/src/server/implementation/mutations/verifyCodeAndSignIn.ts +205 -0
- package/src/server/implementation/provider.ts +38 -0
- package/src/server/implementation/rateLimit.ts +105 -0
- package/src/server/implementation/redirects.ts +58 -0
- package/src/server/implementation/refreshTokens.ts +221 -0
- package/src/server/implementation/sessions.ts +155 -0
- package/src/server/implementation/signIn.ts +253 -0
- package/src/server/implementation/tokens.ts +29 -0
- package/src/server/implementation/types.ts +220 -0
- package/src/server/implementation/users.ts +286 -0
- package/src/server/implementation/utils.ts +91 -0
- package/src/server/index.ts +74 -0
- package/src/server/oauth/NOTICE.txt +21 -0
- package/src/server/oauth/README.md +7 -0
- package/src/server/oauth/authorizationUrl.ts +113 -0
- package/src/server/oauth/callback.ts +243 -0
- package/src/server/oauth/checks.ts +136 -0
- package/src/server/oauth/convexAuth.ts +168 -0
- package/src/server/oauth/lib/utils/customFetch.ts +18 -0
- package/src/server/oauth/lib/utils/providers.ts +12 -0
- package/src/server/oauth/providers/oauth.ts +56 -0
- package/src/server/oauth/types.ts +60 -0
- package/src/server/provider_utils.ts +222 -0
- package/src/server/types.ts +470 -0
- package/src/server/utils.ts +12 -0
- package/src/test.ts +24 -0
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Configure {@link Phone} provider given a {@link PhoneUserConfig}.
|
|
3
|
+
*
|
|
4
|
+
* Simplifies creating phone providers.
|
|
5
|
+
*
|
|
6
|
+
* By default checks that there is an `phone` field during token verification
|
|
7
|
+
* that matches the `phone` used during the initial `signIn` call.
|
|
8
|
+
*
|
|
9
|
+
* @module
|
|
10
|
+
*/
|
|
11
|
+
import { GenericDataModel } from "convex/server";
|
|
12
|
+
import { PhoneConfig, PhoneUserConfig } from "../server/types.js";
|
|
13
|
+
/**
|
|
14
|
+
* Phone providers send a token to the user's phone number
|
|
15
|
+
* for sign-in.
|
|
16
|
+
*
|
|
17
|
+
* When you use this function to create your config, it
|
|
18
|
+
* checks that there is a `phone` field during token verification
|
|
19
|
+
* that matches the `phone` used during the initial `signIn` call.
|
|
20
|
+
*/
|
|
21
|
+
export default function phone<DataModel extends GenericDataModel>(config: PhoneUserConfig & Pick<PhoneConfig, "sendVerificationRequest">): PhoneConfig<DataModel>;
|
|
22
|
+
//# sourceMappingURL=Phone.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Phone.d.ts","sourceRoot":"","sources":["../../src/providers/Phone.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAElE;;;;;;;GAOG;AACH,MAAM,CAAC,OAAO,UAAU,KAAK,CAAC,SAAS,SAAS,gBAAgB,EAC9D,MAAM,EAAE,eAAe,GAAG,IAAI,CAAC,WAAW,EAAE,yBAAyB,CAAC,GACrE,WAAW,CAAC,SAAS,CAAC,CAqBxB"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Configure {@link Phone} provider given a {@link PhoneUserConfig}.
|
|
3
|
+
*
|
|
4
|
+
* Simplifies creating phone providers.
|
|
5
|
+
*
|
|
6
|
+
* By default checks that there is an `phone` field during token verification
|
|
7
|
+
* that matches the `phone` used during the initial `signIn` call.
|
|
8
|
+
*
|
|
9
|
+
* @module
|
|
10
|
+
*/
|
|
11
|
+
/**
|
|
12
|
+
* Phone providers send a token to the user's phone number
|
|
13
|
+
* for sign-in.
|
|
14
|
+
*
|
|
15
|
+
* When you use this function to create your config, it
|
|
16
|
+
* checks that there is a `phone` field during token verification
|
|
17
|
+
* that matches the `phone` used during the initial `signIn` call.
|
|
18
|
+
*/
|
|
19
|
+
export default function phone(config) {
|
|
20
|
+
return {
|
|
21
|
+
id: "phone",
|
|
22
|
+
type: "phone",
|
|
23
|
+
maxAge: 60 * 20, // 20 minutes
|
|
24
|
+
authorize: async (params, account) => {
|
|
25
|
+
if (typeof params.phone !== "string") {
|
|
26
|
+
throw new Error("Token verification requires an `phone` in params of `signIn`.");
|
|
27
|
+
}
|
|
28
|
+
if (account.providerAccountId !== params.phone) {
|
|
29
|
+
throw new Error("Short verification code requires a matching `phone` " +
|
|
30
|
+
"in params of `signIn`.");
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
sendVerificationRequest: config.sendVerificationRequest,
|
|
34
|
+
options: config,
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=Phone.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Phone.js","sourceRoot":"","sources":["../../src/providers/Phone.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAKH;;;;;;;GAOG;AACH,MAAM,CAAC,OAAO,UAAU,KAAK,CAC3B,MAAsE;IAEtE,OAAO;QACL,EAAE,EAAE,OAAO;QACX,IAAI,EAAE,OAAO;QACb,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE,aAAa;QAC9B,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE;YACnC,IAAI,OAAO,MAAM,CAAC,KAAK,KAAK,QAAQ,EAAE,CAAC;gBACrC,MAAM,IAAI,KAAK,CACb,+DAA+D,CAChE,CAAC;YACJ,CAAC;YACD,IAAI,OAAO,CAAC,iBAAiB,KAAK,MAAM,CAAC,KAAK,EAAE,CAAC;gBAC/C,MAAM,IAAI,KAAK,CACb,sDAAsD;oBACpD,wBAAwB,CAC3B,CAAC;YACJ,CAAC;QACH,CAAC;QACD,uBAAuB,EAAE,MAAM,CAAC,uBAAuB;QACvD,OAAO,EAAE,MAAM;KAChB,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { DocumentByName, FunctionReference, GenericDataModel, RegisteredAction, RegisteredMutation, RegisteredQuery, TableNamesInDataModel } from "convex/server";
|
|
2
|
+
import { GenericId } from "convex/values";
|
|
3
|
+
/**
|
|
4
|
+
* Convex document from a given table.
|
|
5
|
+
*/
|
|
6
|
+
export type GenericDoc<DataModel extends GenericDataModel, TableName extends TableNamesInDataModel<DataModel>> = DocumentByName<DataModel, TableName> & {
|
|
7
|
+
_id: GenericId<TableName>;
|
|
8
|
+
_creationTime: number;
|
|
9
|
+
};
|
|
10
|
+
/**
|
|
11
|
+
* @internal
|
|
12
|
+
*/
|
|
13
|
+
export type FunctionReferenceFromExport<Export> = Export extends RegisteredQuery<infer Visibility, infer Args, infer Output> ? FunctionReference<"query", Visibility, Args, ConvertReturnType<Output>> : Export extends RegisteredMutation<infer Visibility, infer Args, infer Output> ? FunctionReference<"mutation", Visibility, Args, ConvertReturnType<Output>> : Export extends RegisteredAction<infer Visibility, infer Args, infer Output> ? FunctionReference<"action", Visibility, Args, ConvertReturnType<Output>> : never;
|
|
14
|
+
type ConvertReturnType<T> = UndefinedToNull<Awaited<T>>;
|
|
15
|
+
type UndefinedToNull<T> = T extends void ? null : T;
|
|
16
|
+
export {};
|
|
17
|
+
//# sourceMappingURL=convex_types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"convex_types.d.ts","sourceRoot":"","sources":["../../src/server/convex_types.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,EACd,iBAAiB,EACjB,gBAAgB,EAChB,gBAAgB,EAChB,kBAAkB,EAClB,eAAe,EACf,qBAAqB,EACtB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE1C;;GAEG;AACH,MAAM,MAAM,UAAU,CACpB,SAAS,SAAS,gBAAgB,EAClC,SAAS,SAAS,qBAAqB,CAAC,SAAS,CAAC,IAChD,cAAc,CAAC,SAAS,EAAE,SAAS,CAAC,GAAG;IACzC,GAAG,EAAE,SAAS,CAAC,SAAS,CAAC,CAAC;IAC1B,aAAa,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,2BAA2B,CAAC,MAAM,IAC5C,MAAM,SAAS,eAAe,CAAC,MAAM,UAAU,EAAE,MAAM,IAAI,EAAE,MAAM,MAAM,CAAC,GACtE,iBAAiB,CAAC,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,iBAAiB,CAAC,MAAM,CAAC,CAAC,GACvE,MAAM,SAAS,kBAAkB,CAC7B,MAAM,UAAU,EAChB,MAAM,IAAI,EACV,MAAM,MAAM,CACb,GACD,iBAAiB,CACf,UAAU,EACV,UAAU,EACV,IAAI,EACJ,iBAAiB,CAAC,MAAM,CAAC,CAC1B,GACD,MAAM,SAAS,gBAAgB,CAC3B,MAAM,UAAU,EAChB,MAAM,IAAI,EACV,MAAM,MAAM,CACb,GACD,iBAAiB,CACf,QAAQ,EACR,UAAU,EACV,IAAI,EACJ,iBAAiB,CAAC,MAAM,CAAC,CAC1B,GACD,KAAK,CAAC;AAEhB,KAAK,iBAAiB,CAAC,CAAC,IAAI,eAAe,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;AAExD,KAAK,eAAe,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"convex_types.js","sourceRoot":"","sources":["../../src/server/convex_types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export declare const SHARED_COOKIE_OPTIONS: {
|
|
2
|
+
httpOnly: boolean;
|
|
3
|
+
sameSite: "none";
|
|
4
|
+
secure: boolean;
|
|
5
|
+
path: string;
|
|
6
|
+
partitioned: boolean;
|
|
7
|
+
};
|
|
8
|
+
export declare function redirectToParamCookie(providerId: string, redirectTo: string): {
|
|
9
|
+
name: string;
|
|
10
|
+
value: string;
|
|
11
|
+
options: {
|
|
12
|
+
maxAge: number;
|
|
13
|
+
httpOnly: boolean;
|
|
14
|
+
sameSite: "none";
|
|
15
|
+
secure: boolean;
|
|
16
|
+
path: string;
|
|
17
|
+
partitioned: boolean;
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
export declare function useRedirectToParam(providerId: string, cookies: Record<string, string | undefined>): {
|
|
21
|
+
redirectTo: string;
|
|
22
|
+
updatedCookie: {
|
|
23
|
+
name: string;
|
|
24
|
+
value: string;
|
|
25
|
+
options: {
|
|
26
|
+
maxAge: number;
|
|
27
|
+
httpOnly: boolean;
|
|
28
|
+
sameSite: "none";
|
|
29
|
+
secure: boolean;
|
|
30
|
+
path: string;
|
|
31
|
+
partitioned: boolean;
|
|
32
|
+
};
|
|
33
|
+
};
|
|
34
|
+
} | null;
|
|
35
|
+
//# sourceMappingURL=cookies.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cookies.d.ts","sourceRoot":"","sources":["../../src/server/cookies.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,qBAAqB;;;;;;CAMjC,CAAC;AAGF,wBAAgB,qBAAqB,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM;;;;;;;;;;;EAM3E;AAED,wBAAgB,kBAAkB,CAChC,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC;;;;;;;;;;;;;;SAgB5C"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { isLocalHost } from "./utils.js";
|
|
2
|
+
export const SHARED_COOKIE_OPTIONS = {
|
|
3
|
+
httpOnly: true,
|
|
4
|
+
sameSite: "none",
|
|
5
|
+
secure: true,
|
|
6
|
+
path: "/",
|
|
7
|
+
partitioned: true,
|
|
8
|
+
};
|
|
9
|
+
const REDIRECT_MAX_AGE = 60 * 15; // 15 minutes in seconds
|
|
10
|
+
export function redirectToParamCookie(providerId, redirectTo) {
|
|
11
|
+
return {
|
|
12
|
+
name: redirectToParamCookieName(providerId),
|
|
13
|
+
value: redirectTo,
|
|
14
|
+
options: { ...SHARED_COOKIE_OPTIONS, maxAge: REDIRECT_MAX_AGE },
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
export function useRedirectToParam(providerId, cookies) {
|
|
18
|
+
const cookieName = redirectToParamCookieName(providerId);
|
|
19
|
+
const redirectTo = cookies[cookieName];
|
|
20
|
+
if (redirectTo === undefined) {
|
|
21
|
+
return null;
|
|
22
|
+
}
|
|
23
|
+
// Clear the cookie
|
|
24
|
+
const updatedCookie = {
|
|
25
|
+
name: cookieName,
|
|
26
|
+
value: "",
|
|
27
|
+
options: { ...SHARED_COOKIE_OPTIONS, maxAge: 0 },
|
|
28
|
+
};
|
|
29
|
+
return { redirectTo, updatedCookie };
|
|
30
|
+
}
|
|
31
|
+
function redirectToParamCookieName(providerId) {
|
|
32
|
+
return (!isLocalHost(process.env.CONVEX_SITE_URL) ? "__Host-" : "") + providerId + "RedirectTo";
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=cookies.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cookies.js","sourceRoot":"","sources":["../../src/server/cookies.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAEzC,MAAM,CAAC,MAAM,qBAAqB,GAAG;IACnC,QAAQ,EAAE,IAAI;IACd,QAAQ,EAAE,MAAe;IACzB,MAAM,EAAE,IAAI;IACZ,IAAI,EAAE,GAAG;IACT,WAAW,EAAE,IAAI;CAClB,CAAC;AAEF,MAAM,gBAAgB,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,wBAAwB;AAC1D,MAAM,UAAU,qBAAqB,CAAC,UAAkB,EAAE,UAAkB;IAC1E,OAAO;QACL,IAAI,EAAE,yBAAyB,CAAC,UAAU,CAAC;QAC3C,KAAK,EAAE,UAAU;QACjB,OAAO,EAAE,EAAE,GAAG,qBAAqB,EAAE,MAAM,EAAE,gBAAgB,EAAE;KAChE,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,kBAAkB,CAChC,UAAkB,EAClB,OAA2C;IAE3C,MAAM,UAAU,GAAG,yBAAyB,CAAC,UAAU,CAAC,CAAC;IACzD,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IACvC,IAAI,UAAU,KAAK,SAAS,EAAE,CAAC;QAC7B,OAAO,IAAI,CAAC;IACd,CAAC;IAED,mBAAmB;IACnB,MAAM,aAAa,GAAG;QACpB,IAAI,EAAE,UAAU;QAChB,KAAK,EAAE,EAAE;QACT,OAAO,EAAE,EAAE,GAAG,qBAAqB,EAAE,MAAM,EAAE,CAAC,EAAE;KACjD,CAAC;IAEF,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,CAAC;AACvC,CAAC;AAED,SAAS,yBAAyB,CAAC,UAAkB;IACnD,OAAO,CAAC,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,UAAU,GAAG,YAAY,CAAC;AAClG,CAAC"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { GenericActionCtx, GenericDataModel, GenericMutationCtx } from "convex/server";
|
|
2
|
+
import { AuthComponentApi } from "../types.js";
|
|
3
|
+
type MutationCtxLike = Pick<GenericMutationCtx<GenericDataModel>, "runQuery" | "runMutation">;
|
|
4
|
+
type ActionCtxLike = Pick<GenericActionCtx<GenericDataModel>, "runQuery" | "runMutation" | "runAction">;
|
|
5
|
+
type CtxLike = MutationCtxLike | ActionCtxLike;
|
|
6
|
+
export type AuthDb = ReturnType<typeof createAuthDb>;
|
|
7
|
+
export declare function createAuthDb(ctx: CtxLike, component: AuthComponentApi): {
|
|
8
|
+
users: {
|
|
9
|
+
getById: (userId: string) => Promise<any>;
|
|
10
|
+
findByVerifiedEmail: (email: string) => Promise<any>;
|
|
11
|
+
findByVerifiedPhone: (phone: string) => Promise<any>;
|
|
12
|
+
insert: (data: Record<string, unknown>) => Promise<string>;
|
|
13
|
+
patch: (userId: string, data: Record<string, unknown>) => Promise<any>;
|
|
14
|
+
upsert: (userId: string | undefined, data: Record<string, unknown>) => Promise<string>;
|
|
15
|
+
};
|
|
16
|
+
accounts: {
|
|
17
|
+
get: (provider: string, providerAccountId: string) => Promise<any>;
|
|
18
|
+
getById: (accountId: string) => Promise<any>;
|
|
19
|
+
create: (args: {
|
|
20
|
+
userId: string;
|
|
21
|
+
provider: string;
|
|
22
|
+
providerAccountId: string;
|
|
23
|
+
secret?: string;
|
|
24
|
+
}) => Promise<string>;
|
|
25
|
+
patch: (accountId: string, data: Record<string, unknown>) => Promise<any>;
|
|
26
|
+
delete: (accountId: string) => Promise<any>;
|
|
27
|
+
};
|
|
28
|
+
sessions: {
|
|
29
|
+
create: (userId: string, expirationTime: number) => Promise<string>;
|
|
30
|
+
getById: (sessionId: string) => Promise<any>;
|
|
31
|
+
delete: (sessionId: string) => Promise<any>;
|
|
32
|
+
listByUser: (userId: string) => Promise<any>;
|
|
33
|
+
};
|
|
34
|
+
verifiers: {
|
|
35
|
+
create: (sessionId?: string) => Promise<string>;
|
|
36
|
+
getById: (verifierId: string) => Promise<any>;
|
|
37
|
+
getBySignature: (signature: string) => Promise<any>;
|
|
38
|
+
patch: (verifierId: string, data: Record<string, unknown>) => Promise<any>;
|
|
39
|
+
delete: (verifierId: string) => Promise<any>;
|
|
40
|
+
};
|
|
41
|
+
verificationCodes: {
|
|
42
|
+
getByAccountId: (accountId: string) => Promise<any>;
|
|
43
|
+
getByCode: (code: string) => Promise<any>;
|
|
44
|
+
create: (args: {
|
|
45
|
+
accountId: string;
|
|
46
|
+
provider: string;
|
|
47
|
+
code: string;
|
|
48
|
+
expirationTime: number;
|
|
49
|
+
verifier?: string;
|
|
50
|
+
emailVerified?: string;
|
|
51
|
+
phoneVerified?: string;
|
|
52
|
+
}) => Promise<any>;
|
|
53
|
+
delete: (verificationCodeId: string) => Promise<any>;
|
|
54
|
+
};
|
|
55
|
+
refreshTokens: {
|
|
56
|
+
create: (args: {
|
|
57
|
+
sessionId: string;
|
|
58
|
+
expirationTime: number;
|
|
59
|
+
parentRefreshTokenId?: string;
|
|
60
|
+
}) => Promise<string>;
|
|
61
|
+
getById: (refreshTokenId: string) => Promise<any>;
|
|
62
|
+
patch: (refreshTokenId: string, data: Record<string, unknown>) => Promise<any>;
|
|
63
|
+
getChildren: (sessionId: string, parentRefreshTokenId: string) => Promise<any>;
|
|
64
|
+
listBySession: (sessionId: string) => Promise<any>;
|
|
65
|
+
deleteAll: (sessionId: string) => Promise<any>;
|
|
66
|
+
getActive: (sessionId: string) => Promise<any>;
|
|
67
|
+
};
|
|
68
|
+
rateLimits: {
|
|
69
|
+
get: (identifier: string) => Promise<any>;
|
|
70
|
+
create: (args: {
|
|
71
|
+
identifier: string;
|
|
72
|
+
attemptsLeft: number;
|
|
73
|
+
lastAttemptTime: number;
|
|
74
|
+
}) => Promise<any>;
|
|
75
|
+
patch: (rateLimitId: string, data: Record<string, unknown>) => Promise<any>;
|
|
76
|
+
delete: (rateLimitId: string) => Promise<any>;
|
|
77
|
+
};
|
|
78
|
+
};
|
|
79
|
+
export {};
|
|
80
|
+
//# sourceMappingURL=db.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"db.d.ts","sourceRoot":"","sources":["../../../src/server/implementation/db.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AACvF,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAE/C,KAAK,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,CAAC,EAAE,UAAU,GAAG,aAAa,CAAC,CAAC;AAC9F,KAAK,aAAa,GAAG,IAAI,CACvB,gBAAgB,CAAC,gBAAgB,CAAC,EAClC,UAAU,GAAG,aAAa,GAAG,WAAW,CACzC,CAAC;AAEF,KAAK,OAAO,GAAG,eAAe,GAAG,aAAa,CAAC;AAE/C,MAAM,MAAM,MAAM,GAAG,UAAU,CAAC,OAAO,YAAY,CAAC,CAAC;AAErD,wBAAgB,YAAY,CAAC,GAAG,EAAE,OAAO,EAAE,SAAS,EAAE,gBAAgB;;0BAG9C,MAAM;qCAEK,MAAM;qCAEN,MAAM;uBAEpB,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KACsB,OAAO,CAAC,MAAM,CAAC;wBAC3D,MAAM,QAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;yBAEpC,MAAM,GAAG,SAAS,QAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KACE,OAAO,CAAC,MAAM,CAAC;;;wBAGnE,MAAM,qBAAqB,MAAM;6BAE5B,MAAM;uBAEZ;YACb,MAAM,EAAE,MAAM,CAAC;YACf,QAAQ,EAAE,MAAM,CAAC;YACjB,iBAAiB,EAAE,MAAM,CAAC;YAC1B,MAAM,CAAC,EAAE,MAAM,CAAC;SACjB,KAA8D,OAAO,CAAC,MAAM,CAAC;2BAC3D,MAAM,QAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;4BAEpC,MAAM;;;yBAIT,MAAM,kBAAkB,MAAM,KACkC,OAAO,CAAC,MAAM,CAAC;6BAC3E,MAAM;4BAEP,MAAM;6BAEL,MAAM;;;6BAIN,MAAM,KAC0C,OAAO,CAAC,MAAM,CAAC;8BAC9D,MAAM;oCAEA,MAAM;4BAEd,MAAM,QAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;6BAEpC,MAAM;;;oCAIC,MAAM;0BAEhB,MAAM;uBAET;YACb,SAAS,EAAE,MAAM,CAAC;YAClB,QAAQ,EAAE,MAAM,CAAC;YACjB,IAAI,EAAE,MAAM,CAAC;YACb,cAAc,EAAE,MAAM,CAAC;YACvB,QAAQ,CAAC,EAAE,MAAM,CAAC;YAClB,aAAa,CAAC,EAAE,MAAM,CAAC;YACvB,aAAa,CAAC,EAAE,MAAM,CAAC;SACxB;qCAE4B,MAAM;;;uBAMpB;YACb,SAAS,EAAE,MAAM,CAAC;YAClB,cAAc,EAAE,MAAM,CAAC;YACvB,oBAAoB,CAAC,EAAE,MAAM,CAAC;SAC/B,KAC+D,OAAO,CAAC,MAAM,CAAC;kCACrD,MAAM;gCAER,MAAM,QAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;iCAEpC,MAAM,wBAAwB,MAAM;mCAKlC,MAAM;+BAEV,MAAM;+BAEN,MAAM;;;0BAIX,MAAM;uBAET;YACb,UAAU,EAAE,MAAM,CAAC;YACnB,YAAY,EAAE,MAAM,CAAC;YACrB,eAAe,EAAE,MAAM,CAAC;SACzB;6BACoB,MAAM,QAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;8BAEpC,MAAM;;EAIjC"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
export function createAuthDb(ctx, component) {
|
|
2
|
+
return {
|
|
3
|
+
users: {
|
|
4
|
+
getById: (userId) => ctx.runQuery(component.public.userGetById, { userId }),
|
|
5
|
+
findByVerifiedEmail: (email) => ctx.runQuery(component.public.userFindByVerifiedEmail, { email }),
|
|
6
|
+
findByVerifiedPhone: (phone) => ctx.runQuery(component.public.userFindByVerifiedPhone, { phone }),
|
|
7
|
+
insert: (data) => ctx.runMutation(component.public.userInsert, { data }),
|
|
8
|
+
patch: (userId, data) => ctx.runMutation(component.public.userPatch, { userId, data }),
|
|
9
|
+
upsert: (userId, data) => ctx.runMutation(component.public.userUpsert, { userId, data }),
|
|
10
|
+
},
|
|
11
|
+
accounts: {
|
|
12
|
+
get: (provider, providerAccountId) => ctx.runQuery(component.public.accountGet, { provider, providerAccountId }),
|
|
13
|
+
getById: (accountId) => ctx.runQuery(component.public.accountGetById, { accountId }),
|
|
14
|
+
create: (args) => ctx.runMutation(component.public.accountInsert, args),
|
|
15
|
+
patch: (accountId, data) => ctx.runMutation(component.public.accountPatch, { accountId, data }),
|
|
16
|
+
delete: (accountId) => ctx.runMutation(component.public.accountDelete, { accountId }),
|
|
17
|
+
},
|
|
18
|
+
sessions: {
|
|
19
|
+
create: (userId, expirationTime) => ctx.runMutation(component.public.sessionCreate, { userId, expirationTime }),
|
|
20
|
+
getById: (sessionId) => ctx.runQuery(component.public.sessionGetById, { sessionId }),
|
|
21
|
+
delete: (sessionId) => ctx.runMutation(component.public.sessionDelete, { sessionId }),
|
|
22
|
+
listByUser: (userId) => ctx.runQuery(component.public.sessionListByUser, { userId }),
|
|
23
|
+
},
|
|
24
|
+
verifiers: {
|
|
25
|
+
create: (sessionId) => ctx.runMutation(component.public.verifierCreate, { sessionId }),
|
|
26
|
+
getById: (verifierId) => ctx.runQuery(component.public.verifierGetById, { verifierId }),
|
|
27
|
+
getBySignature: (signature) => ctx.runQuery(component.public.verifierGetBySignature, { signature }),
|
|
28
|
+
patch: (verifierId, data) => ctx.runMutation(component.public.verifierPatch, { verifierId, data }),
|
|
29
|
+
delete: (verifierId) => ctx.runMutation(component.public.verifierDelete, { verifierId }),
|
|
30
|
+
},
|
|
31
|
+
verificationCodes: {
|
|
32
|
+
getByAccountId: (accountId) => ctx.runQuery(component.public.verificationCodeGetByAccountId, { accountId }),
|
|
33
|
+
getByCode: (code) => ctx.runQuery(component.public.verificationCodeGetByCode, { code }),
|
|
34
|
+
create: (args) => ctx.runMutation(component.public.verificationCodeCreate, args),
|
|
35
|
+
delete: (verificationCodeId) => ctx.runMutation(component.public.verificationCodeDelete, {
|
|
36
|
+
verificationCodeId,
|
|
37
|
+
}),
|
|
38
|
+
},
|
|
39
|
+
refreshTokens: {
|
|
40
|
+
create: (args) => ctx.runMutation(component.public.refreshTokenCreate, args),
|
|
41
|
+
getById: (refreshTokenId) => ctx.runQuery(component.public.refreshTokenGetById, { refreshTokenId }),
|
|
42
|
+
patch: (refreshTokenId, data) => ctx.runMutation(component.public.refreshTokenPatch, { refreshTokenId, data }),
|
|
43
|
+
getChildren: (sessionId, parentRefreshTokenId) => ctx.runQuery(component.public.refreshTokenGetChildren, {
|
|
44
|
+
sessionId,
|
|
45
|
+
parentRefreshTokenId,
|
|
46
|
+
}),
|
|
47
|
+
listBySession: (sessionId) => ctx.runQuery(component.public.refreshTokenListBySession, { sessionId }),
|
|
48
|
+
deleteAll: (sessionId) => ctx.runMutation(component.public.refreshTokenDeleteAll, { sessionId }),
|
|
49
|
+
getActive: (sessionId) => ctx.runQuery(component.public.refreshTokenGetActive, { sessionId }),
|
|
50
|
+
},
|
|
51
|
+
rateLimits: {
|
|
52
|
+
get: (identifier) => ctx.runQuery(component.public.rateLimitGet, { identifier }),
|
|
53
|
+
create: (args) => ctx.runMutation(component.public.rateLimitCreate, args),
|
|
54
|
+
patch: (rateLimitId, data) => ctx.runMutation(component.public.rateLimitPatch, { rateLimitId, data }),
|
|
55
|
+
delete: (rateLimitId) => ctx.runMutation(component.public.rateLimitDelete, { rateLimitId }),
|
|
56
|
+
},
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=db.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"db.js","sourceRoot":"","sources":["../../../src/server/implementation/db.ts"],"names":[],"mappings":"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"}
|