@studious-lms/server 1.1.24 → 1.2.6

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 (485) hide show
  1. package/.coderabbit.yaml +9 -0
  2. package/.env.example +53 -0
  3. package/.env.test.example +37 -0
  4. package/README.md +34 -7
  5. package/dist/exportType.d.ts.map +1 -1
  6. package/dist/exportType.js +4 -0
  7. package/dist/exportType.js.map +1 -0
  8. package/dist/index.d.ts +1 -1
  9. package/dist/index.d.ts.map +1 -1
  10. package/dist/index.js +212 -51
  11. package/dist/index.js.map +1 -0
  12. package/dist/instrument.d.ts +2 -0
  13. package/dist/instrument.d.ts.map +1 -0
  14. package/dist/instrument.js +18 -0
  15. package/dist/instrument.js.map +1 -0
  16. package/dist/lib/config/env.d.ts +190 -0
  17. package/dist/lib/config/env.d.ts.map +1 -0
  18. package/dist/lib/config/env.js +121 -0
  19. package/dist/lib/config/env.js.map +1 -0
  20. package/dist/lib/fileUpload.d.ts +2 -2
  21. package/dist/lib/fileUpload.d.ts.map +1 -1
  22. package/dist/lib/fileUpload.js +82 -15
  23. package/dist/lib/fileUpload.js.map +1 -0
  24. package/dist/lib/googleCloudStorage.d.ts +13 -0
  25. package/dist/lib/googleCloudStorage.d.ts.map +1 -1
  26. package/dist/lib/googleCloudStorage.js +45 -6
  27. package/dist/lib/googleCloudStorage.js.map +1 -0
  28. package/dist/lib/jsonConversion.d.ts.map +1 -1
  29. package/dist/lib/jsonConversion.js +16 -14
  30. package/dist/lib/jsonConversion.js.map +1 -0
  31. package/dist/lib/jsonStyles.d.ts.map +1 -1
  32. package/dist/lib/jsonStyles.js +4 -0
  33. package/dist/lib/jsonStyles.js.map +1 -0
  34. package/dist/lib/notificationHandler.d.ts +25 -0
  35. package/dist/lib/notificationHandler.d.ts.map +1 -0
  36. package/dist/lib/notificationHandler.js +32 -0
  37. package/dist/lib/notificationHandler.js.map +1 -0
  38. package/dist/lib/prisma.d.ts +2 -2
  39. package/dist/lib/prisma.d.ts.map +1 -1
  40. package/dist/lib/prisma.js +24 -1
  41. package/dist/lib/prisma.js.map +1 -0
  42. package/dist/lib/pusher.d.ts +4 -1
  43. package/dist/lib/pusher.d.ts.map +1 -1
  44. package/dist/lib/pusher.js +14 -6
  45. package/dist/lib/pusher.js.map +1 -0
  46. package/dist/lib/redis.d.ts +5 -0
  47. package/dist/lib/redis.d.ts.map +1 -0
  48. package/dist/lib/redis.js +53 -0
  49. package/dist/lib/redis.js.map +1 -0
  50. package/dist/lib/thumbnailGenerator.d.ts +0 -21
  51. package/dist/lib/thumbnailGenerator.d.ts.map +1 -1
  52. package/dist/lib/thumbnailGenerator.js +159 -158
  53. package/dist/lib/thumbnailGenerator.js.map +1 -0
  54. package/dist/middleware/auth.d.ts.map +1 -1
  55. package/dist/middleware/auth.js +41 -93
  56. package/dist/middleware/auth.js.map +1 -0
  57. package/dist/middleware/logging.d.ts.map +1 -1
  58. package/dist/middleware/logging.js +4 -0
  59. package/dist/middleware/logging.js.map +1 -0
  60. package/dist/middleware/security.d.ts +5 -0
  61. package/dist/middleware/security.d.ts.map +1 -0
  62. package/dist/middleware/security.js +77 -0
  63. package/dist/middleware/security.js.map +1 -0
  64. package/dist/models/agenda.d.ts +97 -0
  65. package/dist/models/agenda.d.ts.map +1 -0
  66. package/dist/models/agenda.js +40 -0
  67. package/dist/models/agenda.js.map +1 -0
  68. package/dist/models/announcement.d.ts +223 -0
  69. package/dist/models/announcement.d.ts.map +1 -0
  70. package/dist/models/announcement.js +120 -0
  71. package/dist/models/announcement.js.map +1 -0
  72. package/dist/models/assignment.d.ts +1292 -0
  73. package/dist/models/assignment.d.ts.map +1 -0
  74. package/dist/models/assignment.js +309 -0
  75. package/dist/models/assignment.js.map +1 -0
  76. package/dist/models/attendance.d.ts +180 -0
  77. package/dist/models/attendance.d.ts.map +1 -0
  78. package/dist/models/attendance.js +188 -0
  79. package/dist/models/attendance.js.map +1 -0
  80. package/dist/models/auth.d.ts +153 -0
  81. package/dist/models/auth.d.ts.map +1 -0
  82. package/dist/models/auth.js +217 -0
  83. package/dist/models/auth.js.map +1 -0
  84. package/dist/models/class.d.ts +439 -0
  85. package/dist/models/class.d.ts.map +1 -0
  86. package/dist/models/class.js +546 -0
  87. package/dist/models/class.js.map +1 -0
  88. package/dist/models/comment.d.ts +171 -0
  89. package/dist/models/comment.d.ts.map +1 -0
  90. package/dist/models/comment.js +138 -0
  91. package/dist/models/comment.js.map +1 -0
  92. package/dist/models/conversation.d.ts +164 -0
  93. package/dist/models/conversation.d.ts.map +1 -0
  94. package/dist/models/conversation.js +175 -0
  95. package/dist/models/conversation.js.map +1 -0
  96. package/dist/models/event.d.ts +295 -0
  97. package/dist/models/event.d.ts.map +1 -0
  98. package/dist/models/event.js +145 -0
  99. package/dist/models/event.js.map +1 -0
  100. package/dist/models/file.d.ts +536 -0
  101. package/dist/models/file.d.ts.map +1 -0
  102. package/dist/models/file.js +126 -0
  103. package/dist/models/file.js.map +1 -0
  104. package/dist/models/folder.d.ts +295 -0
  105. package/dist/models/folder.d.ts.map +1 -0
  106. package/dist/models/folder.js +202 -0
  107. package/dist/models/folder.js.map +1 -0
  108. package/dist/models/labChat.d.ts +243 -0
  109. package/dist/models/labChat.d.ts.map +1 -0
  110. package/dist/models/labChat.js +204 -0
  111. package/dist/models/labChat.js.map +1 -0
  112. package/dist/models/marketing.d.ts +72 -0
  113. package/dist/models/marketing.d.ts.map +1 -0
  114. package/dist/models/marketing.js +26 -0
  115. package/dist/models/marketing.js.map +1 -0
  116. package/dist/models/message.d.ts +100 -0
  117. package/dist/models/message.d.ts.map +1 -0
  118. package/dist/models/message.js +131 -0
  119. package/dist/models/message.js.map +1 -0
  120. package/dist/models/newtonChat.d.ts +72 -0
  121. package/dist/models/newtonChat.d.ts.map +1 -0
  122. package/dist/models/newtonChat.js +61 -0
  123. package/dist/models/newtonChat.js.map +1 -0
  124. package/dist/models/notification.d.ts +65 -0
  125. package/dist/models/notification.d.ts.map +1 -0
  126. package/dist/models/notification.js +46 -0
  127. package/dist/models/notification.js.map +1 -0
  128. package/dist/models/section.d.ts +102 -0
  129. package/dist/models/section.d.ts.map +1 -0
  130. package/dist/models/section.js +83 -0
  131. package/dist/models/section.js.map +1 -0
  132. package/dist/models/user.d.ts +39 -0
  133. package/dist/models/user.d.ts.map +1 -0
  134. package/dist/models/user.js +38 -0
  135. package/dist/models/user.js.map +1 -0
  136. package/dist/models/worksheet.d.ts +460 -0
  137. package/dist/models/worksheet.d.ts.map +1 -0
  138. package/dist/models/worksheet.js +200 -0
  139. package/dist/models/worksheet.js.map +1 -0
  140. package/dist/pipelines/aiLabChat.d.ts +21 -0
  141. package/dist/pipelines/aiLabChat.d.ts.map +1 -0
  142. package/dist/pipelines/aiLabChat.js +460 -0
  143. package/dist/pipelines/aiLabChat.js.map +1 -0
  144. package/dist/pipelines/aiNewtonChat.d.ts +30 -0
  145. package/dist/pipelines/aiNewtonChat.d.ts.map +1 -0
  146. package/dist/pipelines/aiNewtonChat.js +289 -0
  147. package/dist/pipelines/aiNewtonChat.js.map +1 -0
  148. package/dist/pipelines/gradeWorksheet.d.ts +30 -0
  149. package/dist/pipelines/gradeWorksheet.d.ts.map +1 -0
  150. package/dist/pipelines/gradeWorksheet.js +252 -0
  151. package/dist/pipelines/gradeWorksheet.js.map +1 -0
  152. package/dist/routers/_app.d.ts +6403 -3741
  153. package/dist/routers/_app.d.ts.map +1 -1
  154. package/dist/routers/_app.js +10 -0
  155. package/dist/routers/_app.js.map +1 -0
  156. package/dist/routers/agenda.d.ts +58 -6
  157. package/dist/routers/agenda.d.ts.map +1 -1
  158. package/dist/routers/agenda.js +6 -58
  159. package/dist/routers/agenda.js.map +1 -0
  160. package/dist/routers/announcement.d.ts +325 -6
  161. package/dist/routers/announcement.d.ts.map +1 -1
  162. package/dist/routers/announcement.js +547 -57
  163. package/dist/routers/announcement.js.map +1 -0
  164. package/dist/routers/assignment.d.ts +431 -318
  165. package/dist/routers/assignment.d.ts.map +1 -1
  166. package/dist/routers/assignment.js +104 -1559
  167. package/dist/routers/assignment.js.map +1 -0
  168. package/dist/routers/attendance.d.ts +20 -9
  169. package/dist/routers/attendance.d.ts.map +1 -1
  170. package/dist/routers/attendance.js +10 -263
  171. package/dist/routers/attendance.js.map +1 -0
  172. package/dist/routers/auth.d.ts +21 -1
  173. package/dist/routers/auth.d.ts.map +1 -1
  174. package/dist/routers/auth.js +37 -241
  175. package/dist/routers/auth.js.map +1 -0
  176. package/dist/routers/class.d.ts +198 -68
  177. package/dist/routers/class.d.ts.map +1 -1
  178. package/dist/routers/class.js +88 -909
  179. package/dist/routers/class.js.map +1 -0
  180. package/dist/routers/comment.d.ts +153 -0
  181. package/dist/routers/comment.d.ts.map +1 -0
  182. package/dist/routers/comment.js +58 -0
  183. package/dist/routers/comment.js.map +1 -0
  184. package/dist/routers/conversation.d.ts +73 -3
  185. package/dist/routers/conversation.d.ts.map +1 -1
  186. package/dist/routers/conversation.js +23 -265
  187. package/dist/routers/conversation.js.map +1 -0
  188. package/dist/routers/event.d.ts +46 -37
  189. package/dist/routers/event.d.ts.map +1 -1
  190. package/dist/routers/event.js +15 -431
  191. package/dist/routers/event.js.map +1 -0
  192. package/dist/routers/file.d.ts +4 -2
  193. package/dist/routers/file.d.ts.map +1 -1
  194. package/dist/routers/file.js +11 -295
  195. package/dist/routers/file.js.map +1 -0
  196. package/dist/routers/folder.d.ts +21 -14
  197. package/dist/routers/folder.d.ts.map +1 -1
  198. package/dist/routers/folder.js +36 -743
  199. package/dist/routers/folder.js.map +1 -0
  200. package/dist/routers/labChat.d.ts +12 -9
  201. package/dist/routers/labChat.d.ts.map +1 -1
  202. package/dist/routers/labChat.js +21 -877
  203. package/dist/routers/labChat.js.map +1 -0
  204. package/dist/routers/marketing.d.ts +2 -2
  205. package/dist/routers/marketing.d.ts.map +1 -1
  206. package/dist/routers/marketing.js +9 -54
  207. package/dist/routers/marketing.js.map +1 -0
  208. package/dist/routers/message.d.ts +2 -1
  209. package/dist/routers/message.d.ts.map +1 -1
  210. package/dist/routers/message.js +29 -519
  211. package/dist/routers/message.js.map +1 -0
  212. package/dist/routers/newtonChat.d.ts +55 -0
  213. package/dist/routers/newtonChat.d.ts.map +1 -0
  214. package/dist/routers/newtonChat.js +22 -0
  215. package/dist/routers/newtonChat.js.map +1 -0
  216. package/dist/routers/notifications.d.ts +8 -8
  217. package/dist/routers/notifications.d.ts.map +1 -1
  218. package/dist/routers/notifications.js +20 -81
  219. package/dist/routers/notifications.js.map +1 -0
  220. package/dist/routers/section.d.ts +37 -6
  221. package/dist/routers/section.d.ts.map +1 -1
  222. package/dist/routers/section.js +26 -167
  223. package/dist/routers/section.js.map +1 -0
  224. package/dist/routers/user.d.ts +1 -1
  225. package/dist/routers/user.d.ts.map +1 -1
  226. package/dist/routers/user.js +34 -204
  227. package/dist/routers/user.js.map +1 -0
  228. package/dist/routers/worksheet.d.ts +362 -0
  229. package/dist/routers/worksheet.d.ts.map +1 -0
  230. package/dist/routers/worksheet.js +153 -0
  231. package/dist/routers/worksheet.js.map +1 -0
  232. package/dist/seedDatabase.d.ts +2 -3
  233. package/dist/seedDatabase.d.ts.map +1 -1
  234. package/dist/seedDatabase.js +311 -289
  235. package/dist/seedDatabase.js.map +1 -0
  236. package/dist/server/pipelines/aiLabChat.d.ts +21 -0
  237. package/dist/server/pipelines/aiLabChat.d.ts.map +1 -0
  238. package/dist/server/pipelines/aiLabChat.js +456 -0
  239. package/dist/server/pipelines/aiLabChat.js.map +1 -0
  240. package/dist/server/pipelines/aiNewtonChat.d.ts +30 -0
  241. package/dist/server/pipelines/aiNewtonChat.d.ts.map +1 -0
  242. package/dist/server/pipelines/aiNewtonChat.js +285 -0
  243. package/dist/server/pipelines/aiNewtonChat.js.map +1 -0
  244. package/dist/server/pipelines/gradeWorksheet.d.ts +30 -0
  245. package/dist/server/pipelines/gradeWorksheet.d.ts.map +1 -0
  246. package/dist/server/pipelines/gradeWorksheet.js +248 -0
  247. package/dist/server/pipelines/gradeWorksheet.js.map +1 -0
  248. package/dist/services/agenda.d.ts +100 -0
  249. package/dist/services/agenda.d.ts.map +1 -0
  250. package/dist/services/agenda.js +21 -0
  251. package/dist/services/agenda.js.map +1 -0
  252. package/dist/services/announcement.d.ts +135 -0
  253. package/dist/services/announcement.d.ts.map +1 -0
  254. package/dist/services/announcement.js +223 -0
  255. package/dist/services/announcement.js.map +1 -0
  256. package/dist/services/assignment.d.ts +1462 -0
  257. package/dist/services/assignment.d.ts.map +1 -0
  258. package/dist/services/assignment.js +898 -0
  259. package/dist/services/assignment.js.map +1 -0
  260. package/dist/services/attendance.d.ts +93 -0
  261. package/dist/services/attendance.d.ts.map +1 -0
  262. package/dist/services/attendance.js +61 -0
  263. package/dist/services/attendance.js.map +1 -0
  264. package/dist/services/auth.d.ts +68 -0
  265. package/dist/services/auth.d.ts.map +1 -0
  266. package/dist/services/auth.js +218 -0
  267. package/dist/services/auth.js.map +1 -0
  268. package/dist/services/class.d.ts +621 -0
  269. package/dist/services/class.d.ts.map +1 -0
  270. package/dist/services/class.js +474 -0
  271. package/dist/services/class.js.map +1 -0
  272. package/dist/services/comment.d.ts +100 -0
  273. package/dist/services/comment.d.ts.map +1 -0
  274. package/dist/services/comment.js +83 -0
  275. package/dist/services/comment.js.map +1 -0
  276. package/dist/services/conversation.d.ts +159 -0
  277. package/dist/services/conversation.d.ts.map +1 -0
  278. package/dist/services/conversation.js +138 -0
  279. package/dist/services/conversation.js.map +1 -0
  280. package/dist/services/event.d.ts +216 -0
  281. package/dist/services/event.d.ts.map +1 -0
  282. package/dist/services/event.js +168 -0
  283. package/dist/services/event.js.map +1 -0
  284. package/dist/services/file.d.ts +74 -0
  285. package/dist/services/file.d.ts.map +1 -0
  286. package/dist/services/file.js +133 -0
  287. package/dist/services/file.js.map +1 -0
  288. package/dist/services/folder.d.ts +239 -0
  289. package/dist/services/folder.d.ts.map +1 -0
  290. package/dist/services/folder.js +248 -0
  291. package/dist/services/folder.js.map +1 -0
  292. package/dist/services/labChat.d.ts +165 -0
  293. package/dist/services/labChat.d.ts.map +1 -0
  294. package/dist/services/labChat.js +289 -0
  295. package/dist/services/labChat.js.map +1 -0
  296. package/dist/services/marketing.d.ts +50 -0
  297. package/dist/services/marketing.d.ts.map +1 -0
  298. package/dist/services/marketing.js +32 -0
  299. package/dist/services/marketing.js.map +1 -0
  300. package/dist/services/message.d.ts +95 -0
  301. package/dist/services/message.d.ts.map +1 -0
  302. package/dist/services/message.js +350 -0
  303. package/dist/services/message.js.map +1 -0
  304. package/dist/services/newtonChat.d.ts +22 -0
  305. package/dist/services/newtonChat.d.ts.map +1 -0
  306. package/dist/services/newtonChat.js +174 -0
  307. package/dist/services/newtonChat.js.map +1 -0
  308. package/dist/services/notification.d.ts +65 -0
  309. package/dist/services/notification.d.ts.map +1 -0
  310. package/dist/services/notification.js +33 -0
  311. package/dist/services/notification.js.map +1 -0
  312. package/dist/services/section.d.ts +53 -0
  313. package/dist/services/section.d.ts.map +1 -0
  314. package/dist/services/section.js +199 -0
  315. package/dist/services/section.js.map +1 -0
  316. package/dist/services/user.d.ts +48 -0
  317. package/dist/services/user.d.ts.map +1 -0
  318. package/dist/services/user.js +141 -0
  319. package/dist/services/user.js.map +1 -0
  320. package/dist/services/worksheet.d.ts +239 -0
  321. package/dist/services/worksheet.d.ts.map +1 -0
  322. package/dist/services/worksheet.js +235 -0
  323. package/dist/services/worksheet.js.map +1 -0
  324. package/dist/socket/handlers.d.ts.map +1 -1
  325. package/dist/socket/handlers.js +4 -0
  326. package/dist/socket/handlers.js.map +1 -0
  327. package/dist/trpc.d.ts.map +1 -1
  328. package/dist/trpc.js +4 -0
  329. package/dist/trpc.js.map +1 -0
  330. package/dist/types/trpc.d.ts.map +1 -1
  331. package/dist/types/trpc.js +4 -0
  332. package/dist/types/trpc.js.map +1 -0
  333. package/dist/utils/aiUser.d.ts +1 -3
  334. package/dist/utils/aiUser.d.ts.map +1 -1
  335. package/dist/utils/aiUser.js +8 -3
  336. package/dist/utils/aiUser.js.map +1 -0
  337. package/dist/utils/email.d.ts +12 -1
  338. package/dist/utils/email.d.ts.map +1 -1
  339. package/dist/utils/email.js +26 -4
  340. package/dist/utils/email.js.map +1 -0
  341. package/dist/utils/generateInviteCode.d.ts +1 -2
  342. package/dist/utils/generateInviteCode.d.ts.map +1 -1
  343. package/dist/utils/generateInviteCode.js +5 -2
  344. package/dist/utils/generateInviteCode.js.map +1 -0
  345. package/dist/utils/inference.d.ts +8 -0
  346. package/dist/utils/inference.d.ts.map +1 -1
  347. package/dist/utils/inference.js +78 -10
  348. package/dist/utils/inference.js.map +1 -0
  349. package/dist/utils/logger.d.ts +4 -0
  350. package/dist/utils/logger.d.ts.map +1 -1
  351. package/dist/utils/logger.js +35 -3
  352. package/dist/utils/logger.js.map +1 -0
  353. package/dist/utils/prismaErrorHandler.d.ts.map +1 -1
  354. package/dist/utils/prismaErrorHandler.js +7 -0
  355. package/dist/utils/prismaErrorHandler.js.map +1 -0
  356. package/dist/utils/prismaWrapper.d.ts +1 -0
  357. package/dist/utils/prismaWrapper.d.ts.map +1 -1
  358. package/dist/utils/prismaWrapper.js +8 -0
  359. package/dist/utils/prismaWrapper.js.map +1 -0
  360. package/docker-compose.yml +19 -0
  361. package/package.json +21 -4
  362. package/prisma/migrations/20251109122857_annuoncements_comments/migration.sql +30 -0
  363. package/prisma/migrations/20251109135555_reactions_announcements_comments/migration.sql +35 -0
  364. package/prisma/schema.prisma +180 -12
  365. package/scripts/test-pre-push.ts +14 -0
  366. package/src/index.ts +247 -52
  367. package/src/instrument.ts +15 -0
  368. package/src/lib/config/env.ts +132 -0
  369. package/src/lib/fileUpload.ts +81 -16
  370. package/src/lib/googleCloudStorage.ts +42 -6
  371. package/src/lib/jsonConversion.ts +12 -14
  372. package/src/lib/prisma.ts +23 -2
  373. package/src/lib/pusher.ts +11 -6
  374. package/src/lib/redis.ts +56 -0
  375. package/src/lib/thumbnailGenerator.ts +170 -168
  376. package/src/middleware/auth.ts +86 -137
  377. package/src/middleware/security.ts +80 -0
  378. package/src/models/agenda.ts +46 -0
  379. package/src/models/announcement.ts +134 -0
  380. package/src/models/assignment.ts +322 -0
  381. package/src/models/attendance.ts +208 -0
  382. package/src/models/auth.ts +247 -0
  383. package/src/models/class.ts +598 -0
  384. package/src/models/comment.ts +152 -0
  385. package/src/models/conversation.ts +200 -0
  386. package/src/models/event.ts +177 -0
  387. package/src/models/file.ts +129 -0
  388. package/src/models/folder.ts +225 -0
  389. package/src/models/labChat.ts +213 -0
  390. package/src/models/marketing.ts +45 -0
  391. package/src/models/message.ts +153 -0
  392. package/src/models/newtonChat.ts +70 -0
  393. package/src/models/notification.ts +54 -0
  394. package/src/models/section.ts +98 -0
  395. package/src/models/user.ts +47 -0
  396. package/src/models/worksheet.ts +294 -0
  397. package/src/pipelines/aiLabChat.ts +511 -0
  398. package/src/pipelines/aiNewtonChat.ts +347 -0
  399. package/src/pipelines/gradeWorksheet.ts +286 -0
  400. package/src/routers/_app.ts +6 -0
  401. package/src/routers/agenda.ts +3 -61
  402. package/src/routers/announcement.ts +622 -57
  403. package/src/routers/assignment.ts +157 -1688
  404. package/src/routers/attendance.ts +16 -277
  405. package/src/routers/auth.ts +79 -313
  406. package/src/routers/class.ts +265 -1038
  407. package/src/routers/comment.ts +76 -0
  408. package/src/routers/conversation.ts +53 -284
  409. package/src/routers/event.ts +50 -481
  410. package/src/routers/file.ts +45 -341
  411. package/src/routers/folder.ts +107 -836
  412. package/src/routers/labChat.ts +29 -960
  413. package/src/routers/marketing.ts +35 -77
  414. package/src/routers/message.ts +45 -571
  415. package/src/routers/newtonChat.ts +36 -0
  416. package/src/routers/notifications.ts +32 -82
  417. package/src/routers/section.ts +58 -200
  418. package/src/routers/user.ts +49 -226
  419. package/src/routers/worksheet.ts +252 -0
  420. package/src/seedDatabase.ts +330 -290
  421. package/src/services/agenda.ts +21 -0
  422. package/src/services/announcement.ts +290 -0
  423. package/src/services/assignment.ts +1198 -0
  424. package/src/services/attendance.ts +85 -0
  425. package/src/services/auth.ts +277 -0
  426. package/src/services/class.ts +622 -0
  427. package/src/services/comment.ts +106 -0
  428. package/src/services/conversation.ts +213 -0
  429. package/src/services/event.ts +231 -0
  430. package/src/services/file.ts +167 -0
  431. package/src/services/folder.ts +316 -0
  432. package/src/services/labChat.ts +352 -0
  433. package/src/services/marketing.ts +57 -0
  434. package/src/services/message.ts +461 -0
  435. package/src/services/newtonChat.ts +222 -0
  436. package/src/services/notification.ts +50 -0
  437. package/src/services/section.ts +283 -0
  438. package/src/services/user.ts +172 -0
  439. package/src/services/worksheet.ts +358 -0
  440. package/src/trpc.ts +4 -0
  441. package/src/utils/aiUser.ts +4 -3
  442. package/src/utils/email.ts +33 -4
  443. package/src/utils/generateInviteCode.ts +1 -3
  444. package/src/utils/inference.ts +89 -10
  445. package/src/utils/logger.ts +33 -3
  446. package/src/utils/prismaErrorHandler.ts +3 -0
  447. package/src/utils/prismaWrapper.ts +4 -0
  448. package/tests/globalSetup.ts +62 -0
  449. package/tests/helpers.ts +22 -0
  450. package/tests/middleware/security.test.ts +42 -0
  451. package/tests/routers/agenda.test.ts +138 -0
  452. package/tests/routers/announcement.test.ts +490 -0
  453. package/tests/routers/assignment.test.ts +837 -0
  454. package/tests/routers/attendance.test.ts +160 -0
  455. package/tests/routers/auth.test.ts +171 -0
  456. package/tests/{class.test.ts → routers/class.test.ts} +163 -92
  457. package/tests/routers/comment.test.ts +126 -0
  458. package/tests/routers/conversation.test.ts +145 -0
  459. package/tests/routers/event.test.ts +289 -0
  460. package/tests/routers/folder.test.ts +178 -0
  461. package/tests/routers/labChat.test.ts +115 -0
  462. package/tests/routers/marketing.test.ts +59 -0
  463. package/tests/routers/message.test.ts +123 -0
  464. package/tests/routers/notification.test.ts +69 -0
  465. package/tests/routers/section.test.ts +208 -0
  466. package/tests/server/rateLimit.test.ts +73 -0
  467. package/tests/setup.ts +39 -65
  468. package/tests/user.test.ts +136 -0
  469. package/tests/utils/aiUser.test.ts +22 -0
  470. package/tests/utils/generateInviteCode.test.ts +24 -0
  471. package/tests/utils/logger.test.ts +74 -0
  472. package/tests/utils/prismaErrorHandler.test.ts +101 -0
  473. package/tests/utils/prismaWrapper.test.ts +82 -0
  474. package/tests/worksheet.test.ts +181 -0
  475. package/tsconfig.json +9 -2
  476. package/vitest.config.ts +30 -1
  477. package/vitest.unit.config.ts +21 -0
  478. package/API_SPECIFICATION.md +0 -1597
  479. package/BASE64_REMOVAL_SUMMARY.md +0 -164
  480. package/CHAT_API_SPEC.md +0 -579
  481. package/LAB_CHAT_API_SPEC.md +0 -518
  482. package/dist/routers/school.d.ts +0 -208
  483. package/dist/routers/school.d.ts.map +0 -1
  484. package/dist/routers/school.js +0 -481
  485. package/tests/auth.test.ts +0 -25
@@ -1,8 +1,14 @@
1
1
  import { z } from "zod";
2
2
  import { createTRPCRouter, protectedProcedure } from "../trpc.js";
3
- import { TRPCError } from "@trpc/server";
4
- import { prisma } from "../lib/prisma.js";
5
- import { parseISO } from "date-fns";
3
+ import {
4
+ getEvent,
5
+ createEventRecord,
6
+ updateEventRecord,
7
+ deleteEventRecord,
8
+ attachAssignment,
9
+ detachAssignment,
10
+ getAvailableAssignments,
11
+ } from "../services/event.js";
6
12
 
7
13
  const eventSchema = z.object({
8
14
  name: z.string().optional(),
@@ -16,494 +22,57 @@ const eventSchema = z.object({
16
22
 
17
23
  export const eventRouter = createTRPCRouter({
18
24
  get: protectedProcedure
19
- .input(z.object({
20
- id: z.string(),
21
- }))
22
- .query(async ({ ctx, input }) => {
23
- if (!ctx.user) {
24
- throw new TRPCError({
25
- code: "UNAUTHORIZED",
26
- message: "You must be logged in to get an event",
27
- });
28
- }
29
-
30
- const event = await prisma.event.findUnique({
31
- where: { id: input.id },
32
- include: {
33
- class: true,
34
- user: true,
35
- assignmentsAttached: {
36
- select: {
37
- id: true,
38
- title: true,
39
- instructions: true,
40
- dueDate: true,
41
- type: true,
42
- graded: true,
43
- maxGrade: true,
44
- weight: true,
45
- attachments: {
46
- select: {
47
- id: true,
48
- name: true,
49
- type: true,
50
- }
51
- },
52
- section: {
53
- select: {
54
- id: true,
55
- name: true
56
- }
57
- },
58
- teacher: {
59
- select: {
60
- id: true,
61
- username: true
62
- }
63
- }
64
- }
65
- }
66
- },
67
- });
68
-
69
- if (!event) {
70
- throw new TRPCError({
71
- code: "NOT_FOUND",
72
- message: "Event not found",
73
- });
74
- }
75
-
76
- if (event.userId !== ctx.user.id) {
77
- throw new TRPCError({
78
- code: "UNAUTHORIZED",
79
- message: "You are not authorized to view this event",
80
- });
81
- }
82
-
83
- return { event };
84
- }),
25
+ .input(z.object({ id: z.string() }))
26
+ .query(({ ctx, input }) => getEvent(ctx.user!.id, input.id)),
85
27
 
86
28
  create: protectedProcedure
87
29
  .input(eventSchema)
88
- .mutation(async ({ ctx, input }) => {
89
- if (!ctx.user) {
90
- throw new TRPCError({
91
- code: "UNAUTHORIZED",
92
- message: "You must be logged in to create an event",
93
- });
94
- }
95
-
96
- // If classId is provided, check if user is a teacher of the class
97
- if (input.classId) {
98
- const classData = await prisma.class.findUnique({
99
- where: {
100
- id: input.classId,
101
- teachers: {
102
- some: {
103
- id: ctx.user.id,
104
- },
105
- },
106
- },
107
- });
108
-
109
- if (!classData) {
110
- throw new TRPCError({
111
- code: "UNAUTHORIZED",
112
- message: "You are not authorized to create events for this class",
113
- });
114
- }
115
- }
116
-
117
- const event = await prisma.event.create({
118
- data: {
119
- name: input.name,
120
- location: input.location,
121
- remarks: input.remarks,
122
- startTime: parseISO(input.startTime),
123
- endTime: parseISO(input.endTime),
124
- userId: ctx.user.id,
125
- color: input.color,
126
- ...(input.classId ? { classId: input.classId } : {}),
127
- },
128
- select: {
129
- id: true,
130
- name: true,
131
- location: true,
132
- remarks: true,
133
- startTime: true,
134
- endTime: true,
135
- color: true,
136
- classId: true,
137
- userId: true,
138
- class: {
139
- select: {
140
- id: true,
141
- name: true
142
- }
143
- },
144
- }
145
- });
146
-
147
- return { event };
148
- }),
30
+ .mutation(({ ctx, input }) =>
31
+ createEventRecord(ctx.user!.id, input)
32
+ ),
149
33
 
150
34
  update: protectedProcedure
151
- .input(z.object({
152
- id: z.string(),
153
- data: eventSchema,
154
- }))
155
- .mutation(async ({ ctx, input }) => {
156
- if (!ctx.user) {
157
- throw new TRPCError({
158
- code: "UNAUTHORIZED",
159
- message: "You must be logged in to update an event",
160
- });
161
- }
162
-
163
- const event = await prisma.event.findUnique({
164
- where: { id: input.id },
165
- });
166
-
167
- if (!event) {
168
- throw new TRPCError({
169
- code: "NOT_FOUND",
170
- message: "Event not found",
171
- });
172
- }
173
-
174
- if (event.userId !== ctx.user.id) {
175
- throw new TRPCError({
176
- code: "UNAUTHORIZED",
177
- message: "You are not authorized to update this event",
178
- });
179
- }
180
-
181
- const updatedEvent = await prisma.event.update({
182
- where: { id: input.id },
183
- data: {
184
- name: input.data.name,
185
- location: input.data.location,
186
- remarks: input.data.remarks,
187
- startTime: parseISO(input.data.startTime),
188
- endTime: parseISO(input.data.endTime),
189
- color: input.data.color,
190
- ...(input.data.classId ? { classId: input.data.classId } : {}),
191
- },
192
- });
193
-
194
- return { event: updatedEvent };
195
- }),
35
+ .input(
36
+ z.object({
37
+ id: z.string(),
38
+ data: eventSchema,
39
+ })
40
+ )
41
+ .mutation(({ ctx, input }) =>
42
+ updateEventRecord(ctx.user!.id, input.id, input.data)
43
+ ),
196
44
 
197
45
  delete: protectedProcedure
198
- .input(z.object({
199
- id: z.string(),
200
- }))
201
- .mutation(async ({ ctx, input }) => {
202
- if (!ctx.user) {
203
- throw new TRPCError({
204
- code: "UNAUTHORIZED",
205
- message: "You must be logged in to delete an event",
206
- });
207
- }
208
-
209
- const event = await prisma.event.findUnique({
210
- where: { id: input.id },
211
- });
212
-
213
- if (!event) {
214
- throw new TRPCError({
215
- code: "NOT_FOUND",
216
- message: "Event not found",
217
- });
218
- }
219
-
220
- if (event.userId !== ctx.user.id) {
221
- throw new TRPCError({
222
- code: "UNAUTHORIZED",
223
- message: "You are not authorized to delete this event",
224
- });
225
- }
226
-
227
- await prisma.event.delete({
228
- where: { id: input.id },
229
- });
230
-
231
- return { success: true };
232
- }),
46
+ .input(z.object({ id: z.string() }))
47
+ .mutation(({ ctx, input }) =>
48
+ deleteEventRecord(ctx.user!.id, input.id)
49
+ ),
233
50
 
234
51
  attachAssignment: protectedProcedure
235
- .input(z.object({
236
- eventId: z.string(),
237
- assignmentId: z.string(),
238
- }))
239
- .mutation(async ({ ctx, input }) => {
240
- if (!ctx.user || !ctx.user.id) {
241
- throw new TRPCError({
242
- code: "UNAUTHORIZED",
243
- message: "You must be logged in to attach an assignment",
244
- });
245
- }
246
-
247
- // Check if user owns the event
248
- const event = await prisma.event.findUnique({
249
- where: { id: input.eventId },
250
- include: {
251
- class: {
252
- include: {
253
- teachers: {
254
- select: { id: true }
255
- }
256
- }
257
- }
258
- }
259
- });
260
-
261
- if (!event) {
262
- throw new TRPCError({
263
- code: "NOT_FOUND",
264
- message: "Event not found",
265
- });
266
- }
267
-
268
- // Check if user is the event owner or a teacher of the class
269
- if (event.userId !== ctx.user.id &&
270
- !event.class?.teachers.some(teacher => teacher.id === ctx.user!.id)) {
271
- throw new TRPCError({
272
- code: "UNAUTHORIZED",
273
- message: "You are not authorized to modify this event",
274
- });
275
- }
276
-
277
- // Check if assignment exists and belongs to the same class
278
- const assignment = await prisma.assignment.findUnique({
279
- where: { id: input.assignmentId },
280
- include: {
281
- class: {
282
- include: {
283
- teachers: {
284
- select: { id: true }
285
- }
286
- }
287
- }
288
- }
289
- });
290
-
291
- if (!assignment) {
292
- throw new TRPCError({
293
- code: "NOT_FOUND",
294
- message: "Assignment not found",
295
- });
296
- }
297
-
298
- // Check if user is a teacher of the assignment's class
299
- if (!assignment.class.teachers.some(teacher => teacher.id === ctx.user!.id)) {
300
- throw new TRPCError({
301
- code: "UNAUTHORIZED",
302
- message: "You are not authorized to modify this assignment",
303
- });
304
- }
305
-
306
- // Check if event and assignment belong to the same class
307
- if (event.classId !== assignment.classId) {
308
- throw new TRPCError({
309
- code: "BAD_REQUEST",
310
- message: "Event and assignment must belong to the same class",
311
- });
312
- }
313
-
314
- // Attach assignment to event
315
- const updatedAssignment = await prisma.assignment.update({
316
- where: { id: input.assignmentId },
317
- data: {
318
- eventAttached: {
319
- connect: { id: input.eventId }
320
- }
321
- },
322
- include: {
323
- attachments: {
324
- select: {
325
- id: true,
326
- name: true,
327
- type: true,
328
- }
329
- },
330
- section: {
331
- select: {
332
- id: true,
333
- name: true
334
- }
335
- },
336
- teacher: {
337
- select: {
338
- id: true,
339
- username: true
340
- }
341
- }
342
- }
343
- });
344
-
345
- return { assignment: updatedAssignment };
346
- }),
52
+ .input(
53
+ z.object({
54
+ eventId: z.string(),
55
+ assignmentId: z.string(),
56
+ })
57
+ )
58
+ .mutation(({ ctx, input }) =>
59
+ attachAssignment(ctx.user!.id, input.eventId, input.assignmentId)
60
+ ),
347
61
 
348
62
  detachAssignment: protectedProcedure
349
- .input(z.object({
350
- eventId: z.string(),
351
- assignmentId: z.string(),
352
- }))
353
- .mutation(async ({ ctx, input }) => {
354
- if (!ctx.user) {
355
- throw new TRPCError({
356
- code: "UNAUTHORIZED",
357
- message: "You must be logged in to detach an assignment",
358
- });
359
- }
360
-
361
- // Check if user owns the event
362
- const event = await prisma.event.findUnique({
363
- where: { id: input.eventId },
364
- include: {
365
- class: {
366
- include: {
367
- teachers: {
368
- select: { id: true }
369
- }
370
- }
371
- }
372
- }
373
- });
374
-
375
- if (!event) {
376
- throw new TRPCError({
377
- code: "NOT_FOUND",
378
- message: "Event not found",
379
- });
380
- }
381
-
382
- // Check if user is the event owner or a teacher of the class
383
- if (event.userId !== ctx.user.id &&
384
- !event.class?.teachers.some(teacher => teacher.id === ctx.user!.id)) {
385
- throw new TRPCError({
386
- code: "UNAUTHORIZED",
387
- message: "You are not authorized to modify this event",
388
- });
389
- }
390
-
391
- // Detach assignment from event
392
- const updatedAssignment = await prisma.assignment.update({
393
- where: { id: input.assignmentId },
394
- data: {
395
- eventAttached: {
396
- disconnect: true
397
- }
398
- },
399
- include: {
400
- attachments: {
401
- select: {
402
- id: true,
403
- name: true,
404
- type: true,
405
- }
406
- },
407
- section: {
408
- select: {
409
- id: true,
410
- name: true
411
- }
412
- },
413
- teacher: {
414
- select: {
415
- id: true,
416
- username: true
417
- }
418
- }
419
- }
420
- });
421
-
422
- return { assignment: updatedAssignment };
423
- }),
63
+ .input(
64
+ z.object({
65
+ eventId: z.string(),
66
+ assignmentId: z.string(),
67
+ })
68
+ )
69
+ .mutation(({ ctx, input }) =>
70
+ detachAssignment(ctx.user!.id, input.eventId, input.assignmentId)
71
+ ),
424
72
 
425
73
  getAvailableAssignments: protectedProcedure
426
- .input(z.object({
427
- eventId: z.string(),
428
- }))
429
- .query(async ({ ctx, input }) => {
430
- if (!ctx.user) {
431
- throw new TRPCError({
432
- code: "UNAUTHORIZED",
433
- message: "You must be logged in to get available assignments",
434
- });
435
- }
436
-
437
- // Get the event to find the class
438
- const event = await prisma.event.findUnique({
439
- where: { id: input.eventId },
440
- include: {
441
- class: {
442
- include: {
443
- teachers: {
444
- select: { id: true }
445
- }
446
- }
447
- }
448
- }
449
- });
450
-
451
- if (!event || !event.classId) {
452
- throw new TRPCError({
453
- code: "NOT_FOUND",
454
- message: "Event not found",
455
- });
456
- }
457
-
458
- // Check if user is authorized to access this event/class
459
- if (event.userId !== ctx.user.id &&
460
- !event.class?.teachers.some(teacher => teacher.id === ctx.user!.id)) {
461
- throw new TRPCError({
462
- code: "UNAUTHORIZED",
463
- message: "You are not authorized to access this event",
464
- });
465
- }
466
-
467
- // Get all assignments for the class that are not already attached to an event
468
- const assignments = await prisma.assignment.findMany({
469
- where: {
470
- classId: event.classId,
471
- eventId: null, // Not already attached to any event
472
- },
473
- select: {
474
- id: true,
475
- title: true,
476
- instructions: true,
477
- dueDate: true,
478
- type: true,
479
- graded: true,
480
- maxGrade: true,
481
- weight: true,
482
- section: {
483
- select: {
484
- id: true,
485
- name: true
486
- }
487
- },
488
- attachments: {
489
- select: {
490
- id: true,
491
- name: true,
492
- type: true,
493
- }
494
- },
495
- teacher: {
496
- select: {
497
- id: true,
498
- username: true
499
- }
500
- }
501
- },
502
- orderBy: {
503
- createdAt: 'desc'
504
- }
505
- });
506
-
507
- return { assignments };
508
- }),
509
- });
74
+ .input(z.object({ eventId: z.string() }))
75
+ .query(({ ctx, input }) =>
76
+ getAvailableAssignments(ctx.user!.id, input.eventId)
77
+ ),
78
+ });