@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,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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=convex_types.js.map
@@ -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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"}