rez_core 3.1.110 → 3.1.112

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