@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.
- package/.coderabbit.yaml +9 -0
- package/.env.example +9 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +102 -8
- package/dist/index.js.map +1 -1
- package/dist/lib/config/env.d.ts +21 -0
- package/dist/lib/config/env.d.ts.map +1 -1
- package/dist/lib/config/env.js +8 -2
- package/dist/lib/config/env.js.map +1 -1
- package/dist/lib/fileUpload.d.ts.map +1 -1
- package/dist/lib/fileUpload.js +2 -2
- package/dist/lib/fileUpload.js.map +1 -1
- package/dist/lib/googleCloudStorage.d.ts +6 -0
- package/dist/lib/googleCloudStorage.d.ts.map +1 -1
- package/dist/lib/googleCloudStorage.js +19 -2
- package/dist/lib/googleCloudStorage.js.map +1 -1
- package/dist/lib/pusher.d.ts +4 -1
- package/dist/lib/pusher.d.ts.map +1 -1
- package/dist/lib/pusher.js +6 -3
- package/dist/lib/pusher.js.map +1 -1
- package/dist/lib/redis.d.ts +5 -0
- package/dist/lib/redis.d.ts.map +1 -0
- package/dist/lib/redis.js +53 -0
- package/dist/lib/redis.js.map +1 -0
- package/dist/lib/thumbnailGenerator.d.ts +0 -21
- package/dist/lib/thumbnailGenerator.d.ts.map +1 -1
- package/dist/lib/thumbnailGenerator.js +157 -160
- package/dist/lib/thumbnailGenerator.js.map +1 -1
- package/dist/middleware/auth.d.ts.map +1 -1
- package/dist/middleware/auth.js +36 -94
- package/dist/middleware/auth.js.map +1 -1
- package/dist/models/agenda.d.ts +97 -0
- package/dist/models/agenda.d.ts.map +1 -0
- package/dist/models/agenda.js +40 -0
- package/dist/models/agenda.js.map +1 -0
- package/dist/models/announcement.d.ts +223 -0
- package/dist/models/announcement.d.ts.map +1 -0
- package/dist/models/announcement.js +120 -0
- package/dist/models/announcement.js.map +1 -0
- package/dist/models/assignment.d.ts +1292 -0
- package/dist/models/assignment.d.ts.map +1 -0
- package/dist/models/assignment.js +309 -0
- package/dist/models/assignment.js.map +1 -0
- package/dist/models/attendance.d.ts +180 -0
- package/dist/models/attendance.d.ts.map +1 -0
- package/dist/models/attendance.js +188 -0
- package/dist/models/attendance.js.map +1 -0
- package/dist/models/auth.d.ts +153 -0
- package/dist/models/auth.d.ts.map +1 -0
- package/dist/models/auth.js +217 -0
- package/dist/models/auth.js.map +1 -0
- package/dist/models/class.d.ts +439 -0
- package/dist/models/class.d.ts.map +1 -0
- package/dist/models/class.js +546 -0
- package/dist/models/class.js.map +1 -0
- package/dist/models/comment.d.ts +171 -0
- package/dist/models/comment.d.ts.map +1 -0
- package/dist/models/comment.js +138 -0
- package/dist/models/comment.js.map +1 -0
- package/dist/models/conversation.d.ts +164 -0
- package/dist/models/conversation.d.ts.map +1 -0
- package/dist/models/conversation.js +175 -0
- package/dist/models/conversation.js.map +1 -0
- package/dist/models/event.d.ts +295 -0
- package/dist/models/event.d.ts.map +1 -0
- package/dist/models/event.js +145 -0
- package/dist/models/event.js.map +1 -0
- package/dist/models/file.d.ts +536 -0
- package/dist/models/file.d.ts.map +1 -0
- package/dist/models/file.js +126 -0
- package/dist/models/file.js.map +1 -0
- package/dist/models/folder.d.ts +295 -0
- package/dist/models/folder.d.ts.map +1 -0
- package/dist/models/folder.js +202 -0
- package/dist/models/folder.js.map +1 -0
- package/dist/models/labChat.d.ts +243 -0
- package/dist/models/labChat.d.ts.map +1 -0
- package/dist/models/labChat.js +204 -0
- package/dist/models/labChat.js.map +1 -0
- package/dist/models/marketing.d.ts +72 -0
- package/dist/models/marketing.d.ts.map +1 -0
- package/dist/models/marketing.js +26 -0
- package/dist/models/marketing.js.map +1 -0
- package/dist/models/message.d.ts +100 -0
- package/dist/models/message.d.ts.map +1 -0
- package/dist/models/message.js +131 -0
- package/dist/models/message.js.map +1 -0
- package/dist/models/newtonChat.d.ts +72 -0
- package/dist/models/newtonChat.d.ts.map +1 -0
- package/dist/models/newtonChat.js +61 -0
- package/dist/models/newtonChat.js.map +1 -0
- package/dist/models/notification.d.ts +65 -0
- package/dist/models/notification.d.ts.map +1 -0
- package/dist/models/notification.js +46 -0
- package/dist/models/notification.js.map +1 -0
- package/dist/models/section.d.ts +102 -0
- package/dist/models/section.d.ts.map +1 -0
- package/dist/models/section.js +83 -0
- package/dist/models/section.js.map +1 -0
- package/dist/models/user.d.ts +39 -0
- package/dist/models/user.d.ts.map +1 -0
- package/dist/models/user.js +38 -0
- package/dist/models/user.js.map +1 -0
- package/dist/models/worksheet.d.ts +460 -0
- package/dist/models/worksheet.d.ts.map +1 -0
- package/dist/models/worksheet.js +200 -0
- package/dist/models/worksheet.js.map +1 -0
- package/dist/pipelines/aiLabChat.d.ts +21 -0
- package/dist/pipelines/aiLabChat.d.ts.map +1 -0
- package/dist/pipelines/aiLabChat.js +460 -0
- package/dist/pipelines/aiLabChat.js.map +1 -0
- package/dist/pipelines/aiNewtonChat.d.ts +30 -0
- package/dist/pipelines/aiNewtonChat.d.ts.map +1 -0
- package/dist/pipelines/aiNewtonChat.js +289 -0
- package/dist/pipelines/aiNewtonChat.js.map +1 -0
- package/dist/pipelines/gradeWorksheet.d.ts +30 -0
- package/dist/pipelines/gradeWorksheet.d.ts.map +1 -0
- package/dist/pipelines/gradeWorksheet.js +252 -0
- package/dist/pipelines/gradeWorksheet.js.map +1 -0
- package/dist/routers/_app.d.ts +1399 -1271
- package/dist/routers/_app.d.ts.map +1 -1
- package/dist/routers/agenda.d.ts +22 -22
- package/dist/routers/agenda.d.ts.map +1 -1
- package/dist/routers/agenda.js +4 -65
- package/dist/routers/agenda.js.map +1 -1
- package/dist/routers/announcement.d.ts +16 -16
- package/dist/routers/announcement.d.ts.map +1 -1
- package/dist/routers/announcement.js +37 -446
- package/dist/routers/announcement.js.map +1 -1
- package/dist/routers/assignment.d.ts +300 -378
- package/dist/routers/assignment.d.ts.map +1 -1
- package/dist/routers/assignment.js +78 -1868
- package/dist/routers/assignment.js.map +1 -1
- package/dist/routers/attendance.d.ts +19 -9
- package/dist/routers/attendance.d.ts.map +1 -1
- package/dist/routers/attendance.js +7 -264
- package/dist/routers/attendance.js.map +1 -1
- package/dist/routers/auth.d.ts +2 -2
- package/dist/routers/auth.d.ts.map +1 -1
- package/dist/routers/auth.js +29 -354
- package/dist/routers/auth.js.map +1 -1
- package/dist/routers/class.d.ts +140 -68
- package/dist/routers/class.d.ts.map +1 -1
- package/dist/routers/class.js +82 -1051
- package/dist/routers/class.js.map +1 -1
- package/dist/routers/comment.d.ts +6 -42
- package/dist/routers/comment.d.ts.map +1 -1
- package/dist/routers/comment.js +24 -244
- package/dist/routers/comment.js.map +1 -1
- package/dist/routers/conversation.d.ts +45 -7
- package/dist/routers/conversation.d.ts.map +1 -1
- package/dist/routers/conversation.js +19 -327
- package/dist/routers/conversation.js.map +1 -1
- package/dist/routers/event.d.ts +36 -36
- package/dist/routers/event.d.ts.map +1 -1
- package/dist/routers/event.js +13 -433
- package/dist/routers/event.js.map +1 -1
- package/dist/routers/file.d.ts +2 -2
- package/dist/routers/file.d.ts.map +1 -1
- package/dist/routers/file.js +9 -323
- package/dist/routers/file.js.map +1 -1
- package/dist/routers/folder.d.ts +21 -14
- package/dist/routers/folder.d.ts.map +1 -1
- package/dist/routers/folder.js +34 -745
- package/dist/routers/folder.js.map +1 -1
- package/dist/routers/labChat.d.ts +11 -10
- package/dist/routers/labChat.d.ts.map +1 -1
- package/dist/routers/labChat.js +19 -570
- package/dist/routers/labChat.js.map +1 -1
- package/dist/routers/marketing.d.ts +1 -1
- package/dist/routers/marketing.d.ts.map +1 -1
- package/dist/routers/marketing.js +7 -56
- package/dist/routers/marketing.js.map +1 -1
- package/dist/routers/message.d.ts +2 -2
- package/dist/routers/message.d.ts.map +1 -1
- package/dist/routers/message.js +27 -522
- package/dist/routers/message.js.map +1 -1
- package/dist/routers/newtonChat.d.ts +1 -1
- package/dist/routers/newtonChat.d.ts.map +1 -1
- package/dist/routers/newtonChat.js +7 -246
- package/dist/routers/newtonChat.js.map +1 -1
- package/dist/routers/notifications.d.ts +4 -4
- package/dist/routers/notifications.d.ts.map +1 -1
- package/dist/routers/notifications.js +18 -83
- package/dist/routers/notifications.js.map +1 -1
- package/dist/routers/section.d.ts +4 -4
- package/dist/routers/section.d.ts.map +1 -1
- package/dist/routers/section.js +14 -286
- package/dist/routers/section.js.map +1 -1
- package/dist/routers/user.d.ts +1 -1
- package/dist/routers/user.d.ts.map +1 -1
- package/dist/routers/user.js +32 -207
- package/dist/routers/user.js.map +1 -1
- package/dist/routers/worksheet.d.ts +51 -38
- package/dist/routers/worksheet.d.ts.map +1 -1
- package/dist/routers/worksheet.js +79 -394
- package/dist/routers/worksheet.js.map +1 -1
- package/dist/seedDatabase.d.ts +1 -1
- package/dist/server/pipelines/aiNewtonChat.d.ts.map +1 -1
- package/dist/server/pipelines/aiNewtonChat.js +8 -3
- package/dist/server/pipelines/aiNewtonChat.js.map +1 -1
- package/dist/server/pipelines/gradeWorksheet.d.ts +6 -6
- package/dist/server/pipelines/gradeWorksheet.d.ts.map +1 -1
- package/dist/server/pipelines/gradeWorksheet.js +12 -5
- package/dist/server/pipelines/gradeWorksheet.js.map +1 -1
- package/dist/services/agenda.d.ts +100 -0
- package/dist/services/agenda.d.ts.map +1 -0
- package/dist/services/agenda.js +21 -0
- package/dist/services/agenda.js.map +1 -0
- package/dist/services/announcement.d.ts +135 -0
- package/dist/services/announcement.d.ts.map +1 -0
- package/dist/services/announcement.js +223 -0
- package/dist/services/announcement.js.map +1 -0
- package/dist/services/assignment.d.ts +1462 -0
- package/dist/services/assignment.d.ts.map +1 -0
- package/dist/services/assignment.js +898 -0
- package/dist/services/assignment.js.map +1 -0
- package/dist/services/attendance.d.ts +93 -0
- package/dist/services/attendance.d.ts.map +1 -0
- package/dist/services/attendance.js +61 -0
- package/dist/services/attendance.js.map +1 -0
- package/dist/services/auth.d.ts +68 -0
- package/dist/services/auth.d.ts.map +1 -0
- package/dist/services/auth.js +218 -0
- package/dist/services/auth.js.map +1 -0
- package/dist/services/class.d.ts +621 -0
- package/dist/services/class.d.ts.map +1 -0
- package/dist/services/class.js +474 -0
- package/dist/services/class.js.map +1 -0
- package/dist/services/comment.d.ts +100 -0
- package/dist/services/comment.d.ts.map +1 -0
- package/dist/services/comment.js +83 -0
- package/dist/services/comment.js.map +1 -0
- package/dist/services/conversation.d.ts +159 -0
- package/dist/services/conversation.d.ts.map +1 -0
- package/dist/services/conversation.js +138 -0
- package/dist/services/conversation.js.map +1 -0
- package/dist/services/event.d.ts +216 -0
- package/dist/services/event.d.ts.map +1 -0
- package/dist/services/event.js +168 -0
- package/dist/services/event.js.map +1 -0
- package/dist/services/file.d.ts +74 -0
- package/dist/services/file.d.ts.map +1 -0
- package/dist/services/file.js +133 -0
- package/dist/services/file.js.map +1 -0
- package/dist/services/folder.d.ts +239 -0
- package/dist/services/folder.d.ts.map +1 -0
- package/dist/services/folder.js +248 -0
- package/dist/services/folder.js.map +1 -0
- package/dist/services/labChat.d.ts +165 -0
- package/dist/services/labChat.d.ts.map +1 -0
- package/dist/services/labChat.js +289 -0
- package/dist/services/labChat.js.map +1 -0
- package/dist/services/marketing.d.ts +50 -0
- package/dist/services/marketing.d.ts.map +1 -0
- package/dist/services/marketing.js +32 -0
- package/dist/services/marketing.js.map +1 -0
- package/dist/services/message.d.ts +95 -0
- package/dist/services/message.d.ts.map +1 -0
- package/dist/services/message.js +350 -0
- package/dist/services/message.js.map +1 -0
- package/dist/services/newtonChat.d.ts +22 -0
- package/dist/services/newtonChat.d.ts.map +1 -0
- package/dist/services/newtonChat.js +174 -0
- package/dist/services/newtonChat.js.map +1 -0
- package/dist/services/notification.d.ts +65 -0
- package/dist/services/notification.d.ts.map +1 -0
- package/dist/services/notification.js +33 -0
- package/dist/services/notification.js.map +1 -0
- package/dist/services/section.d.ts +53 -0
- package/dist/services/section.d.ts.map +1 -0
- package/dist/services/section.js +199 -0
- package/dist/services/section.js.map +1 -0
- package/dist/services/user.d.ts +48 -0
- package/dist/services/user.d.ts.map +1 -0
- package/dist/services/user.js +141 -0
- package/dist/services/user.js.map +1 -0
- package/dist/services/worksheet.d.ts +239 -0
- package/dist/services/worksheet.d.ts.map +1 -0
- package/dist/services/worksheet.js +235 -0
- package/dist/services/worksheet.js.map +1 -0
- package/dist/utils/aiUser.d.ts +1 -3
- package/dist/utils/aiUser.d.ts.map +1 -1
- package/dist/utils/aiUser.js +6 -5
- package/dist/utils/aiUser.js.map +1 -1
- package/dist/utils/email.d.ts +3 -0
- package/dist/utils/email.d.ts.map +1 -1
- package/dist/utils/email.js +7 -4
- package/dist/utils/email.js.map +1 -1
- package/dist/utils/generateInviteCode.d.ts +1 -2
- package/dist/utils/generateInviteCode.d.ts.map +1 -1
- package/dist/utils/generateInviteCode.js +3 -4
- package/dist/utils/generateInviteCode.js.map +1 -1
- package/dist/utils/inference.d.ts +3 -0
- package/dist/utils/inference.d.ts.map +1 -1
- package/dist/utils/inference.js +7 -4
- package/dist/utils/inference.js.map +1 -1
- package/dist/utils/logger.d.ts +3 -0
- package/dist/utils/logger.d.ts.map +1 -1
- package/dist/utils/logger.js +5 -2
- package/dist/utils/logger.js.map +1 -1
- package/dist/utils/prismaErrorHandler.d.ts.map +1 -1
- package/dist/utils/prismaErrorHandler.js +5 -2
- package/dist/utils/prismaErrorHandler.js.map +1 -1
- package/dist/utils/prismaWrapper.d.ts +1 -0
- package/dist/utils/prismaWrapper.d.ts.map +1 -1
- package/dist/utils/prismaWrapper.js +6 -2
- package/dist/utils/prismaWrapper.js.map +1 -1
- package/docker-compose.yml +5 -0
- package/package.json +4 -3
- package/src/index.ts +119 -12
- package/src/lib/config/env.ts +6 -0
- package/src/lib/fileUpload.ts +0 -1
- package/src/lib/googleCloudStorage.ts +17 -0
- package/src/lib/pusher.ts +5 -1
- package/src/lib/redis.ts +56 -0
- package/src/lib/thumbnailGenerator.ts +170 -168
- package/src/middleware/auth.ts +83 -136
- package/src/models/agenda.ts +46 -0
- package/src/models/announcement.ts +134 -0
- package/src/models/assignment.ts +322 -0
- package/src/models/attendance.ts +208 -0
- package/src/models/auth.ts +247 -0
- package/src/models/class.ts +598 -0
- package/src/models/comment.ts +152 -0
- package/src/models/conversation.ts +200 -0
- package/src/models/event.ts +177 -0
- package/src/models/file.ts +129 -0
- package/src/models/folder.ts +225 -0
- package/src/models/labChat.ts +213 -0
- package/src/models/marketing.ts +45 -0
- package/src/models/message.ts +153 -0
- package/src/models/newtonChat.ts +70 -0
- package/src/models/notification.ts +54 -0
- package/src/models/section.ts +98 -0
- package/src/models/user.ts +47 -0
- package/src/models/worksheet.ts +294 -0
- package/src/{server/pipelines → pipelines}/aiLabChat.ts +11 -7
- package/src/{server/pipelines → pipelines}/aiNewtonChat.ts +15 -6
- package/src/{server/pipelines → pipelines}/gradeWorksheet.ts +25 -14
- package/src/routers/agenda.ts +3 -66
- package/src/routers/announcement.ts +54 -495
- package/src/routers/assignment.ts +126 -2018
- package/src/routers/attendance.ts +15 -276
- package/src/routers/auth.ts +79 -442
- package/src/routers/class.ts +263 -1186
- package/src/routers/comment.ts +61 -288
- package/src/routers/conversation.ts +51 -360
- package/src/routers/event.ts +50 -481
- package/src/routers/file.ts +45 -368
- package/src/routers/folder.ts +107 -836
- package/src/routers/labChat.ts +29 -605
- package/src/routers/marketing.ts +35 -77
- package/src/routers/message.ts +45 -571
- package/src/routers/newtonChat.ts +17 -278
- package/src/routers/notifications.ts +32 -82
- package/src/routers/section.ts +46 -330
- package/src/routers/user.ts +49 -227
- package/src/routers/worksheet.ts +215 -503
- package/src/services/agenda.ts +21 -0
- package/src/services/announcement.ts +290 -0
- package/src/services/assignment.ts +1198 -0
- package/src/services/attendance.ts +85 -0
- package/src/services/auth.ts +277 -0
- package/src/services/class.ts +622 -0
- package/src/services/comment.ts +106 -0
- package/src/services/conversation.ts +213 -0
- package/src/services/event.ts +231 -0
- package/src/services/file.ts +167 -0
- package/src/services/folder.ts +316 -0
- package/src/services/labChat.ts +352 -0
- package/src/services/marketing.ts +57 -0
- package/src/services/message.ts +461 -0
- package/src/services/newtonChat.ts +222 -0
- package/src/services/notification.ts +50 -0
- package/src/services/section.ts +283 -0
- package/src/services/user.ts +172 -0
- package/src/services/worksheet.ts +358 -0
- package/src/utils/aiUser.ts +4 -3
- package/src/utils/email.ts +5 -3
- package/src/utils/generateInviteCode.ts +1 -3
- package/src/utils/inference.ts +5 -2
- package/src/utils/logger.ts +3 -1
- package/src/utils/prismaErrorHandler.ts +3 -0
- package/src/utils/prismaWrapper.ts +4 -0
- package/tests/globalSetup.ts +62 -0
- package/tests/helpers.ts +22 -0
- package/tests/middleware/security.test.ts +42 -0
- package/tests/routers/agenda.test.ts +138 -0
- package/tests/routers/announcement.test.ts +490 -0
- package/tests/routers/assignment.test.ts +837 -0
- package/tests/{attendance.test.ts → routers/attendance.test.ts} +6 -14
- package/tests/routers/auth.test.ts +171 -0
- package/tests/{class.test.ts → routers/class.test.ts} +131 -85
- package/tests/routers/comment.test.ts +126 -0
- package/tests/routers/conversation.test.ts +145 -0
- package/tests/{event.test.ts → routers/event.test.ts} +93 -32
- package/tests/routers/folder.test.ts +178 -0
- package/tests/routers/labChat.test.ts +115 -0
- package/tests/routers/marketing.test.ts +59 -0
- package/tests/routers/message.test.ts +123 -0
- package/tests/routers/notification.test.ts +69 -0
- package/tests/{section.test.ts → routers/section.test.ts} +5 -13
- package/tests/server/rateLimit.test.ts +73 -0
- package/tests/setup.ts +18 -92
- package/tests/user.test.ts +9 -31
- package/tests/utils/aiUser.test.ts +22 -0
- package/tests/utils/generateInviteCode.test.ts +24 -0
- package/tests/utils/logger.test.ts +74 -0
- package/tests/utils/prismaErrorHandler.test.ts +101 -0
- package/tests/utils/prismaWrapper.test.ts +82 -0
- package/tests/worksheet.test.ts +181 -0
- package/vitest.config.ts +6 -3
- package/vitest.unit.config.ts +21 -0
- package/TODO.md +0 -2
- package/coverage/base.css +0 -224
- package/coverage/block-navigation.js +0 -87
- package/coverage/clover.xml +0 -12110
- package/coverage/coverage-final.json +0 -44
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +0 -221
- package/coverage/prettify.css +0 -1
- package/coverage/prettify.js +0 -2
- package/coverage/server/index.html +0 -116
- package/coverage/server/src/exportType.ts.html +0 -109
- package/coverage/server/src/index.html +0 -161
- package/coverage/server/src/index.ts.html +0 -1702
- package/coverage/server/src/instrument.ts.html +0 -130
- package/coverage/server/src/lib/config/env.ts.html +0 -448
- package/coverage/server/src/lib/config/index.html +0 -116
- package/coverage/server/src/lib/fileUpload.ts.html +0 -1138
- package/coverage/server/src/lib/googleCloudStorage.ts.html +0 -334
- package/coverage/server/src/lib/index.html +0 -206
- package/coverage/server/src/lib/jsonConversion.ts.html +0 -2323
- package/coverage/server/src/lib/jsonStyles.ts.html +0 -193
- package/coverage/server/src/lib/notificationHandler.ts.html +0 -193
- package/coverage/server/src/lib/pusher.ts.html +0 -121
- package/coverage/server/src/lib/thumbnailGenerator.ts.html +0 -592
- package/coverage/server/src/middleware/auth.ts.html +0 -646
- package/coverage/server/src/middleware/index.html +0 -146
- package/coverage/server/src/middleware/logging.ts.html +0 -244
- package/coverage/server/src/middleware/security.ts.html +0 -271
- package/coverage/server/src/routers/_app.ts.html +0 -232
- package/coverage/server/src/routers/agenda.ts.html +0 -319
- package/coverage/server/src/routers/announcement.ts.html +0 -3481
- package/coverage/server/src/routers/assignment.ts.html +0 -7633
- package/coverage/server/src/routers/attendance.ts.html +0 -1030
- package/coverage/server/src/routers/auth.ts.html +0 -1081
- package/coverage/server/src/routers/class.ts.html +0 -3535
- package/coverage/server/src/routers/comment.ts.html +0 -991
- package/coverage/server/src/routers/conversation.ts.html +0 -982
- package/coverage/server/src/routers/event.ts.html +0 -1609
- package/coverage/server/src/routers/file.ts.html +0 -1144
- package/coverage/server/src/routers/folder.ts.html +0 -2797
- package/coverage/server/src/routers/index.html +0 -386
- package/coverage/server/src/routers/labChat.ts.html +0 -3073
- package/coverage/server/src/routers/marketing.ts.html +0 -340
- package/coverage/server/src/routers/message.ts.html +0 -1912
- package/coverage/server/src/routers/notifications.ts.html +0 -364
- package/coverage/server/src/routers/section.ts.html +0 -1120
- package/coverage/server/src/routers/user.ts.html +0 -862
- package/coverage/server/src/routers/worksheet.ts.html +0 -1729
- package/coverage/server/src/trpc.ts.html +0 -397
- package/coverage/server/src/types/index.html +0 -116
- package/coverage/server/src/types/trpc.ts.html +0 -127
- package/coverage/server/src/utils/aiUser.ts.html +0 -280
- package/coverage/server/src/utils/email.ts.html +0 -121
- package/coverage/server/src/utils/generateInviteCode.ts.html +0 -106
- package/coverage/server/src/utils/index.html +0 -206
- package/coverage/server/src/utils/inference.ts.html +0 -709
- package/coverage/server/src/utils/logger.ts.html +0 -664
- package/coverage/server/src/utils/prismaErrorHandler.ts.html +0 -907
- package/coverage/server/src/utils/prismaWrapper.ts.html +0 -355
- package/coverage/server/vitest.config.ts.html +0 -196
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +0 -210
- package/src/lib/notificationHandler.ts +0 -36
- package/tests/announcement.test.ts +0 -164
- package/tests/assignment.test.ts +0 -296
- package/tests/auth.test.ts +0 -48
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Comment service – get comments, replies, and reactions. Used for announcements and worksheets.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
!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]="381af507-0513-5413-ae9b-6bcb211761ee")}catch(e){}}();
|
|
6
|
+
import { TRPCError } from "@trpc/server";
|
|
7
|
+
import { findCommentById, findRepliesByCommentId, createComment, findReactionByUserAndComment, upsertReaction, deleteReactionById, findCommentWithAnnouncement, getReactionCountsByCommentId, } from "../models/comment.js";
|
|
8
|
+
/** Get a comment by ID. */
|
|
9
|
+
export async function getComment(id) {
|
|
10
|
+
const comment = await findCommentById(id);
|
|
11
|
+
if (!comment) {
|
|
12
|
+
throw new TRPCError({
|
|
13
|
+
code: "NOT_FOUND",
|
|
14
|
+
message: "Comment not found",
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
return comment;
|
|
18
|
+
}
|
|
19
|
+
/** Get all replies to a comment. */
|
|
20
|
+
export async function getReplies(commentId) {
|
|
21
|
+
return findRepliesByCommentId(commentId);
|
|
22
|
+
}
|
|
23
|
+
/** Create a reply to an existing comment. */
|
|
24
|
+
export async function replyToComment(userId, parentCommentId, content) {
|
|
25
|
+
return createComment({
|
|
26
|
+
parentCommentId,
|
|
27
|
+
content,
|
|
28
|
+
authorId: userId,
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
/** Add or update a reaction (emoji) on a comment. */
|
|
32
|
+
export async function addReaction(userId, commentId, type) {
|
|
33
|
+
const comment = await findCommentById(commentId);
|
|
34
|
+
if (!comment) {
|
|
35
|
+
throw new TRPCError({
|
|
36
|
+
code: "INTERNAL_SERVER_ERROR",
|
|
37
|
+
message: "Unexpected error",
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
const reaction = await upsertReaction({ userId, commentId, type });
|
|
41
|
+
return { reaction };
|
|
42
|
+
}
|
|
43
|
+
/** Remove user's reaction from a comment. */
|
|
44
|
+
export async function removeReaction(userId, commentId) {
|
|
45
|
+
const reaction = await findReactionByUserAndComment(userId, commentId);
|
|
46
|
+
if (!reaction) {
|
|
47
|
+
throw new TRPCError({
|
|
48
|
+
code: "NOT_FOUND",
|
|
49
|
+
message: "Reaction not found",
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
await deleteReactionById(reaction.id);
|
|
53
|
+
return { success: true };
|
|
54
|
+
}
|
|
55
|
+
export async function getReactions(userId, commentId) {
|
|
56
|
+
const comment = await findCommentWithAnnouncement(commentId);
|
|
57
|
+
if (!comment) {
|
|
58
|
+
throw new TRPCError({
|
|
59
|
+
code: "NOT_FOUND",
|
|
60
|
+
message: "Comment not found",
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
const reactionCounts = await getReactionCountsByCommentId(commentId);
|
|
64
|
+
const userReaction = await findReactionByUserAndComment(userId, commentId);
|
|
65
|
+
const counts = {
|
|
66
|
+
THUMBSUP: 0,
|
|
67
|
+
CELEBRATE: 0,
|
|
68
|
+
CARE: 0,
|
|
69
|
+
HEART: 0,
|
|
70
|
+
IDEA: 0,
|
|
71
|
+
HAPPY: 0,
|
|
72
|
+
};
|
|
73
|
+
reactionCounts.forEach((item) => {
|
|
74
|
+
counts[item.type] = item._count.type;
|
|
75
|
+
});
|
|
76
|
+
return {
|
|
77
|
+
counts,
|
|
78
|
+
userReaction: userReaction?.type || null,
|
|
79
|
+
total: reactionCounts.reduce((sum, item) => sum + item._count.type, 0),
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=comment.js.map
|
|
83
|
+
//# debugId=381af507-0513-5413-ae9b-6bcb211761ee
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"comment.js","sources":["services/comment.ts"],"sourceRoot":"/","sourcesContent":["/**\n * Comment service – get comments, replies, and reactions. Used for announcements and worksheets.\n */\nimport { TRPCError } from \"@trpc/server\";\nimport {\n findCommentById,\n findRepliesByCommentId,\n createComment,\n findReactionByUserAndComment,\n upsertReaction,\n deleteReactionById,\n findCommentWithAnnouncement,\n getReactionCountsByCommentId,\n} from \"../models/comment.js\";\n\n/** Get a comment by ID. */\nexport async function getComment(id: string) {\n const comment = await findCommentById(id);\n if (!comment) {\n throw new TRPCError({\n code: \"NOT_FOUND\",\n message: \"Comment not found\",\n });\n }\n return comment;\n}\n\n/** Get all replies to a comment. */\nexport async function getReplies(commentId: string) {\n return findRepliesByCommentId(commentId);\n}\n\n/** Create a reply to an existing comment. */\nexport async function replyToComment(\n userId: string,\n parentCommentId: string,\n content: string\n) {\n return createComment({\n parentCommentId,\n content,\n authorId: userId,\n });\n}\n\n/** Add or update a reaction (emoji) on a comment. */\nexport async function addReaction(\n userId: string,\n commentId: string,\n type: string\n) {\n const comment = await findCommentById(commentId);\n if (!comment) {\n throw new TRPCError({\n code: \"INTERNAL_SERVER_ERROR\",\n message: \"Unexpected error\",\n });\n }\n\n const reaction = await upsertReaction({ userId, commentId, type });\n return { reaction };\n}\n\n/** Remove user's reaction from a comment. */\nexport async function removeReaction(userId: string, commentId: string) {\n const reaction = await findReactionByUserAndComment(userId, commentId);\n if (!reaction) {\n throw new TRPCError({\n code: \"NOT_FOUND\",\n message: \"Reaction not found\",\n });\n }\n await deleteReactionById(reaction.id);\n return { success: true };\n}\n\nexport async function getReactions(userId: string, commentId: string) {\n const comment = await findCommentWithAnnouncement(commentId);\n if (!comment) {\n throw new TRPCError({\n code: \"NOT_FOUND\",\n message: \"Comment not found\",\n });\n }\n\n const reactionCounts = await getReactionCountsByCommentId(commentId);\n const userReaction = await findReactionByUserAndComment(userId, commentId);\n\n const counts = {\n THUMBSUP: 0,\n CELEBRATE: 0,\n CARE: 0,\n HEART: 0,\n IDEA: 0,\n HAPPY: 0,\n };\n reactionCounts.forEach((item) => {\n counts[item.type as keyof typeof counts] = item._count.type;\n });\n\n return {\n counts,\n userReaction: userReaction?.type || null,\n total: reactionCounts.reduce((sum, item) => sum + item._count.type, 0),\n };\n}\n"],"names":[],"mappings":"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","debug_id":"381af507-0513-5413-ae9b-6bcb211761ee"}
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
/** List user's conversations with unread and mention counts. */
|
|
2
|
+
export declare function listConversations(userId: string): Promise<{
|
|
3
|
+
id: string;
|
|
4
|
+
type: import(".prisma/client").$Enums.ConversationType;
|
|
5
|
+
name: string | null;
|
|
6
|
+
createdAt: Date;
|
|
7
|
+
updatedAt: Date;
|
|
8
|
+
labChat: {
|
|
9
|
+
id: string;
|
|
10
|
+
title: string;
|
|
11
|
+
} | null;
|
|
12
|
+
members: ({
|
|
13
|
+
user: {
|
|
14
|
+
id: string;
|
|
15
|
+
username: string;
|
|
16
|
+
profile: {
|
|
17
|
+
displayName: string | null;
|
|
18
|
+
profilePicture: string | null;
|
|
19
|
+
} | null;
|
|
20
|
+
};
|
|
21
|
+
} & {
|
|
22
|
+
id: string;
|
|
23
|
+
role: import(".prisma/client").$Enums.ConversationRole;
|
|
24
|
+
userId: string;
|
|
25
|
+
conversationId: string;
|
|
26
|
+
joinedAt: Date;
|
|
27
|
+
lastViewedAt: Date | null;
|
|
28
|
+
lastViewedMentionAt: Date | null;
|
|
29
|
+
})[];
|
|
30
|
+
lastMessage: {
|
|
31
|
+
sender: {
|
|
32
|
+
id: string;
|
|
33
|
+
username: string;
|
|
34
|
+
profile: {
|
|
35
|
+
displayName: string | null;
|
|
36
|
+
} | null;
|
|
37
|
+
};
|
|
38
|
+
} & {
|
|
39
|
+
status: import(".prisma/client").$Enums.GenerationStatus | null;
|
|
40
|
+
id: string;
|
|
41
|
+
createdAt: Date;
|
|
42
|
+
meta: import("@prisma/client/runtime/library.js").JsonValue | null;
|
|
43
|
+
content: string;
|
|
44
|
+
conversationId: string;
|
|
45
|
+
senderId: string;
|
|
46
|
+
};
|
|
47
|
+
unreadCount: number;
|
|
48
|
+
unreadMentionCount: number;
|
|
49
|
+
}[]>;
|
|
50
|
+
/** Create a DM or group conversation with the given members. */
|
|
51
|
+
export declare function createConversationRecord(userId: string, type: "DM" | "GROUP", name: string | undefined, memberIds: string[]): Promise<{
|
|
52
|
+
members: ({
|
|
53
|
+
user: {
|
|
54
|
+
id: string;
|
|
55
|
+
username: string;
|
|
56
|
+
profile: {
|
|
57
|
+
displayName: string | null;
|
|
58
|
+
profilePicture: string | null;
|
|
59
|
+
} | null;
|
|
60
|
+
};
|
|
61
|
+
} & {
|
|
62
|
+
id: string;
|
|
63
|
+
role: import(".prisma/client").$Enums.ConversationRole;
|
|
64
|
+
userId: string;
|
|
65
|
+
conversationId: string;
|
|
66
|
+
joinedAt: Date;
|
|
67
|
+
lastViewedAt: Date | null;
|
|
68
|
+
lastViewedMentionAt: Date | null;
|
|
69
|
+
})[];
|
|
70
|
+
} & {
|
|
71
|
+
type: import(".prisma/client").$Enums.ConversationType;
|
|
72
|
+
id: string;
|
|
73
|
+
createdAt: Date;
|
|
74
|
+
updatedAt: Date;
|
|
75
|
+
name: string | null;
|
|
76
|
+
displayInChat: boolean;
|
|
77
|
+
}>;
|
|
78
|
+
export declare function getConversation(userId: string, conversationId: string): Promise<{
|
|
79
|
+
members: ({
|
|
80
|
+
user: {
|
|
81
|
+
id: string;
|
|
82
|
+
username: string;
|
|
83
|
+
profile: {
|
|
84
|
+
displayName: string | null;
|
|
85
|
+
profilePicture: string | null;
|
|
86
|
+
} | null;
|
|
87
|
+
};
|
|
88
|
+
} & {
|
|
89
|
+
id: string;
|
|
90
|
+
role: import(".prisma/client").$Enums.ConversationRole;
|
|
91
|
+
userId: string;
|
|
92
|
+
conversationId: string;
|
|
93
|
+
joinedAt: Date;
|
|
94
|
+
lastViewedAt: Date | null;
|
|
95
|
+
lastViewedMentionAt: Date | null;
|
|
96
|
+
})[];
|
|
97
|
+
} & {
|
|
98
|
+
type: import(".prisma/client").$Enums.ConversationType;
|
|
99
|
+
id: string;
|
|
100
|
+
createdAt: Date;
|
|
101
|
+
updatedAt: Date;
|
|
102
|
+
name: string | null;
|
|
103
|
+
displayInChat: boolean;
|
|
104
|
+
}>;
|
|
105
|
+
export declare function addMemberToConversation(userId: string, conversationId: string, memberUsername: string): Promise<{
|
|
106
|
+
members: ({
|
|
107
|
+
user: {
|
|
108
|
+
id: string;
|
|
109
|
+
username: string;
|
|
110
|
+
profile: {
|
|
111
|
+
displayName: string | null;
|
|
112
|
+
profilePicture: string | null;
|
|
113
|
+
} | null;
|
|
114
|
+
};
|
|
115
|
+
} & {
|
|
116
|
+
id: string;
|
|
117
|
+
role: import(".prisma/client").$Enums.ConversationRole;
|
|
118
|
+
userId: string;
|
|
119
|
+
conversationId: string;
|
|
120
|
+
joinedAt: Date;
|
|
121
|
+
lastViewedAt: Date | null;
|
|
122
|
+
lastViewedMentionAt: Date | null;
|
|
123
|
+
})[];
|
|
124
|
+
} & {
|
|
125
|
+
type: import(".prisma/client").$Enums.ConversationType;
|
|
126
|
+
id: string;
|
|
127
|
+
createdAt: Date;
|
|
128
|
+
updatedAt: Date;
|
|
129
|
+
name: string | null;
|
|
130
|
+
displayInChat: boolean;
|
|
131
|
+
}>;
|
|
132
|
+
export declare function removeMemberFromConversation(userId: string, conversationId: string, memberId: string): Promise<{
|
|
133
|
+
members: ({
|
|
134
|
+
user: {
|
|
135
|
+
id: string;
|
|
136
|
+
username: string;
|
|
137
|
+
profile: {
|
|
138
|
+
displayName: string | null;
|
|
139
|
+
profilePicture: string | null;
|
|
140
|
+
} | null;
|
|
141
|
+
};
|
|
142
|
+
} & {
|
|
143
|
+
id: string;
|
|
144
|
+
role: import(".prisma/client").$Enums.ConversationRole;
|
|
145
|
+
userId: string;
|
|
146
|
+
conversationId: string;
|
|
147
|
+
joinedAt: Date;
|
|
148
|
+
lastViewedAt: Date | null;
|
|
149
|
+
lastViewedMentionAt: Date | null;
|
|
150
|
+
})[];
|
|
151
|
+
} & {
|
|
152
|
+
type: import(".prisma/client").$Enums.ConversationType;
|
|
153
|
+
id: string;
|
|
154
|
+
createdAt: Date;
|
|
155
|
+
updatedAt: Date;
|
|
156
|
+
name: string | null;
|
|
157
|
+
displayInChat: boolean;
|
|
158
|
+
}>;
|
|
159
|
+
//# sourceMappingURL=conversation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"conversation.d.ts","sourceRoot":"/","sources":["services/conversation.ts"],"names":[],"mappings":"AAkBA,gEAAgE;AAChE,wBAAsB,iBAAiB,CAAC,MAAM,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA8CrD;AAED,gEAAgE;AAChE,wBAAsB,wBAAwB,CAC5C,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,IAAI,GAAG,OAAO,EACpB,IAAI,EAAE,MAAM,GAAG,SAAS,EACxB,SAAS,EAAE,MAAM,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;GAsEpB;AAED,wBAAsB,eAAe,CACnC,MAAM,EAAE,MAAM,EACd,cAAc,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;GAavB;AAED,wBAAsB,uBAAuB,CAC3C,MAAM,EAAE,MAAM,EACd,cAAc,EAAE,MAAM,EACtB,cAAc,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BvB;AAED,wBAAsB,4BAA4B,CAChD,MAAM,EAAE,MAAM,EACd,cAAc,EAAE,MAAM,EACtB,QAAQ,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;GAejB"}
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Conversation service – list, create, and manage DM/group conversations.
|
|
3
|
+
* Handles member management and unread counts.
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
!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]="4ed19abe-3dc1-5bea-9dac-6a700dc76438")}catch(e){}}();
|
|
7
|
+
import { TRPCError } from "@trpc/server";
|
|
8
|
+
import { findConversationsByUserId, countUnreadMessages, countUnreadMentions, findUserByUsername, findDmConversationsByUserId, findUsersByIdsOrUsernames, createConversation, findConversationByIdAndMember, createConversationMember, deleteConversationMember, } from "../models/conversation.js";
|
|
9
|
+
/** List user's conversations with unread and mention counts. */
|
|
10
|
+
export async function listConversations(userId) {
|
|
11
|
+
const conversations = await findConversationsByUserId(userId);
|
|
12
|
+
const conversationsWithUnread = await Promise.all(conversations.map(async (conversation) => {
|
|
13
|
+
const userMembership = conversation.members.find((m) => m.userId === userId);
|
|
14
|
+
const lastViewedAt = userMembership?.lastViewedAt;
|
|
15
|
+
const lastViewedMentionAt = userMembership?.lastViewedMentionAt;
|
|
16
|
+
const unreadCount = await countUnreadMessages(conversation.id, userId, lastViewedAt ?? undefined);
|
|
17
|
+
const mentionCutoffTime = lastViewedMentionAt && lastViewedAt
|
|
18
|
+
? lastViewedMentionAt > lastViewedAt
|
|
19
|
+
? lastViewedMentionAt
|
|
20
|
+
: lastViewedAt
|
|
21
|
+
: lastViewedMentionAt || lastViewedAt;
|
|
22
|
+
const unreadMentionCount = await countUnreadMentions(conversation.id, userId, mentionCutoffTime ?? undefined);
|
|
23
|
+
return {
|
|
24
|
+
id: conversation.id,
|
|
25
|
+
type: conversation.type,
|
|
26
|
+
name: conversation.name,
|
|
27
|
+
createdAt: conversation.createdAt,
|
|
28
|
+
updatedAt: conversation.updatedAt,
|
|
29
|
+
labChat: conversation.labChat,
|
|
30
|
+
members: conversation.members,
|
|
31
|
+
lastMessage: conversation.messages[0] || null,
|
|
32
|
+
unreadCount,
|
|
33
|
+
unreadMentionCount,
|
|
34
|
+
};
|
|
35
|
+
}));
|
|
36
|
+
return conversationsWithUnread;
|
|
37
|
+
}
|
|
38
|
+
/** Create a DM or group conversation with the given members. */
|
|
39
|
+
export async function createConversationRecord(userId, type, name, memberIds) {
|
|
40
|
+
if (type === "GROUP" && !name) {
|
|
41
|
+
throw new TRPCError({
|
|
42
|
+
code: "BAD_REQUEST",
|
|
43
|
+
message: "Group conversations must have a name",
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
if (type === "DM" && memberIds.length !== 1) {
|
|
47
|
+
throw new TRPCError({
|
|
48
|
+
code: "BAD_REQUEST",
|
|
49
|
+
message: "DM conversations must have exactly one other member",
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
if (type === "DM") {
|
|
53
|
+
const targetUser = await findUserByUsername(memberIds[0]);
|
|
54
|
+
if (!targetUser) {
|
|
55
|
+
throw new TRPCError({
|
|
56
|
+
code: "BAD_REQUEST",
|
|
57
|
+
message: `User "${memberIds[0]}" not found`,
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
const existingDMs = await findDmConversationsByUserId(userId);
|
|
61
|
+
const existingDM = existingDMs.find((conv) => {
|
|
62
|
+
const memberUserIds = conv.members.map((m) => m.userId);
|
|
63
|
+
return (memberUserIds.length === 2 &&
|
|
64
|
+
memberUserIds.includes(userId) &&
|
|
65
|
+
memberUserIds.includes(targetUser.id));
|
|
66
|
+
});
|
|
67
|
+
if (existingDM) {
|
|
68
|
+
throw new TRPCError({
|
|
69
|
+
code: "BAD_REQUEST",
|
|
70
|
+
message: `A conversation with ${targetUser.username} already exists`,
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
const members = await findUsersByIdsOrUsernames(memberIds);
|
|
75
|
+
const uniqueMembers = Array.from(new Map(members.map((m) => [m.id, m])).values());
|
|
76
|
+
if (uniqueMembers.length !== memberIds.length) {
|
|
77
|
+
throw new TRPCError({
|
|
78
|
+
code: "BAD_REQUEST",
|
|
79
|
+
message: "One or more members not found",
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
const toAddIds = memberIds
|
|
83
|
+
.map((id) => uniqueMembers.find((m) => m.id === id || m.username === id)?.id)
|
|
84
|
+
.filter(Boolean);
|
|
85
|
+
return createConversation({
|
|
86
|
+
type,
|
|
87
|
+
name,
|
|
88
|
+
members: [
|
|
89
|
+
{ userId, role: type === "GROUP" ? "ADMIN" : "MEMBER" },
|
|
90
|
+
...toAddIds.map((uid) => ({ userId: uid, role: "MEMBER" })),
|
|
91
|
+
],
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
export async function getConversation(userId, conversationId) {
|
|
95
|
+
const conversation = await findConversationByIdAndMember(conversationId, userId);
|
|
96
|
+
if (!conversation) {
|
|
97
|
+
throw new TRPCError({
|
|
98
|
+
code: "NOT_FOUND",
|
|
99
|
+
message: "Conversation not found or access denied",
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
return conversation;
|
|
103
|
+
}
|
|
104
|
+
export async function addMemberToConversation(userId, conversationId, memberUsername) {
|
|
105
|
+
const conversation = await findConversationByIdAndMember(conversationId, userId);
|
|
106
|
+
if (!conversation) {
|
|
107
|
+
throw new TRPCError({
|
|
108
|
+
code: "NOT_FOUND",
|
|
109
|
+
message: "Conversation not found or access denied",
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
const member = await findUserByUsername(memberUsername);
|
|
113
|
+
if (!member) {
|
|
114
|
+
throw new TRPCError({
|
|
115
|
+
code: "NOT_FOUND",
|
|
116
|
+
message: "Member not found",
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
await createConversationMember({
|
|
120
|
+
userId: member.id,
|
|
121
|
+
conversationId,
|
|
122
|
+
role: "MEMBER",
|
|
123
|
+
});
|
|
124
|
+
return conversation;
|
|
125
|
+
}
|
|
126
|
+
export async function removeMemberFromConversation(userId, conversationId, memberId) {
|
|
127
|
+
const conversation = await findConversationByIdAndMember(conversationId, userId);
|
|
128
|
+
if (!conversation) {
|
|
129
|
+
throw new TRPCError({
|
|
130
|
+
code: "NOT_FOUND",
|
|
131
|
+
message: "Conversation not found or access denied",
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
await deleteConversationMember(memberId, conversationId);
|
|
135
|
+
return conversation;
|
|
136
|
+
}
|
|
137
|
+
//# sourceMappingURL=conversation.js.map
|
|
138
|
+
//# debugId=4ed19abe-3dc1-5bea-9dac-6a700dc76438
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"conversation.js","sources":["services/conversation.ts"],"sourceRoot":"/","sourcesContent":["/**\n * Conversation service – list, create, and manage DM/group conversations.\n * Handles member management and unread counts.\n */\nimport { TRPCError } from \"@trpc/server\";\nimport {\n findConversationsByUserId,\n countUnreadMessages,\n countUnreadMentions,\n findUserByUsername,\n findDmConversationsByUserId,\n findUsersByIdsOrUsernames,\n createConversation,\n findConversationByIdAndMember,\n createConversationMember,\n deleteConversationMember,\n} from \"../models/conversation.js\";\n\n/** List user's conversations with unread and mention counts. */\nexport async function listConversations(userId: string) {\n const conversations = await findConversationsByUserId(userId);\n\n const conversationsWithUnread = await Promise.all(\n conversations.map(async (conversation) => {\n const userMembership = conversation.members.find(\n (m) => m.userId === userId\n );\n const lastViewedAt = userMembership?.lastViewedAt;\n const lastViewedMentionAt = userMembership?.lastViewedMentionAt;\n\n const unreadCount = await countUnreadMessages(\n conversation.id,\n userId,\n lastViewedAt ?? undefined\n );\n\n const mentionCutoffTime =\n lastViewedMentionAt && lastViewedAt\n ? lastViewedMentionAt > lastViewedAt\n ? lastViewedMentionAt\n : lastViewedAt\n : lastViewedMentionAt || lastViewedAt;\n\n const unreadMentionCount = await countUnreadMentions(\n conversation.id,\n userId,\n mentionCutoffTime ?? undefined\n );\n\n return {\n id: conversation.id,\n type: conversation.type,\n name: conversation.name,\n createdAt: conversation.createdAt,\n updatedAt: conversation.updatedAt,\n labChat: conversation.labChat,\n members: conversation.members,\n lastMessage: conversation.messages[0] || null,\n unreadCount,\n unreadMentionCount,\n };\n })\n );\n\n return conversationsWithUnread;\n}\n\n/** Create a DM or group conversation with the given members. */\nexport async function createConversationRecord(\n userId: string,\n type: \"DM\" | \"GROUP\",\n name: string | undefined,\n memberIds: string[]\n) {\n if (type === \"GROUP\" && !name) {\n throw new TRPCError({\n code: \"BAD_REQUEST\",\n message: \"Group conversations must have a name\",\n });\n }\n\n if (type === \"DM\" && memberIds.length !== 1) {\n throw new TRPCError({\n code: \"BAD_REQUEST\",\n message: \"DM conversations must have exactly one other member\",\n });\n }\n\n if (type === \"DM\") {\n const targetUser = await findUserByUsername(memberIds[0]);\n if (!targetUser) {\n throw new TRPCError({\n code: \"BAD_REQUEST\",\n message: `User \"${memberIds[0]}\" not found`,\n });\n }\n\n const existingDMs = await findDmConversationsByUserId(userId);\n const existingDM = existingDMs.find((conv) => {\n const memberUserIds = conv.members.map((m) => m.userId);\n return (\n memberUserIds.length === 2 &&\n memberUserIds.includes(userId) &&\n memberUserIds.includes(targetUser.id)\n );\n });\n\n if (existingDM) {\n throw new TRPCError({\n code: \"BAD_REQUEST\",\n message: `A conversation with ${targetUser.username} already exists`,\n });\n }\n }\n\n const members = await findUsersByIdsOrUsernames(memberIds);\n type Member = (typeof members)[number];\n const uniqueMembers = Array.from(\n new Map(members.map((m) => [m.id, m] as [string, Member])).values()\n );\n\n if (uniqueMembers.length !== memberIds.length) {\n throw new TRPCError({\n code: \"BAD_REQUEST\",\n message: \"One or more members not found\",\n });\n }\n\n const toAddIds = memberIds\n .map((id) =>\n uniqueMembers.find((m) => m.id === id || m.username === id)?.id\n )\n .filter(Boolean) as string[];\n\n return createConversation({\n type,\n name,\n members: [\n { userId, role: type === \"GROUP\" ? \"ADMIN\" : \"MEMBER\" },\n ...toAddIds.map((uid) => ({ userId: uid, role: \"MEMBER\" })),\n ],\n });\n}\n\nexport async function getConversation(\n userId: string,\n conversationId: string\n) {\n const conversation = await findConversationByIdAndMember(\n conversationId,\n userId\n );\n if (!conversation) {\n throw new TRPCError({\n code: \"NOT_FOUND\",\n message: \"Conversation not found or access denied\",\n });\n }\n return conversation;\n}\n\nexport async function addMemberToConversation(\n userId: string,\n conversationId: string,\n memberUsername: string\n) {\n const conversation = await findConversationByIdAndMember(\n conversationId,\n userId\n );\n if (!conversation) {\n throw new TRPCError({\n code: \"NOT_FOUND\",\n message: \"Conversation not found or access denied\",\n });\n }\n\n const member = await findUserByUsername(memberUsername);\n if (!member) {\n throw new TRPCError({\n code: \"NOT_FOUND\",\n message: \"Member not found\",\n });\n }\n\n await createConversationMember({\n userId: member.id,\n conversationId,\n role: \"MEMBER\",\n });\n\n return conversation;\n}\n\nexport async function removeMemberFromConversation(\n userId: string,\n conversationId: string,\n memberId: string\n) {\n const conversation = await findConversationByIdAndMember(\n conversationId,\n userId\n );\n if (!conversation) {\n throw new TRPCError({\n code: \"NOT_FOUND\",\n message: \"Conversation not found or access denied\",\n });\n }\n\n await deleteConversationMember(memberId, conversationId);\n return conversation;\n}\n"],"names":[],"mappings":"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","debug_id":"4ed19abe-3dc1-5bea-9dac-6a700dc76438"}
|
|
@@ -0,0 +1,216 @@
|
|
|
1
|
+
/** Get a single event. Personal events require ownership. */
|
|
2
|
+
export declare function getEvent(userId: string, id: string): Promise<{
|
|
3
|
+
event: {
|
|
4
|
+
user: {
|
|
5
|
+
id: string;
|
|
6
|
+
username: string;
|
|
7
|
+
email: string;
|
|
8
|
+
password: string;
|
|
9
|
+
verified: boolean;
|
|
10
|
+
role: import(".prisma/client").$Enums.UserRole;
|
|
11
|
+
schoolId: string | null;
|
|
12
|
+
} | null;
|
|
13
|
+
class: {
|
|
14
|
+
id: string;
|
|
15
|
+
schoolId: string | null;
|
|
16
|
+
name: string;
|
|
17
|
+
subject: string;
|
|
18
|
+
color: string | null;
|
|
19
|
+
section: string;
|
|
20
|
+
syllabus: string | null;
|
|
21
|
+
} | null;
|
|
22
|
+
assignmentsAttached: {
|
|
23
|
+
type: import(".prisma/client").$Enums.AssignmentType;
|
|
24
|
+
id: string;
|
|
25
|
+
section: {
|
|
26
|
+
id: string;
|
|
27
|
+
name: string;
|
|
28
|
+
} | null;
|
|
29
|
+
title: string;
|
|
30
|
+
dueDate: Date;
|
|
31
|
+
maxGrade: number | null;
|
|
32
|
+
instructions: string;
|
|
33
|
+
graded: boolean;
|
|
34
|
+
weight: number;
|
|
35
|
+
teacher: {
|
|
36
|
+
id: string;
|
|
37
|
+
username: string;
|
|
38
|
+
};
|
|
39
|
+
attachments: {
|
|
40
|
+
type: string;
|
|
41
|
+
id: string;
|
|
42
|
+
name: string;
|
|
43
|
+
}[];
|
|
44
|
+
}[];
|
|
45
|
+
} & {
|
|
46
|
+
id: string;
|
|
47
|
+
userId: string | null;
|
|
48
|
+
location: string | null;
|
|
49
|
+
classId: string | null;
|
|
50
|
+
name: string | null;
|
|
51
|
+
color: string | null;
|
|
52
|
+
startTime: Date;
|
|
53
|
+
endTime: Date;
|
|
54
|
+
remarks: string | null;
|
|
55
|
+
};
|
|
56
|
+
}>;
|
|
57
|
+
/** Create a personal or class event. */
|
|
58
|
+
export declare function createEventRecord(userId: string, input: {
|
|
59
|
+
name?: string;
|
|
60
|
+
location?: string;
|
|
61
|
+
remarks?: string;
|
|
62
|
+
startTime: string;
|
|
63
|
+
endTime: string;
|
|
64
|
+
classId?: string;
|
|
65
|
+
color?: string;
|
|
66
|
+
}): Promise<{
|
|
67
|
+
event: {
|
|
68
|
+
id: string;
|
|
69
|
+
userId: string | null;
|
|
70
|
+
location: string | null;
|
|
71
|
+
classId: string | null;
|
|
72
|
+
class: {
|
|
73
|
+
id: string;
|
|
74
|
+
name: string;
|
|
75
|
+
} | null;
|
|
76
|
+
name: string | null;
|
|
77
|
+
color: string | null;
|
|
78
|
+
startTime: Date;
|
|
79
|
+
endTime: Date;
|
|
80
|
+
remarks: string | null;
|
|
81
|
+
};
|
|
82
|
+
}>;
|
|
83
|
+
export declare function updateEventRecord(userId: string, id: string, data: {
|
|
84
|
+
name?: string;
|
|
85
|
+
location?: string;
|
|
86
|
+
remarks?: string;
|
|
87
|
+
startTime?: string;
|
|
88
|
+
endTime?: string;
|
|
89
|
+
color?: string;
|
|
90
|
+
classId?: string;
|
|
91
|
+
}): Promise<{
|
|
92
|
+
event: {
|
|
93
|
+
id: string;
|
|
94
|
+
userId: string | null;
|
|
95
|
+
location: string | null;
|
|
96
|
+
classId: string | null;
|
|
97
|
+
name: string | null;
|
|
98
|
+
color: string | null;
|
|
99
|
+
startTime: Date;
|
|
100
|
+
endTime: Date;
|
|
101
|
+
remarks: string | null;
|
|
102
|
+
};
|
|
103
|
+
}>;
|
|
104
|
+
export declare function deleteEventRecord(userId: string, id: string): Promise<{
|
|
105
|
+
success: boolean;
|
|
106
|
+
}>;
|
|
107
|
+
export declare function attachAssignment(userId: string, eventId: string, assignmentId: string): Promise<{
|
|
108
|
+
assignment: {
|
|
109
|
+
section: {
|
|
110
|
+
id: string;
|
|
111
|
+
name: string;
|
|
112
|
+
} | null;
|
|
113
|
+
teacher: {
|
|
114
|
+
id: string;
|
|
115
|
+
username: string;
|
|
116
|
+
};
|
|
117
|
+
attachments: {
|
|
118
|
+
type: string;
|
|
119
|
+
id: string;
|
|
120
|
+
name: string;
|
|
121
|
+
}[];
|
|
122
|
+
} & {
|
|
123
|
+
type: import(".prisma/client").$Enums.AssignmentType;
|
|
124
|
+
id: string;
|
|
125
|
+
createdAt: Date | null;
|
|
126
|
+
classId: string;
|
|
127
|
+
title: string;
|
|
128
|
+
dueDate: Date;
|
|
129
|
+
maxGrade: number | null;
|
|
130
|
+
eventId: string | null;
|
|
131
|
+
instructions: string;
|
|
132
|
+
modifiedAt: Date | null;
|
|
133
|
+
teacherId: string;
|
|
134
|
+
acceptFiles: boolean;
|
|
135
|
+
acceptExtendedResponse: boolean;
|
|
136
|
+
acceptWorksheet: boolean;
|
|
137
|
+
gradeWithAI: boolean;
|
|
138
|
+
aiPolicyLevel: number;
|
|
139
|
+
sectionId: string | null;
|
|
140
|
+
graded: boolean;
|
|
141
|
+
weight: number;
|
|
142
|
+
inProgress: boolean;
|
|
143
|
+
template: boolean;
|
|
144
|
+
markSchemeId: string | null;
|
|
145
|
+
order: number | null;
|
|
146
|
+
gradingBoundaryId: string | null;
|
|
147
|
+
};
|
|
148
|
+
}>;
|
|
149
|
+
export declare function detachAssignment(userId: string, eventId: string, assignmentId: string): Promise<{
|
|
150
|
+
assignment: {
|
|
151
|
+
section: {
|
|
152
|
+
id: string;
|
|
153
|
+
name: string;
|
|
154
|
+
} | null;
|
|
155
|
+
teacher: {
|
|
156
|
+
id: string;
|
|
157
|
+
username: string;
|
|
158
|
+
};
|
|
159
|
+
attachments: {
|
|
160
|
+
type: string;
|
|
161
|
+
id: string;
|
|
162
|
+
name: string;
|
|
163
|
+
}[];
|
|
164
|
+
} & {
|
|
165
|
+
type: import(".prisma/client").$Enums.AssignmentType;
|
|
166
|
+
id: string;
|
|
167
|
+
createdAt: Date | null;
|
|
168
|
+
classId: string;
|
|
169
|
+
title: string;
|
|
170
|
+
dueDate: Date;
|
|
171
|
+
maxGrade: number | null;
|
|
172
|
+
eventId: string | null;
|
|
173
|
+
instructions: string;
|
|
174
|
+
modifiedAt: Date | null;
|
|
175
|
+
teacherId: string;
|
|
176
|
+
acceptFiles: boolean;
|
|
177
|
+
acceptExtendedResponse: boolean;
|
|
178
|
+
acceptWorksheet: boolean;
|
|
179
|
+
gradeWithAI: boolean;
|
|
180
|
+
aiPolicyLevel: number;
|
|
181
|
+
sectionId: string | null;
|
|
182
|
+
graded: boolean;
|
|
183
|
+
weight: number;
|
|
184
|
+
inProgress: boolean;
|
|
185
|
+
template: boolean;
|
|
186
|
+
markSchemeId: string | null;
|
|
187
|
+
order: number | null;
|
|
188
|
+
gradingBoundaryId: string | null;
|
|
189
|
+
};
|
|
190
|
+
}>;
|
|
191
|
+
export declare function getAvailableAssignments(userId: string, eventId: string): Promise<{
|
|
192
|
+
assignments: {
|
|
193
|
+
type: import(".prisma/client").$Enums.AssignmentType;
|
|
194
|
+
id: string;
|
|
195
|
+
section: {
|
|
196
|
+
id: string;
|
|
197
|
+
name: string;
|
|
198
|
+
} | null;
|
|
199
|
+
title: string;
|
|
200
|
+
dueDate: Date;
|
|
201
|
+
maxGrade: number | null;
|
|
202
|
+
instructions: string;
|
|
203
|
+
graded: boolean;
|
|
204
|
+
weight: number;
|
|
205
|
+
teacher: {
|
|
206
|
+
id: string;
|
|
207
|
+
username: string;
|
|
208
|
+
};
|
|
209
|
+
attachments: {
|
|
210
|
+
type: string;
|
|
211
|
+
id: string;
|
|
212
|
+
name: string;
|
|
213
|
+
}[];
|
|
214
|
+
}[];
|
|
215
|
+
}>;
|
|
216
|
+
//# sourceMappingURL=event.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event.d.ts","sourceRoot":"/","sources":["services/event.ts"],"names":[],"mappings":"AAmBA,6DAA6D;AAC7D,wBAAsB,QAAQ,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAexD;AAED,wCAAwC;AACxC,wBAAsB,iBAAiB,CACrC,MAAM,EAAE,MAAM,EACd,KAAK,EAAE;IACL,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;;;;;;;;;;;;;;;;GAwBF;AAED,wBAAsB,iBAAiB,CACrC,MAAM,EAAE,MAAM,EACd,EAAE,EAAE,MAAM,EACV,IAAI,EAAE;IACJ,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;;;;;;;;;;;;GA2BF;AAED,wBAAsB,iBAAiB,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM;;GAiBjE;AAUD,wBAAsB,gBAAgB,CACpC,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,MAAM,EACf,YAAY,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyCrB;AAED,wBAAsB,gBAAgB,CACpC,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,MAAM,EACf,YAAY,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkBrB;AAED,wBAAsB,uBAAuB,CAC3C,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;;;;GAkBhB"}
|