rez_core 5.0.84 → 5.0.86

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