@studious-lms/server 1.2.52 → 1.3.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 (480) hide show
  1. package/.coderabbit.yaml +9 -0
  2. package/.env.example +9 -1
  3. package/dist/index.d.ts.map +1 -1
  4. package/dist/index.js +102 -8
  5. package/dist/index.js.map +1 -1
  6. package/dist/lib/config/env.d.ts +21 -0
  7. package/dist/lib/config/env.d.ts.map +1 -1
  8. package/dist/lib/config/env.js +8 -2
  9. package/dist/lib/config/env.js.map +1 -1
  10. package/dist/lib/fileUpload.d.ts.map +1 -1
  11. package/dist/lib/fileUpload.js +2 -2
  12. package/dist/lib/fileUpload.js.map +1 -1
  13. package/dist/lib/googleCloudStorage.d.ts +6 -0
  14. package/dist/lib/googleCloudStorage.d.ts.map +1 -1
  15. package/dist/lib/googleCloudStorage.js +19 -2
  16. package/dist/lib/googleCloudStorage.js.map +1 -1
  17. package/dist/lib/pusher.d.ts +4 -1
  18. package/dist/lib/pusher.d.ts.map +1 -1
  19. package/dist/lib/pusher.js +6 -3
  20. package/dist/lib/pusher.js.map +1 -1
  21. package/dist/lib/redis.d.ts +5 -0
  22. package/dist/lib/redis.d.ts.map +1 -0
  23. package/dist/lib/redis.js +53 -0
  24. package/dist/lib/redis.js.map +1 -0
  25. package/dist/lib/thumbnailGenerator.d.ts +0 -21
  26. package/dist/lib/thumbnailGenerator.d.ts.map +1 -1
  27. package/dist/lib/thumbnailGenerator.js +157 -160
  28. package/dist/lib/thumbnailGenerator.js.map +1 -1
  29. package/dist/middleware/auth.d.ts.map +1 -1
  30. package/dist/middleware/auth.js +36 -94
  31. package/dist/middleware/auth.js.map +1 -1
  32. package/dist/models/agenda.d.ts +97 -0
  33. package/dist/models/agenda.d.ts.map +1 -0
  34. package/dist/models/agenda.js +40 -0
  35. package/dist/models/agenda.js.map +1 -0
  36. package/dist/models/announcement.d.ts +223 -0
  37. package/dist/models/announcement.d.ts.map +1 -0
  38. package/dist/models/announcement.js +120 -0
  39. package/dist/models/announcement.js.map +1 -0
  40. package/dist/models/assignment.d.ts +1292 -0
  41. package/dist/models/assignment.d.ts.map +1 -0
  42. package/dist/models/assignment.js +309 -0
  43. package/dist/models/assignment.js.map +1 -0
  44. package/dist/models/attendance.d.ts +180 -0
  45. package/dist/models/attendance.d.ts.map +1 -0
  46. package/dist/models/attendance.js +188 -0
  47. package/dist/models/attendance.js.map +1 -0
  48. package/dist/models/auth.d.ts +153 -0
  49. package/dist/models/auth.d.ts.map +1 -0
  50. package/dist/models/auth.js +217 -0
  51. package/dist/models/auth.js.map +1 -0
  52. package/dist/models/class.d.ts +439 -0
  53. package/dist/models/class.d.ts.map +1 -0
  54. package/dist/models/class.js +546 -0
  55. package/dist/models/class.js.map +1 -0
  56. package/dist/models/comment.d.ts +171 -0
  57. package/dist/models/comment.d.ts.map +1 -0
  58. package/dist/models/comment.js +138 -0
  59. package/dist/models/comment.js.map +1 -0
  60. package/dist/models/conversation.d.ts +164 -0
  61. package/dist/models/conversation.d.ts.map +1 -0
  62. package/dist/models/conversation.js +175 -0
  63. package/dist/models/conversation.js.map +1 -0
  64. package/dist/models/event.d.ts +295 -0
  65. package/dist/models/event.d.ts.map +1 -0
  66. package/dist/models/event.js +145 -0
  67. package/dist/models/event.js.map +1 -0
  68. package/dist/models/file.d.ts +536 -0
  69. package/dist/models/file.d.ts.map +1 -0
  70. package/dist/models/file.js +126 -0
  71. package/dist/models/file.js.map +1 -0
  72. package/dist/models/folder.d.ts +295 -0
  73. package/dist/models/folder.d.ts.map +1 -0
  74. package/dist/models/folder.js +202 -0
  75. package/dist/models/folder.js.map +1 -0
  76. package/dist/models/labChat.d.ts +243 -0
  77. package/dist/models/labChat.d.ts.map +1 -0
  78. package/dist/models/labChat.js +204 -0
  79. package/dist/models/labChat.js.map +1 -0
  80. package/dist/models/marketing.d.ts +72 -0
  81. package/dist/models/marketing.d.ts.map +1 -0
  82. package/dist/models/marketing.js +26 -0
  83. package/dist/models/marketing.js.map +1 -0
  84. package/dist/models/message.d.ts +100 -0
  85. package/dist/models/message.d.ts.map +1 -0
  86. package/dist/models/message.js +131 -0
  87. package/dist/models/message.js.map +1 -0
  88. package/dist/models/newtonChat.d.ts +72 -0
  89. package/dist/models/newtonChat.d.ts.map +1 -0
  90. package/dist/models/newtonChat.js +61 -0
  91. package/dist/models/newtonChat.js.map +1 -0
  92. package/dist/models/notification.d.ts +65 -0
  93. package/dist/models/notification.d.ts.map +1 -0
  94. package/dist/models/notification.js +46 -0
  95. package/dist/models/notification.js.map +1 -0
  96. package/dist/models/section.d.ts +102 -0
  97. package/dist/models/section.d.ts.map +1 -0
  98. package/dist/models/section.js +83 -0
  99. package/dist/models/section.js.map +1 -0
  100. package/dist/models/user.d.ts +39 -0
  101. package/dist/models/user.d.ts.map +1 -0
  102. package/dist/models/user.js +38 -0
  103. package/dist/models/user.js.map +1 -0
  104. package/dist/models/worksheet.d.ts +460 -0
  105. package/dist/models/worksheet.d.ts.map +1 -0
  106. package/dist/models/worksheet.js +200 -0
  107. package/dist/models/worksheet.js.map +1 -0
  108. package/dist/pipelines/aiLabChat.d.ts +21 -0
  109. package/dist/pipelines/aiLabChat.d.ts.map +1 -0
  110. package/dist/pipelines/aiLabChat.js +460 -0
  111. package/dist/pipelines/aiLabChat.js.map +1 -0
  112. package/dist/pipelines/aiNewtonChat.d.ts +30 -0
  113. package/dist/pipelines/aiNewtonChat.d.ts.map +1 -0
  114. package/dist/pipelines/aiNewtonChat.js +289 -0
  115. package/dist/pipelines/aiNewtonChat.js.map +1 -0
  116. package/dist/pipelines/gradeWorksheet.d.ts +30 -0
  117. package/dist/pipelines/gradeWorksheet.d.ts.map +1 -0
  118. package/dist/pipelines/gradeWorksheet.js +252 -0
  119. package/dist/pipelines/gradeWorksheet.js.map +1 -0
  120. package/dist/routers/_app.d.ts +1399 -1271
  121. package/dist/routers/_app.d.ts.map +1 -1
  122. package/dist/routers/agenda.d.ts +22 -22
  123. package/dist/routers/agenda.d.ts.map +1 -1
  124. package/dist/routers/agenda.js +4 -65
  125. package/dist/routers/agenda.js.map +1 -1
  126. package/dist/routers/announcement.d.ts +16 -16
  127. package/dist/routers/announcement.d.ts.map +1 -1
  128. package/dist/routers/announcement.js +37 -446
  129. package/dist/routers/announcement.js.map +1 -1
  130. package/dist/routers/assignment.d.ts +300 -378
  131. package/dist/routers/assignment.d.ts.map +1 -1
  132. package/dist/routers/assignment.js +78 -1868
  133. package/dist/routers/assignment.js.map +1 -1
  134. package/dist/routers/attendance.d.ts +19 -9
  135. package/dist/routers/attendance.d.ts.map +1 -1
  136. package/dist/routers/attendance.js +7 -264
  137. package/dist/routers/attendance.js.map +1 -1
  138. package/dist/routers/auth.d.ts +2 -2
  139. package/dist/routers/auth.d.ts.map +1 -1
  140. package/dist/routers/auth.js +29 -354
  141. package/dist/routers/auth.js.map +1 -1
  142. package/dist/routers/class.d.ts +140 -68
  143. package/dist/routers/class.d.ts.map +1 -1
  144. package/dist/routers/class.js +82 -1051
  145. package/dist/routers/class.js.map +1 -1
  146. package/dist/routers/comment.d.ts +6 -42
  147. package/dist/routers/comment.d.ts.map +1 -1
  148. package/dist/routers/comment.js +24 -244
  149. package/dist/routers/comment.js.map +1 -1
  150. package/dist/routers/conversation.d.ts +45 -7
  151. package/dist/routers/conversation.d.ts.map +1 -1
  152. package/dist/routers/conversation.js +19 -327
  153. package/dist/routers/conversation.js.map +1 -1
  154. package/dist/routers/event.d.ts +36 -36
  155. package/dist/routers/event.d.ts.map +1 -1
  156. package/dist/routers/event.js +13 -433
  157. package/dist/routers/event.js.map +1 -1
  158. package/dist/routers/file.d.ts +2 -2
  159. package/dist/routers/file.d.ts.map +1 -1
  160. package/dist/routers/file.js +9 -323
  161. package/dist/routers/file.js.map +1 -1
  162. package/dist/routers/folder.d.ts +21 -14
  163. package/dist/routers/folder.d.ts.map +1 -1
  164. package/dist/routers/folder.js +34 -745
  165. package/dist/routers/folder.js.map +1 -1
  166. package/dist/routers/labChat.d.ts +11 -10
  167. package/dist/routers/labChat.d.ts.map +1 -1
  168. package/dist/routers/labChat.js +19 -570
  169. package/dist/routers/labChat.js.map +1 -1
  170. package/dist/routers/marketing.d.ts +1 -1
  171. package/dist/routers/marketing.d.ts.map +1 -1
  172. package/dist/routers/marketing.js +7 -56
  173. package/dist/routers/marketing.js.map +1 -1
  174. package/dist/routers/message.d.ts +2 -2
  175. package/dist/routers/message.d.ts.map +1 -1
  176. package/dist/routers/message.js +27 -522
  177. package/dist/routers/message.js.map +1 -1
  178. package/dist/routers/newtonChat.d.ts +1 -1
  179. package/dist/routers/newtonChat.d.ts.map +1 -1
  180. package/dist/routers/newtonChat.js +7 -246
  181. package/dist/routers/newtonChat.js.map +1 -1
  182. package/dist/routers/notifications.d.ts +4 -4
  183. package/dist/routers/notifications.d.ts.map +1 -1
  184. package/dist/routers/notifications.js +18 -83
  185. package/dist/routers/notifications.js.map +1 -1
  186. package/dist/routers/section.d.ts +4 -4
  187. package/dist/routers/section.d.ts.map +1 -1
  188. package/dist/routers/section.js +14 -286
  189. package/dist/routers/section.js.map +1 -1
  190. package/dist/routers/user.d.ts +1 -1
  191. package/dist/routers/user.d.ts.map +1 -1
  192. package/dist/routers/user.js +32 -207
  193. package/dist/routers/user.js.map +1 -1
  194. package/dist/routers/worksheet.d.ts +51 -38
  195. package/dist/routers/worksheet.d.ts.map +1 -1
  196. package/dist/routers/worksheet.js +79 -394
  197. package/dist/routers/worksheet.js.map +1 -1
  198. package/dist/seedDatabase.d.ts +1 -1
  199. package/dist/server/pipelines/aiNewtonChat.d.ts.map +1 -1
  200. package/dist/server/pipelines/aiNewtonChat.js +8 -3
  201. package/dist/server/pipelines/aiNewtonChat.js.map +1 -1
  202. package/dist/server/pipelines/gradeWorksheet.d.ts +6 -6
  203. package/dist/server/pipelines/gradeWorksheet.d.ts.map +1 -1
  204. package/dist/server/pipelines/gradeWorksheet.js +12 -5
  205. package/dist/server/pipelines/gradeWorksheet.js.map +1 -1
  206. package/dist/services/agenda.d.ts +100 -0
  207. package/dist/services/agenda.d.ts.map +1 -0
  208. package/dist/services/agenda.js +21 -0
  209. package/dist/services/agenda.js.map +1 -0
  210. package/dist/services/announcement.d.ts +135 -0
  211. package/dist/services/announcement.d.ts.map +1 -0
  212. package/dist/services/announcement.js +223 -0
  213. package/dist/services/announcement.js.map +1 -0
  214. package/dist/services/assignment.d.ts +1462 -0
  215. package/dist/services/assignment.d.ts.map +1 -0
  216. package/dist/services/assignment.js +898 -0
  217. package/dist/services/assignment.js.map +1 -0
  218. package/dist/services/attendance.d.ts +93 -0
  219. package/dist/services/attendance.d.ts.map +1 -0
  220. package/dist/services/attendance.js +61 -0
  221. package/dist/services/attendance.js.map +1 -0
  222. package/dist/services/auth.d.ts +68 -0
  223. package/dist/services/auth.d.ts.map +1 -0
  224. package/dist/services/auth.js +218 -0
  225. package/dist/services/auth.js.map +1 -0
  226. package/dist/services/class.d.ts +621 -0
  227. package/dist/services/class.d.ts.map +1 -0
  228. package/dist/services/class.js +474 -0
  229. package/dist/services/class.js.map +1 -0
  230. package/dist/services/comment.d.ts +100 -0
  231. package/dist/services/comment.d.ts.map +1 -0
  232. package/dist/services/comment.js +83 -0
  233. package/dist/services/comment.js.map +1 -0
  234. package/dist/services/conversation.d.ts +159 -0
  235. package/dist/services/conversation.d.ts.map +1 -0
  236. package/dist/services/conversation.js +138 -0
  237. package/dist/services/conversation.js.map +1 -0
  238. package/dist/services/event.d.ts +216 -0
  239. package/dist/services/event.d.ts.map +1 -0
  240. package/dist/services/event.js +168 -0
  241. package/dist/services/event.js.map +1 -0
  242. package/dist/services/file.d.ts +74 -0
  243. package/dist/services/file.d.ts.map +1 -0
  244. package/dist/services/file.js +133 -0
  245. package/dist/services/file.js.map +1 -0
  246. package/dist/services/folder.d.ts +239 -0
  247. package/dist/services/folder.d.ts.map +1 -0
  248. package/dist/services/folder.js +248 -0
  249. package/dist/services/folder.js.map +1 -0
  250. package/dist/services/labChat.d.ts +165 -0
  251. package/dist/services/labChat.d.ts.map +1 -0
  252. package/dist/services/labChat.js +289 -0
  253. package/dist/services/labChat.js.map +1 -0
  254. package/dist/services/marketing.d.ts +50 -0
  255. package/dist/services/marketing.d.ts.map +1 -0
  256. package/dist/services/marketing.js +32 -0
  257. package/dist/services/marketing.js.map +1 -0
  258. package/dist/services/message.d.ts +95 -0
  259. package/dist/services/message.d.ts.map +1 -0
  260. package/dist/services/message.js +350 -0
  261. package/dist/services/message.js.map +1 -0
  262. package/dist/services/newtonChat.d.ts +22 -0
  263. package/dist/services/newtonChat.d.ts.map +1 -0
  264. package/dist/services/newtonChat.js +174 -0
  265. package/dist/services/newtonChat.js.map +1 -0
  266. package/dist/services/notification.d.ts +65 -0
  267. package/dist/services/notification.d.ts.map +1 -0
  268. package/dist/services/notification.js +33 -0
  269. package/dist/services/notification.js.map +1 -0
  270. package/dist/services/section.d.ts +53 -0
  271. package/dist/services/section.d.ts.map +1 -0
  272. package/dist/services/section.js +199 -0
  273. package/dist/services/section.js.map +1 -0
  274. package/dist/services/user.d.ts +48 -0
  275. package/dist/services/user.d.ts.map +1 -0
  276. package/dist/services/user.js +141 -0
  277. package/dist/services/user.js.map +1 -0
  278. package/dist/services/worksheet.d.ts +239 -0
  279. package/dist/services/worksheet.d.ts.map +1 -0
  280. package/dist/services/worksheet.js +235 -0
  281. package/dist/services/worksheet.js.map +1 -0
  282. package/dist/utils/aiUser.d.ts +1 -3
  283. package/dist/utils/aiUser.d.ts.map +1 -1
  284. package/dist/utils/aiUser.js +6 -5
  285. package/dist/utils/aiUser.js.map +1 -1
  286. package/dist/utils/email.d.ts +3 -0
  287. package/dist/utils/email.d.ts.map +1 -1
  288. package/dist/utils/email.js +7 -4
  289. package/dist/utils/email.js.map +1 -1
  290. package/dist/utils/generateInviteCode.d.ts +1 -2
  291. package/dist/utils/generateInviteCode.d.ts.map +1 -1
  292. package/dist/utils/generateInviteCode.js +3 -4
  293. package/dist/utils/generateInviteCode.js.map +1 -1
  294. package/dist/utils/inference.d.ts +3 -0
  295. package/dist/utils/inference.d.ts.map +1 -1
  296. package/dist/utils/inference.js +7 -4
  297. package/dist/utils/inference.js.map +1 -1
  298. package/dist/utils/logger.d.ts +3 -0
  299. package/dist/utils/logger.d.ts.map +1 -1
  300. package/dist/utils/logger.js +5 -2
  301. package/dist/utils/logger.js.map +1 -1
  302. package/dist/utils/prismaErrorHandler.d.ts.map +1 -1
  303. package/dist/utils/prismaErrorHandler.js +5 -2
  304. package/dist/utils/prismaErrorHandler.js.map +1 -1
  305. package/dist/utils/prismaWrapper.d.ts +1 -0
  306. package/dist/utils/prismaWrapper.d.ts.map +1 -1
  307. package/dist/utils/prismaWrapper.js +6 -2
  308. package/dist/utils/prismaWrapper.js.map +1 -1
  309. package/docker-compose.yml +5 -0
  310. package/package.json +4 -3
  311. package/src/index.ts +119 -12
  312. package/src/lib/config/env.ts +6 -0
  313. package/src/lib/fileUpload.ts +0 -1
  314. package/src/lib/googleCloudStorage.ts +17 -0
  315. package/src/lib/pusher.ts +5 -1
  316. package/src/lib/redis.ts +56 -0
  317. package/src/lib/thumbnailGenerator.ts +170 -168
  318. package/src/middleware/auth.ts +83 -136
  319. package/src/models/agenda.ts +46 -0
  320. package/src/models/announcement.ts +134 -0
  321. package/src/models/assignment.ts +322 -0
  322. package/src/models/attendance.ts +208 -0
  323. package/src/models/auth.ts +247 -0
  324. package/src/models/class.ts +598 -0
  325. package/src/models/comment.ts +152 -0
  326. package/src/models/conversation.ts +200 -0
  327. package/src/models/event.ts +177 -0
  328. package/src/models/file.ts +129 -0
  329. package/src/models/folder.ts +225 -0
  330. package/src/models/labChat.ts +213 -0
  331. package/src/models/marketing.ts +45 -0
  332. package/src/models/message.ts +153 -0
  333. package/src/models/newtonChat.ts +70 -0
  334. package/src/models/notification.ts +54 -0
  335. package/src/models/section.ts +98 -0
  336. package/src/models/user.ts +47 -0
  337. package/src/models/worksheet.ts +294 -0
  338. package/src/{server/pipelines → pipelines}/aiLabChat.ts +11 -7
  339. package/src/{server/pipelines → pipelines}/aiNewtonChat.ts +15 -6
  340. package/src/{server/pipelines → pipelines}/gradeWorksheet.ts +25 -14
  341. package/src/routers/agenda.ts +3 -66
  342. package/src/routers/announcement.ts +54 -495
  343. package/src/routers/assignment.ts +126 -2018
  344. package/src/routers/attendance.ts +15 -276
  345. package/src/routers/auth.ts +79 -442
  346. package/src/routers/class.ts +263 -1186
  347. package/src/routers/comment.ts +61 -288
  348. package/src/routers/conversation.ts +51 -360
  349. package/src/routers/event.ts +50 -481
  350. package/src/routers/file.ts +45 -368
  351. package/src/routers/folder.ts +107 -836
  352. package/src/routers/labChat.ts +29 -605
  353. package/src/routers/marketing.ts +35 -77
  354. package/src/routers/message.ts +45 -571
  355. package/src/routers/newtonChat.ts +17 -278
  356. package/src/routers/notifications.ts +32 -82
  357. package/src/routers/section.ts +46 -330
  358. package/src/routers/user.ts +49 -227
  359. package/src/routers/worksheet.ts +215 -503
  360. package/src/services/agenda.ts +21 -0
  361. package/src/services/announcement.ts +290 -0
  362. package/src/services/assignment.ts +1198 -0
  363. package/src/services/attendance.ts +85 -0
  364. package/src/services/auth.ts +277 -0
  365. package/src/services/class.ts +622 -0
  366. package/src/services/comment.ts +106 -0
  367. package/src/services/conversation.ts +213 -0
  368. package/src/services/event.ts +231 -0
  369. package/src/services/file.ts +167 -0
  370. package/src/services/folder.ts +316 -0
  371. package/src/services/labChat.ts +352 -0
  372. package/src/services/marketing.ts +57 -0
  373. package/src/services/message.ts +461 -0
  374. package/src/services/newtonChat.ts +222 -0
  375. package/src/services/notification.ts +50 -0
  376. package/src/services/section.ts +283 -0
  377. package/src/services/user.ts +172 -0
  378. package/src/services/worksheet.ts +358 -0
  379. package/src/utils/aiUser.ts +4 -3
  380. package/src/utils/email.ts +5 -3
  381. package/src/utils/generateInviteCode.ts +1 -3
  382. package/src/utils/inference.ts +5 -2
  383. package/src/utils/logger.ts +3 -1
  384. package/src/utils/prismaErrorHandler.ts +3 -0
  385. package/src/utils/prismaWrapper.ts +4 -0
  386. package/tests/globalSetup.ts +62 -0
  387. package/tests/helpers.ts +22 -0
  388. package/tests/middleware/security.test.ts +42 -0
  389. package/tests/routers/agenda.test.ts +138 -0
  390. package/tests/routers/announcement.test.ts +490 -0
  391. package/tests/routers/assignment.test.ts +837 -0
  392. package/tests/{attendance.test.ts → routers/attendance.test.ts} +6 -14
  393. package/tests/routers/auth.test.ts +171 -0
  394. package/tests/{class.test.ts → routers/class.test.ts} +131 -85
  395. package/tests/routers/comment.test.ts +126 -0
  396. package/tests/routers/conversation.test.ts +145 -0
  397. package/tests/{event.test.ts → routers/event.test.ts} +93 -32
  398. package/tests/routers/folder.test.ts +178 -0
  399. package/tests/routers/labChat.test.ts +115 -0
  400. package/tests/routers/marketing.test.ts +59 -0
  401. package/tests/routers/message.test.ts +123 -0
  402. package/tests/routers/notification.test.ts +69 -0
  403. package/tests/{section.test.ts → routers/section.test.ts} +5 -13
  404. package/tests/server/rateLimit.test.ts +73 -0
  405. package/tests/setup.ts +18 -92
  406. package/tests/user.test.ts +9 -31
  407. package/tests/utils/aiUser.test.ts +22 -0
  408. package/tests/utils/generateInviteCode.test.ts +24 -0
  409. package/tests/utils/logger.test.ts +74 -0
  410. package/tests/utils/prismaErrorHandler.test.ts +101 -0
  411. package/tests/utils/prismaWrapper.test.ts +82 -0
  412. package/tests/worksheet.test.ts +181 -0
  413. package/vitest.config.ts +6 -3
  414. package/vitest.unit.config.ts +21 -0
  415. package/TODO.md +0 -2
  416. package/coverage/base.css +0 -224
  417. package/coverage/block-navigation.js +0 -87
  418. package/coverage/clover.xml +0 -12110
  419. package/coverage/coverage-final.json +0 -44
  420. package/coverage/favicon.png +0 -0
  421. package/coverage/index.html +0 -221
  422. package/coverage/prettify.css +0 -1
  423. package/coverage/prettify.js +0 -2
  424. package/coverage/server/index.html +0 -116
  425. package/coverage/server/src/exportType.ts.html +0 -109
  426. package/coverage/server/src/index.html +0 -161
  427. package/coverage/server/src/index.ts.html +0 -1702
  428. package/coverage/server/src/instrument.ts.html +0 -130
  429. package/coverage/server/src/lib/config/env.ts.html +0 -448
  430. package/coverage/server/src/lib/config/index.html +0 -116
  431. package/coverage/server/src/lib/fileUpload.ts.html +0 -1138
  432. package/coverage/server/src/lib/googleCloudStorage.ts.html +0 -334
  433. package/coverage/server/src/lib/index.html +0 -206
  434. package/coverage/server/src/lib/jsonConversion.ts.html +0 -2323
  435. package/coverage/server/src/lib/jsonStyles.ts.html +0 -193
  436. package/coverage/server/src/lib/notificationHandler.ts.html +0 -193
  437. package/coverage/server/src/lib/pusher.ts.html +0 -121
  438. package/coverage/server/src/lib/thumbnailGenerator.ts.html +0 -592
  439. package/coverage/server/src/middleware/auth.ts.html +0 -646
  440. package/coverage/server/src/middleware/index.html +0 -146
  441. package/coverage/server/src/middleware/logging.ts.html +0 -244
  442. package/coverage/server/src/middleware/security.ts.html +0 -271
  443. package/coverage/server/src/routers/_app.ts.html +0 -232
  444. package/coverage/server/src/routers/agenda.ts.html +0 -319
  445. package/coverage/server/src/routers/announcement.ts.html +0 -3481
  446. package/coverage/server/src/routers/assignment.ts.html +0 -7633
  447. package/coverage/server/src/routers/attendance.ts.html +0 -1030
  448. package/coverage/server/src/routers/auth.ts.html +0 -1081
  449. package/coverage/server/src/routers/class.ts.html +0 -3535
  450. package/coverage/server/src/routers/comment.ts.html +0 -991
  451. package/coverage/server/src/routers/conversation.ts.html +0 -982
  452. package/coverage/server/src/routers/event.ts.html +0 -1609
  453. package/coverage/server/src/routers/file.ts.html +0 -1144
  454. package/coverage/server/src/routers/folder.ts.html +0 -2797
  455. package/coverage/server/src/routers/index.html +0 -386
  456. package/coverage/server/src/routers/labChat.ts.html +0 -3073
  457. package/coverage/server/src/routers/marketing.ts.html +0 -340
  458. package/coverage/server/src/routers/message.ts.html +0 -1912
  459. package/coverage/server/src/routers/notifications.ts.html +0 -364
  460. package/coverage/server/src/routers/section.ts.html +0 -1120
  461. package/coverage/server/src/routers/user.ts.html +0 -862
  462. package/coverage/server/src/routers/worksheet.ts.html +0 -1729
  463. package/coverage/server/src/trpc.ts.html +0 -397
  464. package/coverage/server/src/types/index.html +0 -116
  465. package/coverage/server/src/types/trpc.ts.html +0 -127
  466. package/coverage/server/src/utils/aiUser.ts.html +0 -280
  467. package/coverage/server/src/utils/email.ts.html +0 -121
  468. package/coverage/server/src/utils/generateInviteCode.ts.html +0 -106
  469. package/coverage/server/src/utils/index.html +0 -206
  470. package/coverage/server/src/utils/inference.ts.html +0 -709
  471. package/coverage/server/src/utils/logger.ts.html +0 -664
  472. package/coverage/server/src/utils/prismaErrorHandler.ts.html +0 -907
  473. package/coverage/server/src/utils/prismaWrapper.ts.html +0 -355
  474. package/coverage/server/vitest.config.ts.html +0 -196
  475. package/coverage/sort-arrow-sprite.png +0 -0
  476. package/coverage/sorter.js +0 -210
  477. package/src/lib/notificationHandler.ts +0 -36
  478. package/tests/announcement.test.ts +0 -164
  479. package/tests/assignment.test.ts +0 -296
  480. package/tests/auth.test.ts +0 -48
@@ -1,460 +1,97 @@
1
1
  import { z } from "zod";
2
- import { createTRPCRouter, protectedProcedure, publicProcedure } from "../trpc.js";
3
2
  import { TRPCError } from "@trpc/server";
4
- import { prisma } from "../lib/prisma.js";
5
- import { v4 as uuidv4 } from 'uuid';
6
- import { compare, hash } from "bcryptjs";
7
- import { sendMail } from "../utils/email.js";
8
- import { prismaWrapper } from "../utils/prismaWrapper.js";
9
- import { env } from "../lib/config/env.js";
10
- import { logger } from "../utils/logger.js";
3
+ import {
4
+ createTRPCRouter,
5
+ protectedProcedure,
6
+ publicProcedure,
7
+ } from "../trpc.js";
8
+ import {
9
+ register,
10
+ login,
11
+ logout,
12
+ check,
13
+ resendVerificationEmail,
14
+ verify,
15
+ requestPasswordReset,
16
+ resetPassword,
17
+ } from "../services/auth.js";
11
18
 
12
19
  const loginSchema = z.object({
13
20
  username: z.string(),
14
21
  password: z.string(),
15
22
  });
16
23
 
17
- const registerSchema = z.object({
18
- username: z.string().min(3, "Username must be at least 3 characters"),
19
- email: z.string().email("Invalid email address"),
20
- password: z.string().min(6, "Password must be at least 6 characters"),
21
- confirmPassword: z.string(),
22
- }).refine((data) => data.password === data.confirmPassword, {
23
- message: "Passwords don't match",
24
- path: ["confirmPassword"],
25
- });
24
+ const registerSchema = z
25
+ .object({
26
+ username: z.string().min(3, "Username must be at least 3 characters"),
27
+ email: z.string().email("Invalid email address"),
28
+ password: z.string().min(6, "Password must be at least 6 characters"),
29
+ confirmPassword: z.string(),
30
+ })
31
+ .refine((data) => data.password === data.confirmPassword, {
32
+ message: "Passwords don't match",
33
+ path: ["confirmPassword"],
34
+ });
26
35
 
27
36
  export const authRouter = createTRPCRouter({
28
37
  register: publicProcedure
29
38
  .input(registerSchema)
30
- .mutation(async ({ input }) => {
31
- const { username, email, password } = input;
32
-
33
- // Check if username already exists
34
- const existingUser = await prismaWrapper.findFirst(
35
- () => prisma.user.findFirst({
36
- where: {
37
- OR: [
38
- { username },
39
- { email }
40
- ]
41
- },
42
- select: {
43
- id: true,
44
- username: true,
45
- email: true,
46
- verified: true,
47
- }
48
- }),
49
- 'checking for existing user during registration'
50
- );
51
-
52
- if (existingUser && existingUser.verified) {
53
- if (existingUser.username === username) {
54
- throw new TRPCError({
55
- code: "CONFLICT",
56
- message: "Username already exists",
57
- });
58
- }
59
- if (existingUser.email === email) {
60
- throw new TRPCError({
61
- code: "CONFLICT",
62
- message: "Email already exists",
63
- });
64
- }
65
- } else if (existingUser && !existingUser.verified) {
66
- await prismaWrapper.deleteMany(
67
- () => prisma.session.deleteMany({
68
- where: { userId: existingUser.id },
69
- }),
70
- 'deleting existing sessions for unverified user'
71
- );
72
-
73
- await prismaWrapper.delete(
74
- () => prisma.user.delete({
75
- where: { id: existingUser.id },
76
- }),
77
- 'deleting unverified user'
78
- );
79
- }
80
-
81
- // Create new user
82
- const user = await prismaWrapper.create(
83
- async () => await prisma.user.create({
84
- data: {
85
- username,
86
- email,
87
- password: await hash(password, 10),
88
- profile: {},
89
- verified: true, // temporary
90
- },
91
- select: {
92
- id: true,
93
- username: true,
94
- email: true,
95
- }
96
- }),
97
- 'creating new user during registration'
98
- );
99
-
100
- const verificationToken = await prismaWrapper.create(
101
- () => prisma.session.create({
102
- data: {
103
- id: uuidv4(),
104
- userId: user.id,
105
- expiresAt: new Date(Date.now() + 1000 * 60 * 60 * 24 * 30),
106
- },
107
- }),
108
- 'creating verification token'
109
- );
110
-
111
- try {
112
- await sendMail({
113
- from: 'noreply@studious.sh',
114
- to: user.email,
115
- subject: 'Verify your email',
116
- text: `Click the link to verify your email: ${env.NEXT_PUBLIC_APP_URL}/verify/${verificationToken.id}`,
117
- });
118
- } catch (err) {
119
- logger.error('Failed to send verification email', { email: user.email, err });
120
- }
121
-
122
- // logger.info(`Password verification email sent to ${user.email} at ${env.NEXT_PUBLIC_APP_URL}/verify/${verificationToken.id}`);
123
-
124
- return {
125
- user: {
126
- id: user.id,
127
- username: user.username,
128
- },
129
- };
130
- }),
39
+ .mutation(({ input }) =>
40
+ register({
41
+ username: input.username,
42
+ email: input.email,
43
+ password: input.password,
44
+ })
45
+ ),
131
46
 
132
47
  login: publicProcedure
133
48
  .input(loginSchema)
134
- .mutation(async ({ input }) => {
135
- const { username, password } = input;
136
-
137
- const user = await prisma.user.findFirst({
138
- where: { username },
139
- select: {
140
- id: true,
141
- username: true,
142
- password: true,
143
- email: true,
144
- verified: true,
145
- }
146
- });
147
-
148
- if (!user) {
149
- throw new TRPCError({
150
- code: "UNAUTHORIZED",
151
- message: "Invalid username or password",
152
- });
153
- }
154
-
155
- if (!(await compare(password, user.password))) {
156
- throw new TRPCError({
157
- code: "UNAUTHORIZED",
158
- message: "Invalid username or password",
159
- });
160
- }
49
+ .mutation(({ input }) => login(input)),
161
50
 
162
- if (!user.verified) {
163
- return {
164
- verified: false,
165
- user: {
166
- email: user.email,
167
- },
168
- }
169
- }
170
-
171
- // Create a new session
172
- const session = await prisma.session.create({
173
- data: {
174
- id: uuidv4(),
175
- userId: user.id,
176
- expiresAt: new Date(Date.now() + 1000 * 60 * 60 * 24 * 30),
177
- },
51
+ logout: protectedProcedure.mutation(({ ctx }) => {
52
+ if (!ctx.user) {
53
+ throw new TRPCError({
54
+ code: "UNAUTHORIZED",
55
+ message: "Not authenticated",
178
56
  });
179
-
180
- return {
181
- token: session.id,
182
- user: {
183
- id: user.id,
184
- username: user.username,
185
- },
186
- };
187
- }),
188
-
189
- logout: protectedProcedure
190
- .mutation(async ({ ctx }) => {
191
- if (!ctx.user) {
192
- throw new TRPCError({
193
- code: "UNAUTHORIZED",
194
- message: "Not authenticated",
195
- });
196
- }
197
-
198
- // Delete the current session
199
- await prisma.session.deleteMany({
200
- where: { userId: ctx.user.id },
57
+ }
58
+ return logout(ctx.user.id);
59
+ }),
60
+
61
+ check: protectedProcedure.query(({ ctx }) => {
62
+ if (!ctx.user) {
63
+ throw new TRPCError({
64
+ code: "UNAUTHORIZED",
65
+ message: "Not authenticated",
201
66
  });
202
-
203
- return { success: true };
204
- }),
205
-
206
-
207
- check: protectedProcedure
208
- .query(async ({ ctx }) => {
209
- if (!ctx.user) {
210
- throw new TRPCError({
211
- code: "UNAUTHORIZED",
212
- message: "Not authenticated",
213
- });
214
- }
215
-
216
- const user = await prisma.user.findUnique({
217
- where: { id: ctx.user.id },
218
- select: {
219
- id: true,
220
- username: true,
221
- profile: {
222
- select: {
223
- displayName: true,
224
- bio: true,
225
- location: true,
226
- website: true,
227
- profilePicture: true,
228
- profilePictureThumbnail: true,
229
- },
230
- },
231
- }
232
- });
233
-
234
- if (!user) {
235
- throw new TRPCError({
236
- code: "NOT_FOUND",
237
- message: "User not found",
238
- });
239
- }
240
-
241
- return {user};
242
- }),
243
- resendVerificationEmail: publicProcedure
244
- .input(z.object({
245
- email: z.string().email(),
246
- }))
247
- .mutation(async ({ input }) => {
248
- const { email } = input;
249
-
250
- const user = await prisma.user.findFirst({
251
- where: {
252
- email,
253
- },
254
- select: {
255
- id: true,
256
- email: true,
257
- role: true,
258
- profile: {
259
- select: {
260
- displayName: true,
261
- bio: true,
262
- location: true,
263
- website: true,
264
- profilePicture: true,
265
- },
266
- },
267
- },
268
- });
269
-
270
- if (!user) {
271
- throw new TRPCError({
272
- code: "NOT_FOUND",
273
- message: "User not found",
274
- });
275
- }
276
-
277
- await prisma.session.deleteMany({
278
- where: { userId: user?.id },
279
- });
280
-
281
- const verificationToken = await prisma.session.create({
282
- data: {
283
- id: uuidv4(),
284
- userId: user.id,
285
- expiresAt: new Date(Date.now() + 1000 * 60 * 60 * 24 * 30),
286
- },
287
- });
288
-
289
- try {
290
- await sendMail({
291
- from: 'noreply@studious.sh',
292
- to: user.email,
293
- subject: 'Verify your email',
294
- text: `Click the link to verify your email: ${env.NEXT_PUBLIC_APP_URL}/verify/${verificationToken.id}`,
295
- });
296
- } catch (err) {
297
- logger.error('Failed to send verification email', { email: user.email, err });
298
- }
299
-
300
- // logger.info(`Password verification email sent to ${user.email} at ${env.NEXT_PUBLIC_APP_URL}/verify/${verificationToken.id}`);
301
-
302
- return { success: true };
303
- }),
304
- verify: publicProcedure
305
- .input(z.object({
306
- token: z.string(),
307
- }))
308
- .mutation(async ({ input }) => {
309
- const { token } = input;
310
-
311
- const session = await prisma.session.findUnique({
312
- where: { id: token },
313
- });
314
-
315
- if (!session) {
316
- throw new TRPCError({
317
- code: "NOT_FOUND",
318
- message: "Session not found",
319
- });
320
- }
321
-
322
- if (session.expiresAt && session.expiresAt < new Date()) {
323
- throw new TRPCError({
324
- code: "UNAUTHORIZED",
325
- message: "Session expired",
326
- });
327
- }
328
-
329
- await prisma.user.update({
330
- where: { id: session.userId! },
331
- data: {
332
- verified: true,
333
- },
334
- });
335
-
336
- // Clean up the verification token
337
- await prisma.session.delete({
338
- where: { id: token },
339
- });
340
-
341
- return { success: true };
342
- }),
343
-
344
- requestPasswordReset: publicProcedure
345
- .input(z.object({
346
- email: z.string().email(),
347
- }))
348
- .mutation(async ({ input }) => {
349
- const { email } = input;
350
-
351
- const user = await prisma.user.findFirst({
352
- where: { email },
353
- select: {
354
- id: true,
355
- email: true,
356
- username: true,
357
- },
358
- });
359
-
360
- // Don't reveal if user exists or not for security
361
- if (!user) {
362
- return { success: true };
363
- }
364
-
365
- // Delete any existing password reset tokens for this user
366
- // Only delete tokens that expire within 2 hours (likely password reset tokens)
367
- const twoHoursFromNow = new Date(Date.now() + 1000 * 60 * 60 * 2);
368
- await prisma.session.deleteMany({
369
- where: {
370
- userId: user.id,
371
- classId: null,
372
- expiresAt: {
373
- lte: twoHoursFromNow, // Only delete short-lived tokens (password reset tokens)
374
- },
375
- },
376
- });
377
-
378
- // Create a new password reset token (expires in 1 hour)
379
- const resetToken = await prisma.session.create({
380
- data: {
381
- id: uuidv4(),
382
- userId: user.id,
383
- expiresAt: new Date(Date.now() + 1000 * 60 * 60), // 1 hour
384
- },
385
- });
386
-
387
- // Send password reset email
388
- try {
389
- await sendMail({
390
- from: 'noreply@studious.sh',
391
- to: user.email,
392
- subject: 'Reset your password',
393
- text: `Click the link to reset your password: ${env.NEXT_PUBLIC_APP_URL}/reset-password/${resetToken.id}`,
394
- });
395
- } catch (err) {
396
- logger.error('Failed to send password reset email', { email: user.email, err });
397
- }
398
-
399
- // logger.info(`Password reset email sent to ${user.email} at ${env.NEXT_PUBLIC_APP_URL}/reset-password/${resetToken.id}`);
400
-
401
- return { success: true };
402
- }),
403
-
404
- resetPassword: publicProcedure
405
- .input(z.object({
406
- token: z.string(),
407
- password: z.string().min(6, "Password must be at least 6 characters"),
408
- confirmPassword: z.string(),
409
- }).refine((data) => data.password === data.confirmPassword, {
410
- message: "Passwords don't match",
411
- path: ["confirmPassword"],
412
- }))
413
- .mutation(async ({ input }) => {
414
- const { token, password } = input;
415
-
416
- const session = await prisma.session.findUnique({
417
- where: { id: token },
418
- include: {
419
- user: {
420
- select: {
421
- id: true,
422
- },
423
- },
424
- },
425
- });
426
-
427
- if (!session || !session.userId) {
428
- throw new TRPCError({
429
- code: "NOT_FOUND",
430
- message: "Invalid or expired reset token",
431
- });
432
- }
433
-
434
- if (session.expiresAt && session.expiresAt < new Date()) {
435
- // Clean up expired token
436
- await prisma.session.delete({
437
- where: { id: token },
438
- });
439
- throw new TRPCError({
440
- code: "UNAUTHORIZED",
441
- message: "Reset token has expired",
442
- });
443
- }
444
-
445
- // Update the user's password
446
- await prisma.user.update({
447
- where: { id: session.userId },
448
- data: {
449
- password: await hash(password, 10),
450
- },
451
- });
452
-
453
- // Clean up the reset token
454
- await prisma.session.delete({
455
- where: { id: token },
456
- });
457
-
458
- return { success: true };
459
- }),
460
- });
67
+ }
68
+ return check(ctx.user.id);
69
+ }),
70
+
71
+ resendVerificationEmail: publicProcedure
72
+ .input(z.object({ email: z.string().email() }))
73
+ .mutation(({ input }) => resendVerificationEmail(input.email)),
74
+
75
+ verify: publicProcedure
76
+ .input(z.object({ token: z.string() }))
77
+ .mutation(({ input }) => verify(input.token)),
78
+
79
+ requestPasswordReset: publicProcedure
80
+ .input(z.object({ email: z.string().email() }))
81
+ .mutation(({ input }) => requestPasswordReset(input.email)),
82
+
83
+ resetPassword: publicProcedure
84
+ .input(
85
+ z
86
+ .object({
87
+ token: z.string(),
88
+ password: z.string().min(6, "Password must be at least 6 characters"),
89
+ confirmPassword: z.string(),
90
+ })
91
+ .refine((data) => data.password === data.confirmPassword, {
92
+ message: "Passwords don't match",
93
+ path: ["confirmPassword"],
94
+ })
95
+ )
96
+ .mutation(({ input }) => resetPassword(input.token, input.password)),
97
+ });