rez_core 3.1.154 → 3.1.156

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 (540) hide show
  1. package/.claude/settings.local.json +26 -0
  2. package/.idea/250218_nodejs_core.iml +9 -0
  3. package/.idea/codeStyles/Project.xml +59 -0
  4. package/.idea/codeStyles/codeStyleConfig.xml +5 -0
  5. package/.idea/copilot.data.migration.agent.xml +6 -0
  6. package/.idea/copilot.data.migration.ask.xml +6 -0
  7. package/.idea/copilot.data.migration.ask2agent.xml +6 -0
  8. package/.idea/copilot.data.migration.edit.xml +6 -0
  9. package/.idea/inspectionProfiles/Project_Default.xml +6 -0
  10. package/.idea/misc.xml +6 -0
  11. package/.idea/modules.xml +8 -0
  12. package/.idea/prettier.xml +6 -0
  13. package/.idea/vcs.xml +6 -0
  14. package/.prettierrc +3 -3
  15. package/README.md +99 -99
  16. package/dist/app.module.js +2 -0
  17. package/dist/app.module.js.map +1 -1
  18. package/dist/config/config.module.js +2 -1
  19. package/dist/config/config.module.js.map +1 -1
  20. package/dist/config/database.config.js +1 -1
  21. package/dist/config/database.config.js.map +1 -1
  22. package/dist/main.js +10 -17
  23. package/dist/main.js.map +1 -1
  24. package/dist/module/auth/auth.module.js +0 -1
  25. package/dist/module/auth/auth.module.js.map +1 -1
  26. package/dist/module/auth/guards/role.guard.js +3 -3
  27. package/dist/module/auth/services/auth.service.js +2 -2
  28. package/dist/module/enterprise/enterprise.module.js +25 -7
  29. package/dist/module/enterprise/enterprise.module.js.map +1 -1
  30. package/dist/module/enterprise/entity/brand.entity.d.ts +0 -0
  31. package/dist/module/enterprise/entity/brand.entity.js +1 -0
  32. package/dist/module/enterprise/entity/brand.entity.js.map +1 -0
  33. package/dist/module/enterprise/entity/school.entity.d.ts +0 -0
  34. package/dist/module/enterprise/entity/school.entity.js +1 -0
  35. package/dist/module/enterprise/entity/school.entity.js.map +1 -0
  36. package/dist/module/enterprise/repository/brand.repository.d.ts +0 -0
  37. package/dist/module/enterprise/repository/brand.repository.js +1 -0
  38. package/dist/module/enterprise/repository/brand.repository.js.map +1 -0
  39. package/dist/module/enterprise/service/brand-profile.service.d.ts +4 -0
  40. package/dist/module/enterprise/service/brand-profile.service.js +25 -0
  41. package/dist/module/enterprise/service/brand-profile.service.js.map +1 -0
  42. package/dist/module/enterprise/service/brand.service.d.ts +4 -0
  43. package/dist/module/enterprise/service/brand.service.js +40 -1
  44. package/dist/module/enterprise/service/brand.service.js.map +1 -1
  45. package/dist/module/enterprise/service/organization.service.d.ts +6 -4
  46. package/dist/module/enterprise/service/organization.service.js +9 -5
  47. package/dist/module/enterprise/service/organization.service.js.map +1 -1
  48. package/dist/module/enterprise/service/school.service.d.ts +3 -0
  49. package/dist/module/enterprise/service/school.service.js +18 -0
  50. package/dist/module/enterprise/service/school.service.js.map +1 -0
  51. package/dist/module/filter/controller/filter.controller.js.map +1 -1
  52. package/dist/module/filter/dto/filter-request.dto.d.ts +0 -1
  53. package/dist/module/filter/repository/saved-filter.repository.js +4 -4
  54. package/dist/module/filter/service/filter-evaluator.service.js +2 -3
  55. package/dist/module/filter/service/filter-evaluator.service.js.map +1 -1
  56. package/dist/module/filter/service/filter.service.js +7 -7
  57. package/dist/module/ics/service/ics.service.d.ts +1 -1
  58. package/dist/module/ics/service/ics.service.js +2 -2
  59. package/dist/module/ics/service/ics.service.js.map +1 -1
  60. package/dist/module/integration/controller/wrapper.controller.d.ts +3 -3
  61. package/dist/module/integration/controller/wrapper.controller.js +4 -3
  62. package/dist/module/integration/controller/wrapper.controller.js.map +1 -1
  63. package/dist/module/integration/examples/usage.example.js +9 -9
  64. package/dist/module/integration/service/integration.service.js +2 -4
  65. package/dist/module/integration/service/integration.service.js.map +1 -1
  66. package/dist/module/integration/service/wrapper.service.d.ts +3 -3
  67. package/dist/module/integration/service/wrapper.service.js +36 -59
  68. package/dist/module/integration/service/wrapper.service.js.map +1 -1
  69. package/dist/module/listmaster/repository/list-master-items.repository.js +1 -1
  70. package/dist/module/listmaster/repository/list-master-items.repository.js.map +1 -1
  71. package/dist/module/listmaster/service/list-master-engine.js +2 -2
  72. package/dist/module/listmaster/service/list-master-engine.js.map +1 -1
  73. package/dist/module/listmaster/service/list-master-item.service.js +2 -2
  74. package/dist/module/listmaster/service/list-master.service.js +3 -4
  75. package/dist/module/listmaster/service/list-master.service.js.map +1 -1
  76. package/dist/module/mapper/controller/field-mapper.controller.js.map +1 -1
  77. package/dist/module/mapper/dto/field-mapper.dto.d.ts +1 -0
  78. package/dist/module/mapper/dto/field-mapper.dto.js.map +1 -1
  79. package/dist/module/mapper/service/field-mapper.service.js +4 -4
  80. package/dist/module/mapper/service/mapper.service.js +2 -2
  81. package/dist/module/meta/controller/media.controller.js +1 -1
  82. package/dist/module/meta/controller/media.controller.js.map +1 -1
  83. package/dist/module/meta/entity/brand-profile.entity.d.ts +3 -0
  84. package/dist/module/meta/entity/brand-profile.entity.js +18 -0
  85. package/dist/module/meta/entity/brand-profile.entity.js.map +1 -0
  86. package/dist/module/meta/entity/field-group.entity.d.ts +0 -0
  87. package/dist/module/meta/entity/field-group.entity.js +1 -0
  88. package/dist/module/meta/entity/field-group.entity.js.map +1 -0
  89. package/dist/module/meta/entity/school.entity.d.ts +8 -0
  90. package/dist/module/meta/entity/school.entity.js +44 -0
  91. package/dist/module/meta/entity/school.entity.js.map +1 -0
  92. package/dist/module/meta/entity/schoolAddress.entity.d.ts +9 -0
  93. package/dist/module/meta/entity/schoolAddress.entity.js +48 -0
  94. package/dist/module/meta/entity/schoolAddress.entity.js.map +1 -0
  95. package/dist/module/meta/entity/section-master.entity.d.ts +0 -0
  96. package/dist/module/meta/entity/section-master.entity.js +1 -0
  97. package/dist/module/meta/entity/section-master.entity.js.map +1 -0
  98. package/dist/module/meta/entity/user-app-mapping.entity.d.ts +0 -0
  99. package/dist/module/meta/entity/user-app-mapping.entity.js +1 -0
  100. package/dist/module/meta/entity/user-app-mapping.entity.js.map +1 -0
  101. package/dist/module/meta/entity.module.js +6 -0
  102. package/dist/module/meta/entity.module.js.map +1 -1
  103. package/dist/module/meta/service/entity-dynamic.service.js +18 -18
  104. package/dist/module/meta/service/entity-list.service.js +3 -3
  105. package/dist/module/meta/service/entity-master.service.js +3 -3
  106. package/dist/module/meta/service/entity-relation.service.js +11 -11
  107. package/dist/module/meta/service/entity-service-impl.service.js +4 -6
  108. package/dist/module/meta/service/entity-service-impl.service.js.map +1 -1
  109. package/dist/module/meta/service/entity-table.service.js.map +1 -1
  110. package/dist/module/meta/service/entity-validation.service.js.map +1 -1
  111. package/dist/module/meta/service/resolver.service.d.ts +2 -2
  112. package/dist/module/meta/service/resolver.service.js +4 -4
  113. package/dist/module/meta/service/resolver.service.js.map +1 -1
  114. package/dist/module/module/module.module.js.map +1 -1
  115. package/dist/module/module/repository/menu.repository.js +12 -12
  116. package/dist/module/module/repository/module-access.repository.js +1 -0
  117. package/dist/module/module/repository/module-access.repository.js.map +1 -1
  118. package/dist/module/module/service/module-access.service.js +1 -7
  119. package/dist/module/module/service/module-access.service.js.map +1 -1
  120. package/dist/module/notification/service/email.service.js +5 -10
  121. package/dist/module/notification/service/email.service.js.map +1 -1
  122. package/dist/module/notification/service/notification.service.js +12 -12
  123. package/dist/module/school/controller/school.controller.d.ts +0 -0
  124. package/dist/module/school/controller/school.controller.js +1 -0
  125. package/dist/module/school/controller/school.controller.js.map +1 -0
  126. package/dist/module/school/dto/school.dto.d.ts +2 -0
  127. package/dist/module/school/dto/school.dto.js +6 -0
  128. package/dist/module/school/dto/school.dto.js.map +1 -0
  129. package/dist/module/school/entity/school-address.entity.d.ts +12 -0
  130. package/dist/module/school/entity/school-address.entity.js +58 -0
  131. package/dist/module/school/entity/school-address.entity.js.map +1 -0
  132. package/dist/module/school/entity/school-board-affiliations.entity.d.ts +0 -0
  133. package/dist/module/school/entity/school-board-affiliations.entity.js +1 -0
  134. package/dist/module/school/entity/school-board-affiliations.entity.js.map +1 -0
  135. package/dist/module/school/entity/school-certification.entity.d.ts +0 -0
  136. package/dist/module/school/entity/school-certification.entity.js +1 -0
  137. package/dist/module/school/entity/school-certification.entity.js.map +1 -0
  138. package/dist/module/school/entity/school-contact.entity.d.ts +7 -0
  139. package/dist/module/school/entity/school-contact.entity.js +38 -0
  140. package/dist/module/school/entity/school-contact.entity.js.map +1 -0
  141. package/dist/module/school/entity/school-infrastructure.entity.d.ts +0 -0
  142. package/dist/module/school/entity/school-infrastructure.entity.js +1 -0
  143. package/dist/module/school/entity/school-infrastructure.entity.js.map +1 -0
  144. package/dist/module/school/entity/school-lead.entity.d.ts +0 -0
  145. package/dist/module/school/entity/school-lead.entity.js +1 -0
  146. package/dist/module/school/entity/school-lead.entity.js.map +1 -0
  147. package/dist/module/school/entity/school-operational-information.entity.d.ts +0 -0
  148. package/dist/module/school/entity/school-operational-information.entity.js +1 -0
  149. package/dist/module/school/entity/school-operational-information.entity.js.map +1 -0
  150. package/dist/module/school/entity/school-shift-time.entity.d.ts +0 -0
  151. package/dist/module/school/entity/school-shift-time.entity.js +1 -0
  152. package/dist/module/school/entity/school-shift-time.entity.js.map +1 -0
  153. package/dist/module/school/entity/school-shift.entity.d.ts +0 -0
  154. package/dist/module/school/entity/school-shift.entity.js +1 -0
  155. package/dist/module/school/entity/school-shift.entity.js.map +1 -0
  156. package/dist/module/school/entity/school.entity.d.ts +37 -0
  157. package/dist/module/school/entity/school.entity.js +158 -0
  158. package/dist/module/school/entity/school.entity.js.map +1 -0
  159. package/dist/module/school/repository/school-lead.repository.d.ts +0 -0
  160. package/dist/module/school/repository/school-lead.repository.js +1 -0
  161. package/dist/module/school/repository/school-lead.repository.js.map +1 -0
  162. package/dist/module/school/repository/school.repository.d.ts +17 -0
  163. package/dist/module/school/repository/school.repository.js +101 -0
  164. package/dist/module/school/repository/school.repository.js.map +1 -0
  165. package/dist/module/school/school.module.d.ts +2 -0
  166. package/dist/module/school/school.module.js +38 -0
  167. package/dist/module/school/school.module.js.map +1 -0
  168. package/dist/module/school/service/school-lead.service.d.ts +0 -0
  169. package/dist/module/school/service/school-lead.service.js +1 -0
  170. package/dist/module/school/service/school-lead.service.js.map +1 -0
  171. package/dist/module/school/service/school.service.d.ts +11 -0
  172. package/dist/module/school/service/school.service.js +144 -0
  173. package/dist/module/school/service/school.service.js.map +1 -0
  174. package/dist/module/user/controller/login.controller.js +18 -18
  175. package/dist/module/user/service/login.service.d.ts +2 -2
  176. package/dist/module/user/service/role.service.js +4 -4
  177. package/dist/module/user/service/user-session.service.js +2 -2
  178. package/dist/module/user/service/user-session.service.js.map +1 -1
  179. package/dist/module/user/service/user.service.d.ts +0 -4
  180. package/dist/module/user/service/user.service.js +0 -104
  181. package/dist/module/user/service/user.service.js.map +1 -1
  182. package/dist/module/workflow/repository/action.repository.js +16 -16
  183. package/dist/module/workflow/repository/activity-log.repository.d.ts +3 -2
  184. package/dist/module/workflow/repository/activity-log.repository.js +3 -2
  185. package/dist/module/workflow/repository/activity-log.repository.js.map +1 -1
  186. package/dist/module/workflow/repository/comm-template.repository.js +6 -6
  187. package/dist/module/workflow/repository/form-master.repository.js +2 -2
  188. package/dist/module/workflow/repository/stage-group.repository.js +23 -23
  189. package/dist/module/workflow/repository/stage-movement.repository.js +11 -11
  190. package/dist/module/workflow/repository/stage.repository.js +8 -8
  191. package/dist/module/workflow/repository/task.repository.js +0 -2
  192. package/dist/module/workflow/repository/task.repository.js.map +1 -1
  193. package/dist/module/workflow/service/action-template-mapping.service.js +10 -10
  194. package/dist/module/workflow/service/action.service.js +7 -7
  195. package/dist/module/workflow/service/entity-modification.service.js +6 -6
  196. package/dist/module/workflow/service/stage-group.service.js +5 -5
  197. package/dist/module/workflow/service/stage.service.js +2 -2
  198. package/dist/module/workflow/service/task.service.js +33 -33
  199. package/dist/module/workflow/service/workflow-list-master.service.js +15 -15
  200. package/dist/module/workflow/service/workflow-meta.service.js +50 -50
  201. package/dist/module/workflow/service/workflow.service.js +2 -2
  202. package/dist/resources/dev.properties.yaml +30 -0
  203. package/dist/resources/local.properties.yaml +27 -0
  204. package/dist/resources/uat.properties.yaml +16 -0
  205. package/dist/tsconfig.build.tsbuildinfo +1 -1
  206. package/dist/utils/service/reflection-helper.service.js +2 -2
  207. package/docs/modules/event-driven-integration-design.md +91 -91
  208. package/docs/modules/integration.md +250 -250
  209. package/eslint.config.mjs +34 -34
  210. package/nest-cli.json +14 -14
  211. package/package.json +118 -118
  212. package/server.log +850 -0
  213. package/src/app.controller.ts +12 -12
  214. package/src/app.module.ts +49 -49
  215. package/src/app.service.ts +8 -8
  216. package/src/config/config.module.ts +18 -18
  217. package/src/config/database.config.ts +23 -23
  218. package/src/constant/global.constant.ts +67 -67
  219. package/src/core.module.ts +81 -81
  220. package/src/decorators/roles.decorator.ts +7 -7
  221. package/src/dtos/response.dto.ts +6 -6
  222. package/src/dtos/response.ts +5 -5
  223. package/src/index.ts +1 -1
  224. package/src/module/auth/auth.module.ts +49 -49
  225. package/src/module/auth/controller/auth.controller.ts +28 -28
  226. package/src/module/auth/guards/google-auth.guard.ts +9 -9
  227. package/src/module/auth/guards/jwt.guard.ts +22 -22
  228. package/src/module/auth/guards/role.guard.ts +68 -68
  229. package/src/module/auth/services/auth.service.ts +50 -50
  230. package/src/module/auth/services/jwt.service.ts +11 -11
  231. package/src/module/auth/strategies/google.strategy.ts +54 -54
  232. package/src/module/auth/strategies/jwt.strategy.ts +58 -58
  233. package/src/module/auth/strategies/local.strategy.ts +13 -13
  234. package/src/module/dashboard/controller/dashboard.controller.ts +36 -36
  235. package/src/module/dashboard/dashboard.module.ts +21 -21
  236. package/src/module/dashboard/entity/dashboard_page_data.entity.ts +27 -27
  237. package/src/module/dashboard/entity/widget_master.entity.ts +18 -18
  238. package/src/module/dashboard/repository/dashboard.repository.ts +42 -42
  239. package/src/module/dashboard/service/dashboard.service.ts +73 -73
  240. package/src/module/dev/dev.module.ts +12 -12
  241. package/src/module/dev/service/dev.service.ts +7 -7
  242. package/src/module/enterprise/controller/organization.controller.ts +36 -36
  243. package/src/module/enterprise/enterprise.module.ts +30 -30
  244. package/src/module/enterprise/entity/enterprise.entity.ts +37 -37
  245. package/src/module/enterprise/entity/organization-app-mapping.entity.ts +13 -13
  246. package/src/module/enterprise/entity/organization.entity.ts +92 -92
  247. package/src/module/enterprise/repository/enterprise.repository.ts +31 -31
  248. package/src/module/enterprise/repository/organization.repository.ts +26 -26
  249. package/src/module/enterprise/repository/school.repository.ts +281 -281
  250. package/src/module/enterprise/service/brand.service.ts +5 -5
  251. package/src/module/enterprise/service/enterprise.service.ts +16 -16
  252. package/src/module/enterprise/service/organization-app-mapping.service.ts +4 -4
  253. package/src/module/enterprise/service/organization.service.ts +145 -145
  254. package/src/module/filter/controller/filter.controller.ts +84 -84
  255. package/src/module/filter/dto/filter-request.dto.ts +38 -38
  256. package/src/module/filter/entity/saved-filter-detail.entity.ts +41 -41
  257. package/src/module/filter/entity/saved-filter-master.entity.ts +23 -23
  258. package/src/module/filter/filter.module.ts +31 -31
  259. package/src/module/filter/repository/saved-filter.repository.ts +168 -168
  260. package/src/module/filter/service/filter-evaluator.service.ts +86 -86
  261. package/src/module/filter/service/filter.service.ts +841 -841
  262. package/src/module/filter/service/saved-filter.service.ts +170 -170
  263. package/src/module/ics/controller/ics.controller.ts +21 -21
  264. package/src/module/ics/dto/ics.dto.ts +55 -55
  265. package/src/module/ics/ics.module.ts +13 -13
  266. package/src/module/ics/service/ics.service.ts +57 -57
  267. package/src/module/integration/controller/calender-event.controller.ts +31 -31
  268. package/src/module/integration/controller/integration.controller.ts +662 -662
  269. package/src/module/integration/controller/wrapper.controller.ts +37 -39
  270. package/src/module/integration/dto/create-config.dto.ts +526 -526
  271. package/src/module/integration/entity/integration-config.entity.ts +112 -112
  272. package/src/module/integration/entity/integration-entity-mapper.entity.ts +14 -14
  273. package/src/module/integration/entity/integration-source.entity.ts +17 -17
  274. package/src/module/integration/entity/user-integration.entity.ts +71 -71
  275. package/src/module/integration/examples/usage.example.ts +338 -338
  276. package/src/module/integration/factories/base.factory.ts +7 -7
  277. package/src/module/integration/factories/email.factory.ts +49 -49
  278. package/src/module/integration/factories/integration.factory.ts +121 -121
  279. package/src/module/integration/factories/sms.factory.ts +51 -51
  280. package/src/module/integration/factories/telephone.factory.ts +41 -41
  281. package/src/module/integration/factories/whatsapp.factory.ts +56 -56
  282. package/src/module/integration/integration.module.ts +110 -110
  283. package/src/module/integration/service/calendar-event.service.ts +118 -118
  284. package/src/module/integration/service/integration-entity-mapper.service.ts +17 -17
  285. package/src/module/integration/service/integration-queue.service.ts +229 -229
  286. package/src/module/integration/service/integration.service.ts +2572 -2572
  287. package/src/module/integration/service/oauth.service.ts +224 -224
  288. package/src/module/integration/service/wrapper.service.ts +439 -513
  289. package/src/module/integration/strategies/email/gmail-api.strategy.ts +280 -280
  290. package/src/module/integration/strategies/email/outlook-api.strategy.ts +44 -44
  291. package/src/module/integration/strategies/email/outlook.strategy.ts +64 -64
  292. package/src/module/integration/strategies/email/sendgrid-api.strategy.ts +260 -260
  293. package/src/module/integration/strategies/integration.strategy.ts +97 -97
  294. package/src/module/integration/strategies/sms/gupshup-sms.strategy.ts +146 -146
  295. package/src/module/integration/strategies/sms/msg91-sms.strategy.ts +164 -164
  296. package/src/module/integration/strategies/sms/tubelight-sms.strategy.ts +163 -163
  297. package/src/module/integration/strategies/telephone/ozonetel-voice.strategy.ts +238 -238
  298. package/src/module/integration/strategies/telephone/tubelight-voice.strategy.ts +210 -210
  299. package/src/module/integration/strategies/whatsapp/gupshup-whatsapp.strategy.ts +359 -359
  300. package/src/module/integration/strategies/whatsapp/tubelight-whatsapp.strategy.ts +372 -372
  301. package/src/module/integration/strategies/whatsapp/whatsapp-cloud.strategy.ts +403 -403
  302. package/src/module/integration/strategies/whatsapp/whatsapp.strategy.ts +57 -57
  303. package/src/module/layout/controller/layout.controller.ts +47 -47
  304. package/src/module/layout/entity/header-items.entity.ts +28 -28
  305. package/src/module/layout/entity/header-section.entity.ts +19 -19
  306. package/src/module/layout/layout.module.ts +21 -21
  307. package/src/module/layout/repository/header-items.repository.ts +18 -18
  308. package/src/module/layout/repository/header-section.repository.ts +22 -22
  309. package/src/module/layout/service/header-section.service.ts +25 -25
  310. package/src/module/layout_preference/controller/layout_preference.controller.ts +47 -47
  311. package/src/module/layout_preference/entity/layout_preference.entity.ts +28 -28
  312. package/src/module/layout_preference/layout_preference.module.ts +18 -18
  313. package/src/module/layout_preference/repository/layout_preference.repository.ts +30 -30
  314. package/src/module/layout_preference/service/layout_preference.service.ts +172 -172
  315. package/src/module/lead/controller/lead.controller.ts +30 -30
  316. package/src/module/lead/lead.module.ts +14 -14
  317. package/src/module/lead/repository/lead.repository.ts +41 -41
  318. package/src/module/lead/service/lead.service.ts +54 -54
  319. package/src/module/listmaster/controller/list-master.controller.ts +143 -143
  320. package/src/module/listmaster/entity/list-master-items.entity.ts +41 -41
  321. package/src/module/listmaster/entity/list-master.entity.ts +32 -32
  322. package/src/module/listmaster/listmaster.module.ts +44 -44
  323. package/src/module/listmaster/repository/list-master-items.repository.ts +169 -169
  324. package/src/module/listmaster/repository/list-master.repository.ts +46 -46
  325. package/src/module/listmaster/service/list-master-engine.ts +19 -17
  326. package/src/module/listmaster/service/list-master-extension.interface.ts +4 -4
  327. package/src/module/listmaster/service/list-master-item.service.ts +292 -292
  328. package/src/module/listmaster/service/list-master-registry.ts +15 -15
  329. package/src/module/listmaster/service/list-master.service.ts +375 -375
  330. package/src/module/mapper/controller/field-mapper.controller.ts +69 -69
  331. package/src/module/mapper/controller/mapper.controller.ts +14 -14
  332. package/src/module/mapper/dto/field-mapper.dto.ts +14 -14
  333. package/src/module/mapper/entity/field-lovs.entity.ts +19 -19
  334. package/src/module/mapper/entity/field-mapper.entity.ts +53 -53
  335. package/src/module/mapper/entity/mapper.entity.ts +16 -16
  336. package/src/module/mapper/mapper.module.ts +34 -34
  337. package/src/module/mapper/repository/field-lovs.repository.ts +35 -35
  338. package/src/module/mapper/repository/field-mapper.repository.ts +42 -42
  339. package/src/module/mapper/repository/mapper.repository.ts +15 -15
  340. package/src/module/mapper/service/field-mapper.service.ts +223 -223
  341. package/src/module/mapper/service/mapper.service.ts +72 -72
  342. package/src/module/master/controller/master.controller.ts +74 -74
  343. package/src/module/master/service/master.service.ts +483 -483
  344. package/src/module/meta/controller/app-master.controller.ts +38 -38
  345. package/src/module/meta/controller/attribute-master.controller.ts +66 -66
  346. package/src/module/meta/controller/entity-dynamic.controller.ts +125 -125
  347. package/src/module/meta/controller/entity-master.controller.ts +28 -28
  348. package/src/module/meta/controller/entity-relation.controller.ts +36 -36
  349. package/src/module/meta/controller/entity.controller.ts +385 -385
  350. package/src/module/meta/controller/media.controller.ts +82 -82
  351. package/src/module/meta/controller/meta.controller.ts +96 -96
  352. package/src/module/meta/controller/view-master.controller.ts +86 -86
  353. package/src/module/meta/dto/entity-list-data.dto.ts +6 -6
  354. package/src/module/meta/dto/entity-tab.dto.ts +4 -4
  355. package/src/module/meta/dto/entity-table.dto.ts +9 -9
  356. package/src/module/meta/entity/app-master.entity.ts +34 -34
  357. package/src/module/meta/entity/attribute-master.entity.ts +87 -87
  358. package/src/module/meta/entity/base-entity.entity.ts +75 -75
  359. package/src/module/meta/entity/entity-master.entity.ts +78 -78
  360. package/src/module/meta/entity/entity-relation-data.entity.ts +29 -29
  361. package/src/module/meta/entity/entity-relation.entity.ts +23 -23
  362. package/src/module/meta/entity/entity-table-column.entity.ts +61 -61
  363. package/src/module/meta/entity/entity-table.entity.ts +50 -50
  364. package/src/module/meta/entity/media-data.entity.ts +32 -32
  365. package/src/module/meta/entity/preference.entity.ts +62 -62
  366. package/src/module/meta/entity/view-master.entity.ts +41 -41
  367. package/src/module/meta/entity.module.ts +156 -156
  368. package/src/module/meta/repository/app-master.repository.ts +20 -20
  369. package/src/module/meta/repository/attribute-master.repository.ts +110 -110
  370. package/src/module/meta/repository/entity-master.repository.ts +69 -69
  371. package/src/module/meta/repository/entity-table-column.repository.ts +39 -39
  372. package/src/module/meta/repository/entity-table.repository.ts +53 -53
  373. package/src/module/meta/repository/media-data.repository.ts +50 -50
  374. package/src/module/meta/repository/preference.repository.ts +20 -20
  375. package/src/module/meta/repository/user-app-mapping.repository.ts +28 -28
  376. package/src/module/meta/repository/view-master.repository.ts +42 -42
  377. package/src/module/meta/service/app-master.service.ts +37 -37
  378. package/src/module/meta/service/attribute-master.service.ts +117 -117
  379. package/src/module/meta/service/common.service.ts +9 -9
  380. package/src/module/meta/service/entity-dynamic.service.ts +762 -762
  381. package/src/module/meta/service/entity-list.service.ts +205 -205
  382. package/src/module/meta/service/entity-master.service.ts +164 -164
  383. package/src/module/meta/service/entity-realation-data.service.ts +9 -9
  384. package/src/module/meta/service/entity-relation.service.ts +69 -69
  385. package/src/module/meta/service/entity-service-impl.service.ts +524 -524
  386. package/src/module/meta/service/entity-table-column.service.ts +39 -39
  387. package/src/module/meta/service/entity-table.service.ts +150 -150
  388. package/src/module/meta/service/entity-validation.service.ts +185 -185
  389. package/src/module/meta/service/entity.service.ts +67 -67
  390. package/src/module/meta/service/field-group.service.ts +103 -103
  391. package/src/module/meta/service/media-data.service.ts +140 -140
  392. package/src/module/meta/service/populate-meta.service.ts +173 -173
  393. package/src/module/meta/service/preference.service.ts +16 -16
  394. package/src/module/meta/service/resolver.service.ts +274 -274
  395. package/src/module/meta/service/section-master.service.ts +104 -104
  396. package/src/module/meta/service/update-form-json.service.ts +22 -22
  397. package/src/module/meta/service/user-app-mapping.service.ts +17 -17
  398. package/src/module/meta/service/view-master.service.ts +111 -111
  399. package/src/module/module/controller/menu.controller.ts +15 -15
  400. package/src/module/module/controller/module-access.controller.ts +132 -132
  401. package/src/module/module/entity/menu.entity.ts +43 -43
  402. package/src/module/module/entity/module-access.entity.ts +25 -25
  403. package/src/module/module/entity/module-action.entity.ts +17 -17
  404. package/src/module/module/entity/module.entity.ts +52 -52
  405. package/src/module/module/module.module.ts +42 -42
  406. package/src/module/module/repository/menu.repository.ts +184 -184
  407. package/src/module/module/repository/module-access.repository.ts +331 -331
  408. package/src/module/module/service/menu.service.ts +82 -82
  409. package/src/module/module/service/module-access.service.ts +209 -209
  410. package/src/module/notification/controller/notification.controller.ts +58 -58
  411. package/src/module/notification/controller/otp.controller.ts +117 -117
  412. package/src/module/notification/entity/notification.entity.ts +23 -23
  413. package/src/module/notification/entity/otp.entity.ts +28 -28
  414. package/src/module/notification/firebase-admin.config.ts +22 -22
  415. package/src/module/notification/notification.module.ts +69 -69
  416. package/src/module/notification/repository/otp.repository.ts +27 -27
  417. package/src/module/notification/service/email.service.ts +127 -127
  418. package/src/module/notification/service/notification.service.ts +138 -138
  419. package/src/module/notification/service/otp.service.ts +121 -121
  420. package/src/module/third-party-module/entity/third-party-api-registry.entity.ts +52 -52
  421. package/src/module/third-party-module/repository/third-party-api-registry.repository.ts +20 -20
  422. package/src/module/third-party-module/service/api-registry.service.ts +13 -13
  423. package/src/module/third-party-module/third-party.module.ts +12 -12
  424. package/src/module/user/controller/login.controller.ts +197 -197
  425. package/src/module/user/controller/user.controller.ts +40 -40
  426. package/src/module/user/dto/create-user.dto.ts +62 -62
  427. package/src/module/user/dto/update-user.dto.ts +4 -4
  428. package/src/module/user/entity/role.entity.ts +33 -33
  429. package/src/module/user/entity/user-role-mapping.entity.ts +38 -38
  430. package/src/module/user/entity/user-session.entity.ts +61 -61
  431. package/src/module/user/entity/user.entity.ts +68 -68
  432. package/src/module/user/repository/role.repository.ts +96 -96
  433. package/src/module/user/repository/user-role-mapping.repository.ts +126 -126
  434. package/src/module/user/repository/user.repository.ts +50 -50
  435. package/src/module/user/repository/userSession.repository.ts +33 -33
  436. package/src/module/user/service/login.service.ts +280 -280
  437. package/src/module/user/service/role.service.ts +189 -189
  438. package/src/module/user/service/user-role-mapping.service.ts +98 -98
  439. package/src/module/user/service/user-session.service.ts +168 -168
  440. package/src/module/user/service/user.service.ts +353 -353
  441. package/src/module/user/user.module.ts +65 -65
  442. package/src/module/workflow/controller/action-category.controller.ts +54 -54
  443. package/src/module/workflow/controller/action-resource-mapping.controller.ts +23 -23
  444. package/src/module/workflow/controller/action-template-mapping.controller.ts +35 -35
  445. package/src/module/workflow/controller/action.controller.ts +95 -95
  446. package/src/module/workflow/controller/activity-log.controller.ts +55 -55
  447. package/src/module/workflow/controller/comm-template.controller.ts +34 -34
  448. package/src/module/workflow/controller/entity-modification.controller.ts +35 -35
  449. package/src/module/workflow/controller/form-master.controller.ts +43 -43
  450. package/src/module/workflow/controller/stage-group.controller.ts +48 -48
  451. package/src/module/workflow/controller/stage.controller.ts +50 -50
  452. package/src/module/workflow/controller/task.controller.ts +77 -77
  453. package/src/module/workflow/controller/workflow-list-master.controller.ts +44 -44
  454. package/src/module/workflow/controller/workflow-meta.controller.ts +80 -80
  455. package/src/module/workflow/controller/workflow.controller.ts +67 -67
  456. package/src/module/workflow/entity/action-category.entity.ts +38 -38
  457. package/src/module/workflow/entity/action-data.entity.ts +55 -55
  458. package/src/module/workflow/entity/action-resources-mapping.entity.ts +29 -29
  459. package/src/module/workflow/entity/action-template-mapping.entity.ts +17 -17
  460. package/src/module/workflow/entity/action.entity.ts +50 -50
  461. package/src/module/workflow/entity/activity-log.entity.ts +43 -43
  462. package/src/module/workflow/entity/comm-template.entity.ts +43 -43
  463. package/src/module/workflow/entity/entity-modification.entity.ts +38 -38
  464. package/src/module/workflow/entity/form.entity.ts +25 -25
  465. package/src/module/workflow/entity/stage-action-mapping.entity.ts +17 -17
  466. package/src/module/workflow/entity/stage-group.entity.ts +23 -23
  467. package/src/module/workflow/entity/stage-movement-data.entity.ts +38 -38
  468. package/src/module/workflow/entity/stage.entity.ts +20 -20
  469. package/src/module/workflow/entity/task-data.entity.ts +88 -88
  470. package/src/module/workflow/entity/template-attach-mapper.entity.ts +30 -30
  471. package/src/module/workflow/entity/workflow-data.entity.ts +11 -11
  472. package/src/module/workflow/entity/workflow-level-mapping.entity.ts +18 -18
  473. package/src/module/workflow/entity/workflow.entity.ts +20 -20
  474. package/src/module/workflow/repository/action-category.repository.ts +79 -79
  475. package/src/module/workflow/repository/action-data.repository.ts +219 -219
  476. package/src/module/workflow/repository/action.repository.ts +277 -277
  477. package/src/module/workflow/repository/activity-log.repository.ts +121 -121
  478. package/src/module/workflow/repository/comm-template.repository.ts +142 -142
  479. package/src/module/workflow/repository/form-master.repository.ts +59 -59
  480. package/src/module/workflow/repository/stage-group.repository.ts +176 -176
  481. package/src/module/workflow/repository/stage-movement.repository.ts +227 -227
  482. package/src/module/workflow/repository/stage.repository.ts +172 -172
  483. package/src/module/workflow/repository/task.repository.ts +113 -113
  484. package/src/module/workflow/repository/workflow.repository.ts +42 -42
  485. package/src/module/workflow/service/action-category.service.ts +33 -33
  486. package/src/module/workflow/service/action-data.service.ts +62 -62
  487. package/src/module/workflow/service/action-resources-mapping.service.ts +10 -10
  488. package/src/module/workflow/service/action-template-mapping.service.ts +55 -55
  489. package/src/module/workflow/service/action.service.ts +263 -263
  490. package/src/module/workflow/service/activity-log.service.ts +107 -107
  491. package/src/module/workflow/service/comm-template.service.ts +121 -121
  492. package/src/module/workflow/service/entity-modification.service.ts +67 -67
  493. package/src/module/workflow/service/form-master.service.ts +35 -35
  494. package/src/module/workflow/service/populate-workflow.service.ts +303 -303
  495. package/src/module/workflow/service/stage-action-mapping.service.ts +5 -5
  496. package/src/module/workflow/service/stage-group.service.ts +300 -300
  497. package/src/module/workflow/service/stage.service.ts +199 -199
  498. package/src/module/workflow/service/task.service.ts +504 -504
  499. package/src/module/workflow/service/workflow-list-master.service.ts +60 -60
  500. package/src/module/workflow/service/workflow-meta.service.ts +581 -581
  501. package/src/module/workflow/service/workflow.service.ts +205 -205
  502. package/src/module/workflow/workflow.module.ts +172 -172
  503. package/src/module/workflow-automation/controller/workflow-automation.controller.ts +21 -21
  504. package/src/module/workflow-automation/entity/workflow-automation-action.entity.ts +26 -26
  505. package/src/module/workflow-automation/entity/workflow-automation.entity.ts +35 -35
  506. package/src/module/workflow-automation/interface/action.decorator.ts +7 -7
  507. package/src/module/workflow-automation/interface/action.interface.ts +5 -5
  508. package/src/module/workflow-automation/service/action-registery.service.ts +35 -35
  509. package/src/module/workflow-automation/service/workflow-automation-engine.service.ts +214 -214
  510. package/src/module/workflow-automation/service/workflow-automation.service.ts +345 -345
  511. package/src/module/workflow-automation/workflow-automation.module.ts +34 -34
  512. package/src/resources/dev.properties.yaml +30 -30
  513. package/src/resources/local.properties.yaml +27 -27
  514. package/src/resources/properties.module.ts +12 -12
  515. package/src/resources/properties.yaml.ts +11 -11
  516. package/src/resources/uat.properties.yaml +15 -15
  517. package/src/utils/dto/excel-data.dto.ts +14 -14
  518. package/src/utils/dto/excelsheet-data.dto.ts +5 -5
  519. package/src/utils/service/base64util.service.ts +18 -18
  520. package/src/utils/service/clockIDGenUtil.service.ts +21 -21
  521. package/src/utils/service/codeGenerator.service.ts +22 -22
  522. package/src/utils/service/dateUtil.service.ts +17 -17
  523. package/src/utils/service/encryptUtil.service.ts +97 -97
  524. package/src/utils/service/excel-helper.service.ts +72 -72
  525. package/src/utils/service/excelUtil.service.ts +15 -15
  526. package/src/utils/service/file-util.service.ts +11 -11
  527. package/src/utils/service/json-util.service.ts +23 -23
  528. package/src/utils/service/loggingUtil.service.ts +34 -34
  529. package/src/utils/service/reflection-helper.service.ts +62 -62
  530. package/src/utils/service/wbsCodeGen.service.ts +8 -8
  531. package/src/utils/utils.module.ts +25 -25
  532. package/tsconfig.build.json +4 -4
  533. package/tsconfig.json +24 -24
  534. package/.vscode/extensions.json +0 -5
  535. package/dist/core.module.d.ts +0 -4
  536. package/dist/core.module.js +0 -79
  537. package/dist/core.module.js.map +0 -1
  538. package/dist/index.d.ts +0 -1
  539. package/dist/index.js +0 -18
  540. package/dist/index.js.map +0 -1
@@ -1,504 +1,504 @@
1
- import { Inject, Injectable } from '@nestjs/common';
2
- import { EntityServiceImpl } from 'src/module/meta/service/entity-service-impl.service';
3
- import { UserData } from 'src/module/user/entity/user.entity';
4
- import { TaskRepository } from '../repository/task.repository';
5
- import { ActionDataService } from './action-data.service';
6
- import { DataSource, EntityManager } from 'typeorm';
7
- import { BaseEntity } from 'src/module/meta/entity/base-entity.entity';
8
- import { ActivityLogService } from './activity-log.service';
9
- import { ACTIVITY_CATEGORIES } from '../repository/activity-log.repository';
10
- import { MediaDataService } from 'src/module/meta/service/media-data.service';
11
- import { ActionHandler } from 'src/module/workflow-automation/interface/action.decorator';
12
-
13
- @Injectable()
14
- @ActionHandler('add_task')
15
- export class TaskService extends EntityServiceImpl {
16
- constructor(
17
- private readonly taskRepository: TaskRepository,
18
- private readonly actionDataService: ActionDataService,
19
- private readonly dataSource: DataSource,
20
- @Inject('ActivityLogService')
21
- private readonly activityLogService: ActivityLogService,
22
- private readonly mediaDataService: MediaDataService,
23
- ) {
24
- super();
25
- }
26
- name: string = 'add_task';
27
-
28
- async execute(payload: any): Promise<any> {
29
- const { entity, user, config } = payload;
30
-
31
- let toValue: string | null = null;
32
-
33
- // 2. Get current stage_id from cr_wf_stage_movement_data
34
- const stageRow = await this.dataSource.query(
35
- `SELECT stage_id
36
- FROM cr_wf_stage_movement_data
37
- WHERE mapped_entity_id = ?
38
- AND is_current = 'Y'
39
- LIMIT 1`,
40
- [entity.id],
41
- );
42
-
43
- const stageId = stageRow.length > 0 ? stageRow[0].stage_id : null;
44
-
45
- if (!stageId) {
46
- throw new Error(
47
- `No current stage found in cr_wf_stage_movement_data for entity_id=${entity.id}`,
48
- );
49
- }
50
-
51
- // 3. Build entityData
52
- const entityData = {
53
- ...config,
54
- mapped_entity_id: entity.id,
55
- mapped_entity_type: entity.entity_type,
56
- task_owner: config.task_owner,
57
- stage_id: stageId,
58
- status: config.status,
59
- due_date: config.due_date,
60
- due_time: config.due_time,
61
- reminder: config.reminder,
62
- description: config.description,
63
- is_mandatory: config.is_mandatory,
64
- };
65
-
66
- return await this.createEntity(entityData, user);
67
- }
68
-
69
- async createEntity(
70
- entityData: any,
71
- loggedInUser: any,
72
- manager?: EntityManager | null,
73
- appcode?: string,
74
- ): Promise<any> {
75
- if (entityData && typeof entityData['is_mandatory'] === 'string') {
76
- entityData['is_mandatory'] = entityData['is_mandatory'] === '1';
77
- }
78
- const createdEntity = await super.createEntity(
79
- entityData,
80
- loggedInUser,
81
- manager,
82
- appcode,
83
- );
84
-
85
- try {
86
- const logData = {
87
- mapped_entity_id: createdEntity.mapped_entity_id,
88
- mapped_entity_type: createdEntity.mapped_entity_type,
89
- title: `Task added`,
90
- description: `A new task ${createdEntity.name} was added`,
91
- category: ACTIVITY_CATEGORIES.TASK,
92
- action: 'add',
93
- appcode: loggedInUser.appcode,
94
- };
95
-
96
- await this.activityLogService.logActivity(logData, loggedInUser);
97
- } catch (error) {
98
- console.error(
99
- 'Failed to log activity for meeting:',
100
- error?.message || error,
101
- );
102
- // Logging should not block main flow
103
- }
104
-
105
- let relationData = await this.dataSource.query(
106
- `SELECT * FROM cr_entity_relation WHERE source_entity_type = ? AND target_entity_type = ?`,
107
- [createdEntity.mapped_entity_type, createdEntity.entity_type],
108
- );
109
-
110
- if (relationData) {
111
- await this.dataSource.query(
112
- `INSERT INTO cr_entity_relation_data (organization_id, source_entity_id, source_entity_type, target_entity_id, target_entity_type, relation_type) VALUES (?, ?, ?, ?, ? , ?)`,
113
- [
114
- loggedInUser.organization_id,
115
- createdEntity.mapped_entity_id,
116
- createdEntity.mapped_entity_type,
117
- createdEntity.id,
118
- createdEntity.entity_type,
119
- relationData[0]?.relation_type,
120
- ],
121
- );
122
- }
123
-
124
- return createdEntity;
125
- }
126
-
127
- async updateEntity(
128
- entityData,
129
- loggedInUser: UserData,
130
- appcode?: string,
131
- ): Promise<any> {
132
- const taskStatusQuery = `
133
- SELECT name
134
- FROM cr_list_master_items
135
- WHERE id = ?
136
- AND organization_id = ?
137
- AND listtype = 'TKST'
138
- LIMIT 1;
139
- `;
140
-
141
- const statusRows = await this.dataSource.query(taskStatusQuery, [
142
- entityData.status,
143
- loggedInUser.organization_id,
144
- ]);
145
-
146
- const isCompletedStatus =
147
- statusRows.length > 0 &&
148
- statusRows[0].name?.toLowerCase() === 'completed';
149
-
150
- // Sync flags based on status
151
- entityData.is_completed = isCompletedStatus;
152
- entityData.is_done = isCompletedStatus;
153
-
154
- const isMandatory =
155
- String(entityData.is_mandatory).toLowerCase() === 'true' ||
156
- entityData.is_mandatory === true ||
157
- entityData.is_mandatory === 1 ||
158
- entityData.is_mandatory === '1';
159
-
160
- const updatedEntity = await super.updateEntity(
161
- {
162
- ...entityData,
163
- is_mandatory: isMandatory,
164
- },
165
- loggedInUser,
166
- appcode,
167
- );
168
-
169
- // Convert boolean back to "1" / "0" for response
170
- if (updatedEntity && typeof updatedEntity['is_mandatory'] === 'boolean') {
171
- updatedEntity['is_mandatory'] = updatedEntity['is_mandatory'] ? '1' : '0';
172
- }
173
-
174
- try {
175
- // Always log edit
176
- const editLogData = {
177
- mapped_entity_id: updatedEntity.mapped_entity_id,
178
- mapped_entity_type: updatedEntity.mapped_entity_type,
179
- title: `Task edited`,
180
- description: `${updatedEntity.code} was edited`,
181
- category: ACTIVITY_CATEGORIES.TASK,
182
- action: 'edit',
183
- appcode: loggedInUser.appcode,
184
- };
185
-
186
- await this.activityLogService.logActivity(editLogData, loggedInUser);
187
-
188
- if (isCompletedStatus) {
189
- const completedLogData = {
190
- mapped_entity_id: updatedEntity.mapped_entity_id,
191
- mapped_entity_type: updatedEntity.mapped_entity_type,
192
- title: `Task completed`,
193
- description: `${updatedEntity.code} was marked as completed`,
194
- category: ACTIVITY_CATEGORIES.TASK,
195
- action: 'completed',
196
- appcode: loggedInUser.appcode,
197
- };
198
-
199
- await this.activityLogService.logActivity(
200
- completedLogData,
201
- loggedInUser,
202
- );
203
- }
204
- } catch (error) {
205
- console.error(
206
- 'Failed to log activity for task:',
207
- error?.message || error,
208
- );
209
- // Don't block main flow
210
- }
211
-
212
- return updatedEntity;
213
- }
214
-
215
- async getAllTaskByUserIdandStageId(
216
- loggedInUser: UserData,
217
- data,
218
- ): Promise<any> {
219
- const taskData = await this.taskRepository.getAllTaskByUserIdAndStageId({
220
- user_id: data.user_id,
221
- stage_id: data.stage_id,
222
- mapped_entity_type: data.mapped_entity_type,
223
- mapped_entity_id: data.mapped_entity_id,
224
- });
225
-
226
- const grouped: { mandatory: any[]; non_mandatory: any[] } = {
227
- mandatory: [],
228
- non_mandatory: [],
229
- };
230
-
231
- for (const task of taskData) {
232
- if (task && task.is_mandatory) {
233
- grouped.mandatory.push(task);
234
- } else {
235
- grouped.non_mandatory.push(task);
236
- }
237
- }
238
-
239
- return grouped;
240
- }
241
-
242
- async getAllTask(
243
- loggedInUser: UserData,
244
- data: {
245
- mapped_entity_type: string;
246
- mapped_entity_id: number;
247
- status?: string;
248
- mandatory?: boolean;
249
- overdue?: boolean;
250
- },
251
- ): Promise<any[]> {
252
- const { mapped_entity_type, mapped_entity_id, status, mandatory, overdue } =
253
- data;
254
-
255
- // Build dynamic WHERE clauses
256
- const whereClauses = [`t.mapped_entity_type = ?`, `t.mapped_entity_id = ?`];
257
- const params: any[] = [mapped_entity_type, mapped_entity_id];
258
-
259
- if (status) {
260
- whereClauses.push(`t.status = ?`);
261
- params.push(status);
262
- }
263
- if (mandatory) {
264
- whereClauses.push(`t.is_mandatory = ?`);
265
- params.push(mandatory ? 1 : 0);
266
- }
267
- if (overdue) {
268
- whereClauses.push(
269
- `(t.due_date < CURDATE() OR (t.due_date = CURDATE() AND t.due_time < CURTIME()))`,
270
- );
271
- // exclude tasks that are already completed
272
- whereClauses.push(`t.is_done = ?`);
273
- params.push(0); // Only include tasks that are not done
274
- }
275
-
276
- const sql = `
277
- SELECT
278
- t.*,
279
- sg.name AS stage_group_name,
280
- s.name AS stage_name,
281
- a.name AS action_name,
282
- u.name AS created_by_name,
283
- u2.name AS task_owner_name,
284
- u2.profile_image AS task_owner_profile
285
- FROM cr_wf_task_data t
286
- LEFT JOIN cr_wf_stage s ON t.stage_id = s.id
287
- LEFT JOIN cr_wf_stage_group sg ON s.stage_group_id = sg.id
288
- LEFT JOIN cr_wf_action a ON t.action_id = a.id
289
- LEFT JOIN sso_user u ON t.created_by = u.id
290
- LEFT JOIN eth_user_profile u2 ON t.task_owner = u2.parent_id
291
- WHERE ${whereClauses.join(' AND ')}
292
- ORDER BY t.created_date DESC
293
- `;
294
-
295
- const taskData = await this.dataSource.query(sql, params);
296
-
297
- if (taskData.length === 0) {
298
- return [];
299
- }
300
-
301
- // Fetch all TKST statuses in a single query
302
- const taskStatusQuery = `
303
- SELECT id, name
304
- FROM cr_list_master_items
305
- WHERE organization_id = ?
306
- AND listtype = 'TKST'
307
- `;
308
- const taskAllStatus = await this.dataSource.query(taskStatusQuery, [
309
- loggedInUser.organization_id,
310
- ]);
311
-
312
- // Build a hash map { id → name }
313
- const statusMap = new Map(
314
- taskAllStatus.map((row) => [String(row.id), row.name]),
315
- );
316
-
317
- // Assign task_status using the map
318
-
319
- const mediaCache = new Map<number, any>();
320
-
321
- for (const task of taskData) {
322
- // Map status name
323
- task.task_status = task.status
324
- ? statusMap.get(String(task.status)) || null
325
- : null;
326
-
327
- // Fix action_name for generic tasks
328
- task.action_name =
329
- task.action_id === '0' || task.action_id === 0
330
- ? 'Generic'
331
- : task.action_name;
332
-
333
- // Profile media (with caching like notes)
334
- if (task.task_owner_profile) {
335
- if (!mediaCache.has(task.task_owner_profile)) {
336
- const url = await this.mediaDataService.getMediaDownloadUrl(
337
- task.task_owner_profile,
338
- loggedInUser,
339
- );
340
- mediaCache.set(task.task_owner_profile, url);
341
- }
342
- task.task_owner_profile = mediaCache.get(task.task_owner_profile);
343
- } else {
344
- task.task_owner_profile = null;
345
- }
346
- }
347
-
348
- // Normalize is_mandatory to '0'/'1' as string
349
- return taskData.map((task) => ({
350
- ...task,
351
- is_mandatory: task.is_mandatory ? '1' : '0',
352
- }));
353
- }
354
-
355
- async getEntityData(entityType: string, id: number, loggedInUser: any) {
356
- const taskData = await super.getEntityData(entityType, id, loggedInUser);
357
-
358
- return taskData;
359
- }
360
-
361
- async saveActionData(
362
- action: any,
363
- loggedInUser: UserData,
364
- mapped_entity_id: number,
365
- mapped_entity_type: string,
366
- ): Promise<any> {
367
- await this.taskRepository.saveActionDataInTask(
368
- action,
369
- loggedInUser,
370
- mapped_entity_id,
371
- mapped_entity_type,
372
- );
373
- }
374
-
375
- async moveTask(
376
- loggedInUser: UserData,
377
- body: {
378
- mapped_entity_type: string;
379
- mapped_entity_id: number;
380
- stage_id: number;
381
- action_id: number;
382
- reason_code?: string | number;
383
- remark?: string;
384
- stage_group_id?: number;
385
- },
386
- ): Promise<any> {
387
- // Logic to move task based on the provided body parameters
388
- // This could involve updating the task's stage, action, etc.
389
-
390
- // update task status
391
- this.taskRepository.updateTaskStatus(
392
- loggedInUser,
393
- body.mapped_entity_type,
394
- body.mapped_entity_id,
395
- body.stage_id,
396
- body.action_id,
397
- );
398
-
399
- // update action status
400
- await this.actionDataService.updateActionStatus(
401
- loggedInUser,
402
- body.mapped_entity_type,
403
- body.mapped_entity_id,
404
- body.stage_id,
405
- body.action_id,
406
- );
407
-
408
- if (body.reason_code || body.remark) {
409
- await this.createSystemNote(
410
- {
411
- reason_code: body.reason_code!,
412
- remark: body.remark || '',
413
- mapped_entity_id: body.mapped_entity_id,
414
- stage_id: body.stage_id,
415
- action_id: body.action_id,
416
- stage_group_id: body.stage_group_id,
417
- },
418
- loggedInUser,
419
- );
420
- }
421
-
422
- return 'Task moved successfully';
423
- }
424
-
425
- async deleteEntity(
426
- entity_type: string,
427
- taskId: number,
428
- loggedInUser: UserData,
429
- ): Promise<any> {
430
- // Fetch the task before deleting
431
- const task: any = await super.getEntityData(
432
- entity_type,
433
- taskId,
434
- loggedInUser,
435
- );
436
-
437
- if (!task) {
438
- throw new Error('Task not found');
439
- }
440
-
441
- // Check if the task is system-generated
442
- if (task.is_system) {
443
- throw new Error('Cannot delete system-generated tasks');
444
- }
445
-
446
- // Perform the deletion
447
- await super.deleteEntity(entity_type, taskId, loggedInUser);
448
-
449
- // Try to log the delete activity
450
- try {
451
- const logData = {
452
- mapped_entity_id: task.mapped_entity_id,
453
- mapped_entity_type: task.mapped_entity_type,
454
- title: `Task deleted`,
455
- description: `${task.name} was deleted`,
456
- category: ACTIVITY_CATEGORIES.TASK,
457
- action: 'delete',
458
- appcode: loggedInUser.appcode,
459
- };
460
-
461
- await this.activityLogService.logActivity(logData, loggedInUser);
462
- } catch (error) {
463
- console.error(
464
- 'Failed to log activity for task deletion:',
465
- error?.message || error,
466
- );
467
- }
468
-
469
- return { message: 'Task deleted successfully' };
470
- }
471
-
472
- async createSystemNote(
473
- entity: {
474
- reason_code: string | number;
475
- remark: string;
476
- mapped_entity_id: number;
477
- stage_id: number;
478
- action_id: number;
479
- stage_group_id?: number;
480
- },
481
- loggedInUser: any,
482
- ) {
483
- if (!entity || !entity.mapped_entity_id || !entity.reason_code) return null;
484
-
485
- const [reason] = await this.dataSource.query(
486
- `SELECT name FROM cr_list_master_items WHERE id = ? AND organization_id = ?`,
487
- [entity.reason_code, loggedInUser.organization_id],
488
- );
489
-
490
- const notePayload = {
491
- note_title: reason ? reason.name : entity.reason_code,
492
- note: entity.remark,
493
- is_system: true,
494
- mapped_entity_type: 'LEAD',
495
- entity_type: 'NOTE',
496
- mapped_entity_id: entity.mapped_entity_id,
497
- stage_id: entity.stage_id,
498
- action_id: entity.action_id,
499
- stage_group_id: entity.stage_group_id,
500
- } as any;
501
-
502
- return await super.createEntity(notePayload, loggedInUser);
503
- }
504
- }
1
+ import { Inject, Injectable } from '@nestjs/common';
2
+ import { EntityServiceImpl } from 'src/module/meta/service/entity-service-impl.service';
3
+ import { UserData } from 'src/module/user/entity/user.entity';
4
+ import { TaskRepository } from '../repository/task.repository';
5
+ import { ActionDataService } from './action-data.service';
6
+ import { DataSource, EntityManager } from 'typeorm';
7
+ import { BaseEntity } from 'src/module/meta/entity/base-entity.entity';
8
+ import { ActivityLogService } from './activity-log.service';
9
+ import { ACTIVITY_CATEGORIES } from '../repository/activity-log.repository';
10
+ import { MediaDataService } from 'src/module/meta/service/media-data.service';
11
+ import { ActionHandler } from 'src/module/workflow-automation/interface/action.decorator';
12
+
13
+ @Injectable()
14
+ @ActionHandler('add_task')
15
+ export class TaskService extends EntityServiceImpl {
16
+ constructor(
17
+ private readonly taskRepository: TaskRepository,
18
+ private readonly actionDataService: ActionDataService,
19
+ private readonly dataSource: DataSource,
20
+ @Inject('ActivityLogService')
21
+ private readonly activityLogService: ActivityLogService,
22
+ private readonly mediaDataService: MediaDataService,
23
+ ) {
24
+ super();
25
+ }
26
+ name: string = 'add_task';
27
+
28
+ async execute(payload: any): Promise<any> {
29
+ const { entity, user, config } = payload;
30
+
31
+ let toValue: string | null = null;
32
+
33
+ // 2. Get current stage_id from cr_wf_stage_movement_data
34
+ const stageRow = await this.dataSource.query(
35
+ `SELECT stage_id
36
+ FROM cr_wf_stage_movement_data
37
+ WHERE mapped_entity_id = ?
38
+ AND is_current = 'Y'
39
+ LIMIT 1`,
40
+ [entity.id],
41
+ );
42
+
43
+ const stageId = stageRow.length > 0 ? stageRow[0].stage_id : null;
44
+
45
+ if (!stageId) {
46
+ throw new Error(
47
+ `No current stage found in cr_wf_stage_movement_data for entity_id=${entity.id}`,
48
+ );
49
+ }
50
+
51
+ // 3. Build entityData
52
+ const entityData = {
53
+ ...config,
54
+ mapped_entity_id: entity.id,
55
+ mapped_entity_type: entity.entity_type,
56
+ task_owner: config.task_owner,
57
+ stage_id: stageId,
58
+ status: config.status,
59
+ due_date: config.due_date,
60
+ due_time: config.due_time,
61
+ reminder: config.reminder,
62
+ description: config.description,
63
+ is_mandatory: config.is_mandatory,
64
+ };
65
+
66
+ return await this.createEntity(entityData, user);
67
+ }
68
+
69
+ async createEntity(
70
+ entityData: any,
71
+ loggedInUser: any,
72
+ manager?: EntityManager | null,
73
+ appcode?: string,
74
+ ): Promise<any> {
75
+ if (entityData && typeof entityData['is_mandatory'] === 'string') {
76
+ entityData['is_mandatory'] = entityData['is_mandatory'] === '1';
77
+ }
78
+ const createdEntity = await super.createEntity(
79
+ entityData,
80
+ loggedInUser,
81
+ manager,
82
+ appcode,
83
+ );
84
+
85
+ try {
86
+ const logData = {
87
+ mapped_entity_id: createdEntity.mapped_entity_id,
88
+ mapped_entity_type: createdEntity.mapped_entity_type,
89
+ title: `Task added`,
90
+ description: `A new task ${createdEntity.name} was added`,
91
+ category: ACTIVITY_CATEGORIES.TASK,
92
+ action: 'add',
93
+ appcode: loggedInUser.appcode,
94
+ };
95
+
96
+ await this.activityLogService.logActivity(logData, loggedInUser);
97
+ } catch (error) {
98
+ console.error(
99
+ 'Failed to log activity for meeting:',
100
+ error?.message || error,
101
+ );
102
+ // Logging should not block main flow
103
+ }
104
+
105
+ let relationData = await this.dataSource.query(
106
+ `SELECT * FROM cr_entity_relation WHERE source_entity_type = ? AND target_entity_type = ?`,
107
+ [createdEntity.mapped_entity_type, createdEntity.entity_type],
108
+ );
109
+
110
+ if (relationData) {
111
+ await this.dataSource.query(
112
+ `INSERT INTO cr_entity_relation_data (organization_id, source_entity_id, source_entity_type, target_entity_id, target_entity_type, relation_type) VALUES (?, ?, ?, ?, ? , ?)`,
113
+ [
114
+ loggedInUser.organization_id,
115
+ createdEntity.mapped_entity_id,
116
+ createdEntity.mapped_entity_type,
117
+ createdEntity.id,
118
+ createdEntity.entity_type,
119
+ relationData[0]?.relation_type,
120
+ ],
121
+ );
122
+ }
123
+
124
+ return createdEntity;
125
+ }
126
+
127
+ async updateEntity(
128
+ entityData,
129
+ loggedInUser: UserData,
130
+ appcode?: string,
131
+ ): Promise<any> {
132
+ const taskStatusQuery = `
133
+ SELECT name
134
+ FROM cr_list_master_items
135
+ WHERE id = ?
136
+ AND organization_id = ?
137
+ AND listtype = 'TKST'
138
+ LIMIT 1;
139
+ `;
140
+
141
+ const statusRows = await this.dataSource.query(taskStatusQuery, [
142
+ entityData.status,
143
+ loggedInUser.organization_id,
144
+ ]);
145
+
146
+ const isCompletedStatus =
147
+ statusRows.length > 0 &&
148
+ statusRows[0].name?.toLowerCase() === 'completed';
149
+
150
+ // Sync flags based on status
151
+ entityData.is_completed = isCompletedStatus;
152
+ entityData.is_done = isCompletedStatus;
153
+
154
+ const isMandatory =
155
+ String(entityData.is_mandatory).toLowerCase() === 'true' ||
156
+ entityData.is_mandatory === true ||
157
+ entityData.is_mandatory === 1 ||
158
+ entityData.is_mandatory === '1';
159
+
160
+ const updatedEntity = await super.updateEntity(
161
+ {
162
+ ...entityData,
163
+ is_mandatory: isMandatory,
164
+ },
165
+ loggedInUser,
166
+ appcode,
167
+ );
168
+
169
+ // Convert boolean back to "1" / "0" for response
170
+ if (updatedEntity && typeof updatedEntity['is_mandatory'] === 'boolean') {
171
+ updatedEntity['is_mandatory'] = updatedEntity['is_mandatory'] ? '1' : '0';
172
+ }
173
+
174
+ try {
175
+ // Always log edit
176
+ const editLogData = {
177
+ mapped_entity_id: updatedEntity.mapped_entity_id,
178
+ mapped_entity_type: updatedEntity.mapped_entity_type,
179
+ title: `Task edited`,
180
+ description: `${updatedEntity.code} was edited`,
181
+ category: ACTIVITY_CATEGORIES.TASK,
182
+ action: 'edit',
183
+ appcode: loggedInUser.appcode,
184
+ };
185
+
186
+ await this.activityLogService.logActivity(editLogData, loggedInUser);
187
+
188
+ if (isCompletedStatus) {
189
+ const completedLogData = {
190
+ mapped_entity_id: updatedEntity.mapped_entity_id,
191
+ mapped_entity_type: updatedEntity.mapped_entity_type,
192
+ title: `Task completed`,
193
+ description: `${updatedEntity.code} was marked as completed`,
194
+ category: ACTIVITY_CATEGORIES.TASK,
195
+ action: 'completed',
196
+ appcode: loggedInUser.appcode,
197
+ };
198
+
199
+ await this.activityLogService.logActivity(
200
+ completedLogData,
201
+ loggedInUser,
202
+ );
203
+ }
204
+ } catch (error) {
205
+ console.error(
206
+ 'Failed to log activity for task:',
207
+ error?.message || error,
208
+ );
209
+ // Don't block main flow
210
+ }
211
+
212
+ return updatedEntity;
213
+ }
214
+
215
+ async getAllTaskByUserIdandStageId(
216
+ loggedInUser: UserData,
217
+ data,
218
+ ): Promise<any> {
219
+ const taskData = await this.taskRepository.getAllTaskByUserIdAndStageId({
220
+ user_id: data.user_id,
221
+ stage_id: data.stage_id,
222
+ mapped_entity_type: data.mapped_entity_type,
223
+ mapped_entity_id: data.mapped_entity_id,
224
+ });
225
+
226
+ const grouped: { mandatory: any[]; non_mandatory: any[] } = {
227
+ mandatory: [],
228
+ non_mandatory: [],
229
+ };
230
+
231
+ for (const task of taskData) {
232
+ if (task && task.is_mandatory) {
233
+ grouped.mandatory.push(task);
234
+ } else {
235
+ grouped.non_mandatory.push(task);
236
+ }
237
+ }
238
+
239
+ return grouped;
240
+ }
241
+
242
+ async getAllTask(
243
+ loggedInUser: UserData,
244
+ data: {
245
+ mapped_entity_type: string;
246
+ mapped_entity_id: number;
247
+ status?: string;
248
+ mandatory?: boolean;
249
+ overdue?: boolean;
250
+ },
251
+ ): Promise<any[]> {
252
+ const { mapped_entity_type, mapped_entity_id, status, mandatory, overdue } =
253
+ data;
254
+
255
+ // Build dynamic WHERE clauses
256
+ const whereClauses = [`t.mapped_entity_type = ?`, `t.mapped_entity_id = ?`];
257
+ const params: any[] = [mapped_entity_type, mapped_entity_id];
258
+
259
+ if (status) {
260
+ whereClauses.push(`t.status = ?`);
261
+ params.push(status);
262
+ }
263
+ if (mandatory) {
264
+ whereClauses.push(`t.is_mandatory = ?`);
265
+ params.push(mandatory ? 1 : 0);
266
+ }
267
+ if (overdue) {
268
+ whereClauses.push(
269
+ `(t.due_date < CURDATE() OR (t.due_date = CURDATE() AND t.due_time < CURTIME()))`,
270
+ );
271
+ // exclude tasks that are already completed
272
+ whereClauses.push(`t.is_done = ?`);
273
+ params.push(0); // Only include tasks that are not done
274
+ }
275
+
276
+ const sql = `
277
+ SELECT
278
+ t.*,
279
+ sg.name AS stage_group_name,
280
+ s.name AS stage_name,
281
+ a.name AS action_name,
282
+ u.name AS created_by_name,
283
+ u2.name AS task_owner_name,
284
+ u2.profile_image AS task_owner_profile
285
+ FROM cr_wf_task_data t
286
+ LEFT JOIN cr_wf_stage s ON t.stage_id = s.id
287
+ LEFT JOIN cr_wf_stage_group sg ON s.stage_group_id = sg.id
288
+ LEFT JOIN cr_wf_action a ON t.action_id = a.id
289
+ LEFT JOIN sso_user u ON t.created_by = u.id
290
+ LEFT JOIN eth_user_profile u2 ON t.task_owner = u2.parent_id
291
+ WHERE ${whereClauses.join(' AND ')}
292
+ ORDER BY t.created_date DESC
293
+ `;
294
+
295
+ const taskData = await this.dataSource.query(sql, params);
296
+
297
+ if (taskData.length === 0) {
298
+ return [];
299
+ }
300
+
301
+ // Fetch all TKST statuses in a single query
302
+ const taskStatusQuery = `
303
+ SELECT id, name
304
+ FROM cr_list_master_items
305
+ WHERE organization_id = ?
306
+ AND listtype = 'TKST'
307
+ `;
308
+ const taskAllStatus = await this.dataSource.query(taskStatusQuery, [
309
+ loggedInUser.organization_id,
310
+ ]);
311
+
312
+ // Build a hash map { id → name }
313
+ const statusMap = new Map(
314
+ taskAllStatus.map((row) => [String(row.id), row.name]),
315
+ );
316
+
317
+ // Assign task_status using the map
318
+
319
+ const mediaCache = new Map<number, any>();
320
+
321
+ for (const task of taskData) {
322
+ // Map status name
323
+ task.task_status = task.status
324
+ ? statusMap.get(String(task.status)) || null
325
+ : null;
326
+
327
+ // Fix action_name for generic tasks
328
+ task.action_name =
329
+ task.action_id === '0' || task.action_id === 0
330
+ ? 'Generic'
331
+ : task.action_name;
332
+
333
+ // Profile media (with caching like notes)
334
+ if (task.task_owner_profile) {
335
+ if (!mediaCache.has(task.task_owner_profile)) {
336
+ const url = await this.mediaDataService.getMediaDownloadUrl(
337
+ task.task_owner_profile,
338
+ loggedInUser,
339
+ );
340
+ mediaCache.set(task.task_owner_profile, url);
341
+ }
342
+ task.task_owner_profile = mediaCache.get(task.task_owner_profile);
343
+ } else {
344
+ task.task_owner_profile = null;
345
+ }
346
+ }
347
+
348
+ // Normalize is_mandatory to '0'/'1' as string
349
+ return taskData.map((task) => ({
350
+ ...task,
351
+ is_mandatory: task.is_mandatory ? '1' : '0',
352
+ }));
353
+ }
354
+
355
+ async getEntityData(entityType: string, id: number, loggedInUser: any) {
356
+ const taskData = await super.getEntityData(entityType, id, loggedInUser);
357
+
358
+ return taskData;
359
+ }
360
+
361
+ async saveActionData(
362
+ action: any,
363
+ loggedInUser: UserData,
364
+ mapped_entity_id: number,
365
+ mapped_entity_type: string,
366
+ ): Promise<any> {
367
+ await this.taskRepository.saveActionDataInTask(
368
+ action,
369
+ loggedInUser,
370
+ mapped_entity_id,
371
+ mapped_entity_type,
372
+ );
373
+ }
374
+
375
+ async moveTask(
376
+ loggedInUser: UserData,
377
+ body: {
378
+ mapped_entity_type: string;
379
+ mapped_entity_id: number;
380
+ stage_id: number;
381
+ action_id: number;
382
+ reason_code?: string | number;
383
+ remark?: string;
384
+ stage_group_id?: number;
385
+ },
386
+ ): Promise<any> {
387
+ // Logic to move task based on the provided body parameters
388
+ // This could involve updating the task's stage, action, etc.
389
+
390
+ // update task status
391
+ this.taskRepository.updateTaskStatus(
392
+ loggedInUser,
393
+ body.mapped_entity_type,
394
+ body.mapped_entity_id,
395
+ body.stage_id,
396
+ body.action_id,
397
+ );
398
+
399
+ // update action status
400
+ await this.actionDataService.updateActionStatus(
401
+ loggedInUser,
402
+ body.mapped_entity_type,
403
+ body.mapped_entity_id,
404
+ body.stage_id,
405
+ body.action_id,
406
+ );
407
+
408
+ if (body.reason_code || body.remark) {
409
+ await this.createSystemNote(
410
+ {
411
+ reason_code: body.reason_code!,
412
+ remark: body.remark || '',
413
+ mapped_entity_id: body.mapped_entity_id,
414
+ stage_id: body.stage_id,
415
+ action_id: body.action_id,
416
+ stage_group_id: body.stage_group_id,
417
+ },
418
+ loggedInUser,
419
+ );
420
+ }
421
+
422
+ return 'Task moved successfully';
423
+ }
424
+
425
+ async deleteEntity(
426
+ entity_type: string,
427
+ taskId: number,
428
+ loggedInUser: UserData,
429
+ ): Promise<any> {
430
+ // Fetch the task before deleting
431
+ const task: any = await super.getEntityData(
432
+ entity_type,
433
+ taskId,
434
+ loggedInUser,
435
+ );
436
+
437
+ if (!task) {
438
+ throw new Error('Task not found');
439
+ }
440
+
441
+ // Check if the task is system-generated
442
+ if (task.is_system) {
443
+ throw new Error('Cannot delete system-generated tasks');
444
+ }
445
+
446
+ // Perform the deletion
447
+ await super.deleteEntity(entity_type, taskId, loggedInUser);
448
+
449
+ // Try to log the delete activity
450
+ try {
451
+ const logData = {
452
+ mapped_entity_id: task.mapped_entity_id,
453
+ mapped_entity_type: task.mapped_entity_type,
454
+ title: `Task deleted`,
455
+ description: `${task.name} was deleted`,
456
+ category: ACTIVITY_CATEGORIES.TASK,
457
+ action: 'delete',
458
+ appcode: loggedInUser.appcode,
459
+ };
460
+
461
+ await this.activityLogService.logActivity(logData, loggedInUser);
462
+ } catch (error) {
463
+ console.error(
464
+ 'Failed to log activity for task deletion:',
465
+ error?.message || error,
466
+ );
467
+ }
468
+
469
+ return { message: 'Task deleted successfully' };
470
+ }
471
+
472
+ async createSystemNote(
473
+ entity: {
474
+ reason_code: string | number;
475
+ remark: string;
476
+ mapped_entity_id: number;
477
+ stage_id: number;
478
+ action_id: number;
479
+ stage_group_id?: number;
480
+ },
481
+ loggedInUser: any,
482
+ ) {
483
+ if (!entity || !entity.mapped_entity_id || !entity.reason_code) return null;
484
+
485
+ const [reason] = await this.dataSource.query(
486
+ `SELECT name FROM cr_list_master_items WHERE id = ? AND organization_id = ?`,
487
+ [entity.reason_code, loggedInUser.organization_id],
488
+ );
489
+
490
+ const notePayload = {
491
+ note_title: reason ? reason.name : entity.reason_code,
492
+ note: entity.remark,
493
+ is_system: true,
494
+ mapped_entity_type: 'LEAD',
495
+ entity_type: 'NOTE',
496
+ mapped_entity_id: entity.mapped_entity_id,
497
+ stage_id: entity.stage_id,
498
+ action_id: entity.action_id,
499
+ stage_group_id: entity.stage_group_id,
500
+ } as any;
501
+
502
+ return await super.createEntity(notePayload, loggedInUser);
503
+ }
504
+ }