@studious-lms/server 1.1.26 → 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 (486) 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 +15 -5
  23. package/dist/lib/fileUpload.js.map +1 -0
  24. package/dist/lib/googleCloudStorage.d.ts +6 -0
  25. package/dist/lib/googleCloudStorage.d.ts.map +1 -1
  26. package/dist/lib/googleCloudStorage.js +26 -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 +2 -2
  35. package/dist/lib/notificationHandler.d.ts.map +1 -1
  36. package/dist/lib/notificationHandler.js +4 -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 +6438 -3910
  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 +543 -77
  163. package/dist/routers/announcement.js.map +1 -0
  164. package/dist/routers/assignment.d.ts +419 -357
  165. package/dist/routers/assignment.d.ts.map +1 -1
  166. package/dist/routers/assignment.js +100 -1689
  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 -298
  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 -885
  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 +23 -8
  221. package/dist/routers/section.d.ts.map +1 -1
  222. package/dist/routers/section.js +23 -273
  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 +309 -288
  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 +3 -0
  350. package/dist/utils/logger.d.ts.map +1 -1
  351. package/dist/utils/logger.js +8 -1
  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 +13 -6
  370. package/src/lib/googleCloudStorage.ts +23 -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 +616 -79
  403. package/src/routers/assignment.ts +148 -1827
  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 -344
  411. package/src/routers/folder.ts +107 -836
  412. package/src/routers/labChat.ts +29 -969
  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 -322
  418. package/src/routers/user.ts +49 -226
  419. package/src/routers/worksheet.ts +252 -0
  420. package/src/seedDatabase.ts +328 -289
  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 +4 -1
  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 -59
  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/src/lib/notificationHandler.ts +0 -36
  486. package/tests/auth.test.ts +0 -25
@@ -1,9 +1,8 @@
1
- import { z } from 'zod';
2
- import { createTRPCRouter, protectedProcedure } from '../trpc.js';
3
- import { prisma } from '../lib/prisma.js';
4
- import { pusher } from '../lib/pusher.js';
5
- import { TRPCError } from '@trpc/server';
6
- import { logger } from '../utils/logger.js';
1
+
2
+ !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="c62d9318-bd9d-54ec-a569-32971e00ed38")}catch(e){}}();
3
+ import { z } from "zod";
4
+ import { createTRPCRouter, protectedProcedure } from "../trpc.js";
5
+ import { listMessages, sendMessage, updateMessage, deleteMessage, markAsRead, markMentionsAsRead, getUnreadCount, } from "../services/message.js";
7
6
  export const messageRouter = createTRPCRouter({
8
7
  list: protectedProcedure
9
8
  .input(z.object({
@@ -11,534 +10,45 @@ export const messageRouter = createTRPCRouter({
11
10
  cursor: z.string().optional(),
12
11
  limit: z.number().min(1).max(100).default(50),
13
12
  }))
14
- .query(async ({ input, ctx }) => {
15
- const userId = ctx.user.id;
16
- const { conversationId, cursor, limit } = input;
17
- // Verify user is a member of the conversation
18
- const membership = await prisma.conversationMember.findFirst({
19
- where: {
20
- conversationId,
21
- userId,
22
- },
23
- });
24
- if (!membership) {
25
- throw new TRPCError({
26
- code: 'FORBIDDEN',
27
- message: 'Not a member of this conversation',
28
- });
29
- }
30
- const messages = await prisma.message.findMany({
31
- where: {
32
- conversationId,
33
- ...(cursor && {
34
- createdAt: {
35
- lt: new Date(cursor),
36
- },
37
- }),
38
- },
39
- include: {
40
- attachments: {
41
- select: {
42
- id: true,
43
- name: true,
44
- type: true,
45
- },
46
- },
47
- sender: {
48
- select: {
49
- id: true,
50
- username: true,
51
- profile: {
52
- select: {
53
- displayName: true,
54
- profilePicture: true,
55
- },
56
- },
57
- },
58
- },
59
- mentions: {
60
- include: {
61
- user: {
62
- select: {
63
- id: true,
64
- username: true,
65
- profile: {
66
- select: {
67
- displayName: true,
68
- },
69
- },
70
- },
71
- },
72
- },
73
- },
74
- },
75
- orderBy: {
76
- createdAt: 'desc',
77
- },
78
- take: limit + 1,
79
- });
80
- let nextCursor = undefined;
81
- if (messages.length > limit) {
82
- const nextItem = messages.pop();
83
- nextCursor = nextItem.createdAt.toISOString();
84
- }
85
- return {
86
- messages: messages.reverse().map((message) => ({
87
- id: message.id,
88
- content: message.content,
89
- senderId: message.senderId,
90
- conversationId: message.conversationId,
91
- createdAt: message.createdAt,
92
- sender: message.sender,
93
- attachments: message.attachments.map((attachment) => ({
94
- id: attachment.id,
95
- name: attachment.name,
96
- type: attachment.type,
97
- })),
98
- mentions: message.mentions.map((mention) => ({
99
- user: mention.user,
100
- })),
101
- mentionsMe: message.mentions.some((mention) => mention.userId === userId),
102
- })),
103
- nextCursor,
104
- };
105
- }),
13
+ .query(({ ctx, input }) => listMessages(ctx.user.id, {
14
+ conversationId: input.conversationId,
15
+ cursor: input.cursor,
16
+ limit: input.limit,
17
+ })),
106
18
  send: protectedProcedure
107
19
  .input(z.object({
108
20
  conversationId: z.string(),
109
21
  content: z.string().min(1).max(4000),
110
22
  mentionedUserIds: z.array(z.string()).optional(),
111
23
  }))
112
- .mutation(async ({ input, ctx }) => {
113
- const userId = ctx.user.id;
114
- const { conversationId, content, mentionedUserIds = [] } = input;
115
- // Verify user is a member of the conversation
116
- const membership = await prisma.conversationMember.findFirst({
117
- where: {
118
- conversationId,
119
- userId,
120
- },
121
- });
122
- if (!membership) {
123
- throw new TRPCError({
124
- code: 'FORBIDDEN',
125
- message: 'Not a member of this conversation',
126
- });
127
- }
128
- // Verify mentioned users are members of the conversation
129
- if (mentionedUserIds.length > 0) {
130
- const mentionedMemberships = await prisma.conversationMember.findMany({
131
- where: {
132
- conversationId,
133
- userId: { in: mentionedUserIds },
134
- },
135
- });
136
- if (mentionedMemberships.length !== mentionedUserIds.length) {
137
- throw new TRPCError({
138
- code: 'BAD_REQUEST',
139
- message: 'Some mentioned users are not members of this conversation',
140
- });
141
- }
142
- }
143
- // Create message, mentions, and update conversation timestamp
144
- const result = await prisma.$transaction(async (tx) => {
145
- const message = await tx.message.create({
146
- data: {
147
- content,
148
- senderId: userId,
149
- conversationId,
150
- },
151
- include: {
152
- sender: {
153
- select: {
154
- id: true,
155
- username: true,
156
- profile: {
157
- select: {
158
- displayName: true,
159
- profilePicture: true,
160
- },
161
- },
162
- },
163
- },
164
- },
165
- });
166
- // Create mentions
167
- if (mentionedUserIds.length > 0) {
168
- await tx.mention.createMany({
169
- data: mentionedUserIds.map((mentionedUserId) => ({
170
- messageId: message.id,
171
- userId: mentionedUserId,
172
- })),
173
- });
174
- }
175
- // Update conversation timestamp
176
- await tx.conversation.update({
177
- where: { id: conversationId },
178
- data: { updatedAt: new Date() },
179
- });
180
- return message;
181
- });
182
- // Broadcast to Pusher channel
183
- try {
184
- await pusher.trigger(`conversation-${conversationId}`, 'new-message', {
185
- id: result.id,
186
- content: result.content,
187
- senderId: result.senderId,
188
- conversationId: result.conversationId,
189
- createdAt: result.createdAt,
190
- sender: result.sender,
191
- mentionedUserIds,
192
- });
193
- }
194
- catch (error) {
195
- logger.error('Failed to broadcast message:', { error });
196
- // Don't fail the request if Pusher fails
197
- }
198
- return {
199
- id: result.id,
200
- content: result.content,
201
- senderId: result.senderId,
202
- conversationId: result.conversationId,
203
- createdAt: result.createdAt,
204
- sender: result.sender,
205
- mentionedUserIds,
206
- };
207
- }),
24
+ .mutation(({ ctx, input }) => sendMessage(ctx.user.id, {
25
+ conversationId: input.conversationId,
26
+ content: input.content,
27
+ mentionedUserIds: input.mentionedUserIds,
28
+ })),
208
29
  update: protectedProcedure
209
30
  .input(z.object({
210
31
  messageId: z.string(),
211
32
  content: z.string().min(1).max(4000),
212
33
  mentionedUserIds: z.array(z.string()).optional(),
213
34
  }))
214
- .mutation(async ({ input, ctx }) => {
215
- const userId = ctx.user.id;
216
- const { messageId, content, mentionedUserIds = [] } = input;
217
- // Get the existing message and verify user is the sender
218
- const existingMessage = await prisma.message.findUnique({
219
- where: { id: messageId },
220
- include: {
221
- sender: {
222
- select: {
223
- id: true,
224
- username: true,
225
- profile: {
226
- select: {
227
- displayName: true,
228
- profilePicture: true,
229
- },
230
- },
231
- },
232
- },
233
- },
234
- });
235
- if (!existingMessage) {
236
- throw new TRPCError({
237
- code: 'NOT_FOUND',
238
- message: 'Message not found',
239
- });
240
- }
241
- if (existingMessage.senderId !== userId) {
242
- throw new TRPCError({
243
- code: 'FORBIDDEN',
244
- message: 'Not the sender of this message',
245
- });
246
- }
247
- // Verify user is still a member of the conversation
248
- const membership = await prisma.conversationMember.findFirst({
249
- where: {
250
- conversationId: existingMessage.conversationId,
251
- userId,
252
- },
253
- });
254
- if (!membership) {
255
- throw new TRPCError({
256
- code: 'FORBIDDEN',
257
- message: 'Not a member of this conversation',
258
- });
259
- }
260
- // Verify mentioned users are members of the conversation
261
- if (mentionedUserIds.length > 0) {
262
- const mentionedMemberships = await prisma.conversationMember.findMany({
263
- where: {
264
- conversationId: existingMessage.conversationId,
265
- userId: { in: mentionedUserIds },
266
- },
267
- });
268
- if (mentionedMemberships.length !== mentionedUserIds.length) {
269
- throw new TRPCError({
270
- code: 'BAD_REQUEST',
271
- message: 'Some mentioned users are not members of this conversation',
272
- });
273
- }
274
- }
275
- // Update message and mentions in transaction
276
- const updatedMessage = await prisma.$transaction(async (tx) => {
277
- // Update the message content
278
- const message = await tx.message.update({
279
- where: { id: messageId },
280
- data: { content },
281
- include: {
282
- sender: {
283
- select: {
284
- id: true,
285
- username: true,
286
- profile: {
287
- select: {
288
- displayName: true,
289
- profilePicture: true,
290
- },
291
- },
292
- },
293
- },
294
- },
295
- });
296
- // Delete existing mentions
297
- await tx.mention.deleteMany({
298
- where: { messageId },
299
- });
300
- // Create new mentions if any
301
- if (mentionedUserIds.length > 0) {
302
- await tx.mention.createMany({
303
- data: mentionedUserIds.map((mentionedUserId) => ({
304
- messageId,
305
- userId: mentionedUserId,
306
- })),
307
- });
308
- }
309
- return message;
310
- });
311
- // Broadcast message update to Pusher
312
- try {
313
- await pusher.trigger(`conversation-${existingMessage.conversationId}`, 'message-updated', {
314
- id: updatedMessage.id,
315
- content: updatedMessage.content,
316
- senderId: updatedMessage.senderId,
317
- conversationId: updatedMessage.conversationId,
318
- createdAt: updatedMessage.createdAt,
319
- sender: updatedMessage.sender,
320
- mentionedUserIds,
321
- });
322
- }
323
- catch (error) {
324
- logger.error('Failed to broadcast message update:', { error });
325
- // Don't fail the request if Pusher fails
326
- }
327
- return {
328
- id: updatedMessage.id,
329
- content: updatedMessage.content,
330
- senderId: updatedMessage.senderId,
331
- conversationId: updatedMessage.conversationId,
332
- createdAt: updatedMessage.createdAt,
333
- sender: updatedMessage.sender,
334
- mentionedUserIds,
335
- };
336
- }),
35
+ .mutation(({ ctx, input }) => updateMessage(ctx.user.id, {
36
+ messageId: input.messageId,
37
+ content: input.content,
38
+ mentionedUserIds: input.mentionedUserIds,
39
+ })),
337
40
  delete: protectedProcedure
338
- .input(z.object({
339
- messageId: z.string(),
340
- }))
341
- .mutation(async ({ input, ctx }) => {
342
- const userId = ctx.user.id;
343
- const { messageId } = input;
344
- // Get the message and verify user is the sender
345
- const existingMessage = await prisma.message.findUnique({
346
- where: { id: messageId },
347
- include: {
348
- sender: {
349
- select: {
350
- id: true,
351
- username: true,
352
- },
353
- },
354
- },
355
- });
356
- if (!existingMessage) {
357
- throw new TRPCError({
358
- code: 'NOT_FOUND',
359
- message: 'Message not found',
360
- });
361
- }
362
- if (existingMessage.senderId !== userId) {
363
- throw new TRPCError({
364
- code: 'FORBIDDEN',
365
- message: 'Not the sender of this message',
366
- });
367
- }
368
- // Verify user is still a member of the conversation
369
- const membership = await prisma.conversationMember.findFirst({
370
- where: {
371
- conversationId: existingMessage.conversationId,
372
- userId,
373
- },
374
- });
375
- if (!membership) {
376
- throw new TRPCError({
377
- code: 'FORBIDDEN',
378
- message: 'Not a member of this conversation',
379
- });
380
- }
381
- // Delete message and all related mentions in transaction
382
- await prisma.$transaction(async (tx) => {
383
- // Delete mentions first (due to foreign key constraint)
384
- await tx.mention.deleteMany({
385
- where: { messageId },
386
- });
387
- // Delete the message
388
- await tx.message.delete({
389
- where: { id: messageId },
390
- });
391
- });
392
- // Broadcast message deletion to Pusher
393
- try {
394
- await pusher.trigger(`conversation-${existingMessage.conversationId}`, 'message-deleted', {
395
- messageId,
396
- conversationId: existingMessage.conversationId,
397
- senderId: existingMessage.senderId,
398
- });
399
- }
400
- catch (error) {
401
- logger.error('Failed to broadcast message deletion:', { error });
402
- // Don't fail the request if Pusher fails
403
- }
404
- return {
405
- success: true,
406
- messageId,
407
- };
408
- }),
41
+ .input(z.object({ messageId: z.string() }))
42
+ .mutation(({ ctx, input }) => deleteMessage(ctx.user.id, input.messageId)),
409
43
  markAsRead: protectedProcedure
410
- .input(z.object({
411
- conversationId: z.string(),
412
- }))
413
- .mutation(async ({ input, ctx }) => {
414
- const userId = ctx.user.id;
415
- const { conversationId } = input;
416
- // Verify user is a member of the conversation and update lastViewedAt
417
- const membership = await prisma.conversationMember.findFirst({
418
- where: {
419
- conversationId,
420
- userId,
421
- },
422
- });
423
- if (!membership) {
424
- throw new TRPCError({
425
- code: 'FORBIDDEN',
426
- message: 'Not a member of this conversation',
427
- });
428
- }
429
- // Update the user's lastViewedAt timestamp for this conversation
430
- await prisma.conversationMember.update({
431
- where: {
432
- id: membership.id,
433
- },
434
- data: {
435
- lastViewedAt: new Date(),
436
- },
437
- });
438
- // Broadcast that user has viewed the conversation
439
- try {
440
- await pusher.trigger(`conversation-${conversationId}`, 'conversation-viewed', {
441
- userId,
442
- viewedAt: new Date(),
443
- });
444
- }
445
- catch (error) {
446
- logger.error('Failed to broadcast conversation view:', { error });
447
- // Don't fail the request if Pusher fails
448
- }
449
- return { success: true };
450
- }),
44
+ .input(z.object({ conversationId: z.string() }))
45
+ .mutation(({ ctx, input }) => markAsRead(ctx.user.id, input.conversationId)),
451
46
  markMentionsAsRead: protectedProcedure
452
- .input(z.object({
453
- conversationId: z.string(),
454
- }))
455
- .mutation(async ({ input, ctx }) => {
456
- const userId = ctx.user.id;
457
- const { conversationId } = input;
458
- // Verify user is a member of the conversation and update lastViewedMentionAt
459
- const membership = await prisma.conversationMember.findFirst({
460
- where: {
461
- conversationId,
462
- userId,
463
- },
464
- });
465
- if (!membership) {
466
- throw new TRPCError({
467
- code: 'FORBIDDEN',
468
- message: 'Not a member of this conversation',
469
- });
470
- }
471
- // Update the user's lastViewedMentionAt timestamp for this conversation
472
- await prisma.conversationMember.update({
473
- where: {
474
- id: membership.id,
475
- },
476
- data: {
477
- lastViewedMentionAt: new Date(),
478
- },
479
- });
480
- // Broadcast that user has viewed mentions
481
- try {
482
- await pusher.trigger(`conversation-${conversationId}`, 'mentions-viewed', {
483
- userId,
484
- viewedAt: new Date(),
485
- });
486
- }
487
- catch (error) {
488
- logger.error('Failed to broadcast mentions view:', { error });
489
- // Don't fail the request if Pusher fails
490
- }
491
- return { success: true };
492
- }),
47
+ .input(z.object({ conversationId: z.string() }))
48
+ .mutation(({ ctx, input }) => markMentionsAsRead(ctx.user.id, input.conversationId)),
493
49
  getUnreadCount: protectedProcedure
494
50
  .input(z.object({ conversationId: z.string() }))
495
- .query(async ({ input, ctx }) => {
496
- const userId = ctx.user.id;
497
- const { conversationId } = input;
498
- // Get user's membership with lastViewedAt and lastViewedMentionAt
499
- const membership = await prisma.conversationMember.findFirst({
500
- where: {
501
- conversationId,
502
- userId,
503
- },
504
- });
505
- if (!membership) {
506
- throw new TRPCError({
507
- code: 'FORBIDDEN',
508
- message: 'Not a member of this conversation',
509
- });
510
- }
511
- // Count regular unread messages
512
- const unreadCount = await prisma.message.count({
513
- where: {
514
- conversationId,
515
- senderId: { not: userId },
516
- ...(membership.lastViewedAt && {
517
- createdAt: { gt: membership.lastViewedAt }
518
- }),
519
- },
520
- });
521
- // Count unread mentions
522
- // Use the later of lastViewedAt or lastViewedMentionAt
523
- // This means if user viewed conversation after mention, mention is considered read
524
- const mentionCutoffTime = membership.lastViewedMentionAt && membership.lastViewedAt
525
- ? (membership.lastViewedMentionAt > membership.lastViewedAt ? membership.lastViewedMentionAt : membership.lastViewedAt)
526
- : (membership.lastViewedMentionAt || membership.lastViewedAt);
527
- const unreadMentionCount = await prisma.mention.count({
528
- where: {
529
- userId,
530
- message: {
531
- conversationId,
532
- senderId: { not: userId },
533
- ...(mentionCutoffTime && {
534
- createdAt: { gt: mentionCutoffTime }
535
- }),
536
- },
537
- },
538
- });
539
- return {
540
- unreadCount,
541
- unreadMentionCount
542
- };
543
- }),
51
+ .query(({ ctx, input }) => getUnreadCount(ctx.user.id, input.conversationId)),
544
52
  });
53
+ //# sourceMappingURL=message.js.map
54
+ //# debugId=c62d9318-bd9d-54ec-a569-32971e00ed38
@@ -0,0 +1 @@
1
+ {"version":3,"file":"message.js","sources":["routers/message.ts"],"sourceRoot":"/","sourcesContent":["import { z } from \"zod\";\nimport { createTRPCRouter, protectedProcedure } from \"../trpc.js\";\nimport {\n listMessages,\n sendMessage,\n updateMessage,\n deleteMessage,\n markAsRead,\n markMentionsAsRead,\n getUnreadCount,\n} from \"../services/message.js\";\n\nexport const messageRouter = createTRPCRouter({\n list: protectedProcedure\n .input(\n z.object({\n conversationId: z.string(),\n cursor: z.string().optional(),\n limit: z.number().min(1).max(100).default(50),\n })\n )\n .query(({ ctx, input }) =>\n listMessages(ctx.user!.id, {\n conversationId: input.conversationId,\n cursor: input.cursor,\n limit: input.limit,\n })\n ),\n\n send: protectedProcedure\n .input(\n z.object({\n conversationId: z.string(),\n content: z.string().min(1).max(4000),\n mentionedUserIds: z.array(z.string()).optional(),\n })\n )\n .mutation(({ ctx, input }) =>\n sendMessage(ctx.user!.id, {\n conversationId: input.conversationId,\n content: input.content,\n mentionedUserIds: input.mentionedUserIds,\n })\n ),\n\n update: protectedProcedure\n .input(\n z.object({\n messageId: z.string(),\n content: z.string().min(1).max(4000),\n mentionedUserIds: z.array(z.string()).optional(),\n })\n )\n .mutation(({ ctx, input }) =>\n updateMessage(ctx.user!.id, {\n messageId: input.messageId,\n content: input.content,\n mentionedUserIds: input.mentionedUserIds,\n })\n ),\n\n delete: protectedProcedure\n .input(z.object({ messageId: z.string() }))\n .mutation(({ ctx, input }) => deleteMessage(ctx.user!.id, input.messageId)),\n\n markAsRead: protectedProcedure\n .input(z.object({ conversationId: z.string() }))\n .mutation(({ ctx, input }) =>\n markAsRead(ctx.user!.id, input.conversationId)\n ),\n\n markMentionsAsRead: protectedProcedure\n .input(z.object({ conversationId: z.string() }))\n .mutation(({ ctx, input }) =>\n markMentionsAsRead(ctx.user!.id, input.conversationId)\n ),\n\n getUnreadCount: protectedProcedure\n .input(z.object({ conversationId: z.string() }))\n .query(({ ctx, input }) =>\n getUnreadCount(ctx.user!.id, input.conversationId)\n ),\n});\n"],"names":[],"mappings":"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","debug_id":"c62d9318-bd9d-54ec-a569-32971e00ed38"}
@@ -0,0 +1,55 @@
1
+ import { z } from "zod";
2
+ export declare const newtonChatRouter: import("@trpc/server").TRPCBuiltRouter<{
3
+ ctx: import("../trpc.js").Context;
4
+ meta: object;
5
+ errorShape: {
6
+ data: {
7
+ zodError: z.typeToFlattenedError<any, string> | null;
8
+ prismaError: import("../utils/prismaErrorHandler.js").PrismaErrorInfo | null;
9
+ code: import("@trpc/server").TRPC_ERROR_CODE_KEY;
10
+ httpStatus: number;
11
+ path?: string;
12
+ stack?: string;
13
+ };
14
+ message: string;
15
+ code: import("@trpc/server").TRPC_ERROR_CODE_NUMBER;
16
+ };
17
+ transformer: false;
18
+ }, import("@trpc/server").TRPCDecorateCreateRouterOptions<{
19
+ getTutorConversation: import("@trpc/server").TRPCQueryProcedure<{
20
+ input: {
21
+ classId: string;
22
+ assignmentId: string;
23
+ };
24
+ output: {
25
+ conversationId: string;
26
+ newtonChatId: string;
27
+ };
28
+ meta: object;
29
+ }>;
30
+ postToNewtonChat: import("@trpc/server").TRPCMutationProcedure<{
31
+ input: {
32
+ content: string;
33
+ newtonChatId: string;
34
+ mentionedUserIds?: string[] | undefined;
35
+ };
36
+ output: {
37
+ id: string;
38
+ content: string;
39
+ senderId: string;
40
+ conversationId: string;
41
+ createdAt: Date;
42
+ sender: {
43
+ id: string;
44
+ username: string;
45
+ profile: {
46
+ displayName: string | null;
47
+ profilePicture: string | null;
48
+ } | null;
49
+ };
50
+ mentionedUserIds: string[];
51
+ };
52
+ meta: object;
53
+ }>;
54
+ }>>;
55
+ //# sourceMappingURL=newtonChat.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"newtonChat.d.ts","sourceRoot":"/","sources":["routers/newtonChat.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAOxB,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4B3B,CAAC"}
@@ -0,0 +1,22 @@
1
+
2
+ !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="9a20639c-ff71-5a5a-92be-013861f4ac53")}catch(e){}}();
3
+ import { z } from "zod";
4
+ import { createTRPCRouter, protectedProcedure } from "../trpc.js";
5
+ import { getTutorConversation, postToNewtonChat, } from "../services/newtonChat.js";
6
+ export const newtonChatRouter = createTRPCRouter({
7
+ getTutorConversation: protectedProcedure
8
+ .input(z.object({
9
+ assignmentId: z.string(),
10
+ classId: z.string(),
11
+ }))
12
+ .query(({ ctx, input }) => getTutorConversation(ctx.user.id, input.assignmentId, input.classId)),
13
+ postToNewtonChat: protectedProcedure
14
+ .input(z.object({
15
+ newtonChatId: z.string(),
16
+ content: z.string().min(1).max(4000),
17
+ mentionedUserIds: z.array(z.string()).optional(),
18
+ }))
19
+ .mutation(({ ctx, input }) => postToNewtonChat(ctx.user.id, input.newtonChatId, input.content, input.mentionedUserIds ?? [])),
20
+ });
21
+ //# sourceMappingURL=newtonChat.js.map
22
+ //# debugId=9a20639c-ff71-5a5a-92be-013861f4ac53
@@ -0,0 +1 @@
1
+ {"version":3,"file":"newtonChat.js","sources":["routers/newtonChat.ts"],"sourceRoot":"/","sourcesContent":["import { z } from \"zod\";\nimport { createTRPCRouter, protectedProcedure } from \"../trpc.js\";\nimport {\n getTutorConversation,\n postToNewtonChat,\n} from \"../services/newtonChat.js\";\n\nexport const newtonChatRouter = createTRPCRouter({\n getTutorConversation: protectedProcedure\n .input(\n z.object({\n assignmentId: z.string(),\n classId: z.string(),\n })\n )\n .query(({ ctx, input }) =>\n getTutorConversation(ctx.user!.id, input.assignmentId, input.classId)\n ),\n\n postToNewtonChat: protectedProcedure\n .input(\n z.object({\n newtonChatId: z.string(),\n content: z.string().min(1).max(4000),\n mentionedUserIds: z.array(z.string()).optional(),\n })\n )\n .mutation(({ ctx, input }) =>\n postToNewtonChat(\n ctx.user!.id,\n input.newtonChatId,\n input.content,\n input.mentionedUserIds ?? []\n )\n ),\n});\n"],"names":[],"mappings":";;AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAClE,OAAO,EACL,oBAAoB,EACpB,gBAAgB,GACjB,MAAM,2BAA2B,CAAC;AAEnC,MAAM,CAAC,MAAM,gBAAgB,GAAG,gBAAgB,CAAC;IAC/C,oBAAoB,EAAE,kBAAkB;SACrC,KAAK,CACJ,CAAC,CAAC,MAAM,CAAC;QACP,YAAY,EAAE,CAAC,CAAC,MAAM,EAAE;QACxB,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE;KACpB,CAAC,CACH;SACA,KAAK,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,EAAE,CACxB,oBAAoB,CAAC,GAAG,CAAC,IAAK,CAAC,EAAE,EAAE,KAAK,CAAC,YAAY,EAAE,KAAK,CAAC,OAAO,CAAC,CACtE;IAEH,gBAAgB,EAAE,kBAAkB;SACjC,KAAK,CACJ,CAAC,CAAC,MAAM,CAAC;QACP,YAAY,EAAE,CAAC,CAAC,MAAM,EAAE;QACxB,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC;QACpC,gBAAgB,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE;KACjD,CAAC,CACH;SACA,QAAQ,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,EAAE,CAC3B,gBAAgB,CACd,GAAG,CAAC,IAAK,CAAC,EAAE,EACZ,KAAK,CAAC,YAAY,EAClB,KAAK,CAAC,OAAO,EACb,KAAK,CAAC,gBAAgB,IAAI,EAAE,CAC7B,CACF;CACJ,CAAC,CAAC","debug_id":"9a20639c-ff71-5a5a-92be-013861f4ac53"}