rez_core 3.1.186 → 3.1.187

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 (389) 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/examples/usage.example.js +9 -9
  22. package/dist/module/integration/service/integration.service.js +1 -1
  23. package/dist/module/integration/service/wrapper.service.js +25 -25
  24. package/dist/module/listmaster/service/list-master-item.service.js +2 -2
  25. package/dist/module/listmaster/service/list-master.service.js +2 -2
  26. package/dist/module/mapper/controller/mapper.controller.d.ts +1 -1
  27. package/dist/module/mapper/controller/mapper.controller.js +4 -3
  28. package/dist/module/mapper/controller/mapper.controller.js.map +1 -1
  29. package/dist/module/mapper/service/field-mapper.service.js +4 -4
  30. package/dist/module/mapper/service/mapper.service.d.ts +1 -1
  31. package/dist/module/mapper/service/mapper.service.js +6 -4
  32. package/dist/module/mapper/service/mapper.service.js.map +1 -1
  33. package/dist/module/meta/service/entity-dynamic.service.js +18 -18
  34. package/dist/module/meta/service/entity-list.service.js +3 -3
  35. package/dist/module/meta/service/entity-master.service.js +3 -3
  36. package/dist/module/meta/service/entity-relation.service.js +11 -11
  37. package/dist/module/meta/service/entity-service-impl.service.js +3 -3
  38. package/dist/module/meta/service/resolver.service.js +3 -3
  39. package/dist/module/module/repository/menu.repository.js +12 -12
  40. package/dist/module/notification/service/notification.service.js +12 -12
  41. package/dist/module/user/controller/login.controller.js +18 -18
  42. package/dist/module/user/service/role.service.js +4 -4
  43. package/dist/module/user/service/user-session.service.js +2 -2
  44. package/dist/module/workflow/repository/action.repository.js +16 -16
  45. package/dist/module/workflow/repository/comm-template.repository.js +6 -6
  46. package/dist/module/workflow/repository/form-master.repository.js +2 -2
  47. package/dist/module/workflow/repository/stage-group.repository.js +23 -23
  48. package/dist/module/workflow/repository/stage-movement.repository.js +11 -11
  49. package/dist/module/workflow/repository/stage.repository.js +8 -8
  50. package/dist/module/workflow/service/action-template-mapping.service.js +10 -10
  51. package/dist/module/workflow/service/action.service.js +7 -7
  52. package/dist/module/workflow/service/entity-modification.service.js +6 -6
  53. package/dist/module/workflow/service/stage-group.service.js +2 -2
  54. package/dist/module/workflow/service/stage.service.js +2 -2
  55. package/dist/module/workflow/service/task.service.js +33 -33
  56. package/dist/module/workflow/service/workflow-list-master.service.js +15 -15
  57. package/dist/module/workflow/service/workflow-meta.service.js +50 -50
  58. package/dist/module/workflow/service/workflow.service.js +2 -2
  59. package/dist/tsconfig.build.tsbuildinfo +1 -1
  60. package/dist/utils/service/reflection-helper.service.js +2 -2
  61. package/docs/modules/event-driven-integration-design.md +91 -91
  62. package/docs/modules/integration.md +250 -250
  63. package/eslint.config.mjs +34 -34
  64. package/nest-cli.json +14 -14
  65. package/package.json +118 -118
  66. package/server.log +850 -0
  67. package/src/app.controller.ts +12 -12
  68. package/src/app.module.ts +49 -49
  69. package/src/app.service.ts +8 -8
  70. package/src/config/config.module.ts +18 -18
  71. package/src/config/database.config.ts +23 -23
  72. package/src/constant/global.constant.ts +67 -67
  73. package/src/core.module.ts +81 -81
  74. package/src/decorators/roles.decorator.ts +7 -7
  75. package/src/dtos/response.dto.ts +6 -6
  76. package/src/dtos/response.ts +5 -5
  77. package/src/index.ts +1 -1
  78. package/src/module/auth/auth.module.ts +49 -49
  79. package/src/module/auth/controller/auth.controller.ts +28 -28
  80. package/src/module/auth/guards/google-auth.guard.ts +9 -9
  81. package/src/module/auth/guards/jwt.guard.ts +22 -22
  82. package/src/module/auth/guards/role.guard.ts +68 -68
  83. package/src/module/auth/services/auth.service.ts +50 -50
  84. package/src/module/auth/services/jwt.service.ts +11 -11
  85. package/src/module/auth/strategies/google.strategy.ts +54 -54
  86. package/src/module/auth/strategies/jwt.strategy.ts +58 -58
  87. package/src/module/auth/strategies/local.strategy.ts +13 -13
  88. package/src/module/dashboard/controller/dashboard.controller.ts +36 -36
  89. package/src/module/dashboard/dashboard.module.ts +21 -21
  90. package/src/module/dashboard/entity/dashboard_page_data.entity.ts +27 -27
  91. package/src/module/dashboard/entity/widget_master.entity.ts +18 -18
  92. package/src/module/dashboard/repository/dashboard.repository.ts +42 -42
  93. package/src/module/dashboard/service/dashboard.service.ts +73 -73
  94. package/src/module/dev/dev.module.ts +12 -12
  95. package/src/module/dev/service/dev.service.ts +7 -7
  96. package/src/module/enterprise/controller/organization.controller.ts +36 -36
  97. package/src/module/enterprise/enterprise.module.ts +30 -30
  98. package/src/module/enterprise/entity/enterprise.entity.ts +37 -37
  99. package/src/module/enterprise/entity/organization-app-mapping.entity.ts +13 -13
  100. package/src/module/enterprise/entity/organization.entity.ts +92 -92
  101. package/src/module/enterprise/repository/enterprise.repository.ts +31 -31
  102. package/src/module/enterprise/repository/organization.repository.ts +26 -26
  103. package/src/module/enterprise/repository/school.repository.ts +281 -281
  104. package/src/module/enterprise/service/brand.service.ts +5 -5
  105. package/src/module/enterprise/service/enterprise.service.ts +16 -16
  106. package/src/module/enterprise/service/organization-app-mapping.service.ts +4 -4
  107. package/src/module/enterprise/service/organization.service.ts +145 -145
  108. package/src/module/filter/controller/filter.controller.ts +84 -84
  109. package/src/module/filter/dto/filter-request.dto.ts +38 -38
  110. package/src/module/filter/entity/saved-filter-detail.entity.ts +41 -41
  111. package/src/module/filter/entity/saved-filter-master.entity.ts +23 -23
  112. package/src/module/filter/filter.module.ts +31 -31
  113. package/src/module/filter/repository/saved-filter.repository.ts +168 -168
  114. package/src/module/filter/service/filter-evaluator.service.ts +86 -86
  115. package/src/module/filter/service/filter.service.ts +868 -868
  116. package/src/module/filter/service/saved-filter.service.ts +170 -170
  117. package/src/module/ics/controller/ics.controller.ts +21 -21
  118. package/src/module/ics/dto/ics.dto.ts +55 -55
  119. package/src/module/ics/ics.module.ts +13 -13
  120. package/src/module/ics/service/ics.service.ts +57 -57
  121. package/src/module/integration/controller/calender-event.controller.ts +31 -31
  122. package/src/module/integration/controller/integration.controller.ts +662 -662
  123. package/src/module/integration/controller/wrapper.controller.ts +37 -37
  124. package/src/module/integration/dto/create-config.dto.ts +526 -526
  125. package/src/module/integration/entity/integration-config.entity.ts +112 -112
  126. package/src/module/integration/entity/integration-entity-mapper.entity.ts +14 -14
  127. package/src/module/integration/entity/integration-source.entity.ts +17 -17
  128. package/src/module/integration/entity/user-integration.entity.ts +71 -71
  129. package/src/module/integration/examples/usage.example.ts +338 -338
  130. package/src/module/integration/factories/base.factory.ts +7 -7
  131. package/src/module/integration/factories/email.factory.ts +49 -49
  132. package/src/module/integration/factories/integration.factory.ts +121 -121
  133. package/src/module/integration/factories/sms.factory.ts +51 -51
  134. package/src/module/integration/factories/telephone.factory.ts +41 -41
  135. package/src/module/integration/factories/whatsapp.factory.ts +56 -56
  136. package/src/module/integration/integration.module.ts +110 -110
  137. package/src/module/integration/service/calendar-event.service.ts +118 -118
  138. package/src/module/integration/service/integration-entity-mapper.service.ts +17 -17
  139. package/src/module/integration/service/integration-queue.service.ts +229 -229
  140. package/src/module/integration/service/integration.service.ts +2572 -2572
  141. package/src/module/integration/service/oauth.service.ts +224 -224
  142. package/src/module/integration/service/wrapper.service.ts +457 -457
  143. package/src/module/integration/strategies/email/gmail-api.strategy.ts +280 -280
  144. package/src/module/integration/strategies/email/outlook-api.strategy.ts +44 -44
  145. package/src/module/integration/strategies/email/outlook.strategy.ts +64 -64
  146. package/src/module/integration/strategies/email/sendgrid-api.strategy.ts +260 -260
  147. package/src/module/integration/strategies/integration.strategy.ts +97 -97
  148. package/src/module/integration/strategies/sms/gupshup-sms.strategy.ts +146 -146
  149. package/src/module/integration/strategies/sms/msg91-sms.strategy.ts +164 -164
  150. package/src/module/integration/strategies/sms/tubelight-sms.strategy.ts +163 -163
  151. package/src/module/integration/strategies/telephone/ozonetel-voice.strategy.ts +238 -238
  152. package/src/module/integration/strategies/telephone/tubelight-voice.strategy.ts +210 -210
  153. package/src/module/integration/strategies/whatsapp/gupshup-whatsapp.strategy.ts +359 -359
  154. package/src/module/integration/strategies/whatsapp/tubelight-whatsapp.strategy.ts +372 -372
  155. package/src/module/integration/strategies/whatsapp/whatsapp-cloud.strategy.ts +403 -403
  156. package/src/module/integration/strategies/whatsapp/whatsapp.strategy.ts +57 -57
  157. package/src/module/layout/controller/layout.controller.ts +47 -47
  158. package/src/module/layout/entity/header-items.entity.ts +28 -28
  159. package/src/module/layout/entity/header-section.entity.ts +19 -19
  160. package/src/module/layout/layout.module.ts +21 -21
  161. package/src/module/layout/repository/header-items.repository.ts +18 -18
  162. package/src/module/layout/repository/header-section.repository.ts +22 -22
  163. package/src/module/layout/service/header-section.service.ts +25 -25
  164. package/src/module/layout_preference/controller/layout_preference.controller.ts +47 -47
  165. package/src/module/layout_preference/entity/layout_preference.entity.ts +28 -28
  166. package/src/module/layout_preference/layout_preference.module.ts +18 -18
  167. package/src/module/layout_preference/repository/layout_preference.repository.ts +30 -30
  168. package/src/module/layout_preference/service/layout_preference.service.ts +172 -172
  169. package/src/module/lead/controller/lead.controller.ts +30 -30
  170. package/src/module/lead/lead.module.ts +14 -14
  171. package/src/module/lead/repository/lead.repository.ts +41 -41
  172. package/src/module/lead/service/lead.service.ts +54 -54
  173. package/src/module/listmaster/controller/list-master.controller.ts +187 -187
  174. package/src/module/listmaster/entity/list-master-items.entity.ts +41 -41
  175. package/src/module/listmaster/entity/list-master.entity.ts +32 -32
  176. package/src/module/listmaster/listmaster.module.ts +44 -44
  177. package/src/module/listmaster/repository/list-master-items.repository.ts +169 -169
  178. package/src/module/listmaster/repository/list-master.repository.ts +46 -46
  179. package/src/module/listmaster/service/list-master-engine.ts +19 -19
  180. package/src/module/listmaster/service/list-master-extension.interface.ts +4 -4
  181. package/src/module/listmaster/service/list-master-item.service.ts +292 -292
  182. package/src/module/listmaster/service/list-master-registry.ts +15 -15
  183. package/src/module/listmaster/service/list-master.service.ts +424 -424
  184. package/src/module/mapper/controller/field-mapper.controller.ts +69 -69
  185. package/src/module/mapper/controller/mapper.controller.ts +15 -14
  186. package/src/module/mapper/dto/field-mapper.dto.ts +14 -14
  187. package/src/module/mapper/entity/field-lovs.entity.ts +19 -19
  188. package/src/module/mapper/entity/field-mapper.entity.ts +53 -53
  189. package/src/module/mapper/entity/mapper.entity.ts +16 -16
  190. package/src/module/mapper/mapper.module.ts +34 -34
  191. package/src/module/mapper/repository/field-lovs.repository.ts +35 -35
  192. package/src/module/mapper/repository/field-mapper.repository.ts +42 -42
  193. package/src/module/mapper/repository/mapper.repository.ts +15 -15
  194. package/src/module/mapper/service/field-mapper.service.ts +245 -245
  195. package/src/module/mapper/service/mapper.service.ts +74 -72
  196. package/src/module/master/controller/master.controller.ts +74 -74
  197. package/src/module/master/service/master.service.ts +483 -483
  198. package/src/module/meta/controller/app-master.controller.ts +38 -38
  199. package/src/module/meta/controller/attribute-master.controller.ts +66 -66
  200. package/src/module/meta/controller/entity-dynamic.controller.ts +125 -125
  201. package/src/module/meta/controller/entity-master.controller.ts +28 -28
  202. package/src/module/meta/controller/entity-relation.controller.ts +36 -36
  203. package/src/module/meta/controller/entity.controller.ts +385 -385
  204. package/src/module/meta/controller/entity.public.controller.ts +75 -75
  205. package/src/module/meta/controller/media.controller.ts +82 -82
  206. package/src/module/meta/controller/meta.controller.ts +96 -96
  207. package/src/module/meta/controller/view-master.controller.ts +86 -86
  208. package/src/module/meta/dto/entity-list-data.dto.ts +6 -6
  209. package/src/module/meta/dto/entity-tab.dto.ts +4 -4
  210. package/src/module/meta/dto/entity-table.dto.ts +9 -9
  211. package/src/module/meta/entity/app-master.entity.ts +34 -34
  212. package/src/module/meta/entity/attribute-master.entity.ts +87 -87
  213. package/src/module/meta/entity/base-entity.entity.ts +75 -75
  214. package/src/module/meta/entity/entity-master.entity.ts +78 -78
  215. package/src/module/meta/entity/entity-relation-data.entity.ts +29 -29
  216. package/src/module/meta/entity/entity-relation.entity.ts +23 -23
  217. package/src/module/meta/entity/entity-table-column.entity.ts +61 -61
  218. package/src/module/meta/entity/entity-table.entity.ts +50 -50
  219. package/src/module/meta/entity/media-data.entity.ts +32 -32
  220. package/src/module/meta/entity/preference.entity.ts +62 -62
  221. package/src/module/meta/entity/view-master.entity.ts +41 -41
  222. package/src/module/meta/entity.module.ts +158 -158
  223. package/src/module/meta/repository/app-master.repository.ts +20 -20
  224. package/src/module/meta/repository/attribute-master.repository.ts +110 -110
  225. package/src/module/meta/repository/entity-master.repository.ts +69 -69
  226. package/src/module/meta/repository/entity-table-column.repository.ts +39 -39
  227. package/src/module/meta/repository/entity-table.repository.ts +53 -53
  228. package/src/module/meta/repository/media-data.repository.ts +50 -50
  229. package/src/module/meta/repository/preference.repository.ts +20 -20
  230. package/src/module/meta/repository/user-app-mapping.repository.ts +28 -28
  231. package/src/module/meta/repository/view-master.repository.ts +42 -42
  232. package/src/module/meta/service/app-master.service.ts +37 -37
  233. package/src/module/meta/service/attribute-master.service.ts +117 -117
  234. package/src/module/meta/service/common.service.ts +9 -9
  235. package/src/module/meta/service/entity-dynamic.service.ts +762 -762
  236. package/src/module/meta/service/entity-list.service.ts +205 -205
  237. package/src/module/meta/service/entity-master.service.ts +164 -164
  238. package/src/module/meta/service/entity-realation-data.service.ts +9 -9
  239. package/src/module/meta/service/entity-relation.service.ts +69 -69
  240. package/src/module/meta/service/entity-service-impl.service.ts +524 -524
  241. package/src/module/meta/service/entity-table-column.service.ts +39 -39
  242. package/src/module/meta/service/entity-table.service.ts +150 -150
  243. package/src/module/meta/service/entity-validation.service.ts +185 -185
  244. package/src/module/meta/service/entity.service.ts +67 -67
  245. package/src/module/meta/service/field-group.service.ts +103 -103
  246. package/src/module/meta/service/media-data.service.ts +149 -149
  247. package/src/module/meta/service/populate-meta.service.ts +173 -173
  248. package/src/module/meta/service/preference.service.ts +16 -16
  249. package/src/module/meta/service/resolver.service.ts +240 -240
  250. package/src/module/meta/service/section-master.service.ts +104 -104
  251. package/src/module/meta/service/update-form-json.service.ts +22 -22
  252. package/src/module/meta/service/user-app-mapping.service.ts +17 -17
  253. package/src/module/meta/service/view-master.service.ts +111 -111
  254. package/src/module/module/controller/menu.controller.ts +15 -15
  255. package/src/module/module/controller/module-access.controller.ts +132 -132
  256. package/src/module/module/entity/menu.entity.ts +43 -43
  257. package/src/module/module/entity/module-access.entity.ts +25 -25
  258. package/src/module/module/entity/module-action.entity.ts +17 -17
  259. package/src/module/module/entity/module.entity.ts +52 -52
  260. package/src/module/module/module.module.ts +42 -42
  261. package/src/module/module/repository/menu.repository.ts +184 -184
  262. package/src/module/module/repository/module-access.repository.ts +331 -331
  263. package/src/module/module/service/menu.service.ts +82 -82
  264. package/src/module/module/service/module-access.service.ts +209 -209
  265. package/src/module/notification/controller/notification.controller.ts +58 -58
  266. package/src/module/notification/controller/otp.controller.ts +117 -117
  267. package/src/module/notification/entity/notification.entity.ts +26 -26
  268. package/src/module/notification/entity/otp.entity.ts +28 -28
  269. package/src/module/notification/firebase-admin.config.ts +22 -22
  270. package/src/module/notification/notification.module.ts +69 -69
  271. package/src/module/notification/repository/otp.repository.ts +27 -27
  272. package/src/module/notification/service/email.service.ts +127 -127
  273. package/src/module/notification/service/notification.service.ts +138 -138
  274. package/src/module/notification/service/otp.service.ts +125 -125
  275. package/src/module/third-party-module/entity/third-party-api-registry.entity.ts +52 -52
  276. package/src/module/third-party-module/repository/third-party-api-registry.repository.ts +20 -20
  277. package/src/module/third-party-module/service/api-registry.service.ts +13 -13
  278. package/src/module/third-party-module/third-party.module.ts +12 -12
  279. package/src/module/user/controller/login.controller.ts +197 -197
  280. package/src/module/user/controller/user.controller.ts +40 -40
  281. package/src/module/user/dto/create-user.dto.ts +62 -62
  282. package/src/module/user/dto/update-user.dto.ts +4 -4
  283. package/src/module/user/entity/role.entity.ts +33 -33
  284. package/src/module/user/entity/user-role-mapping.entity.ts +38 -38
  285. package/src/module/user/entity/user-session.entity.ts +61 -61
  286. package/src/module/user/entity/user.entity.ts +71 -71
  287. package/src/module/user/repository/role.repository.ts +96 -96
  288. package/src/module/user/repository/user-role-mapping.repository.ts +126 -126
  289. package/src/module/user/repository/user.repository.ts +50 -50
  290. package/src/module/user/repository/userSession.repository.ts +33 -33
  291. package/src/module/user/service/login.service.ts +280 -280
  292. package/src/module/user/service/role.service.ts +189 -189
  293. package/src/module/user/service/user-role-mapping.service.ts +98 -98
  294. package/src/module/user/service/user-session.service.ts +168 -168
  295. package/src/module/user/service/user.service.ts +353 -353
  296. package/src/module/user/user.module.ts +65 -65
  297. package/src/module/workflow/controller/action-category.controller.ts +54 -54
  298. package/src/module/workflow/controller/action-resource-mapping.controller.ts +23 -23
  299. package/src/module/workflow/controller/action-template-mapping.controller.ts +35 -35
  300. package/src/module/workflow/controller/action.controller.ts +95 -95
  301. package/src/module/workflow/controller/activity-log.controller.ts +55 -55
  302. package/src/module/workflow/controller/comm-template.controller.ts +34 -34
  303. package/src/module/workflow/controller/entity-modification.controller.ts +35 -35
  304. package/src/module/workflow/controller/form-master.controller.ts +43 -43
  305. package/src/module/workflow/controller/stage-group.controller.ts +48 -48
  306. package/src/module/workflow/controller/stage.controller.ts +50 -50
  307. package/src/module/workflow/controller/task.controller.ts +77 -77
  308. package/src/module/workflow/controller/workflow-list-master.controller.ts +44 -44
  309. package/src/module/workflow/controller/workflow-meta.controller.ts +80 -80
  310. package/src/module/workflow/controller/workflow.controller.ts +67 -67
  311. package/src/module/workflow/entity/action-category.entity.ts +38 -38
  312. package/src/module/workflow/entity/action-data.entity.ts +55 -55
  313. package/src/module/workflow/entity/action-resources-mapping.entity.ts +29 -29
  314. package/src/module/workflow/entity/action-template-mapping.entity.ts +17 -17
  315. package/src/module/workflow/entity/action.entity.ts +50 -50
  316. package/src/module/workflow/entity/activity-log.entity.ts +43 -43
  317. package/src/module/workflow/entity/comm-template.entity.ts +43 -43
  318. package/src/module/workflow/entity/entity-modification.entity.ts +38 -38
  319. package/src/module/workflow/entity/form.entity.ts +25 -25
  320. package/src/module/workflow/entity/stage-action-mapping.entity.ts +17 -17
  321. package/src/module/workflow/entity/stage-group.entity.ts +23 -23
  322. package/src/module/workflow/entity/stage-movement-data.entity.ts +38 -38
  323. package/src/module/workflow/entity/stage.entity.ts +20 -20
  324. package/src/module/workflow/entity/task-data.entity.ts +88 -88
  325. package/src/module/workflow/entity/template-attach-mapper.entity.ts +30 -30
  326. package/src/module/workflow/entity/workflow-data.entity.ts +11 -11
  327. package/src/module/workflow/entity/workflow-level-mapping.entity.ts +18 -18
  328. package/src/module/workflow/entity/workflow.entity.ts +20 -20
  329. package/src/module/workflow/repository/action-category.repository.ts +79 -79
  330. package/src/module/workflow/repository/action-data.repository.ts +219 -219
  331. package/src/module/workflow/repository/action.repository.ts +277 -277
  332. package/src/module/workflow/repository/activity-log.repository.ts +121 -121
  333. package/src/module/workflow/repository/comm-template.repository.ts +142 -142
  334. package/src/module/workflow/repository/form-master.repository.ts +59 -59
  335. package/src/module/workflow/repository/stage-group.repository.ts +176 -176
  336. package/src/module/workflow/repository/stage-movement.repository.ts +227 -227
  337. package/src/module/workflow/repository/stage.repository.ts +172 -172
  338. package/src/module/workflow/repository/task.repository.ts +117 -117
  339. package/src/module/workflow/repository/workflow.repository.ts +42 -42
  340. package/src/module/workflow/service/action-category.service.ts +33 -33
  341. package/src/module/workflow/service/action-data.service.ts +62 -62
  342. package/src/module/workflow/service/action-resources-mapping.service.ts +10 -10
  343. package/src/module/workflow/service/action-template-mapping.service.ts +55 -55
  344. package/src/module/workflow/service/action.service.ts +263 -263
  345. package/src/module/workflow/service/activity-log.service.ts +107 -107
  346. package/src/module/workflow/service/comm-template.service.ts +121 -121
  347. package/src/module/workflow/service/entity-modification.service.ts +67 -67
  348. package/src/module/workflow/service/form-master.service.ts +35 -35
  349. package/src/module/workflow/service/populate-workflow.service.ts +303 -303
  350. package/src/module/workflow/service/stage-action-mapping.service.ts +5 -5
  351. package/src/module/workflow/service/stage-group.service.ts +330 -330
  352. package/src/module/workflow/service/stage.service.ts +199 -199
  353. package/src/module/workflow/service/task.service.ts +531 -531
  354. package/src/module/workflow/service/workflow-list-master.service.ts +60 -60
  355. package/src/module/workflow/service/workflow-meta.service.ts +581 -581
  356. package/src/module/workflow/service/workflow.service.ts +205 -205
  357. package/src/module/workflow/workflow.module.ts +172 -172
  358. package/src/module/workflow-automation/controller/workflow-automation.controller.ts +21 -21
  359. package/src/module/workflow-automation/entity/workflow-automation-action.entity.ts +26 -26
  360. package/src/module/workflow-automation/entity/workflow-automation.entity.ts +35 -35
  361. package/src/module/workflow-automation/interface/action.decorator.ts +7 -7
  362. package/src/module/workflow-automation/interface/action.interface.ts +5 -5
  363. package/src/module/workflow-automation/service/action-registery.service.ts +35 -35
  364. package/src/module/workflow-automation/service/workflow-automation-engine.service.ts +214 -214
  365. package/src/module/workflow-automation/service/workflow-automation.service.ts +345 -345
  366. package/src/module/workflow-automation/workflow-automation.module.ts +34 -34
  367. package/src/resources/dev.properties.yaml +30 -30
  368. package/src/resources/local.properties.yaml +27 -27
  369. package/src/resources/properties.module.ts +12 -12
  370. package/src/resources/properties.yaml.ts +11 -11
  371. package/src/resources/uat.properties.yaml +15 -15
  372. package/src/utils/dto/excel-data.dto.ts +14 -14
  373. package/src/utils/dto/excelsheet-data.dto.ts +5 -5
  374. package/src/utils/service/base64util.service.ts +18 -18
  375. package/src/utils/service/clockIDGenUtil.service.ts +21 -21
  376. package/src/utils/service/codeGenerator.service.ts +22 -22
  377. package/src/utils/service/dateUtil.service.ts +17 -17
  378. package/src/utils/service/encryptUtil.service.ts +97 -97
  379. package/src/utils/service/excel-helper.service.ts +72 -72
  380. package/src/utils/service/excelUtil.service.ts +15 -15
  381. package/src/utils/service/file-util.service.ts +11 -11
  382. package/src/utils/service/json-util.service.ts +23 -23
  383. package/src/utils/service/loggingUtil.service.ts +34 -34
  384. package/src/utils/service/reflection-helper.service.ts +62 -62
  385. package/src/utils/service/wbsCodeGen.service.ts +8 -8
  386. package/src/utils/utils.module.ts +25 -25
  387. package/tsconfig.build.json +4 -4
  388. package/tsconfig.json +24 -24
  389. 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
+ }