rez_core 4.0.127 → 4.0.129

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