@hed-hog/lms 0.0.349 → 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.
Files changed (409) hide show
  1. package/dist/achievement/achievement.controller.d.ts +62 -0
  2. package/dist/achievement/achievement.controller.d.ts.map +1 -0
  3. package/dist/achievement/achievement.controller.js +90 -0
  4. package/dist/achievement/achievement.controller.js.map +1 -0
  5. package/dist/achievement/achievement.mcp-tools.d.ts +19 -0
  6. package/dist/achievement/achievement.mcp-tools.d.ts.map +1 -0
  7. package/dist/achievement/achievement.mcp-tools.js +157 -0
  8. package/dist/achievement/achievement.mcp-tools.js.map +1 -0
  9. package/dist/achievement/achievement.module.d.ts +3 -0
  10. package/dist/achievement/achievement.module.d.ts.map +1 -0
  11. package/dist/achievement/achievement.module.js +26 -0
  12. package/dist/achievement/achievement.module.js.map +1 -0
  13. package/dist/achievement/achievement.service.d.ts +72 -0
  14. package/dist/achievement/achievement.service.d.ts.map +1 -0
  15. package/dist/achievement/achievement.service.js +200 -0
  16. package/dist/achievement/achievement.service.js.map +1 -0
  17. package/dist/achievement/dto/create-achievement.dto.d.ts +12 -0
  18. package/dist/achievement/dto/create-achievement.dto.d.ts.map +1 -0
  19. package/dist/achievement/dto/create-achievement.dto.js +60 -0
  20. package/dist/achievement/dto/create-achievement.dto.js.map +1 -0
  21. package/dist/achievement/dto/update-achievement.dto.d.ts +11 -0
  22. package/dist/achievement/dto/update-achievement.dto.d.ts.map +1 -0
  23. package/dist/achievement/dto/update-achievement.dto.js +57 -0
  24. package/dist/achievement/dto/update-achievement.dto.js.map +1 -0
  25. package/dist/bitcode-wallet/bitcode-wallet.controller.d.ts +114 -0
  26. package/dist/bitcode-wallet/bitcode-wallet.controller.d.ts.map +1 -0
  27. package/dist/bitcode-wallet/bitcode-wallet.controller.js +102 -0
  28. package/dist/bitcode-wallet/bitcode-wallet.controller.js.map +1 -0
  29. package/dist/bitcode-wallet/bitcode-wallet.mcp-tools.d.ts +25 -0
  30. package/dist/bitcode-wallet/bitcode-wallet.mcp-tools.d.ts.map +1 -0
  31. package/dist/bitcode-wallet/bitcode-wallet.mcp-tools.js +160 -0
  32. package/dist/bitcode-wallet/bitcode-wallet.mcp-tools.js.map +1 -0
  33. package/dist/bitcode-wallet/bitcode-wallet.module.d.ts +3 -0
  34. package/dist/bitcode-wallet/bitcode-wallet.module.d.ts.map +1 -0
  35. package/dist/bitcode-wallet/bitcode-wallet.module.js +26 -0
  36. package/dist/bitcode-wallet/bitcode-wallet.module.js.map +1 -0
  37. package/dist/bitcode-wallet/bitcode-wallet.service.d.ts +127 -0
  38. package/dist/bitcode-wallet/bitcode-wallet.service.d.ts.map +1 -0
  39. package/dist/bitcode-wallet/bitcode-wallet.service.js +264 -0
  40. package/dist/bitcode-wallet/bitcode-wallet.service.js.map +1 -0
  41. package/dist/bitcode-wallet/dto/create-bitcode-wallet-transaction.dto.d.ts +8 -0
  42. package/dist/bitcode-wallet/dto/create-bitcode-wallet-transaction.dto.d.ts.map +1 -0
  43. package/dist/bitcode-wallet/dto/create-bitcode-wallet-transaction.dto.js +33 -0
  44. package/dist/bitcode-wallet/dto/create-bitcode-wallet-transaction.dto.js.map +1 -0
  45. package/dist/bitcode-wallet/dto/create-bitcode-wallet.dto.d.ts +4 -0
  46. package/dist/bitcode-wallet/dto/create-bitcode-wallet.dto.d.ts.map +1 -0
  47. package/dist/bitcode-wallet/dto/create-bitcode-wallet.dto.js +22 -0
  48. package/dist/bitcode-wallet/dto/create-bitcode-wallet.dto.js.map +1 -0
  49. package/dist/bitcode-wallet/dto/update-bitcode-wallet-transaction.dto.d.ts +7 -0
  50. package/dist/bitcode-wallet/dto/update-bitcode-wallet-transaction.dto.d.ts.map +1 -0
  51. package/dist/bitcode-wallet/dto/update-bitcode-wallet-transaction.dto.js +35 -0
  52. package/dist/bitcode-wallet/dto/update-bitcode-wallet-transaction.dto.js.map +1 -0
  53. package/dist/bitcode-wallet/dto/update-bitcode-wallet.dto.d.ts +4 -0
  54. package/dist/bitcode-wallet/dto/update-bitcode-wallet.dto.d.ts.map +1 -0
  55. package/dist/bitcode-wallet/dto/update-bitcode-wallet.dto.js +23 -0
  56. package/dist/bitcode-wallet/dto/update-bitcode-wallet.dto.js.map +1 -0
  57. package/dist/certificate/certificate.controller.d.ts +22 -0
  58. package/dist/certificate/certificate.controller.d.ts.map +1 -1
  59. package/dist/certificate/certificate.controller.js +12 -0
  60. package/dist/certificate/certificate.controller.js.map +1 -1
  61. package/dist/certificate/certificate.mcp-tools.d.ts +24 -0
  62. package/dist/certificate/certificate.mcp-tools.d.ts.map +1 -0
  63. package/dist/certificate/certificate.mcp-tools.js +188 -0
  64. package/dist/certificate/certificate.mcp-tools.js.map +1 -0
  65. package/dist/certificate/certificate.module.d.ts.map +1 -1
  66. package/dist/certificate/certificate.module.js +2 -1
  67. package/dist/certificate/certificate.module.js.map +1 -1
  68. package/dist/certificate/certificate.service.d.ts +25 -2
  69. package/dist/certificate/certificate.service.d.ts.map +1 -1
  70. package/dist/certificate/certificate.service.js +87 -2
  71. package/dist/certificate/certificate.service.js.map +1 -1
  72. package/dist/certificate/dto/update-certificate-public-access.dto.d.ts +4 -0
  73. package/dist/certificate/dto/update-certificate-public-access.dto.d.ts.map +1 -0
  74. package/dist/certificate/dto/update-certificate-public-access.dto.js +21 -0
  75. package/dist/certificate/dto/update-certificate-public-access.dto.js.map +1 -0
  76. package/dist/class-group/class-group.mcp-tools.d.ts +87 -0
  77. package/dist/class-group/class-group.mcp-tools.d.ts.map +1 -0
  78. package/dist/class-group/class-group.mcp-tools.js +553 -0
  79. package/dist/class-group/class-group.mcp-tools.js.map +1 -0
  80. package/dist/class-group/class-group.module.d.ts.map +1 -1
  81. package/dist/class-group/class-group.module.js +2 -1
  82. package/dist/class-group/class-group.module.js.map +1 -1
  83. package/dist/class-group/class-group.service.d.ts +3 -1
  84. package/dist/class-group/class-group.service.d.ts.map +1 -1
  85. package/dist/class-group/class-group.service.js +45 -2
  86. package/dist/class-group/class-group.service.js.map +1 -1
  87. package/dist/course/course-operations-integration.service.d.ts +40 -0
  88. package/dist/course/course-operations-integration.service.d.ts.map +1 -0
  89. package/dist/course/course-operations-integration.service.js +372 -0
  90. package/dist/course/course-operations-integration.service.js.map +1 -0
  91. package/dist/course/course-structure.controller.d.ts +43 -4
  92. package/dist/course/course-structure.controller.d.ts.map +1 -1
  93. package/dist/course/course-structure.controller.js +22 -0
  94. package/dist/course/course-structure.controller.js.map +1 -1
  95. package/dist/course/course-structure.service.d.ts +42 -1
  96. package/dist/course/course-structure.service.d.ts.map +1 -1
  97. package/dist/course/course-structure.service.js +199 -32
  98. package/dist/course/course-structure.service.js.map +1 -1
  99. package/dist/course/course.controller.d.ts +12 -0
  100. package/dist/course/course.controller.d.ts.map +1 -1
  101. package/dist/course/course.mcp-tools.d.ts +90 -0
  102. package/dist/course/course.mcp-tools.d.ts.map +1 -0
  103. package/dist/course/course.mcp-tools.js +520 -0
  104. package/dist/course/course.mcp-tools.js.map +1 -0
  105. package/dist/course/course.module.d.ts.map +1 -1
  106. package/dist/course/course.module.js +8 -1
  107. package/dist/course/course.module.js.map +1 -1
  108. package/dist/course/course.service.d.ts +15 -1
  109. package/dist/course/course.service.d.ts.map +1 -1
  110. package/dist/course/course.service.js +70 -35
  111. package/dist/course/course.service.js.map +1 -1
  112. package/dist/course/dto/create-course.dto.d.ts +1 -0
  113. package/dist/course/dto/create-course.dto.d.ts.map +1 -1
  114. package/dist/course/dto/create-course.dto.js +7 -0
  115. package/dist/course/dto/create-course.dto.js.map +1 -1
  116. package/dist/course/dto/update-course-resources.dto.d.ts +11 -0
  117. package/dist/course/dto/update-course-resources.dto.d.ts.map +1 -0
  118. package/dist/course/dto/update-course-resources.dto.js +51 -0
  119. package/dist/course/dto/update-course-resources.dto.js.map +1 -0
  120. package/dist/course-lesson-discussion/course-lesson-discussion.controller.d.ts +23 -0
  121. package/dist/course-lesson-discussion/course-lesson-discussion.controller.d.ts.map +1 -0
  122. package/dist/course-lesson-discussion/course-lesson-discussion.controller.js +78 -0
  123. package/dist/course-lesson-discussion/course-lesson-discussion.controller.js.map +1 -0
  124. package/dist/course-lesson-discussion/course-lesson-discussion.mcp-tools.d.ts +22 -0
  125. package/dist/course-lesson-discussion/course-lesson-discussion.mcp-tools.d.ts.map +1 -0
  126. package/dist/course-lesson-discussion/course-lesson-discussion.mcp-tools.js +120 -0
  127. package/dist/course-lesson-discussion/course-lesson-discussion.mcp-tools.js.map +1 -0
  128. package/dist/course-lesson-discussion/course-lesson-discussion.module.d.ts +3 -0
  129. package/dist/course-lesson-discussion/course-lesson-discussion.module.d.ts.map +1 -0
  130. package/dist/course-lesson-discussion/course-lesson-discussion.module.js +26 -0
  131. package/dist/course-lesson-discussion/course-lesson-discussion.module.js.map +1 -0
  132. package/dist/course-lesson-discussion/course-lesson-discussion.service.d.ts +49 -0
  133. package/dist/course-lesson-discussion/course-lesson-discussion.service.d.ts.map +1 -0
  134. package/dist/course-lesson-discussion/course-lesson-discussion.service.js +272 -0
  135. package/dist/course-lesson-discussion/course-lesson-discussion.service.js.map +1 -0
  136. package/dist/course-lesson-discussion/dto/create-course-lesson-discussion-topic.dto.d.ts +6 -0
  137. package/dist/course-lesson-discussion/dto/create-course-lesson-discussion-topic.dto.d.ts.map +1 -0
  138. package/dist/course-lesson-discussion/dto/create-course-lesson-discussion-topic.dto.js +33 -0
  139. package/dist/course-lesson-discussion/dto/create-course-lesson-discussion-topic.dto.js.map +1 -0
  140. package/dist/course-lesson-note/course-lesson-note.controller.d.ts +53 -0
  141. package/dist/course-lesson-note/course-lesson-note.controller.d.ts.map +1 -0
  142. package/dist/course-lesson-note/course-lesson-note.controller.js +93 -0
  143. package/dist/course-lesson-note/course-lesson-note.controller.js.map +1 -0
  144. package/dist/course-lesson-note/course-lesson-note.mcp-tools.d.ts +27 -0
  145. package/dist/course-lesson-note/course-lesson-note.mcp-tools.d.ts.map +1 -0
  146. package/dist/course-lesson-note/course-lesson-note.mcp-tools.js +145 -0
  147. package/dist/course-lesson-note/course-lesson-note.mcp-tools.js.map +1 -0
  148. package/dist/course-lesson-note/course-lesson-note.module.d.ts +3 -0
  149. package/dist/course-lesson-note/course-lesson-note.module.d.ts.map +1 -0
  150. package/dist/course-lesson-note/course-lesson-note.module.js +26 -0
  151. package/dist/course-lesson-note/course-lesson-note.module.js.map +1 -0
  152. package/dist/course-lesson-note/course-lesson-note.service.d.ts +59 -0
  153. package/dist/course-lesson-note/course-lesson-note.service.d.ts.map +1 -0
  154. package/dist/course-lesson-note/course-lesson-note.service.js +195 -0
  155. package/dist/course-lesson-note/course-lesson-note.service.js.map +1 -0
  156. package/dist/course-lesson-note/dto/create-course-lesson-note.dto.d.ts +6 -0
  157. package/dist/course-lesson-note/dto/create-course-lesson-note.dto.d.ts.map +1 -0
  158. package/dist/course-lesson-note/dto/create-course-lesson-note.dto.js +33 -0
  159. package/dist/course-lesson-note/dto/create-course-lesson-note.dto.js.map +1 -0
  160. package/dist/course-lesson-note/dto/update-course-lesson-note.dto.d.ts +6 -0
  161. package/dist/course-lesson-note/dto/update-course-lesson-note.dto.d.ts.map +1 -0
  162. package/dist/course-lesson-note/dto/update-course-lesson-note.dto.js +35 -0
  163. package/dist/course-lesson-note/dto/update-course-lesson-note.dto.js.map +1 -0
  164. package/dist/dashboard/dashboard.mcp-tools.d.ts +10 -0
  165. package/dist/dashboard/dashboard.mcp-tools.d.ts.map +1 -0
  166. package/dist/dashboard/dashboard.mcp-tools.js +46 -0
  167. package/dist/dashboard/dashboard.mcp-tools.js.map +1 -0
  168. package/dist/dashboard/dashboard.module.d.ts.map +1 -1
  169. package/dist/dashboard/dashboard.module.js +2 -1
  170. package/dist/dashboard/dashboard.module.js.map +1 -1
  171. package/dist/enterprise/enterprise.mcp-tools.d.ts +82 -0
  172. package/dist/enterprise/enterprise.mcp-tools.d.ts.map +1 -0
  173. package/dist/enterprise/enterprise.mcp-tools.js +516 -0
  174. package/dist/enterprise/enterprise.mcp-tools.js.map +1 -0
  175. package/dist/enterprise/enterprise.module.d.ts.map +1 -1
  176. package/dist/enterprise/enterprise.module.js +2 -1
  177. package/dist/enterprise/enterprise.module.js.map +1 -1
  178. package/dist/enterprise/training/enterprise-training.module.d.ts.map +1 -1
  179. package/dist/enterprise/training/enterprise-training.module.js +11 -1
  180. package/dist/enterprise/training/enterprise-training.module.js.map +1 -1
  181. package/dist/enterprise/training/training-admin.mcp-tools.d.ts +79 -0
  182. package/dist/enterprise/training/training-admin.mcp-tools.d.ts.map +1 -0
  183. package/dist/enterprise/training/training-admin.mcp-tools.js +620 -0
  184. package/dist/enterprise/training/training-admin.mcp-tools.js.map +1 -0
  185. package/dist/enterprise/training/training-instructor.mcp-tools.d.ts +47 -0
  186. package/dist/enterprise/training/training-instructor.mcp-tools.d.ts.map +1 -0
  187. package/dist/enterprise/training/training-instructor.mcp-tools.js +275 -0
  188. package/dist/enterprise/training/training-instructor.mcp-tools.js.map +1 -0
  189. package/dist/enterprise/training/training-student.controller.d.ts +24 -0
  190. package/dist/enterprise/training/training-student.controller.d.ts.map +1 -1
  191. package/dist/enterprise/training/training-student.controller.js +22 -0
  192. package/dist/enterprise/training/training-student.controller.js.map +1 -1
  193. package/dist/enterprise/training/training-student.mcp-tools.d.ts +27 -0
  194. package/dist/enterprise/training/training-student.mcp-tools.d.ts.map +1 -0
  195. package/dist/enterprise/training/training-student.mcp-tools.js +186 -0
  196. package/dist/enterprise/training/training-student.mcp-tools.js.map +1 -0
  197. package/dist/enterprise/training/training-student.service.d.ts +32 -0
  198. package/dist/enterprise/training/training-student.service.d.ts.map +1 -1
  199. package/dist/enterprise/training/training-student.service.js +138 -0
  200. package/dist/enterprise/training/training-student.service.js.map +1 -1
  201. package/dist/evaluation/evaluation.mcp-tools.d.ts +25 -0
  202. package/dist/evaluation/evaluation.mcp-tools.d.ts.map +1 -0
  203. package/dist/evaluation/evaluation.mcp-tools.js +220 -0
  204. package/dist/evaluation/evaluation.mcp-tools.js.map +1 -0
  205. package/dist/evaluation/evaluation.module.d.ts.map +1 -1
  206. package/dist/evaluation/evaluation.module.js +2 -1
  207. package/dist/evaluation/evaluation.module.js.map +1 -1
  208. package/dist/exam/dto/create-exam-question.dto.d.ts +2 -0
  209. package/dist/exam/dto/create-exam-question.dto.d.ts.map +1 -1
  210. package/dist/exam/dto/create-exam-question.dto.js +10 -0
  211. package/dist/exam/dto/create-exam-question.dto.js.map +1 -1
  212. package/dist/exam/dto/create-exam.dto.d.ts +2 -0
  213. package/dist/exam/dto/create-exam.dto.d.ts.map +1 -1
  214. package/dist/exam/dto/create-exam.dto.js +10 -0
  215. package/dist/exam/dto/create-exam.dto.js.map +1 -1
  216. package/dist/exam/dto/create-question-subject.dto.d.ts +5 -0
  217. package/dist/exam/dto/create-question-subject.dto.d.ts.map +1 -0
  218. package/dist/exam/dto/create-question-subject.dto.js +28 -0
  219. package/dist/exam/dto/create-question-subject.dto.js.map +1 -0
  220. package/dist/exam/exam-attempt.controller.d.ts +4 -0
  221. package/dist/exam/exam-attempt.controller.d.ts.map +1 -1
  222. package/dist/exam/exam-attempt.service.d.ts +7 -1
  223. package/dist/exam/exam-attempt.service.d.ts.map +1 -1
  224. package/dist/exam/exam-attempt.service.js +47 -17
  225. package/dist/exam/exam-attempt.service.js.map +1 -1
  226. package/dist/exam/exam.controller.d.ts +34 -0
  227. package/dist/exam/exam.controller.d.ts.map +1 -1
  228. package/dist/exam/exam.controller.js +27 -0
  229. package/dist/exam/exam.controller.js.map +1 -1
  230. package/dist/exam/exam.mcp-tools.d.ts +62 -0
  231. package/dist/exam/exam.mcp-tools.d.ts.map +1 -0
  232. package/dist/exam/exam.mcp-tools.js +430 -0
  233. package/dist/exam/exam.mcp-tools.js.map +1 -0
  234. package/dist/exam/exam.module.d.ts.map +1 -1
  235. package/dist/exam/exam.module.js +2 -1
  236. package/dist/exam/exam.module.js.map +1 -1
  237. package/dist/exam/exam.service.d.ts +38 -0
  238. package/dist/exam/exam.service.d.ts.map +1 -1
  239. package/dist/exam/exam.service.js +114 -17
  240. package/dist/exam/exam.service.js.map +1 -1
  241. package/dist/index.d.ts +9 -0
  242. package/dist/index.d.ts.map +1 -1
  243. package/dist/index.js +9 -0
  244. package/dist/index.js.map +1 -1
  245. package/dist/instructor/instructor.mcp-tools.d.ts +41 -0
  246. package/dist/instructor/instructor.mcp-tools.d.ts.map +1 -0
  247. package/dist/instructor/instructor.mcp-tools.js +326 -0
  248. package/dist/instructor/instructor.mcp-tools.js.map +1 -0
  249. package/dist/instructor/instructor.module.d.ts.map +1 -1
  250. package/dist/instructor/instructor.module.js +2 -1
  251. package/dist/instructor/instructor.module.js.map +1 -1
  252. package/dist/lms.module.d.ts.map +1 -1
  253. package/dist/lms.module.js +15 -0
  254. package/dist/lms.module.js.map +1 -1
  255. package/dist/realtime/lms-realtime.controller.d.ts +7 -0
  256. package/dist/realtime/lms-realtime.controller.d.ts.map +1 -0
  257. package/dist/realtime/lms-realtime.controller.js +34 -0
  258. package/dist/realtime/lms-realtime.controller.js.map +1 -0
  259. package/dist/realtime/lms-realtime.module.d.ts +3 -0
  260. package/dist/realtime/lms-realtime.module.d.ts.map +1 -0
  261. package/dist/realtime/lms-realtime.module.js +25 -0
  262. package/dist/realtime/lms-realtime.module.js.map +1 -0
  263. package/dist/realtime/lms-realtime.service.d.ts +36 -0
  264. package/dist/realtime/lms-realtime.service.d.ts.map +1 -0
  265. package/dist/realtime/lms-realtime.service.js +59 -0
  266. package/dist/realtime/lms-realtime.service.js.map +1 -0
  267. package/dist/realtime/lms-realtime.subscriber.d.ts +10 -0
  268. package/dist/realtime/lms-realtime.subscriber.d.ts.map +1 -0
  269. package/dist/realtime/lms-realtime.subscriber.js +70 -0
  270. package/dist/realtime/lms-realtime.subscriber.js.map +1 -0
  271. package/dist/reports/reports.mcp-tools.d.ts +10 -0
  272. package/dist/reports/reports.mcp-tools.d.ts.map +1 -0
  273. package/dist/reports/reports.mcp-tools.js +50 -0
  274. package/dist/reports/reports.mcp-tools.js.map +1 -0
  275. package/dist/reports/reports.module.d.ts.map +1 -1
  276. package/dist/reports/reports.module.js +2 -1
  277. package/dist/reports/reports.module.js.map +1 -1
  278. package/dist/training/training.mcp-tools.d.ts +20 -0
  279. package/dist/training/training.mcp-tools.d.ts.map +1 -0
  280. package/dist/training/training.mcp-tools.js +181 -0
  281. package/dist/training/training.mcp-tools.js.map +1 -0
  282. package/dist/training/training.module.d.ts.map +1 -1
  283. package/dist/training/training.module.js +2 -1
  284. package/dist/training/training.module.js.map +1 -1
  285. package/hedhog/data/integration_event_catalog.yaml +69 -0
  286. package/hedhog/data/menu.yaml +34 -0
  287. package/hedhog/data/route.yaml +2351 -0
  288. package/hedhog/frontend/app/_components/class-form-sheet.tsx.ejs +168 -103
  289. package/hedhog/frontend/app/_components/course-form-sheet.tsx.ejs +80 -1
  290. package/hedhog/frontend/app/_components/course-picker.tsx.ejs +228 -0
  291. package/hedhog/frontend/app/_lib/hooks/use-lms-realtime-refresh.ts.ejs +58 -0
  292. package/hedhog/frontend/app/achievements/page.tsx.ejs +844 -0
  293. package/hedhog/frontend/app/bitcodes/page.tsx.ejs +1010 -0
  294. package/hedhog/frontend/app/certificates/issued/page.tsx.ejs +61 -2
  295. package/hedhog/frontend/app/classes/[id]/page.tsx.ejs +7 -0
  296. package/hedhog/frontend/app/classes/page.tsx.ejs +55 -2060
  297. package/hedhog/frontend/app/courses/[id]/_components/CourseRelationsCard.tsx.ejs +28 -0
  298. package/hedhog/frontend/app/courses/[id]/_components/course-edit-types.ts.ejs +1 -0
  299. package/hedhog/frontend/app/courses/[id]/page.tsx.ejs +0 -9
  300. package/hedhog/frontend/app/courses/[id]/structure/_components/course-tree-dnd.tsx.ejs +80 -66
  301. package/hedhog/frontend/app/courses/[id]/structure/_components/editor-course.tsx.ejs +583 -8
  302. package/hedhog/frontend/app/courses/[id]/structure/_components/editor-lesson.tsx.ejs +527 -57
  303. package/hedhog/frontend/app/courses/[id]/structure/_components/mock-data.ts.ejs +1 -1
  304. package/hedhog/frontend/app/courses/[id]/structure/_components/tree-context-menu.tsx.ejs +106 -4
  305. package/hedhog/frontend/app/courses/[id]/structure/_components/types.ts.ejs +2 -1
  306. package/hedhog/frontend/app/courses/[id]/structure/_data/adapters/course-structure.adapter.ts.ejs +11 -1
  307. package/hedhog/frontend/app/courses/[id]/structure/_data/services/course-structure.service.ts.ejs +53 -6
  308. package/hedhog/frontend/app/courses/[id]/structure/_data/types/api-course.types.ts.ejs +13 -2
  309. package/hedhog/frontend/app/courses/page.tsx.ejs +175 -29
  310. package/hedhog/frontend/app/enterprise/_components/enterprise-course-create-sheet.tsx.ejs +3 -0
  311. package/hedhog/frontend/app/enterprise/_components/enterprise-course-edit-sheet.tsx.ejs +7 -0
  312. package/hedhog/frontend/app/exams/[id]/questions/page.tsx.ejs +169 -2
  313. package/hedhog/frontend/app/exams/page.tsx.ejs +77 -22
  314. package/hedhog/frontend/app/instructor-skills/page.tsx.ejs +1 -0
  315. package/hedhog/frontend/app/instructors/page.tsx.ejs +1 -0
  316. package/hedhog/frontend/app/paths/page.tsx.ejs +6 -24
  317. package/hedhog/frontend/app/training/page.tsx.ejs +6 -24
  318. package/hedhog/frontend/messages/en.json +314 -12
  319. package/hedhog/frontend/messages/pt.json +314 -12
  320. package/hedhog/query/triggers.sql +53 -0
  321. package/hedhog/table/achievement.yaml +46 -0
  322. package/hedhog/table/bitcode_wallet.yaml +18 -0
  323. package/hedhog/table/bitcode_wallet_transaction.yaml +22 -0
  324. package/hedhog/table/certificate.yaml +3 -0
  325. package/hedhog/table/course.yaml +4 -0
  326. package/hedhog/table/course_file.yaml +23 -0
  327. package/hedhog/table/course_lesson.yaml +5 -0
  328. package/hedhog/table/course_lesson_discussion_like.yaml +21 -0
  329. package/hedhog/table/course_lesson_discussion_topic.yaml +35 -0
  330. package/hedhog/table/course_lesson_note.yaml +34 -0
  331. package/hedhog/table/exam.yaml +5 -0
  332. package/hedhog/table/learning_path_enrollment.yaml +6 -0
  333. package/hedhog/table/question.yaml +10 -0
  334. package/hedhog/table/question_subject.yaml +17 -0
  335. package/hedhog/table/student_activity_streak.yaml +25 -0
  336. package/package.json +6 -6
  337. package/src/achievement/achievement.controller.ts +60 -0
  338. package/src/achievement/achievement.mcp-tools.ts +108 -0
  339. package/src/achievement/achievement.module.ts +13 -0
  340. package/src/achievement/achievement.service.ts +252 -0
  341. package/src/achievement/dto/create-achievement.dto.ts +50 -0
  342. package/src/achievement/dto/update-achievement.dto.ts +47 -0
  343. package/src/bitcode-wallet/bitcode-wallet.controller.ts +69 -0
  344. package/src/bitcode-wallet/bitcode-wallet.mcp-tools.ts +107 -0
  345. package/src/bitcode-wallet/bitcode-wallet.module.ts +13 -0
  346. package/src/bitcode-wallet/bitcode-wallet.service.ts +361 -0
  347. package/src/bitcode-wallet/dto/create-bitcode-wallet-transaction.dto.ts +27 -0
  348. package/src/bitcode-wallet/dto/create-bitcode-wallet.dto.ts +7 -0
  349. package/src/bitcode-wallet/dto/update-bitcode-wallet-transaction.dto.ts +28 -0
  350. package/src/bitcode-wallet/dto/update-bitcode-wallet.dto.ts +8 -0
  351. package/src/certificate/certificate.controller.ts +20 -11
  352. package/src/certificate/certificate.mcp-tools.ts +131 -0
  353. package/src/certificate/certificate.module.ts +2 -1
  354. package/src/certificate/certificate.service.ts +95 -4
  355. package/src/certificate/dto/update-certificate-public-access.dto.ts +6 -0
  356. package/src/class-group/class-group.mcp-tools.ts +435 -0
  357. package/src/class-group/class-group.module.ts +2 -1
  358. package/src/class-group/class-group.service.ts +51 -1
  359. package/src/course/course-operations-integration.service.ts +520 -0
  360. package/src/course/course-structure.controller.ts +22 -8
  361. package/src/course/course-structure.service.ts +215 -23
  362. package/src/course/course.mcp-tools.ts +409 -0
  363. package/src/course/course.module.ts +8 -1
  364. package/src/course/course.service.ts +106 -27
  365. package/src/course/dto/create-course.dto.ts +8 -0
  366. package/src/course/dto/update-course-resources.dto.ts +39 -0
  367. package/src/course-lesson-discussion/course-lesson-discussion.controller.ts +55 -0
  368. package/src/course-lesson-discussion/course-lesson-discussion.mcp-tools.ts +75 -0
  369. package/src/course-lesson-discussion/course-lesson-discussion.module.ts +13 -0
  370. package/src/course-lesson-discussion/course-lesson-discussion.service.ts +354 -0
  371. package/src/course-lesson-discussion/dto/create-course-lesson-discussion-topic.dto.ts +16 -0
  372. package/src/course-lesson-note/course-lesson-note.controller.ts +68 -0
  373. package/src/course-lesson-note/course-lesson-note.mcp-tools.ts +96 -0
  374. package/src/course-lesson-note/course-lesson-note.module.ts +13 -0
  375. package/src/course-lesson-note/course-lesson-note.service.ts +248 -0
  376. package/src/course-lesson-note/dto/create-course-lesson-note.dto.ts +16 -0
  377. package/src/course-lesson-note/dto/update-course-lesson-note.dto.ts +18 -0
  378. package/src/dashboard/dashboard.mcp-tools.ts +23 -0
  379. package/src/dashboard/dashboard.module.ts +2 -1
  380. package/src/enterprise/enterprise.mcp-tools.ts +403 -0
  381. package/src/enterprise/enterprise.module.ts +2 -1
  382. package/src/enterprise/training/enterprise-training.module.ts +11 -1
  383. package/src/enterprise/training/training-admin.mcp-tools.ts +479 -0
  384. package/src/enterprise/training/training-instructor.mcp-tools.ts +210 -0
  385. package/src/enterprise/training/training-student.controller.ts +17 -1
  386. package/src/enterprise/training/training-student.mcp-tools.ts +136 -0
  387. package/src/enterprise/training/training-student.service.ts +167 -1
  388. package/src/evaluation/evaluation.mcp-tools.ts +155 -0
  389. package/src/evaluation/evaluation.module.ts +2 -1
  390. package/src/exam/dto/create-exam-question.dto.ts +8 -0
  391. package/src/exam/dto/create-exam.dto.ts +8 -0
  392. package/src/exam/dto/create-question-subject.dto.ts +12 -0
  393. package/src/exam/exam-attempt.service.ts +46 -14
  394. package/src/exam/exam.controller.ts +19 -0
  395. package/src/exam/exam.mcp-tools.ts +337 -0
  396. package/src/exam/exam.module.ts +2 -1
  397. package/src/exam/exam.service.ts +121 -0
  398. package/src/index.ts +9 -0
  399. package/src/instructor/instructor.mcp-tools.ts +243 -0
  400. package/src/instructor/instructor.module.ts +2 -1
  401. package/src/lms.module.ts +15 -1
  402. package/src/realtime/lms-realtime.controller.ts +12 -0
  403. package/src/realtime/lms-realtime.module.ts +12 -0
  404. package/src/realtime/lms-realtime.service.ts +98 -0
  405. package/src/realtime/lms-realtime.subscriber.ts +61 -0
  406. package/src/reports/reports.mcp-tools.ts +27 -0
  407. package/src/reports/reports.module.ts +2 -1
  408. package/src/training/training.mcp-tools.ts +128 -0
  409. 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 extrasById = await this.getCourseExtras(
204
- courses.map((course) => course.id),
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) => this.mapCourse(c, undefined, extrasById.get(c.id))),
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 this.getCourseExtras([id]);
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(c, {
348
- lessonCount,
349
- sessionCount,
350
- certificatesIssued,
351
- averageCompletion: avgProgress._avg.progress_percent ?? 0,
352
- progressByModule,
353
- }, extrasById.get(id));
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 this.getCourseExtras([c.id]);
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(c, undefined, extrasById.get(c.id));
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 this.getCourseExtras([id]);
742
+ const [extrasById, projectLinksById] = await Promise.all([
743
+ this.getCourseExtras([id]),
744
+ this.operationsIntegration.getCourseProjectLinks([id]),
745
+ ]);
687
746
 
688
- const updateResult = this.mapCourse(c, undefined, extrasById.get(id));
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 updateData: Record<string, string | boolean> = {};
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
- updateData.name = data.name;
959
+ pushSetClause('name', data.name);
886
960
  }
887
961
 
888
962
  if (data.isFeatured !== undefined) {
889
- updateData.is_featured = data.isFeatured;
963
+ pushSetClause('is_featured', data.isFeatured);
890
964
  }
891
965
 
892
966
  if (data.hasCertificate !== undefined) {
893
- updateData.has_certificate = data.hasCertificate;
967
+ pushSetClause('has_certificate', data.hasCertificate);
894
968
  }
895
969
 
896
970
  if (data.isListed !== undefined) {
897
- updateData.is_listed = data.isListed;
971
+ pushSetClause('is_listed', data.isListed);
898
972
  }
899
973
 
900
974
  if (data.offeringType !== undefined) {
901
- updateData.offering_type = data.offeringType;
975
+ pushSetClause('offering_type', data.offeringType);
902
976
  }
903
977
 
904
- if (Object.keys(updateData).length === 0) {
978
+ if (setClauses.length === 0) {
905
979
  return;
906
980
  }
907
981
 
908
982
  try {
909
- await this.prisma.course.update({
910
- where: { id },
911
- data: updateData as any,
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 {}