rez_core 5.0.156 → 5.0.157

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