@hed-hog/lms 0.0.347 → 0.0.350
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/dist/achievement/achievement.controller.d.ts +62 -0
- package/dist/achievement/achievement.controller.d.ts.map +1 -0
- package/dist/achievement/achievement.controller.js +90 -0
- package/dist/achievement/achievement.controller.js.map +1 -0
- package/dist/achievement/achievement.mcp-tools.d.ts +19 -0
- package/dist/achievement/achievement.mcp-tools.d.ts.map +1 -0
- package/dist/achievement/achievement.mcp-tools.js +157 -0
- package/dist/achievement/achievement.mcp-tools.js.map +1 -0
- package/dist/achievement/achievement.module.d.ts +3 -0
- package/dist/achievement/achievement.module.d.ts.map +1 -0
- package/dist/achievement/achievement.module.js +26 -0
- package/dist/achievement/achievement.module.js.map +1 -0
- package/dist/achievement/achievement.service.d.ts +72 -0
- package/dist/achievement/achievement.service.d.ts.map +1 -0
- package/dist/achievement/achievement.service.js +200 -0
- package/dist/achievement/achievement.service.js.map +1 -0
- package/dist/achievement/dto/create-achievement.dto.d.ts +12 -0
- package/dist/achievement/dto/create-achievement.dto.d.ts.map +1 -0
- package/dist/achievement/dto/create-achievement.dto.js +60 -0
- package/dist/achievement/dto/create-achievement.dto.js.map +1 -0
- package/dist/achievement/dto/update-achievement.dto.d.ts +11 -0
- package/dist/achievement/dto/update-achievement.dto.d.ts.map +1 -0
- package/dist/achievement/dto/update-achievement.dto.js +57 -0
- package/dist/achievement/dto/update-achievement.dto.js.map +1 -0
- package/dist/bitcode-wallet/bitcode-wallet.controller.d.ts +114 -0
- package/dist/bitcode-wallet/bitcode-wallet.controller.d.ts.map +1 -0
- package/dist/bitcode-wallet/bitcode-wallet.controller.js +102 -0
- package/dist/bitcode-wallet/bitcode-wallet.controller.js.map +1 -0
- package/dist/bitcode-wallet/bitcode-wallet.mcp-tools.d.ts +25 -0
- package/dist/bitcode-wallet/bitcode-wallet.mcp-tools.d.ts.map +1 -0
- package/dist/bitcode-wallet/bitcode-wallet.mcp-tools.js +160 -0
- package/dist/bitcode-wallet/bitcode-wallet.mcp-tools.js.map +1 -0
- package/dist/bitcode-wallet/bitcode-wallet.module.d.ts +3 -0
- package/dist/bitcode-wallet/bitcode-wallet.module.d.ts.map +1 -0
- package/dist/bitcode-wallet/bitcode-wallet.module.js +26 -0
- package/dist/bitcode-wallet/bitcode-wallet.module.js.map +1 -0
- package/dist/bitcode-wallet/bitcode-wallet.service.d.ts +127 -0
- package/dist/bitcode-wallet/bitcode-wallet.service.d.ts.map +1 -0
- package/dist/bitcode-wallet/bitcode-wallet.service.js +264 -0
- package/dist/bitcode-wallet/bitcode-wallet.service.js.map +1 -0
- package/dist/bitcode-wallet/dto/create-bitcode-wallet-transaction.dto.d.ts +8 -0
- package/dist/bitcode-wallet/dto/create-bitcode-wallet-transaction.dto.d.ts.map +1 -0
- package/dist/bitcode-wallet/dto/create-bitcode-wallet-transaction.dto.js +33 -0
- package/dist/bitcode-wallet/dto/create-bitcode-wallet-transaction.dto.js.map +1 -0
- package/dist/bitcode-wallet/dto/create-bitcode-wallet.dto.d.ts +4 -0
- package/dist/bitcode-wallet/dto/create-bitcode-wallet.dto.d.ts.map +1 -0
- package/dist/bitcode-wallet/dto/create-bitcode-wallet.dto.js +22 -0
- package/dist/bitcode-wallet/dto/create-bitcode-wallet.dto.js.map +1 -0
- package/dist/bitcode-wallet/dto/update-bitcode-wallet-transaction.dto.d.ts +7 -0
- package/dist/bitcode-wallet/dto/update-bitcode-wallet-transaction.dto.d.ts.map +1 -0
- package/dist/bitcode-wallet/dto/update-bitcode-wallet-transaction.dto.js +35 -0
- package/dist/bitcode-wallet/dto/update-bitcode-wallet-transaction.dto.js.map +1 -0
- package/dist/bitcode-wallet/dto/update-bitcode-wallet.dto.d.ts +4 -0
- package/dist/bitcode-wallet/dto/update-bitcode-wallet.dto.d.ts.map +1 -0
- package/dist/bitcode-wallet/dto/update-bitcode-wallet.dto.js +23 -0
- package/dist/bitcode-wallet/dto/update-bitcode-wallet.dto.js.map +1 -0
- package/dist/certificate/certificate.controller.d.ts +22 -0
- package/dist/certificate/certificate.controller.d.ts.map +1 -1
- package/dist/certificate/certificate.controller.js +12 -0
- package/dist/certificate/certificate.controller.js.map +1 -1
- package/dist/certificate/certificate.mcp-tools.d.ts +24 -0
- package/dist/certificate/certificate.mcp-tools.d.ts.map +1 -0
- package/dist/certificate/certificate.mcp-tools.js +188 -0
- package/dist/certificate/certificate.mcp-tools.js.map +1 -0
- package/dist/certificate/certificate.module.d.ts.map +1 -1
- package/dist/certificate/certificate.module.js +2 -1
- package/dist/certificate/certificate.module.js.map +1 -1
- package/dist/certificate/certificate.service.d.ts +25 -2
- package/dist/certificate/certificate.service.d.ts.map +1 -1
- package/dist/certificate/certificate.service.js +87 -2
- package/dist/certificate/certificate.service.js.map +1 -1
- package/dist/certificate/dto/update-certificate-public-access.dto.d.ts +4 -0
- package/dist/certificate/dto/update-certificate-public-access.dto.d.ts.map +1 -0
- package/dist/certificate/dto/update-certificate-public-access.dto.js +21 -0
- package/dist/certificate/dto/update-certificate-public-access.dto.js.map +1 -0
- package/dist/class-group/class-group.controller.d.ts +3 -3
- package/dist/class-group/class-group.mcp-tools.d.ts +87 -0
- package/dist/class-group/class-group.mcp-tools.d.ts.map +1 -0
- package/dist/class-group/class-group.mcp-tools.js +553 -0
- package/dist/class-group/class-group.mcp-tools.js.map +1 -0
- package/dist/class-group/class-group.module.d.ts.map +1 -1
- package/dist/class-group/class-group.module.js +2 -1
- package/dist/class-group/class-group.module.js.map +1 -1
- package/dist/class-group/class-group.service.d.ts +6 -4
- package/dist/class-group/class-group.service.d.ts.map +1 -1
- package/dist/class-group/class-group.service.js +45 -2
- package/dist/class-group/class-group.service.js.map +1 -1
- package/dist/course/course-operations-integration.service.d.ts +40 -0
- package/dist/course/course-operations-integration.service.d.ts.map +1 -0
- package/dist/course/course-operations-integration.service.js +372 -0
- package/dist/course/course-operations-integration.service.js.map +1 -0
- package/dist/course/course-structure.controller.d.ts +43 -4
- package/dist/course/course-structure.controller.d.ts.map +1 -1
- package/dist/course/course-structure.controller.js +22 -0
- package/dist/course/course-structure.controller.js.map +1 -1
- package/dist/course/course-structure.service.d.ts +42 -1
- package/dist/course/course-structure.service.d.ts.map +1 -1
- package/dist/course/course-structure.service.js +199 -32
- package/dist/course/course-structure.service.js.map +1 -1
- package/dist/course/course.controller.d.ts +12 -0
- package/dist/course/course.controller.d.ts.map +1 -1
- package/dist/course/course.mcp-tools.d.ts +90 -0
- package/dist/course/course.mcp-tools.d.ts.map +1 -0
- package/dist/course/course.mcp-tools.js +520 -0
- package/dist/course/course.mcp-tools.js.map +1 -0
- package/dist/course/course.module.d.ts.map +1 -1
- package/dist/course/course.module.js +8 -1
- package/dist/course/course.module.js.map +1 -1
- package/dist/course/course.service.d.ts +15 -1
- package/dist/course/course.service.d.ts.map +1 -1
- package/dist/course/course.service.js +70 -35
- package/dist/course/course.service.js.map +1 -1
- package/dist/course/dto/create-course.dto.d.ts +1 -0
- package/dist/course/dto/create-course.dto.d.ts.map +1 -1
- package/dist/course/dto/create-course.dto.js +7 -0
- package/dist/course/dto/create-course.dto.js.map +1 -1
- package/dist/course/dto/update-course-resources.dto.d.ts +11 -0
- package/dist/course/dto/update-course-resources.dto.d.ts.map +1 -0
- package/dist/course/dto/update-course-resources.dto.js +51 -0
- package/dist/course/dto/update-course-resources.dto.js.map +1 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.controller.d.ts +23 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.controller.d.ts.map +1 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.controller.js +78 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.controller.js.map +1 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.mcp-tools.d.ts +22 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.mcp-tools.d.ts.map +1 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.mcp-tools.js +120 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.mcp-tools.js.map +1 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.module.d.ts +3 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.module.d.ts.map +1 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.module.js +26 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.module.js.map +1 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.service.d.ts +49 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.service.d.ts.map +1 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.service.js +272 -0
- package/dist/course-lesson-discussion/course-lesson-discussion.service.js.map +1 -0
- package/dist/course-lesson-discussion/dto/create-course-lesson-discussion-topic.dto.d.ts +6 -0
- package/dist/course-lesson-discussion/dto/create-course-lesson-discussion-topic.dto.d.ts.map +1 -0
- package/dist/course-lesson-discussion/dto/create-course-lesson-discussion-topic.dto.js +33 -0
- package/dist/course-lesson-discussion/dto/create-course-lesson-discussion-topic.dto.js.map +1 -0
- package/dist/course-lesson-note/course-lesson-note.controller.d.ts +53 -0
- package/dist/course-lesson-note/course-lesson-note.controller.d.ts.map +1 -0
- package/dist/course-lesson-note/course-lesson-note.controller.js +93 -0
- package/dist/course-lesson-note/course-lesson-note.controller.js.map +1 -0
- package/dist/course-lesson-note/course-lesson-note.mcp-tools.d.ts +27 -0
- package/dist/course-lesson-note/course-lesson-note.mcp-tools.d.ts.map +1 -0
- package/dist/course-lesson-note/course-lesson-note.mcp-tools.js +145 -0
- package/dist/course-lesson-note/course-lesson-note.mcp-tools.js.map +1 -0
- package/dist/course-lesson-note/course-lesson-note.module.d.ts +3 -0
- package/dist/course-lesson-note/course-lesson-note.module.d.ts.map +1 -0
- package/dist/course-lesson-note/course-lesson-note.module.js +26 -0
- package/dist/course-lesson-note/course-lesson-note.module.js.map +1 -0
- package/dist/course-lesson-note/course-lesson-note.service.d.ts +59 -0
- package/dist/course-lesson-note/course-lesson-note.service.d.ts.map +1 -0
- package/dist/course-lesson-note/course-lesson-note.service.js +195 -0
- package/dist/course-lesson-note/course-lesson-note.service.js.map +1 -0
- package/dist/course-lesson-note/dto/create-course-lesson-note.dto.d.ts +6 -0
- package/dist/course-lesson-note/dto/create-course-lesson-note.dto.d.ts.map +1 -0
- package/dist/course-lesson-note/dto/create-course-lesson-note.dto.js +33 -0
- package/dist/course-lesson-note/dto/create-course-lesson-note.dto.js.map +1 -0
- package/dist/course-lesson-note/dto/update-course-lesson-note.dto.d.ts +6 -0
- package/dist/course-lesson-note/dto/update-course-lesson-note.dto.d.ts.map +1 -0
- package/dist/course-lesson-note/dto/update-course-lesson-note.dto.js +35 -0
- package/dist/course-lesson-note/dto/update-course-lesson-note.dto.js.map +1 -0
- package/dist/dashboard/dashboard.mcp-tools.d.ts +10 -0
- package/dist/dashboard/dashboard.mcp-tools.d.ts.map +1 -0
- package/dist/dashboard/dashboard.mcp-tools.js +46 -0
- package/dist/dashboard/dashboard.mcp-tools.js.map +1 -0
- package/dist/dashboard/dashboard.module.d.ts.map +1 -1
- package/dist/dashboard/dashboard.module.js +2 -1
- package/dist/dashboard/dashboard.module.js.map +1 -1
- package/dist/enterprise/enterprise.mcp-tools.d.ts +82 -0
- package/dist/enterprise/enterprise.mcp-tools.d.ts.map +1 -0
- package/dist/enterprise/enterprise.mcp-tools.js +516 -0
- package/dist/enterprise/enterprise.mcp-tools.js.map +1 -0
- package/dist/enterprise/enterprise.module.d.ts.map +1 -1
- package/dist/enterprise/enterprise.module.js +2 -1
- package/dist/enterprise/enterprise.module.js.map +1 -1
- package/dist/enterprise/training/enterprise-training.module.d.ts.map +1 -1
- package/dist/enterprise/training/enterprise-training.module.js +11 -1
- package/dist/enterprise/training/enterprise-training.module.js.map +1 -1
- package/dist/enterprise/training/training-admin.controller.d.ts +2 -2
- package/dist/enterprise/training/training-admin.mcp-tools.d.ts +79 -0
- package/dist/enterprise/training/training-admin.mcp-tools.d.ts.map +1 -0
- package/dist/enterprise/training/training-admin.mcp-tools.js +620 -0
- package/dist/enterprise/training/training-admin.mcp-tools.js.map +1 -0
- package/dist/enterprise/training/training-admin.service.d.ts +2 -2
- package/dist/enterprise/training/training-instructor.mcp-tools.d.ts +47 -0
- package/dist/enterprise/training/training-instructor.mcp-tools.d.ts.map +1 -0
- package/dist/enterprise/training/training-instructor.mcp-tools.js +275 -0
- package/dist/enterprise/training/training-instructor.mcp-tools.js.map +1 -0
- package/dist/enterprise/training/training-student.controller.d.ts +24 -0
- package/dist/enterprise/training/training-student.controller.d.ts.map +1 -1
- package/dist/enterprise/training/training-student.controller.js +22 -0
- package/dist/enterprise/training/training-student.controller.js.map +1 -1
- package/dist/enterprise/training/training-student.mcp-tools.d.ts +27 -0
- package/dist/enterprise/training/training-student.mcp-tools.d.ts.map +1 -0
- package/dist/enterprise/training/training-student.mcp-tools.js +186 -0
- package/dist/enterprise/training/training-student.mcp-tools.js.map +1 -0
- package/dist/enterprise/training/training-student.service.d.ts +32 -0
- package/dist/enterprise/training/training-student.service.d.ts.map +1 -1
- package/dist/enterprise/training/training-student.service.js +138 -0
- package/dist/enterprise/training/training-student.service.js.map +1 -1
- package/dist/evaluation/evaluation.controller.d.ts +4 -4
- package/dist/evaluation/evaluation.mcp-tools.d.ts +25 -0
- package/dist/evaluation/evaluation.mcp-tools.d.ts.map +1 -0
- package/dist/evaluation/evaluation.mcp-tools.js +220 -0
- package/dist/evaluation/evaluation.mcp-tools.js.map +1 -0
- package/dist/evaluation/evaluation.module.d.ts.map +1 -1
- package/dist/evaluation/evaluation.module.js +2 -1
- package/dist/evaluation/evaluation.module.js.map +1 -1
- package/dist/evaluation/evaluation.service.d.ts +4 -4
- package/dist/exam/dto/create-exam-question.dto.d.ts +2 -0
- package/dist/exam/dto/create-exam-question.dto.d.ts.map +1 -1
- package/dist/exam/dto/create-exam-question.dto.js +10 -0
- package/dist/exam/dto/create-exam-question.dto.js.map +1 -1
- package/dist/exam/dto/create-exam.dto.d.ts +2 -0
- package/dist/exam/dto/create-exam.dto.d.ts.map +1 -1
- package/dist/exam/dto/create-exam.dto.js +10 -0
- package/dist/exam/dto/create-exam.dto.js.map +1 -1
- package/dist/exam/dto/create-question-subject.dto.d.ts +5 -0
- package/dist/exam/dto/create-question-subject.dto.d.ts.map +1 -0
- package/dist/exam/dto/create-question-subject.dto.js +28 -0
- package/dist/exam/dto/create-question-subject.dto.js.map +1 -0
- package/dist/exam/exam-attempt.controller.d.ts +4 -0
- package/dist/exam/exam-attempt.controller.d.ts.map +1 -1
- package/dist/exam/exam-attempt.service.d.ts +7 -1
- package/dist/exam/exam-attempt.service.d.ts.map +1 -1
- package/dist/exam/exam-attempt.service.js +47 -17
- package/dist/exam/exam-attempt.service.js.map +1 -1
- package/dist/exam/exam.controller.d.ts +34 -0
- package/dist/exam/exam.controller.d.ts.map +1 -1
- package/dist/exam/exam.controller.js +27 -0
- package/dist/exam/exam.controller.js.map +1 -1
- package/dist/exam/exam.mcp-tools.d.ts +62 -0
- package/dist/exam/exam.mcp-tools.d.ts.map +1 -0
- package/dist/exam/exam.mcp-tools.js +430 -0
- package/dist/exam/exam.mcp-tools.js.map +1 -0
- package/dist/exam/exam.module.d.ts.map +1 -1
- package/dist/exam/exam.module.js +2 -1
- package/dist/exam/exam.module.js.map +1 -1
- package/dist/exam/exam.service.d.ts +38 -0
- package/dist/exam/exam.service.d.ts.map +1 -1
- package/dist/exam/exam.service.js +114 -17
- package/dist/exam/exam.service.js.map +1 -1
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +9 -0
- package/dist/index.js.map +1 -1
- package/dist/instructor/instructor.mcp-tools.d.ts +41 -0
- package/dist/instructor/instructor.mcp-tools.d.ts.map +1 -0
- package/dist/instructor/instructor.mcp-tools.js +326 -0
- package/dist/instructor/instructor.mcp-tools.js.map +1 -0
- package/dist/instructor/instructor.module.d.ts.map +1 -1
- package/dist/instructor/instructor.module.js +2 -1
- package/dist/instructor/instructor.module.js.map +1 -1
- package/dist/lms.module.d.ts.map +1 -1
- package/dist/lms.module.js +15 -0
- package/dist/lms.module.js.map +1 -1
- package/dist/realtime/lms-realtime.controller.d.ts +7 -0
- package/dist/realtime/lms-realtime.controller.d.ts.map +1 -0
- package/dist/realtime/lms-realtime.controller.js +34 -0
- package/dist/realtime/lms-realtime.controller.js.map +1 -0
- package/dist/realtime/lms-realtime.module.d.ts +3 -0
- package/dist/realtime/lms-realtime.module.d.ts.map +1 -0
- package/dist/realtime/lms-realtime.module.js +25 -0
- package/dist/realtime/lms-realtime.module.js.map +1 -0
- package/dist/realtime/lms-realtime.service.d.ts +36 -0
- package/dist/realtime/lms-realtime.service.d.ts.map +1 -0
- package/dist/realtime/lms-realtime.service.js +59 -0
- package/dist/realtime/lms-realtime.service.js.map +1 -0
- package/dist/realtime/lms-realtime.subscriber.d.ts +10 -0
- package/dist/realtime/lms-realtime.subscriber.d.ts.map +1 -0
- package/dist/realtime/lms-realtime.subscriber.js +70 -0
- package/dist/realtime/lms-realtime.subscriber.js.map +1 -0
- package/dist/reports/reports.mcp-tools.d.ts +10 -0
- package/dist/reports/reports.mcp-tools.d.ts.map +1 -0
- package/dist/reports/reports.mcp-tools.js +50 -0
- package/dist/reports/reports.mcp-tools.js.map +1 -0
- package/dist/reports/reports.module.d.ts.map +1 -1
- package/dist/reports/reports.module.js +2 -1
- package/dist/reports/reports.module.js.map +1 -1
- package/dist/training/training.mcp-tools.d.ts +20 -0
- package/dist/training/training.mcp-tools.d.ts.map +1 -0
- package/dist/training/training.mcp-tools.js +181 -0
- package/dist/training/training.mcp-tools.js.map +1 -0
- package/dist/training/training.module.d.ts.map +1 -1
- package/dist/training/training.module.js +2 -1
- package/dist/training/training.module.js.map +1 -1
- package/hedhog/data/integration_event_catalog.yaml +69 -0
- package/hedhog/data/menu.yaml +34 -0
- package/hedhog/data/route.yaml +2351 -0
- package/hedhog/frontend/app/_components/class-form-sheet.tsx.ejs +168 -103
- package/hedhog/frontend/app/_components/course-form-sheet.tsx.ejs +80 -1
- package/hedhog/frontend/app/_components/course-picker.tsx.ejs +228 -0
- package/hedhog/frontend/app/_lib/hooks/use-lms-realtime-refresh.ts.ejs +58 -0
- package/hedhog/frontend/app/achievements/page.tsx.ejs +844 -0
- package/hedhog/frontend/app/bitcodes/page.tsx.ejs +1010 -0
- package/hedhog/frontend/app/certificates/issued/page.tsx.ejs +61 -2
- package/hedhog/frontend/app/classes/[id]/page.tsx.ejs +7 -0
- package/hedhog/frontend/app/classes/page.tsx.ejs +55 -2060
- package/hedhog/frontend/app/courses/[id]/_components/CourseRelationsCard.tsx.ejs +28 -0
- package/hedhog/frontend/app/courses/[id]/_components/course-edit-types.ts.ejs +1 -0
- package/hedhog/frontend/app/courses/[id]/page.tsx.ejs +0 -9
- package/hedhog/frontend/app/courses/[id]/structure/_components/course-tree-dnd.tsx.ejs +80 -66
- package/hedhog/frontend/app/courses/[id]/structure/_components/editor-course.tsx.ejs +583 -8
- package/hedhog/frontend/app/courses/[id]/structure/_components/editor-lesson.tsx.ejs +527 -57
- package/hedhog/frontend/app/courses/[id]/structure/_components/mock-data.ts.ejs +1 -1
- package/hedhog/frontend/app/courses/[id]/structure/_components/tree-context-menu.tsx.ejs +106 -4
- package/hedhog/frontend/app/courses/[id]/structure/_components/types.ts.ejs +2 -1
- package/hedhog/frontend/app/courses/[id]/structure/_data/adapters/course-structure.adapter.ts.ejs +11 -1
- package/hedhog/frontend/app/courses/[id]/structure/_data/services/course-structure.service.ts.ejs +53 -6
- package/hedhog/frontend/app/courses/[id]/structure/_data/types/api-course.types.ts.ejs +13 -2
- package/hedhog/frontend/app/courses/page.tsx.ejs +175 -29
- package/hedhog/frontend/app/enterprise/_components/enterprise-course-create-sheet.tsx.ejs +3 -0
- package/hedhog/frontend/app/enterprise/_components/enterprise-course-edit-sheet.tsx.ejs +7 -0
- package/hedhog/frontend/app/exams/[id]/questions/page.tsx.ejs +169 -2
- package/hedhog/frontend/app/exams/page.tsx.ejs +77 -22
- package/hedhog/frontend/app/instructor-skills/page.tsx.ejs +1 -0
- package/hedhog/frontend/app/instructors/page.tsx.ejs +1 -0
- package/hedhog/frontend/app/paths/page.tsx.ejs +6 -24
- package/hedhog/frontend/app/training/page.tsx.ejs +6 -24
- package/hedhog/frontend/messages/en.json +314 -12
- package/hedhog/frontend/messages/pt.json +314 -12
- package/hedhog/query/triggers.sql +53 -0
- package/hedhog/table/achievement.yaml +46 -0
- package/hedhog/table/bitcode_wallet.yaml +18 -0
- package/hedhog/table/bitcode_wallet_transaction.yaml +22 -0
- package/hedhog/table/certificate.yaml +3 -0
- package/hedhog/table/course.yaml +4 -0
- package/hedhog/table/course_file.yaml +23 -0
- package/hedhog/table/course_lesson.yaml +5 -0
- package/hedhog/table/course_lesson_discussion_like.yaml +21 -0
- package/hedhog/table/course_lesson_discussion_topic.yaml +35 -0
- package/hedhog/table/course_lesson_note.yaml +34 -0
- package/hedhog/table/exam.yaml +5 -0
- package/hedhog/table/learning_path_enrollment.yaml +6 -0
- package/hedhog/table/question.yaml +10 -0
- package/hedhog/table/question_subject.yaml +17 -0
- package/hedhog/table/student_activity_streak.yaml +25 -0
- package/package.json +7 -7
- package/src/achievement/achievement.controller.ts +60 -0
- package/src/achievement/achievement.mcp-tools.ts +108 -0
- package/src/achievement/achievement.module.ts +13 -0
- package/src/achievement/achievement.service.ts +252 -0
- package/src/achievement/dto/create-achievement.dto.ts +50 -0
- package/src/achievement/dto/update-achievement.dto.ts +47 -0
- package/src/bitcode-wallet/bitcode-wallet.controller.ts +69 -0
- package/src/bitcode-wallet/bitcode-wallet.mcp-tools.ts +107 -0
- package/src/bitcode-wallet/bitcode-wallet.module.ts +13 -0
- package/src/bitcode-wallet/bitcode-wallet.service.ts +361 -0
- package/src/bitcode-wallet/dto/create-bitcode-wallet-transaction.dto.ts +27 -0
- package/src/bitcode-wallet/dto/create-bitcode-wallet.dto.ts +7 -0
- package/src/bitcode-wallet/dto/update-bitcode-wallet-transaction.dto.ts +28 -0
- package/src/bitcode-wallet/dto/update-bitcode-wallet.dto.ts +8 -0
- package/src/certificate/certificate.controller.ts +20 -11
- package/src/certificate/certificate.mcp-tools.ts +131 -0
- package/src/certificate/certificate.module.ts +2 -1
- package/src/certificate/certificate.service.ts +95 -4
- package/src/certificate/dto/update-certificate-public-access.dto.ts +6 -0
- package/src/class-group/class-group.mcp-tools.ts +435 -0
- package/src/class-group/class-group.module.ts +2 -1
- package/src/class-group/class-group.service.ts +51 -1
- package/src/course/course-operations-integration.service.ts +520 -0
- package/src/course/course-structure.controller.ts +22 -8
- package/src/course/course-structure.service.ts +215 -23
- package/src/course/course.mcp-tools.ts +409 -0
- package/src/course/course.module.ts +8 -1
- package/src/course/course.service.ts +106 -27
- package/src/course/dto/create-course.dto.ts +8 -0
- package/src/course/dto/update-course-resources.dto.ts +39 -0
- package/src/course-lesson-discussion/course-lesson-discussion.controller.ts +55 -0
- package/src/course-lesson-discussion/course-lesson-discussion.mcp-tools.ts +75 -0
- package/src/course-lesson-discussion/course-lesson-discussion.module.ts +13 -0
- package/src/course-lesson-discussion/course-lesson-discussion.service.ts +354 -0
- package/src/course-lesson-discussion/dto/create-course-lesson-discussion-topic.dto.ts +16 -0
- package/src/course-lesson-note/course-lesson-note.controller.ts +68 -0
- package/src/course-lesson-note/course-lesson-note.mcp-tools.ts +96 -0
- package/src/course-lesson-note/course-lesson-note.module.ts +13 -0
- package/src/course-lesson-note/course-lesson-note.service.ts +248 -0
- package/src/course-lesson-note/dto/create-course-lesson-note.dto.ts +16 -0
- package/src/course-lesson-note/dto/update-course-lesson-note.dto.ts +18 -0
- package/src/dashboard/dashboard.mcp-tools.ts +23 -0
- package/src/dashboard/dashboard.module.ts +2 -1
- package/src/enterprise/enterprise.mcp-tools.ts +403 -0
- package/src/enterprise/enterprise.module.ts +2 -1
- package/src/enterprise/training/enterprise-training.module.ts +11 -1
- package/src/enterprise/training/training-admin.mcp-tools.ts +479 -0
- package/src/enterprise/training/training-instructor.mcp-tools.ts +210 -0
- package/src/enterprise/training/training-student.controller.ts +17 -1
- package/src/enterprise/training/training-student.mcp-tools.ts +136 -0
- package/src/enterprise/training/training-student.service.ts +167 -1
- package/src/evaluation/evaluation.mcp-tools.ts +155 -0
- package/src/evaluation/evaluation.module.ts +2 -1
- package/src/exam/dto/create-exam-question.dto.ts +8 -0
- package/src/exam/dto/create-exam.dto.ts +8 -0
- package/src/exam/dto/create-question-subject.dto.ts +12 -0
- package/src/exam/exam-attempt.service.ts +46 -14
- package/src/exam/exam.controller.ts +19 -0
- package/src/exam/exam.mcp-tools.ts +337 -0
- package/src/exam/exam.module.ts +2 -1
- package/src/exam/exam.service.ts +121 -0
- package/src/index.ts +9 -0
- package/src/instructor/instructor.mcp-tools.ts +243 -0
- package/src/instructor/instructor.module.ts +2 -1
- package/src/lms.module.ts +15 -1
- package/src/realtime/lms-realtime.controller.ts +12 -0
- package/src/realtime/lms-realtime.module.ts +12 -0
- package/src/realtime/lms-realtime.service.ts +98 -0
- package/src/realtime/lms-realtime.subscriber.ts +61 -0
- package/src/reports/reports.mcp-tools.ts +27 -0
- package/src/reports/reports.module.ts +2 -1
- package/src/training/training.mcp-tools.ts +128 -0
- package/src/training/training.module.ts +2 -1
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { PrismaService } from '@hed-hog/api-prisma';
|
|
2
2
|
import { IntegrationDeveloperApiService } from '@hed-hog/core';
|
|
3
3
|
import { BadRequestException, Inject, Injectable, forwardRef } from '@nestjs/common';
|
|
4
|
+
import { CourseOperationsIntegrationService } from './course-operations-integration.service';
|
|
4
5
|
import { CreateCourseDto } from './dto/create-course.dto';
|
|
5
6
|
import { UpdateCourseDto } from './dto/update-course.dto';
|
|
6
7
|
|
|
@@ -14,6 +15,12 @@ type CourseExtraFields = {
|
|
|
14
15
|
offering_type?: 'scheduled' | 'on_demand' | 'blended' | null;
|
|
15
16
|
};
|
|
16
17
|
|
|
18
|
+
type CourseProjectFields = {
|
|
19
|
+
projectId?: number | null;
|
|
20
|
+
projectCode?: string | null;
|
|
21
|
+
projectName?: string | null;
|
|
22
|
+
};
|
|
23
|
+
|
|
17
24
|
type PersistCourseExtrasInput = {
|
|
18
25
|
name?: string;
|
|
19
26
|
isFeatured?: boolean;
|
|
@@ -28,6 +35,7 @@ export class CourseService {
|
|
|
28
35
|
private readonly prisma: PrismaService,
|
|
29
36
|
@Inject(forwardRef(() => IntegrationDeveloperApiService))
|
|
30
37
|
private readonly integrationApi: IntegrationDeveloperApiService,
|
|
38
|
+
private readonly operationsIntegration: CourseOperationsIntegrationService,
|
|
31
39
|
) {}
|
|
32
40
|
|
|
33
41
|
private normalizeLevel(value?: string | null) {
|
|
@@ -200,16 +208,25 @@ export class CourseService {
|
|
|
200
208
|
this.prisma.course.count({ where }),
|
|
201
209
|
]);
|
|
202
210
|
|
|
203
|
-
const
|
|
204
|
-
|
|
205
|
-
|
|
211
|
+
const courseIds = courses.map((course) => course.id);
|
|
212
|
+
const [extrasById, projectLinksById] = await Promise.all([
|
|
213
|
+
this.getCourseExtras(courseIds),
|
|
214
|
+
this.operationsIntegration.getCourseProjectLinks(courseIds),
|
|
215
|
+
]);
|
|
206
216
|
|
|
207
217
|
return {
|
|
208
218
|
total,
|
|
209
219
|
page,
|
|
210
220
|
pageSize,
|
|
211
221
|
lastPage: Math.max(1, Math.ceil(total / pageSize)),
|
|
212
|
-
data: courses.map((c) =>
|
|
222
|
+
data: courses.map((c) =>
|
|
223
|
+
this.mapCourse(
|
|
224
|
+
c,
|
|
225
|
+
undefined,
|
|
226
|
+
extrasById.get(c.id),
|
|
227
|
+
projectLinksById.get(c.id),
|
|
228
|
+
),
|
|
229
|
+
),
|
|
213
230
|
};
|
|
214
231
|
}
|
|
215
232
|
|
|
@@ -293,7 +310,10 @@ export class CourseService {
|
|
|
293
310
|
|
|
294
311
|
if (!c) return null;
|
|
295
312
|
|
|
296
|
-
const extrasById = await
|
|
313
|
+
const [extrasById, projectLinksById] = await Promise.all([
|
|
314
|
+
this.getCourseExtras([id]),
|
|
315
|
+
this.operationsIntegration.getCourseProjectLinks([id]),
|
|
316
|
+
]);
|
|
297
317
|
|
|
298
318
|
const [lessonCount, sessionCount, certificatesIssued, avgProgress, modules] =
|
|
299
319
|
await Promise.all([
|
|
@@ -344,13 +364,18 @@ export class CourseService {
|
|
|
344
364
|
};
|
|
345
365
|
});
|
|
346
366
|
|
|
347
|
-
return this.mapCourse(
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
367
|
+
return this.mapCourse(
|
|
368
|
+
c,
|
|
369
|
+
{
|
|
370
|
+
lessonCount,
|
|
371
|
+
sessionCount,
|
|
372
|
+
certificatesIssued,
|
|
373
|
+
averageCompletion: avgProgress._avg.progress_percent ?? 0,
|
|
374
|
+
progressByModule,
|
|
375
|
+
},
|
|
376
|
+
extrasById.get(id),
|
|
377
|
+
projectLinksById.get(id),
|
|
378
|
+
);
|
|
354
379
|
}
|
|
355
380
|
|
|
356
381
|
async create(dto: CreateCourseDto) {
|
|
@@ -360,12 +385,17 @@ export class CourseService {
|
|
|
360
385
|
bannerFileId,
|
|
361
386
|
instructorIds,
|
|
362
387
|
certificateModel,
|
|
388
|
+
operationsProjectId,
|
|
363
389
|
...data
|
|
364
390
|
} = dto;
|
|
365
391
|
const normalizedSlug = data.slug.trim();
|
|
366
392
|
const resolvedTitle = this.resolveCourseTitle(data.title, normalizedSlug);
|
|
367
393
|
const certificateTemplateId =
|
|
368
394
|
await this.resolveCertificateTemplateId(certificateModel);
|
|
395
|
+
const resolvedOperationsProjectId =
|
|
396
|
+
await this.operationsIntegration.resolveOperationsProjectId(
|
|
397
|
+
operationsProjectId,
|
|
398
|
+
);
|
|
369
399
|
|
|
370
400
|
const categories = categorySlugs?.length
|
|
371
401
|
? await this.prisma.category.findMany({
|
|
@@ -491,10 +521,22 @@ export class CourseService {
|
|
|
491
521
|
...data,
|
|
492
522
|
offeringType: this.normalizeOfferingType(data.offeringType) ?? 'on_demand',
|
|
493
523
|
});
|
|
524
|
+
await this.operationsIntegration.persistCourseProjectLink(
|
|
525
|
+
c.id,
|
|
526
|
+
resolvedOperationsProjectId ?? null,
|
|
527
|
+
);
|
|
494
528
|
|
|
495
|
-
const extrasById = await
|
|
529
|
+
const [extrasById, projectLinksById] = await Promise.all([
|
|
530
|
+
this.getCourseExtras([c.id]),
|
|
531
|
+
this.operationsIntegration.getCourseProjectLinks([c.id]),
|
|
532
|
+
]);
|
|
496
533
|
|
|
497
|
-
const result = this.mapCourse(
|
|
534
|
+
const result = this.mapCourse(
|
|
535
|
+
c,
|
|
536
|
+
undefined,
|
|
537
|
+
extrasById.get(c.id),
|
|
538
|
+
projectLinksById.get(c.id),
|
|
539
|
+
);
|
|
498
540
|
|
|
499
541
|
await this.integrationApi.publishEvent({
|
|
500
542
|
eventName: 'lms.course.created',
|
|
@@ -514,6 +556,7 @@ export class CourseService {
|
|
|
514
556
|
bannerFileId,
|
|
515
557
|
instructorIds,
|
|
516
558
|
certificateModel,
|
|
559
|
+
operationsProjectId,
|
|
517
560
|
...data
|
|
518
561
|
} = dto;
|
|
519
562
|
let existingSlug: string | undefined;
|
|
@@ -538,6 +581,10 @@ export class CourseService {
|
|
|
538
581
|
: undefined;
|
|
539
582
|
const certificateTemplateId =
|
|
540
583
|
await this.resolveCertificateTemplateId(certificateModel);
|
|
584
|
+
const resolvedOperationsProjectId =
|
|
585
|
+
await this.operationsIntegration.resolveOperationsProjectId(
|
|
586
|
+
operationsProjectId,
|
|
587
|
+
);
|
|
541
588
|
|
|
542
589
|
const categories = categorySlugs?.length
|
|
543
590
|
? await this.prisma.category.findMany({
|
|
@@ -682,10 +729,27 @@ export class CourseService {
|
|
|
682
729
|
});
|
|
683
730
|
|
|
684
731
|
await this.persistCourseExtras(id, data);
|
|
732
|
+
if (resolvedOperationsProjectId !== undefined) {
|
|
733
|
+
await this.operationsIntegration.persistCourseProjectLink(
|
|
734
|
+
id,
|
|
735
|
+
resolvedOperationsProjectId,
|
|
736
|
+
);
|
|
737
|
+
if (resolvedOperationsProjectId) {
|
|
738
|
+
await this.operationsIntegration.createMissingTasksForCourseLessons(id);
|
|
739
|
+
}
|
|
740
|
+
}
|
|
685
741
|
|
|
686
|
-
const extrasById = await
|
|
742
|
+
const [extrasById, projectLinksById] = await Promise.all([
|
|
743
|
+
this.getCourseExtras([id]),
|
|
744
|
+
this.operationsIntegration.getCourseProjectLinks([id]),
|
|
745
|
+
]);
|
|
687
746
|
|
|
688
|
-
const updateResult = this.mapCourse(
|
|
747
|
+
const updateResult = this.mapCourse(
|
|
748
|
+
c,
|
|
749
|
+
undefined,
|
|
750
|
+
extrasById.get(id),
|
|
751
|
+
projectLinksById.get(id),
|
|
752
|
+
);
|
|
689
753
|
|
|
690
754
|
await this.integrationApi.publishEvent({
|
|
691
755
|
eventName: 'lms.course.updated',
|
|
@@ -726,6 +790,7 @@ export class CourseService {
|
|
|
726
790
|
}[];
|
|
727
791
|
},
|
|
728
792
|
extras?: CourseExtraFields,
|
|
793
|
+
project?: CourseProjectFields,
|
|
729
794
|
) {
|
|
730
795
|
const resolvedName = extras?.name ?? c.name ?? null;
|
|
731
796
|
const resolvedTitle = this.normalizeOptionalText(c.title) ?? c.slug;
|
|
@@ -789,6 +854,9 @@ export class CourseService {
|
|
|
789
854
|
hasCertificate: extras?.has_certificate ?? c.has_certificate ?? false,
|
|
790
855
|
isListed: extras?.is_listed ?? c.is_listed ?? false,
|
|
791
856
|
offeringType,
|
|
857
|
+
operationsProjectId: project?.projectId ?? null,
|
|
858
|
+
operationsProjectCode: project?.projectCode ?? null,
|
|
859
|
+
operationsProjectName: project?.projectName ?? null,
|
|
792
860
|
enrollmentCount: c._count?.course_enrollment ?? 0,
|
|
793
861
|
moduleCount: c._count?.course_module ?? 0,
|
|
794
862
|
classCount,
|
|
@@ -879,37 +947,48 @@ export class CourseService {
|
|
|
879
947
|
id: number,
|
|
880
948
|
data: PersistCourseExtrasInput,
|
|
881
949
|
) {
|
|
882
|
-
const
|
|
950
|
+
const setClauses: string[] = [];
|
|
951
|
+
const values: Array<string | boolean | number> = [];
|
|
952
|
+
|
|
953
|
+
const pushSetClause = (column: string, value: string | boolean) => {
|
|
954
|
+
values.push(value);
|
|
955
|
+
setClauses.push(`${column} = $${values.length}`);
|
|
956
|
+
};
|
|
883
957
|
|
|
884
958
|
if (data.name !== undefined) {
|
|
885
|
-
|
|
959
|
+
pushSetClause('name', data.name);
|
|
886
960
|
}
|
|
887
961
|
|
|
888
962
|
if (data.isFeatured !== undefined) {
|
|
889
|
-
|
|
963
|
+
pushSetClause('is_featured', data.isFeatured);
|
|
890
964
|
}
|
|
891
965
|
|
|
892
966
|
if (data.hasCertificate !== undefined) {
|
|
893
|
-
|
|
967
|
+
pushSetClause('has_certificate', data.hasCertificate);
|
|
894
968
|
}
|
|
895
969
|
|
|
896
970
|
if (data.isListed !== undefined) {
|
|
897
|
-
|
|
971
|
+
pushSetClause('is_listed', data.isListed);
|
|
898
972
|
}
|
|
899
973
|
|
|
900
974
|
if (data.offeringType !== undefined) {
|
|
901
|
-
|
|
975
|
+
pushSetClause('offering_type', data.offeringType);
|
|
902
976
|
}
|
|
903
977
|
|
|
904
|
-
if (
|
|
978
|
+
if (setClauses.length === 0) {
|
|
905
979
|
return;
|
|
906
980
|
}
|
|
907
981
|
|
|
908
982
|
try {
|
|
909
|
-
|
|
910
|
-
|
|
911
|
-
|
|
912
|
-
|
|
983
|
+
values.push(id);
|
|
984
|
+
await this.prisma.$executeRawUnsafe(
|
|
985
|
+
`
|
|
986
|
+
UPDATE course
|
|
987
|
+
SET ${setClauses.join(', ')}
|
|
988
|
+
WHERE id = $${values.length}
|
|
989
|
+
`,
|
|
990
|
+
...values,
|
|
991
|
+
);
|
|
913
992
|
} catch {
|
|
914
993
|
// Some environments may still be behind the current course schema.
|
|
915
994
|
}
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
import {
|
|
2
|
+
Type,
|
|
3
|
+
} from 'class-transformer';
|
|
1
4
|
import {
|
|
2
5
|
IsArray,
|
|
3
6
|
IsBoolean,
|
|
@@ -115,4 +118,9 @@ export class CreateCourseDto {
|
|
|
115
118
|
@IsInt()
|
|
116
119
|
@IsOptional()
|
|
117
120
|
bannerFileId?: number | null;
|
|
121
|
+
|
|
122
|
+
@Type(() => Number)
|
|
123
|
+
@IsInt()
|
|
124
|
+
@IsOptional()
|
|
125
|
+
operationsProjectId?: number | null;
|
|
118
126
|
}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { Type } from 'class-transformer';
|
|
2
|
+
import {
|
|
3
|
+
IsArray,
|
|
4
|
+
IsBoolean,
|
|
5
|
+
IsInt,
|
|
6
|
+
IsNotEmpty,
|
|
7
|
+
IsOptional,
|
|
8
|
+
IsString,
|
|
9
|
+
MaxLength,
|
|
10
|
+
Min,
|
|
11
|
+
ValidateNested,
|
|
12
|
+
} from 'class-validator';
|
|
13
|
+
|
|
14
|
+
class CourseResourceDto {
|
|
15
|
+
@IsString()
|
|
16
|
+
@IsNotEmpty()
|
|
17
|
+
@MaxLength(255)
|
|
18
|
+
nome: string;
|
|
19
|
+
|
|
20
|
+
@IsInt()
|
|
21
|
+
@Min(1)
|
|
22
|
+
@IsOptional()
|
|
23
|
+
fileId?: number;
|
|
24
|
+
|
|
25
|
+
@IsString()
|
|
26
|
+
@IsOptional()
|
|
27
|
+
tipo?: string;
|
|
28
|
+
|
|
29
|
+
@IsBoolean()
|
|
30
|
+
@IsOptional()
|
|
31
|
+
publico?: boolean;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
export class UpdateCourseResourcesDto {
|
|
35
|
+
@IsArray()
|
|
36
|
+
@ValidateNested({ each: true })
|
|
37
|
+
@Type(() => CourseResourceDto)
|
|
38
|
+
recursos: CourseResourceDto[] = [];
|
|
39
|
+
}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Role, User } from '@hed-hog/api';
|
|
2
|
+
import {
|
|
3
|
+
Body,
|
|
4
|
+
Controller,
|
|
5
|
+
Delete,
|
|
6
|
+
Get,
|
|
7
|
+
Param,
|
|
8
|
+
ParseIntPipe,
|
|
9
|
+
Post,
|
|
10
|
+
} from '@nestjs/common';
|
|
11
|
+
import { CreateCourseLessonDiscussionTopicDto } from './dto/create-course-lesson-discussion-topic.dto';
|
|
12
|
+
import { CourseLessonDiscussionService } from './course-lesson-discussion.service';
|
|
13
|
+
|
|
14
|
+
@Role()
|
|
15
|
+
@Controller('lms/course-lessons/:lessonId/discussion')
|
|
16
|
+
export class CourseLessonDiscussionController {
|
|
17
|
+
constructor(
|
|
18
|
+
private readonly discussionService: CourseLessonDiscussionService
|
|
19
|
+
) {}
|
|
20
|
+
|
|
21
|
+
@Get('topics')
|
|
22
|
+
listTopics(
|
|
23
|
+
@Param('lessonId', ParseIntPipe) lessonId: number,
|
|
24
|
+
@User('id') userId: number
|
|
25
|
+
) {
|
|
26
|
+
return this.discussionService.listTopics(lessonId, userId);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
@Post('topics')
|
|
30
|
+
createTopic(
|
|
31
|
+
@Param('lessonId', ParseIntPipe) lessonId: number,
|
|
32
|
+
@User('id') userId: number,
|
|
33
|
+
@Body() dto: CreateCourseLessonDiscussionTopicDto
|
|
34
|
+
) {
|
|
35
|
+
return this.discussionService.createTopic(lessonId, userId, dto);
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
@Post('topics/:topicId/likes')
|
|
39
|
+
likeTopic(
|
|
40
|
+
@Param('lessonId', ParseIntPipe) lessonId: number,
|
|
41
|
+
@Param('topicId', ParseIntPipe) topicId: number,
|
|
42
|
+
@User('id') userId: number
|
|
43
|
+
) {
|
|
44
|
+
return this.discussionService.likeTopic(lessonId, topicId, userId);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
@Delete('topics/:topicId/likes')
|
|
48
|
+
unlikeTopic(
|
|
49
|
+
@Param('lessonId', ParseIntPipe) lessonId: number,
|
|
50
|
+
@Param('topicId', ParseIntPipe) topicId: number,
|
|
51
|
+
@User('id') userId: number
|
|
52
|
+
) {
|
|
53
|
+
return this.discussionService.unlikeTopic(lessonId, topicId, userId);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { McpContext, McpTool } from '@hed-hog/core';
|
|
2
|
+
import { Injectable } from '@nestjs/common';
|
|
3
|
+
import { CourseLessonDiscussionService } from './course-lesson-discussion.service';
|
|
4
|
+
|
|
5
|
+
@Injectable()
|
|
6
|
+
export class LmsCourseLessonDiscussionMcpTools {
|
|
7
|
+
constructor(private readonly discussionService: CourseLessonDiscussionService) {}
|
|
8
|
+
|
|
9
|
+
@McpTool({
|
|
10
|
+
name: 'lms.lesson-discussion.topics.list',
|
|
11
|
+
description: 'Lists discussion topics for a course lesson, returned as a thread tree. Requires the authenticated user to be enrolled in the course.',
|
|
12
|
+
inputSchema: {
|
|
13
|
+
type: 'object',
|
|
14
|
+
properties: {
|
|
15
|
+
lessonId: { type: 'number', description: 'Course lesson ID' },
|
|
16
|
+
},
|
|
17
|
+
required: ['lessonId'],
|
|
18
|
+
},
|
|
19
|
+
readOnly: true,
|
|
20
|
+
})
|
|
21
|
+
async listTopics(args: { lessonId: number }, context: McpContext): Promise<any> {
|
|
22
|
+
return this.discussionService.listTopics(args.lessonId, context.userId);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
@McpTool({
|
|
26
|
+
name: 'lms.lesson-discussion.topics.create',
|
|
27
|
+
description: 'Creates a new discussion topic (or reply) on a course lesson.',
|
|
28
|
+
inputSchema: {
|
|
29
|
+
type: 'object',
|
|
30
|
+
properties: {
|
|
31
|
+
lessonId: { type: 'number', description: 'Course lesson ID' },
|
|
32
|
+
content: { type: 'string', description: 'Topic content (HTML allowed, scripts stripped)' },
|
|
33
|
+
playerTimeSeconds: { type: 'number', description: 'Video player timestamp in seconds when the topic was created' },
|
|
34
|
+
parentTopicId: { type: 'number', description: 'Parent topic ID for replies' },
|
|
35
|
+
},
|
|
36
|
+
required: ['lessonId', 'content', 'playerTimeSeconds'],
|
|
37
|
+
},
|
|
38
|
+
})
|
|
39
|
+
async createTopic(args: { lessonId: number; [key: string]: any }, context: McpContext): Promise<any> {
|
|
40
|
+
const { lessonId, ...dto } = args;
|
|
41
|
+
return this.discussionService.createTopic(lessonId, context.userId, dto as any);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
@McpTool({
|
|
45
|
+
name: 'lms.lesson-discussion.topics.like',
|
|
46
|
+
description: 'Likes a discussion topic on a course lesson.',
|
|
47
|
+
inputSchema: {
|
|
48
|
+
type: 'object',
|
|
49
|
+
properties: {
|
|
50
|
+
lessonId: { type: 'number', description: 'Course lesson ID' },
|
|
51
|
+
topicId: { type: 'number', description: 'Topic ID to like' },
|
|
52
|
+
},
|
|
53
|
+
required: ['lessonId', 'topicId'],
|
|
54
|
+
},
|
|
55
|
+
})
|
|
56
|
+
async likeTopic(args: { lessonId: number; topicId: number }, context: McpContext): Promise<any> {
|
|
57
|
+
return this.discussionService.likeTopic(args.lessonId, args.topicId, context.userId);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
@McpTool({
|
|
61
|
+
name: 'lms.lesson-discussion.topics.unlike',
|
|
62
|
+
description: 'Removes the like from a discussion topic on a course lesson.',
|
|
63
|
+
inputSchema: {
|
|
64
|
+
type: 'object',
|
|
65
|
+
properties: {
|
|
66
|
+
lessonId: { type: 'number', description: 'Course lesson ID' },
|
|
67
|
+
topicId: { type: 'number', description: 'Topic ID to unlike' },
|
|
68
|
+
},
|
|
69
|
+
required: ['lessonId', 'topicId'],
|
|
70
|
+
},
|
|
71
|
+
})
|
|
72
|
+
async unlikeTopic(args: { lessonId: number; topicId: number }, context: McpContext): Promise<any> {
|
|
73
|
+
return this.discussionService.unlikeTopic(args.lessonId, args.topicId, context.userId);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { PrismaModule } from '@hed-hog/api-prisma';
|
|
2
|
+
import { forwardRef, Module } from '@nestjs/common';
|
|
3
|
+
import { CourseLessonDiscussionController } from './course-lesson-discussion.controller';
|
|
4
|
+
import { LmsCourseLessonDiscussionMcpTools } from './course-lesson-discussion.mcp-tools';
|
|
5
|
+
import { CourseLessonDiscussionService } from './course-lesson-discussion.service';
|
|
6
|
+
|
|
7
|
+
@Module({
|
|
8
|
+
imports: [forwardRef(() => PrismaModule)],
|
|
9
|
+
controllers: [CourseLessonDiscussionController],
|
|
10
|
+
providers: [CourseLessonDiscussionService, LmsCourseLessonDiscussionMcpTools],
|
|
11
|
+
exports: [CourseLessonDiscussionService],
|
|
12
|
+
})
|
|
13
|
+
export class CourseLessonDiscussionModule {}
|