@robelest/convex-auth 0.0.4-preview.21 → 0.0.4-preview.23

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 (310) hide show
  1. package/dist/authorization/index.d.ts +1 -1
  2. package/dist/authorization/index.js +1 -1
  3. package/dist/authorization/index.js.map +1 -1
  4. package/dist/client/index.d.ts +1 -2
  5. package/dist/client/index.d.ts.map +1 -1
  6. package/dist/client/index.js +36 -39
  7. package/dist/client/index.js.map +1 -1
  8. package/dist/component/client/index.d.ts +1 -2
  9. package/dist/component/convex.config.d.ts +2 -2
  10. package/dist/component/convex.config.d.ts.map +1 -1
  11. package/dist/component/model.d.ts +5 -5
  12. package/dist/component/model.d.ts.map +1 -1
  13. package/dist/component/public/enterprise/audit.d.ts.map +1 -1
  14. package/dist/component/public/enterprise/audit.js.map +1 -1
  15. package/dist/component/public/enterprise/core.d.ts.map +1 -1
  16. package/dist/component/public/enterprise/core.js.map +1 -1
  17. package/dist/component/public/enterprise/domains.d.ts.map +1 -1
  18. package/dist/component/public/enterprise/domains.js.map +1 -1
  19. package/dist/component/public/enterprise/scim.d.ts.map +1 -1
  20. package/dist/component/public/enterprise/scim.js.map +1 -1
  21. package/dist/component/public/enterprise/secrets.d.ts.map +1 -1
  22. package/dist/component/public/enterprise/secrets.js.map +1 -1
  23. package/dist/component/public/enterprise/webhooks.d.ts.map +1 -1
  24. package/dist/component/public/enterprise/webhooks.js.map +1 -1
  25. package/dist/component/public/factors/devices.d.ts.map +1 -1
  26. package/dist/component/public/factors/devices.js.map +1 -1
  27. package/dist/component/public/factors/passkeys.d.ts.map +1 -1
  28. package/dist/component/public/factors/passkeys.js.map +1 -1
  29. package/dist/component/public/factors/totp.d.ts.map +1 -1
  30. package/dist/component/public/factors/totp.js.map +1 -1
  31. package/dist/component/public/groups/core.js.map +1 -1
  32. package/dist/component/public/groups/invites.d.ts.map +1 -1
  33. package/dist/component/public/groups/invites.js.map +1 -1
  34. package/dist/component/public/groups/members.d.ts.map +1 -1
  35. package/dist/component/public/groups/members.js.map +1 -1
  36. package/dist/component/public/identity/accounts.d.ts.map +1 -1
  37. package/dist/component/public/identity/accounts.js.map +1 -1
  38. package/dist/component/public/identity/codes.d.ts.map +1 -1
  39. package/dist/component/public/identity/codes.js.map +1 -1
  40. package/dist/component/public/identity/sessions.d.ts.map +1 -1
  41. package/dist/component/public/identity/sessions.js.map +1 -1
  42. package/dist/component/public/identity/tokens.d.ts.map +1 -1
  43. package/dist/component/public/identity/tokens.js.map +1 -1
  44. package/dist/component/public/identity/users.d.ts.map +1 -1
  45. package/dist/component/public/identity/users.js.map +1 -1
  46. package/dist/component/public/identity/verifiers.d.ts.map +1 -1
  47. package/dist/component/public/identity/verifiers.js.map +1 -1
  48. package/dist/component/public/security/keys.d.ts.map +1 -1
  49. package/dist/component/public/security/keys.js.map +1 -1
  50. package/dist/component/public/security/limits.d.ts.map +1 -1
  51. package/dist/component/public/security/limits.js.map +1 -1
  52. package/dist/component/schema.d.ts +39 -39
  53. package/dist/component/server/auth.d.ts +95 -52
  54. package/dist/component/server/auth.d.ts.map +1 -1
  55. package/dist/component/server/auth.js +63 -43
  56. package/dist/component/server/auth.js.map +1 -1
  57. package/dist/component/server/core.js +116 -235
  58. package/dist/component/server/core.js.map +1 -1
  59. package/dist/component/server/crypto.js +25 -7
  60. package/dist/component/server/crypto.js.map +1 -1
  61. package/dist/component/server/device.js +58 -15
  62. package/dist/component/server/device.js.map +1 -1
  63. package/dist/component/server/enterprise/domain.js +148 -59
  64. package/dist/component/server/enterprise/domain.js.map +1 -1
  65. package/dist/component/server/enterprise/http.js +36 -15
  66. package/dist/component/server/enterprise/http.js.map +1 -1
  67. package/dist/component/server/enterprise/oidc.js +1 -1
  68. package/dist/component/server/http.js +26 -21
  69. package/dist/component/server/http.js.map +1 -1
  70. package/dist/component/server/identity.js +5 -2
  71. package/dist/component/server/identity.js.map +1 -1
  72. package/dist/component/server/limits.js +21 -30
  73. package/dist/component/server/limits.js.map +1 -1
  74. package/dist/component/server/mutations/account.js +12 -10
  75. package/dist/component/server/mutations/account.js.map +1 -1
  76. package/dist/component/server/mutations/code.js +5 -2
  77. package/dist/component/server/mutations/code.js.map +1 -1
  78. package/dist/component/server/mutations/invalidate.js +1 -1
  79. package/dist/component/server/mutations/invalidate.js.map +1 -1
  80. package/dist/component/server/mutations/oauth.js +10 -4
  81. package/dist/component/server/mutations/oauth.js.map +1 -1
  82. package/dist/component/server/mutations/refresh.js +2 -2
  83. package/dist/component/server/mutations/refresh.js.map +1 -1
  84. package/dist/component/server/mutations/register.js +46 -42
  85. package/dist/component/server/mutations/register.js.map +1 -1
  86. package/dist/component/server/mutations/retrieve.js +21 -25
  87. package/dist/component/server/mutations/retrieve.js.map +1 -1
  88. package/dist/component/server/mutations/signature.js +10 -4
  89. package/dist/component/server/mutations/signature.js.map +1 -1
  90. package/dist/component/server/mutations/signout.js.map +1 -1
  91. package/dist/component/server/mutations/store.js +9 -24
  92. package/dist/component/server/mutations/store.js.map +1 -1
  93. package/dist/component/server/mutations/verifier.js.map +1 -1
  94. package/dist/component/server/mutations/verify.js +1 -1
  95. package/dist/component/server/mutations/verify.js.map +1 -1
  96. package/dist/component/server/oauth.js +53 -16
  97. package/dist/component/server/oauth.js.map +1 -1
  98. package/dist/component/server/passkey.js +115 -31
  99. package/dist/component/server/passkey.js.map +1 -1
  100. package/dist/component/server/redirects.js +9 -3
  101. package/dist/component/server/redirects.js.map +1 -1
  102. package/dist/component/server/refresh.js +10 -7
  103. package/dist/component/server/refresh.js.map +1 -1
  104. package/dist/component/server/runtime.d.ts +3 -3
  105. package/dist/component/server/runtime.d.ts.map +1 -1
  106. package/dist/component/server/runtime.js +62 -20
  107. package/dist/component/server/runtime.js.map +1 -1
  108. package/dist/component/server/signin.js +34 -10
  109. package/dist/component/server/signin.js.map +1 -1
  110. package/dist/component/server/totp.js +79 -19
  111. package/dist/component/server/totp.js.map +1 -1
  112. package/dist/component/server/types.d.ts +12 -20
  113. package/dist/component/server/types.d.ts.map +1 -1
  114. package/dist/component/server/types.js.map +1 -1
  115. package/dist/component/server/users.js +6 -3
  116. package/dist/component/server/users.js.map +1 -1
  117. package/dist/component/server/utils.js +10 -4
  118. package/dist/component/server/utils.js.map +1 -1
  119. package/dist/core/types.d.ts +14 -22
  120. package/dist/core/types.d.ts.map +1 -1
  121. package/dist/factors/device.js +8 -9
  122. package/dist/factors/device.js.map +1 -1
  123. package/dist/factors/passkey.js +18 -21
  124. package/dist/factors/passkey.js.map +1 -1
  125. package/dist/providers/password.js +66 -81
  126. package/dist/providers/password.js.map +1 -1
  127. package/dist/runtime/invite.js +2 -8
  128. package/dist/runtime/invite.js.map +1 -1
  129. package/dist/server/auth.d.ts +95 -52
  130. package/dist/server/auth.d.ts.map +1 -1
  131. package/dist/server/auth.js +63 -43
  132. package/dist/server/auth.js.map +1 -1
  133. package/dist/server/core.d.ts +71 -159
  134. package/dist/server/core.d.ts.map +1 -1
  135. package/dist/server/core.js +116 -235
  136. package/dist/server/core.js.map +1 -1
  137. package/dist/server/crypto.d.ts.map +1 -1
  138. package/dist/server/crypto.js +25 -7
  139. package/dist/server/crypto.js.map +1 -1
  140. package/dist/server/device.js +58 -15
  141. package/dist/server/device.js.map +1 -1
  142. package/dist/server/enterprise/domain.d.ts +0 -8
  143. package/dist/server/enterprise/domain.d.ts.map +1 -1
  144. package/dist/server/enterprise/domain.js +148 -59
  145. package/dist/server/enterprise/domain.js.map +1 -1
  146. package/dist/server/enterprise/http.d.ts.map +1 -1
  147. package/dist/server/enterprise/http.js +35 -14
  148. package/dist/server/enterprise/http.js.map +1 -1
  149. package/dist/server/http.d.ts +2 -2
  150. package/dist/server/http.d.ts.map +1 -1
  151. package/dist/server/http.js +25 -20
  152. package/dist/server/http.js.map +1 -1
  153. package/dist/server/identity.js +5 -2
  154. package/dist/server/identity.js.map +1 -1
  155. package/dist/server/index.d.ts +2 -2
  156. package/dist/server/limits.js +21 -30
  157. package/dist/server/limits.js.map +1 -1
  158. package/dist/server/mounts.d.ts +26 -64
  159. package/dist/server/mounts.d.ts.map +1 -1
  160. package/dist/server/mounts.js +45 -106
  161. package/dist/server/mounts.js.map +1 -1
  162. package/dist/server/mutations/account.d.ts +8 -9
  163. package/dist/server/mutations/account.d.ts.map +1 -1
  164. package/dist/server/mutations/account.js +11 -9
  165. package/dist/server/mutations/account.js.map +1 -1
  166. package/dist/server/mutations/code.d.ts +13 -13
  167. package/dist/server/mutations/code.d.ts.map +1 -1
  168. package/dist/server/mutations/code.js +5 -2
  169. package/dist/server/mutations/code.js.map +1 -1
  170. package/dist/server/mutations/invalidate.d.ts +4 -4
  171. package/dist/server/mutations/invalidate.d.ts.map +1 -1
  172. package/dist/server/mutations/invalidate.js.map +1 -1
  173. package/dist/server/mutations/oauth.d.ts +12 -10
  174. package/dist/server/mutations/oauth.d.ts.map +1 -1
  175. package/dist/server/mutations/oauth.js +9 -3
  176. package/dist/server/mutations/oauth.js.map +1 -1
  177. package/dist/server/mutations/refresh.d.ts +3 -3
  178. package/dist/server/mutations/refresh.d.ts.map +1 -1
  179. package/dist/server/mutations/refresh.js +1 -1
  180. package/dist/server/mutations/refresh.js.map +1 -1
  181. package/dist/server/mutations/register.d.ts +11 -11
  182. package/dist/server/mutations/register.d.ts.map +1 -1
  183. package/dist/server/mutations/register.js +45 -41
  184. package/dist/server/mutations/register.js.map +1 -1
  185. package/dist/server/mutations/retrieve.d.ts +6 -6
  186. package/dist/server/mutations/retrieve.d.ts.map +1 -1
  187. package/dist/server/mutations/retrieve.js +20 -24
  188. package/dist/server/mutations/retrieve.js.map +1 -1
  189. package/dist/server/mutations/signature.d.ts +6 -7
  190. package/dist/server/mutations/signature.d.ts.map +1 -1
  191. package/dist/server/mutations/signature.js +9 -3
  192. package/dist/server/mutations/signature.js.map +1 -1
  193. package/dist/server/mutations/signin.d.ts +5 -5
  194. package/dist/server/mutations/signin.d.ts.map +1 -1
  195. package/dist/server/mutations/signout.js.map +1 -1
  196. package/dist/server/mutations/store.d.ts +97 -97
  197. package/dist/server/mutations/store.d.ts.map +1 -1
  198. package/dist/server/mutations/store.js +8 -23
  199. package/dist/server/mutations/store.js.map +1 -1
  200. package/dist/server/mutations/verifier.js.map +1 -1
  201. package/dist/server/mutations/verify.d.ts +10 -10
  202. package/dist/server/mutations/verify.d.ts.map +1 -1
  203. package/dist/server/mutations/verify.js.map +1 -1
  204. package/dist/server/oauth.js +53 -16
  205. package/dist/server/oauth.js.map +1 -1
  206. package/dist/server/passkey.d.ts +2 -2
  207. package/dist/server/passkey.d.ts.map +1 -1
  208. package/dist/server/passkey.js +114 -30
  209. package/dist/server/passkey.js.map +1 -1
  210. package/dist/server/redirects.js +9 -3
  211. package/dist/server/redirects.js.map +1 -1
  212. package/dist/server/refresh.js +10 -7
  213. package/dist/server/refresh.js.map +1 -1
  214. package/dist/server/runtime.d.ts +14 -14
  215. package/dist/server/runtime.d.ts.map +1 -1
  216. package/dist/server/runtime.js +61 -19
  217. package/dist/server/runtime.js.map +1 -1
  218. package/dist/server/signin.js +34 -10
  219. package/dist/server/signin.js.map +1 -1
  220. package/dist/server/ssr.d.ts.map +1 -1
  221. package/dist/server/ssr.js +175 -184
  222. package/dist/server/ssr.js.map +1 -1
  223. package/dist/server/totp.js +78 -18
  224. package/dist/server/totp.js.map +1 -1
  225. package/dist/server/types.d.ts +13 -21
  226. package/dist/server/types.d.ts.map +1 -1
  227. package/dist/server/types.js.map +1 -1
  228. package/dist/server/users.js +6 -3
  229. package/dist/server/users.js.map +1 -1
  230. package/dist/server/utils.js +10 -4
  231. package/dist/server/utils.js.map +1 -1
  232. package/package.json +2 -6
  233. package/src/authorization/index.ts +1 -1
  234. package/src/cli/index.ts +1 -1
  235. package/src/client/core/types.ts +14 -14
  236. package/src/client/factors/device.ts +10 -12
  237. package/src/client/factors/passkey.ts +23 -26
  238. package/src/client/index.ts +54 -64
  239. package/src/client/runtime/invite.ts +5 -7
  240. package/src/component/index.ts +1 -0
  241. package/src/component/public/enterprise/audit.ts +6 -1
  242. package/src/component/public/enterprise/core.ts +1 -0
  243. package/src/component/public/enterprise/domains.ts +5 -1
  244. package/src/component/public/enterprise/scim.ts +1 -0
  245. package/src/component/public/enterprise/secrets.ts +1 -0
  246. package/src/component/public/enterprise/webhooks.ts +1 -0
  247. package/src/component/public/factors/devices.ts +1 -0
  248. package/src/component/public/factors/passkeys.ts +1 -0
  249. package/src/component/public/factors/totp.ts +1 -0
  250. package/src/component/public/groups/core.ts +1 -1
  251. package/src/component/public/groups/invites.ts +7 -1
  252. package/src/component/public/groups/members.ts +1 -0
  253. package/src/component/public/identity/accounts.ts +1 -0
  254. package/src/component/public/identity/codes.ts +1 -0
  255. package/src/component/public/identity/sessions.ts +1 -0
  256. package/src/component/public/identity/tokens.ts +1 -0
  257. package/src/component/public/identity/users.ts +1 -0
  258. package/src/component/public/identity/verifiers.ts +1 -0
  259. package/src/component/public/security/keys.ts +1 -0
  260. package/src/component/public/security/limits.ts +1 -0
  261. package/src/providers/password.ts +89 -110
  262. package/src/server/auth.ts +177 -111
  263. package/src/server/core.ts +197 -233
  264. package/src/server/crypto.ts +31 -29
  265. package/src/server/device.ts +65 -32
  266. package/src/server/enterprise/domain.ts +158 -170
  267. package/src/server/enterprise/http.ts +46 -39
  268. package/src/server/http.ts +36 -30
  269. package/src/server/identity.ts +5 -5
  270. package/src/server/index.ts +2 -0
  271. package/src/server/limits.ts +53 -80
  272. package/src/server/mounts.ts +47 -74
  273. package/src/server/mutations/account.ts +22 -36
  274. package/src/server/mutations/code.ts +6 -6
  275. package/src/server/mutations/invalidate.ts +1 -1
  276. package/src/server/mutations/oauth.ts +14 -8
  277. package/src/server/mutations/refresh.ts +5 -4
  278. package/src/server/mutations/register.ts +87 -132
  279. package/src/server/mutations/retrieve.ts +44 -44
  280. package/src/server/mutations/signature.ts +13 -6
  281. package/src/server/mutations/signout.ts +1 -1
  282. package/src/server/mutations/store.ts +16 -31
  283. package/src/server/mutations/verifier.ts +1 -1
  284. package/src/server/mutations/verify.ts +3 -5
  285. package/src/server/oauth.ts +60 -69
  286. package/src/server/passkey.ts +567 -517
  287. package/src/server/redirects.ts +10 -6
  288. package/src/server/refresh.ts +14 -18
  289. package/src/server/runtime.ts +70 -55
  290. package/src/server/signin.ts +44 -37
  291. package/src/server/ssr.ts +390 -407
  292. package/src/server/totp.ts +85 -35
  293. package/src/server/types.ts +19 -22
  294. package/src/server/users.ts +7 -6
  295. package/src/server/utils.ts +10 -12
  296. package/dist/component/server/authError.js +0 -34
  297. package/dist/component/server/authError.js.map +0 -1
  298. package/dist/component/server/errors.d.ts +0 -1
  299. package/dist/component/server/errors.js +0 -137
  300. package/dist/component/server/errors.js.map +0 -1
  301. package/dist/server/authError.d.ts +0 -46
  302. package/dist/server/authError.d.ts.map +0 -1
  303. package/dist/server/authError.js +0 -34
  304. package/dist/server/authError.js.map +0 -1
  305. package/dist/server/errors.d.ts +0 -177
  306. package/dist/server/errors.d.ts.map +0 -1
  307. package/dist/server/errors.js +0 -212
  308. package/dist/server/errors.js.map +0 -1
  309. package/src/server/authError.ts +0 -44
  310. package/src/server/errors.ts +0 -290
@@ -1,4 +1,5 @@
1
1
  import { v } from "convex/values";
2
+
2
3
  import { mutation, query } from "../../functions";
3
4
  import { vTotpFactorDoc } from "../../model";
4
5
 
@@ -1,9 +1,9 @@
1
1
  import { v } from "convex/values";
2
+
2
3
  import type { Id } from "../../_generated/dataModel";
3
4
  import { mutation, query } from "../../functions";
4
5
  import { vGroupDoc, vPaginated, vTag } from "../../model";
5
6
 
6
-
7
7
  type TagPair = { key: string; value: string };
8
8
 
9
9
  function normalizeTag(tag: TagPair): TagPair {
@@ -1,7 +1,13 @@
1
1
  import { ConvexError, v } from "convex/values";
2
+
2
3
  import type { Id } from "../../_generated/dataModel";
3
4
  import { mutation, query } from "../../functions";
4
- import { vGroupInviteDoc, vInviteAcceptByTokenResult, vInviteStatus, vPaginated } from "../../model";
5
+ import {
6
+ vGroupInviteDoc,
7
+ vInviteAcceptByTokenResult,
8
+ vInviteStatus,
9
+ vPaginated,
10
+ } from "../../model";
5
11
 
6
12
  /**
7
13
  * Create a new platform-level invitation. Optionally set `groupId` to tie
@@ -1,4 +1,5 @@
1
1
  import { ConvexError, v } from "convex/values";
2
+
2
3
  import type { Id } from "../../_generated/dataModel";
3
4
  import { mutation, query } from "../../functions";
4
5
  import { vGroupMemberDoc, vPaginated } from "../../model";
@@ -1,4 +1,5 @@
1
1
  import { v } from "convex/values";
2
+
2
3
  import { mutation, query } from "../../functions";
3
4
  import { vAccountDoc } from "../../model";
4
5
 
@@ -1,4 +1,5 @@
1
1
  import { v } from "convex/values";
2
+
2
3
  import { mutation, query } from "../../functions";
3
4
  import { vVerificationCodeDoc } from "../../model";
4
5
 
@@ -1,4 +1,5 @@
1
1
  import { v } from "convex/values";
2
+
2
3
  import { mutation, query } from "../../functions";
3
4
  import { vPaginated, vSessionDoc } from "../../model";
4
5
 
@@ -1,4 +1,5 @@
1
1
  import { v } from "convex/values";
2
+
2
3
  import { mutation, query } from "../../functions";
3
4
  import { vRefreshTokenDoc } from "../../model";
4
5
 
@@ -1,4 +1,5 @@
1
1
  import { v } from "convex/values";
2
+
2
3
  import { mutation, query } from "../../functions";
3
4
  import { vPaginated, vUserDoc } from "../../model";
4
5
 
@@ -1,4 +1,5 @@
1
1
  import { v } from "convex/values";
2
+
2
3
  import { mutation, query } from "../../functions";
3
4
  import { vAuthVerifierDoc } from "../../model";
4
5
 
@@ -1,4 +1,5 @@
1
1
  import { ConvexError, v } from "convex/values";
2
+
2
3
  import { mutation, query } from "../../functions";
3
4
  import {
4
5
  vApiKeyDoc,
@@ -1,4 +1,5 @@
1
1
  import { v } from "convex/values";
2
+
2
3
  import { mutation, query } from "../../functions";
3
4
  import { vRateLimitResult } from "../../model";
4
5
 
@@ -220,127 +220,106 @@ export class Password<DataModel extends GenericDataModel = GenericDataModel> {
220
220
  return await Fx.run(
221
221
  Fx.match(flowDispatch, flowDispatch.tag, {
222
222
  signUp: () =>
223
- Fx.from({
224
- ok: async () => {
225
- const secret = requirePasswordParam(
226
- params.password,
227
- "signUp",
228
- );
229
- const created = await ctx.auth.account.create(ctx, {
230
- provider,
231
- account: { id: email, secret },
232
- profile: profile as any,
233
- shouldLinkViaEmail: config.verify !== undefined,
234
- shouldLinkViaPhone: false,
235
- });
236
- return await finalizeCredentialsResult(
237
- created.account,
238
- created.user,
239
- );
240
- },
241
- err: (e) => e as never,
223
+ Fx.promise(async () => {
224
+ const secret = requirePasswordParam(params.password, "signUp");
225
+ const created = await ctx.auth.account.create(ctx, {
226
+ provider,
227
+ account: { id: email, secret },
228
+ profile: profile as any,
229
+ shouldLinkViaEmail: config.verify !== undefined,
230
+ shouldLinkViaPhone: false,
231
+ });
232
+ return await finalizeCredentialsResult(
233
+ created.account,
234
+ created.user,
235
+ );
242
236
  }),
243
237
  signIn: () =>
244
- Fx.from({
245
- ok: async () => {
246
- const secret = requirePasswordParam(
247
- params.password,
248
- "signIn",
249
- );
250
- const retrieved = await ctx.auth.account.get(ctx, {
251
- provider,
252
- account: { id: email, secret },
253
- });
254
- if (retrieved === null) {
255
- throw new Error("Invalid credentials");
256
- }
257
- return await finalizeCredentialsResult(
258
- retrieved.account,
259
- retrieved.user,
260
- );
261
- },
262
- err: (e) => e as never,
238
+ Fx.promise(async () => {
239
+ const secret = requirePasswordParam(params.password, "signIn");
240
+ const retrieved = await ctx.auth.account.get(ctx, {
241
+ provider,
242
+ account: { id: email, secret },
243
+ });
244
+ if (retrieved === null) {
245
+ throw new Error("Invalid credentials");
246
+ }
247
+ return await finalizeCredentialsResult(
248
+ retrieved.account,
249
+ retrieved.user,
250
+ );
263
251
  }),
264
252
  reset: () =>
265
- Fx.from({
266
- ok: async () => {
267
- if (!config.reset) {
268
- throw new Error(
269
- `Password reset is not enabled for ${provider}`,
270
- );
271
- }
272
- const { account } = await ctx.auth.account.get(ctx, {
273
- provider,
274
- account: { id: email },
275
- });
276
- return await ctx.auth.provider.signIn(
277
- ctx,
278
- config.reset as AuthProviderConfig,
279
- {
280
- accountId: account._id,
281
- params,
282
- },
253
+ Fx.promise(async () => {
254
+ if (!config.reset) {
255
+ throw new Error(
256
+ `Password reset is not enabled for ${provider}`,
283
257
  );
284
- },
285
- err: (e) => e as never,
258
+ }
259
+ const { account } = await ctx.auth.account.get(ctx, {
260
+ provider,
261
+ account: { id: email },
262
+ });
263
+ return await ctx.auth.provider.signIn(
264
+ ctx,
265
+ config.reset as AuthProviderConfig,
266
+ {
267
+ accountId: account._id,
268
+ params,
269
+ },
270
+ );
286
271
  }),
287
272
  resetVerification: () =>
288
- Fx.from({
289
- ok: async () => {
290
- if (!config.reset) {
291
- throw new Error(
292
- `Password reset is not enabled for ${provider}`,
293
- );
294
- }
295
- if (params.newPassword === undefined) {
296
- throw new Error(
297
- "Missing `newPassword` param for `reset-verification` flow",
298
- );
299
- }
300
- const result = await ctx.auth.provider.signIn(
301
- ctx,
302
- config.reset as AuthProviderConfig,
303
- { params },
273
+ Fx.promise(async () => {
274
+ if (!config.reset) {
275
+ throw new Error(
276
+ `Password reset is not enabled for ${provider}`,
277
+ );
278
+ }
279
+ if (params.newPassword === undefined) {
280
+ throw new Error(
281
+ "Missing `newPassword` param for `reset-verification` flow",
304
282
  );
305
- if (result === null) {
306
- throw new Error("Invalid code");
307
- }
308
- const { userId, sessionId } = result;
309
- const secret = params.newPassword as string;
310
- await ctx.auth.account.update(ctx, {
311
- provider,
312
- account: { id: email, secret },
313
- });
314
- await ctx.auth.session.invalidate(ctx, {
315
- userId,
316
- except: [sessionId],
317
- });
318
- return { userId, sessionId };
319
- },
320
- err: (e) => e as never,
283
+ }
284
+ const result = await ctx.auth.provider.signIn(
285
+ ctx,
286
+ config.reset as AuthProviderConfig,
287
+ { params },
288
+ );
289
+ if (result === null) {
290
+ throw new Error("Invalid code");
291
+ }
292
+ const { userId, sessionId } = result;
293
+ const secret = params.newPassword as string;
294
+ await ctx.auth.account.update(ctx, {
295
+ provider,
296
+ account: { id: email, secret },
297
+ });
298
+ await ctx.auth.session.invalidate(ctx, {
299
+ userId,
300
+ except: [sessionId],
301
+ });
302
+ return { userId, sessionId };
321
303
  }),
322
304
  emailVerification: () =>
323
- Fx.from({
324
- ok: async () => {
325
- if (!config.verify) {
326
- throw new Error(
327
- `Email verification is not enabled for ${provider}`,
328
- );
329
- }
330
- const { account } = await ctx.auth.account.get(ctx, {
331
- provider,
332
- account: { id: email },
333
- });
334
- return await ctx.auth.provider.signIn(
335
- ctx,
336
- config.verify as AuthProviderConfig,
337
- {
338
- accountId: account._id,
339
- params,
340
- },
305
+ Fx.promise(async () => {
306
+ if (!config.verify) {
307
+ throw new Error(
308
+ `Email verification is not enabled for ${provider}`,
341
309
  );
342
- },
343
- err: (e) => e as never,
310
+ }
311
+ const { account } = await ctx.auth.account.get(ctx, {
312
+ provider,
313
+ account: { id: email },
314
+ });
315
+ return await ctx.auth.provider.signIn(
316
+ ctx,
317
+ config.verify as AuthProviderConfig,
318
+ {
319
+ accountId: account._id,
320
+ params,
321
+ },
322
+ );
344
323
  }),
345
324
  invalid: () =>
346
325
  Fx.fatal(