@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,521 @@
|
|
|
1
|
+
import { actionGeneric, httpActionGeneric, internalMutationGeneric, } from "convex/server";
|
|
2
|
+
import { ConvexError, v } from "convex/values";
|
|
3
|
+
import { parse as parseCookies, serialize as serializeCookie } from "cookie";
|
|
4
|
+
import { redirectToParamCookie, useRedirectToParam } from "../cookies.js";
|
|
5
|
+
import { configDefaults, listAvailableProviders, materializeProvider, } from "../provider_utils.js";
|
|
6
|
+
import { requireEnv } from "../utils.js";
|
|
7
|
+
export { authTables } from "./types.js";
|
|
8
|
+
import { LOG_LEVELS, TOKEN_SUB_CLAIM_DIVIDER, logError, logWithLevel, } from "./utils.js";
|
|
9
|
+
import { callCreateAccountFromCredentials, callInvalidateSessions, callModifyAccount, callRetreiveAccountWithCredentials, callSignOut, callUserOAuth, callVerifierSignature, storeArgs, storeImpl, } from "./mutations/index.js";
|
|
10
|
+
import { signInImpl } from "./signIn.js";
|
|
11
|
+
import { redirectAbsoluteUrl, setURLSearchParam } from "./redirects.js";
|
|
12
|
+
import { getAuthorizationUrl } from "../oauth/authorizationUrl.js";
|
|
13
|
+
import { defaultCookiesOptions, oAuthConfigToInternalProvider, } from "../oauth/convexAuth.js";
|
|
14
|
+
import { handleOAuth } from "../oauth/callback.js";
|
|
15
|
+
export { getAuthSessionId } from "./sessions.js";
|
|
16
|
+
/**
|
|
17
|
+
* Configure the Convex Auth library. Returns an object with
|
|
18
|
+
* functions and `auth` helper. You must export the functions
|
|
19
|
+
* from `convex/auth.ts` to make them callable:
|
|
20
|
+
*
|
|
21
|
+
* ```ts filename="convex/auth.ts"
|
|
22
|
+
* import { Auth } from "@robelest/convex-auth/component";
|
|
23
|
+
*
|
|
24
|
+
* export const { auth, signIn, signOut, store } = Auth({
|
|
25
|
+
* providers: [],
|
|
26
|
+
* });
|
|
27
|
+
* ```
|
|
28
|
+
*
|
|
29
|
+
* @returns An object with fields you should reexport from your
|
|
30
|
+
* `convex/auth.ts` file.
|
|
31
|
+
*/
|
|
32
|
+
export function Auth(config_) {
|
|
33
|
+
const config = configDefaults(config_);
|
|
34
|
+
const hasOAuth = config.providers.some((provider) => provider.type === "oauth" || provider.type === "oidc");
|
|
35
|
+
const getProvider = (id, allowExtraProviders = false) => {
|
|
36
|
+
return (config.providers.find((provider) => provider.id === id) ??
|
|
37
|
+
(allowExtraProviders
|
|
38
|
+
? config.extraProviders.find((provider) => provider.id === id)
|
|
39
|
+
: undefined));
|
|
40
|
+
};
|
|
41
|
+
const getProviderOrThrow = (id, allowExtraProviders = false) => {
|
|
42
|
+
const provider = getProvider(id, allowExtraProviders);
|
|
43
|
+
if (provider === undefined) {
|
|
44
|
+
const message = `Provider \`${id}\` is not configured, ` +
|
|
45
|
+
`available providers are ${listAvailableProviders(config, allowExtraProviders)}.`;
|
|
46
|
+
logWithLevel(LOG_LEVELS.ERROR, message);
|
|
47
|
+
throw new Error(message);
|
|
48
|
+
}
|
|
49
|
+
return provider;
|
|
50
|
+
};
|
|
51
|
+
const enrichCtx = (ctx) => ({ ...ctx, auth: { ...ctx.auth, config } });
|
|
52
|
+
const requireComponent = () => {
|
|
53
|
+
if (config.component === undefined) {
|
|
54
|
+
throw new Error("Auth component is not configured. Pass `component: components.auth` in Auth config.");
|
|
55
|
+
}
|
|
56
|
+
return config.component;
|
|
57
|
+
};
|
|
58
|
+
const auth = {
|
|
59
|
+
user: {
|
|
60
|
+
current: async (ctx) => {
|
|
61
|
+
const identity = await ctx.auth.getUserIdentity();
|
|
62
|
+
if (identity === null) {
|
|
63
|
+
return null;
|
|
64
|
+
}
|
|
65
|
+
const [userId] = identity.subject.split(TOKEN_SUB_CLAIM_DIVIDER);
|
|
66
|
+
return userId;
|
|
67
|
+
},
|
|
68
|
+
require: async (ctx) => {
|
|
69
|
+
const identity = await ctx.auth.getUserIdentity();
|
|
70
|
+
if (identity === null) {
|
|
71
|
+
throw new Error("Not signed in");
|
|
72
|
+
}
|
|
73
|
+
const [userId] = identity.subject.split(TOKEN_SUB_CLAIM_DIVIDER);
|
|
74
|
+
return userId;
|
|
75
|
+
},
|
|
76
|
+
get: async (ctx, userId) => {
|
|
77
|
+
const component = requireComponent();
|
|
78
|
+
return await ctx.runQuery(component.public.userGetById, { userId });
|
|
79
|
+
},
|
|
80
|
+
viewer: async (ctx) => {
|
|
81
|
+
const userId = await auth.user.current(ctx);
|
|
82
|
+
if (userId === null) {
|
|
83
|
+
return null;
|
|
84
|
+
}
|
|
85
|
+
const component = requireComponent();
|
|
86
|
+
return await ctx.runQuery(component.public.userGetById, { userId });
|
|
87
|
+
},
|
|
88
|
+
},
|
|
89
|
+
organization: {
|
|
90
|
+
create: async (ctx, data) => {
|
|
91
|
+
const component = requireComponent();
|
|
92
|
+
return (await ctx.runMutation(component.public.organizationCreate, {
|
|
93
|
+
data,
|
|
94
|
+
}));
|
|
95
|
+
},
|
|
96
|
+
get: async (ctx, organizationId) => {
|
|
97
|
+
const component = requireComponent();
|
|
98
|
+
return await ctx.runQuery(component.public.organizationGet, {
|
|
99
|
+
organizationId,
|
|
100
|
+
});
|
|
101
|
+
},
|
|
102
|
+
list: async (ctx, ownerUserId) => {
|
|
103
|
+
const component = requireComponent();
|
|
104
|
+
return await ctx.runQuery(component.public.organizationList, {
|
|
105
|
+
ownerUserId,
|
|
106
|
+
});
|
|
107
|
+
},
|
|
108
|
+
update: async (ctx, organizationId, data) => {
|
|
109
|
+
const component = requireComponent();
|
|
110
|
+
await ctx.runMutation(component.public.organizationUpdate, {
|
|
111
|
+
organizationId,
|
|
112
|
+
data,
|
|
113
|
+
});
|
|
114
|
+
},
|
|
115
|
+
delete: async (ctx, organizationId) => {
|
|
116
|
+
const component = requireComponent();
|
|
117
|
+
await ctx.runMutation(component.public.organizationDelete, {
|
|
118
|
+
organizationId,
|
|
119
|
+
});
|
|
120
|
+
},
|
|
121
|
+
member: {
|
|
122
|
+
add: async (ctx, data) => {
|
|
123
|
+
const component = requireComponent();
|
|
124
|
+
return (await ctx.runMutation(component.public.memberAdd, {
|
|
125
|
+
data,
|
|
126
|
+
}));
|
|
127
|
+
},
|
|
128
|
+
remove: async (ctx, memberId) => {
|
|
129
|
+
const component = requireComponent();
|
|
130
|
+
await ctx.runMutation(component.public.memberRemove, { memberId });
|
|
131
|
+
},
|
|
132
|
+
list: async (ctx, args) => {
|
|
133
|
+
const component = requireComponent();
|
|
134
|
+
return await ctx.runQuery(component.public.memberList, args);
|
|
135
|
+
},
|
|
136
|
+
role: {
|
|
137
|
+
set: async (ctx, memberId, role) => {
|
|
138
|
+
const component = requireComponent();
|
|
139
|
+
await ctx.runMutation(component.public.memberRoleSet, {
|
|
140
|
+
memberId,
|
|
141
|
+
role,
|
|
142
|
+
});
|
|
143
|
+
},
|
|
144
|
+
get: async (ctx, memberId) => {
|
|
145
|
+
const component = requireComponent();
|
|
146
|
+
return await ctx.runQuery(component.public.memberRoleGet, {
|
|
147
|
+
memberId,
|
|
148
|
+
});
|
|
149
|
+
},
|
|
150
|
+
},
|
|
151
|
+
},
|
|
152
|
+
},
|
|
153
|
+
invite: {
|
|
154
|
+
create: async (ctx, data) => {
|
|
155
|
+
const component = requireComponent();
|
|
156
|
+
return (await ctx.runMutation(component.public.inviteCreate, {
|
|
157
|
+
data,
|
|
158
|
+
}));
|
|
159
|
+
},
|
|
160
|
+
get: async (ctx, inviteId) => {
|
|
161
|
+
const component = requireComponent();
|
|
162
|
+
return await ctx.runQuery(component.public.inviteGet, { inviteId });
|
|
163
|
+
},
|
|
164
|
+
list: async (ctx, args) => {
|
|
165
|
+
const component = requireComponent();
|
|
166
|
+
return await ctx.runQuery(component.public.inviteList, args);
|
|
167
|
+
},
|
|
168
|
+
accept: async (ctx, inviteId) => {
|
|
169
|
+
const component = requireComponent();
|
|
170
|
+
await ctx.runMutation(component.public.inviteAccept, { inviteId });
|
|
171
|
+
},
|
|
172
|
+
revoke: async (ctx, inviteId) => {
|
|
173
|
+
const component = requireComponent();
|
|
174
|
+
await ctx.runMutation(component.public.inviteRevoke, { inviteId });
|
|
175
|
+
},
|
|
176
|
+
},
|
|
177
|
+
/**
|
|
178
|
+
* Add HTTP actions for JWT verification and OAuth sign-in.
|
|
179
|
+
*
|
|
180
|
+
* ```ts
|
|
181
|
+
* import { httpRouter } from "convex/server";
|
|
182
|
+
* import { auth } from "./auth.js";
|
|
183
|
+
*
|
|
184
|
+
* const http = httpRouter();
|
|
185
|
+
*
|
|
186
|
+
* auth.addHttpRoutes(http);
|
|
187
|
+
*
|
|
188
|
+
* export default http;
|
|
189
|
+
* ```
|
|
190
|
+
*
|
|
191
|
+
* The following routes are handled always:
|
|
192
|
+
*
|
|
193
|
+
* - `/.well-known/openid-configuration`
|
|
194
|
+
* - `/.well-known/jwks.json`
|
|
195
|
+
*
|
|
196
|
+
* The following routes are handled if OAuth is configured:
|
|
197
|
+
*
|
|
198
|
+
* - `/api/auth/signin/*`
|
|
199
|
+
* - `/api/auth/callback/*`
|
|
200
|
+
*
|
|
201
|
+
* @param http your HTTP router
|
|
202
|
+
*/
|
|
203
|
+
addHttpRoutes: (http) => {
|
|
204
|
+
http.route({
|
|
205
|
+
path: "/.well-known/openid-configuration",
|
|
206
|
+
method: "GET",
|
|
207
|
+
handler: httpActionGeneric(async () => {
|
|
208
|
+
return new Response(JSON.stringify({
|
|
209
|
+
issuer: requireEnv("CONVEX_SITE_URL"),
|
|
210
|
+
jwks_uri: requireEnv("CONVEX_SITE_URL") + "/.well-known/jwks.json",
|
|
211
|
+
authorization_endpoint: requireEnv("CONVEX_SITE_URL") + "/oauth/authorize",
|
|
212
|
+
}), {
|
|
213
|
+
status: 200,
|
|
214
|
+
headers: {
|
|
215
|
+
"Content-Type": "application/json",
|
|
216
|
+
"Cache-Control": "public, max-age=15, stale-while-revalidate=15, stale-if-error=86400",
|
|
217
|
+
},
|
|
218
|
+
});
|
|
219
|
+
}),
|
|
220
|
+
});
|
|
221
|
+
http.route({
|
|
222
|
+
path: "/.well-known/jwks.json",
|
|
223
|
+
method: "GET",
|
|
224
|
+
handler: httpActionGeneric(async () => {
|
|
225
|
+
return new Response(requireEnv("JWKS"), {
|
|
226
|
+
status: 200,
|
|
227
|
+
headers: {
|
|
228
|
+
"Content-Type": "application/json",
|
|
229
|
+
"Cache-Control": "public, max-age=15, stale-while-revalidate=15, stale-if-error=86400",
|
|
230
|
+
},
|
|
231
|
+
});
|
|
232
|
+
}),
|
|
233
|
+
});
|
|
234
|
+
if (hasOAuth) {
|
|
235
|
+
http.route({
|
|
236
|
+
pathPrefix: "/api/auth/signin/",
|
|
237
|
+
method: "GET",
|
|
238
|
+
handler: httpActionGeneric(convertErrorsToResponse(400, async (ctx, request) => {
|
|
239
|
+
const url = new URL(request.url);
|
|
240
|
+
const pathParts = url.pathname.split("/");
|
|
241
|
+
const providerId = pathParts.at(-1);
|
|
242
|
+
if (providerId === null) {
|
|
243
|
+
throw new Error("Missing provider id");
|
|
244
|
+
}
|
|
245
|
+
const verifier = url.searchParams.get("code");
|
|
246
|
+
if (verifier === null) {
|
|
247
|
+
throw new Error("Missing sign-in verifier");
|
|
248
|
+
}
|
|
249
|
+
const provider = getProviderOrThrow(providerId);
|
|
250
|
+
const { redirect, cookies, signature } = await getAuthorizationUrl({
|
|
251
|
+
provider: await oAuthConfigToInternalProvider(provider),
|
|
252
|
+
cookies: defaultCookiesOptions(providerId),
|
|
253
|
+
});
|
|
254
|
+
await callVerifierSignature(ctx, {
|
|
255
|
+
verifier,
|
|
256
|
+
signature,
|
|
257
|
+
});
|
|
258
|
+
const redirectTo = url.searchParams.get("redirectTo");
|
|
259
|
+
if (redirectTo !== null) {
|
|
260
|
+
cookies.push(redirectToParamCookie(providerId, redirectTo));
|
|
261
|
+
}
|
|
262
|
+
const headers = new Headers({ Location: redirect });
|
|
263
|
+
for (const { name, value, options } of cookies) {
|
|
264
|
+
headers.append("Set-Cookie", serializeCookie(name, value, options));
|
|
265
|
+
}
|
|
266
|
+
return new Response(null, { status: 302, headers });
|
|
267
|
+
})),
|
|
268
|
+
});
|
|
269
|
+
const callbackAction = httpActionGeneric(async (genericCtx, request) => {
|
|
270
|
+
const ctx = genericCtx;
|
|
271
|
+
const url = new URL(request.url);
|
|
272
|
+
const pathParts = url.pathname.split("/");
|
|
273
|
+
const providerId = pathParts.at(-1);
|
|
274
|
+
logWithLevel(LOG_LEVELS.DEBUG, "Handling OAuth callback for provider:", providerId);
|
|
275
|
+
const provider = getProviderOrThrow(providerId);
|
|
276
|
+
const cookies = getCookies(request);
|
|
277
|
+
const maybeRedirectTo = useRedirectToParam(provider.id, cookies);
|
|
278
|
+
const destinationUrl = await redirectAbsoluteUrl(config, {
|
|
279
|
+
redirectTo: maybeRedirectTo?.redirectTo,
|
|
280
|
+
});
|
|
281
|
+
const params = url.searchParams;
|
|
282
|
+
// Handle OAuth providers that use formData (such as Apple)
|
|
283
|
+
if (request.headers.get("Content-Type") ===
|
|
284
|
+
"application/x-www-form-urlencoded") {
|
|
285
|
+
const formData = await request.formData();
|
|
286
|
+
for (const [key, value] of formData.entries()) {
|
|
287
|
+
if (typeof value === "string") {
|
|
288
|
+
params.append(key, value);
|
|
289
|
+
}
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
try {
|
|
293
|
+
const { profile, tokens, signature } = await handleOAuth(Object.fromEntries(params.entries()), cookies, {
|
|
294
|
+
provider: await oAuthConfigToInternalProvider(provider),
|
|
295
|
+
cookies: defaultCookiesOptions(provider.id),
|
|
296
|
+
});
|
|
297
|
+
const { id, ...profileFromCallback } = await provider.profile(profile, tokens);
|
|
298
|
+
if (typeof id !== "string") {
|
|
299
|
+
throw new Error(`The profile method of the ${providerId} config must return a string ID`);
|
|
300
|
+
}
|
|
301
|
+
const verificationCode = await callUserOAuth(ctx, {
|
|
302
|
+
provider: providerId,
|
|
303
|
+
providerAccountId: id,
|
|
304
|
+
profile: profileFromCallback,
|
|
305
|
+
signature,
|
|
306
|
+
});
|
|
307
|
+
return new Response(null, {
|
|
308
|
+
status: 302,
|
|
309
|
+
headers: {
|
|
310
|
+
Location: setURLSearchParam(destinationUrl, "code", verificationCode),
|
|
311
|
+
"Cache-Control": "must-revalidate",
|
|
312
|
+
},
|
|
313
|
+
});
|
|
314
|
+
}
|
|
315
|
+
catch (error) {
|
|
316
|
+
logError(error);
|
|
317
|
+
return Response.redirect(destinationUrl);
|
|
318
|
+
}
|
|
319
|
+
});
|
|
320
|
+
http.route({
|
|
321
|
+
pathPrefix: "/api/auth/callback/",
|
|
322
|
+
method: "GET",
|
|
323
|
+
handler: callbackAction,
|
|
324
|
+
});
|
|
325
|
+
http.route({
|
|
326
|
+
pathPrefix: "/api/auth/callback/",
|
|
327
|
+
method: "POST",
|
|
328
|
+
handler: callbackAction,
|
|
329
|
+
});
|
|
330
|
+
}
|
|
331
|
+
},
|
|
332
|
+
};
|
|
333
|
+
return {
|
|
334
|
+
/**
|
|
335
|
+
* Helper for configuring HTTP actions.
|
|
336
|
+
*/
|
|
337
|
+
auth,
|
|
338
|
+
/**
|
|
339
|
+
* Action called by the client to sign the user in.
|
|
340
|
+
*
|
|
341
|
+
* Also used for refreshing the session.
|
|
342
|
+
*/
|
|
343
|
+
signIn: actionGeneric({
|
|
344
|
+
args: {
|
|
345
|
+
provider: v.optional(v.string()),
|
|
346
|
+
params: v.optional(v.any()),
|
|
347
|
+
verifier: v.optional(v.string()),
|
|
348
|
+
refreshToken: v.optional(v.string()),
|
|
349
|
+
calledBy: v.optional(v.string()),
|
|
350
|
+
},
|
|
351
|
+
handler: async (ctx, args) => {
|
|
352
|
+
if (args.calledBy !== undefined) {
|
|
353
|
+
logWithLevel("INFO", `\`auth:signIn\` called by ${args.calledBy}`);
|
|
354
|
+
}
|
|
355
|
+
const provider = args.provider !== undefined
|
|
356
|
+
? getProviderOrThrow(args.provider)
|
|
357
|
+
: null;
|
|
358
|
+
const result = await signInImpl(enrichCtx(ctx), provider, args, {
|
|
359
|
+
generateTokens: true,
|
|
360
|
+
allowExtraProviders: false,
|
|
361
|
+
});
|
|
362
|
+
switch (result.kind) {
|
|
363
|
+
case "redirect":
|
|
364
|
+
return { redirect: result.redirect, verifier: result.verifier };
|
|
365
|
+
case "signedIn":
|
|
366
|
+
case "refreshTokens":
|
|
367
|
+
return { tokens: result.signedIn?.tokens ?? null };
|
|
368
|
+
case "started":
|
|
369
|
+
return { started: true };
|
|
370
|
+
default: {
|
|
371
|
+
const _typecheck = result;
|
|
372
|
+
throw new Error(`Unexpected result from signIn, ${result}`);
|
|
373
|
+
}
|
|
374
|
+
}
|
|
375
|
+
},
|
|
376
|
+
}),
|
|
377
|
+
/**
|
|
378
|
+
* Action called by the client to invalidate the current session.
|
|
379
|
+
*/
|
|
380
|
+
signOut: actionGeneric({
|
|
381
|
+
args: {},
|
|
382
|
+
handler: async (ctx) => {
|
|
383
|
+
await callSignOut(ctx);
|
|
384
|
+
},
|
|
385
|
+
}),
|
|
386
|
+
/**
|
|
387
|
+
* Internal mutation used by the library to read and write
|
|
388
|
+
* to the database during signin and signout.
|
|
389
|
+
*/
|
|
390
|
+
store: internalMutationGeneric({
|
|
391
|
+
args: storeArgs,
|
|
392
|
+
handler: async (ctx, args) => {
|
|
393
|
+
return storeImpl(ctx, args, getProviderOrThrow, config);
|
|
394
|
+
},
|
|
395
|
+
}),
|
|
396
|
+
};
|
|
397
|
+
}
|
|
398
|
+
/**
|
|
399
|
+
* Return the currently signed-in user's ID.
|
|
400
|
+
*
|
|
401
|
+
* ```ts filename="convex/myFunctions.tsx"
|
|
402
|
+
* import { mutation } from "./_generated/server";
|
|
403
|
+
* import { getAuthUserId } from "@robelest/convex-auth/component";
|
|
404
|
+
*
|
|
405
|
+
* export const doSomething = mutation({
|
|
406
|
+
* args: {/* ... *\/},
|
|
407
|
+
* handler: async (ctx, args) => {
|
|
408
|
+
* const userId = await getAuthUserId(ctx);
|
|
409
|
+
* if (userId === null) {
|
|
410
|
+
* throw new Error("Client is not authenticated!")
|
|
411
|
+
* }
|
|
412
|
+
* const user = await ctx.db.get(userId);
|
|
413
|
+
* // ...
|
|
414
|
+
* },
|
|
415
|
+
* });
|
|
416
|
+
* ```
|
|
417
|
+
*
|
|
418
|
+
* @param ctx query, mutation or action `ctx`
|
|
419
|
+
* @returns the user ID or `null` if the client isn't authenticated
|
|
420
|
+
*/
|
|
421
|
+
export async function getAuthUserId(ctx) {
|
|
422
|
+
const identity = await ctx.auth.getUserIdentity();
|
|
423
|
+
if (identity === null) {
|
|
424
|
+
return null;
|
|
425
|
+
}
|
|
426
|
+
const [userId] = identity.subject.split(TOKEN_SUB_CLAIM_DIVIDER);
|
|
427
|
+
return userId;
|
|
428
|
+
}
|
|
429
|
+
/**
|
|
430
|
+
* Use this function from a
|
|
431
|
+
* [`ConvexCredentials`](https://labs.convex.dev/auth/api_reference/providers/ConvexCredentials)
|
|
432
|
+
* provider to create an account and a user with a unique account "id" (OAuth
|
|
433
|
+
* provider ID, email address, phone number, username etc.).
|
|
434
|
+
*
|
|
435
|
+
* @returns user ID if it successfully creates the account
|
|
436
|
+
* or throws an error.
|
|
437
|
+
*/
|
|
438
|
+
export async function createAccount(ctx, args) {
|
|
439
|
+
const actionCtx = ctx;
|
|
440
|
+
return (await callCreateAccountFromCredentials(actionCtx, args));
|
|
441
|
+
}
|
|
442
|
+
/**
|
|
443
|
+
* Use this function from a
|
|
444
|
+
* [`ConvexCredentials`](https://labs.convex.dev/auth/api_reference/providers/ConvexCredentials)
|
|
445
|
+
* provider to retrieve a user given the account provider ID and
|
|
446
|
+
* the provider-specific account ID.
|
|
447
|
+
*
|
|
448
|
+
* @returns the retrieved user document, or `null` if there is no account
|
|
449
|
+
* for given account ID or throws if the provided
|
|
450
|
+
* secret does not match.
|
|
451
|
+
*/
|
|
452
|
+
export async function retrieveAccount(ctx, args) {
|
|
453
|
+
const actionCtx = ctx;
|
|
454
|
+
const result = await callRetreiveAccountWithCredentials(actionCtx, args);
|
|
455
|
+
if (typeof result === "string") {
|
|
456
|
+
throw new Error(result);
|
|
457
|
+
}
|
|
458
|
+
return result;
|
|
459
|
+
}
|
|
460
|
+
/**
|
|
461
|
+
* Use this function to modify the account credentials
|
|
462
|
+
* from a [`ConvexCredentials`](https://labs.convex.dev/auth/api_reference/providers/ConvexCredentials)
|
|
463
|
+
* provider.
|
|
464
|
+
*/
|
|
465
|
+
export async function modifyAccountCredentials(ctx, args) {
|
|
466
|
+
const actionCtx = ctx;
|
|
467
|
+
return await callModifyAccount(actionCtx, args);
|
|
468
|
+
}
|
|
469
|
+
/**
|
|
470
|
+
* Use this function to invalidate existing sessions.
|
|
471
|
+
*/
|
|
472
|
+
export async function invalidateSessions(ctx, args) {
|
|
473
|
+
const actionCtx = ctx;
|
|
474
|
+
return await callInvalidateSessions(actionCtx, args);
|
|
475
|
+
}
|
|
476
|
+
/**
|
|
477
|
+
* Use this function from a
|
|
478
|
+
* [`ConvexCredentials`](https://labs.convex.dev/auth/api_reference/providers/ConvexCredentials)
|
|
479
|
+
* provider to sign in the user via another provider (usually
|
|
480
|
+
* for email verification on sign up or password reset).
|
|
481
|
+
*
|
|
482
|
+
* Returns the user ID if the sign can proceed,
|
|
483
|
+
* or `null`.
|
|
484
|
+
*/
|
|
485
|
+
export async function signInViaProvider(ctx, provider, args) {
|
|
486
|
+
const result = await signInImpl(ctx, materializeProvider(provider), args, {
|
|
487
|
+
generateTokens: false,
|
|
488
|
+
allowExtraProviders: true,
|
|
489
|
+
});
|
|
490
|
+
return result.kind === "signedIn"
|
|
491
|
+
? result.signedIn !== null
|
|
492
|
+
? { userId: result.signedIn.userId, sessionId: result.signedIn.sessionId }
|
|
493
|
+
: null
|
|
494
|
+
: null;
|
|
495
|
+
}
|
|
496
|
+
function convertErrorsToResponse(errorStatusCode, action) {
|
|
497
|
+
return async (ctx, request) => {
|
|
498
|
+
try {
|
|
499
|
+
return await action(ctx, request);
|
|
500
|
+
}
|
|
501
|
+
catch (error) {
|
|
502
|
+
if (error instanceof ConvexError) {
|
|
503
|
+
return new Response(null, {
|
|
504
|
+
status: errorStatusCode,
|
|
505
|
+
statusText: error.data,
|
|
506
|
+
});
|
|
507
|
+
}
|
|
508
|
+
else {
|
|
509
|
+
logError(error);
|
|
510
|
+
return new Response(null, {
|
|
511
|
+
status: 500,
|
|
512
|
+
statusText: "Internal Server Error",
|
|
513
|
+
});
|
|
514
|
+
}
|
|
515
|
+
}
|
|
516
|
+
};
|
|
517
|
+
}
|
|
518
|
+
function getCookies(request) {
|
|
519
|
+
return parseCookies(request.headers.get("Cookie") ?? "");
|
|
520
|
+
}
|
|
521
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/server/implementation/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { Infer } from "convex/values";
|
|
2
|
+
import { ActionCtx, Doc, MutationCtx } from "../types.js";
|
|
3
|
+
import * as Provider from "../provider.js";
|
|
4
|
+
export declare const createAccountFromCredentialsArgs: import("convex/values").VObject<{
|
|
5
|
+
shouldLinkViaEmail?: boolean | undefined;
|
|
6
|
+
shouldLinkViaPhone?: boolean | undefined;
|
|
7
|
+
profile: any;
|
|
8
|
+
account: {
|
|
9
|
+
secret?: string | undefined;
|
|
10
|
+
id: string;
|
|
11
|
+
};
|
|
12
|
+
provider: string;
|
|
13
|
+
}, {
|
|
14
|
+
provider: import("convex/values").VString<string, "required">;
|
|
15
|
+
account: import("convex/values").VObject<{
|
|
16
|
+
secret?: string | undefined;
|
|
17
|
+
id: string;
|
|
18
|
+
}, {
|
|
19
|
+
id: import("convex/values").VString<string, "required">;
|
|
20
|
+
secret: import("convex/values").VString<string | undefined, "optional">;
|
|
21
|
+
}, "required", "id" | "secret">;
|
|
22
|
+
profile: import("convex/values").VAny<any, "required", string>;
|
|
23
|
+
shouldLinkViaEmail: import("convex/values").VBoolean<boolean | undefined, "optional">;
|
|
24
|
+
shouldLinkViaPhone: import("convex/values").VBoolean<boolean | undefined, "optional">;
|
|
25
|
+
}, "required", "profile" | "account" | "provider" | `profile.${string}` | "shouldLinkViaEmail" | "shouldLinkViaPhone" | "account.id" | "account.secret">;
|
|
26
|
+
type ReturnType = {
|
|
27
|
+
account: Doc<"account">;
|
|
28
|
+
user: Doc<"user">;
|
|
29
|
+
};
|
|
30
|
+
export declare function createAccountFromCredentialsImpl(ctx: MutationCtx, args: Infer<typeof createAccountFromCredentialsArgs>, getProviderOrThrow: Provider.GetProviderOrThrowFunc, config: Provider.Config): Promise<ReturnType>;
|
|
31
|
+
export declare const callCreateAccountFromCredentials: (ctx: ActionCtx, args: Infer<typeof createAccountFromCredentialsArgs>) => Promise<ReturnType>;
|
|
32
|
+
export {};
|
|
33
|
+
//# sourceMappingURL=createAccountFromCredentials.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createAccountFromCredentials.d.ts","sourceRoot":"","sources":["../../../../src/server/implementation/mutations/createAccountFromCredentials.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAK,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,SAAS,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1D,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAO3C,eAAO,MAAM,gCAAgC;;;;;;;;;;;;;;;;;;;;;wJAM3C,CAAC;AAEH,KAAK,UAAU,GAAG;IAAE,OAAO,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC;IAAC,IAAI,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;CAAE,CAAC;AAEjE,wBAAsB,gCAAgC,CACpD,GAAG,EAAE,WAAW,EAChB,IAAI,EAAE,KAAK,CAAC,OAAO,gCAAgC,CAAC,EACpD,kBAAkB,EAAE,QAAQ,CAAC,sBAAsB,EACnD,MAAM,EAAE,QAAQ,CAAC,MAAM,GACtB,OAAO,CAAC,UAAU,CAAC,CA4ErB;AAED,eAAO,MAAM,gCAAgC,GAC3C,KAAK,SAAS,EACd,MAAM,KAAK,CAAC,OAAO,gCAAgC,CAAC,KACnD,OAAO,CAAC,UAAU,CAOpB,CAAC"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { v } from "convex/values";
|
|
2
|
+
import * as Provider from "../provider.js";
|
|
3
|
+
import { upsertUserAndAccount } from "../users.js";
|
|
4
|
+
import { getAuthSessionId } from "../sessions.js";
|
|
5
|
+
import { LOG_LEVELS, logWithLevel, maybeRedact } from "../utils.js";
|
|
6
|
+
import { createAuthDb } from "../db.js";
|
|
7
|
+
export const createAccountFromCredentialsArgs = v.object({
|
|
8
|
+
provider: v.string(),
|
|
9
|
+
account: v.object({ id: v.string(), secret: v.optional(v.string()) }),
|
|
10
|
+
profile: v.any(),
|
|
11
|
+
shouldLinkViaEmail: v.optional(v.boolean()),
|
|
12
|
+
shouldLinkViaPhone: v.optional(v.boolean()),
|
|
13
|
+
});
|
|
14
|
+
export async function createAccountFromCredentialsImpl(ctx, args, getProviderOrThrow, config) {
|
|
15
|
+
logWithLevel(LOG_LEVELS.DEBUG, "createAccountFromCredentialsImpl args:", {
|
|
16
|
+
provider: args.provider,
|
|
17
|
+
account: {
|
|
18
|
+
id: args.account.id,
|
|
19
|
+
secret: maybeRedact(args.account.secret ?? ""),
|
|
20
|
+
},
|
|
21
|
+
});
|
|
22
|
+
const { provider: providerId, account, profile, shouldLinkViaEmail, shouldLinkViaPhone, } = args;
|
|
23
|
+
const authDb = config.component !== undefined ? createAuthDb(ctx, config.component) : null;
|
|
24
|
+
const provider = getProviderOrThrow(providerId);
|
|
25
|
+
const existingAccount = authDb !== null
|
|
26
|
+
? (await authDb.accounts.get(provider.id, account.id))
|
|
27
|
+
: await ctx.db
|
|
28
|
+
.query("account")
|
|
29
|
+
.withIndex("providerAndAccountId", (q) => q.eq("provider", provider.id).eq("providerAccountId", account.id))
|
|
30
|
+
.unique();
|
|
31
|
+
if (existingAccount !== null) {
|
|
32
|
+
if (account.secret !== undefined &&
|
|
33
|
+
!(await Provider.verify(provider, account.secret, existingAccount.secret ?? ""))) {
|
|
34
|
+
throw new Error(`Account ${account.id} already exists`);
|
|
35
|
+
}
|
|
36
|
+
return {
|
|
37
|
+
account: existingAccount,
|
|
38
|
+
// TODO: Ian removed this,
|
|
39
|
+
user: authDb !== null
|
|
40
|
+
? (await authDb.users.getById(existingAccount.userId))
|
|
41
|
+
: (await ctx.db.get(existingAccount.userId)),
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
const secret = account.secret !== undefined
|
|
45
|
+
? await Provider.hash(provider, account.secret)
|
|
46
|
+
: undefined;
|
|
47
|
+
const { userId, accountId } = await upsertUserAndAccount(ctx, await getAuthSessionId(ctx), { providerAccountId: account.id, secret }, {
|
|
48
|
+
type: "credentials",
|
|
49
|
+
provider,
|
|
50
|
+
profile,
|
|
51
|
+
shouldLinkViaEmail,
|
|
52
|
+
shouldLinkViaPhone,
|
|
53
|
+
}, config);
|
|
54
|
+
return {
|
|
55
|
+
account: authDb !== null
|
|
56
|
+
? (await authDb.accounts.getById(accountId))
|
|
57
|
+
: (await ctx.db.get(accountId)),
|
|
58
|
+
user: authDb !== null
|
|
59
|
+
? (await authDb.users.getById(userId))
|
|
60
|
+
: (await ctx.db.get(userId)),
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
export const callCreateAccountFromCredentials = async (ctx, args) => {
|
|
64
|
+
return ctx.runMutation("auth:store", {
|
|
65
|
+
args: {
|
|
66
|
+
type: "createAccountFromCredentials",
|
|
67
|
+
...args,
|
|
68
|
+
},
|
|
69
|
+
});
|
|
70
|
+
};
|
|
71
|
+
//# sourceMappingURL=createAccountFromCredentials.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createAccountFromCredentials.js","sourceRoot":"","sources":["../../../../src/server/implementation/mutations/createAccountFromCredentials.ts"],"names":[],"mappings":"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"}
|