rez_core 5.0.157 → 5.0.158

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