@hed-hog/lms 0.0.349 → 0.0.351

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 (496) 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 +24 -2
  58. package/dist/certificate/certificate.controller.d.ts.map +1 -1
  59. package/dist/certificate/certificate.controller.js +20 -6
  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 +30 -4
  69. package/dist/certificate/certificate.service.d.ts.map +1 -1
  70. package/dist/certificate/certificate.service.js +157 -8
  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 +67 -14
  92. package/dist/course/course-structure.controller.d.ts.map +1 -1
  93. package/dist/course/course-structure.controller.js +45 -2
  94. package/dist/course/course-structure.controller.js.map +1 -1
  95. package/dist/course/course-structure.service.d.ts +58 -9
  96. package/dist/course/course-structure.service.d.ts.map +1 -1
  97. package/dist/course/course-structure.service.js +260 -62
  98. package/dist/course/course-structure.service.js.map +1 -1
  99. package/dist/course/course-video-conversion.service.d.ts +37 -0
  100. package/dist/course/course-video-conversion.service.d.ts.map +1 -0
  101. package/dist/course/course-video-conversion.service.js +308 -0
  102. package/dist/course/course-video-conversion.service.js.map +1 -0
  103. package/dist/course/course.controller.d.ts +29 -0
  104. package/dist/course/course.controller.d.ts.map +1 -1
  105. package/dist/course/course.controller.js +23 -0
  106. package/dist/course/course.controller.js.map +1 -1
  107. package/dist/course/course.mcp-tools.d.ts +90 -0
  108. package/dist/course/course.mcp-tools.d.ts.map +1 -0
  109. package/dist/course/course.mcp-tools.js +520 -0
  110. package/dist/course/course.mcp-tools.js.map +1 -0
  111. package/dist/course/course.module.d.ts.map +1 -1
  112. package/dist/course/course.module.js +23 -3
  113. package/dist/course/course.module.js.map +1 -1
  114. package/dist/course/course.service.d.ts +30 -1
  115. package/dist/course/course.service.d.ts.map +1 -1
  116. package/dist/course/course.service.js +159 -70
  117. package/dist/course/course.service.js.map +1 -1
  118. package/dist/course/dto/create-course-structure-lesson.dto.d.ts +5 -1
  119. package/dist/course/dto/create-course-structure-lesson.dto.d.ts.map +1 -1
  120. package/dist/course/dto/create-course-structure-lesson.dto.js +16 -2
  121. package/dist/course/dto/create-course-structure-lesson.dto.js.map +1 -1
  122. package/dist/course/dto/create-course.dto.d.ts +2 -0
  123. package/dist/course/dto/create-course.dto.d.ts.map +1 -1
  124. package/dist/course/dto/create-course.dto.js +16 -0
  125. package/dist/course/dto/create-course.dto.js.map +1 -1
  126. package/dist/course/dto/update-course-resources.dto.d.ts +11 -0
  127. package/dist/course/dto/update-course-resources.dto.d.ts.map +1 -0
  128. package/dist/course/dto/update-course-resources.dto.js +51 -0
  129. package/dist/course/dto/update-course-resources.dto.js.map +1 -0
  130. package/dist/course-lesson-discussion/course-lesson-discussion.controller.d.ts +23 -0
  131. package/dist/course-lesson-discussion/course-lesson-discussion.controller.d.ts.map +1 -0
  132. package/dist/course-lesson-discussion/course-lesson-discussion.controller.js +78 -0
  133. package/dist/course-lesson-discussion/course-lesson-discussion.controller.js.map +1 -0
  134. package/dist/course-lesson-discussion/course-lesson-discussion.mcp-tools.d.ts +22 -0
  135. package/dist/course-lesson-discussion/course-lesson-discussion.mcp-tools.d.ts.map +1 -0
  136. package/dist/course-lesson-discussion/course-lesson-discussion.mcp-tools.js +120 -0
  137. package/dist/course-lesson-discussion/course-lesson-discussion.mcp-tools.js.map +1 -0
  138. package/dist/course-lesson-discussion/course-lesson-discussion.module.d.ts +3 -0
  139. package/dist/course-lesson-discussion/course-lesson-discussion.module.d.ts.map +1 -0
  140. package/dist/course-lesson-discussion/course-lesson-discussion.module.js +26 -0
  141. package/dist/course-lesson-discussion/course-lesson-discussion.module.js.map +1 -0
  142. package/dist/course-lesson-discussion/course-lesson-discussion.service.d.ts +49 -0
  143. package/dist/course-lesson-discussion/course-lesson-discussion.service.d.ts.map +1 -0
  144. package/dist/course-lesson-discussion/course-lesson-discussion.service.js +272 -0
  145. package/dist/course-lesson-discussion/course-lesson-discussion.service.js.map +1 -0
  146. package/dist/course-lesson-discussion/dto/create-course-lesson-discussion-topic.dto.d.ts +6 -0
  147. package/dist/course-lesson-discussion/dto/create-course-lesson-discussion-topic.dto.d.ts.map +1 -0
  148. package/dist/course-lesson-discussion/dto/create-course-lesson-discussion-topic.dto.js +33 -0
  149. package/dist/course-lesson-discussion/dto/create-course-lesson-discussion-topic.dto.js.map +1 -0
  150. package/dist/course-lesson-note/course-lesson-note.controller.d.ts +53 -0
  151. package/dist/course-lesson-note/course-lesson-note.controller.d.ts.map +1 -0
  152. package/dist/course-lesson-note/course-lesson-note.controller.js +93 -0
  153. package/dist/course-lesson-note/course-lesson-note.controller.js.map +1 -0
  154. package/dist/course-lesson-note/course-lesson-note.mcp-tools.d.ts +27 -0
  155. package/dist/course-lesson-note/course-lesson-note.mcp-tools.d.ts.map +1 -0
  156. package/dist/course-lesson-note/course-lesson-note.mcp-tools.js +145 -0
  157. package/dist/course-lesson-note/course-lesson-note.mcp-tools.js.map +1 -0
  158. package/dist/course-lesson-note/course-lesson-note.module.d.ts +3 -0
  159. package/dist/course-lesson-note/course-lesson-note.module.d.ts.map +1 -0
  160. package/dist/course-lesson-note/course-lesson-note.module.js +26 -0
  161. package/dist/course-lesson-note/course-lesson-note.module.js.map +1 -0
  162. package/dist/course-lesson-note/course-lesson-note.service.d.ts +59 -0
  163. package/dist/course-lesson-note/course-lesson-note.service.d.ts.map +1 -0
  164. package/dist/course-lesson-note/course-lesson-note.service.js +195 -0
  165. package/dist/course-lesson-note/course-lesson-note.service.js.map +1 -0
  166. package/dist/course-lesson-note/dto/create-course-lesson-note.dto.d.ts +6 -0
  167. package/dist/course-lesson-note/dto/create-course-lesson-note.dto.d.ts.map +1 -0
  168. package/dist/course-lesson-note/dto/create-course-lesson-note.dto.js +33 -0
  169. package/dist/course-lesson-note/dto/create-course-lesson-note.dto.js.map +1 -0
  170. package/dist/course-lesson-note/dto/update-course-lesson-note.dto.d.ts +6 -0
  171. package/dist/course-lesson-note/dto/update-course-lesson-note.dto.d.ts.map +1 -0
  172. package/dist/course-lesson-note/dto/update-course-lesson-note.dto.js +35 -0
  173. package/dist/course-lesson-note/dto/update-course-lesson-note.dto.js.map +1 -0
  174. package/dist/dashboard/dashboard.mcp-tools.d.ts +10 -0
  175. package/dist/dashboard/dashboard.mcp-tools.d.ts.map +1 -0
  176. package/dist/dashboard/dashboard.mcp-tools.js +46 -0
  177. package/dist/dashboard/dashboard.mcp-tools.js.map +1 -0
  178. package/dist/dashboard/dashboard.module.d.ts.map +1 -1
  179. package/dist/dashboard/dashboard.module.js +2 -1
  180. package/dist/dashboard/dashboard.module.js.map +1 -1
  181. package/dist/enterprise/enterprise.controller.d.ts +3 -3
  182. package/dist/enterprise/enterprise.controller.d.ts.map +1 -1
  183. package/dist/enterprise/enterprise.controller.js +0 -1
  184. package/dist/enterprise/enterprise.controller.js.map +1 -1
  185. package/dist/enterprise/enterprise.mcp-tools.d.ts +82 -0
  186. package/dist/enterprise/enterprise.mcp-tools.d.ts.map +1 -0
  187. package/dist/enterprise/enterprise.mcp-tools.js +516 -0
  188. package/dist/enterprise/enterprise.mcp-tools.js.map +1 -0
  189. package/dist/enterprise/enterprise.module.d.ts.map +1 -1
  190. package/dist/enterprise/enterprise.module.js +2 -1
  191. package/dist/enterprise/enterprise.module.js.map +1 -1
  192. package/dist/enterprise/enterprise.service.d.ts +3 -3
  193. package/dist/enterprise/training/enterprise-training.module.d.ts.map +1 -1
  194. package/dist/enterprise/training/enterprise-training.module.js +11 -1
  195. package/dist/enterprise/training/enterprise-training.module.js.map +1 -1
  196. package/dist/enterprise/training/training-admin.mcp-tools.d.ts +79 -0
  197. package/dist/enterprise/training/training-admin.mcp-tools.d.ts.map +1 -0
  198. package/dist/enterprise/training/training-admin.mcp-tools.js +620 -0
  199. package/dist/enterprise/training/training-admin.mcp-tools.js.map +1 -0
  200. package/dist/enterprise/training/training-instructor.mcp-tools.d.ts +47 -0
  201. package/dist/enterprise/training/training-instructor.mcp-tools.d.ts.map +1 -0
  202. package/dist/enterprise/training/training-instructor.mcp-tools.js +275 -0
  203. package/dist/enterprise/training/training-instructor.mcp-tools.js.map +1 -0
  204. package/dist/enterprise/training/training-student.controller.d.ts +24 -0
  205. package/dist/enterprise/training/training-student.controller.d.ts.map +1 -1
  206. package/dist/enterprise/training/training-student.controller.js +22 -0
  207. package/dist/enterprise/training/training-student.controller.js.map +1 -1
  208. package/dist/enterprise/training/training-student.mcp-tools.d.ts +27 -0
  209. package/dist/enterprise/training/training-student.mcp-tools.d.ts.map +1 -0
  210. package/dist/enterprise/training/training-student.mcp-tools.js +186 -0
  211. package/dist/enterprise/training/training-student.mcp-tools.js.map +1 -0
  212. package/dist/enterprise/training/training-student.service.d.ts +32 -0
  213. package/dist/enterprise/training/training-student.service.d.ts.map +1 -1
  214. package/dist/enterprise/training/training-student.service.js +138 -0
  215. package/dist/enterprise/training/training-student.service.js.map +1 -1
  216. package/dist/evaluation/evaluation.mcp-tools.d.ts +25 -0
  217. package/dist/evaluation/evaluation.mcp-tools.d.ts.map +1 -0
  218. package/dist/evaluation/evaluation.mcp-tools.js +220 -0
  219. package/dist/evaluation/evaluation.mcp-tools.js.map +1 -0
  220. package/dist/evaluation/evaluation.module.d.ts.map +1 -1
  221. package/dist/evaluation/evaluation.module.js +2 -1
  222. package/dist/evaluation/evaluation.module.js.map +1 -1
  223. package/dist/evaluation/evaluation.service.d.ts.map +1 -1
  224. package/dist/evaluation/evaluation.service.js +9 -2
  225. package/dist/evaluation/evaluation.service.js.map +1 -1
  226. package/dist/exam/dto/create-exam-question.dto.d.ts +2 -0
  227. package/dist/exam/dto/create-exam-question.dto.d.ts.map +1 -1
  228. package/dist/exam/dto/create-exam-question.dto.js +10 -0
  229. package/dist/exam/dto/create-exam-question.dto.js.map +1 -1
  230. package/dist/exam/dto/create-exam.dto.d.ts +2 -0
  231. package/dist/exam/dto/create-exam.dto.d.ts.map +1 -1
  232. package/dist/exam/dto/create-exam.dto.js +10 -0
  233. package/dist/exam/dto/create-exam.dto.js.map +1 -1
  234. package/dist/exam/dto/create-question-subject.dto.d.ts +5 -0
  235. package/dist/exam/dto/create-question-subject.dto.d.ts.map +1 -0
  236. package/dist/exam/dto/create-question-subject.dto.js +28 -0
  237. package/dist/exam/dto/create-question-subject.dto.js.map +1 -0
  238. package/dist/exam/exam-attempt.controller.d.ts +4 -0
  239. package/dist/exam/exam-attempt.controller.d.ts.map +1 -1
  240. package/dist/exam/exam-attempt.service.d.ts +7 -1
  241. package/dist/exam/exam-attempt.service.d.ts.map +1 -1
  242. package/dist/exam/exam-attempt.service.js +47 -17
  243. package/dist/exam/exam-attempt.service.js.map +1 -1
  244. package/dist/exam/exam.controller.d.ts +34 -0
  245. package/dist/exam/exam.controller.d.ts.map +1 -1
  246. package/dist/exam/exam.controller.js +27 -0
  247. package/dist/exam/exam.controller.js.map +1 -1
  248. package/dist/exam/exam.mcp-tools.d.ts +62 -0
  249. package/dist/exam/exam.mcp-tools.d.ts.map +1 -0
  250. package/dist/exam/exam.mcp-tools.js +430 -0
  251. package/dist/exam/exam.mcp-tools.js.map +1 -0
  252. package/dist/exam/exam.module.d.ts.map +1 -1
  253. package/dist/exam/exam.module.js +2 -1
  254. package/dist/exam/exam.module.js.map +1 -1
  255. package/dist/exam/exam.service.d.ts +38 -0
  256. package/dist/exam/exam.service.d.ts.map +1 -1
  257. package/dist/exam/exam.service.js +114 -17
  258. package/dist/exam/exam.service.js.map +1 -1
  259. package/dist/index.d.ts +10 -0
  260. package/dist/index.d.ts.map +1 -1
  261. package/dist/index.js +10 -0
  262. package/dist/index.js.map +1 -1
  263. package/dist/instructor/instructor.mcp-tools.d.ts +41 -0
  264. package/dist/instructor/instructor.mcp-tools.d.ts.map +1 -0
  265. package/dist/instructor/instructor.mcp-tools.js +326 -0
  266. package/dist/instructor/instructor.mcp-tools.js.map +1 -0
  267. package/dist/instructor/instructor.module.d.ts.map +1 -1
  268. package/dist/instructor/instructor.module.js +2 -1
  269. package/dist/instructor/instructor.module.js.map +1 -1
  270. package/dist/lms.module.d.ts.map +1 -1
  271. package/dist/lms.module.js +18 -0
  272. package/dist/lms.module.js.map +1 -1
  273. package/dist/realtime/lms-realtime.controller.d.ts +7 -0
  274. package/dist/realtime/lms-realtime.controller.d.ts.map +1 -0
  275. package/dist/realtime/lms-realtime.controller.js +34 -0
  276. package/dist/realtime/lms-realtime.controller.js.map +1 -0
  277. package/dist/realtime/lms-realtime.module.d.ts +3 -0
  278. package/dist/realtime/lms-realtime.module.d.ts.map +1 -0
  279. package/dist/realtime/lms-realtime.module.js +25 -0
  280. package/dist/realtime/lms-realtime.module.js.map +1 -0
  281. package/dist/realtime/lms-realtime.service.d.ts +36 -0
  282. package/dist/realtime/lms-realtime.service.d.ts.map +1 -0
  283. package/dist/realtime/lms-realtime.service.js +59 -0
  284. package/dist/realtime/lms-realtime.service.js.map +1 -0
  285. package/dist/realtime/lms-realtime.subscriber.d.ts +10 -0
  286. package/dist/realtime/lms-realtime.subscriber.d.ts.map +1 -0
  287. package/dist/realtime/lms-realtime.subscriber.js +70 -0
  288. package/dist/realtime/lms-realtime.subscriber.js.map +1 -0
  289. package/dist/reports/reports.mcp-tools.d.ts +10 -0
  290. package/dist/reports/reports.mcp-tools.d.ts.map +1 -0
  291. package/dist/reports/reports.mcp-tools.js +50 -0
  292. package/dist/reports/reports.mcp-tools.js.map +1 -0
  293. package/dist/reports/reports.module.d.ts.map +1 -1
  294. package/dist/reports/reports.module.js +2 -1
  295. package/dist/reports/reports.module.js.map +1 -1
  296. package/dist/training/training.mcp-tools.d.ts +20 -0
  297. package/dist/training/training.mcp-tools.d.ts.map +1 -0
  298. package/dist/training/training.mcp-tools.js +181 -0
  299. package/dist/training/training.mcp-tools.js.map +1 -0
  300. package/dist/training/training.module.d.ts.map +1 -1
  301. package/dist/training/training.module.js +2 -1
  302. package/dist/training/training.module.js.map +1 -1
  303. package/dist/video-resolution-profile/dto/create-video-resolution-profile.dto.d.ts +6 -0
  304. package/dist/video-resolution-profile/dto/create-video-resolution-profile.dto.d.ts.map +1 -0
  305. package/dist/video-resolution-profile/dto/create-video-resolution-profile.dto.js +33 -0
  306. package/dist/video-resolution-profile/dto/create-video-resolution-profile.dto.js.map +1 -0
  307. package/dist/video-resolution-profile/dto/update-video-resolution-profile.dto.d.ts +6 -0
  308. package/dist/video-resolution-profile/dto/update-video-resolution-profile.dto.d.ts.map +1 -0
  309. package/dist/video-resolution-profile/dto/update-video-resolution-profile.dto.js +33 -0
  310. package/dist/video-resolution-profile/dto/update-video-resolution-profile.dto.js.map +1 -0
  311. package/dist/video-resolution-profile/video-resolution-profile.controller.d.ts +38 -0
  312. package/dist/video-resolution-profile/video-resolution-profile.controller.d.ts.map +1 -0
  313. package/dist/video-resolution-profile/video-resolution-profile.controller.js +89 -0
  314. package/dist/video-resolution-profile/video-resolution-profile.controller.js.map +1 -0
  315. package/dist/video-resolution-profile/video-resolution-profile.mcp-tools.d.ts +26 -0
  316. package/dist/video-resolution-profile/video-resolution-profile.mcp-tools.d.ts.map +1 -0
  317. package/dist/video-resolution-profile/video-resolution-profile.mcp-tools.js +160 -0
  318. package/dist/video-resolution-profile/video-resolution-profile.mcp-tools.js.map +1 -0
  319. package/dist/video-resolution-profile/video-resolution-profile.module.d.ts +3 -0
  320. package/dist/video-resolution-profile/video-resolution-profile.module.d.ts.map +1 -0
  321. package/dist/video-resolution-profile/video-resolution-profile.module.js +26 -0
  322. package/dist/video-resolution-profile/video-resolution-profile.module.js.map +1 -0
  323. package/dist/video-resolution-profile/video-resolution-profile.service.d.ts +45 -0
  324. package/dist/video-resolution-profile/video-resolution-profile.service.d.ts.map +1 -0
  325. package/dist/video-resolution-profile/video-resolution-profile.service.js +117 -0
  326. package/dist/video-resolution-profile/video-resolution-profile.service.js.map +1 -0
  327. package/hedhog/data/integration_event_catalog.yaml +69 -0
  328. package/hedhog/data/menu.yaml +51 -0
  329. package/hedhog/data/route.yaml +2484 -0
  330. package/hedhog/data/video_resolution_profile.yaml +7 -0
  331. package/hedhog/frontend/app/_components/class-form-sheet.tsx.ejs +432 -422
  332. package/hedhog/frontend/app/_components/course-form-sheet.tsx.ejs +200 -67
  333. package/hedhog/frontend/app/_components/course-picker.tsx.ejs +228 -0
  334. package/hedhog/frontend/app/_components/create-lms-instructor-sheet.tsx.ejs +7 -4
  335. package/hedhog/frontend/app/_components/create-lms-person-sheet.tsx.ejs +2 -2
  336. package/hedhog/frontend/app/_components/create-lms-student-person-sheet.tsx.ejs +2 -2
  337. package/hedhog/frontend/app/_lib/editor/templateSerializer.ts.ejs +34 -4
  338. package/hedhog/frontend/app/_lib/editor/types.ts.ejs +28 -3
  339. package/hedhog/frontend/app/_lib/hooks/use-lms-realtime-refresh.ts.ejs +58 -0
  340. package/hedhog/frontend/app/achievements/page.tsx.ejs +850 -0
  341. package/hedhog/frontend/app/bitcodes/page.tsx.ejs +1016 -0
  342. package/hedhog/frontend/app/certificates/issued/page.tsx.ejs +68 -5
  343. package/hedhog/frontend/app/certificates/models/CanvasStage.tsx.ejs +29 -8
  344. package/hedhog/frontend/app/certificates/models/LeftPanel.tsx.ejs +14 -0
  345. package/hedhog/frontend/app/certificates/models/RightPanel.tsx.ejs +194 -9
  346. package/hedhog/frontend/app/certificates/models/page.tsx.ejs +15 -5
  347. package/hedhog/frontend/app/classes/[id]/page.tsx.ejs +16 -5
  348. package/hedhog/frontend/app/classes/page.tsx.ejs +126 -2105
  349. package/hedhog/frontend/app/courses/[id]/_components/CourseCertificateCard.tsx.ejs +19 -9
  350. package/hedhog/frontend/app/courses/[id]/_components/CourseClassificationCard.tsx.ejs +24 -1
  351. package/hedhog/frontend/app/courses/[id]/_components/CourseContentCard.tsx.ejs +1 -1
  352. package/hedhog/frontend/app/courses/[id]/_components/CourseMainInfoCard.tsx.ejs +1 -1
  353. package/hedhog/frontend/app/courses/[id]/_components/CourseRelationsCard.tsx.ejs +51 -11
  354. package/hedhog/frontend/app/courses/[id]/_components/CourseSectionCard.tsx.ejs +11 -6
  355. package/hedhog/frontend/app/courses/[id]/_components/CourseSummaryCard.tsx.ejs +7 -4
  356. package/hedhog/frontend/app/courses/[id]/_components/course-edit-types.ts.ejs +2 -0
  357. package/hedhog/frontend/app/courses/[id]/page.tsx.ejs +24 -96
  358. package/hedhog/frontend/app/courses/[id]/structure/_components/course-tree-dnd.tsx.ejs +80 -66
  359. package/hedhog/frontend/app/courses/[id]/structure/_components/editor-course.tsx.ejs +1286 -230
  360. package/hedhog/frontend/app/courses/[id]/structure/_components/editor-lesson.tsx.ejs +1334 -153
  361. package/hedhog/frontend/app/courses/[id]/structure/_components/editor-session.tsx.ejs +11 -11
  362. package/hedhog/frontend/app/courses/[id]/structure/_components/mock-data.ts.ejs +1 -1
  363. package/hedhog/frontend/app/courses/[id]/structure/_components/shortcuts-help.tsx.ejs +62 -52
  364. package/hedhog/frontend/app/courses/[id]/structure/_components/tree-context-menu.tsx.ejs +106 -4
  365. package/hedhog/frontend/app/courses/[id]/structure/_components/types.ts.ejs +4 -1
  366. package/hedhog/frontend/app/courses/[id]/structure/_data/adapters/course-structure.adapter.ts.ejs +30 -7
  367. package/hedhog/frontend/app/courses/[id]/structure/_data/services/course-structure.service.ts.ejs +138 -6
  368. package/hedhog/frontend/app/courses/[id]/structure/_data/types/api-course.types.ts.ejs +16 -2
  369. package/hedhog/frontend/app/courses/[id]/structure/_data/use-course-structure-mutations.ts.ejs +1 -0
  370. package/hedhog/frontend/app/courses/page.tsx.ejs +282 -113
  371. package/hedhog/frontend/app/enterprise/[id]/page.tsx.ejs +1 -1
  372. package/hedhog/frontend/app/enterprise/_components/enterprise-admin-create-sheet.tsx.ejs +10 -3
  373. package/hedhog/frontend/app/enterprise/_components/enterprise-course-create-sheet.tsx.ejs +3 -0
  374. package/hedhog/frontend/app/enterprise/_components/enterprise-course-edit-sheet.tsx.ejs +7 -0
  375. package/hedhog/frontend/app/enterprise/_components/enterprise-detail-sheet.tsx.ejs +8 -4
  376. package/hedhog/frontend/app/enterprise/_components/enterprise-person-edit-sheet.tsx.ejs +2 -2
  377. package/hedhog/frontend/app/enterprise/_components/enterprise-sheet.tsx.ejs +10 -4
  378. package/hedhog/frontend/app/enterprise/_components/enterprise-student-create-sheet.tsx.ejs +10 -3
  379. package/hedhog/frontend/app/enterprise/_components/enterprise-user-create-sheet.tsx.ejs +10 -3
  380. package/hedhog/frontend/app/evaluations/_components/evaluation-topic-form-sheet.tsx.ejs +10 -3
  381. package/hedhog/frontend/app/exams/[id]/questions/page.tsx.ejs +186 -5
  382. package/hedhog/frontend/app/exams/page.tsx.ejs +89 -26
  383. package/hedhog/frontend/app/instructor-skills/page.tsx.ejs +10 -3
  384. package/hedhog/frontend/app/instructors/_components/instructor-form-sheet.tsx.ejs +190 -17
  385. package/hedhog/frontend/app/instructors/page.tsx.ejs +1 -0
  386. package/hedhog/frontend/app/layout.tsx.ejs +5 -1
  387. package/hedhog/frontend/app/paths/page.tsx.ejs +19 -29
  388. package/hedhog/frontend/app/reports/evaluations/page.tsx.ejs +10 -10
  389. package/hedhog/frontend/app/training/page.tsx.ejs +19 -29
  390. package/hedhog/frontend/app/video-resolution-profiles/page.tsx.ejs +607 -0
  391. package/hedhog/frontend/messages/en.json +563 -20
  392. package/hedhog/frontend/messages/pt.json +563 -20
  393. package/hedhog/query/triggers.sql +53 -0
  394. package/hedhog/table/achievement.yaml +46 -0
  395. package/hedhog/table/bitcode_wallet.yaml +18 -0
  396. package/hedhog/table/bitcode_wallet_transaction.yaml +22 -0
  397. package/hedhog/table/certificate.yaml +3 -0
  398. package/hedhog/table/course.yaml +8 -0
  399. package/hedhog/table/course_file.yaml +23 -0
  400. package/hedhog/table/course_lesson.yaml +5 -0
  401. package/hedhog/table/course_lesson_discussion_like.yaml +21 -0
  402. package/hedhog/table/course_lesson_discussion_topic.yaml +35 -0
  403. package/hedhog/table/course_lesson_file.yaml +8 -0
  404. package/hedhog/table/course_lesson_note.yaml +34 -0
  405. package/hedhog/table/course_video_resolution_profile.yaml +22 -0
  406. package/hedhog/table/exam.yaml +5 -0
  407. package/hedhog/table/learning_path_enrollment.yaml +6 -0
  408. package/hedhog/table/question.yaml +10 -0
  409. package/hedhog/table/question_subject.yaml +17 -0
  410. package/hedhog/table/student_activity_streak.yaml +25 -0
  411. package/hedhog/table/video_resolution_profile.yaml +18 -0
  412. package/package.json +8 -7
  413. package/src/achievement/achievement.controller.ts +60 -0
  414. package/src/achievement/achievement.mcp-tools.ts +108 -0
  415. package/src/achievement/achievement.module.ts +13 -0
  416. package/src/achievement/achievement.service.ts +252 -0
  417. package/src/achievement/dto/create-achievement.dto.ts +50 -0
  418. package/src/achievement/dto/update-achievement.dto.ts +47 -0
  419. package/src/bitcode-wallet/bitcode-wallet.controller.ts +69 -0
  420. package/src/bitcode-wallet/bitcode-wallet.mcp-tools.ts +107 -0
  421. package/src/bitcode-wallet/bitcode-wallet.module.ts +13 -0
  422. package/src/bitcode-wallet/bitcode-wallet.service.ts +361 -0
  423. package/src/bitcode-wallet/dto/create-bitcode-wallet-transaction.dto.ts +27 -0
  424. package/src/bitcode-wallet/dto/create-bitcode-wallet.dto.ts +7 -0
  425. package/src/bitcode-wallet/dto/update-bitcode-wallet-transaction.dto.ts +28 -0
  426. package/src/bitcode-wallet/dto/update-bitcode-wallet.dto.ts +8 -0
  427. package/src/certificate/certificate.controller.ts +17 -3
  428. package/src/certificate/certificate.mcp-tools.ts +131 -0
  429. package/src/certificate/certificate.module.ts +2 -1
  430. package/src/certificate/certificate.service.ts +193 -7
  431. package/src/certificate/dto/update-certificate-public-access.dto.ts +6 -0
  432. package/src/class-group/class-group.mcp-tools.ts +435 -0
  433. package/src/class-group/class-group.module.ts +2 -1
  434. package/src/class-group/class-group.service.ts +51 -1
  435. package/src/course/course-operations-integration.service.ts +520 -0
  436. package/src/course/course-structure.controller.ts +46 -10
  437. package/src/course/course-structure.service.ts +236 -27
  438. package/src/course/course-video-conversion.service.ts +415 -0
  439. package/src/course/course.controller.ts +18 -0
  440. package/src/course/course.mcp-tools.ts +409 -0
  441. package/src/course/course.module.ts +23 -3
  442. package/src/course/course.service.ts +178 -29
  443. package/src/course/dto/create-course-structure-lesson.dto.ts +13 -2
  444. package/src/course/dto/create-course.dto.ts +16 -0
  445. package/src/course/dto/update-course-resources.dto.ts +39 -0
  446. package/src/course-lesson-discussion/course-lesson-discussion.controller.ts +55 -0
  447. package/src/course-lesson-discussion/course-lesson-discussion.mcp-tools.ts +75 -0
  448. package/src/course-lesson-discussion/course-lesson-discussion.module.ts +13 -0
  449. package/src/course-lesson-discussion/course-lesson-discussion.service.ts +354 -0
  450. package/src/course-lesson-discussion/dto/create-course-lesson-discussion-topic.dto.ts +16 -0
  451. package/src/course-lesson-note/course-lesson-note.controller.ts +68 -0
  452. package/src/course-lesson-note/course-lesson-note.mcp-tools.ts +96 -0
  453. package/src/course-lesson-note/course-lesson-note.module.ts +13 -0
  454. package/src/course-lesson-note/course-lesson-note.service.ts +248 -0
  455. package/src/course-lesson-note/dto/create-course-lesson-note.dto.ts +16 -0
  456. package/src/course-lesson-note/dto/update-course-lesson-note.dto.ts +18 -0
  457. package/src/dashboard/dashboard.mcp-tools.ts +23 -0
  458. package/src/dashboard/dashboard.module.ts +2 -1
  459. package/src/enterprise/enterprise.controller.ts +0 -1
  460. package/src/enterprise/enterprise.mcp-tools.ts +403 -0
  461. package/src/enterprise/enterprise.module.ts +2 -1
  462. package/src/enterprise/training/enterprise-training.module.ts +11 -1
  463. package/src/enterprise/training/training-admin.mcp-tools.ts +479 -0
  464. package/src/enterprise/training/training-instructor.mcp-tools.ts +210 -0
  465. package/src/enterprise/training/training-student.controller.ts +17 -1
  466. package/src/enterprise/training/training-student.mcp-tools.ts +136 -0
  467. package/src/enterprise/training/training-student.service.ts +167 -1
  468. package/src/evaluation/evaluation.mcp-tools.ts +155 -0
  469. package/src/evaluation/evaluation.module.ts +2 -1
  470. package/src/evaluation/evaluation.service.ts +9 -2
  471. package/src/exam/dto/create-exam-question.dto.ts +8 -0
  472. package/src/exam/dto/create-exam.dto.ts +8 -0
  473. package/src/exam/dto/create-question-subject.dto.ts +12 -0
  474. package/src/exam/exam-attempt.service.ts +46 -14
  475. package/src/exam/exam.controller.ts +19 -0
  476. package/src/exam/exam.mcp-tools.ts +337 -0
  477. package/src/exam/exam.module.ts +2 -1
  478. package/src/exam/exam.service.ts +121 -0
  479. package/src/index.ts +10 -0
  480. package/src/instructor/instructor.mcp-tools.ts +243 -0
  481. package/src/instructor/instructor.module.ts +2 -1
  482. package/src/lms.module.ts +18 -1
  483. package/src/realtime/lms-realtime.controller.ts +12 -0
  484. package/src/realtime/lms-realtime.module.ts +12 -0
  485. package/src/realtime/lms-realtime.service.ts +98 -0
  486. package/src/realtime/lms-realtime.subscriber.ts +61 -0
  487. package/src/reports/reports.mcp-tools.ts +27 -0
  488. package/src/reports/reports.module.ts +2 -1
  489. package/src/training/training.mcp-tools.ts +128 -0
  490. package/src/training/training.module.ts +2 -1
  491. package/src/video-resolution-profile/dto/create-video-resolution-profile.dto.ts +16 -0
  492. package/src/video-resolution-profile/dto/update-video-resolution-profile.dto.ts +16 -0
  493. package/src/video-resolution-profile/video-resolution-profile.controller.ts +62 -0
  494. package/src/video-resolution-profile/video-resolution-profile.mcp-tools.ts +128 -0
  495. package/src/video-resolution-profile/video-resolution-profile.module.ts +13 -0
  496. package/src/video-resolution-profile/video-resolution-profile.service.ts +117 -0
@@ -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) {
@@ -193,23 +201,42 @@ export class CourseService {
193
201
  orderBy: [{ is_primary: 'desc' }, { order: 'asc' }],
194
202
  },
195
203
  _count: {
196
- select: { course_enrollment: true, course_class_group: true },
204
+ select: {
205
+ course_enrollment: true,
206
+ course_class_group: true,
207
+ course_module: true,
208
+ course_file: true,
209
+ },
210
+ },
211
+ course_module: {
212
+ select: {
213
+ _count: { select: { course_lesson: true } },
214
+ },
197
215
  },
198
216
  },
199
217
  }),
200
218
  this.prisma.course.count({ where }),
201
219
  ]);
202
220
 
203
- const extrasById = await this.getCourseExtras(
204
- courses.map((course) => course.id),
205
- );
221
+ const courseIds = courses.map((course) => course.id);
222
+ const [extrasById, projectLinksById] = await Promise.all([
223
+ this.getCourseExtras(courseIds),
224
+ this.operationsIntegration.getCourseProjectLinks(courseIds),
225
+ ]);
206
226
 
207
227
  return {
208
228
  total,
209
229
  page,
210
230
  pageSize,
211
231
  lastPage: Math.max(1, Math.ceil(total / pageSize)),
212
- data: courses.map((c) => this.mapCourse(c, undefined, extrasById.get(c.id))),
232
+ data: courses.map((c) =>
233
+ this.mapCourse(
234
+ c,
235
+ undefined,
236
+ extrasById.get(c.id),
237
+ projectLinksById.get(c.id),
238
+ ),
239
+ ),
213
240
  };
214
241
  }
215
242
 
@@ -293,7 +320,10 @@ export class CourseService {
293
320
 
294
321
  if (!c) return null;
295
322
 
296
- const extrasById = await this.getCourseExtras([id]);
323
+ const [extrasById, projectLinksById] = await Promise.all([
324
+ this.getCourseExtras([id]),
325
+ this.operationsIntegration.getCourseProjectLinks([id]),
326
+ ]);
297
327
 
298
328
  const [lessonCount, sessionCount, certificatesIssued, avgProgress, modules] =
299
329
  await Promise.all([
@@ -344,13 +374,18 @@ export class CourseService {
344
374
  };
345
375
  });
346
376
 
347
- return this.mapCourse(c, {
348
- lessonCount,
349
- sessionCount,
350
- certificatesIssued,
351
- averageCompletion: avgProgress._avg.progress_percent ?? 0,
352
- progressByModule,
353
- }, extrasById.get(id));
377
+ return this.mapCourse(
378
+ c,
379
+ {
380
+ lessonCount,
381
+ sessionCount,
382
+ certificatesIssued,
383
+ averageCompletion: avgProgress._avg.progress_percent ?? 0,
384
+ progressByModule,
385
+ },
386
+ extrasById.get(id),
387
+ projectLinksById.get(id),
388
+ );
354
389
  }
355
390
 
356
391
  async create(dto: CreateCourseDto) {
@@ -360,12 +395,17 @@ export class CourseService {
360
395
  bannerFileId,
361
396
  instructorIds,
362
397
  certificateModel,
398
+ operationsProjectId,
363
399
  ...data
364
400
  } = dto;
365
401
  const normalizedSlug = data.slug.trim();
366
402
  const resolvedTitle = this.resolveCourseTitle(data.title, normalizedSlug);
367
403
  const certificateTemplateId =
368
404
  await this.resolveCertificateTemplateId(certificateModel);
405
+ const resolvedOperationsProjectId =
406
+ await this.operationsIntegration.resolveOperationsProjectId(
407
+ operationsProjectId,
408
+ );
369
409
 
370
410
  const categories = categorySlugs?.length
371
411
  ? await this.prisma.category.findMany({
@@ -395,6 +435,7 @@ export class CourseService {
395
435
  }),
396
436
  level: this.normalizeLevel(data.level) ?? 'beginner',
397
437
  status: this.normalizeStatus(data.status) ?? 'draft',
438
+ offering_type: (this.normalizeOfferingType(data.offeringType) ?? 'on_demand') as any,
398
439
  ...(data.requirements !== undefined && {
399
440
  requirements: data.requirements,
400
441
  }),
@@ -425,6 +466,7 @@ export class CourseService {
425
466
  ...(data.secondaryContrastColor !== undefined && {
426
467
  secondary_contrast_color: data.secondaryContrastColor,
427
468
  }),
469
+ ...(data.code !== undefined && { code: data.code }),
428
470
  ...(categories.length > 0 && {
429
471
  course_category: {
430
472
  create: categories.map((item) => ({ category_id: item.id })),
@@ -491,10 +533,22 @@ export class CourseService {
491
533
  ...data,
492
534
  offeringType: this.normalizeOfferingType(data.offeringType) ?? 'on_demand',
493
535
  });
536
+ await this.operationsIntegration.persistCourseProjectLink(
537
+ c.id,
538
+ resolvedOperationsProjectId ?? null,
539
+ );
494
540
 
495
- const extrasById = await this.getCourseExtras([c.id]);
541
+ const [extrasById, projectLinksById] = await Promise.all([
542
+ this.getCourseExtras([c.id]),
543
+ this.operationsIntegration.getCourseProjectLinks([c.id]),
544
+ ]);
496
545
 
497
- const result = this.mapCourse(c, undefined, extrasById.get(c.id));
546
+ const result = this.mapCourse(
547
+ c,
548
+ undefined,
549
+ extrasById.get(c.id),
550
+ projectLinksById.get(c.id),
551
+ );
498
552
 
499
553
  await this.integrationApi.publishEvent({
500
554
  eventName: 'lms.course.created',
@@ -514,6 +568,7 @@ export class CourseService {
514
568
  bannerFileId,
515
569
  instructorIds,
516
570
  certificateModel,
571
+ operationsProjectId,
517
572
  ...data
518
573
  } = dto;
519
574
  let existingSlug: string | undefined;
@@ -538,6 +593,10 @@ export class CourseService {
538
593
  : undefined;
539
594
  const certificateTemplateId =
540
595
  await this.resolveCertificateTemplateId(certificateModel);
596
+ const resolvedOperationsProjectId =
597
+ await this.operationsIntegration.resolveOperationsProjectId(
598
+ operationsProjectId,
599
+ );
541
600
 
542
601
  const categories = categorySlugs?.length
543
602
  ? await this.prisma.category.findMany({
@@ -580,6 +639,10 @@ export class CourseService {
580
639
  ...(data.status !== undefined && {
581
640
  status: this.normalizeStatus(data.status),
582
641
  }),
642
+ ...(data.offeringType !== undefined &&
643
+ this.normalizeOfferingType(data.offeringType) !== undefined && {
644
+ offering_type: this.normalizeOfferingType(data.offeringType) as any,
645
+ }),
583
646
  ...(data.requirements !== undefined && {
584
647
  requirements: data.requirements,
585
648
  }),
@@ -610,6 +673,7 @@ export class CourseService {
610
673
  ...(data.secondaryContrastColor !== undefined && {
611
674
  secondary_contrast_color: data.secondaryContrastColor,
612
675
  }),
676
+ ...(data.code !== undefined && { code: data.code }),
613
677
  ...(categories.length > 0 && {
614
678
  course_category: {
615
679
  create: categories.map((item) => ({ category_id: item.id })),
@@ -682,10 +746,27 @@ export class CourseService {
682
746
  });
683
747
 
684
748
  await this.persistCourseExtras(id, data);
749
+ if (resolvedOperationsProjectId !== undefined) {
750
+ await this.operationsIntegration.persistCourseProjectLink(
751
+ id,
752
+ resolvedOperationsProjectId,
753
+ );
754
+ if (resolvedOperationsProjectId) {
755
+ await this.operationsIntegration.createMissingTasksForCourseLessons(id);
756
+ }
757
+ }
685
758
 
686
- const extrasById = await this.getCourseExtras([id]);
759
+ const [extrasById, projectLinksById] = await Promise.all([
760
+ this.getCourseExtras([id]),
761
+ this.operationsIntegration.getCourseProjectLinks([id]),
762
+ ]);
687
763
 
688
- const updateResult = this.mapCourse(c, undefined, extrasById.get(id));
764
+ const updateResult = this.mapCourse(
765
+ c,
766
+ undefined,
767
+ extrasById.get(id),
768
+ projectLinksById.get(id),
769
+ );
689
770
 
690
771
  await this.integrationApi.publishEvent({
691
772
  eventName: 'lms.course.updated',
@@ -726,6 +807,7 @@ export class CourseService {
726
807
  }[];
727
808
  },
728
809
  extras?: CourseExtraFields,
810
+ project?: CourseProjectFields,
729
811
  ) {
730
812
  const resolvedName = extras?.name ?? c.name ?? null;
731
813
  const resolvedTitle = this.normalizeOptionalText(c.title) ?? c.slug;
@@ -746,6 +828,7 @@ export class CourseService {
746
828
  id: c.id,
747
829
  name: resolvedName ?? '',
748
830
  slug: c.slug,
831
+ code: c.code ?? null,
749
832
  title: resolvedTitle,
750
833
  description: c.description ?? '',
751
834
  level: c.level,
@@ -789,10 +872,18 @@ export class CourseService {
789
872
  hasCertificate: extras?.has_certificate ?? c.has_certificate ?? false,
790
873
  isListed: extras?.is_listed ?? c.is_listed ?? false,
791
874
  offeringType,
875
+ operationsProjectId: project?.projectId ?? null,
876
+ operationsProjectCode: project?.projectCode ?? null,
877
+ operationsProjectName: project?.projectName ?? null,
792
878
  enrollmentCount: c._count?.course_enrollment ?? 0,
793
879
  moduleCount: c._count?.course_module ?? 0,
794
880
  classCount,
795
- lessonCount: metrics?.lessonCount ?? 0,
881
+ lessonCount:
882
+ (c.course_module as { _count: { course_lesson: number } }[] | undefined)
883
+ ?.reduce((sum: number, m: any) => sum + (m._count?.course_lesson ?? 0), 0) ??
884
+ metrics?.lessonCount ??
885
+ 0,
886
+ resourceCount: c._count?.course_file ?? 0,
796
887
  sessionCount: metrics?.sessionCount ?? 0,
797
888
  averageCompletion: Math.round(metrics?.averageCompletion ?? 0),
798
889
  certificatesIssued:
@@ -879,37 +970,48 @@ export class CourseService {
879
970
  id: number,
880
971
  data: PersistCourseExtrasInput,
881
972
  ) {
882
- const updateData: Record<string, string | boolean> = {};
973
+ const setClauses: string[] = [];
974
+ const values: Array<string | boolean | number> = [];
975
+
976
+ const pushSetClause = (column: string, value: string | boolean) => {
977
+ values.push(value);
978
+ setClauses.push(`${column} = $${values.length}`);
979
+ };
883
980
 
884
981
  if (data.name !== undefined) {
885
- updateData.name = data.name;
982
+ pushSetClause('name', data.name);
886
983
  }
887
984
 
888
985
  if (data.isFeatured !== undefined) {
889
- updateData.is_featured = data.isFeatured;
986
+ pushSetClause('is_featured', data.isFeatured);
890
987
  }
891
988
 
892
989
  if (data.hasCertificate !== undefined) {
893
- updateData.has_certificate = data.hasCertificate;
990
+ pushSetClause('has_certificate', data.hasCertificate);
894
991
  }
895
992
 
896
993
  if (data.isListed !== undefined) {
897
- updateData.is_listed = data.isListed;
994
+ pushSetClause('is_listed', data.isListed);
898
995
  }
899
996
 
900
997
  if (data.offeringType !== undefined) {
901
- updateData.offering_type = data.offeringType;
998
+ pushSetClause('offering_type', data.offeringType);
902
999
  }
903
1000
 
904
- if (Object.keys(updateData).length === 0) {
1001
+ if (setClauses.length === 0) {
905
1002
  return;
906
1003
  }
907
1004
 
908
1005
  try {
909
- await this.prisma.course.update({
910
- where: { id },
911
- data: updateData as any,
912
- });
1006
+ values.push(id);
1007
+ await this.prisma.$executeRawUnsafe(
1008
+ `
1009
+ UPDATE course
1010
+ SET ${setClauses.join(', ')}
1011
+ WHERE id = $${values.length}
1012
+ `,
1013
+ ...values,
1014
+ );
913
1015
  } catch {
914
1016
  // Some environments may still be behind the current course schema.
915
1017
  }
@@ -1075,4 +1177,51 @@ export class CourseService {
1075
1177
  select: { id: true },
1076
1178
  });
1077
1179
  }
1180
+
1181
+ async getCourseVideoProfiles(courseId: number) {
1182
+ const rows = await (this.prisma as any).course_video_resolution_profile.findMany({
1183
+ where: { course_id: courseId },
1184
+ include: { video_resolution_profile: true },
1185
+ orderBy: { video_resolution_profile: { name: 'asc' } },
1186
+ });
1187
+
1188
+ return (rows as any[]).map((row) => ({
1189
+ id: row.video_resolution_profile.id,
1190
+ name: row.video_resolution_profile.name,
1191
+ ffmpeg_params: row.video_resolution_profile.ffmpeg_params,
1192
+ status: row.video_resolution_profile.status,
1193
+ }));
1194
+ }
1195
+
1196
+ async syncCourseVideoProfiles(courseId: number, profileIds: number[]) {
1197
+ const linkClient = (this.prisma as any).course_video_resolution_profile;
1198
+
1199
+ await this.prisma.$transaction(async (tx: any) => {
1200
+ await tx.course_video_resolution_profile.deleteMany({
1201
+ where: { course_id: courseId },
1202
+ });
1203
+
1204
+ if (profileIds.length > 0) {
1205
+ await tx.course_video_resolution_profile.createMany({
1206
+ data: profileIds.map((id) => ({
1207
+ course_id: courseId,
1208
+ video_resolution_profile_id: id,
1209
+ })),
1210
+ });
1211
+ }
1212
+ });
1213
+
1214
+ return linkClient.findMany({
1215
+ where: { course_id: courseId },
1216
+ include: { video_resolution_profile: true },
1217
+ orderBy: { video_resolution_profile: { name: 'asc' } },
1218
+ }).then((rows: any[]) =>
1219
+ rows.map((row: any) => ({
1220
+ id: row.video_resolution_profile.id,
1221
+ name: row.video_resolution_profile.name,
1222
+ ffmpeg_params: row.video_resolution_profile.ffmpeg_params,
1223
+ status: row.video_resolution_profile.status,
1224
+ })),
1225
+ );
1226
+ }
1078
1227
  }
@@ -32,6 +32,12 @@ class CourseLessonResourceDto {
32
32
  publico?: boolean;
33
33
  }
34
34
 
35
+ export class CreateLessonVideoConversionDto {
36
+ @IsInt()
37
+ @Min(1)
38
+ originalFileId: number;
39
+ }
40
+
35
41
  export class CreateCourseStructureLessonDto {
36
42
  @IsString()
37
43
  @IsNotEmpty()
@@ -60,9 +66,9 @@ export class CreateCourseStructureLessonDto {
60
66
  @IsOptional()
61
67
  duracao: number = 0;
62
68
 
63
- @IsEnum(['youtube', 'vimeo', 'bunny', 'custom'])
69
+ @IsEnum(['youtube', 'vimeo', 'file_storage', 'bunny', 'custom'])
64
70
  @IsOptional()
65
- videoProvedor?: 'youtube' | 'vimeo' | 'bunny' | 'custom';
71
+ videoProvedor?: 'youtube' | 'vimeo' | 'file_storage' | 'bunny' | 'custom';
66
72
 
67
73
  @IsString()
68
74
  @IsOptional()
@@ -76,6 +82,11 @@ export class CreateCourseStructureLessonDto {
76
82
  @IsOptional()
77
83
  transcricao?: string;
78
84
 
85
+ @IsInt()
86
+ @Min(1)
87
+ @IsOptional()
88
+ videoConversionJobId?: number;
89
+
79
90
  @IsInt()
80
91
  @Min(1)
81
92
  @IsOptional()
@@ -1,3 +1,6 @@
1
+ import {
2
+ Type,
3
+ } from 'class-transformer';
1
4
  import {
2
5
  IsArray,
3
6
  IsBoolean,
@@ -115,4 +118,17 @@ 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;
126
+
127
+ @IsString()
128
+ @MaxLength(32)
129
+ @Matches(/^[A-Z0-9]{2,}$/, {
130
+ message: 'code deve conter apenas letras maiúsculas e números, mínimo 2 caracteres',
131
+ })
132
+ @IsOptional()
133
+ code?: string;
118
134
  }
@@ -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 {}