modelence 0.7.2 → 0.9.0-dev.0

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 (377) hide show
  1. package/dist/app/authConfig.d.ts +68 -0
  2. package/dist/app/authConfig.d.ts.map +1 -0
  3. package/dist/app/authConfig.js +8 -0
  4. package/dist/app/authConfig.js.map +1 -0
  5. package/dist/app/backendApi.d.ts +29 -0
  6. package/dist/app/backendApi.d.ts.map +1 -0
  7. package/dist/app/backendApi.js +69 -0
  8. package/dist/app/backendApi.js.map +1 -0
  9. package/dist/app/email.d.ts +3 -0
  10. package/dist/app/email.d.ts.map +1 -0
  11. package/dist/app/email.js +8 -0
  12. package/dist/app/email.js.map +1 -0
  13. package/dist/app/emailConfig.d.ts +27 -0
  14. package/dist/app/emailConfig.d.ts.map +1 -0
  15. package/dist/app/emailConfig.js +8 -0
  16. package/dist/app/emailConfig.js.map +1 -0
  17. package/dist/app/index.d.ts +20 -0
  18. package/dist/app/index.d.ts.map +1 -0
  19. package/dist/app/index.js +258 -0
  20. package/dist/app/index.js.map +1 -0
  21. package/dist/app/loggerProcess.d.ts +5 -0
  22. package/dist/app/loggerProcess.d.ts.map +1 -0
  23. package/dist/app/loggerProcess.js +90 -0
  24. package/dist/app/loggerProcess.js.map +1 -0
  25. package/dist/app/metrics.d.ts +6 -0
  26. package/dist/app/metrics.d.ts.map +1 -0
  27. package/dist/app/metrics.js +92 -0
  28. package/dist/app/metrics.js.map +1 -0
  29. package/dist/app/module.d.ts +77 -0
  30. package/dist/app/module.d.ts.map +1 -0
  31. package/dist/app/module.js +46 -0
  32. package/dist/app/module.js.map +1 -0
  33. package/dist/app/server.d.ts +37 -0
  34. package/dist/app/server.d.ts.map +1 -0
  35. package/dist/app/server.js +198 -0
  36. package/dist/app/server.js.map +1 -0
  37. package/dist/app/state.d.ts +19 -0
  38. package/dist/app/state.d.ts.map +1 -0
  39. package/dist/app/state.js +27 -0
  40. package/dist/app/state.js.map +1 -0
  41. package/dist/app/websocketConfig.d.ts +7 -0
  42. package/dist/app/websocketConfig.d.ts.map +1 -0
  43. package/dist/app/websocketConfig.js +8 -0
  44. package/dist/app/websocketConfig.js.map +1 -0
  45. package/dist/auth/client/index.d.ts +69 -0
  46. package/dist/auth/client/index.d.ts.map +1 -0
  47. package/dist/auth/client/index.js +79 -0
  48. package/dist/auth/client/index.js.map +1 -0
  49. package/dist/auth/db.d.ts +176 -0
  50. package/dist/auth/db.d.ts.map +1 -0
  51. package/dist/auth/db.js +117 -0
  52. package/dist/auth/db.js.map +1 -0
  53. package/dist/auth/deleteUser.d.ts +5 -0
  54. package/dist/auth/deleteUser.d.ts.map +1 -0
  55. package/dist/auth/deleteUser.js +34 -0
  56. package/dist/auth/deleteUser.js.map +1 -0
  57. package/dist/auth/disposableEmails.d.ts +6 -0
  58. package/dist/auth/disposableEmails.d.ts.map +1 -0
  59. package/dist/auth/disposableEmails.js +47 -0
  60. package/dist/auth/disposableEmails.js.map +1 -0
  61. package/dist/auth/index.d.ts +7 -0
  62. package/dist/auth/index.d.ts.map +1 -0
  63. package/dist/auth/index.js +33 -0
  64. package/dist/auth/index.js.map +1 -0
  65. package/dist/auth/login.d.ts +9 -0
  66. package/dist/auth/login.d.ts.map +1 -0
  67. package/dist/auth/login.js +100 -0
  68. package/dist/auth/login.js.map +1 -0
  69. package/dist/auth/password.d.ts +14 -0
  70. package/dist/auth/password.d.ts.map +1 -0
  71. package/dist/auth/password.js +26 -0
  72. package/dist/auth/password.js.map +1 -0
  73. package/dist/auth/profile.d.ts +10 -0
  74. package/dist/auth/profile.d.ts.map +1 -0
  75. package/dist/auth/profile.js +13 -0
  76. package/dist/auth/profile.js.map +1 -0
  77. package/dist/auth/providers/github.d.ts +3 -0
  78. package/dist/auth/providers/github.d.ts.map +1 -0
  79. package/dist/auth/providers/github.js +122 -0
  80. package/dist/auth/providers/github.js.map +1 -0
  81. package/dist/auth/providers/google.d.ts +3 -0
  82. package/dist/auth/providers/google.d.ts.map +1 -0
  83. package/dist/auth/providers/google.js +108 -0
  84. package/dist/auth/providers/google.js.map +1 -0
  85. package/dist/auth/providers/oauth-common.d.ts +13 -0
  86. package/dist/auth/providers/oauth-common.d.ts.map +1 -0
  87. package/dist/auth/providers/oauth-common.js +109 -0
  88. package/dist/auth/providers/oauth-common.js.map +1 -0
  89. package/dist/auth/resetPassword.d.ts +10 -0
  90. package/dist/auth/resetPassword.d.ts.map +1 -0
  91. package/dist/auth/resetPassword.js +108 -0
  92. package/dist/auth/resetPassword.js.map +1 -0
  93. package/dist/auth/role.d.ts +8 -0
  94. package/dist/auth/role.d.ts.map +1 -0
  95. package/dist/auth/role.js +37 -0
  96. package/dist/auth/role.js.map +1 -0
  97. package/dist/auth/session.d.ts +24 -0
  98. package/dist/auth/session.d.ts.map +1 -0
  99. package/dist/auth/session.js +84 -0
  100. package/dist/auth/session.js.map +1 -0
  101. package/dist/auth/signup.d.ts +3 -0
  102. package/dist/auth/signup.d.ts.map +1 -0
  103. package/dist/auth/signup.js +89 -0
  104. package/dist/auth/signup.js.map +1 -0
  105. package/dist/auth/templates/emailVerficationTemplate.d.ts +6 -0
  106. package/dist/auth/templates/emailVerficationTemplate.d.ts.map +1 -0
  107. package/dist/auth/templates/emailVerficationTemplate.js +9 -0
  108. package/dist/auth/templates/emailVerficationTemplate.js.map +1 -0
  109. package/dist/auth/types.d.ts +22 -0
  110. package/dist/auth/types.d.ts.map +1 -0
  111. package/dist/auth/types.js +2 -0
  112. package/dist/auth/types.js.map +1 -0
  113. package/dist/auth/user.d.ts +5 -0
  114. package/dist/auth/user.d.ts.map +1 -0
  115. package/dist/auth/user.js +152 -0
  116. package/dist/auth/user.js.map +1 -0
  117. package/dist/auth/validators.d.ts +3 -0
  118. package/dist/auth/validators.d.ts.map +1 -0
  119. package/dist/auth/validators.js +8 -0
  120. package/dist/auth/validators.js.map +1 -0
  121. package/dist/auth/verification.d.ts +8 -0
  122. package/dist/auth/verification.d.ts.map +1 -0
  123. package/dist/auth/verification.js +94 -0
  124. package/dist/auth/verification.js.map +1 -0
  125. package/dist/bin/auth.d.ts +4 -0
  126. package/dist/bin/auth.d.ts.map +1 -0
  127. package/dist/bin/auth.js +48 -0
  128. package/dist/bin/auth.js.map +1 -0
  129. package/dist/bin/build.d.ts +2 -0
  130. package/dist/bin/build.d.ts.map +1 -0
  131. package/dist/bin/build.js +78 -0
  132. package/dist/bin/build.js.map +1 -0
  133. package/dist/bin/config.d.ts +11 -0
  134. package/dist/bin/config.d.ts.map +1 -0
  135. package/dist/bin/config.js +91 -0
  136. package/dist/bin/config.js.map +1 -0
  137. package/dist/bin/deploy.d.ts +6 -0
  138. package/dist/bin/deploy.d.ts.map +1 -0
  139. package/dist/bin/deploy.js +129 -0
  140. package/dist/bin/deploy.js.map +1 -0
  141. package/dist/bin/dev.d.ts +2 -0
  142. package/dist/bin/dev.d.ts.map +1 -0
  143. package/dist/bin/dev.js +14 -0
  144. package/dist/bin/dev.js.map +1 -0
  145. package/dist/bin/modelence.d.ts +3 -0
  146. package/dist/bin/modelence.d.ts.map +1 -0
  147. package/dist/bin/modelence.js +57 -3
  148. package/dist/bin/modelence.js.map +1 -1
  149. package/dist/bin/setup.d.ts +5 -0
  150. package/dist/bin/setup.d.ts.map +1 -0
  151. package/dist/bin/setup.js +91 -0
  152. package/dist/bin/setup.js.map +1 -0
  153. package/dist/bin/start.d.ts +2 -0
  154. package/dist/bin/start.d.ts.map +1 -0
  155. package/dist/bin/start.js +15 -0
  156. package/dist/bin/start.js.map +1 -0
  157. package/dist/client/AppProvider.d.ts +8 -0
  158. package/dist/client/AppProvider.d.ts.map +1 -0
  159. package/dist/client/AppProvider.js +31 -0
  160. package/dist/client/AppProvider.js.map +1 -0
  161. package/dist/client/errorHandler.d.ts +4 -0
  162. package/dist/client/errorHandler.d.ts.map +1 -0
  163. package/dist/client/errorHandler.js +10 -0
  164. package/dist/client/errorHandler.js.map +1 -0
  165. package/dist/client/localStorage.d.ts +3 -0
  166. package/dist/client/localStorage.d.ts.map +1 -0
  167. package/dist/client/localStorage.js +14 -0
  168. package/dist/client/localStorage.js.map +1 -0
  169. package/dist/client/method.d.ts +6 -0
  170. package/dist/client/method.d.ts.map +1 -0
  171. package/dist/client/method.js +52 -0
  172. package/dist/client/method.js.map +1 -0
  173. package/dist/client/renderApp.d.ts +9 -0
  174. package/dist/client/renderApp.d.ts.map +1 -0
  175. package/dist/client/renderApp.js +28 -0
  176. package/dist/client/renderApp.js.map +1 -0
  177. package/dist/client/session.d.ts +34 -0
  178. package/dist/client/session.d.ts.map +1 -0
  179. package/dist/client/session.js +83 -0
  180. package/dist/client/session.js.map +1 -0
  181. package/dist/client.d.ts +10 -133
  182. package/dist/client.d.ts.map +1 -0
  183. package/dist/client.js +14 -1
  184. package/dist/client.js.map +1 -1
  185. package/dist/config/client.d.ts +10 -0
  186. package/dist/config/client.d.ts.map +1 -0
  187. package/dist/config/client.js +14 -0
  188. package/dist/config/client.js.map +1 -0
  189. package/dist/config/server.d.ts +48 -0
  190. package/dist/config/server.d.ts.map +1 -0
  191. package/dist/config/server.js +85 -0
  192. package/dist/config/server.js.map +1 -0
  193. package/dist/config/sync.d.ts +2 -0
  194. package/dist/config/sync.d.ts.map +1 -0
  195. package/dist/config/sync.js +32 -0
  196. package/dist/config/sync.js.map +1 -0
  197. package/dist/config/types.d.ts +19 -0
  198. package/dist/config/types.d.ts.map +1 -0
  199. package/dist/config/types.js +2 -0
  200. package/dist/config/types.js.map +1 -0
  201. package/dist/cron/jobs.d.ts +13 -0
  202. package/dist/cron/jobs.d.ts.map +1 -0
  203. package/dist/cron/jobs.js +155 -0
  204. package/dist/cron/jobs.js.map +1 -0
  205. package/dist/cron/types.d.ts +29 -0
  206. package/dist/cron/types.d.ts.map +1 -0
  207. package/dist/cron/types.js +2 -0
  208. package/dist/cron/types.js.map +1 -0
  209. package/dist/data/schemaSerializer.d.ts +37 -0
  210. package/dist/data/schemaSerializer.d.ts.map +1 -0
  211. package/dist/data/schemaSerializer.js +104 -0
  212. package/dist/data/schemaSerializer.js.map +1 -0
  213. package/dist/{types-WgRbQ-tj.d.ts → data/store.d.ts} +13 -231
  214. package/dist/data/store.d.ts.map +1 -0
  215. package/dist/data/store.js +501 -0
  216. package/dist/data/store.js.map +1 -0
  217. package/dist/data/types.d.ts +47 -0
  218. package/dist/data/types.d.ts.map +1 -0
  219. package/dist/data/types.js +35 -0
  220. package/dist/data/types.js.map +1 -0
  221. package/dist/db/client.d.ts +5 -0
  222. package/dist/db/client.d.ts.map +1 -0
  223. package/dist/db/client.js +41 -0
  224. package/dist/db/client.js.map +1 -0
  225. package/dist/error.d.ts +16 -0
  226. package/dist/error.d.ts.map +1 -0
  227. package/dist/error.js +24 -0
  228. package/dist/error.js.map +1 -0
  229. package/dist/index.d.ts +6 -31
  230. package/dist/index.d.ts.map +1 -0
  231. package/dist/index.js +2 -1
  232. package/dist/index.js.map +1 -1
  233. package/dist/lock/db.d.ts +19 -0
  234. package/dist/lock/db.d.ts.map +1 -0
  235. package/dist/lock/db.js +28 -0
  236. package/dist/lock/db.js.map +1 -0
  237. package/dist/lock/helpers.d.ts +28 -0
  238. package/dist/lock/helpers.d.ts.map +1 -0
  239. package/dist/lock/helpers.js +107 -0
  240. package/dist/lock/helpers.js.map +1 -0
  241. package/dist/lock/index.d.ts +4 -0
  242. package/dist/lock/index.d.ts.map +1 -0
  243. package/dist/lock/index.js +4 -0
  244. package/dist/lock/index.js.map +1 -0
  245. package/dist/lock/module.d.ts +7 -0
  246. package/dist/lock/module.d.ts.map +1 -0
  247. package/dist/lock/module.js +9 -0
  248. package/dist/lock/module.js.map +1 -0
  249. package/dist/methods/index.d.ts +7 -0
  250. package/dist/methods/index.d.ts.map +1 -0
  251. package/dist/methods/index.js +65 -0
  252. package/dist/methods/index.js.map +1 -0
  253. package/dist/methods/serialize.d.ts +15 -0
  254. package/dist/methods/serialize.d.ts.map +1 -0
  255. package/dist/methods/serialize.js +56 -0
  256. package/dist/methods/serialize.js.map +1 -0
  257. package/dist/methods/types.d.ts +37 -0
  258. package/dist/methods/types.d.ts.map +1 -0
  259. package/dist/methods/types.js +2 -0
  260. package/dist/methods/types.js.map +1 -0
  261. package/dist/migration/db.d.ts +17 -0
  262. package/dist/migration/db.d.ts.map +1 -0
  263. package/dist/migration/db.js +13 -0
  264. package/dist/migration/db.js.map +1 -0
  265. package/dist/migration/index.d.ts +11 -0
  266. package/dist/migration/index.d.ts.map +1 -0
  267. package/dist/migration/index.js +85 -0
  268. package/dist/migration/index.js.map +1 -0
  269. package/dist/mongo.d.ts +2 -3
  270. package/dist/mongo.d.ts.map +1 -0
  271. package/dist/mongo.js +2 -1
  272. package/dist/mongo.js.map +1 -1
  273. package/dist/rate-limit/db.d.ts +29 -0
  274. package/dist/rate-limit/db.d.ts.map +1 -0
  275. package/dist/rate-limit/db.js +25 -0
  276. package/dist/rate-limit/db.js.map +1 -0
  277. package/dist/rate-limit/index.d.ts +4 -0
  278. package/dist/rate-limit/index.d.ts.map +1 -0
  279. package/dist/rate-limit/index.js +6 -0
  280. package/dist/rate-limit/index.js.map +1 -0
  281. package/dist/rate-limit/rules.d.ts +22 -0
  282. package/dist/rate-limit/rules.d.ts.map +1 -0
  283. package/dist/rate-limit/rules.js +112 -0
  284. package/dist/rate-limit/rules.js.map +1 -0
  285. package/dist/rate-limit/types.d.ts +12 -0
  286. package/dist/rate-limit/types.d.ts.map +1 -0
  287. package/dist/rate-limit/types.js +2 -0
  288. package/dist/rate-limit/types.js.map +1 -0
  289. package/dist/routes/handler.d.ts +4 -0
  290. package/dist/routes/handler.d.ts.map +1 -0
  291. package/dist/routes/handler.js +66 -0
  292. package/dist/routes/handler.js.map +1 -0
  293. package/dist/routes/types.d.ts +45 -0
  294. package/dist/routes/types.d.ts.map +1 -0
  295. package/dist/routes/types.js +2 -0
  296. package/dist/routes/types.js.map +1 -0
  297. package/dist/server.d.ts +19 -551
  298. package/dist/server.d.ts.map +1 -0
  299. package/dist/server.js +15 -18
  300. package/dist/server.js.map +1 -1
  301. package/dist/system/index.d.ts +4 -0
  302. package/dist/system/index.d.ts.map +1 -0
  303. package/dist/system/index.js +21 -0
  304. package/dist/system/index.js.map +1 -0
  305. package/dist/telemetry/index.d.ts +11 -0
  306. package/dist/telemetry/index.d.ts.map +1 -0
  307. package/dist/telemetry/index.js +79 -0
  308. package/dist/telemetry/index.js.map +1 -0
  309. package/dist/telemetry.d.ts +2 -11
  310. package/dist/telemetry.d.ts.map +1 -0
  311. package/dist/telemetry.js +1 -1
  312. package/dist/telemetry.js.map +1 -1
  313. package/dist/time.d.ts +8 -0
  314. package/dist/time.d.ts.map +1 -0
  315. package/dist/time.js +13 -0
  316. package/dist/time.js.map +1 -0
  317. package/dist/types/email.d.ts +25 -0
  318. package/dist/types/email.d.ts.map +1 -0
  319. package/dist/types/email.js +2 -0
  320. package/dist/types/email.js.map +1 -0
  321. package/dist/types/index.d.ts +14 -0
  322. package/dist/types/index.d.ts.map +1 -0
  323. package/dist/types/index.js +2 -0
  324. package/dist/types/index.js.map +1 -0
  325. package/dist/types.d.ts +10 -7
  326. package/dist/types.d.ts.map +1 -0
  327. package/dist/types.js +1 -1
  328. package/dist/types.js.map +1 -1
  329. package/dist/utils/index.d.ts +4 -0
  330. package/dist/utils/index.d.ts.map +1 -0
  331. package/dist/utils/index.js +15 -0
  332. package/dist/utils/index.js.map +1 -0
  333. package/dist/viteServer.d.ts +13 -0
  334. package/dist/viteServer.d.ts.map +1 -0
  335. package/dist/viteServer.js +132 -0
  336. package/dist/viteServer.js.map +1 -0
  337. package/dist/websocket/client.d.ts +9 -0
  338. package/dist/websocket/client.d.ts.map +1 -0
  339. package/dist/websocket/client.js +16 -0
  340. package/dist/websocket/client.js.map +1 -0
  341. package/dist/websocket/clientChannel.d.ts +9 -0
  342. package/dist/websocket/clientChannel.d.ts.map +1 -0
  343. package/dist/websocket/clientChannel.js +26 -0
  344. package/dist/websocket/clientChannel.js.map +1 -0
  345. package/dist/websocket/serverChannel.d.ts +14 -0
  346. package/dist/websocket/serverChannel.d.ts.map +1 -0
  347. package/dist/websocket/serverChannel.js +21 -0
  348. package/dist/websocket/serverChannel.js.map +1 -0
  349. package/dist/websocket/socketio/client.d.ts +4 -0
  350. package/dist/websocket/socketio/client.d.ts.map +1 -0
  351. package/dist/websocket/socketio/client.js +48 -0
  352. package/dist/websocket/socketio/client.js.map +1 -0
  353. package/dist/websocket/socketio/server.d.ts +10 -0
  354. package/dist/websocket/socketio/server.d.ts.map +1 -0
  355. package/dist/websocket/socketio/server.js +80 -0
  356. package/dist/websocket/socketio/server.js.map +1 -0
  357. package/dist/websocket/types.d.ts +45 -0
  358. package/dist/websocket/types.d.ts.map +1 -0
  359. package/dist/websocket/types.js +2 -0
  360. package/dist/websocket/types.js.map +1 -0
  361. package/package.json +5 -6
  362. package/dist/chunk-3S2FFBNS.js +0 -2
  363. package/dist/chunk-3S2FFBNS.js.map +0 -1
  364. package/dist/chunk-55J6XMHW.js +0 -2
  365. package/dist/chunk-55J6XMHW.js.map +0 -1
  366. package/dist/chunk-C3UESBRX.js +0 -2
  367. package/dist/chunk-C3UESBRX.js.map +0 -1
  368. package/dist/chunk-DO5TZLF5.js +0 -2
  369. package/dist/chunk-DO5TZLF5.js.map +0 -1
  370. package/dist/chunk-KUL6YKKP.js +0 -3
  371. package/dist/chunk-KUL6YKKP.js.map +0 -1
  372. package/dist/chunk-PB6WQQ4L.js +0 -3
  373. package/dist/chunk-PB6WQQ4L.js.map +0 -1
  374. package/dist/index-CwdohC5n.d.ts +0 -15
  375. package/dist/package-IIELPLTY.js +0 -2
  376. package/dist/package-IIELPLTY.js.map +0 -1
  377. package/dist/types-Ds1ESQSs.d.ts +0 -106
@@ -0,0 +1 @@
1
+ {"version":3,"file":"websocketConfig.d.ts","sourceRoot":"","sources":["../../src/app/websocketConfig.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,mBAAmB,CAAC;AAE5D,MAAM,MAAM,eAAe,GAAG;IAC5B,QAAQ,CAAC,EAAE,uBAAuB,CAAC;CACpC,CAAC;AAIF,wBAAgB,kBAAkB,CAAC,kBAAkB,EAAE,eAAe,QAErE;AAED,wBAAgB,kBAAkB,oBAEjC"}
@@ -0,0 +1,8 @@
1
+ let websocketConfig = Object.freeze({});
2
+ export function setWebsocketConfig(newWebsocketConfig) {
3
+ websocketConfig = Object.freeze(Object.assign({}, websocketConfig, newWebsocketConfig));
4
+ }
5
+ export function getWebsocketConfig() {
6
+ return websocketConfig;
7
+ }
8
+ //# sourceMappingURL=websocketConfig.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"websocketConfig.js","sourceRoot":"","sources":["../../src/app/websocketConfig.ts"],"names":[],"mappings":"AAMA,IAAI,eAAe,GAAoB,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;AAEzD,MAAM,UAAU,kBAAkB,CAAC,kBAAmC;IACpE,eAAe,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,eAAe,EAAE,kBAAkB,CAAC,CAAC,CAAC;AAC1F,CAAC;AAED,MAAM,UAAU,kBAAkB;IAChC,OAAO,eAAe,CAAC;AACzB,CAAC"}
@@ -0,0 +1,69 @@
1
+ export type UserInfo = {
2
+ id: string;
3
+ handle: string;
4
+ roles: string[];
5
+ hasRole: (role: string) => boolean;
6
+ requireRole: (role: string) => void;
7
+ };
8
+ /**
9
+ * Sign up a new user with an email and password.
10
+ *
11
+ * @example
12
+ * ```ts
13
+ * await signupWithPassword({ email: 'test@example.com', password: '12345678' });
14
+ * ```
15
+ * @param options.email - The email of the user.
16
+ * @param options.password - The password of the user.
17
+ */
18
+ export declare function signupWithPassword(options: {
19
+ email: string;
20
+ password: string;
21
+ }): Promise<void>;
22
+ /**
23
+ * Login a user with an email and password.
24
+ *
25
+ * @example
26
+ * ```ts
27
+ * await loginWithPassword({ email: 'test@example.com', password: '12345678' });
28
+ * ```
29
+ * @param options.email - The email of the user.
30
+ * @param options.password - The password of the user.
31
+ */
32
+ export declare function loginWithPassword(options: {
33
+ email: string;
34
+ password: string;
35
+ }): Promise<UserInfo>;
36
+ /**
37
+ * Verify user's email with a verification token.
38
+ *
39
+ * @example
40
+ * ```ts
41
+ * await verifyEmail({ token: 'verification-token' });
42
+ * ```
43
+ * @param options.token - The email verification token.
44
+ */
45
+ export declare function verifyEmail(options: {
46
+ token: string;
47
+ }): Promise<void>;
48
+ /**
49
+ * Logout the current user.
50
+ *
51
+ */
52
+ export declare function logout(): Promise<void>;
53
+ /**
54
+ * Send reset password token.
55
+ * @param options.email - The email of the user.
56
+ */
57
+ export declare function sendResetPasswordToken(options: {
58
+ email: string;
59
+ }): Promise<void>;
60
+ /**
61
+ * Reset password.
62
+ * @param options.token - The password reset token.
63
+ * @param options.password - The new password.
64
+ */
65
+ export declare function resetPassword(options: {
66
+ token: string;
67
+ password: string;
68
+ }): Promise<void>;
69
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/auth/client/index.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,QAAQ,GAAG;IACrB,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC;IACnC,WAAW,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;CACrC,CAAC;AAEF;;;;;;;;;GASG;AACH,wBAAsB,kBAAkB,CAAC,OAAO,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,iBAGpF;AAED;;;;;;;;;GASG;AACH,wBAAsB,iBAAiB,CAAC,OAAO,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,qBAQnF;AAED;;;;;;;;GAQG;AACH,wBAAsB,WAAW,CAAC,OAAO,EAAE;IAAE,KAAK,EAAE,MAAM,CAAA;CAAE,iBAG3D;AAED;;;GAGG;AACH,wBAAsB,MAAM,kBAG3B;AAED;;;GAGG;AACH,wBAAsB,sBAAsB,CAAC,OAAO,EAAE;IAAE,KAAK,EAAE,MAAM,CAAA;CAAE,iBAKtE;AAED;;;;GAIG;AACH,wBAAsB,aAAa,CAAC,OAAO,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,iBAM/E"}
@@ -0,0 +1,79 @@
1
+ import { setCurrentUser } from '../../client/session';
2
+ import { callMethod } from '../../client/method';
3
+ /**
4
+ * Sign up a new user with an email and password.
5
+ *
6
+ * @example
7
+ * ```ts
8
+ * await signupWithPassword({ email: 'test@example.com', password: '12345678' });
9
+ * ```
10
+ * @param options.email - The email of the user.
11
+ * @param options.password - The password of the user.
12
+ */
13
+ export async function signupWithPassword(options) {
14
+ const { email, password } = options;
15
+ await callMethod('_system.user.signupWithPassword', { email, password });
16
+ }
17
+ /**
18
+ * Login a user with an email and password.
19
+ *
20
+ * @example
21
+ * ```ts
22
+ * await loginWithPassword({ email: 'test@example.com', password: '12345678' });
23
+ * ```
24
+ * @param options.email - The email of the user.
25
+ * @param options.password - The password of the user.
26
+ */
27
+ export async function loginWithPassword(options) {
28
+ const { email, password } = options;
29
+ const { user } = await callMethod('_system.user.loginWithPassword', {
30
+ email,
31
+ password,
32
+ });
33
+ setCurrentUser(user);
34
+ return user;
35
+ }
36
+ /**
37
+ * Verify user's email with a verification token.
38
+ *
39
+ * @example
40
+ * ```ts
41
+ * await verifyEmail({ token: 'verification-token' });
42
+ * ```
43
+ * @param options.token - The email verification token.
44
+ */
45
+ export async function verifyEmail(options) {
46
+ const { token } = options;
47
+ await callMethod('_system.user.verifyEmail', { token });
48
+ }
49
+ /**
50
+ * Logout the current user.
51
+ *
52
+ */
53
+ export async function logout() {
54
+ await callMethod('_system.user.logout');
55
+ setCurrentUser(null);
56
+ }
57
+ /**
58
+ * Send reset password token.
59
+ * @param options.email - The email of the user.
60
+ */
61
+ export async function sendResetPasswordToken(options) {
62
+ const { email } = options;
63
+ await callMethod('_system.user.sendResetPasswordToken', {
64
+ email,
65
+ });
66
+ }
67
+ /**
68
+ * Reset password.
69
+ * @param options.token - The password reset token.
70
+ * @param options.password - The new password.
71
+ */
72
+ export async function resetPassword(options) {
73
+ const { token, password } = options;
74
+ await callMethod('_system.user.resetPassword', {
75
+ token,
76
+ password,
77
+ });
78
+ }
79
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/auth/client/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAUjD;;;;;;;;;GASG;AACH,MAAM,CAAC,KAAK,UAAU,kBAAkB,CAAC,OAA4C;IACnF,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC;IACpC,MAAM,UAAU,CAAC,iCAAiC,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;AAC3E,CAAC;AAED;;;;;;;;;GASG;AACH,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,OAA4C;IAClF,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC;IACpC,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,UAAU,CAAqB,gCAAgC,EAAE;QACtF,KAAK;QACL,QAAQ;KACT,CAAC,CAAC;IACH,cAAc,CAAC,IAAI,CAAC,CAAC;IACrB,OAAO,IAAI,CAAC;AACd,CAAC;AAED;;;;;;;;GAQG;AACH,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,OAA0B;IAC1D,MAAM,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC;IAC1B,MAAM,UAAU,CAAqB,0BAA0B,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;AAC9E,CAAC;AAED;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,MAAM;IAC1B,MAAM,UAAU,CAAC,qBAAqB,CAAC,CAAC;IACxC,cAAc,CAAC,IAAI,CAAC,CAAC;AACvB,CAAC;AAED;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAAC,OAA0B;IACrE,MAAM,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC;IAC1B,MAAM,UAAU,CAAC,qCAAqC,EAAE;QACtD,KAAK;KACN,CAAC,CAAC;AACL,CAAC;AAED;;;;GAIG;AACH,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,OAA4C;IAC9E,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC;IACpC,MAAM,UAAU,CAAC,4BAA4B,EAAE;QAC7C,KAAK;QACL,QAAQ;KACT,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,176 @@
1
+ import { Store } from '../data/store';
2
+ /**
3
+ * Database collection for storing user accounts with authentication methods and profile information.
4
+ *
5
+ * This is where **signupWithPassword** automatically creates new users.
6
+ *
7
+ * @example
8
+ * ```typescript
9
+ * // Find user by email
10
+ * const user = await dbUsers.findOne(
11
+ * { 'emails.address': 'john@example.com' }
12
+ * );
13
+ * ```
14
+ *
15
+ */
16
+ export declare const usersCollection: Store<{
17
+ handle: import("zod").ZodString;
18
+ emails: import("zod").ZodOptional<import("zod").ZodArray<import("zod").ZodObject<{
19
+ address: import("zod").ZodString;
20
+ verified: import("zod").ZodBoolean;
21
+ }, "strip", import("zod").ZodTypeAny, {
22
+ address: string;
23
+ verified: boolean;
24
+ }, {
25
+ address: string;
26
+ verified: boolean;
27
+ }>, "many">>;
28
+ status: import("zod").ZodOptional<import("zod").ZodEnum<["active", "disabled", "deleted"]>>;
29
+ createdAt: import("zod").ZodDate;
30
+ disabledAt: import("zod").ZodOptional<import("zod").ZodDate>;
31
+ deletedAt: import("zod").ZodOptional<import("zod").ZodDate>;
32
+ roles: import("zod").ZodOptional<import("zod").ZodArray<import("zod").ZodString, "many">>;
33
+ authMethods: import("zod").ZodObject<{
34
+ password: import("zod").ZodOptional<import("zod").ZodObject<{
35
+ hash: import("zod").ZodString;
36
+ }, "strip", import("zod").ZodTypeAny, {
37
+ hash: string;
38
+ }, {
39
+ hash: string;
40
+ }>>;
41
+ google: import("zod").ZodOptional<import("zod").ZodObject<{
42
+ id: import("zod").ZodString;
43
+ }, "strip", import("zod").ZodTypeAny, {
44
+ id: string;
45
+ }, {
46
+ id: string;
47
+ }>>;
48
+ github: import("zod").ZodOptional<import("zod").ZodObject<{
49
+ id: import("zod").ZodString;
50
+ }, "strip", import("zod").ZodTypeAny, {
51
+ id: string;
52
+ }, {
53
+ id: string;
54
+ }>>;
55
+ }, "strip", import("zod").ZodTypeAny, {
56
+ password?: {
57
+ hash: string;
58
+ } | undefined;
59
+ google?: {
60
+ id: string;
61
+ } | undefined;
62
+ github?: {
63
+ id: string;
64
+ } | undefined;
65
+ }, {
66
+ password?: {
67
+ hash: string;
68
+ } | undefined;
69
+ google?: {
70
+ id: string;
71
+ } | undefined;
72
+ github?: {
73
+ id: string;
74
+ } | undefined;
75
+ }>;
76
+ }, Record<string, (this: Pick<import("../types").InferDocumentType<{
77
+ handle: import("zod").ZodString;
78
+ emails: import("zod").ZodOptional<import("zod").ZodArray<import("zod").ZodObject<{
79
+ address: import("zod").ZodString;
80
+ verified: import("zod").ZodBoolean;
81
+ }, "strip", import("zod").ZodTypeAny, {
82
+ address: string;
83
+ verified: boolean;
84
+ }, {
85
+ address: string;
86
+ verified: boolean;
87
+ }>, "many">>;
88
+ status: import("zod").ZodOptional<import("zod").ZodEnum<["active", "disabled", "deleted"]>>;
89
+ createdAt: import("zod").ZodDate;
90
+ disabledAt: import("zod").ZodOptional<import("zod").ZodDate>;
91
+ deletedAt: import("zod").ZodOptional<import("zod").ZodDate>;
92
+ roles: import("zod").ZodOptional<import("zod").ZodArray<import("zod").ZodString, "many">>;
93
+ authMethods: import("zod").ZodObject<{
94
+ password: import("zod").ZodOptional<import("zod").ZodObject<{
95
+ hash: import("zod").ZodString;
96
+ }, "strip", import("zod").ZodTypeAny, {
97
+ hash: string;
98
+ }, {
99
+ hash: string;
100
+ }>>;
101
+ google: import("zod").ZodOptional<import("zod").ZodObject<{
102
+ id: import("zod").ZodString;
103
+ }, "strip", import("zod").ZodTypeAny, {
104
+ id: string;
105
+ }, {
106
+ id: string;
107
+ }>>;
108
+ github: import("zod").ZodOptional<import("zod").ZodObject<{
109
+ id: import("zod").ZodString;
110
+ }, "strip", import("zod").ZodTypeAny, {
111
+ id: string;
112
+ }, {
113
+ id: string;
114
+ }>>;
115
+ }, "strip", import("zod").ZodTypeAny, {
116
+ password?: {
117
+ hash: string;
118
+ } | undefined;
119
+ google?: {
120
+ id: string;
121
+ } | undefined;
122
+ github?: {
123
+ id: string;
124
+ } | undefined;
125
+ }, {
126
+ password?: {
127
+ hash: string;
128
+ } | undefined;
129
+ google?: {
130
+ id: string;
131
+ } | undefined;
132
+ github?: {
133
+ id: string;
134
+ } | undefined;
135
+ }>;
136
+ }>, "handle" | "roles" | "status" | "createdAt" | "emails" | "disabledAt" | "deletedAt" | "authMethods"> & {
137
+ _id: import("bson").ObjectId;
138
+ }, ...args: any[]) => any>>;
139
+ export declare const dbDisposableEmailDomains: Store<{
140
+ domain: import("zod").ZodString;
141
+ addedAt: import("zod").ZodDate;
142
+ }, Record<string, (this: Pick<import("../types").InferDocumentType<{
143
+ domain: import("zod").ZodString;
144
+ addedAt: import("zod").ZodDate;
145
+ }>, "domain" | "addedAt"> & {
146
+ _id: import("bson").ObjectId;
147
+ }, ...args: any[]) => any>>;
148
+ export declare const emailVerificationTokensCollection: Store<{
149
+ userId: import("zod").ZodType<import("bson").ObjectId, import("zod").ZodTypeDef, import("bson").ObjectId>;
150
+ email: import("zod").ZodOptional<import("zod").ZodString>;
151
+ token: import("zod").ZodString;
152
+ createdAt: import("zod").ZodDate;
153
+ expiresAt: import("zod").ZodDate;
154
+ }, Record<string, (this: Pick<import("../types").InferDocumentType<{
155
+ userId: import("zod").ZodType<import("bson").ObjectId, import("zod").ZodTypeDef, import("bson").ObjectId>;
156
+ email: import("zod").ZodOptional<import("zod").ZodString>;
157
+ token: import("zod").ZodString;
158
+ createdAt: import("zod").ZodDate;
159
+ expiresAt: import("zod").ZodDate;
160
+ }>, "email" | "token" | "createdAt" | "expiresAt" | "userId"> & {
161
+ _id: import("bson").ObjectId;
162
+ }, ...args: any[]) => any>>;
163
+ export declare const resetPasswordTokensCollection: Store<{
164
+ userId: import("zod").ZodType<import("bson").ObjectId, import("zod").ZodTypeDef, import("bson").ObjectId>;
165
+ token: import("zod").ZodString;
166
+ createdAt: import("zod").ZodDate;
167
+ expiresAt: import("zod").ZodDate;
168
+ }, Record<string, (this: Pick<import("../types").InferDocumentType<{
169
+ userId: import("zod").ZodType<import("bson").ObjectId, import("zod").ZodTypeDef, import("bson").ObjectId>;
170
+ token: import("zod").ZodString;
171
+ createdAt: import("zod").ZodDate;
172
+ expiresAt: import("zod").ZodDate;
173
+ }>, "token" | "createdAt" | "expiresAt" | "userId"> & {
174
+ _id: import("bson").ObjectId;
175
+ }, ...args: any[]) => any>>;
176
+ //# sourceMappingURL=db.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"db.d.ts","sourceRoot":"","sources":["../../src/auth/db.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAEtC;;;;;;;;;;;;;GAaG;AACH,eAAO,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2BAoD1B,CAAC;AAEH,eAAO,MAAM,wBAAwB;;;;;;;;2BAWnC,CAAC;AAEH,eAAO,MAAM,iCAAiC;;;;;;;;;;;;;;2BAkB5C,CAAC;AAEH,eAAO,MAAM,6BAA6B;;;;;;;;;;;;2BAiBxC,CAAC"}
@@ -0,0 +1,117 @@
1
+ import { schema } from '../data/types';
2
+ import { Store } from '../data/store';
3
+ /**
4
+ * Database collection for storing user accounts with authentication methods and profile information.
5
+ *
6
+ * This is where **signupWithPassword** automatically creates new users.
7
+ *
8
+ * @example
9
+ * ```typescript
10
+ * // Find user by email
11
+ * const user = await dbUsers.findOne(
12
+ * { 'emails.address': 'john@example.com' }
13
+ * );
14
+ * ```
15
+ *
16
+ */
17
+ export const usersCollection = new Store('_modelenceUsers', {
18
+ schema: {
19
+ handle: schema.string(),
20
+ emails: schema
21
+ .array(schema.object({
22
+ address: schema.string(),
23
+ verified: schema.boolean(),
24
+ }))
25
+ .optional(),
26
+ status: schema.enum(['active', 'disabled', 'deleted']).optional(),
27
+ createdAt: schema.date(),
28
+ disabledAt: schema.date().optional(),
29
+ deletedAt: schema.date().optional(),
30
+ roles: schema.array(schema.string()).optional(),
31
+ authMethods: schema.object({
32
+ password: schema
33
+ .object({
34
+ hash: schema.string(),
35
+ })
36
+ .optional(),
37
+ google: schema
38
+ .object({
39
+ id: schema.string(),
40
+ })
41
+ .optional(),
42
+ github: schema
43
+ .object({
44
+ id: schema.string(),
45
+ })
46
+ .optional(),
47
+ }),
48
+ },
49
+ indexes: [
50
+ {
51
+ key: { handle: 1 },
52
+ unique: true,
53
+ collation: { locale: 'en', strength: 2 }, // Case-insensitive
54
+ },
55
+ {
56
+ key: { 'emails.address': 1, status: 1 },
57
+ },
58
+ {
59
+ key: { 'authMethods.google.id': 1, status: 1 },
60
+ sparse: true,
61
+ },
62
+ {
63
+ key: { 'authMethods.github.id': 1, status: 1 },
64
+ sparse: true,
65
+ },
66
+ ],
67
+ });
68
+ export const dbDisposableEmailDomains = new Store('_modelenceDisposableEmailDomains', {
69
+ schema: {
70
+ domain: schema.string(),
71
+ addedAt: schema.date(),
72
+ },
73
+ indexes: [
74
+ {
75
+ key: { domain: 1 },
76
+ unique: true,
77
+ },
78
+ ],
79
+ });
80
+ export const emailVerificationTokensCollection = new Store('_modelenceEmailVerificationTokens', {
81
+ schema: {
82
+ userId: schema.objectId(),
83
+ email: schema.string().optional(),
84
+ token: schema.string(),
85
+ createdAt: schema.date(),
86
+ expiresAt: schema.date(),
87
+ },
88
+ indexes: [
89
+ {
90
+ key: { token: 1 },
91
+ unique: true,
92
+ },
93
+ {
94
+ key: { expiresAt: 1 },
95
+ expireAfterSeconds: 0,
96
+ },
97
+ ],
98
+ });
99
+ export const resetPasswordTokensCollection = new Store('_modelenceResetPasswordTokens', {
100
+ schema: {
101
+ userId: schema.objectId(),
102
+ token: schema.string(),
103
+ createdAt: schema.date(),
104
+ expiresAt: schema.date(),
105
+ },
106
+ indexes: [
107
+ {
108
+ key: { token: 1 },
109
+ unique: true,
110
+ },
111
+ {
112
+ key: { expiresAt: 1 },
113
+ expireAfterSeconds: 0,
114
+ },
115
+ ],
116
+ });
117
+ //# sourceMappingURL=db.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"db.js","sourceRoot":"","sources":["../../src/auth/db.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import { ObjectId } from 'mongodb';
2
+ export declare function clearTokens(userId: ObjectId): Promise<void>;
3
+ export declare function disableUser(userId: ObjectId): Promise<void>;
4
+ export declare function deleteUser(userId: ObjectId): Promise<void>;
5
+ //# sourceMappingURL=deleteUser.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deleteUser.d.ts","sourceRoot":"","sources":["../../src/auth/deleteUser.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAQnC,wBAAsB,WAAW,CAAC,MAAM,EAAE,QAAQ,iBAQjD;AAED,wBAAsB,WAAW,CAAC,MAAM,EAAE,QAAQ,iBASjD;AAED,wBAAsB,UAAU,CAAC,MAAM,EAAE,QAAQ,iBAiBhD"}
@@ -0,0 +1,34 @@
1
+ import { randomUUID } from 'crypto';
2
+ import { usersCollection, emailVerificationTokensCollection, resetPasswordTokensCollection, } from './db';
3
+ export async function clearTokens(userId) {
4
+ await emailVerificationTokensCollection.deleteMany({
5
+ userId,
6
+ });
7
+ await resetPasswordTokensCollection.deleteMany({
8
+ userId,
9
+ });
10
+ }
11
+ export async function disableUser(userId) {
12
+ await clearTokens(userId);
13
+ await usersCollection.updateOne(userId, {
14
+ $set: {
15
+ status: 'disabled',
16
+ disabledAt: new Date(),
17
+ },
18
+ });
19
+ }
20
+ export async function deleteUser(userId) {
21
+ await clearTokens(userId);
22
+ await usersCollection.updateOne({
23
+ _id: userId,
24
+ }, {
25
+ $set: {
26
+ handle: `deleted-${userId}-${randomUUID()}`,
27
+ status: 'deleted',
28
+ deletedAt: new Date(),
29
+ authMethods: {},
30
+ emails: [],
31
+ },
32
+ });
33
+ }
34
+ //# sourceMappingURL=deleteUser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deleteUser.js","sourceRoot":"","sources":["../../src/auth/deleteUser.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AACpC,OAAO,EACL,eAAe,EACf,iCAAiC,EACjC,6BAA6B,GAC9B,MAAM,MAAM,CAAC;AAEd,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,MAAgB;IAChD,MAAM,iCAAiC,CAAC,UAAU,CAAC;QACjD,MAAM;KACP,CAAC,CAAC;IAEH,MAAM,6BAA6B,CAAC,UAAU,CAAC;QAC7C,MAAM;KACP,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,MAAgB;IAChD,MAAM,WAAW,CAAC,MAAM,CAAC,CAAC;IAE1B,MAAM,eAAe,CAAC,SAAS,CAAC,MAAM,EAAE;QACtC,IAAI,EAAE;YACJ,MAAM,EAAE,UAAU;YAClB,UAAU,EAAE,IAAI,IAAI,EAAE;SACvB;KACF,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,MAAgB;IAC/C,MAAM,WAAW,CAAC,MAAM,CAAC,CAAC;IAE1B,MAAM,eAAe,CAAC,SAAS,CAC7B;QACE,GAAG,EAAE,MAAM;KACZ,EACD;QACE,IAAI,EAAE;YACJ,MAAM,EAAE,WAAW,MAAM,IAAI,UAAU,EAAE,EAAE;YAC3C,MAAM,EAAE,SAAS;YACjB,SAAS,EAAE,IAAI,IAAI,EAAE;YACrB,WAAW,EAAE,EAAE;YACf,MAAM,EAAE,EAAE;SACX;KACF,CACF,CAAC;AACJ,CAAC"}
@@ -0,0 +1,6 @@
1
+ export declare function isDisposableEmail(email: string): Promise<boolean>;
2
+ export declare const updateDisposableEmailListCron: {
3
+ interval: number;
4
+ handler(): Promise<void>;
5
+ };
6
+ //# sourceMappingURL=disposableEmails.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"disposableEmails.d.ts","sourceRoot":"","sources":["../../src/auth/disposableEmails.ts"],"names":[],"mappings":"AAGA,wBAAsB,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CASvE;AAED,eAAO,MAAM,6BAA6B;;;CA6CzC,CAAC"}
@@ -0,0 +1,47 @@
1
+ import { time } from '../time';
2
+ import { dbDisposableEmailDomains } from './db';
3
+ export async function isDisposableEmail(email) {
4
+ const emailParts = email.toLowerCase().trim().split('@');
5
+ if (emailParts.length !== 2) {
6
+ return false;
7
+ }
8
+ const domain = emailParts[1];
9
+ const result = await dbDisposableEmailDomains.findOne({ domain });
10
+ return Boolean(result);
11
+ }
12
+ export const updateDisposableEmailListCron = {
13
+ interval: time.days(1),
14
+ async handler() {
15
+ const response = await fetch('https://disposable.github.io/disposable-email-domains/domains.txt');
16
+ if (!response.ok) {
17
+ throw new Error(`HTTP ${response.status}: ${response.statusText}`);
18
+ }
19
+ const domainsText = await response.text();
20
+ const domains = domainsText
21
+ .split('\n')
22
+ .map((domain) => domain.trim().toLowerCase())
23
+ .filter((domain) => domain.length > 0);
24
+ const now = new Date();
25
+ // Insert domains in batches to avoid overwhelming the database
26
+ const batchSize = 500;
27
+ for (let i = 0; i < domains.length; i += batchSize) {
28
+ const batch = domains.slice(i, i + batchSize);
29
+ try {
30
+ await dbDisposableEmailDomains.insertMany(batch.map((domain) => ({
31
+ domain,
32
+ addedAt: now,
33
+ })));
34
+ }
35
+ catch (error) {
36
+ // MongoDB throws BulkWriteError when some documents are duplicates
37
+ if (error &&
38
+ typeof error === 'object' &&
39
+ 'name' in error &&
40
+ error.name === 'MongoBulkWriteError') {
41
+ // console.warn(`Error inserting batch starting at index ${i}:`, error.message);
42
+ }
43
+ }
44
+ }
45
+ },
46
+ };
47
+ //# sourceMappingURL=disposableEmails.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"disposableEmails.js","sourceRoot":"","sources":["../../src/auth/disposableEmails.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,SAAS,CAAC;AAC/B,OAAO,EAAE,wBAAwB,EAAE,MAAM,MAAM,CAAC;AAEhD,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,KAAa;IACnD,MAAM,UAAU,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACzD,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC5B,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;IAC7B,MAAM,MAAM,GAAG,MAAM,wBAAwB,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IAClE,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC;AACzB,CAAC;AAED,MAAM,CAAC,MAAM,6BAA6B,GAAG;IAC3C,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACtB,KAAK,CAAC,OAAO;QACX,MAAM,QAAQ,GAAG,MAAM,KAAK,CAC1B,mEAAmE,CACpE,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,QAAQ,QAAQ,CAAC,MAAM,KAAK,QAAQ,CAAC,UAAU,EAAE,CAAC,CAAC;QACrE,CAAC;QAED,MAAM,WAAW,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;QAE1C,MAAM,OAAO,GAAG,WAAW;aACxB,KAAK,CAAC,IAAI,CAAC;aACX,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;aAC5C,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAEzC,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;QAEvB,+DAA+D;QAC/D,MAAM,SAAS,GAAG,GAAG,CAAC;QACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,IAAI,SAAS,EAAE,CAAC;YACnD,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,CAAC;YAE9C,IAAI,CAAC;gBACH,MAAM,wBAAwB,CAAC,UAAU,CACvC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;oBACrB,MAAM;oBACN,OAAO,EAAE,GAAG;iBACb,CAAC,CAAC,CACJ,CAAC;YACJ,CAAC;YAAC,OAAO,KAAc,EAAE,CAAC;gBACxB,mEAAmE;gBACnE,IACE,KAAK;oBACL,OAAO,KAAK,KAAK,QAAQ;oBACzB,MAAM,IAAI,KAAK;oBACf,KAAK,CAAC,IAAI,KAAK,qBAAqB,EACpC,CAAC;oBACD,gFAAgF;gBAClF,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;CACF,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { Role, Session, UserInfo } from './types';
2
+ export declare function authenticate(authToken: string | null): Promise<{
3
+ session: Session;
4
+ user: UserInfo | null;
5
+ roles: Role[];
6
+ }>;
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/auth/index.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAElD,wBAAsB,YAAY,CAChC,SAAS,EAAE,MAAM,GAAG,IAAI,GACvB,OAAO,CAAC;IAAE,OAAO,EAAE,OAAO,CAAC;IAAC,IAAI,EAAE,QAAQ,GAAG,IAAI,CAAC;IAAC,KAAK,EAAE,IAAI,EAAE,CAAA;CAAE,CAAC,CA8BrE"}
@@ -0,0 +1,33 @@
1
+ import { ObjectId } from 'mongodb';
2
+ import { obtainSession } from './session';
3
+ import { usersCollection } from './db';
4
+ import { getDefaultAuthenticatedRoles, getUnauthenticatedRoles } from './role';
5
+ export async function authenticate(authToken) {
6
+ const session = await obtainSession(authToken);
7
+ const userDoc = session.userId
8
+ ? await usersCollection.findOne({
9
+ _id: new ObjectId(session.userId),
10
+ status: { $nin: ['deleted', 'disabled'] },
11
+ })
12
+ : null;
13
+ const user = userDoc
14
+ ? {
15
+ id: userDoc._id.toString(),
16
+ handle: userDoc.handle,
17
+ roles: userDoc.roles || [],
18
+ hasRole: (role) => (userDoc.roles || []).includes(role),
19
+ requireRole: (role) => {
20
+ if (!(userDoc.roles || []).includes(role)) {
21
+ throw new Error(`Access denied - role '${role}' required`);
22
+ }
23
+ },
24
+ }
25
+ : null;
26
+ const roles = user ? getDefaultAuthenticatedRoles() : getUnauthenticatedRoles();
27
+ return {
28
+ user,
29
+ session,
30
+ roles,
31
+ };
32
+ }
33
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;AACvC,OAAO,EAAE,4BAA4B,EAAE,uBAAuB,EAAE,MAAM,QAAQ,CAAC;AAG/E,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,SAAwB;IAExB,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,SAAS,CAAC,CAAC;IAE/C,MAAM,OAAO,GAAG,OAAO,CAAC,MAAM;QAC5B,CAAC,CAAC,MAAM,eAAe,CAAC,OAAO,CAAC;YAC5B,GAAG,EAAE,IAAI,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC;YACjC,MAAM,EAAE,EAAE,IAAI,EAAE,CAAC,SAAS,EAAE,UAAU,CAAC,EAAE;SAC1C,CAAC;QACJ,CAAC,CAAC,IAAI,CAAC;IACT,MAAM,IAAI,GAAG,OAAO;QAClB,CAAC,CAAC;YACE,EAAE,EAAE,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE;YAC1B,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,KAAK,EAAE,OAAO,CAAC,KAAK,IAAI,EAAE;YAC1B,OAAO,EAAE,CAAC,IAAY,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC;YAC/D,WAAW,EAAE,CAAC,IAAY,EAAE,EAAE;gBAC5B,IAAI,CAAC,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;oBAC1C,MAAM,IAAI,KAAK,CAAC,yBAAyB,IAAI,YAAY,CAAC,CAAC;gBAC7D,CAAC;YACH,CAAC;SACF;QACH,CAAC,CAAC,IAAI,CAAC;IAET,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,4BAA4B,EAAE,CAAC,CAAC,CAAC,uBAAuB,EAAE,CAAC;IAEhF,OAAO;QACL,IAAI;QACJ,OAAO;QACP,KAAK;KACN,CAAC;AACJ,CAAC"}
@@ -0,0 +1,9 @@
1
+ import { Args, Context } from '../methods/types';
2
+ export declare function handleLoginWithPassword(args: Args, { user, session, connectionInfo }: Context): Promise<{
3
+ user: {
4
+ id: import("bson").ObjectId;
5
+ handle: string;
6
+ };
7
+ }>;
8
+ export declare function handleLogout(args: Args, { session }: Context): Promise<void>;
9
+ //# sourceMappingURL=login.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"login.d.ts","sourceRoot":"","sources":["../../src/auth/login.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAUjD,wBAAsB,uBAAuB,CAC3C,IAAI,EAAE,IAAI,EACV,EAAE,IAAI,EAAE,OAAO,EAAE,cAAc,EAAE,EAAE,OAAO;;;;;GA8F3C;AAED,wBAAsB,YAAY,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,iBAMlE"}