rez_core 4.0.136 → 4.0.138

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 (438) hide show
  1. package/.prettierrc +3 -3
  2. package/README.md +99 -99
  3. package/dist/config/config.module.js +2 -2
  4. package/dist/config/config.module.js.map +1 -1
  5. package/dist/config/database.config.d.ts +1 -1
  6. package/dist/config/database.config.js +12 -15
  7. package/dist/config/database.config.js.map +1 -1
  8. package/dist/module/auth/guards/role.guard.js +3 -3
  9. package/dist/module/auth/services/auth.service.js +3 -3
  10. package/dist/module/auth/services/auth.service.js.map +1 -1
  11. package/dist/module/enterprise/entity/organization.entity.js +1 -1
  12. package/dist/module/filter/repository/saved-filter.repository.js +4 -4
  13. package/dist/module/filter/service/filter-evaluator.service.js +2 -2
  14. package/dist/module/filter/service/filter.service.js +22 -22
  15. package/dist/module/integration/entity/integration-config.entity.js +6 -6
  16. package/dist/module/integration/entity/integration-config.entity.js.map +1 -1
  17. package/dist/module/integration/entity/integration-entity-mapper.entity.js +1 -1
  18. package/dist/module/integration/entity/integration-entity-mapper.entity.js.map +1 -1
  19. package/dist/module/integration/entity/integration-source.entity.js +4 -4
  20. package/dist/module/integration/entity/integration-source.entity.js.map +1 -1
  21. package/dist/module/integration/entity/user-integration.entity.js +4 -4
  22. package/dist/module/integration/entity/user-integration.entity.js.map +1 -1
  23. package/dist/module/integration/examples/usage.example.js +9 -9
  24. package/dist/module/integration/service/integration.service.js +1 -1
  25. package/dist/module/integration/service/wrapper.service.d.ts +3 -1
  26. package/dist/module/integration/service/wrapper.service.js +64 -61
  27. package/dist/module/integration/service/wrapper.service.js.map +1 -1
  28. package/dist/module/listmaster/entity/list-master-items.entity.js +3 -3
  29. package/dist/module/listmaster/entity/list-master-items.entity.js.map +1 -1
  30. package/dist/module/listmaster/entity/list-master.entity.js +4 -4
  31. package/dist/module/listmaster/entity/list-master.entity.js.map +1 -1
  32. package/dist/module/listmaster/service/list-master-item.service.js +2 -2
  33. package/dist/module/mapper/entity/field-mapper.entity.js +6 -6
  34. package/dist/module/mapper/entity/field-mapper.entity.js.map +1 -1
  35. package/dist/module/mapper/service/field-mapper.service.js +6 -6
  36. package/dist/module/mapper/service/field-mapper.service.js.map +1 -1
  37. package/dist/module/mapper/service/mapper.service.js +2 -2
  38. package/dist/module/meta/entity/entity-master.entity.js +1 -1
  39. package/dist/module/meta/entity/entity-master.entity.js.map +1 -1
  40. package/dist/module/meta/entity/view-master.entity.js +1 -1
  41. package/dist/module/meta/entity/view-master.entity.js.map +1 -1
  42. package/dist/module/meta/service/attribute-master.service.js +1 -1
  43. package/dist/module/meta/service/attribute-master.service.js.map +1 -1
  44. package/dist/module/meta/service/entity-dynamic.service.js +9 -9
  45. package/dist/module/meta/service/entity-list.service.js +3 -3
  46. package/dist/module/meta/service/entity-master.service.js +3 -3
  47. package/dist/module/meta/service/entity-relation.service.js +11 -11
  48. package/dist/module/meta/service/entity-service-impl.service.js +3 -3
  49. package/dist/module/meta/service/resolver.service.js +5 -5
  50. package/dist/module/meta/service/resolver.service.js.map +1 -1
  51. package/dist/module/module/repository/menu.repository.js +13 -13
  52. package/dist/module/module/repository/menu.repository.js.map +1 -1
  53. package/dist/module/notification/entity/otp.entity.js +1 -1
  54. package/dist/module/notification/entity/otp.entity.js.map +1 -1
  55. package/dist/module/notification/service/notification.service.js +9 -9
  56. package/dist/module/user/controller/login.controller.js +18 -18
  57. package/dist/module/user/entity/user-role-mapping.entity.js +1 -1
  58. package/dist/module/user/entity/user-role-mapping.entity.js.map +1 -1
  59. package/dist/module/user/service/role.service.js +4 -4
  60. package/dist/module/user/service/user-session.service.js +2 -2
  61. package/dist/module/workflow/entity/action-data.entity.js +1 -1
  62. package/dist/module/workflow/entity/action-data.entity.js.map +1 -1
  63. package/dist/module/workflow/entity/action.entity.js +1 -1
  64. package/dist/module/workflow/entity/action.entity.js.map +1 -1
  65. package/dist/module/workflow/entity/comm-template.entity.js +1 -1
  66. package/dist/module/workflow/entity/comm-template.entity.js.map +1 -1
  67. package/dist/module/workflow/repository/action.repository.js +20 -20
  68. package/dist/module/workflow/repository/comm-template.repository.js +6 -6
  69. package/dist/module/workflow/repository/form-master.repository.js +2 -2
  70. package/dist/module/workflow/repository/stage-group.repository.js +23 -23
  71. package/dist/module/workflow/repository/stage-movement.repository.js +15 -15
  72. package/dist/module/workflow/repository/stage.repository.js +8 -8
  73. package/dist/module/workflow/repository/task.repository.d.ts +3 -1
  74. package/dist/module/workflow/repository/task.repository.js +8 -3
  75. package/dist/module/workflow/repository/task.repository.js.map +1 -1
  76. package/dist/module/workflow/service/action-template-mapping.service.js +22 -22
  77. package/dist/module/workflow/service/action.service.js +7 -7
  78. package/dist/module/workflow/service/entity-modification.service.js +6 -6
  79. package/dist/module/workflow/service/stage-group.service.js +2 -2
  80. package/dist/module/workflow/service/stage.service.js +2 -2
  81. package/dist/module/workflow/service/task.service.js +36 -41
  82. package/dist/module/workflow/service/task.service.js.map +1 -1
  83. package/dist/module/workflow/service/workflow-list-master.service.js +15 -15
  84. package/dist/module/workflow/service/workflow-meta.service.js +49 -47
  85. package/dist/module/workflow/service/workflow-meta.service.js.map +1 -1
  86. package/dist/module/workflow/service/workflow.service.js +2 -2
  87. package/dist/tsconfig.build.tsbuildinfo +1 -1
  88. package/dist/utils/service/loggingUtil.service.d.ts +9 -2
  89. package/dist/utils/service/loggingUtil.service.js +65 -14
  90. package/dist/utils/service/loggingUtil.service.js.map +1 -1
  91. package/dist/utils/service/reflection-helper.service.js +2 -2
  92. package/dist/utils/utils.module.js +2 -0
  93. package/dist/utils/utils.module.js.map +1 -1
  94. package/docs/modules/event-driven-integration-design.md +91 -91
  95. package/docs/modules/integration.md +250 -250
  96. package/eslint.config.mjs +34 -34
  97. package/nest-cli.json +14 -14
  98. package/package.json +119 -120
  99. package/src/app.controller.ts +12 -12
  100. package/src/app.module.ts +52 -52
  101. package/src/app.service.ts +8 -8
  102. package/src/config/config.module.ts +18 -17
  103. package/src/config/database.config.ts +23 -47
  104. package/src/constant/global.constant.ts +67 -67
  105. package/src/core.module.ts +81 -81
  106. package/src/decorators/roles.decorator.ts +7 -7
  107. package/src/dtos/response.dto.ts +6 -6
  108. package/src/dtos/response.ts +5 -5
  109. package/src/index.ts +1 -1
  110. package/src/module/auth/auth.module.ts +49 -49
  111. package/src/module/auth/controller/auth.controller.ts +28 -28
  112. package/src/module/auth/guards/google-auth.guard.ts +9 -9
  113. package/src/module/auth/guards/jwt.guard.ts +22 -22
  114. package/src/module/auth/guards/role.guard.ts +68 -68
  115. package/src/module/auth/services/auth.service.ts +50 -50
  116. package/src/module/auth/services/jwt.service.ts +11 -11
  117. package/src/module/auth/strategies/google.strategy.ts +54 -54
  118. package/src/module/auth/strategies/jwt.strategy.ts +58 -58
  119. package/src/module/auth/strategies/local.strategy.ts +13 -13
  120. package/src/module/dashboard/controller/dashboard.controller.ts +36 -36
  121. package/src/module/dashboard/dashboard.module.ts +21 -21
  122. package/src/module/dashboard/entity/dashboard_page_data.entity.ts +27 -27
  123. package/src/module/dashboard/entity/widget_master.entity.ts +18 -18
  124. package/src/module/dashboard/repository/dashboard.repository.ts +42 -42
  125. package/src/module/dashboard/service/dashboard.service.ts +73 -73
  126. package/src/module/dev/dev.module.ts +12 -12
  127. package/src/module/dev/service/dev.service.ts +7 -7
  128. package/src/module/enterprise/controller/organization.controller.ts +36 -36
  129. package/src/module/enterprise/enterprise.module.ts +30 -30
  130. package/src/module/enterprise/entity/enterprise.entity.ts +37 -37
  131. package/src/module/enterprise/entity/organization-app-mapping.entity.ts +13 -13
  132. package/src/module/enterprise/entity/organization.entity.ts +92 -92
  133. package/src/module/enterprise/repository/enterprise.repository.ts +31 -31
  134. package/src/module/enterprise/repository/organization.repository.ts +26 -26
  135. package/src/module/enterprise/repository/school.repository.ts +278 -278
  136. package/src/module/enterprise/service/brand.service.ts +5 -5
  137. package/src/module/enterprise/service/enterprise.service.ts +16 -16
  138. package/src/module/enterprise/service/organization-app-mapping.service.ts +4 -4
  139. package/src/module/enterprise/service/organization.service.ts +145 -145
  140. package/src/module/filter/controller/filter.controller.ts +84 -84
  141. package/src/module/filter/dto/filter-request.dto.ts +38 -38
  142. package/src/module/filter/entity/saved-filter-detail.entity.ts +41 -41
  143. package/src/module/filter/entity/saved-filter-master.entity.ts +23 -23
  144. package/src/module/filter/filter.module.ts +31 -31
  145. package/src/module/filter/repository/saved-filter.repository.ts +168 -168
  146. package/src/module/filter/service/filter-evaluator.service.ts +86 -86
  147. package/src/module/filter/service/filter.service.ts +1005 -1005
  148. package/src/module/filter/service/saved-filter.service.ts +170 -170
  149. package/src/module/ics/controller/ics.controller.ts +21 -21
  150. package/src/module/ics/dto/ics.dto.ts +55 -55
  151. package/src/module/ics/ics.module.ts +13 -13
  152. package/src/module/ics/service/ics.service.ts +57 -57
  153. package/src/module/integration/controller/calender-event.controller.ts +31 -31
  154. package/src/module/integration/controller/integration.controller.ts +662 -662
  155. package/src/module/integration/controller/wrapper.controller.ts +37 -37
  156. package/src/module/integration/dto/create-config.dto.ts +526 -526
  157. package/src/module/integration/entity/integration-config.entity.ts +112 -112
  158. package/src/module/integration/entity/integration-entity-mapper.entity.ts +14 -14
  159. package/src/module/integration/entity/integration-source.entity.ts +17 -17
  160. package/src/module/integration/entity/user-integration.entity.ts +71 -71
  161. package/src/module/integration/examples/usage.example.ts +338 -338
  162. package/src/module/integration/factories/base.factory.ts +7 -7
  163. package/src/module/integration/factories/email.factory.ts +49 -49
  164. package/src/module/integration/factories/integration.factory.ts +121 -121
  165. package/src/module/integration/factories/sms.factory.ts +51 -51
  166. package/src/module/integration/factories/telephone.factory.ts +41 -41
  167. package/src/module/integration/factories/whatsapp.factory.ts +56 -56
  168. package/src/module/integration/integration.module.ts +110 -110
  169. package/src/module/integration/service/calendar-event.service.ts +118 -118
  170. package/src/module/integration/service/integration-entity-mapper.service.ts +17 -17
  171. package/src/module/integration/service/integration-queue.service.ts +229 -229
  172. package/src/module/integration/service/integration.service.ts +2633 -2633
  173. package/src/module/integration/service/oauth.service.ts +224 -224
  174. package/src/module/integration/service/wrapper.service.ts +700 -493
  175. package/src/module/integration/strategies/email/gmail-api.strategy.ts +280 -280
  176. package/src/module/integration/strategies/email/outlook-api.strategy.ts +44 -44
  177. package/src/module/integration/strategies/email/outlook.strategy.ts +64 -64
  178. package/src/module/integration/strategies/email/sendgrid-api.strategy.ts +260 -260
  179. package/src/module/integration/strategies/integration.strategy.ts +97 -97
  180. package/src/module/integration/strategies/sms/gupshup-sms.strategy.ts +146 -146
  181. package/src/module/integration/strategies/sms/msg91-sms.strategy.ts +164 -164
  182. package/src/module/integration/strategies/sms/tubelight-sms.strategy.ts +163 -163
  183. package/src/module/integration/strategies/telephone/ozonetel-voice.strategy.ts +238 -238
  184. package/src/module/integration/strategies/telephone/tubelight-voice.strategy.ts +210 -210
  185. package/src/module/integration/strategies/whatsapp/gupshup-whatsapp.strategy.ts +359 -359
  186. package/src/module/integration/strategies/whatsapp/tubelight-whatsapp.strategy.ts +372 -372
  187. package/src/module/integration/strategies/whatsapp/whatsapp-cloud.strategy.ts +403 -403
  188. package/src/module/integration/strategies/whatsapp/whatsapp.strategy.ts +57 -57
  189. package/src/module/layout/controller/layout.controller.ts +47 -47
  190. package/src/module/layout/entity/header-items.entity.ts +28 -28
  191. package/src/module/layout/entity/header-section.entity.ts +19 -19
  192. package/src/module/layout/layout.module.ts +21 -21
  193. package/src/module/layout/repository/header-items.repository.ts +18 -18
  194. package/src/module/layout/repository/header-section.repository.ts +22 -22
  195. package/src/module/layout/service/header-section.service.ts +25 -25
  196. package/src/module/layout_preference/controller/layout_preference.controller.ts +73 -73
  197. package/src/module/layout_preference/entity/layout_preference.entity.ts +28 -28
  198. package/src/module/layout_preference/layout_preference.module.ts +22 -22
  199. package/src/module/layout_preference/repository/layout_preference.repository.ts +65 -65
  200. package/src/module/layout_preference/service/layout_preference.service.ts +191 -191
  201. package/src/module/lead/controller/lead.controller.ts +30 -30
  202. package/src/module/lead/lead.module.ts +14 -14
  203. package/src/module/lead/repository/lead.repository.ts +41 -41
  204. package/src/module/lead/service/lead.service.ts +54 -54
  205. package/src/module/listmaster/controller/list-master.controller.ts +230 -230
  206. package/src/module/listmaster/entity/list-master-items.entity.ts +43 -43
  207. package/src/module/listmaster/entity/list-master.entity.ts +33 -33
  208. package/src/module/listmaster/listmaster.module.ts +46 -46
  209. package/src/module/listmaster/repository/list-master-items.repository.ts +169 -169
  210. package/src/module/listmaster/repository/list-master.repository.ts +46 -46
  211. package/src/module/listmaster/service/list-master-engine.ts +19 -19
  212. package/src/module/listmaster/service/list-master-extension.interface.ts +4 -4
  213. package/src/module/listmaster/service/list-master-item.service.ts +292 -292
  214. package/src/module/listmaster/service/list-master-registry.ts +15 -15
  215. package/src/module/listmaster/service/list-master.service.ts +535 -535
  216. package/src/module/mapper/controller/field-mapper.controller.ts +76 -76
  217. package/src/module/mapper/controller/mapper.controller.ts +20 -20
  218. package/src/module/mapper/dto/field-mapper.dto.ts +14 -14
  219. package/src/module/mapper/entity/field-lovs.entity.ts +19 -19
  220. package/src/module/mapper/entity/field-mapper.entity.ts +53 -53
  221. package/src/module/mapper/entity/mapper.entity.ts +16 -16
  222. package/src/module/mapper/mapper.module.ts +34 -34
  223. package/src/module/mapper/repository/field-lovs.repository.ts +35 -35
  224. package/src/module/mapper/repository/field-mapper.repository.ts +42 -42
  225. package/src/module/mapper/repository/mapper.repository.ts +15 -15
  226. package/src/module/mapper/service/field-mapper.service.ts +271 -266
  227. package/src/module/mapper/service/mapper.service.ts +79 -79
  228. package/src/module/master/controller/master.controller.ts +74 -74
  229. package/src/module/master/service/master.service.ts +483 -483
  230. package/src/module/meta/controller/app-master.controller.ts +38 -38
  231. package/src/module/meta/controller/attribute-master.controller.ts +66 -66
  232. package/src/module/meta/controller/entity-dynamic.controller.ts +125 -125
  233. package/src/module/meta/controller/entity-master.controller.ts +28 -28
  234. package/src/module/meta/controller/entity-relation.controller.ts +36 -36
  235. package/src/module/meta/controller/entity.controller.ts +392 -392
  236. package/src/module/meta/controller/entity.public.controller.ts +75 -75
  237. package/src/module/meta/controller/media.controller.ts +107 -107
  238. package/src/module/meta/controller/meta.controller.ts +96 -96
  239. package/src/module/meta/controller/view-master.controller.ts +86 -86
  240. package/src/module/meta/dto/entity-list-data.dto.ts +6 -6
  241. package/src/module/meta/dto/entity-tab.dto.ts +4 -4
  242. package/src/module/meta/dto/entity-table.dto.ts +9 -9
  243. package/src/module/meta/entity/app-master.entity.ts +34 -34
  244. package/src/module/meta/entity/attribute-master.entity.ts +89 -89
  245. package/src/module/meta/entity/base-entity.entity.ts +75 -75
  246. package/src/module/meta/entity/entity-master.entity.ts +85 -85
  247. package/src/module/meta/entity/entity-relation-data.entity.ts +29 -29
  248. package/src/module/meta/entity/entity-relation.entity.ts +23 -23
  249. package/src/module/meta/entity/entity-table-column.entity.ts +61 -61
  250. package/src/module/meta/entity/entity-table.entity.ts +50 -50
  251. package/src/module/meta/entity/media-data.entity.ts +32 -32
  252. package/src/module/meta/entity/preference.entity.ts +62 -62
  253. package/src/module/meta/entity/view-master.entity.ts +41 -41
  254. package/src/module/meta/entity.module.ts +158 -158
  255. package/src/module/meta/repository/app-master.repository.ts +20 -20
  256. package/src/module/meta/repository/attribute-master.repository.ts +118 -118
  257. package/src/module/meta/repository/entity-master.repository.ts +69 -69
  258. package/src/module/meta/repository/entity-table-column.repository.ts +39 -39
  259. package/src/module/meta/repository/entity-table.repository.ts +53 -53
  260. package/src/module/meta/repository/media-data.repository.ts +50 -50
  261. package/src/module/meta/repository/preference.repository.ts +20 -20
  262. package/src/module/meta/repository/user-app-mapping.repository.ts +28 -28
  263. package/src/module/meta/repository/view-master.repository.ts +42 -42
  264. package/src/module/meta/service/app-master.service.ts +37 -37
  265. package/src/module/meta/service/attribute-master.service.ts +126 -126
  266. package/src/module/meta/service/common.service.ts +9 -9
  267. package/src/module/meta/service/entity-dynamic.service.ts +819 -819
  268. package/src/module/meta/service/entity-list.service.ts +205 -205
  269. package/src/module/meta/service/entity-master.service.ts +169 -169
  270. package/src/module/meta/service/entity-realation-data.service.ts +9 -9
  271. package/src/module/meta/service/entity-relation.service.ts +69 -69
  272. package/src/module/meta/service/entity-service-impl.service.ts +525 -525
  273. package/src/module/meta/service/entity-table-column.service.ts +39 -39
  274. package/src/module/meta/service/entity-table.service.ts +150 -150
  275. package/src/module/meta/service/entity-validation.service.ts +187 -187
  276. package/src/module/meta/service/entity.service.ts +67 -67
  277. package/src/module/meta/service/field-group.service.ts +103 -103
  278. package/src/module/meta/service/media-data.service.ts +507 -507
  279. package/src/module/meta/service/populate-meta.service.ts +193 -193
  280. package/src/module/meta/service/preference.service.ts +16 -16
  281. package/src/module/meta/service/resolver.service.ts +267 -267
  282. package/src/module/meta/service/section-master.service.ts +104 -104
  283. package/src/module/meta/service/update-form-json.service.ts +22 -22
  284. package/src/module/meta/service/user-app-mapping.service.ts +17 -17
  285. package/src/module/meta/service/view-master.service.ts +127 -127
  286. package/src/module/microservice-client/microservice-clients.module.ts +13 -13
  287. package/src/module/microservice-client/service/microservice-client-factory.ts +37 -37
  288. package/src/module/microservice-client/service/microservice-clients.ts +4 -4
  289. package/src/module/module/controller/menu.controller.ts +15 -15
  290. package/src/module/module/controller/module-access.controller.ts +134 -134
  291. package/src/module/module/entity/menu.entity.ts +43 -43
  292. package/src/module/module/entity/module-access.entity.ts +25 -25
  293. package/src/module/module/entity/module-action.entity.ts +17 -17
  294. package/src/module/module/entity/module.entity.ts +52 -52
  295. package/src/module/module/module.module.ts +42 -42
  296. package/src/module/module/repository/menu.repository.ts +184 -184
  297. package/src/module/module/repository/module-access.repository.ts +344 -344
  298. package/src/module/module/service/menu.service.ts +82 -82
  299. package/src/module/module/service/module-access.service.ts +209 -209
  300. package/src/module/notification/controller/notification.controller.ts +58 -58
  301. package/src/module/notification/controller/otp.controller.ts +117 -117
  302. package/src/module/notification/entity/notification.entity.ts +26 -26
  303. package/src/module/notification/entity/otp.entity.ts +28 -28
  304. package/src/module/notification/firebase-admin.config.ts +22 -22
  305. package/src/module/notification/notification.module.ts +69 -69
  306. package/src/module/notification/repository/otp.repository.ts +27 -27
  307. package/src/module/notification/service/email.service.ts +127 -127
  308. package/src/module/notification/service/notification.service.ts +163 -163
  309. package/src/module/notification/service/otp.service.ts +132 -132
  310. package/src/module/third-party-module/entity/third-party-api-registry.entity.ts +52 -52
  311. package/src/module/third-party-module/repository/third-party-api-registry.repository.ts +20 -20
  312. package/src/module/third-party-module/service/api-registry.service.ts +13 -13
  313. package/src/module/third-party-module/third-party.module.ts +12 -12
  314. package/src/module/user/controller/login.controller.ts +197 -197
  315. package/src/module/user/controller/user.controller.ts +40 -40
  316. package/src/module/user/dto/create-user.dto.ts +62 -62
  317. package/src/module/user/dto/update-user.dto.ts +4 -4
  318. package/src/module/user/entity/role.entity.ts +33 -33
  319. package/src/module/user/entity/user-role-mapping.entity.ts +38 -38
  320. package/src/module/user/entity/user-session.entity.ts +73 -73
  321. package/src/module/user/entity/user.entity.ts +59 -59
  322. package/src/module/user/repository/role.repository.ts +96 -96
  323. package/src/module/user/repository/user-role-mapping.repository.ts +126 -126
  324. package/src/module/user/repository/user.repository.ts +50 -50
  325. package/src/module/user/repository/userSession.repository.ts +33 -33
  326. package/src/module/user/service/login.service.ts +304 -304
  327. package/src/module/user/service/role.service.ts +189 -189
  328. package/src/module/user/service/user-role-mapping.service.ts +98 -98
  329. package/src/module/user/service/user-session.service.ts +168 -168
  330. package/src/module/user/service/user.service.ts +365 -365
  331. package/src/module/user/user.module.ts +65 -65
  332. package/src/module/workflow/controller/action-category.controller.ts +54 -54
  333. package/src/module/workflow/controller/action-resource-mapping.controller.ts +23 -23
  334. package/src/module/workflow/controller/action-template-mapping.controller.ts +35 -35
  335. package/src/module/workflow/controller/action.controller.ts +111 -111
  336. package/src/module/workflow/controller/activity-log.controller.ts +55 -55
  337. package/src/module/workflow/controller/comm-template.controller.ts +43 -43
  338. package/src/module/workflow/controller/entity-modification.controller.ts +35 -35
  339. package/src/module/workflow/controller/form-master.controller.ts +43 -43
  340. package/src/module/workflow/controller/stage-group.controller.ts +48 -48
  341. package/src/module/workflow/controller/stage.controller.ts +50 -50
  342. package/src/module/workflow/controller/task.controller.ts +77 -77
  343. package/src/module/workflow/controller/workflow-list-master.controller.ts +44 -44
  344. package/src/module/workflow/controller/workflow-meta.controller.ts +80 -80
  345. package/src/module/workflow/controller/workflow.controller.ts +67 -67
  346. package/src/module/workflow/entity/action-category.entity.ts +38 -38
  347. package/src/module/workflow/entity/action-data.entity.ts +55 -55
  348. package/src/module/workflow/entity/action-resources-mapping.entity.ts +29 -29
  349. package/src/module/workflow/entity/action-template-mapping.entity.ts +17 -17
  350. package/src/module/workflow/entity/action.entity.ts +50 -50
  351. package/src/module/workflow/entity/activity-log.entity.ts +43 -43
  352. package/src/module/workflow/entity/comm-template.entity.ts +43 -43
  353. package/src/module/workflow/entity/entity-modification.entity.ts +38 -38
  354. package/src/module/workflow/entity/form.entity.ts +25 -25
  355. package/src/module/workflow/entity/stage-action-mapping.entity.ts +17 -17
  356. package/src/module/workflow/entity/stage-group.entity.ts +23 -23
  357. package/src/module/workflow/entity/stage-movement-data.entity.ts +38 -38
  358. package/src/module/workflow/entity/stage.entity.ts +20 -20
  359. package/src/module/workflow/entity/task-data.entity.ts +88 -88
  360. package/src/module/workflow/entity/template-attach-mapper.entity.ts +30 -30
  361. package/src/module/workflow/entity/workflow-data.entity.ts +11 -11
  362. package/src/module/workflow/entity/workflow-level-mapping.entity.ts +18 -18
  363. package/src/module/workflow/entity/workflow.entity.ts +20 -20
  364. package/src/module/workflow/repository/action-category.repository.ts +79 -79
  365. package/src/module/workflow/repository/action-data.repository.ts +333 -333
  366. package/src/module/workflow/repository/action.repository.ts +323 -323
  367. package/src/module/workflow/repository/activity-log.repository.ts +148 -148
  368. package/src/module/workflow/repository/comm-template.repository.ts +149 -149
  369. package/src/module/workflow/repository/form-master.repository.ts +59 -59
  370. package/src/module/workflow/repository/stage-group.repository.ts +176 -176
  371. package/src/module/workflow/repository/stage-movement.repository.ts +244 -244
  372. package/src/module/workflow/repository/stage.repository.ts +172 -172
  373. package/src/module/workflow/repository/task.repository.ts +134 -127
  374. package/src/module/workflow/repository/workflow.repository.ts +42 -42
  375. package/src/module/workflow/service/action-category.service.ts +33 -33
  376. package/src/module/workflow/service/action-data.service.ts +62 -62
  377. package/src/module/workflow/service/action-resources-mapping.service.ts +10 -10
  378. package/src/module/workflow/service/action-template-mapping.service.ts +106 -106
  379. package/src/module/workflow/service/action.service.ts +279 -279
  380. package/src/module/workflow/service/activity-log.service.ts +107 -107
  381. package/src/module/workflow/service/comm-template.service.ts +180 -180
  382. package/src/module/workflow/service/entity-modification.service.ts +67 -67
  383. package/src/module/workflow/service/form-master.service.ts +35 -35
  384. package/src/module/workflow/service/populate-workflow.service.ts +303 -303
  385. package/src/module/workflow/service/stage-action-mapping.service.ts +5 -5
  386. package/src/module/workflow/service/stage-group.service.ts +319 -319
  387. package/src/module/workflow/service/stage.service.ts +199 -199
  388. package/src/module/workflow/service/task.service.ts +547 -560
  389. package/src/module/workflow/service/workflow-list-master.service.ts +60 -60
  390. package/src/module/workflow/service/workflow-meta.service.ts +654 -640
  391. package/src/module/workflow/service/workflow.service.ts +205 -205
  392. package/src/module/workflow/workflow.module.ts +176 -176
  393. package/src/module/workflow-automation/controller/workflow-automation.controller.ts +21 -21
  394. package/src/module/workflow-automation/entity/workflow-automation-action.entity.ts +26 -26
  395. package/src/module/workflow-automation/entity/workflow-automation.entity.ts +35 -35
  396. package/src/module/workflow-automation/interface/action.decorator.ts +7 -7
  397. package/src/module/workflow-automation/interface/action.interface.ts +5 -5
  398. package/src/module/workflow-automation/service/action-registery.service.ts +35 -35
  399. package/src/module/workflow-automation/service/workflow-automation-engine.service.ts +214 -214
  400. package/src/module/workflow-automation/service/workflow-automation.service.ts +347 -347
  401. package/src/module/workflow-automation/workflow-automation.module.ts +34 -34
  402. package/src/resources/dev.properties.yaml +30 -31
  403. package/src/resources/local.properties.yaml +27 -27
  404. package/src/resources/properties.module.ts +12 -12
  405. package/src/resources/properties.yaml.ts +11 -11
  406. package/src/resources/uat.properties.yaml +31 -31
  407. package/src/table.config.ts +126 -126
  408. package/src/utils/dto/excel-data.dto.ts +14 -14
  409. package/src/utils/dto/excelsheet-data.dto.ts +5 -5
  410. package/src/utils/service/base64util.service.ts +18 -18
  411. package/src/utils/service/clockIDGenUtil.service.ts +21 -21
  412. package/src/utils/service/codeGenerator.service.ts +22 -22
  413. package/src/utils/service/dateUtil.service.ts +17 -17
  414. package/src/utils/service/encryptUtil.service.ts +97 -97
  415. package/src/utils/service/excel-helper.service.ts +72 -72
  416. package/src/utils/service/excelUtil.service.ts +15 -15
  417. package/src/utils/service/file-util.service.ts +11 -11
  418. package/src/utils/service/json-util.service.ts +23 -23
  419. package/src/utils/service/loggingUtil.service.ts +88 -34
  420. package/src/utils/service/reflection-helper.service.ts +62 -62
  421. package/src/utils/service/wbsCodeGen.service.ts +8 -8
  422. package/src/utils/utils.module.ts +27 -25
  423. package/tsconfig.build.json +4 -4
  424. package/tsconfig.json +24 -24
  425. package/.claude/settings.local.json +0 -26
  426. package/.idea/250218_nodejs_core.iml +0 -9
  427. package/.idea/codeStyles/Project.xml +0 -59
  428. package/.idea/codeStyles/codeStyleConfig.xml +0 -5
  429. package/.idea/copilot.data.migration.agent.xml +0 -6
  430. package/.idea/copilot.data.migration.ask.xml +0 -6
  431. package/.idea/copilot.data.migration.ask2agent.xml +0 -6
  432. package/.idea/copilot.data.migration.edit.xml +0 -6
  433. package/.idea/inspectionProfiles/Project_Default.xml +0 -6
  434. package/.idea/misc.xml +0 -6
  435. package/.idea/modules.xml +0 -8
  436. package/.idea/prettier.xml +0 -6
  437. package/.idea/vcs.xml +0 -6
  438. package/server.log +0 -850
@@ -1,483 +1,483 @@
1
- import { BadRequestException, Injectable } from '@nestjs/common';
2
- import { Brackets, EntityManager } from 'typeorm';
3
- import { ExcelUtil } from 'src/utils/service/excelUtil.service';
4
- import { EntityMasterService } from '../../meta/service/entity-master.service';
5
- import { AttributeMasterService } from 'src/module/meta/service/attribute-master.service';
6
- import { EntityMaster } from 'src/module/meta/entity/entity-master.entity';
7
- import { EntityServiceImpl } from 'src/module/meta/service/entity-service-impl.service';
8
- import { ReflectionHelper } from 'src/utils/service/reflection-helper.service';
9
- import { EntityValidationService } from 'src/module/meta/service/entity-validation.service';
10
-
11
- @Injectable()
12
- export class MasterService {
13
- constructor(
14
- private readonly entityManager: EntityManager,
15
- private readonly entityMasterService: EntityMasterService,
16
- private readonly attributeMasterService: AttributeMasterService,
17
- private readonly excelUtil: ExcelUtil,
18
- private reflectionHelper: ReflectionHelper,
19
-
20
- private readonly entityServiceImpl: EntityServiceImpl,
21
- protected readonly entityValidationService: EntityValidationService,
22
- ) {}
23
-
24
- // private readonly metaSheets = [
25
- // 'frm_entity_master',
26
- // 'frm_entity_attribute',
27
- // 'frm_list_master',
28
- // 'frm_list_master_items',
29
- // 'frm_entity_table',
30
- // 'frm_entity_table_column',
31
- // 'frm_entity_view',
32
- // ];
33
- private readonly sequence = [
34
- {
35
- table: 'frm_entity_master',
36
- unique_fields: ['id', 'organization_id'],
37
- },
38
- {
39
- table: 'frm_entity_attribute',
40
- unique_fields: ['mapped_entity_type', 'attribute_key', 'organization_id'],
41
- },
42
- {
43
- table: 'frm_list_master',
44
- unique_fields: ['type', 'organization_id'],
45
- },
46
- {
47
- table: 'frm_list_master_items',
48
- unique_fields: ['listtype', 'code', 'organization_id'],
49
- },
50
- {
51
- table: 'frm_entity_table',
52
- unique_fields: ['list_type', 'mapped_entity_type', 'organization_id'],
53
- },
54
- {
55
- table: 'frm_entity_table_column',
56
- unique_fields: [
57
- 'parent_id',
58
- 'parent_type',
59
- 'attribute_key',
60
- 'organization_id',
61
- ],
62
- },
63
- {
64
- table: 'frm_entity_view',
65
- unique_fields: ['mapped_entity_type', 'organization_id'],
66
- },
67
- {
68
- table: 'sso_user',
69
- unique_fields: ['organization_id'],
70
- },
71
- {
72
- table: 'sso_header_items',
73
- unique_fields: ['code', 'section_id', 'organization_id'],
74
- },
75
- {
76
- table: 'sso_module_access',
77
- unique_fields: ['module_code', 'action_type', 'role_code'],
78
- },
79
- {
80
- table: 'sso_module_action',
81
- unique_fields: ['module_code', 'action_type', 'organization_id'],
82
- },
83
- {
84
- table: 'sso_menu',
85
- unique_fields: ['module_code', 'organization_id'],
86
- },
87
- {
88
- table: 'sso_module',
89
- unique_fields: ['module_code', 'organization_id'],
90
- },
91
- {
92
- table: 'sso_role',
93
- unique_fields: ['code', 'organization_id'],
94
- },
95
- {
96
- table: 'sso_header_sections',
97
- unique_fields: ['section_name', 'organization_id'],
98
- },
99
- {
100
- table: 'sso_user_role_mapping',
101
- unique_fields: ['user_id', 'role_id', 'organization_id'],
102
- },
103
- {
104
- table: 'sso_organization',
105
- unique_fields: ['code'],
106
- },
107
- {
108
- table: 'eth_academic_year',
109
- unique_fields: ['code'],
110
- },
111
- ];
112
- private readonly dataSequence = [
113
- {
114
- table: 'sso_user',
115
- unique_fields: ['code'],
116
- },
117
- {
118
- table: 'sso_role',
119
- unique_fields: ['code'],
120
- },
121
- {
122
- table: 'sso_user_role_mapping',
123
- unique_fields: ['user_id', 'role_id'],
124
- },
125
- {
126
- table: 'eth_school',
127
- unique_fields: ['code'],
128
- },
129
- {
130
- table: 'eth_school_address',
131
- unique_fields: ['code'],
132
- },
133
- ];
134
-
135
- async uploadMeta(file) {
136
- const data = ExcelUtil.readExcel(file.buffer);
137
-
138
- for (let i = 0; i < this.sequence.length; i++) {
139
- const { table, unique_fields } = this.sequence[i];
140
- const sheetData = data[table];
141
-
142
- if (!sheetData) {
143
- console.log(`Sheet ${table} not found in the Excel file.`);
144
- continue;
145
- }
146
- console.log(`Processing sheet: ${table}`);
147
- await this.upsertData(table, unique_fields, sheetData);
148
- }
149
- return {
150
- message: 'Data uploaded successfully',
151
- };
152
- }
153
-
154
- async uploadData(file, loggedInUser) {
155
- const data = ExcelUtil.readExcel(file.buffer);
156
-
157
- for (let i = 0; i < this.dataSequence.length; i++) {
158
- const { table, unique_fields } = this.dataSequence[i];
159
- const sheetData = data[table];
160
-
161
- if (!sheetData) {
162
- console.log(`Sheet ${table} not found in the Excel file.`);
163
- continue;
164
- }
165
-
166
- const entityMasterData =
167
- await this.entityMasterService.getEntityByTableName(table);
168
-
169
- if (!entityMasterData) {
170
- throw new Error(`Entity master not found for table: ${table}`);
171
- }
172
-
173
- const attributes =
174
- await this.attributeMasterService.findAttributesByMappedEntityType(
175
- entityMasterData.mapped_entity_type,
176
- loggedInUser.organization_id,
177
- );
178
-
179
- for (const row of sheetData) {
180
- if (row.parent_type !== undefined && row.parent_id !== undefined) {
181
- this.resolveParent(row);
182
- }
183
-
184
- for (const attribute of attributes) {
185
- if (attribute.data_source_type === 'entity') {
186
- const entityMaster = await this.entityMasterService.getEntityData(
187
- attribute.datasource_list,
188
- loggedInUser,
189
- );
190
- const entityData = await this.entityManager.query(
191
- `SELECT * FROM ${entityMaster.db_table_name} WHERE code = ? LIMIT 1`,
192
- [row[attribute.attribute_key]],
193
- );
194
- row[attribute.attribute_key] = entityData[0].id;
195
- }
196
- }
197
- }
198
-
199
- console.log(`Processing sheet: ${table}`);
200
- await this.upsertData(table, unique_fields, sheetData);
201
- }
202
- return {
203
- message: 'Data uploaded successfully',
204
- };
205
- }
206
-
207
- async uploadEntityData(
208
- file,
209
- entityType,
210
- loggedInUser,
211
- duplicateHandling: 'skip_duplicates' | 'overwrite_items',
212
- ) {
213
- const data = ExcelUtil.readExcel(file.buffer);
214
- const entityMaster =
215
- await this.entityMasterService.findByMappedEntityType(entityType);
216
- if (!entityMaster) {
217
- throw new Error(`Entity master not found for entityType: ${entityType}`);
218
- }
219
-
220
- const tableName = entityMaster.db_table_name;
221
- const sheetData = data[tableName];
222
- if (!sheetData) {
223
- throw new Error(`Sheet for ${tableName} not found in uploaded file`);
224
- }
225
-
226
- const attributes =
227
- await this.attributeMasterService.findAttributesByMappedEntityType(
228
- entityMaster.mapped_entity_type,
229
- loggedInUser,
230
- );
231
-
232
- const uniqueFields = attributes
233
- .filter((attr) => attr.is_unique)
234
- .map((attr) => attr.attribute_key);
235
-
236
- if (uniqueFields.length === 0) {
237
- throw new Error(`No unique fields found for entityType: ${entityType}`);
238
- }
239
-
240
- const errors: any[] = [];
241
-
242
- // ✅ Iterate row by row
243
- for (let i = 0; i < sheetData.length; i++) {
244
- const row = sheetData[i];
245
-
246
- if (row.parent_type && row.parent_id) {
247
- await this.resolveParent(row);
248
- }
249
-
250
- // handle reference entity replacement
251
- for (const attr of attributes) {
252
- if (attr.data_source_type === 'entity' && row[attr.attribute_key]) {
253
- const refEntity = await this.entityMasterService.getEntityData(
254
- attr.datasource_list,
255
- loggedInUser,
256
- );
257
- const refData = await this.entityManager.query(
258
- `SELECT * FROM ${refEntity.db_table_name} WHERE code = ? LIMIT 1`,
259
- [row[attr.attribute_key]],
260
- );
261
-
262
- if (!refData.length) {
263
- errors.push({
264
- row: i + 1,
265
- errors: [
266
- `Reference entity not found for code: ${row[attr.attribute_key]}`,
267
- ],
268
- });
269
- continue; // skip further processing for this row
270
- }
271
-
272
- // replace with reference id
273
- row[attr.attribute_key] = refData[0].id;
274
- }
275
- }
276
-
277
- for (const attr of attributes) {
278
- if (attr.data_source_type === 'master' && row[attr.attribute_key]) {
279
- const refData = await this.entityManager.query(
280
- `SELECT * FROM frm_list_master_items WHERE name = ? and organization_id = ? LIMIT 1`,
281
- [row[attr.attribute_key], loggedInUser.organization_id],
282
- );
283
-
284
- if (!refData.length) {
285
- errors.push({
286
- row: i + 1,
287
- errors: [
288
- `Reference master data not found for name: ${row[attr.attribute_key]}`,
289
- ],
290
- });
291
- continue; // skip further processing for this row
292
- }
293
-
294
- // replace with reference id
295
- row[attr.attribute_key] = refData[0].id;
296
- }
297
- }
298
-
299
- // ✅ validate single row
300
- const rowErrors = await this.entityValidationService.validateImportData(
301
- row,
302
- entityMaster,
303
- loggedInUser,
304
- );
305
-
306
- if (rowErrors.length > 0) {
307
- errors.push({ row: i + 1, errors: rowErrors });
308
- }
309
- }
310
-
311
- // ✅ if any row failed, return errors instead of inserting
312
- if (errors.length > 0) {
313
- throw new BadRequestException({
314
- message: 'Validation errors found',
315
- errors,
316
- });
317
- }
318
-
319
- // ✅ only upsert if no validation errors
320
- await this.upsertViaService(
321
- entityType,
322
- sheetData,
323
- attributes,
324
- uniqueFields,
325
- loggedInUser,
326
- duplicateHandling,
327
- );
328
-
329
- return { message: 'Entity data uploaded successfully' };
330
- }
331
-
332
- // private isMetaSheet(sheetName: string): boolean {
333
- // return this.metaSheets.includes(sheetName.toLowerCase());
334
- // }
335
-
336
- private async resolveParent(row: any): Promise<void> {
337
- const parentType = row.parent_type; // (Future use maybe)
338
- const code = row.parent_id;
339
-
340
- if (!code) {
341
- throw new Error('Parent code is missing in the row');
342
- }
343
-
344
- const parentEntity: EntityMaster | null =
345
- await this.entityMasterService.findByMappedEntityType(parentType);
346
-
347
- const tableName: any = parentEntity?.db_table_name;
348
- if (!tableName) {
349
- throw new Error(`Table name not found for parent type ${parentType}`);
350
- }
351
-
352
- // Using RAW SQL Query
353
- const entityData = await this.entityManager.query(
354
- `SELECT * FROM ${tableName} WHERE code = ? LIMIT 1`,
355
- [code],
356
- );
357
-
358
- if (!entityData || entityData.length === 0) {
359
- throw new Error(
360
- `Parent entity with code ${code} not found in table ${tableName}`,
361
- );
362
- }
363
-
364
- // entityData is an array when using .query()
365
- row.parent_id = entityData[0].id;
366
- }
367
-
368
- async upsertData(
369
- tableName: string,
370
- uniqueFields: string[],
371
- data: any[],
372
- ): Promise<void> {
373
- for (const row of data) {
374
- const whereClause = uniqueFields
375
- .map((field) => `${field} = :${field}`)
376
- .join(' AND ');
377
-
378
- const whereParams = uniqueFields.reduce((acc, field) => {
379
- acc[field] = row[field];
380
- return acc;
381
- }, {});
382
-
383
- const existing = await this.entityManager
384
- .createQueryBuilder()
385
- .select('*')
386
- .from(tableName, tableName)
387
- .where(whereClause, whereParams)
388
- .limit(1)
389
- .getRawMany();
390
-
391
- if (existing.length > 0) {
392
- // Update
393
- await this.entityManager
394
- .createQueryBuilder()
395
- .update(tableName)
396
- .set(row)
397
- .where(whereClause, whereParams)
398
- .execute();
399
- } else {
400
- // Insert
401
- await this.entityManager
402
- .createQueryBuilder()
403
- .insert()
404
- .into(tableName)
405
- .values(row)
406
- .execute();
407
- }
408
- }
409
- }
410
-
411
- async upsertViaService(
412
- entityType: string,
413
- data: any[],
414
- attributes: any[],
415
- uniqueFields: string[],
416
- loggedInUser: any,
417
- duplicateHandling: 'skip_duplicates' | 'overwrite_items',
418
- ): Promise<void> {
419
- const entityMaster =
420
- await this.entityMasterService.findByMappedEntityType(entityType);
421
- if (!entityMaster)
422
- throw new Error(`Entity master not found for ${entityType}`);
423
-
424
- const serviceName = entityMaster.entity_service;
425
- const entityService =
426
- await this.reflectionHelper.getBean<EntityServiceImpl>(serviceName);
427
- if (!entityService)
428
- throw new Error(`Entity service not found for ${entityType}`);
429
-
430
- const errors: { row: number; errors: any[] }[] = [];
431
-
432
- for (const [i, row] of data.entries()) {
433
- row.entity_type = entityType;
434
- row.organization_id = loggedInUser.organization_id;
435
-
436
- // 🧠 Check if this already exists
437
- const qb = this.entityManager
438
- .createQueryBuilder()
439
- .select('*')
440
- .from(entityMaster.db_table_name, entityMaster.db_table_name)
441
- .where(
442
- new Brackets((qbOr) => {
443
- uniqueFields.forEach((field, index) => {
444
- const condition = `${entityMaster.db_table_name}.${field} = :val${index}`;
445
- const param = { [`val${index}`]: row[field] };
446
- if (index === 0) {
447
- qbOr.where(condition, param);
448
- } else {
449
- qbOr.orWhere(condition, param);
450
- }
451
- });
452
- }),
453
- )
454
- .andWhere(`${entityMaster.db_table_name}.organization_id = :orgId`, {
455
- orgId: loggedInUser.organization_id,
456
- })
457
- .andWhere(`${entityMaster.db_table_name}.level_type = :levelType`, {
458
- levelType: loggedInUser.level_type,
459
- })
460
- .andWhere(`${entityMaster.db_table_name}.level_id = :levelId`, {
461
- levelId: loggedInUser.level_id,
462
- });
463
-
464
- const existing = await qb.limit(1).getRawOne();
465
-
466
- if (existing) {
467
- if (duplicateHandling === 'skip_duplicates') continue;
468
- if (duplicateHandling === 'overwrite_items') {
469
- row.id = existing.id;
470
- await entityService.updateEntity(row, loggedInUser);
471
- }
472
- } else {
473
- await entityService.createEntity(row, loggedInUser);
474
- }
475
- }
476
-
477
- // if (errors.length > 0) {
478
- // throw new Error(
479
- // `Validation errors found in the uploaded data: ${JSON.stringify(errors)}`,
480
- // );
481
- // }
482
- }
483
- }
1
+ import { BadRequestException, Injectable } from '@nestjs/common';
2
+ import { Brackets, EntityManager } from 'typeorm';
3
+ import { ExcelUtil } from 'src/utils/service/excelUtil.service';
4
+ import { EntityMasterService } from '../../meta/service/entity-master.service';
5
+ import { AttributeMasterService } from 'src/module/meta/service/attribute-master.service';
6
+ import { EntityMaster } from 'src/module/meta/entity/entity-master.entity';
7
+ import { EntityServiceImpl } from 'src/module/meta/service/entity-service-impl.service';
8
+ import { ReflectionHelper } from 'src/utils/service/reflection-helper.service';
9
+ import { EntityValidationService } from 'src/module/meta/service/entity-validation.service';
10
+
11
+ @Injectable()
12
+ export class MasterService {
13
+ constructor(
14
+ private readonly entityManager: EntityManager,
15
+ private readonly entityMasterService: EntityMasterService,
16
+ private readonly attributeMasterService: AttributeMasterService,
17
+ private readonly excelUtil: ExcelUtil,
18
+ private reflectionHelper: ReflectionHelper,
19
+
20
+ private readonly entityServiceImpl: EntityServiceImpl,
21
+ protected readonly entityValidationService: EntityValidationService,
22
+ ) {}
23
+
24
+ // private readonly metaSheets = [
25
+ // 'frm_entity_master',
26
+ // 'frm_entity_attribute',
27
+ // 'frm_list_master',
28
+ // 'frm_list_master_items',
29
+ // 'frm_entity_table',
30
+ // 'frm_entity_table_column',
31
+ // 'frm_entity_view',
32
+ // ];
33
+ private readonly sequence = [
34
+ {
35
+ table: 'frm_entity_master',
36
+ unique_fields: ['id', 'organization_id'],
37
+ },
38
+ {
39
+ table: 'frm_entity_attribute',
40
+ unique_fields: ['mapped_entity_type', 'attribute_key', 'organization_id'],
41
+ },
42
+ {
43
+ table: 'frm_list_master',
44
+ unique_fields: ['type', 'organization_id'],
45
+ },
46
+ {
47
+ table: 'frm_list_master_items',
48
+ unique_fields: ['listtype', 'code', 'organization_id'],
49
+ },
50
+ {
51
+ table: 'frm_entity_table',
52
+ unique_fields: ['list_type', 'mapped_entity_type', 'organization_id'],
53
+ },
54
+ {
55
+ table: 'frm_entity_table_column',
56
+ unique_fields: [
57
+ 'parent_id',
58
+ 'parent_type',
59
+ 'attribute_key',
60
+ 'organization_id',
61
+ ],
62
+ },
63
+ {
64
+ table: 'frm_entity_view',
65
+ unique_fields: ['mapped_entity_type', 'organization_id'],
66
+ },
67
+ {
68
+ table: 'sso_user',
69
+ unique_fields: ['organization_id'],
70
+ },
71
+ {
72
+ table: 'sso_header_items',
73
+ unique_fields: ['code', 'section_id', 'organization_id'],
74
+ },
75
+ {
76
+ table: 'sso_module_access',
77
+ unique_fields: ['module_code', 'action_type', 'role_code'],
78
+ },
79
+ {
80
+ table: 'sso_module_action',
81
+ unique_fields: ['module_code', 'action_type', 'organization_id'],
82
+ },
83
+ {
84
+ table: 'sso_menu',
85
+ unique_fields: ['module_code', 'organization_id'],
86
+ },
87
+ {
88
+ table: 'sso_module',
89
+ unique_fields: ['module_code', 'organization_id'],
90
+ },
91
+ {
92
+ table: 'sso_role',
93
+ unique_fields: ['code', 'organization_id'],
94
+ },
95
+ {
96
+ table: 'sso_header_sections',
97
+ unique_fields: ['section_name', 'organization_id'],
98
+ },
99
+ {
100
+ table: 'sso_user_role_mapping',
101
+ unique_fields: ['user_id', 'role_id', 'organization_id'],
102
+ },
103
+ {
104
+ table: 'sso_organization',
105
+ unique_fields: ['code'],
106
+ },
107
+ {
108
+ table: 'eth_academic_year',
109
+ unique_fields: ['code'],
110
+ },
111
+ ];
112
+ private readonly dataSequence = [
113
+ {
114
+ table: 'sso_user',
115
+ unique_fields: ['code'],
116
+ },
117
+ {
118
+ table: 'sso_role',
119
+ unique_fields: ['code'],
120
+ },
121
+ {
122
+ table: 'sso_user_role_mapping',
123
+ unique_fields: ['user_id', 'role_id'],
124
+ },
125
+ {
126
+ table: 'eth_school',
127
+ unique_fields: ['code'],
128
+ },
129
+ {
130
+ table: 'eth_school_address',
131
+ unique_fields: ['code'],
132
+ },
133
+ ];
134
+
135
+ async uploadMeta(file) {
136
+ const data = ExcelUtil.readExcel(file.buffer);
137
+
138
+ for (let i = 0; i < this.sequence.length; i++) {
139
+ const { table, unique_fields } = this.sequence[i];
140
+ const sheetData = data[table];
141
+
142
+ if (!sheetData) {
143
+ console.log(`Sheet ${table} not found in the Excel file.`);
144
+ continue;
145
+ }
146
+ console.log(`Processing sheet: ${table}`);
147
+ await this.upsertData(table, unique_fields, sheetData);
148
+ }
149
+ return {
150
+ message: 'Data uploaded successfully',
151
+ };
152
+ }
153
+
154
+ async uploadData(file, loggedInUser) {
155
+ const data = ExcelUtil.readExcel(file.buffer);
156
+
157
+ for (let i = 0; i < this.dataSequence.length; i++) {
158
+ const { table, unique_fields } = this.dataSequence[i];
159
+ const sheetData = data[table];
160
+
161
+ if (!sheetData) {
162
+ console.log(`Sheet ${table} not found in the Excel file.`);
163
+ continue;
164
+ }
165
+
166
+ const entityMasterData =
167
+ await this.entityMasterService.getEntityByTableName(table);
168
+
169
+ if (!entityMasterData) {
170
+ throw new Error(`Entity master not found for table: ${table}`);
171
+ }
172
+
173
+ const attributes =
174
+ await this.attributeMasterService.findAttributesByMappedEntityType(
175
+ entityMasterData.mapped_entity_type,
176
+ loggedInUser.organization_id,
177
+ );
178
+
179
+ for (const row of sheetData) {
180
+ if (row.parent_type !== undefined && row.parent_id !== undefined) {
181
+ this.resolveParent(row);
182
+ }
183
+
184
+ for (const attribute of attributes) {
185
+ if (attribute.data_source_type === 'entity') {
186
+ const entityMaster = await this.entityMasterService.getEntityData(
187
+ attribute.datasource_list,
188
+ loggedInUser,
189
+ );
190
+ const entityData = await this.entityManager.query(
191
+ `SELECT * FROM ${entityMaster.db_table_name} WHERE code = ? LIMIT 1`,
192
+ [row[attribute.attribute_key]],
193
+ );
194
+ row[attribute.attribute_key] = entityData[0].id;
195
+ }
196
+ }
197
+ }
198
+
199
+ console.log(`Processing sheet: ${table}`);
200
+ await this.upsertData(table, unique_fields, sheetData);
201
+ }
202
+ return {
203
+ message: 'Data uploaded successfully',
204
+ };
205
+ }
206
+
207
+ async uploadEntityData(
208
+ file,
209
+ entityType,
210
+ loggedInUser,
211
+ duplicateHandling: 'skip_duplicates' | 'overwrite_items',
212
+ ) {
213
+ const data = ExcelUtil.readExcel(file.buffer);
214
+ const entityMaster =
215
+ await this.entityMasterService.findByMappedEntityType(entityType);
216
+ if (!entityMaster) {
217
+ throw new Error(`Entity master not found for entityType: ${entityType}`);
218
+ }
219
+
220
+ const tableName = entityMaster.db_table_name;
221
+ const sheetData = data[tableName];
222
+ if (!sheetData) {
223
+ throw new Error(`Sheet for ${tableName} not found in uploaded file`);
224
+ }
225
+
226
+ const attributes =
227
+ await this.attributeMasterService.findAttributesByMappedEntityType(
228
+ entityMaster.mapped_entity_type,
229
+ loggedInUser,
230
+ );
231
+
232
+ const uniqueFields = attributes
233
+ .filter((attr) => attr.is_unique)
234
+ .map((attr) => attr.attribute_key);
235
+
236
+ if (uniqueFields.length === 0) {
237
+ throw new Error(`No unique fields found for entityType: ${entityType}`);
238
+ }
239
+
240
+ const errors: any[] = [];
241
+
242
+ // ✅ Iterate row by row
243
+ for (let i = 0; i < sheetData.length; i++) {
244
+ const row = sheetData[i];
245
+
246
+ if (row.parent_type && row.parent_id) {
247
+ await this.resolveParent(row);
248
+ }
249
+
250
+ // handle reference entity replacement
251
+ for (const attr of attributes) {
252
+ if (attr.data_source_type === 'entity' && row[attr.attribute_key]) {
253
+ const refEntity = await this.entityMasterService.getEntityData(
254
+ attr.datasource_list,
255
+ loggedInUser,
256
+ );
257
+ const refData = await this.entityManager.query(
258
+ `SELECT * FROM ${refEntity.db_table_name} WHERE code = ? LIMIT 1`,
259
+ [row[attr.attribute_key]],
260
+ );
261
+
262
+ if (!refData.length) {
263
+ errors.push({
264
+ row: i + 1,
265
+ errors: [
266
+ `Reference entity not found for code: ${row[attr.attribute_key]}`,
267
+ ],
268
+ });
269
+ continue; // skip further processing for this row
270
+ }
271
+
272
+ // replace with reference id
273
+ row[attr.attribute_key] = refData[0].id;
274
+ }
275
+ }
276
+
277
+ for (const attr of attributes) {
278
+ if (attr.data_source_type === 'master' && row[attr.attribute_key]) {
279
+ const refData = await this.entityManager.query(
280
+ `SELECT * FROM frm_list_master_items WHERE name = ? and organization_id = ? LIMIT 1`,
281
+ [row[attr.attribute_key], loggedInUser.organization_id],
282
+ );
283
+
284
+ if (!refData.length) {
285
+ errors.push({
286
+ row: i + 1,
287
+ errors: [
288
+ `Reference master data not found for name: ${row[attr.attribute_key]}`,
289
+ ],
290
+ });
291
+ continue; // skip further processing for this row
292
+ }
293
+
294
+ // replace with reference id
295
+ row[attr.attribute_key] = refData[0].id;
296
+ }
297
+ }
298
+
299
+ // ✅ validate single row
300
+ const rowErrors = await this.entityValidationService.validateImportData(
301
+ row,
302
+ entityMaster,
303
+ loggedInUser,
304
+ );
305
+
306
+ if (rowErrors.length > 0) {
307
+ errors.push({ row: i + 1, errors: rowErrors });
308
+ }
309
+ }
310
+
311
+ // ✅ if any row failed, return errors instead of inserting
312
+ if (errors.length > 0) {
313
+ throw new BadRequestException({
314
+ message: 'Validation errors found',
315
+ errors,
316
+ });
317
+ }
318
+
319
+ // ✅ only upsert if no validation errors
320
+ await this.upsertViaService(
321
+ entityType,
322
+ sheetData,
323
+ attributes,
324
+ uniqueFields,
325
+ loggedInUser,
326
+ duplicateHandling,
327
+ );
328
+
329
+ return { message: 'Entity data uploaded successfully' };
330
+ }
331
+
332
+ // private isMetaSheet(sheetName: string): boolean {
333
+ // return this.metaSheets.includes(sheetName.toLowerCase());
334
+ // }
335
+
336
+ private async resolveParent(row: any): Promise<void> {
337
+ const parentType = row.parent_type; // (Future use maybe)
338
+ const code = row.parent_id;
339
+
340
+ if (!code) {
341
+ throw new Error('Parent code is missing in the row');
342
+ }
343
+
344
+ const parentEntity: EntityMaster | null =
345
+ await this.entityMasterService.findByMappedEntityType(parentType);
346
+
347
+ const tableName: any = parentEntity?.db_table_name;
348
+ if (!tableName) {
349
+ throw new Error(`Table name not found for parent type ${parentType}`);
350
+ }
351
+
352
+ // Using RAW SQL Query
353
+ const entityData = await this.entityManager.query(
354
+ `SELECT * FROM ${tableName} WHERE code = ? LIMIT 1`,
355
+ [code],
356
+ );
357
+
358
+ if (!entityData || entityData.length === 0) {
359
+ throw new Error(
360
+ `Parent entity with code ${code} not found in table ${tableName}`,
361
+ );
362
+ }
363
+
364
+ // entityData is an array when using .query()
365
+ row.parent_id = entityData[0].id;
366
+ }
367
+
368
+ async upsertData(
369
+ tableName: string,
370
+ uniqueFields: string[],
371
+ data: any[],
372
+ ): Promise<void> {
373
+ for (const row of data) {
374
+ const whereClause = uniqueFields
375
+ .map((field) => `${field} = :${field}`)
376
+ .join(' AND ');
377
+
378
+ const whereParams = uniqueFields.reduce((acc, field) => {
379
+ acc[field] = row[field];
380
+ return acc;
381
+ }, {});
382
+
383
+ const existing = await this.entityManager
384
+ .createQueryBuilder()
385
+ .select('*')
386
+ .from(tableName, tableName)
387
+ .where(whereClause, whereParams)
388
+ .limit(1)
389
+ .getRawMany();
390
+
391
+ if (existing.length > 0) {
392
+ // Update
393
+ await this.entityManager
394
+ .createQueryBuilder()
395
+ .update(tableName)
396
+ .set(row)
397
+ .where(whereClause, whereParams)
398
+ .execute();
399
+ } else {
400
+ // Insert
401
+ await this.entityManager
402
+ .createQueryBuilder()
403
+ .insert()
404
+ .into(tableName)
405
+ .values(row)
406
+ .execute();
407
+ }
408
+ }
409
+ }
410
+
411
+ async upsertViaService(
412
+ entityType: string,
413
+ data: any[],
414
+ attributes: any[],
415
+ uniqueFields: string[],
416
+ loggedInUser: any,
417
+ duplicateHandling: 'skip_duplicates' | 'overwrite_items',
418
+ ): Promise<void> {
419
+ const entityMaster =
420
+ await this.entityMasterService.findByMappedEntityType(entityType);
421
+ if (!entityMaster)
422
+ throw new Error(`Entity master not found for ${entityType}`);
423
+
424
+ const serviceName = entityMaster.entity_service;
425
+ const entityService =
426
+ await this.reflectionHelper.getBean<EntityServiceImpl>(serviceName);
427
+ if (!entityService)
428
+ throw new Error(`Entity service not found for ${entityType}`);
429
+
430
+ const errors: { row: number; errors: any[] }[] = [];
431
+
432
+ for (const [i, row] of data.entries()) {
433
+ row.entity_type = entityType;
434
+ row.organization_id = loggedInUser.organization_id;
435
+
436
+ // 🧠 Check if this already exists
437
+ const qb = this.entityManager
438
+ .createQueryBuilder()
439
+ .select('*')
440
+ .from(entityMaster.db_table_name, entityMaster.db_table_name)
441
+ .where(
442
+ new Brackets((qbOr) => {
443
+ uniqueFields.forEach((field, index) => {
444
+ const condition = `${entityMaster.db_table_name}.${field} = :val${index}`;
445
+ const param = { [`val${index}`]: row[field] };
446
+ if (index === 0) {
447
+ qbOr.where(condition, param);
448
+ } else {
449
+ qbOr.orWhere(condition, param);
450
+ }
451
+ });
452
+ }),
453
+ )
454
+ .andWhere(`${entityMaster.db_table_name}.organization_id = :orgId`, {
455
+ orgId: loggedInUser.organization_id,
456
+ })
457
+ .andWhere(`${entityMaster.db_table_name}.level_type = :levelType`, {
458
+ levelType: loggedInUser.level_type,
459
+ })
460
+ .andWhere(`${entityMaster.db_table_name}.level_id = :levelId`, {
461
+ levelId: loggedInUser.level_id,
462
+ });
463
+
464
+ const existing = await qb.limit(1).getRawOne();
465
+
466
+ if (existing) {
467
+ if (duplicateHandling === 'skip_duplicates') continue;
468
+ if (duplicateHandling === 'overwrite_items') {
469
+ row.id = existing.id;
470
+ await entityService.updateEntity(row, loggedInUser);
471
+ }
472
+ } else {
473
+ await entityService.createEntity(row, loggedInUser);
474
+ }
475
+ }
476
+
477
+ // if (errors.length > 0) {
478
+ // throw new Error(
479
+ // `Validation errors found in the uploaded data: ${JSON.stringify(errors)}`,
480
+ // );
481
+ // }
482
+ }
483
+ }