rez_core 3.1.200 → 3.1.202

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