rez_core 3.1.178 → 3.1.180

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 (387) hide show
  1. package/.claude/settings.local.json +26 -0
  2. package/.idea/250218_nodejs_core.iml +9 -0
  3. package/.idea/codeStyles/Project.xml +59 -0
  4. package/.idea/codeStyles/codeStyleConfig.xml +5 -0
  5. package/.idea/copilot.data.migration.agent.xml +6 -0
  6. package/.idea/copilot.data.migration.ask.xml +6 -0
  7. package/.idea/copilot.data.migration.ask2agent.xml +6 -0
  8. package/.idea/copilot.data.migration.edit.xml +6 -0
  9. package/.idea/inspectionProfiles/Project_Default.xml +6 -0
  10. package/.idea/misc.xml +6 -0
  11. package/.idea/modules.xml +8 -0
  12. package/.idea/prettier.xml +6 -0
  13. package/.idea/vcs.xml +6 -0
  14. package/.prettierrc +3 -3
  15. package/README.md +99 -99
  16. package/dist/module/auth/guards/role.guard.js +3 -3
  17. package/dist/module/auth/services/auth.service.js +2 -2
  18. package/dist/module/filter/repository/saved-filter.repository.js +4 -4
  19. package/dist/module/filter/service/filter-evaluator.service.js +2 -2
  20. package/dist/module/filter/service/filter.service.js +7 -7
  21. package/dist/module/integration/controller/wrapper.controller.js +0 -2
  22. package/dist/module/integration/controller/wrapper.controller.js.map +1 -1
  23. package/dist/module/integration/examples/usage.example.js +9 -9
  24. package/dist/module/integration/service/integration.service.js +1 -1
  25. package/dist/module/integration/service/wrapper.service.js +27 -27
  26. package/dist/module/integration/service/wrapper.service.js.map +1 -1
  27. package/dist/module/listmaster/service/list-master-item.service.js +2 -2
  28. package/dist/module/listmaster/service/list-master.service.js +2 -2
  29. package/dist/module/mapper/service/field-mapper.service.js +4 -4
  30. package/dist/module/mapper/service/mapper.service.js +2 -2
  31. package/dist/module/meta/service/entity-dynamic.service.js +18 -18
  32. package/dist/module/meta/service/entity-list.service.js +3 -3
  33. package/dist/module/meta/service/entity-master.service.js +3 -3
  34. package/dist/module/meta/service/entity-relation.service.js +11 -11
  35. package/dist/module/meta/service/entity-service-impl.service.js +3 -3
  36. package/dist/module/meta/service/resolver.service.js +3 -3
  37. package/dist/module/module/repository/menu.repository.js +12 -12
  38. package/dist/module/notification/service/notification.service.js +12 -12
  39. package/dist/module/user/controller/login.controller.js +18 -18
  40. package/dist/module/user/service/role.service.js +4 -4
  41. package/dist/module/user/service/user-session.service.js +2 -2
  42. package/dist/module/workflow/repository/action.repository.js +16 -16
  43. package/dist/module/workflow/repository/comm-template.repository.js +6 -6
  44. package/dist/module/workflow/repository/form-master.repository.js +2 -2
  45. package/dist/module/workflow/repository/stage-group.repository.js +23 -23
  46. package/dist/module/workflow/repository/stage-movement.repository.js +11 -11
  47. package/dist/module/workflow/repository/stage.repository.js +8 -8
  48. package/dist/module/workflow/service/action-template-mapping.service.js +10 -10
  49. package/dist/module/workflow/service/action.service.js +7 -7
  50. package/dist/module/workflow/service/entity-modification.service.js +6 -6
  51. package/dist/module/workflow/service/stage-group.service.js +5 -5
  52. package/dist/module/workflow/service/stage.service.js +2 -2
  53. package/dist/module/workflow/service/task.service.js +54 -33
  54. package/dist/module/workflow/service/task.service.js.map +1 -1
  55. package/dist/module/workflow/service/workflow-list-master.service.js +15 -15
  56. package/dist/module/workflow/service/workflow-meta.service.js +50 -50
  57. package/dist/module/workflow/service/workflow.service.js +2 -2
  58. package/dist/tsconfig.build.tsbuildinfo +1 -1
  59. package/dist/utils/service/reflection-helper.service.js +2 -2
  60. package/docs/modules/event-driven-integration-design.md +91 -91
  61. package/docs/modules/integration.md +250 -250
  62. package/eslint.config.mjs +34 -34
  63. package/nest-cli.json +14 -14
  64. package/package.json +118 -118
  65. package/server.log +850 -0
  66. package/src/app.controller.ts +12 -12
  67. package/src/app.module.ts +49 -49
  68. package/src/app.service.ts +8 -8
  69. package/src/config/config.module.ts +18 -18
  70. package/src/config/database.config.ts +23 -23
  71. package/src/constant/global.constant.ts +67 -67
  72. package/src/core.module.ts +81 -81
  73. package/src/decorators/roles.decorator.ts +7 -7
  74. package/src/dtos/response.dto.ts +6 -6
  75. package/src/dtos/response.ts +5 -5
  76. package/src/index.ts +1 -1
  77. package/src/module/auth/auth.module.ts +49 -49
  78. package/src/module/auth/controller/auth.controller.ts +28 -28
  79. package/src/module/auth/guards/google-auth.guard.ts +9 -9
  80. package/src/module/auth/guards/jwt.guard.ts +22 -22
  81. package/src/module/auth/guards/role.guard.ts +68 -68
  82. package/src/module/auth/services/auth.service.ts +50 -50
  83. package/src/module/auth/services/jwt.service.ts +11 -11
  84. package/src/module/auth/strategies/google.strategy.ts +54 -54
  85. package/src/module/auth/strategies/jwt.strategy.ts +58 -58
  86. package/src/module/auth/strategies/local.strategy.ts +13 -13
  87. package/src/module/dashboard/controller/dashboard.controller.ts +36 -36
  88. package/src/module/dashboard/dashboard.module.ts +21 -21
  89. package/src/module/dashboard/entity/dashboard_page_data.entity.ts +27 -27
  90. package/src/module/dashboard/entity/widget_master.entity.ts +18 -18
  91. package/src/module/dashboard/repository/dashboard.repository.ts +42 -42
  92. package/src/module/dashboard/service/dashboard.service.ts +73 -73
  93. package/src/module/dev/dev.module.ts +12 -12
  94. package/src/module/dev/service/dev.service.ts +7 -7
  95. package/src/module/enterprise/controller/organization.controller.ts +36 -36
  96. package/src/module/enterprise/enterprise.module.ts +30 -30
  97. package/src/module/enterprise/entity/enterprise.entity.ts +37 -37
  98. package/src/module/enterprise/entity/organization-app-mapping.entity.ts +13 -13
  99. package/src/module/enterprise/entity/organization.entity.ts +92 -92
  100. package/src/module/enterprise/repository/enterprise.repository.ts +31 -31
  101. package/src/module/enterprise/repository/organization.repository.ts +26 -26
  102. package/src/module/enterprise/repository/school.repository.ts +281 -281
  103. package/src/module/enterprise/service/brand.service.ts +5 -5
  104. package/src/module/enterprise/service/enterprise.service.ts +16 -16
  105. package/src/module/enterprise/service/organization-app-mapping.service.ts +4 -4
  106. package/src/module/enterprise/service/organization.service.ts +145 -145
  107. package/src/module/filter/controller/filter.controller.ts +84 -84
  108. package/src/module/filter/dto/filter-request.dto.ts +38 -38
  109. package/src/module/filter/entity/saved-filter-detail.entity.ts +41 -41
  110. package/src/module/filter/entity/saved-filter-master.entity.ts +23 -23
  111. package/src/module/filter/filter.module.ts +31 -31
  112. package/src/module/filter/repository/saved-filter.repository.ts +168 -168
  113. package/src/module/filter/service/filter-evaluator.service.ts +86 -86
  114. package/src/module/filter/service/filter.service.ts +841 -841
  115. package/src/module/filter/service/saved-filter.service.ts +170 -170
  116. package/src/module/ics/controller/ics.controller.ts +21 -21
  117. package/src/module/ics/dto/ics.dto.ts +55 -55
  118. package/src/module/ics/ics.module.ts +13 -13
  119. package/src/module/ics/service/ics.service.ts +57 -57
  120. package/src/module/integration/controller/calender-event.controller.ts +31 -31
  121. package/src/module/integration/controller/integration.controller.ts +662 -662
  122. package/src/module/integration/controller/wrapper.controller.ts +37 -37
  123. package/src/module/integration/dto/create-config.dto.ts +526 -526
  124. package/src/module/integration/entity/integration-config.entity.ts +112 -112
  125. package/src/module/integration/entity/integration-entity-mapper.entity.ts +14 -14
  126. package/src/module/integration/entity/integration-source.entity.ts +17 -17
  127. package/src/module/integration/entity/user-integration.entity.ts +71 -71
  128. package/src/module/integration/examples/usage.example.ts +338 -338
  129. package/src/module/integration/factories/base.factory.ts +7 -7
  130. package/src/module/integration/factories/email.factory.ts +49 -49
  131. package/src/module/integration/factories/integration.factory.ts +121 -121
  132. package/src/module/integration/factories/sms.factory.ts +51 -51
  133. package/src/module/integration/factories/telephone.factory.ts +41 -41
  134. package/src/module/integration/factories/whatsapp.factory.ts +56 -56
  135. package/src/module/integration/integration.module.ts +110 -110
  136. package/src/module/integration/service/calendar-event.service.ts +118 -118
  137. package/src/module/integration/service/integration-entity-mapper.service.ts +17 -17
  138. package/src/module/integration/service/integration-queue.service.ts +229 -229
  139. package/src/module/integration/service/integration.service.ts +2572 -2572
  140. package/src/module/integration/service/oauth.service.ts +224 -224
  141. package/src/module/integration/service/wrapper.service.ts +457 -453
  142. package/src/module/integration/strategies/email/gmail-api.strategy.ts +280 -280
  143. package/src/module/integration/strategies/email/outlook-api.strategy.ts +44 -44
  144. package/src/module/integration/strategies/email/outlook.strategy.ts +64 -64
  145. package/src/module/integration/strategies/email/sendgrid-api.strategy.ts +260 -260
  146. package/src/module/integration/strategies/integration.strategy.ts +97 -97
  147. package/src/module/integration/strategies/sms/gupshup-sms.strategy.ts +146 -146
  148. package/src/module/integration/strategies/sms/msg91-sms.strategy.ts +164 -164
  149. package/src/module/integration/strategies/sms/tubelight-sms.strategy.ts +163 -163
  150. package/src/module/integration/strategies/telephone/ozonetel-voice.strategy.ts +238 -238
  151. package/src/module/integration/strategies/telephone/tubelight-voice.strategy.ts +210 -210
  152. package/src/module/integration/strategies/whatsapp/gupshup-whatsapp.strategy.ts +359 -359
  153. package/src/module/integration/strategies/whatsapp/tubelight-whatsapp.strategy.ts +372 -372
  154. package/src/module/integration/strategies/whatsapp/whatsapp-cloud.strategy.ts +403 -403
  155. package/src/module/integration/strategies/whatsapp/whatsapp.strategy.ts +57 -57
  156. package/src/module/layout/controller/layout.controller.ts +47 -47
  157. package/src/module/layout/entity/header-items.entity.ts +28 -28
  158. package/src/module/layout/entity/header-section.entity.ts +19 -19
  159. package/src/module/layout/layout.module.ts +21 -21
  160. package/src/module/layout/repository/header-items.repository.ts +18 -18
  161. package/src/module/layout/repository/header-section.repository.ts +22 -22
  162. package/src/module/layout/service/header-section.service.ts +25 -25
  163. package/src/module/layout_preference/controller/layout_preference.controller.ts +47 -47
  164. package/src/module/layout_preference/entity/layout_preference.entity.ts +28 -28
  165. package/src/module/layout_preference/layout_preference.module.ts +18 -18
  166. package/src/module/layout_preference/repository/layout_preference.repository.ts +30 -30
  167. package/src/module/layout_preference/service/layout_preference.service.ts +172 -172
  168. package/src/module/lead/controller/lead.controller.ts +30 -30
  169. package/src/module/lead/lead.module.ts +14 -14
  170. package/src/module/lead/repository/lead.repository.ts +41 -41
  171. package/src/module/lead/service/lead.service.ts +54 -54
  172. package/src/module/listmaster/controller/list-master.controller.ts +187 -187
  173. package/src/module/listmaster/entity/list-master-items.entity.ts +41 -41
  174. package/src/module/listmaster/entity/list-master.entity.ts +32 -32
  175. package/src/module/listmaster/listmaster.module.ts +44 -44
  176. package/src/module/listmaster/repository/list-master-items.repository.ts +169 -169
  177. package/src/module/listmaster/repository/list-master.repository.ts +46 -46
  178. package/src/module/listmaster/service/list-master-engine.ts +19 -19
  179. package/src/module/listmaster/service/list-master-extension.interface.ts +4 -4
  180. package/src/module/listmaster/service/list-master-item.service.ts +292 -292
  181. package/src/module/listmaster/service/list-master-registry.ts +15 -15
  182. package/src/module/listmaster/service/list-master.service.ts +424 -424
  183. package/src/module/mapper/controller/field-mapper.controller.ts +69 -69
  184. package/src/module/mapper/controller/mapper.controller.ts +14 -14
  185. package/src/module/mapper/dto/field-mapper.dto.ts +14 -14
  186. package/src/module/mapper/entity/field-lovs.entity.ts +19 -19
  187. package/src/module/mapper/entity/field-mapper.entity.ts +53 -53
  188. package/src/module/mapper/entity/mapper.entity.ts +16 -16
  189. package/src/module/mapper/mapper.module.ts +34 -34
  190. package/src/module/mapper/repository/field-lovs.repository.ts +35 -35
  191. package/src/module/mapper/repository/field-mapper.repository.ts +42 -42
  192. package/src/module/mapper/repository/mapper.repository.ts +15 -15
  193. package/src/module/mapper/service/field-mapper.service.ts +223 -223
  194. package/src/module/mapper/service/mapper.service.ts +72 -72
  195. package/src/module/master/controller/master.controller.ts +74 -74
  196. package/src/module/master/service/master.service.ts +483 -483
  197. package/src/module/meta/controller/app-master.controller.ts +38 -38
  198. package/src/module/meta/controller/attribute-master.controller.ts +66 -66
  199. package/src/module/meta/controller/entity-dynamic.controller.ts +125 -125
  200. package/src/module/meta/controller/entity-master.controller.ts +28 -28
  201. package/src/module/meta/controller/entity-relation.controller.ts +36 -36
  202. package/src/module/meta/controller/entity.controller.ts +385 -385
  203. package/src/module/meta/controller/media.controller.ts +82 -82
  204. package/src/module/meta/controller/meta.controller.ts +96 -96
  205. package/src/module/meta/controller/view-master.controller.ts +86 -86
  206. package/src/module/meta/dto/entity-list-data.dto.ts +6 -6
  207. package/src/module/meta/dto/entity-tab.dto.ts +4 -4
  208. package/src/module/meta/dto/entity-table.dto.ts +9 -9
  209. package/src/module/meta/entity/app-master.entity.ts +34 -34
  210. package/src/module/meta/entity/attribute-master.entity.ts +87 -87
  211. package/src/module/meta/entity/base-entity.entity.ts +75 -75
  212. package/src/module/meta/entity/entity-master.entity.ts +78 -78
  213. package/src/module/meta/entity/entity-relation-data.entity.ts +29 -29
  214. package/src/module/meta/entity/entity-relation.entity.ts +23 -23
  215. package/src/module/meta/entity/entity-table-column.entity.ts +61 -61
  216. package/src/module/meta/entity/entity-table.entity.ts +50 -50
  217. package/src/module/meta/entity/media-data.entity.ts +32 -32
  218. package/src/module/meta/entity/preference.entity.ts +62 -62
  219. package/src/module/meta/entity/view-master.entity.ts +41 -41
  220. package/src/module/meta/entity.module.ts +156 -156
  221. package/src/module/meta/repository/app-master.repository.ts +20 -20
  222. package/src/module/meta/repository/attribute-master.repository.ts +110 -110
  223. package/src/module/meta/repository/entity-master.repository.ts +69 -69
  224. package/src/module/meta/repository/entity-table-column.repository.ts +39 -39
  225. package/src/module/meta/repository/entity-table.repository.ts +53 -53
  226. package/src/module/meta/repository/media-data.repository.ts +50 -50
  227. package/src/module/meta/repository/preference.repository.ts +20 -20
  228. package/src/module/meta/repository/user-app-mapping.repository.ts +28 -28
  229. package/src/module/meta/repository/view-master.repository.ts +42 -42
  230. package/src/module/meta/service/app-master.service.ts +37 -37
  231. package/src/module/meta/service/attribute-master.service.ts +117 -117
  232. package/src/module/meta/service/common.service.ts +9 -9
  233. package/src/module/meta/service/entity-dynamic.service.ts +762 -762
  234. package/src/module/meta/service/entity-list.service.ts +205 -205
  235. package/src/module/meta/service/entity-master.service.ts +164 -164
  236. package/src/module/meta/service/entity-realation-data.service.ts +9 -9
  237. package/src/module/meta/service/entity-relation.service.ts +69 -69
  238. package/src/module/meta/service/entity-service-impl.service.ts +524 -524
  239. package/src/module/meta/service/entity-table-column.service.ts +39 -39
  240. package/src/module/meta/service/entity-table.service.ts +150 -150
  241. package/src/module/meta/service/entity-validation.service.ts +185 -185
  242. package/src/module/meta/service/entity.service.ts +67 -67
  243. package/src/module/meta/service/field-group.service.ts +103 -103
  244. package/src/module/meta/service/media-data.service.ts +149 -149
  245. package/src/module/meta/service/populate-meta.service.ts +173 -173
  246. package/src/module/meta/service/preference.service.ts +16 -16
  247. package/src/module/meta/service/resolver.service.ts +240 -240
  248. package/src/module/meta/service/section-master.service.ts +104 -104
  249. package/src/module/meta/service/update-form-json.service.ts +22 -22
  250. package/src/module/meta/service/user-app-mapping.service.ts +17 -17
  251. package/src/module/meta/service/view-master.service.ts +111 -111
  252. package/src/module/module/controller/menu.controller.ts +15 -15
  253. package/src/module/module/controller/module-access.controller.ts +132 -132
  254. package/src/module/module/entity/menu.entity.ts +43 -43
  255. package/src/module/module/entity/module-access.entity.ts +25 -25
  256. package/src/module/module/entity/module-action.entity.ts +17 -17
  257. package/src/module/module/entity/module.entity.ts +52 -52
  258. package/src/module/module/module.module.ts +42 -42
  259. package/src/module/module/repository/menu.repository.ts +184 -184
  260. package/src/module/module/repository/module-access.repository.ts +331 -331
  261. package/src/module/module/service/menu.service.ts +82 -82
  262. package/src/module/module/service/module-access.service.ts +209 -209
  263. package/src/module/notification/controller/notification.controller.ts +58 -58
  264. package/src/module/notification/controller/otp.controller.ts +117 -117
  265. package/src/module/notification/entity/notification.entity.ts +26 -26
  266. package/src/module/notification/entity/otp.entity.ts +28 -28
  267. package/src/module/notification/firebase-admin.config.ts +22 -22
  268. package/src/module/notification/notification.module.ts +69 -69
  269. package/src/module/notification/repository/otp.repository.ts +27 -27
  270. package/src/module/notification/service/email.service.ts +127 -127
  271. package/src/module/notification/service/notification.service.ts +138 -138
  272. package/src/module/notification/service/otp.service.ts +125 -125
  273. package/src/module/third-party-module/entity/third-party-api-registry.entity.ts +52 -52
  274. package/src/module/third-party-module/repository/third-party-api-registry.repository.ts +20 -20
  275. package/src/module/third-party-module/service/api-registry.service.ts +13 -13
  276. package/src/module/third-party-module/third-party.module.ts +12 -12
  277. package/src/module/user/controller/login.controller.ts +197 -197
  278. package/src/module/user/controller/user.controller.ts +40 -40
  279. package/src/module/user/dto/create-user.dto.ts +62 -62
  280. package/src/module/user/dto/update-user.dto.ts +4 -4
  281. package/src/module/user/entity/role.entity.ts +33 -33
  282. package/src/module/user/entity/user-role-mapping.entity.ts +38 -38
  283. package/src/module/user/entity/user-session.entity.ts +61 -61
  284. package/src/module/user/entity/user.entity.ts +68 -68
  285. package/src/module/user/repository/role.repository.ts +96 -96
  286. package/src/module/user/repository/user-role-mapping.repository.ts +126 -126
  287. package/src/module/user/repository/user.repository.ts +50 -50
  288. package/src/module/user/repository/userSession.repository.ts +33 -33
  289. package/src/module/user/service/login.service.ts +280 -280
  290. package/src/module/user/service/role.service.ts +189 -189
  291. package/src/module/user/service/user-role-mapping.service.ts +98 -98
  292. package/src/module/user/service/user-session.service.ts +168 -168
  293. package/src/module/user/service/user.service.ts +353 -353
  294. package/src/module/user/user.module.ts +65 -65
  295. package/src/module/workflow/controller/action-category.controller.ts +54 -54
  296. package/src/module/workflow/controller/action-resource-mapping.controller.ts +23 -23
  297. package/src/module/workflow/controller/action-template-mapping.controller.ts +35 -35
  298. package/src/module/workflow/controller/action.controller.ts +95 -95
  299. package/src/module/workflow/controller/activity-log.controller.ts +55 -55
  300. package/src/module/workflow/controller/comm-template.controller.ts +34 -34
  301. package/src/module/workflow/controller/entity-modification.controller.ts +35 -35
  302. package/src/module/workflow/controller/form-master.controller.ts +43 -43
  303. package/src/module/workflow/controller/stage-group.controller.ts +48 -48
  304. package/src/module/workflow/controller/stage.controller.ts +50 -50
  305. package/src/module/workflow/controller/task.controller.ts +77 -77
  306. package/src/module/workflow/controller/workflow-list-master.controller.ts +44 -44
  307. package/src/module/workflow/controller/workflow-meta.controller.ts +80 -80
  308. package/src/module/workflow/controller/workflow.controller.ts +67 -67
  309. package/src/module/workflow/entity/action-category.entity.ts +38 -38
  310. package/src/module/workflow/entity/action-data.entity.ts +55 -55
  311. package/src/module/workflow/entity/action-resources-mapping.entity.ts +29 -29
  312. package/src/module/workflow/entity/action-template-mapping.entity.ts +17 -17
  313. package/src/module/workflow/entity/action.entity.ts +50 -50
  314. package/src/module/workflow/entity/activity-log.entity.ts +43 -43
  315. package/src/module/workflow/entity/comm-template.entity.ts +43 -43
  316. package/src/module/workflow/entity/entity-modification.entity.ts +38 -38
  317. package/src/module/workflow/entity/form.entity.ts +25 -25
  318. package/src/module/workflow/entity/stage-action-mapping.entity.ts +17 -17
  319. package/src/module/workflow/entity/stage-group.entity.ts +23 -23
  320. package/src/module/workflow/entity/stage-movement-data.entity.ts +38 -38
  321. package/src/module/workflow/entity/stage.entity.ts +20 -20
  322. package/src/module/workflow/entity/task-data.entity.ts +88 -88
  323. package/src/module/workflow/entity/template-attach-mapper.entity.ts +30 -30
  324. package/src/module/workflow/entity/workflow-data.entity.ts +11 -11
  325. package/src/module/workflow/entity/workflow-level-mapping.entity.ts +18 -18
  326. package/src/module/workflow/entity/workflow.entity.ts +20 -20
  327. package/src/module/workflow/repository/action-category.repository.ts +79 -79
  328. package/src/module/workflow/repository/action-data.repository.ts +219 -219
  329. package/src/module/workflow/repository/action.repository.ts +277 -277
  330. package/src/module/workflow/repository/activity-log.repository.ts +121 -121
  331. package/src/module/workflow/repository/comm-template.repository.ts +142 -142
  332. package/src/module/workflow/repository/form-master.repository.ts +59 -59
  333. package/src/module/workflow/repository/stage-group.repository.ts +176 -176
  334. package/src/module/workflow/repository/stage-movement.repository.ts +227 -227
  335. package/src/module/workflow/repository/stage.repository.ts +172 -172
  336. package/src/module/workflow/repository/task.repository.ts +117 -117
  337. package/src/module/workflow/repository/workflow.repository.ts +42 -42
  338. package/src/module/workflow/service/action-category.service.ts +33 -33
  339. package/src/module/workflow/service/action-data.service.ts +62 -62
  340. package/src/module/workflow/service/action-resources-mapping.service.ts +10 -10
  341. package/src/module/workflow/service/action-template-mapping.service.ts +55 -55
  342. package/src/module/workflow/service/action.service.ts +263 -263
  343. package/src/module/workflow/service/activity-log.service.ts +107 -107
  344. package/src/module/workflow/service/comm-template.service.ts +121 -121
  345. package/src/module/workflow/service/entity-modification.service.ts +67 -67
  346. package/src/module/workflow/service/form-master.service.ts +35 -35
  347. package/src/module/workflow/service/populate-workflow.service.ts +303 -303
  348. package/src/module/workflow/service/stage-action-mapping.service.ts +5 -5
  349. package/src/module/workflow/service/stage-group.service.ts +300 -300
  350. package/src/module/workflow/service/stage.service.ts +199 -199
  351. package/src/module/workflow/service/task.service.ts +531 -504
  352. package/src/module/workflow/service/workflow-list-master.service.ts +60 -60
  353. package/src/module/workflow/service/workflow-meta.service.ts +581 -581
  354. package/src/module/workflow/service/workflow.service.ts +205 -205
  355. package/src/module/workflow/workflow.module.ts +172 -172
  356. package/src/module/workflow-automation/controller/workflow-automation.controller.ts +21 -21
  357. package/src/module/workflow-automation/entity/workflow-automation-action.entity.ts +26 -26
  358. package/src/module/workflow-automation/entity/workflow-automation.entity.ts +35 -35
  359. package/src/module/workflow-automation/interface/action.decorator.ts +7 -7
  360. package/src/module/workflow-automation/interface/action.interface.ts +5 -5
  361. package/src/module/workflow-automation/service/action-registery.service.ts +35 -35
  362. package/src/module/workflow-automation/service/workflow-automation-engine.service.ts +214 -214
  363. package/src/module/workflow-automation/service/workflow-automation.service.ts +345 -345
  364. package/src/module/workflow-automation/workflow-automation.module.ts +34 -34
  365. package/src/resources/dev.properties.yaml +30 -30
  366. package/src/resources/local.properties.yaml +27 -27
  367. package/src/resources/properties.module.ts +12 -12
  368. package/src/resources/properties.yaml.ts +11 -11
  369. package/src/resources/uat.properties.yaml +15 -15
  370. package/src/utils/dto/excel-data.dto.ts +14 -14
  371. package/src/utils/dto/excelsheet-data.dto.ts +5 -5
  372. package/src/utils/service/base64util.service.ts +18 -18
  373. package/src/utils/service/clockIDGenUtil.service.ts +21 -21
  374. package/src/utils/service/codeGenerator.service.ts +22 -22
  375. package/src/utils/service/dateUtil.service.ts +17 -17
  376. package/src/utils/service/encryptUtil.service.ts +97 -97
  377. package/src/utils/service/excel-helper.service.ts +72 -72
  378. package/src/utils/service/excelUtil.service.ts +15 -15
  379. package/src/utils/service/file-util.service.ts +11 -11
  380. package/src/utils/service/json-util.service.ts +23 -23
  381. package/src/utils/service/loggingUtil.service.ts +34 -34
  382. package/src/utils/service/reflection-helper.service.ts +62 -62
  383. package/src/utils/service/wbsCodeGen.service.ts +8 -8
  384. package/src/utils/utils.module.ts +25 -25
  385. package/tsconfig.build.json +4 -4
  386. package/tsconfig.json +24 -24
  387. package/.vscode/extensions.json +0 -5
@@ -1,424 +1,424 @@
1
- import {
2
- BadRequestException,
3
- forwardRef,
4
- Inject,
5
- Injectable,
6
- NotFoundException,
7
- } from '@nestjs/common';
8
- import { ListMasterItemsRepository } from '../repository/list-master-items.repository';
9
- import { ListMasterRepository } from '../repository/list-master.repository';
10
- import { ApiRegistryService } from '../../third-party-module/service/api-registry.service';
11
- import { firstValueFrom } from 'rxjs';
12
- import { HttpService } from '@nestjs/axios';
13
- import { EntityManager } from 'typeorm';
14
- import { EntityMasterService } from 'src/module/meta/service/entity-master.service';
15
- import { UserData } from 'src/module/user/entity/user.entity';
16
- import { EntityServiceImpl } from 'src/module/meta/service/entity-service-impl.service';
17
- import { STATUS_ACTIVE, STATUS_INACTIVE } from 'src/constant/global.constant';
18
- import { ListMasterExtension } from './list-master-extension.interface';
19
- import { ListMasterEngine } from './list-master-engine';
20
- import { Action } from '../../workflow-automation/interface/action.interface';
21
- import axios from 'axios';
22
- import { ConfigService } from '@nestjs/config';
23
-
24
- @Injectable()
25
- export class ListMasterService {
26
- constructor(
27
- private readonly entityManager: EntityManager,
28
- @Inject(forwardRef(() => EntityServiceImpl))
29
- private readonly entityServiceImpl: EntityServiceImpl,
30
- @Inject(forwardRef(() => EntityMasterService))
31
- private readonly entityMasterService: EntityMasterService,
32
- private readonly listMasterRepo: ListMasterRepository,
33
- private readonly listItemsRepo: ListMasterItemsRepository,
34
- private readonly apiRegistryService: ApiRegistryService,
35
- private readonly httpService: HttpService,
36
- private readonly listMasterEngine: ListMasterEngine,
37
- private readonly configService: ConfigService,
38
- ) {}
39
-
40
- private readonly skipLevelFilterEntities = ['BRN'];
41
- private readonly actions = new Map<string, Action>();
42
-
43
- registerAction(actionName: string, actionInstance: Action) {
44
- this.actions.set(actionName, actionInstance);
45
- console.log(
46
- `⚙️ [WorkflowAutomationEngine] Registered action: ${actionName}`,
47
- );
48
- }
49
-
50
- async getResolvedListCode(
51
- code: string,
52
- organization_id: number,
53
- ): Promise<any> {
54
- if (!code) return code;
55
-
56
- // Check if it's a valid list type
57
- const listMaster = await this.listItemsRepo.findItemByCode(
58
- code,
59
- organization_id,
60
- );
61
- if (listMaster) {
62
- return listMaster;
63
- }
64
- }
65
-
66
- async getDropdownOptions(
67
- type: string,
68
- params: Record<string, string>,
69
- inactiveIdsArray?: number[],
70
- loggedInUser?,
71
- publicCall = false,
72
- ) {
73
- const config = await this.listMasterRepo.findByType(
74
- type,
75
- loggedInUser?.organization_id,
76
- );
77
-
78
- if (!config) throw new NotFoundException(`Type ${type} not found`);
79
-
80
- if (
81
- config.appcode != null &&
82
- config.appcode != loggedInUser?.appcode &&
83
- !publicCall
84
- ) {
85
- // Call internal API for appcode mismatch
86
- try {
87
- const baseUrl = this.configService.get<string>('REDIRECT_BE_URL');
88
-
89
- // Prepare the query string
90
- const queryParams = new URLSearchParams({
91
- inactiveIds: inactiveIdsArray?.join(',') || '',
92
- loggedInUser: JSON.stringify(loggedInUser),
93
- ...params, // Spread other params into the query string
94
- }).toString();
95
-
96
- // Make the GET request with query parameters
97
- const response = await axios.get(
98
- `${baseUrl}/list-master/getDropdownDataPublic/${type}?${queryParams}`,
99
- {
100
- headers: {
101
- 'Content-Type': 'application/json',
102
- },
103
- },
104
- );
105
-
106
- console.log('✅ Internal API response:', response.data);
107
- return response.data;
108
- } catch (error) {
109
- console.error('⚠️ Internal API call failed:', error.message);
110
- throw new BadRequestException(
111
- `Failed to fetch dropdown for type ${type} from internal API`,
112
- );
113
- }
114
- }
115
-
116
- // Fallback to old logic if no extension exists
117
- switch (config.source) {
118
- case 'entity':
119
- return this.fetchFromEntity(
120
- type,
121
- params,
122
- inactiveIdsArray,
123
- loggedInUser,
124
- );
125
-
126
- case 'master':
127
- return this.listItemsRepo.findItemsByType(
128
- type,
129
- config.sort_by,
130
- inactiveIdsArray,
131
- loggedInUser?.organization_id,
132
- params,
133
- );
134
-
135
- case 'operator':
136
- return this.listItemsRepo.findOperatorsByType(
137
- type,
138
- loggedInUser?.organization_id,
139
- );
140
-
141
- case 'custom':
142
- // If you want Axios call here too:
143
- try {
144
- const response = await axios.get(
145
- `https://external-source.com/${config.custom_source_id}`,
146
- { params },
147
- );
148
- return response.data;
149
- } catch (error) {
150
- console.error('⚠️ Custom source fetch failed:', error.message);
151
- throw new BadRequestException('Failed to fetch custom source');
152
- }
153
-
154
- default:
155
- throw new BadRequestException(`Unknown source: ${config.source}`);
156
- }
157
- }
158
-
159
- private async fetchFromEntity(
160
- sourceList: string,
161
- params: Record<string, any>,
162
- inactiveIdsArray?: number[],
163
- loggedInUser?: UserData,
164
- ) {
165
- console.log(
166
- sourceList,
167
- 'sourceList',
168
- params,
169
- 'params',
170
- inactiveIdsArray,
171
- 'inactiveIdsArray',
172
- loggedInUser,
173
- 'loggedInUser',
174
- );
175
- let result: { label: string; value: number }[] = [];
176
- if (!sourceList) return result;
177
-
178
- const entityMaster = await this.entityMasterService.getEntityData(
179
- sourceList,
180
- loggedInUser,
181
- );
182
- const tableName = entityMaster.data_source;
183
-
184
- const applyCommonFilters = (qb: any, status?: number) => {
185
- if (status) {
186
- const isView = tableName.endsWith('_vw'); // auto-detect view
187
- const statusColumn = isView ? 'status_id' : 'status';
188
- qb.andWhere(`${tableName}.${statusColumn} = :status`, { status });
189
- }
190
-
191
- if (loggedInUser?.level_type && loggedInUser?.level_id) {
192
- // Skip level filter for certain entities
193
- if (!this.skipLevelFilterEntities.includes(sourceList)) {
194
- qb.andWhere(
195
- `${tableName}.level_type = :levelType AND ${tableName}.level_id = :levelId AND ${tableName}.organization_id = :organization_id`,
196
- {
197
- levelType: loggedInUser.level_type,
198
- levelId: loggedInUser.level_id,
199
- organization_id: loggedInUser.organization_id,
200
- },
201
- );
202
- } else {
203
- // IN the case of BRN, we don't filter by level
204
- qb.andWhere(
205
- `${tableName}.parent_id = :organization_id
206
- AND ${tableName}.type = 'BRN'
207
- `,
208
- {
209
- organization_id: loggedInUser.organization_id,
210
- },
211
- );
212
- }
213
- }
214
-
215
- if (loggedInUser?.appcode && sourceList === 'ROL') {
216
- if (!this.skipLevelFilterEntities.includes(sourceList)) {
217
- qb.andWhere(`${tableName}.appcode = :appcode`, {
218
- appcode: loggedInUser.appcode,
219
- });
220
- }
221
- }
222
-
223
- for (const key in params) {
224
- qb.andWhere(`${tableName}.${key} = :${key}`, {
225
- [key]: params[key],
226
- });
227
- }
228
-
229
- return qb;
230
- };
231
-
232
- const resolveStatus = await this.getResolvedListCode(
233
- STATUS_ACTIVE,
234
- loggedInUser?.organization_id || 0,
235
- );
236
-
237
- // Fetpords
238
- const activeQuery = applyCommonFilters(
239
- this.entityManager
240
- .createQueryBuilder()
241
- .select('*')
242
- .from(tableName, tableName),
243
- resolveStatus.id,
244
- );
245
-
246
- const activeResults = await activeQuery.getRawMany();
247
- const activeIds = new Set(activeResults.map((r) => r.id));
248
-
249
- // Add active entries first
250
- activeResults.forEach((r) => {
251
- result.push({ label: r.name, value: r.id });
252
- });
253
-
254
- const resolveInactiveStatus = await this.getResolvedListCode(
255
- STATUS_INACTIVE,
256
- loggedInUser?.organization_id || 0,
257
- );
258
-
259
- // Fetch inactive records (with same filters but without status condition)
260
- if (inactiveIdsArray?.length) {
261
- const inactiveQuery = applyCommonFilters(
262
- this.entityManager
263
- .createQueryBuilder()
264
- .select('*')
265
- .from(tableName, tableName),
266
- resolveInactiveStatus.id,
267
- );
268
-
269
- inactiveQuery.andWhere(`${tableName}.id IN (:...ids)`, {
270
- ids: inactiveIdsArray,
271
- });
272
-
273
- const inactiveResults = await inactiveQuery.getRawMany();
274
-
275
- // Add only those inactive records not already present in active
276
- inactiveResults.forEach((item) => {
277
- if (!activeIds.has(item.id)) {
278
- result.push({
279
- label: `${item.name} [INACTIVE]`,
280
- value: item.id,
281
- });
282
- }
283
- });
284
- }
285
-
286
- return result;
287
- }
288
-
289
- private async fetchFromExternalSource(
290
- customSourceId: number,
291
- params?: Record<string, string>,
292
- ) {
293
- const apiRegistry = await this.apiRegistryService.findById(customSourceId);
294
- if (!apiRegistry) return [];
295
-
296
- const url = `${apiRegistry.base_url}${apiRegistry.endpoint.replace(/{{(.*?)}}/g, (_, key) => params?.[key.trim()] || '')}`;
297
- const payload = this.injectDynamicParams(
298
- apiRegistry.request_payload_schema,
299
- params,
300
- );
301
-
302
- const response = await firstValueFrom(
303
- this.httpService.request({
304
- url,
305
- method: apiRegistry.http_method || 'POST',
306
- data: payload,
307
- headers: apiRegistry.headers ? apiRegistry.headers : undefined,
308
- }),
309
- );
310
-
311
- const data = this.extractByPath(
312
- response.data,
313
- apiRegistry.response_data_path,
314
- );
315
-
316
- if (!Array.isArray(data)) {
317
- return [{ label: data, value: data }];
318
- }
319
-
320
- if (typeof data[0] === 'string') {
321
- return data.map((item: string) => ({ label: item, value: item }));
322
- }
323
-
324
- return data.map((item: any) => ({
325
- label: item[apiRegistry?.label],
326
- value: item[apiRegistry?.value],
327
- }));
328
- }
329
-
330
- private injectDynamicParams(
331
- payload: any,
332
- params?: Record<string, string>,
333
- ): any {
334
- if (params) {
335
- const stringified = JSON.stringify(payload);
336
- const replaced = stringified.replace(
337
- /{{(.*?)}}/g,
338
- (_, key) => params[key.trim()] || '',
339
- );
340
- return JSON.parse(replaced);
341
- }
342
- }
343
-
344
- private extractByPath(obj: any, path: string): any {
345
- if (!path || !obj) return obj;
346
-
347
- return path.split('.').reduce((acc, key) => {
348
- if (acc == null) return undefined;
349
-
350
- // Try to convert to number if it's a numeric string (for array indexes)
351
- const index = Number(key);
352
- if (!isNaN(index) && Array.isArray(acc)) {
353
- return acc[index];
354
- }
355
-
356
- return acc[key];
357
- }, obj);
358
- }
359
-
360
- // createEntity method
361
- async createEntity(entityData: any, loggedInUser: UserData): Promise<any> {
362
- // Trim and validate name and code
363
- const name = entityData.name?.trim();
364
- // const code = entityData.code?.trim();
365
-
366
- if (!name) {
367
- throw new BadRequestException('Name is required and cannot be empty');
368
- }
369
-
370
- entityData.name = name;
371
- entityData.is_factory = entityData.is_factory || 0;
372
- entityData.source = entityData.source || 'master';
373
- entityData.status = entityData.status || 'ACTIVE';
374
- entityData.type = entityData.code;
375
- entityData.sort_by = entityData.sort_by || 'asc';
376
- entityData.organization_id = loggedInUser.organization_id;
377
-
378
- // Check for duplicate name
379
- const nameExists = await this.listMasterRepo.findOneByCondition({
380
- name,
381
- organization_id: loggedInUser.organization_id,
382
- });
383
-
384
- if (nameExists) {
385
- throw new BadRequestException(
386
- 'A List Master with the same name already exists',
387
- );
388
- }
389
-
390
- const createdListMaster = await this.entityServiceImpl.createEntity(
391
- entityData,
392
- loggedInUser,
393
- );
394
-
395
- if (!createdListMaster) {
396
- throw new BadRequestException('Failed to create entity');
397
- }
398
-
399
- return createdListMaster;
400
- }
401
-
402
- async updateEntity(entityData: any, loggedInUser: UserData): Promise<any> {
403
- return await this.entityServiceImpl.updateEntity(entityData, loggedInUser);
404
- }
405
-
406
- async getEntityData(
407
- entity_type: string,
408
- id: number,
409
- loggedInUser,
410
- ): Promise<any> {
411
- return await this.entityServiceImpl.getEntityData(
412
- entity_type,
413
- id,
414
- loggedInUser,
415
- );
416
- }
417
-
418
- async getAllListMasterByOrganization(
419
- organizationId: number,
420
- search?: string,
421
- ): Promise<any[]> {
422
- return await this.listMasterRepo.findAllItems(organizationId, search);
423
- }
424
- }
1
+ import {
2
+ BadRequestException,
3
+ forwardRef,
4
+ Inject,
5
+ Injectable,
6
+ NotFoundException,
7
+ } from '@nestjs/common';
8
+ import { ListMasterItemsRepository } from '../repository/list-master-items.repository';
9
+ import { ListMasterRepository } from '../repository/list-master.repository';
10
+ import { ApiRegistryService } from '../../third-party-module/service/api-registry.service';
11
+ import { firstValueFrom } from 'rxjs';
12
+ import { HttpService } from '@nestjs/axios';
13
+ import { EntityManager } from 'typeorm';
14
+ import { EntityMasterService } from 'src/module/meta/service/entity-master.service';
15
+ import { UserData } from 'src/module/user/entity/user.entity';
16
+ import { EntityServiceImpl } from 'src/module/meta/service/entity-service-impl.service';
17
+ import { STATUS_ACTIVE, STATUS_INACTIVE } from 'src/constant/global.constant';
18
+ import { ListMasterExtension } from './list-master-extension.interface';
19
+ import { ListMasterEngine } from './list-master-engine';
20
+ import { Action } from '../../workflow-automation/interface/action.interface';
21
+ import axios from 'axios';
22
+ import { ConfigService } from '@nestjs/config';
23
+
24
+ @Injectable()
25
+ export class ListMasterService {
26
+ constructor(
27
+ private readonly entityManager: EntityManager,
28
+ @Inject(forwardRef(() => EntityServiceImpl))
29
+ private readonly entityServiceImpl: EntityServiceImpl,
30
+ @Inject(forwardRef(() => EntityMasterService))
31
+ private readonly entityMasterService: EntityMasterService,
32
+ private readonly listMasterRepo: ListMasterRepository,
33
+ private readonly listItemsRepo: ListMasterItemsRepository,
34
+ private readonly apiRegistryService: ApiRegistryService,
35
+ private readonly httpService: HttpService,
36
+ private readonly listMasterEngine: ListMasterEngine,
37
+ private readonly configService: ConfigService,
38
+ ) {}
39
+
40
+ private readonly skipLevelFilterEntities = ['BRN'];
41
+ private readonly actions = new Map<string, Action>();
42
+
43
+ registerAction(actionName: string, actionInstance: Action) {
44
+ this.actions.set(actionName, actionInstance);
45
+ console.log(
46
+ `⚙️ [WorkflowAutomationEngine] Registered action: ${actionName}`,
47
+ );
48
+ }
49
+
50
+ async getResolvedListCode(
51
+ code: string,
52
+ organization_id: number,
53
+ ): Promise<any> {
54
+ if (!code) return code;
55
+
56
+ // Check if it's a valid list type
57
+ const listMaster = await this.listItemsRepo.findItemByCode(
58
+ code,
59
+ organization_id,
60
+ );
61
+ if (listMaster) {
62
+ return listMaster;
63
+ }
64
+ }
65
+
66
+ async getDropdownOptions(
67
+ type: string,
68
+ params: Record<string, string>,
69
+ inactiveIdsArray?: number[],
70
+ loggedInUser?,
71
+ publicCall = false,
72
+ ) {
73
+ const config = await this.listMasterRepo.findByType(
74
+ type,
75
+ loggedInUser?.organization_id,
76
+ );
77
+
78
+ if (!config) throw new NotFoundException(`Type ${type} not found`);
79
+
80
+ if (
81
+ config.appcode != null &&
82
+ config.appcode != loggedInUser?.appcode &&
83
+ !publicCall
84
+ ) {
85
+ // Call internal API for appcode mismatch
86
+ try {
87
+ const baseUrl = this.configService.get<string>('REDIRECT_BE_URL');
88
+
89
+ // Prepare the query string
90
+ const queryParams = new URLSearchParams({
91
+ inactiveIds: inactiveIdsArray?.join(',') || '',
92
+ loggedInUser: JSON.stringify(loggedInUser),
93
+ ...params, // Spread other params into the query string
94
+ }).toString();
95
+
96
+ // Make the GET request with query parameters
97
+ const response = await axios.get(
98
+ `${baseUrl}/list-master/getDropdownDataPublic/${type}?${queryParams}`,
99
+ {
100
+ headers: {
101
+ 'Content-Type': 'application/json',
102
+ },
103
+ },
104
+ );
105
+
106
+ console.log('✅ Internal API response:', response.data);
107
+ return response.data;
108
+ } catch (error) {
109
+ console.error('⚠️ Internal API call failed:', error.message);
110
+ throw new BadRequestException(
111
+ `Failed to fetch dropdown for type ${type} from internal API`,
112
+ );
113
+ }
114
+ }
115
+
116
+ // Fallback to old logic if no extension exists
117
+ switch (config.source) {
118
+ case 'entity':
119
+ return this.fetchFromEntity(
120
+ type,
121
+ params,
122
+ inactiveIdsArray,
123
+ loggedInUser,
124
+ );
125
+
126
+ case 'master':
127
+ return this.listItemsRepo.findItemsByType(
128
+ type,
129
+ config.sort_by,
130
+ inactiveIdsArray,
131
+ loggedInUser?.organization_id,
132
+ params,
133
+ );
134
+
135
+ case 'operator':
136
+ return this.listItemsRepo.findOperatorsByType(
137
+ type,
138
+ loggedInUser?.organization_id,
139
+ );
140
+
141
+ case 'custom':
142
+ // If you want Axios call here too:
143
+ try {
144
+ const response = await axios.get(
145
+ `https://external-source.com/${config.custom_source_id}`,
146
+ { params },
147
+ );
148
+ return response.data;
149
+ } catch (error) {
150
+ console.error('⚠️ Custom source fetch failed:', error.message);
151
+ throw new BadRequestException('Failed to fetch custom source');
152
+ }
153
+
154
+ default:
155
+ throw new BadRequestException(`Unknown source: ${config.source}`);
156
+ }
157
+ }
158
+
159
+ private async fetchFromEntity(
160
+ sourceList: string,
161
+ params: Record<string, any>,
162
+ inactiveIdsArray?: number[],
163
+ loggedInUser?: UserData,
164
+ ) {
165
+ console.log(
166
+ sourceList,
167
+ 'sourceList',
168
+ params,
169
+ 'params',
170
+ inactiveIdsArray,
171
+ 'inactiveIdsArray',
172
+ loggedInUser,
173
+ 'loggedInUser',
174
+ );
175
+ let result: { label: string; value: number }[] = [];
176
+ if (!sourceList) return result;
177
+
178
+ const entityMaster = await this.entityMasterService.getEntityData(
179
+ sourceList,
180
+ loggedInUser,
181
+ );
182
+ const tableName = entityMaster.data_source;
183
+
184
+ const applyCommonFilters = (qb: any, status?: number) => {
185
+ if (status) {
186
+ const isView = tableName.endsWith('_vw'); // auto-detect view
187
+ const statusColumn = isView ? 'status_id' : 'status';
188
+ qb.andWhere(`${tableName}.${statusColumn} = :status`, { status });
189
+ }
190
+
191
+ if (loggedInUser?.level_type && loggedInUser?.level_id) {
192
+ // Skip level filter for certain entities
193
+ if (!this.skipLevelFilterEntities.includes(sourceList)) {
194
+ qb.andWhere(
195
+ `${tableName}.level_type = :levelType AND ${tableName}.level_id = :levelId AND ${tableName}.organization_id = :organization_id`,
196
+ {
197
+ levelType: loggedInUser.level_type,
198
+ levelId: loggedInUser.level_id,
199
+ organization_id: loggedInUser.organization_id,
200
+ },
201
+ );
202
+ } else {
203
+ // IN the case of BRN, we don't filter by level
204
+ qb.andWhere(
205
+ `${tableName}.parent_id = :organization_id
206
+ AND ${tableName}.type = 'BRN'
207
+ `,
208
+ {
209
+ organization_id: loggedInUser.organization_id,
210
+ },
211
+ );
212
+ }
213
+ }
214
+
215
+ if (loggedInUser?.appcode && sourceList === 'ROL') {
216
+ if (!this.skipLevelFilterEntities.includes(sourceList)) {
217
+ qb.andWhere(`${tableName}.appcode = :appcode`, {
218
+ appcode: loggedInUser.appcode,
219
+ });
220
+ }
221
+ }
222
+
223
+ for (const key in params) {
224
+ qb.andWhere(`${tableName}.${key} = :${key}`, {
225
+ [key]: params[key],
226
+ });
227
+ }
228
+
229
+ return qb;
230
+ };
231
+
232
+ const resolveStatus = await this.getResolvedListCode(
233
+ STATUS_ACTIVE,
234
+ loggedInUser?.organization_id || 0,
235
+ );
236
+
237
+ // Fetpords
238
+ const activeQuery = applyCommonFilters(
239
+ this.entityManager
240
+ .createQueryBuilder()
241
+ .select('*')
242
+ .from(tableName, tableName),
243
+ resolveStatus.id,
244
+ );
245
+
246
+ const activeResults = await activeQuery.getRawMany();
247
+ const activeIds = new Set(activeResults.map((r) => r.id));
248
+
249
+ // Add active entries first
250
+ activeResults.forEach((r) => {
251
+ result.push({ label: r.name, value: r.id });
252
+ });
253
+
254
+ const resolveInactiveStatus = await this.getResolvedListCode(
255
+ STATUS_INACTIVE,
256
+ loggedInUser?.organization_id || 0,
257
+ );
258
+
259
+ // Fetch inactive records (with same filters but without status condition)
260
+ if (inactiveIdsArray?.length) {
261
+ const inactiveQuery = applyCommonFilters(
262
+ this.entityManager
263
+ .createQueryBuilder()
264
+ .select('*')
265
+ .from(tableName, tableName),
266
+ resolveInactiveStatus.id,
267
+ );
268
+
269
+ inactiveQuery.andWhere(`${tableName}.id IN (:...ids)`, {
270
+ ids: inactiveIdsArray,
271
+ });
272
+
273
+ const inactiveResults = await inactiveQuery.getRawMany();
274
+
275
+ // Add only those inactive records not already present in active
276
+ inactiveResults.forEach((item) => {
277
+ if (!activeIds.has(item.id)) {
278
+ result.push({
279
+ label: `${item.name} [INACTIVE]`,
280
+ value: item.id,
281
+ });
282
+ }
283
+ });
284
+ }
285
+
286
+ return result;
287
+ }
288
+
289
+ private async fetchFromExternalSource(
290
+ customSourceId: number,
291
+ params?: Record<string, string>,
292
+ ) {
293
+ const apiRegistry = await this.apiRegistryService.findById(customSourceId);
294
+ if (!apiRegistry) return [];
295
+
296
+ const url = `${apiRegistry.base_url}${apiRegistry.endpoint.replace(/{{(.*?)}}/g, (_, key) => params?.[key.trim()] || '')}`;
297
+ const payload = this.injectDynamicParams(
298
+ apiRegistry.request_payload_schema,
299
+ params,
300
+ );
301
+
302
+ const response = await firstValueFrom(
303
+ this.httpService.request({
304
+ url,
305
+ method: apiRegistry.http_method || 'POST',
306
+ data: payload,
307
+ headers: apiRegistry.headers ? apiRegistry.headers : undefined,
308
+ }),
309
+ );
310
+
311
+ const data = this.extractByPath(
312
+ response.data,
313
+ apiRegistry.response_data_path,
314
+ );
315
+
316
+ if (!Array.isArray(data)) {
317
+ return [{ label: data, value: data }];
318
+ }
319
+
320
+ if (typeof data[0] === 'string') {
321
+ return data.map((item: string) => ({ label: item, value: item }));
322
+ }
323
+
324
+ return data.map((item: any) => ({
325
+ label: item[apiRegistry?.label],
326
+ value: item[apiRegistry?.value],
327
+ }));
328
+ }
329
+
330
+ private injectDynamicParams(
331
+ payload: any,
332
+ params?: Record<string, string>,
333
+ ): any {
334
+ if (params) {
335
+ const stringified = JSON.stringify(payload);
336
+ const replaced = stringified.replace(
337
+ /{{(.*?)}}/g,
338
+ (_, key) => params[key.trim()] || '',
339
+ );
340
+ return JSON.parse(replaced);
341
+ }
342
+ }
343
+
344
+ private extractByPath(obj: any, path: string): any {
345
+ if (!path || !obj) return obj;
346
+
347
+ return path.split('.').reduce((acc, key) => {
348
+ if (acc == null) return undefined;
349
+
350
+ // Try to convert to number if it's a numeric string (for array indexes)
351
+ const index = Number(key);
352
+ if (!isNaN(index) && Array.isArray(acc)) {
353
+ return acc[index];
354
+ }
355
+
356
+ return acc[key];
357
+ }, obj);
358
+ }
359
+
360
+ // createEntity method
361
+ async createEntity(entityData: any, loggedInUser: UserData): Promise<any> {
362
+ // Trim and validate name and code
363
+ const name = entityData.name?.trim();
364
+ // const code = entityData.code?.trim();
365
+
366
+ if (!name) {
367
+ throw new BadRequestException('Name is required and cannot be empty');
368
+ }
369
+
370
+ entityData.name = name;
371
+ entityData.is_factory = entityData.is_factory || 0;
372
+ entityData.source = entityData.source || 'master';
373
+ entityData.status = entityData.status || 'ACTIVE';
374
+ entityData.type = entityData.code;
375
+ entityData.sort_by = entityData.sort_by || 'asc';
376
+ entityData.organization_id = loggedInUser.organization_id;
377
+
378
+ // Check for duplicate name
379
+ const nameExists = await this.listMasterRepo.findOneByCondition({
380
+ name,
381
+ organization_id: loggedInUser.organization_id,
382
+ });
383
+
384
+ if (nameExists) {
385
+ throw new BadRequestException(
386
+ 'A List Master with the same name already exists',
387
+ );
388
+ }
389
+
390
+ const createdListMaster = await this.entityServiceImpl.createEntity(
391
+ entityData,
392
+ loggedInUser,
393
+ );
394
+
395
+ if (!createdListMaster) {
396
+ throw new BadRequestException('Failed to create entity');
397
+ }
398
+
399
+ return createdListMaster;
400
+ }
401
+
402
+ async updateEntity(entityData: any, loggedInUser: UserData): Promise<any> {
403
+ return await this.entityServiceImpl.updateEntity(entityData, loggedInUser);
404
+ }
405
+
406
+ async getEntityData(
407
+ entity_type: string,
408
+ id: number,
409
+ loggedInUser,
410
+ ): Promise<any> {
411
+ return await this.entityServiceImpl.getEntityData(
412
+ entity_type,
413
+ id,
414
+ loggedInUser,
415
+ );
416
+ }
417
+
418
+ async getAllListMasterByOrganization(
419
+ organizationId: number,
420
+ search?: string,
421
+ ): Promise<any[]> {
422
+ return await this.listMasterRepo.findAllItems(organizationId, search);
423
+ }
424
+ }