@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.
Files changed (280) hide show
  1. package/README.md +6 -0
  2. package/dist/bin.cjs +27733 -0
  3. package/dist/client/index.d.ts +49 -0
  4. package/dist/client/index.d.ts.map +1 -0
  5. package/dist/client/index.js +283 -0
  6. package/dist/client/index.js.map +1 -0
  7. package/dist/component/_generated/api.d.ts +36 -0
  8. package/dist/component/_generated/api.d.ts.map +1 -0
  9. package/dist/component/_generated/api.js +31 -0
  10. package/dist/component/_generated/api.js.map +1 -0
  11. package/dist/component/_generated/component.d.ts +295 -0
  12. package/dist/component/_generated/component.d.ts.map +1 -0
  13. package/dist/component/_generated/component.js +11 -0
  14. package/dist/component/_generated/component.js.map +1 -0
  15. package/dist/component/_generated/dataModel.d.ts +46 -0
  16. package/dist/component/_generated/dataModel.d.ts.map +1 -0
  17. package/dist/component/_generated/dataModel.js +11 -0
  18. package/dist/component/_generated/dataModel.js.map +1 -0
  19. package/dist/component/_generated/server.d.ts +121 -0
  20. package/dist/component/_generated/server.d.ts.map +1 -0
  21. package/dist/component/_generated/server.js +78 -0
  22. package/dist/component/_generated/server.js.map +1 -0
  23. package/dist/component/convex.config.d.ts +3 -0
  24. package/dist/component/convex.config.d.ts.map +1 -0
  25. package/dist/component/convex.config.js +4 -0
  26. package/dist/component/convex.config.js.map +1 -0
  27. package/dist/component/index.d.ts +15 -0
  28. package/dist/component/index.d.ts.map +1 -0
  29. package/dist/component/index.js +13 -0
  30. package/dist/component/index.js.map +1 -0
  31. package/dist/component/public.d.ts +450 -0
  32. package/dist/component/public.d.ts.map +1 -0
  33. package/dist/component/public.js +528 -0
  34. package/dist/component/public.js.map +1 -0
  35. package/dist/component/schema.d.ts +107 -0
  36. package/dist/component/schema.d.ts.map +1 -0
  37. package/dist/component/schema.js +26 -0
  38. package/dist/component/schema.js.map +1 -0
  39. package/dist/providers/Anonymous.d.ts +50 -0
  40. package/dist/providers/Anonymous.d.ts.map +1 -0
  41. package/dist/providers/Anonymous.js +39 -0
  42. package/dist/providers/Anonymous.js.map +1 -0
  43. package/dist/providers/ConvexCredentials.d.ts +88 -0
  44. package/dist/providers/ConvexCredentials.d.ts.map +1 -0
  45. package/dist/providers/ConvexCredentials.js +37 -0
  46. package/dist/providers/ConvexCredentials.js.map +1 -0
  47. package/dist/providers/Email.d.ts +33 -0
  48. package/dist/providers/Email.d.ts.map +1 -0
  49. package/dist/providers/Email.js +50 -0
  50. package/dist/providers/Email.js.map +1 -0
  51. package/dist/providers/Password.d.ts +95 -0
  52. package/dist/providers/Password.d.ts.map +1 -0
  53. package/dist/providers/Password.js +174 -0
  54. package/dist/providers/Password.js.map +1 -0
  55. package/dist/providers/Phone.d.ts +22 -0
  56. package/dist/providers/Phone.d.ts.map +1 -0
  57. package/dist/providers/Phone.js +37 -0
  58. package/dist/providers/Phone.js.map +1 -0
  59. package/dist/server/convex_types.d.ts +17 -0
  60. package/dist/server/convex_types.d.ts.map +1 -0
  61. package/dist/server/convex_types.js +2 -0
  62. package/dist/server/convex_types.js.map +1 -0
  63. package/dist/server/cookies.d.ts +35 -0
  64. package/dist/server/cookies.d.ts.map +1 -0
  65. package/dist/server/cookies.js +34 -0
  66. package/dist/server/cookies.js.map +1 -0
  67. package/dist/server/implementation/db.d.ts +80 -0
  68. package/dist/server/implementation/db.d.ts.map +1 -0
  69. package/dist/server/implementation/db.js +59 -0
  70. package/dist/server/implementation/db.js.map +1 -0
  71. package/dist/server/implementation/index.d.ts +370 -0
  72. package/dist/server/implementation/index.d.ts.map +1 -0
  73. package/dist/server/implementation/index.js +521 -0
  74. package/dist/server/implementation/index.js.map +1 -0
  75. package/dist/server/implementation/mutations/createAccountFromCredentials.d.ts +33 -0
  76. package/dist/server/implementation/mutations/createAccountFromCredentials.d.ts.map +1 -0
  77. package/dist/server/implementation/mutations/createAccountFromCredentials.js +71 -0
  78. package/dist/server/implementation/mutations/createAccountFromCredentials.js.map +1 -0
  79. package/dist/server/implementation/mutations/createVerificationCode.d.ts +25 -0
  80. package/dist/server/implementation/mutations/createVerificationCode.d.ts.map +1 -0
  81. package/dist/server/implementation/mutations/createVerificationCode.js +84 -0
  82. package/dist/server/implementation/mutations/createVerificationCode.js.map +1 -0
  83. package/dist/server/implementation/mutations/index.d.ts +304 -0
  84. package/dist/server/implementation/mutations/index.d.ts.map +1 -0
  85. package/dist/server/implementation/mutations/index.js +108 -0
  86. package/dist/server/implementation/mutations/index.js.map +1 -0
  87. package/dist/server/implementation/mutations/invalidateSessions.d.ts +13 -0
  88. package/dist/server/implementation/mutations/invalidateSessions.d.ts.map +1 -0
  89. package/dist/server/implementation/mutations/invalidateSessions.js +35 -0
  90. package/dist/server/implementation/mutations/invalidateSessions.js.map +1 -0
  91. package/dist/server/implementation/mutations/modifyAccount.d.ts +23 -0
  92. package/dist/server/implementation/mutations/modifyAccount.d.ts.map +1 -0
  93. package/dist/server/implementation/mutations/modifyAccount.js +48 -0
  94. package/dist/server/implementation/mutations/modifyAccount.js.map +1 -0
  95. package/dist/server/implementation/mutations/refreshSession.d.ts +16 -0
  96. package/dist/server/implementation/mutations/refreshSession.d.ts.map +1 -0
  97. package/dist/server/implementation/mutations/refreshSession.js +116 -0
  98. package/dist/server/implementation/mutations/refreshSession.js.map +1 -0
  99. package/dist/server/implementation/mutations/retrieveAccountWithCredentials.d.ts +27 -0
  100. package/dist/server/implementation/mutations/retrieveAccountWithCredentials.d.ts.map +1 -0
  101. package/dist/server/implementation/mutations/retrieveAccountWithCredentials.js +55 -0
  102. package/dist/server/implementation/mutations/retrieveAccountWithCredentials.js.map +1 -0
  103. package/dist/server/implementation/mutations/signIn.d.ts +17 -0
  104. package/dist/server/implementation/mutations/signIn.d.ts.map +1 -0
  105. package/dist/server/implementation/mutations/signIn.js +26 -0
  106. package/dist/server/implementation/mutations/signIn.js.map +1 -0
  107. package/dist/server/implementation/mutations/signOut.d.ts +11 -0
  108. package/dist/server/implementation/mutations/signOut.d.ts.map +1 -0
  109. package/dist/server/implementation/mutations/signOut.js +24 -0
  110. package/dist/server/implementation/mutations/signOut.js.map +1 -0
  111. package/dist/server/implementation/mutations/userOAuth.d.ts +19 -0
  112. package/dist/server/implementation/mutations/userOAuth.d.ts.map +1 -0
  113. package/dist/server/implementation/mutations/userOAuth.js +84 -0
  114. package/dist/server/implementation/mutations/userOAuth.js.map +1 -0
  115. package/dist/server/implementation/mutations/verifier.d.ts +8 -0
  116. package/dist/server/implementation/mutations/verifier.d.ts.map +1 -0
  117. package/dist/server/implementation/mutations/verifier.js +19 -0
  118. package/dist/server/implementation/mutations/verifier.js.map +1 -0
  119. package/dist/server/implementation/mutations/verifierSignature.d.ts +15 -0
  120. package/dist/server/implementation/mutations/verifierSignature.d.ts.map +1 -0
  121. package/dist/server/implementation/mutations/verifierSignature.js +29 -0
  122. package/dist/server/implementation/mutations/verifierSignature.js.map +1 -0
  123. package/dist/server/implementation/mutations/verifyCodeAndSignIn.d.ts +21 -0
  124. package/dist/server/implementation/mutations/verifyCodeAndSignIn.d.ts.map +1 -0
  125. package/dist/server/implementation/mutations/verifyCodeAndSignIn.js +127 -0
  126. package/dist/server/implementation/mutations/verifyCodeAndSignIn.js.map +1 -0
  127. package/dist/server/implementation/provider.d.ts +6 -0
  128. package/dist/server/implementation/provider.d.ts.map +1 -0
  129. package/dist/server/implementation/provider.js +21 -0
  130. package/dist/server/implementation/provider.js.map +1 -0
  131. package/dist/server/implementation/rateLimit.d.ts +6 -0
  132. package/dist/server/implementation/rateLimit.d.ts.map +1 -0
  133. package/dist/server/implementation/rateLimit.js +76 -0
  134. package/dist/server/implementation/rateLimit.js.map +1 -0
  135. package/dist/server/implementation/redirects.d.ts +6 -0
  136. package/dist/server/implementation/redirects.d.ts.map +1 -0
  137. package/dist/server/implementation/redirects.js +40 -0
  138. package/dist/server/implementation/redirects.js.map +1 -0
  139. package/dist/server/implementation/refreshTokens.d.ts +40 -0
  140. package/dist/server/implementation/refreshTokens.d.ts.map +1 -0
  141. package/dist/server/implementation/refreshTokens.js +160 -0
  142. package/dist/server/implementation/refreshTokens.js.map +1 -0
  143. package/dist/server/implementation/sessions.d.ts +43 -0
  144. package/dist/server/implementation/sessions.d.ts.map +1 -0
  145. package/dist/server/implementation/sessions.js +94 -0
  146. package/dist/server/implementation/sessions.js.map +1 -0
  147. package/dist/server/implementation/signIn.d.ts +31 -0
  148. package/dist/server/implementation/signIn.d.ts.map +1 -0
  149. package/dist/server/implementation/signIn.js +148 -0
  150. package/dist/server/implementation/signIn.js.map +1 -0
  151. package/dist/server/implementation/tokens.d.ts +7 -0
  152. package/dist/server/implementation/tokens.d.ts.map +1 -0
  153. package/dist/server/implementation/tokens.js +18 -0
  154. package/dist/server/implementation/tokens.js.map +1 -0
  155. package/dist/server/implementation/types.d.ts +288 -0
  156. package/dist/server/implementation/types.d.ts.map +1 -0
  157. package/dist/server/implementation/types.js +182 -0
  158. package/dist/server/implementation/types.js.map +1 -0
  159. package/dist/server/implementation/users.d.ts +27 -0
  160. package/dist/server/implementation/users.d.ts.map +1 -0
  161. package/dist/server/implementation/users.js +181 -0
  162. package/dist/server/implementation/users.js.map +1 -0
  163. package/dist/server/implementation/utils.d.ts +17 -0
  164. package/dist/server/implementation/utils.d.ts.map +1 -0
  165. package/dist/server/implementation/utils.js +72 -0
  166. package/dist/server/implementation/utils.js.map +1 -0
  167. package/dist/server/index.d.ts +17 -0
  168. package/dist/server/index.d.ts.map +1 -0
  169. package/dist/server/index.js +54 -0
  170. package/dist/server/index.js.map +1 -0
  171. package/dist/server/oauth/authorizationUrl.d.ts +13 -0
  172. package/dist/server/oauth/authorizationUrl.d.ts.map +1 -0
  173. package/dist/server/oauth/authorizationUrl.js +91 -0
  174. package/dist/server/oauth/authorizationUrl.js.map +1 -0
  175. package/dist/server/oauth/callback.d.ts +19 -0
  176. package/dist/server/oauth/callback.d.ts.map +1 -0
  177. package/dist/server/oauth/callback.js +173 -0
  178. package/dist/server/oauth/callback.js.map +1 -0
  179. package/dist/server/oauth/checks.d.ts +52 -0
  180. package/dist/server/oauth/checks.d.ts.map +1 -0
  181. package/dist/server/oauth/checks.js +106 -0
  182. package/dist/server/oauth/checks.js.map +1 -0
  183. package/dist/server/oauth/convexAuth.d.ts +12 -0
  184. package/dist/server/oauth/convexAuth.d.ts.map +1 -0
  185. package/dist/server/oauth/convexAuth.js +137 -0
  186. package/dist/server/oauth/convexAuth.js.map +1 -0
  187. package/dist/server/oauth/lib/utils/customFetch.d.ts +9 -0
  188. package/dist/server/oauth/lib/utils/customFetch.d.ts.map +1 -0
  189. package/dist/server/oauth/lib/utils/customFetch.js +11 -0
  190. package/dist/server/oauth/lib/utils/customFetch.js.map +1 -0
  191. package/dist/server/oauth/lib/utils/providers.d.ts +3 -0
  192. package/dist/server/oauth/lib/utils/providers.d.ts.map +1 -0
  193. package/dist/server/oauth/lib/utils/providers.js +7 -0
  194. package/dist/server/oauth/lib/utils/providers.js.map +1 -0
  195. package/dist/server/oauth/providers/oauth.d.ts +43 -0
  196. package/dist/server/oauth/providers/oauth.d.ts.map +1 -0
  197. package/dist/server/oauth/providers/oauth.js +3 -0
  198. package/dist/server/oauth/providers/oauth.js.map +1 -0
  199. package/dist/server/oauth/types.d.ts +24 -0
  200. package/dist/server/oauth/types.d.ts.map +1 -0
  201. package/dist/server/oauth/types.js +5 -0
  202. package/dist/server/oauth/types.js.map +1 -0
  203. package/dist/server/provider_utils.d.ts +76 -0
  204. package/dist/server/provider_utils.d.ts.map +1 -0
  205. package/dist/server/provider_utils.js +177 -0
  206. package/dist/server/provider_utils.js.map +1 -0
  207. package/dist/server/types.d.ts +412 -0
  208. package/dist/server/types.d.ts.map +1 -0
  209. package/dist/server/types.js +2 -0
  210. package/dist/server/types.js.map +1 -0
  211. package/dist/server/utils.d.ts +3 -0
  212. package/dist/server/utils.d.ts.map +1 -0
  213. package/dist/server/utils.js +11 -0
  214. package/dist/server/utils.js.map +1 -0
  215. package/package.json +126 -0
  216. package/providers/Anonymous/package.json +6 -0
  217. package/providers/ConvexCredentials/package.json +6 -0
  218. package/providers/Email/package.json +6 -0
  219. package/providers/Password/package.json +6 -0
  220. package/providers/Phone/package.json +6 -0
  221. package/server/package.json +6 -0
  222. package/src/cli/command.ts +69 -0
  223. package/src/cli/generateKeys.ts +20 -0
  224. package/src/cli/index.ts +840 -0
  225. package/src/client/index.ts +415 -0
  226. package/src/component/_generated/api.ts +52 -0
  227. package/src/component/_generated/component.ts +586 -0
  228. package/src/component/_generated/dataModel.ts +60 -0
  229. package/src/component/_generated/server.ts +156 -0
  230. package/src/component/convex.config.ts +5 -0
  231. package/src/component/index.ts +40 -0
  232. package/src/component/public.ts +607 -0
  233. package/src/component/schema.ts +35 -0
  234. package/src/providers/Anonymous.ts +79 -0
  235. package/src/providers/ConvexCredentials.ts +108 -0
  236. package/src/providers/Email.ts +60 -0
  237. package/src/providers/Password.ts +253 -0
  238. package/src/providers/Phone.ts +46 -0
  239. package/src/server/convex_types.ts +55 -0
  240. package/src/server/cookies.ts +42 -0
  241. package/src/server/implementation/db.ts +125 -0
  242. package/src/server/implementation/index.ts +815 -0
  243. package/src/server/implementation/mutations/createAccountFromCredentials.ts +113 -0
  244. package/src/server/implementation/mutations/createVerificationCode.ts +139 -0
  245. package/src/server/implementation/mutations/index.ts +157 -0
  246. package/src/server/implementation/mutations/invalidateSessions.ts +47 -0
  247. package/src/server/implementation/mutations/modifyAccount.ts +65 -0
  248. package/src/server/implementation/mutations/refreshSession.ts +188 -0
  249. package/src/server/implementation/mutations/retrieveAccountWithCredentials.ts +87 -0
  250. package/src/server/implementation/mutations/signIn.ts +51 -0
  251. package/src/server/implementation/mutations/signOut.ts +38 -0
  252. package/src/server/implementation/mutations/userOAuth.ts +112 -0
  253. package/src/server/implementation/mutations/verifier.ts +29 -0
  254. package/src/server/implementation/mutations/verifierSignature.ts +44 -0
  255. package/src/server/implementation/mutations/verifyCodeAndSignIn.ts +205 -0
  256. package/src/server/implementation/provider.ts +38 -0
  257. package/src/server/implementation/rateLimit.ts +105 -0
  258. package/src/server/implementation/redirects.ts +58 -0
  259. package/src/server/implementation/refreshTokens.ts +221 -0
  260. package/src/server/implementation/sessions.ts +155 -0
  261. package/src/server/implementation/signIn.ts +253 -0
  262. package/src/server/implementation/tokens.ts +29 -0
  263. package/src/server/implementation/types.ts +220 -0
  264. package/src/server/implementation/users.ts +286 -0
  265. package/src/server/implementation/utils.ts +91 -0
  266. package/src/server/index.ts +74 -0
  267. package/src/server/oauth/NOTICE.txt +21 -0
  268. package/src/server/oauth/README.md +7 -0
  269. package/src/server/oauth/authorizationUrl.ts +113 -0
  270. package/src/server/oauth/callback.ts +243 -0
  271. package/src/server/oauth/checks.ts +136 -0
  272. package/src/server/oauth/convexAuth.ts +168 -0
  273. package/src/server/oauth/lib/utils/customFetch.ts +18 -0
  274. package/src/server/oauth/lib/utils/providers.ts +12 -0
  275. package/src/server/oauth/providers/oauth.ts +56 -0
  276. package/src/server/oauth/types.ts +60 -0
  277. package/src/server/provider_utils.ts +222 -0
  278. package/src/server/types.ts +470 -0
  279. package/src/server/utils.ts +12 -0
  280. 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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"}