rez_core 5.0.169 → 5.0.172

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