@robelest/convex-auth 0.0.4-preview.25 → 0.0.4-preview.28

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 (666) hide show
  1. package/README.md +43 -36
  2. package/dist/bin.js +5765 -4880
  3. package/dist/browser/index.d.ts +30 -0
  4. package/dist/browser/index.js +93 -0
  5. package/dist/browser/locks.js +11 -0
  6. package/dist/browser/navigation.js +14 -0
  7. package/dist/{factors → browser}/passkey.js +23 -32
  8. package/dist/browser/runtime.js +92 -0
  9. package/dist/client/core/types.d.ts +452 -5
  10. package/dist/client/core/types.js +17 -0
  11. package/dist/client/errors.js +19 -0
  12. package/dist/client/factors/device.js +94 -0
  13. package/dist/{factors → client/factors}/totp.js +12 -4
  14. package/dist/client/index.d.ts +47 -1
  15. package/dist/client/index.js +269 -232
  16. package/dist/client/runtime/mutex.js +24 -0
  17. package/dist/client/runtime/proxy.js +30 -0
  18. package/dist/client/runtime/storage.js +45 -0
  19. package/dist/client/services/adapters.js +7 -0
  20. package/dist/client/services/http.js +6 -0
  21. package/dist/client/services/resolve.js +13 -0
  22. package/dist/client/services/runtime.js +6 -0
  23. package/dist/component/_generated/component.d.ts +1355 -1399
  24. package/dist/component/convex.config.d.ts +2 -2
  25. package/dist/component/index.d.ts +4 -26
  26. package/dist/component/index.js +1 -1
  27. package/dist/component/model.d.ts +26 -112
  28. package/dist/component/model.js +76 -54
  29. package/dist/component/modules.js +38 -0
  30. package/dist/component/public/factors/devices.js +1 -1
  31. package/dist/component/public/factors/passkeys.js +1 -1
  32. package/dist/component/public/factors/totp.js +1 -1
  33. package/dist/component/public/groups/core.js +2 -2
  34. package/dist/component/public/groups/invites.js +1 -1
  35. package/dist/component/public/groups/members.js +1 -1
  36. package/dist/component/public/identity/accounts.js +1 -1
  37. package/dist/component/public/identity/codes.js +1 -1
  38. package/dist/component/public/identity/sessions.js +39 -2
  39. package/dist/component/public/identity/tokens.js +82 -4
  40. package/dist/component/public/identity/users.js +1 -1
  41. package/dist/component/public/identity/verifiers.js +10 -4
  42. package/dist/component/public/security/keys.js +1 -1
  43. package/dist/component/public/security/limits.js +1 -1
  44. package/dist/component/public/{enterprise → sso}/audit.js +26 -26
  45. package/dist/component/public/sso/core.js +263 -0
  46. package/dist/component/public/sso/domains.js +280 -0
  47. package/dist/component/public/{enterprise → sso}/scim.js +87 -87
  48. package/dist/component/public/sso/secrets.js +125 -0
  49. package/dist/component/public/{enterprise → sso}/webhooks.js +59 -59
  50. package/dist/component/public.js +9 -9
  51. package/dist/component/schema.d.ts +472 -393
  52. package/dist/component/schema.js +36 -35
  53. package/dist/core/index.d.ts +380 -0
  54. package/dist/core/index.js +83 -0
  55. package/dist/otel.d.ts +69 -0
  56. package/dist/otel.js +82 -0
  57. package/dist/providers/anonymous.d.ts +15 -34
  58. package/dist/providers/anonymous.js +27 -35
  59. package/dist/providers/apple.d.ts +59 -0
  60. package/dist/providers/apple.js +58 -0
  61. package/dist/providers/credentials.d.ts +18 -34
  62. package/dist/providers/credentials.js +16 -27
  63. package/dist/providers/custom.d.ts +94 -0
  64. package/dist/providers/custom.js +119 -0
  65. package/dist/providers/device.d.ts +15 -49
  66. package/dist/providers/device.js +17 -34
  67. package/dist/providers/email.d.ts +21 -38
  68. package/dist/providers/email.js +36 -55
  69. package/dist/providers/github.d.ts +54 -0
  70. package/dist/providers/github.js +75 -0
  71. package/dist/providers/google.d.ts +54 -0
  72. package/dist/providers/google.js +61 -0
  73. package/dist/providers/index.d.ts +16 -12
  74. package/dist/providers/index.js +15 -11
  75. package/dist/providers/microsoft.d.ts +57 -0
  76. package/dist/providers/microsoft.js +101 -0
  77. package/dist/providers/passkey.d.ts +19 -35
  78. package/dist/providers/passkey.js +20 -30
  79. package/dist/providers/password.d.ts +17 -18
  80. package/dist/providers/password.js +121 -143
  81. package/dist/providers/phone.d.ts +13 -28
  82. package/dist/providers/phone.js +21 -46
  83. package/dist/providers/sso.d.ts +16 -36
  84. package/dist/providers/sso.js +21 -22
  85. package/dist/providers/totp.d.ts +13 -29
  86. package/dist/providers/totp.js +17 -27
  87. package/dist/server/auth-context.d.ts +204 -0
  88. package/dist/server/auth-context.js +76 -0
  89. package/dist/server/auth.d.ts +99 -244
  90. package/dist/server/auth.js +56 -152
  91. package/dist/server/componentContext.d.ts +12 -0
  92. package/dist/server/componentContext.js +1 -0
  93. package/dist/server/config.js +6 -67
  94. package/dist/server/constants.js +6 -0
  95. package/dist/server/contract.d.ts +105 -0
  96. package/dist/server/contract.js +43 -0
  97. package/dist/server/cookies.js +3 -2
  98. package/dist/server/core.js +31 -36
  99. package/dist/server/crypto.js +34 -44
  100. package/dist/server/db.js +6 -1
  101. package/dist/server/device.js +96 -130
  102. package/dist/server/env.js +48 -0
  103. package/dist/server/errors.js +20 -0
  104. package/dist/server/http.d.ts +15 -59
  105. package/dist/server/http.js +136 -120
  106. package/dist/server/identity.js +2 -2
  107. package/dist/server/index.d.ts +5 -4
  108. package/dist/server/index.js +3 -3
  109. package/dist/server/keys.js +10 -1
  110. package/dist/server/limits.js +26 -26
  111. package/dist/server/log.js +28 -0
  112. package/dist/server/mounts.d.ts +1107 -296
  113. package/dist/server/mounts.js +315 -196
  114. package/dist/server/mutations/account.js +11 -14
  115. package/dist/server/mutations/code.js +6 -5
  116. package/dist/server/mutations/invalidate.js +9 -11
  117. package/dist/server/mutations/oauth.js +112 -73
  118. package/dist/server/mutations/refresh.js +47 -97
  119. package/dist/server/mutations/register.js +37 -35
  120. package/dist/server/mutations/retrieve.js +16 -16
  121. package/dist/server/mutations/signature.js +15 -18
  122. package/dist/server/mutations/signin.js +10 -5
  123. package/dist/server/mutations/signout.js +11 -14
  124. package/dist/server/mutations/store.js +25 -18
  125. package/dist/server/mutations/verifier.js +11 -8
  126. package/dist/server/mutations/verify.js +53 -41
  127. package/dist/server/oauth/factory.js +44 -0
  128. package/dist/server/oauth/index.js +12 -0
  129. package/dist/server/oauth/runtime.js +248 -0
  130. package/dist/server/passkey.js +331 -365
  131. package/dist/server/payloads.d.ts +16 -0
  132. package/dist/server/payloads.js +30 -0
  133. package/dist/server/{ssr.d.ts → prefetch.d.ts} +2 -2
  134. package/dist/server/prefetch.js +635 -0
  135. package/dist/server/random.js +19 -0
  136. package/dist/server/redirects.js +10 -5
  137. package/dist/server/refresh.js +14 -86
  138. package/dist/server/runtime.d.ts +531 -31
  139. package/dist/server/runtime.js +106 -267
  140. package/dist/server/secret.js +44 -0
  141. package/dist/server/services/config.js +10 -0
  142. package/dist/server/services/group.js +211 -0
  143. package/dist/server/services/logger.js +8 -0
  144. package/dist/server/services/providers.js +22 -0
  145. package/dist/server/services/refresh.js +8 -0
  146. package/dist/server/services/resolve.js +27 -0
  147. package/dist/server/services/signin.js +8 -0
  148. package/dist/server/sessions.js +35 -34
  149. package/dist/server/signin.js +229 -140
  150. package/dist/server/{enterprise → sso}/config.js +10 -3
  151. package/dist/server/sso/domain.d.ts +614 -0
  152. package/dist/server/sso/domain.js +1175 -0
  153. package/dist/server/sso/http.js +1060 -0
  154. package/dist/server/sso/oidc.js +324 -0
  155. package/dist/server/sso/policies.js +59 -0
  156. package/dist/server/sso/policy.js +139 -0
  157. package/dist/server/sso/profile.js +22 -0
  158. package/dist/server/sso/provision.js +179 -0
  159. package/dist/{component/server/enterprise → server/sso}/saml.js +142 -56
  160. package/dist/{component/server/enterprise → server/sso}/scim.js +13 -7
  161. package/dist/server/sso/shared.js +74 -0
  162. package/dist/server/sso/validators.js +88 -0
  163. package/dist/server/sso/webhook.js +94 -0
  164. package/dist/server/tokens.js +16 -4
  165. package/dist/server/totp.js +155 -164
  166. package/dist/server/types.d.ts +306 -296
  167. package/dist/server/types.js +1 -30
  168. package/dist/server/url.js +32 -0
  169. package/dist/server/users.js +74 -40
  170. package/dist/server/utils/cache.js +51 -0
  171. package/dist/server/utils/dispatch.js +36 -0
  172. package/dist/server/utils/retry.js +24 -0
  173. package/dist/server/utils/span.js +32 -0
  174. package/dist/shared/errors.js +19 -0
  175. package/dist/shared/log.js +45 -0
  176. package/{src/test.ts → dist/test.d.ts} +21 -22
  177. package/dist/test.js +51 -0
  178. package/package.json +70 -42
  179. package/dist/authorization/index.d.ts.map +0 -1
  180. package/dist/authorization/index.js.map +0 -1
  181. package/dist/client/core/types.d.ts.map +0 -1
  182. package/dist/client/index.d.ts.map +0 -1
  183. package/dist/client/index.js.map +0 -1
  184. package/dist/component/_generated/api.d.ts +0 -75
  185. package/dist/component/_generated/api.d.ts.map +0 -1
  186. package/dist/component/_generated/api.js.map +0 -1
  187. package/dist/component/_generated/component.d.ts.map +0 -1
  188. package/dist/component/_generated/dataModel.d.ts +0 -42
  189. package/dist/component/_generated/dataModel.d.ts.map +0 -1
  190. package/dist/component/_generated/server.d.ts +0 -117
  191. package/dist/component/_generated/server.d.ts.map +0 -1
  192. package/dist/component/_generated/server.js.map +0 -1
  193. package/dist/component/_virtual/rolldown_runtime.js +0 -18
  194. package/dist/component/client/core/types.d.ts +0 -2
  195. package/dist/component/client/index.d.ts +0 -1
  196. package/dist/component/convex.config.d.ts.map +0 -1
  197. package/dist/component/convex.config.js.map +0 -1
  198. package/dist/component/functions.d.ts +0 -25
  199. package/dist/component/functions.d.ts.map +0 -1
  200. package/dist/component/functions.js.map +0 -1
  201. package/dist/component/index.d.ts.map +0 -1
  202. package/dist/component/model.d.ts.map +0 -1
  203. package/dist/component/model.js.map +0 -1
  204. package/dist/component/providers/anonymous.d.ts +0 -54
  205. package/dist/component/providers/anonymous.d.ts.map +0 -1
  206. package/dist/component/providers/credentials.d.ts +0 -38
  207. package/dist/component/providers/credentials.d.ts.map +0 -1
  208. package/dist/component/providers/device.d.ts +0 -67
  209. package/dist/component/providers/device.d.ts.map +0 -1
  210. package/dist/component/providers/email.d.ts +0 -62
  211. package/dist/component/providers/email.d.ts.map +0 -1
  212. package/dist/component/providers/oauth.d.ts +0 -25
  213. package/dist/component/providers/oauth.d.ts.map +0 -1
  214. package/dist/component/providers/oauth.js +0 -13
  215. package/dist/component/providers/oauth.js.map +0 -1
  216. package/dist/component/providers/passkey.d.ts +0 -57
  217. package/dist/component/providers/passkey.d.ts.map +0 -1
  218. package/dist/component/providers/password.d.ts +0 -88
  219. package/dist/component/providers/password.d.ts.map +0 -1
  220. package/dist/component/providers/phone.d.ts +0 -48
  221. package/dist/component/providers/phone.d.ts.map +0 -1
  222. package/dist/component/providers/sso.d.ts +0 -50
  223. package/dist/component/providers/sso.d.ts.map +0 -1
  224. package/dist/component/providers/totp.d.ts +0 -45
  225. package/dist/component/providers/totp.d.ts.map +0 -1
  226. package/dist/component/public/enterprise/audit.d.ts +0 -73
  227. package/dist/component/public/enterprise/audit.d.ts.map +0 -1
  228. package/dist/component/public/enterprise/audit.js.map +0 -1
  229. package/dist/component/public/enterprise/core.d.ts +0 -176
  230. package/dist/component/public/enterprise/core.d.ts.map +0 -1
  231. package/dist/component/public/enterprise/core.js +0 -292
  232. package/dist/component/public/enterprise/core.js.map +0 -1
  233. package/dist/component/public/enterprise/domains.d.ts +0 -174
  234. package/dist/component/public/enterprise/domains.d.ts.map +0 -1
  235. package/dist/component/public/enterprise/domains.js +0 -271
  236. package/dist/component/public/enterprise/domains.js.map +0 -1
  237. package/dist/component/public/enterprise/scim.d.ts +0 -245
  238. package/dist/component/public/enterprise/scim.d.ts.map +0 -1
  239. package/dist/component/public/enterprise/scim.js.map +0 -1
  240. package/dist/component/public/enterprise/secrets.d.ts +0 -78
  241. package/dist/component/public/enterprise/secrets.d.ts.map +0 -1
  242. package/dist/component/public/enterprise/secrets.js +0 -118
  243. package/dist/component/public/enterprise/secrets.js.map +0 -1
  244. package/dist/component/public/enterprise/webhooks.d.ts +0 -211
  245. package/dist/component/public/enterprise/webhooks.d.ts.map +0 -1
  246. package/dist/component/public/enterprise/webhooks.js.map +0 -1
  247. package/dist/component/public/factors/devices.d.ts +0 -157
  248. package/dist/component/public/factors/devices.d.ts.map +0 -1
  249. package/dist/component/public/factors/devices.js.map +0 -1
  250. package/dist/component/public/factors/passkeys.d.ts +0 -175
  251. package/dist/component/public/factors/passkeys.d.ts.map +0 -1
  252. package/dist/component/public/factors/passkeys.js.map +0 -1
  253. package/dist/component/public/factors/totp.d.ts +0 -189
  254. package/dist/component/public/factors/totp.d.ts.map +0 -1
  255. package/dist/component/public/factors/totp.js.map +0 -1
  256. package/dist/component/public/groups/core.d.ts +0 -137
  257. package/dist/component/public/groups/core.d.ts.map +0 -1
  258. package/dist/component/public/groups/core.js.map +0 -1
  259. package/dist/component/public/groups/invites.d.ts +0 -217
  260. package/dist/component/public/groups/invites.d.ts.map +0 -1
  261. package/dist/component/public/groups/invites.js.map +0 -1
  262. package/dist/component/public/groups/members.d.ts +0 -204
  263. package/dist/component/public/groups/members.d.ts.map +0 -1
  264. package/dist/component/public/groups/members.js.map +0 -1
  265. package/dist/component/public/identity/accounts.d.ts +0 -147
  266. package/dist/component/public/identity/accounts.d.ts.map +0 -1
  267. package/dist/component/public/identity/accounts.js.map +0 -1
  268. package/dist/component/public/identity/codes.d.ts +0 -104
  269. package/dist/component/public/identity/codes.d.ts.map +0 -1
  270. package/dist/component/public/identity/codes.js.map +0 -1
  271. package/dist/component/public/identity/sessions.d.ts +0 -128
  272. package/dist/component/public/identity/sessions.d.ts.map +0 -1
  273. package/dist/component/public/identity/sessions.js.map +0 -1
  274. package/dist/component/public/identity/tokens.d.ts +0 -169
  275. package/dist/component/public/identity/tokens.d.ts.map +0 -1
  276. package/dist/component/public/identity/tokens.js.map +0 -1
  277. package/dist/component/public/identity/users.d.ts +0 -212
  278. package/dist/component/public/identity/users.d.ts.map +0 -1
  279. package/dist/component/public/identity/users.js.map +0 -1
  280. package/dist/component/public/identity/verifiers.d.ts +0 -116
  281. package/dist/component/public/identity/verifiers.d.ts.map +0 -1
  282. package/dist/component/public/identity/verifiers.js.map +0 -1
  283. package/dist/component/public/security/keys.d.ts +0 -209
  284. package/dist/component/public/security/keys.d.ts.map +0 -1
  285. package/dist/component/public/security/keys.js.map +0 -1
  286. package/dist/component/public/security/limits.d.ts +0 -114
  287. package/dist/component/public/security/limits.d.ts.map +0 -1
  288. package/dist/component/public/security/limits.js.map +0 -1
  289. package/dist/component/public.d.ts +0 -28
  290. package/dist/component/public.d.ts.map +0 -1
  291. package/dist/component/schema.d.ts.map +0 -1
  292. package/dist/component/schema.js.map +0 -1
  293. package/dist/component/server/auth.d.ts +0 -447
  294. package/dist/component/server/auth.d.ts.map +0 -1
  295. package/dist/component/server/auth.js +0 -254
  296. package/dist/component/server/auth.js.map +0 -1
  297. package/dist/component/server/config.js +0 -121
  298. package/dist/component/server/config.js.map +0 -1
  299. package/dist/component/server/context.js +0 -53
  300. package/dist/component/server/context.js.map +0 -1
  301. package/dist/component/server/cookies.js +0 -47
  302. package/dist/component/server/cookies.js.map +0 -1
  303. package/dist/component/server/core.js +0 -576
  304. package/dist/component/server/core.js.map +0 -1
  305. package/dist/component/server/crypto.js +0 -56
  306. package/dist/component/server/crypto.js.map +0 -1
  307. package/dist/component/server/db.js +0 -87
  308. package/dist/component/server/db.js.map +0 -1
  309. package/dist/component/server/device.js +0 -152
  310. package/dist/component/server/device.js.map +0 -1
  311. package/dist/component/server/enterprise/config.js +0 -46
  312. package/dist/component/server/enterprise/config.js.map +0 -1
  313. package/dist/component/server/enterprise/domain.js +0 -974
  314. package/dist/component/server/enterprise/domain.js.map +0 -1
  315. package/dist/component/server/enterprise/http.js +0 -787
  316. package/dist/component/server/enterprise/http.js.map +0 -1
  317. package/dist/component/server/enterprise/oidc.js +0 -248
  318. package/dist/component/server/enterprise/oidc.js.map +0 -1
  319. package/dist/component/server/enterprise/policy.js +0 -85
  320. package/dist/component/server/enterprise/policy.js.map +0 -1
  321. package/dist/component/server/enterprise/saml.js.map +0 -1
  322. package/dist/component/server/enterprise/scim.js.map +0 -1
  323. package/dist/component/server/enterprise/shared.js +0 -51
  324. package/dist/component/server/enterprise/shared.js.map +0 -1
  325. package/dist/component/server/http.d.ts +0 -85
  326. package/dist/component/server/http.d.ts.map +0 -1
  327. package/dist/component/server/http.js +0 -351
  328. package/dist/component/server/http.js.map +0 -1
  329. package/dist/component/server/identity.js +0 -16
  330. package/dist/component/server/identity.js.map +0 -1
  331. package/dist/component/server/keys.js +0 -96
  332. package/dist/component/server/keys.js.map +0 -1
  333. package/dist/component/server/limits.js +0 -52
  334. package/dist/component/server/limits.js.map +0 -1
  335. package/dist/component/server/mutations/account.js +0 -46
  336. package/dist/component/server/mutations/account.js.map +0 -1
  337. package/dist/component/server/mutations/code.js +0 -68
  338. package/dist/component/server/mutations/code.js.map +0 -1
  339. package/dist/component/server/mutations/invalidate.js +0 -32
  340. package/dist/component/server/mutations/invalidate.js.map +0 -1
  341. package/dist/component/server/mutations/oauth.js +0 -116
  342. package/dist/component/server/mutations/oauth.js.map +0 -1
  343. package/dist/component/server/mutations/refresh.js +0 -119
  344. package/dist/component/server/mutations/refresh.js.map +0 -1
  345. package/dist/component/server/mutations/register.js +0 -87
  346. package/dist/component/server/mutations/register.js.map +0 -1
  347. package/dist/component/server/mutations/retrieve.js +0 -61
  348. package/dist/component/server/mutations/retrieve.js.map +0 -1
  349. package/dist/component/server/mutations/signature.js +0 -38
  350. package/dist/component/server/mutations/signature.js.map +0 -1
  351. package/dist/component/server/mutations/signin.js +0 -27
  352. package/dist/component/server/mutations/signin.js.map +0 -1
  353. package/dist/component/server/mutations/signout.js +0 -27
  354. package/dist/component/server/mutations/signout.js.map +0 -1
  355. package/dist/component/server/mutations/store/refs.js +0 -15
  356. package/dist/component/server/mutations/store/refs.js.map +0 -1
  357. package/dist/component/server/mutations/store.js +0 -70
  358. package/dist/component/server/mutations/store.js.map +0 -1
  359. package/dist/component/server/mutations/verifier.js +0 -18
  360. package/dist/component/server/mutations/verifier.js.map +0 -1
  361. package/dist/component/server/mutations/verify.js +0 -98
  362. package/dist/component/server/mutations/verify.js.map +0 -1
  363. package/dist/component/server/oauth.js +0 -242
  364. package/dist/component/server/oauth.js.map +0 -1
  365. package/dist/component/server/passkey.js +0 -415
  366. package/dist/component/server/passkey.js.map +0 -1
  367. package/dist/component/server/redirects.js +0 -40
  368. package/dist/component/server/redirects.js.map +0 -1
  369. package/dist/component/server/refresh.js +0 -99
  370. package/dist/component/server/refresh.js.map +0 -1
  371. package/dist/component/server/runtime.d.ts +0 -136
  372. package/dist/component/server/runtime.d.ts.map +0 -1
  373. package/dist/component/server/runtime.js +0 -456
  374. package/dist/component/server/runtime.js.map +0 -1
  375. package/dist/component/server/sessions.js +0 -71
  376. package/dist/component/server/sessions.js.map +0 -1
  377. package/dist/component/server/signin.js +0 -225
  378. package/dist/component/server/signin.js.map +0 -1
  379. package/dist/component/server/tokens.js +0 -17
  380. package/dist/component/server/tokens.js.map +0 -1
  381. package/dist/component/server/totp.js +0 -208
  382. package/dist/component/server/totp.js.map +0 -1
  383. package/dist/component/server/types.d.ts +0 -949
  384. package/dist/component/server/types.d.ts.map +0 -1
  385. package/dist/component/server/types.js +0 -79
  386. package/dist/component/server/types.js.map +0 -1
  387. package/dist/component/server/users.js +0 -123
  388. package/dist/component/server/users.js.map +0 -1
  389. package/dist/component/server/utils.js +0 -140
  390. package/dist/component/server/utils.js.map +0 -1
  391. package/dist/core/types.d.ts +0 -361
  392. package/dist/core/types.d.ts.map +0 -1
  393. package/dist/factors/device.js +0 -104
  394. package/dist/factors/device.js.map +0 -1
  395. package/dist/factors/passkey.js.map +0 -1
  396. package/dist/factors/totp.js.map +0 -1
  397. package/dist/providers/anonymous.d.ts.map +0 -1
  398. package/dist/providers/anonymous.js.map +0 -1
  399. package/dist/providers/credentials.d.ts.map +0 -1
  400. package/dist/providers/credentials.js.map +0 -1
  401. package/dist/providers/device.d.ts.map +0 -1
  402. package/dist/providers/device.js.map +0 -1
  403. package/dist/providers/email.d.ts.map +0 -1
  404. package/dist/providers/email.js.map +0 -1
  405. package/dist/providers/oauth.d.ts +0 -69
  406. package/dist/providers/oauth.d.ts.map +0 -1
  407. package/dist/providers/oauth.js +0 -43
  408. package/dist/providers/oauth.js.map +0 -1
  409. package/dist/providers/passkey.d.ts.map +0 -1
  410. package/dist/providers/passkey.js.map +0 -1
  411. package/dist/providers/password.d.ts.map +0 -1
  412. package/dist/providers/password.js.map +0 -1
  413. package/dist/providers/phone.d.ts.map +0 -1
  414. package/dist/providers/phone.js.map +0 -1
  415. package/dist/providers/sso.d.ts.map +0 -1
  416. package/dist/providers/sso.js.map +0 -1
  417. package/dist/providers/totp.d.ts.map +0 -1
  418. package/dist/providers/totp.js.map +0 -1
  419. package/dist/runtime/browser.js +0 -68
  420. package/dist/runtime/browser.js.map +0 -1
  421. package/dist/runtime/invite.js.map +0 -1
  422. package/dist/runtime/proxy.js +0 -70
  423. package/dist/runtime/proxy.js.map +0 -1
  424. package/dist/runtime/storage.js +0 -37
  425. package/dist/runtime/storage.js.map +0 -1
  426. package/dist/server/auth.d.ts.map +0 -1
  427. package/dist/server/auth.js.map +0 -1
  428. package/dist/server/config.d.ts +0 -1
  429. package/dist/server/config.js.map +0 -1
  430. package/dist/server/context.d.ts +0 -1
  431. package/dist/server/context.js.map +0 -1
  432. package/dist/server/cookies.d.ts +0 -1
  433. package/dist/server/cookies.js.map +0 -1
  434. package/dist/server/core.d.ts +0 -1315
  435. package/dist/server/core.d.ts.map +0 -1
  436. package/dist/server/core.js.map +0 -1
  437. package/dist/server/crypto.d.ts +0 -8
  438. package/dist/server/crypto.d.ts.map +0 -1
  439. package/dist/server/crypto.js.map +0 -1
  440. package/dist/server/db.d.ts +0 -1
  441. package/dist/server/db.js.map +0 -1
  442. package/dist/server/device.d.ts +0 -1
  443. package/dist/server/device.js.map +0 -1
  444. package/dist/server/enterprise/config.d.ts +0 -1
  445. package/dist/server/enterprise/config.js.map +0 -1
  446. package/dist/server/enterprise/domain.d.ts +0 -401
  447. package/dist/server/enterprise/domain.d.ts.map +0 -1
  448. package/dist/server/enterprise/domain.js +0 -974
  449. package/dist/server/enterprise/domain.js.map +0 -1
  450. package/dist/server/enterprise/http.d.ts +0 -26
  451. package/dist/server/enterprise/http.d.ts.map +0 -1
  452. package/dist/server/enterprise/http.js +0 -787
  453. package/dist/server/enterprise/http.js.map +0 -1
  454. package/dist/server/enterprise/oidc.d.ts +0 -1
  455. package/dist/server/enterprise/oidc.js +0 -248
  456. package/dist/server/enterprise/oidc.js.map +0 -1
  457. package/dist/server/enterprise/policy.d.ts +0 -1
  458. package/dist/server/enterprise/policy.js +0 -85
  459. package/dist/server/enterprise/policy.js.map +0 -1
  460. package/dist/server/enterprise/saml.d.ts +0 -1
  461. package/dist/server/enterprise/saml.js +0 -338
  462. package/dist/server/enterprise/saml.js.map +0 -1
  463. package/dist/server/enterprise/scim.d.ts +0 -1
  464. package/dist/server/enterprise/scim.js +0 -97
  465. package/dist/server/enterprise/scim.js.map +0 -1
  466. package/dist/server/enterprise/shared.d.ts +0 -5
  467. package/dist/server/enterprise/shared.d.ts.map +0 -1
  468. package/dist/server/enterprise/shared.js +0 -51
  469. package/dist/server/enterprise/shared.js.map +0 -1
  470. package/dist/server/enterprise/validators.d.ts +0 -1
  471. package/dist/server/enterprise/validators.js +0 -60
  472. package/dist/server/enterprise/validators.js.map +0 -1
  473. package/dist/server/http.d.ts.map +0 -1
  474. package/dist/server/http.js.map +0 -1
  475. package/dist/server/identity.d.ts +0 -1
  476. package/dist/server/identity.js.map +0 -1
  477. package/dist/server/keys.d.ts +0 -1
  478. package/dist/server/keys.js.map +0 -1
  479. package/dist/server/limits.d.ts +0 -1
  480. package/dist/server/limits.js.map +0 -1
  481. package/dist/server/mounts.d.ts.map +0 -1
  482. package/dist/server/mounts.js.map +0 -1
  483. package/dist/server/mutations/account.d.ts +0 -29
  484. package/dist/server/mutations/account.d.ts.map +0 -1
  485. package/dist/server/mutations/account.js.map +0 -1
  486. package/dist/server/mutations/code.d.ts +0 -30
  487. package/dist/server/mutations/code.d.ts.map +0 -1
  488. package/dist/server/mutations/code.js.map +0 -1
  489. package/dist/server/mutations/index.d.ts +0 -14
  490. package/dist/server/mutations/invalidate.d.ts +0 -20
  491. package/dist/server/mutations/invalidate.d.ts.map +0 -1
  492. package/dist/server/mutations/invalidate.js.map +0 -1
  493. package/dist/server/mutations/oauth.d.ts +0 -30
  494. package/dist/server/mutations/oauth.d.ts.map +0 -1
  495. package/dist/server/mutations/oauth.js.map +0 -1
  496. package/dist/server/mutations/refresh.d.ts +0 -21
  497. package/dist/server/mutations/refresh.d.ts.map +0 -1
  498. package/dist/server/mutations/refresh.js.map +0 -1
  499. package/dist/server/mutations/register.d.ts +0 -38
  500. package/dist/server/mutations/register.d.ts.map +0 -1
  501. package/dist/server/mutations/register.js.map +0 -1
  502. package/dist/server/mutations/retrieve.d.ts +0 -33
  503. package/dist/server/mutations/retrieve.d.ts.map +0 -1
  504. package/dist/server/mutations/retrieve.js.map +0 -1
  505. package/dist/server/mutations/signature.d.ts +0 -21
  506. package/dist/server/mutations/signature.d.ts.map +0 -1
  507. package/dist/server/mutations/signature.js.map +0 -1
  508. package/dist/server/mutations/signin.d.ts +0 -22
  509. package/dist/server/mutations/signin.d.ts.map +0 -1
  510. package/dist/server/mutations/signin.js.map +0 -1
  511. package/dist/server/mutations/signout.d.ts +0 -16
  512. package/dist/server/mutations/signout.d.ts.map +0 -1
  513. package/dist/server/mutations/signout.js.map +0 -1
  514. package/dist/server/mutations/store/refs.d.ts +0 -12
  515. package/dist/server/mutations/store/refs.d.ts.map +0 -1
  516. package/dist/server/mutations/store/refs.js.map +0 -1
  517. package/dist/server/mutations/store.d.ts +0 -306
  518. package/dist/server/mutations/store.d.ts.map +0 -1
  519. package/dist/server/mutations/store.js.map +0 -1
  520. package/dist/server/mutations/verifier.d.ts +0 -13
  521. package/dist/server/mutations/verifier.d.ts.map +0 -1
  522. package/dist/server/mutations/verifier.js.map +0 -1
  523. package/dist/server/mutations/verify.d.ts +0 -26
  524. package/dist/server/mutations/verify.d.ts.map +0 -1
  525. package/dist/server/mutations/verify.js.map +0 -1
  526. package/dist/server/oauth.d.ts +0 -1
  527. package/dist/server/oauth.js +0 -242
  528. package/dist/server/oauth.js.map +0 -1
  529. package/dist/server/passkey.d.ts +0 -27
  530. package/dist/server/passkey.d.ts.map +0 -1
  531. package/dist/server/passkey.js.map +0 -1
  532. package/dist/server/redirects.d.ts +0 -1
  533. package/dist/server/redirects.js.map +0 -1
  534. package/dist/server/refresh.d.ts +0 -1
  535. package/dist/server/refresh.js.map +0 -1
  536. package/dist/server/runtime.d.ts.map +0 -1
  537. package/dist/server/runtime.js.map +0 -1
  538. package/dist/server/sessions.d.ts +0 -1
  539. package/dist/server/sessions.js.map +0 -1
  540. package/dist/server/signin.d.ts +0 -1
  541. package/dist/server/signin.js.map +0 -1
  542. package/dist/server/ssr.d.ts.map +0 -1
  543. package/dist/server/ssr.js +0 -777
  544. package/dist/server/ssr.js.map +0 -1
  545. package/dist/server/templates.d.ts +0 -1
  546. package/dist/server/templates.js.map +0 -1
  547. package/dist/server/tokens.d.ts +0 -1
  548. package/dist/server/tokens.js.map +0 -1
  549. package/dist/server/totp.d.ts +0 -1
  550. package/dist/server/totp.js.map +0 -1
  551. package/dist/server/types.d.ts.map +0 -1
  552. package/dist/server/types.js.map +0 -1
  553. package/dist/server/users.d.ts +0 -1
  554. package/dist/server/users.js.map +0 -1
  555. package/dist/server/utils.d.ts +0 -1
  556. package/dist/server/utils.js +0 -140
  557. package/dist/server/utils.js.map +0 -1
  558. package/src/authorization/index.ts +0 -83
  559. package/src/cli/bin.ts +0 -5
  560. package/src/cli/command.ts +0 -70
  561. package/src/cli/index.ts +0 -1112
  562. package/src/cli/keys.ts +0 -23
  563. package/src/client/core/types.ts +0 -437
  564. package/src/client/factors/device.ts +0 -158
  565. package/src/client/factors/passkey.ts +0 -279
  566. package/src/client/factors/totp.ts +0 -150
  567. package/src/client/index.ts +0 -1124
  568. package/src/client/runtime/browser.ts +0 -112
  569. package/src/client/runtime/invite.ts +0 -63
  570. package/src/client/runtime/proxy.ts +0 -111
  571. package/src/client/runtime/storage.ts +0 -79
  572. package/src/component/_generated/api.ts +0 -96
  573. package/src/component/_generated/component.ts +0 -3774
  574. package/src/component/_generated/dataModel.ts +0 -60
  575. package/src/component/_generated/server.ts +0 -156
  576. package/src/component/convex.config.ts +0 -5
  577. package/src/component/functions.ts +0 -104
  578. package/src/component/index.ts +0 -42
  579. package/src/component/model.ts +0 -449
  580. package/src/component/public/enterprise/audit.ts +0 -125
  581. package/src/component/public/enterprise/core.ts +0 -355
  582. package/src/component/public/enterprise/domains.ts +0 -327
  583. package/src/component/public/enterprise/scim.ts +0 -397
  584. package/src/component/public/enterprise/secrets.ts +0 -133
  585. package/src/component/public/enterprise/webhooks.ts +0 -307
  586. package/src/component/public/factors/devices.ts +0 -224
  587. package/src/component/public/factors/passkeys.ts +0 -243
  588. package/src/component/public/factors/totp.ts +0 -259
  589. package/src/component/public/groups/core.ts +0 -481
  590. package/src/component/public/groups/invites.ts +0 -608
  591. package/src/component/public/groups/members.ts +0 -410
  592. package/src/component/public/identity/accounts.ts +0 -207
  593. package/src/component/public/identity/codes.ts +0 -149
  594. package/src/component/public/identity/sessions.ts +0 -210
  595. package/src/component/public/identity/tokens.ts +0 -251
  596. package/src/component/public/identity/users.ts +0 -355
  597. package/src/component/public/identity/verifiers.ts +0 -158
  598. package/src/component/public/security/keys.ts +0 -366
  599. package/src/component/public/security/limits.ts +0 -174
  600. package/src/component/public.ts +0 -27
  601. package/src/component/schema.ts +0 -505
  602. package/src/providers/anonymous.ts +0 -99
  603. package/src/providers/credentials.ts +0 -102
  604. package/src/providers/device.ts +0 -87
  605. package/src/providers/email.ts +0 -99
  606. package/src/providers/index.ts +0 -31
  607. package/src/providers/oauth.ts +0 -117
  608. package/src/providers/passkey.ts +0 -77
  609. package/src/providers/password.ts +0 -441
  610. package/src/providers/phone.ts +0 -93
  611. package/src/providers/sso.ts +0 -54
  612. package/src/providers/totp.ts +0 -62
  613. package/src/samlify.d.ts +0 -53
  614. package/src/server/auth.ts +0 -949
  615. package/src/server/config.ts +0 -200
  616. package/src/server/context.ts +0 -90
  617. package/src/server/cookies.ts +0 -49
  618. package/src/server/core.ts +0 -2004
  619. package/src/server/crypto.ts +0 -90
  620. package/src/server/db.ts +0 -203
  621. package/src/server/device.ts +0 -254
  622. package/src/server/enterprise/config.ts +0 -51
  623. package/src/server/enterprise/domain.ts +0 -1739
  624. package/src/server/enterprise/http.ts +0 -1331
  625. package/src/server/enterprise/oidc.ts +0 -500
  626. package/src/server/enterprise/policy.ts +0 -128
  627. package/src/server/enterprise/saml.ts +0 -578
  628. package/src/server/enterprise/scim.ts +0 -135
  629. package/src/server/enterprise/shared.ts +0 -134
  630. package/src/server/enterprise/validators.ts +0 -93
  631. package/src/server/http.ts +0 -790
  632. package/src/server/identity.ts +0 -18
  633. package/src/server/index.ts +0 -40
  634. package/src/server/keys.ts +0 -158
  635. package/src/server/limits.ts +0 -107
  636. package/src/server/mounts.ts +0 -924
  637. package/src/server/mutations/account.ts +0 -62
  638. package/src/server/mutations/code.ts +0 -119
  639. package/src/server/mutations/index.ts +0 -13
  640. package/src/server/mutations/invalidate.ts +0 -50
  641. package/src/server/mutations/oauth.ts +0 -243
  642. package/src/server/mutations/refresh.ts +0 -299
  643. package/src/server/mutations/register.ts +0 -155
  644. package/src/server/mutations/retrieve.ts +0 -109
  645. package/src/server/mutations/signature.ts +0 -57
  646. package/src/server/mutations/signin.ts +0 -54
  647. package/src/server/mutations/signout.ts +0 -43
  648. package/src/server/mutations/store/refs.ts +0 -10
  649. package/src/server/mutations/store.ts +0 -123
  650. package/src/server/mutations/verifier.ts +0 -34
  651. package/src/server/mutations/verify.ts +0 -200
  652. package/src/server/oauth.ts +0 -418
  653. package/src/server/passkey.ts +0 -838
  654. package/src/server/redirects.ts +0 -59
  655. package/src/server/refresh.ts +0 -218
  656. package/src/server/runtime.ts +0 -918
  657. package/src/server/sessions.ts +0 -132
  658. package/src/server/signin.ts +0 -445
  659. package/src/server/ssr.ts +0 -1747
  660. package/src/server/templates.ts +0 -82
  661. package/src/server/tokens.ts +0 -35
  662. package/src/server/totp.ts +0 -399
  663. package/src/server/types.ts +0 -1942
  664. package/src/server/users.ts +0 -291
  665. package/src/server/utils.ts +0 -220
  666. /package/dist/{runtime → client/runtime}/invite.js +0 -0
@@ -1,90 +0,0 @@
1
- import { Fx } from "@robelest/fx";
2
- import { Cv } from "@robelest/fx/convex";
3
- import { ConvexError } from "convex/values";
4
-
5
- import { AuthProviderMaterializedConfig } from "./types";
6
- import { ConvexAuthMaterializedConfig } from "./types";
7
- import { errorMessage } from "./utils";
8
-
9
- /**
10
- * Hash a secret using the provider's `crypto.hashSecret` function.
11
- *
12
- * Validates that the provider is a credentials provider and has the
13
- * required crypto function, returning typed errors through the Fx channel.
14
- */
15
- /** @internal */
16
- export const hash = (
17
- provider: any,
18
- secret: string,
19
- ): Fx<string, ConvexError<any>> =>
20
- Fx.gen(function* () {
21
- if (provider.type !== "credentials") {
22
- return yield* Cv.fail({
23
- code: "INVALID_CREDENTIALS_PROVIDER",
24
- message: `Provider ${provider.id} is not a credentials provider`,
25
- });
26
- }
27
-
28
- const hashSecretFn = provider.crypto?.hashSecret as
29
- | ((s: string) => Promise<string>)
30
- | undefined;
31
- if (!hashSecretFn) {
32
- return yield* Cv.fail({
33
- code: "MISSING_CRYPTO_FUNCTION",
34
- message: `Provider ${provider.id} does not have a \`crypto.hashSecret\` function`,
35
- });
36
- }
37
-
38
- return yield* Fx.from({
39
- ok: () => hashSecretFn(secret),
40
- err: (e) =>
41
- Cv.error({
42
- code: "INTERNAL_ERROR",
43
- message: `Hash failed: ${errorMessage(e)}`,
44
- }),
45
- });
46
- });
47
-
48
- /**
49
- * Verify a secret against a hash using the provider's `crypto.verifySecret` function.
50
- */
51
- /** @internal */
52
- export const verify = (
53
- provider: AuthProviderMaterializedConfig,
54
- secret: string,
55
- hashValue: string,
56
- ): Fx<boolean, ConvexError<any>> =>
57
- Fx.gen(function* () {
58
- if (provider.type !== "credentials") {
59
- return yield* Cv.fail({
60
- code: "INVALID_CREDENTIALS_PROVIDER",
61
- message: `Provider ${provider.id} is not a credentials provider`,
62
- });
63
- }
64
-
65
- const verifySecretFn = (provider as any).crypto?.verifySecret as
66
- | ((s: string, h: string) => Promise<boolean>)
67
- | undefined;
68
- if (!verifySecretFn) {
69
- return yield* Cv.fail({
70
- code: "MISSING_CRYPTO_FUNCTION",
71
- message: `Provider ${provider.id} does not have a \`crypto.verifySecret\` function`,
72
- });
73
- }
74
-
75
- return yield* Fx.from({
76
- ok: () => verifySecretFn(secret, hashValue),
77
- err: (e) =>
78
- Cv.error({
79
- code: "INTERNAL_ERROR",
80
- message: `Verify failed: ${errorMessage(e)}`,
81
- }),
82
- });
83
- });
84
-
85
- export type GetProviderOrThrowFunc = (
86
- provider: string,
87
- allowExtraProviders?: boolean,
88
- ) => AuthProviderMaterializedConfig;
89
-
90
- export type Config = ConvexAuthMaterializedConfig;
package/src/server/db.ts DELETED
@@ -1,203 +0,0 @@
1
- import {
2
- GenericActionCtx,
3
- GenericDataModel,
4
- GenericMutationCtx,
5
- FunctionReference,
6
- } from "convex/server";
7
-
8
- type MutationCtxLike = Pick<
9
- GenericMutationCtx<GenericDataModel>,
10
- "runQuery" | "runMutation"
11
- >;
12
- type ActionCtxLike = Pick<
13
- GenericActionCtx<GenericDataModel>,
14
- "runQuery" | "runMutation" | "runAction"
15
- >;
16
-
17
- type CtxLike = MutationCtxLike | ActionCtxLike;
18
-
19
- type AuthComponentApiLike = {
20
- public: {
21
- userGetById: FunctionReference<"query", "internal">;
22
- userFindByVerifiedEmail: FunctionReference<"query", "internal">;
23
- userFindByVerifiedPhone: FunctionReference<"query", "internal">;
24
- userInsert: FunctionReference<"mutation", "internal">;
25
- userPatch: FunctionReference<"mutation", "internal">;
26
- userUpsert: FunctionReference<"mutation", "internal">;
27
- accountGet: FunctionReference<"query", "internal">;
28
- accountGetById: FunctionReference<"query", "internal">;
29
- accountInsert: FunctionReference<"mutation", "internal">;
30
- accountPatch: FunctionReference<"mutation", "internal">;
31
- accountDelete: FunctionReference<"mutation", "internal">;
32
- sessionCreate: FunctionReference<"mutation", "internal">;
33
- sessionGetById: FunctionReference<"query", "internal">;
34
- sessionDelete: FunctionReference<"mutation", "internal">;
35
- sessionListByUser: FunctionReference<"query", "internal">;
36
- verifierCreate: FunctionReference<"mutation", "internal">;
37
- verifierGetById: FunctionReference<"query", "internal">;
38
- verifierGetBySignature: FunctionReference<"query", "internal">;
39
- verifierPatch: FunctionReference<"mutation", "internal">;
40
- verifierDelete: FunctionReference<"mutation", "internal">;
41
- verificationCodeGetByAccountId: FunctionReference<"query", "internal">;
42
- verificationCodeGetByCode: FunctionReference<"query", "internal">;
43
- verificationCodeCreate: FunctionReference<"mutation", "internal">;
44
- verificationCodeDelete: FunctionReference<"mutation", "internal">;
45
- refreshTokenCreate: FunctionReference<"mutation", "internal">;
46
- refreshTokenGetById: FunctionReference<"query", "internal">;
47
- refreshTokenPatch: FunctionReference<"mutation", "internal">;
48
- refreshTokenGetChildren: FunctionReference<"query", "internal">;
49
- refreshTokenListBySession: FunctionReference<"query", "internal">;
50
- refreshTokenDeleteAll: FunctionReference<"mutation", "internal">;
51
- refreshTokenGetActive: FunctionReference<"query", "internal">;
52
- rateLimitGet: FunctionReference<"query", "internal">;
53
- rateLimitCreate: FunctionReference<"mutation", "internal">;
54
- rateLimitPatch: FunctionReference<"mutation", "internal">;
55
- rateLimitDelete: FunctionReference<"mutation", "internal">;
56
- };
57
- };
58
-
59
- /** @internal */
60
- export type AuthDbConfig = { component: AuthComponentApiLike };
61
-
62
- /** @internal */
63
- export type AuthDb = ReturnType<typeof authDb>;
64
-
65
- /** @internal */
66
- export function authDb(ctx: CtxLike, config: AuthDbConfig) {
67
- const component = config.component;
68
- return {
69
- users: {
70
- getById: (userId: string) =>
71
- ctx.runQuery(component.public.userGetById, { userId }),
72
- findByVerifiedEmail: (email: string) =>
73
- ctx.runQuery(component.public.userFindByVerifiedEmail, { email }),
74
- findByVerifiedPhone: (phone: string) =>
75
- ctx.runQuery(component.public.userFindByVerifiedPhone, { phone }),
76
- insert: (data: Record<string, unknown>) =>
77
- ctx.runMutation(component.public.userInsert, {
78
- data,
79
- }) as Promise<string>,
80
- patch: (userId: string, data: Record<string, unknown>) =>
81
- ctx.runMutation(component.public.userPatch, { userId, data }),
82
- upsert: (userId: string | undefined, data: Record<string, unknown>) =>
83
- ctx.runMutation(component.public.userUpsert, {
84
- userId,
85
- data,
86
- }) as Promise<string>,
87
- },
88
- accounts: {
89
- get: (provider: string, providerAccountId: string) =>
90
- ctx.runQuery(component.public.accountGet, {
91
- provider,
92
- providerAccountId,
93
- }),
94
- getById: (accountId: string) =>
95
- ctx.runQuery(component.public.accountGetById, { accountId }),
96
- create: (args: {
97
- userId: string;
98
- provider: string;
99
- providerAccountId: string;
100
- secret?: string;
101
- extend?: Record<string, unknown>;
102
- }) =>
103
- ctx.runMutation(
104
- component.public.accountInsert,
105
- args,
106
- ) as Promise<string>,
107
- patch: (accountId: string, data: Record<string, unknown>) =>
108
- ctx.runMutation(component.public.accountPatch, { accountId, data }),
109
- delete: (accountId: string) =>
110
- ctx.runMutation(component.public.accountDelete, { accountId }),
111
- },
112
- sessions: {
113
- create: (userId: string, expirationTime: number) =>
114
- ctx.runMutation(component.public.sessionCreate, {
115
- userId,
116
- expirationTime,
117
- }) as Promise<string>,
118
- getById: (sessionId: string) =>
119
- ctx.runQuery(component.public.sessionGetById, { sessionId }),
120
- delete: (sessionId: string) =>
121
- ctx.runMutation(component.public.sessionDelete, { sessionId }),
122
- listByUser: (userId: string) =>
123
- ctx.runQuery(component.public.sessionListByUser, { userId }),
124
- },
125
- verifiers: {
126
- create: (sessionId?: string) =>
127
- ctx.runMutation(component.public.verifierCreate, {
128
- sessionId,
129
- }) as Promise<string>,
130
- getById: (verifierId: string) =>
131
- ctx.runQuery(component.public.verifierGetById, { verifierId }),
132
- getBySignature: (signature: string) =>
133
- ctx.runQuery(component.public.verifierGetBySignature, { signature }),
134
- patch: (verifierId: string, data: Record<string, unknown>) =>
135
- ctx.runMutation(component.public.verifierPatch, { verifierId, data }),
136
- delete: (verifierId: string) =>
137
- ctx.runMutation(component.public.verifierDelete, { verifierId }),
138
- },
139
- verificationCodes: {
140
- getByAccountId: (accountId: string) =>
141
- ctx.runQuery(component.public.verificationCodeGetByAccountId, {
142
- accountId,
143
- }),
144
- getByCode: (code: string) =>
145
- ctx.runQuery(component.public.verificationCodeGetByCode, { code }),
146
- create: (args: {
147
- accountId: string;
148
- provider: string;
149
- code: string;
150
- expirationTime: number;
151
- verifier?: string;
152
- emailVerified?: string;
153
- phoneVerified?: string;
154
- }) => ctx.runMutation(component.public.verificationCodeCreate, args),
155
- delete: (verificationCodeId: string) =>
156
- ctx.runMutation(component.public.verificationCodeDelete, {
157
- verificationCodeId,
158
- }),
159
- },
160
- refreshTokens: {
161
- create: (args: {
162
- sessionId: string;
163
- expirationTime: number;
164
- parentRefreshTokenId?: string;
165
- }) =>
166
- ctx.runMutation(
167
- component.public.refreshTokenCreate,
168
- args,
169
- ) as Promise<string>,
170
- getById: (refreshTokenId: string) =>
171
- ctx.runQuery(component.public.refreshTokenGetById, { refreshTokenId }),
172
- patch: (refreshTokenId: string, data: Record<string, unknown>) =>
173
- ctx.runMutation(component.public.refreshTokenPatch, {
174
- refreshTokenId,
175
- data,
176
- }),
177
- getChildren: (sessionId: string, parentRefreshTokenId: string) =>
178
- ctx.runQuery(component.public.refreshTokenGetChildren, {
179
- sessionId,
180
- parentRefreshTokenId,
181
- }),
182
- listBySession: (sessionId: string) =>
183
- ctx.runQuery(component.public.refreshTokenListBySession, { sessionId }),
184
- deleteAll: (sessionId: string) =>
185
- ctx.runMutation(component.public.refreshTokenDeleteAll, { sessionId }),
186
- getActive: (sessionId: string) =>
187
- ctx.runQuery(component.public.refreshTokenGetActive, { sessionId }),
188
- },
189
- rateLimits: {
190
- get: (identifier: string) =>
191
- ctx.runQuery(component.public.rateLimitGet, { identifier }),
192
- create: (args: {
193
- identifier: string;
194
- attemptsLeft: number;
195
- lastAttemptTime: number;
196
- }) => ctx.runMutation(component.public.rateLimitCreate, args),
197
- patch: (rateLimitId: string, data: Record<string, unknown>) =>
198
- ctx.runMutation(component.public.rateLimitPatch, { rateLimitId, data }),
199
- delete: (rateLimitId: string) =>
200
- ctx.runMutation(component.public.rateLimitDelete, { rateLimitId }),
201
- },
202
- };
203
- }
@@ -1,254 +0,0 @@
1
- /**
2
- * Server-side device authorization flow logic (RFC 8628).
3
- *
4
- * Handles the three phases of the device flow:
5
- * 1. (default) — Generate a device code + user code pair
6
- * 2. poll — Device checks whether the user has authorized yet
7
- * 3. verify — Authenticated user links a user code to their session
8
- *
9
- * Uses `@oslojs/crypto/random` for code generation and
10
- * `@oslojs/crypto/sha2` for hashing device codes before storage.
11
- */
12
-
13
- import { Fx } from "@robelest/fx";
14
- import { Cv } from "@robelest/fx/convex";
15
- import { ConvexError } from "convex/values";
16
-
17
- import { userIdFromIdentitySubject } from "./identity";
18
- import { callSignIn } from "./mutations/index";
19
- import { DeviceProviderConfig, GenericActionCtxWithAuthConfig } from "./types";
20
- import {
21
- AuthDataModel,
22
- SessionInfo,
23
- mutateDeviceInsert,
24
- queryDeviceByCodeHash,
25
- queryDeviceByUserCode,
26
- mutateDeviceAuthorize,
27
- mutateDeviceUpdateLastPolled,
28
- mutateDeviceDelete,
29
- } from "./types";
30
- import { generateRandomString, sha256 } from "./utils";
31
- import { requireEnv } from "./utils";
32
-
33
- type EnrichedActionCtx = GenericActionCtxWithAuthConfig<AuthDataModel>;
34
-
35
- // ============================================================================
36
- // Constants
37
- // ============================================================================
38
-
39
- const DEVICE_CODE_ALPHABET =
40
- "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
41
- const DEVICE_CODE_LENGTH = 40;
42
- const DEVICE_FLOWS = ["create", "poll", "verify"] as const;
43
-
44
- // ============================================================================
45
- // Create flow
46
- // ============================================================================
47
-
48
- // ============================================================================
49
- // Poll flow — pipeline of validations + status dispatch
50
- // ============================================================================
51
-
52
- // ============================================================================
53
- // Main dispatch
54
- // ============================================================================
55
-
56
- type DeviceResult =
57
- | {
58
- kind: "deviceCode";
59
- deviceCode: string;
60
- userCode: string;
61
- verificationUri: string;
62
- verificationUriComplete: string;
63
- expiresIn: number;
64
- interval: number;
65
- }
66
- | { kind: "signedIn"; signedIn: SessionInfo | null };
67
-
68
- /** @internal */
69
- export const handleDevice = (
70
- ctx: EnrichedActionCtx,
71
- provider: DeviceProviderConfig,
72
- args: { params?: Record<string, any> },
73
- ): Fx<DeviceResult, ConvexError<any>> =>
74
- Fx.from({
75
- ok: async () => {
76
- const params = (args.params ?? {}) as Record<string, unknown>;
77
- const flow = (typeof params.flow === "string" ? params.flow : "create") as
78
- | "create"
79
- | "poll"
80
- | "verify";
81
-
82
- if (!DEVICE_FLOWS.some((candidate) => candidate === flow)) {
83
- throw Cv.error({
84
- code: "DEVICE_MISSING_FLOW",
85
- message:
86
- "Missing `flow` parameter. Expected one of: create, poll, verify",
87
- });
88
- }
89
-
90
- if (flow === "create") {
91
- const deviceCode = generateRandomString(
92
- DEVICE_CODE_LENGTH,
93
- DEVICE_CODE_ALPHABET,
94
- );
95
- const deviceCodeHash = await sha256(deviceCode);
96
-
97
- const rawUserCode = generateRandomString(
98
- provider.userCodeLength,
99
- provider.charset,
100
- );
101
- const mid = Math.floor(rawUserCode.length / 2);
102
- const userCode =
103
- rawUserCode.slice(0, mid) + "-" + rawUserCode.slice(mid);
104
-
105
- const expiresAt = Date.now() + provider.expiresIn * 1000;
106
- await mutateDeviceInsert(ctx, {
107
- deviceCodeHash,
108
- userCode,
109
- expiresAt,
110
- interval: provider.interval,
111
- status: "pending",
112
- });
113
-
114
- const verificationUri =
115
- provider.verificationUri ??
116
- `${process.env.SITE_URL ?? requireEnv("SITE_URL")}/device`;
117
-
118
- return {
119
- kind: "deviceCode" as const,
120
- deviceCode,
121
- userCode,
122
- verificationUri,
123
- verificationUriComplete: `${verificationUri}?user_code=${encodeURIComponent(userCode)}`,
124
- expiresIn: provider.expiresIn,
125
- interval: provider.interval,
126
- };
127
- }
128
-
129
- if (flow === "poll") {
130
- if (typeof params.deviceCode !== "string") {
131
- throw Cv.error({
132
- code: "DEVICE_MISSING_FLOW",
133
- message: "Missing `deviceCode` parameter for poll flow.",
134
- });
135
- }
136
-
137
- const hash = await sha256(params.deviceCode);
138
- const doc = await queryDeviceByCodeHash(ctx, hash);
139
- if (doc === null) {
140
- throw Cv.error({
141
- code: "DEVICE_CODE_EXPIRED",
142
- message:
143
- "The device code has expired. Please start a new authorization request.",
144
- });
145
- }
146
- if (Date.now() > doc.expiresAt) {
147
- await mutateDeviceDelete(ctx, doc._id);
148
- throw Cv.error({
149
- code: "DEVICE_CODE_EXPIRED",
150
- message:
151
- "The device code has expired. Please start a new authorization request.",
152
- });
153
- }
154
- if (
155
- doc.lastPolledAt !== undefined &&
156
- (Date.now() - doc.lastPolledAt) / 1000 < doc.interval
157
- ) {
158
- throw Cv.error({
159
- code: "DEVICE_SLOW_DOWN",
160
- message:
161
- "Polling too frequently. Increase the interval between requests.",
162
- });
163
- }
164
-
165
- await mutateDeviceUpdateLastPolled(ctx, doc._id, Date.now());
166
-
167
- if (doc.status === "pending") {
168
- throw Cv.error({
169
- code: "DEVICE_AUTHORIZATION_PENDING",
170
- message: "The user has not yet authorized this device.",
171
- });
172
- }
173
- if (doc.status === "denied") {
174
- await mutateDeviceDelete(ctx, doc._id);
175
- throw Cv.error({
176
- code: "DEVICE_CODE_DENIED",
177
- message: "The authorization request was denied.",
178
- });
179
- }
180
-
181
- if (!doc.userId || !doc.sessionId) {
182
- throw Cv.error({
183
- code: "INTERNAL_ERROR",
184
- message: "Authorized device code missing userId or sessionId",
185
- });
186
- }
187
-
188
- await mutateDeviceDelete(ctx, doc._id);
189
- const signInResult = await callSignIn(ctx, {
190
- userId: doc.userId,
191
- sessionId: doc.sessionId,
192
- generateTokens: true,
193
- });
194
- return { kind: "signedIn" as const, signedIn: signInResult };
195
- }
196
-
197
- if (typeof params.userCode !== "string") {
198
- throw Cv.error({
199
- code: "DEVICE_INVALID_USER_CODE",
200
- message: "Missing `userCode` parameter for verify flow.",
201
- });
202
- }
203
-
204
- const identity = await ctx.auth.getUserIdentity();
205
- if (identity === null) {
206
- throw Cv.error({
207
- code: "NOT_SIGNED_IN",
208
- message: "You must be signed in to authorize a device.",
209
- });
210
- }
211
-
212
- const userId = userIdFromIdentitySubject(identity.subject);
213
- const doc = await queryDeviceByUserCode(ctx, params.userCode);
214
- if (doc === null) {
215
- throw Cv.error({
216
- code: "DEVICE_INVALID_USER_CODE",
217
- message: "Invalid or expired user code.",
218
- });
219
- }
220
- if (Date.now() > doc.expiresAt) {
221
- await mutateDeviceDelete(ctx, doc._id);
222
- throw Cv.error({
223
- code: "DEVICE_CODE_EXPIRED",
224
- message:
225
- "The device code has expired. Please start a new authorization request.",
226
- });
227
- }
228
- if (doc.status !== "pending") {
229
- throw Cv.error({
230
- code: "DEVICE_ALREADY_AUTHORIZED",
231
- message: "This device code has already been authorized.",
232
- });
233
- }
234
-
235
- const signInResult = await callSignIn(ctx, {
236
- userId,
237
- generateTokens: false,
238
- });
239
- await mutateDeviceAuthorize(
240
- ctx,
241
- doc._id,
242
- signInResult.userId,
243
- signInResult.sessionId,
244
- );
245
- return { kind: "signedIn" as const, signedIn: null };
246
- },
247
- err: (e) =>
248
- e instanceof ConvexError
249
- ? e
250
- : Cv.error({
251
- code: "INTERNAL_ERROR",
252
- message: `Device flow failed: ${String(e)}`,
253
- }),
254
- });
@@ -1,51 +0,0 @@
1
- import { asRecord } from "./shared";
2
-
3
- const getProtocolConfig = (config: unknown, protocol: "oidc" | "saml") => {
4
- const base = asRecord(config);
5
- const direct = base?.[protocol];
6
- const viaProtocols = asRecord(base?.protocols)?.[protocol];
7
- return asRecord(direct) ?? asRecord(viaProtocols) ?? {};
8
- };
9
-
10
- /** @internal */
11
- export function getOidcConfig(config: unknown): Record<string, any> {
12
- return getProtocolConfig(config, "oidc");
13
- }
14
-
15
- /** @internal */
16
- export function getPublicOidcConfig(config: unknown): Record<string, any> {
17
- const oidc = getOidcConfig(config);
18
- const { clientSecret: _clientSecret, ...publicOidc } = oidc;
19
- return publicOidc;
20
- }
21
-
22
- /** @internal */
23
- export function withOidcSecretState(
24
- config: Record<string, any>,
25
- hasClientSecret: boolean,
26
- ) {
27
- return {
28
- ...config,
29
- hasClientSecret,
30
- };
31
- }
32
-
33
- /** @internal */
34
- export function getSamlConfig(config: unknown): Record<string, any> {
35
- return getProtocolConfig(config, "saml");
36
- }
37
-
38
- /** @internal */
39
- export function upsertProtocolConfig(
40
- config: unknown,
41
- protocol: "oidc" | "saml",
42
- protocolConfig: Record<string, unknown>,
43
- ) {
44
- const base = asRecord(config) ?? {};
45
- const protocols = asRecord(base.protocols) ?? {};
46
- protocols[protocol] = {
47
- ...asRecord(protocols[protocol]),
48
- ...protocolConfig,
49
- };
50
- return { ...base, protocols };
51
- }