rez_core 5.0.18 → 5.0.20

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 (426) hide show
  1. package/.claude/settings.local.json +26 -0
  2. package/.idea/250218_nodejs_core.iml +9 -0
  3. package/.idea/codeStyles/Project.xml +59 -0
  4. package/.idea/codeStyles/codeStyleConfig.xml +5 -0
  5. package/.idea/copilot.data.migration.agent.xml +6 -0
  6. package/.idea/copilot.data.migration.ask.xml +6 -0
  7. package/.idea/copilot.data.migration.ask2agent.xml +6 -0
  8. package/.idea/copilot.data.migration.edit.xml +6 -0
  9. package/.idea/inspectionProfiles/Project_Default.xml +6 -0
  10. package/.idea/misc.xml +6 -0
  11. package/.idea/modules.xml +8 -0
  12. package/.idea/prettier.xml +6 -0
  13. package/.idea/vcs.xml +6 -0
  14. package/.prettierrc +3 -3
  15. package/README.md +99 -99
  16. package/dist/module/auth/guards/role.guard.js +3 -3
  17. package/dist/module/auth/services/auth.service.js +2 -2
  18. package/dist/module/entity_json/service/entity_json.service.js +2 -2
  19. package/dist/module/filter/repository/saved-filter.repository.js +4 -4
  20. package/dist/module/filter/service/filter-evaluator.service.js +2 -2
  21. package/dist/module/filter/service/filter.service.js +22 -22
  22. package/dist/module/integration/examples/usage.example.js +9 -9
  23. package/dist/module/integration/service/integration.service.js +1 -1
  24. package/dist/module/integration/service/wrapper.service.js +26 -26
  25. package/dist/module/listmaster/service/list-master-item.service.js +2 -2
  26. package/dist/module/mapper/service/field-mapper.service.js +4 -4
  27. package/dist/module/mapper/service/mapper.service.js +2 -2
  28. package/dist/module/meta/repository/entity-attribute-update.repository.js +3 -3
  29. package/dist/module/meta/repository/entity-master.repository.js +6 -6
  30. package/dist/module/meta/service/entity-dynamic.service.js +44 -44
  31. package/dist/module/meta/service/entity-list.service.js +3 -3
  32. package/dist/module/meta/service/entity-master.service.js +3 -3
  33. package/dist/module/meta/service/entity-relation.service.js +9 -9
  34. package/dist/module/meta/service/entity-service-impl.service.js +3 -3
  35. package/dist/module/meta/service/resolver.service.js +3 -3
  36. package/dist/module/module/repository/menu.repository.js +12 -12
  37. package/dist/module/notification/service/notification.service.js +10 -10
  38. package/dist/module/user/controller/login.controller.js +18 -18
  39. package/dist/module/user/service/role.service.js +4 -4
  40. package/dist/module/user/service/user-session.service.js +2 -2
  41. package/dist/module/workflow/repository/action.repository.js +20 -20
  42. package/dist/module/workflow/repository/comm-template.repository.js +6 -6
  43. package/dist/module/workflow/repository/form-master.repository.js +2 -2
  44. package/dist/module/workflow/repository/stage-group.repository.d.ts +5 -1
  45. package/dist/module/workflow/repository/stage-group.repository.js +38 -32
  46. package/dist/module/workflow/repository/stage-group.repository.js.map +1 -1
  47. package/dist/module/workflow/repository/stage-movement.repository.js +15 -15
  48. package/dist/module/workflow/repository/stage.repository.js +8 -8
  49. package/dist/module/workflow/service/action-template-mapping.service.js +31 -31
  50. package/dist/module/workflow/service/action.service.js +7 -7
  51. package/dist/module/workflow/service/entity-modification.service.js +6 -6
  52. package/dist/module/workflow/service/stage-group.service.js +2 -2
  53. package/dist/module/workflow/service/stage.service.js +2 -2
  54. package/dist/module/workflow/service/task.service.js +46 -46
  55. package/dist/module/workflow/service/task.service.js.map +1 -1
  56. package/dist/module/workflow/service/workflow-list-master.service.js +15 -15
  57. package/dist/module/workflow/service/workflow-meta.service.js +26 -26
  58. package/dist/module/workflow/service/workflow.service.js +2 -2
  59. package/dist/module/workflow-automation/service/schedule-handler.service.js +14 -14
  60. package/dist/module/workflow-schedule/processors/schedule.processor.js +4 -4
  61. package/dist/module/workflow-schedule/service/workflow-schedule.service.js +9 -9
  62. package/dist/tsconfig.build.tsbuildinfo +1 -1
  63. package/dist/utils/service/reflection-helper.service.js +2 -2
  64. package/docs/modules/event-driven-integration-design.md +91 -91
  65. package/docs/modules/integration.md +250 -250
  66. package/eslint.config.mjs +34 -34
  67. package/nest-cli.json +14 -14
  68. package/package.json +124 -124
  69. package/server.log +850 -0
  70. package/src/app.controller.ts +12 -12
  71. package/src/app.module.ts +66 -66
  72. package/src/app.service.ts +8 -8
  73. package/src/config/bull.config.ts +69 -69
  74. package/src/config/config.module.ts +17 -17
  75. package/src/config/database.config.ts +48 -48
  76. package/src/constant/global.constant.ts +67 -67
  77. package/src/core.module.ts +88 -88
  78. package/src/decorators/roles.decorator.ts +7 -7
  79. package/src/dtos/response.dto.ts +6 -6
  80. package/src/dtos/response.ts +5 -5
  81. package/src/index.ts +1 -1
  82. package/src/module/auth/auth.module.ts +49 -49
  83. package/src/module/auth/controller/auth.controller.ts +28 -28
  84. package/src/module/auth/guards/google-auth.guard.ts +9 -9
  85. package/src/module/auth/guards/jwt.guard.ts +22 -22
  86. package/src/module/auth/guards/role.guard.ts +68 -68
  87. package/src/module/auth/services/auth.service.ts +50 -50
  88. package/src/module/auth/services/jwt.service.ts +11 -11
  89. package/src/module/auth/strategies/google.strategy.ts +54 -54
  90. package/src/module/auth/strategies/jwt.strategy.ts +58 -58
  91. package/src/module/auth/strategies/local.strategy.ts +13 -13
  92. package/src/module/dashboard/controller/dashboard.controller.ts +36 -36
  93. package/src/module/dashboard/dashboard.module.ts +21 -21
  94. package/src/module/dashboard/entity/dashboard_page_data.entity.ts +27 -27
  95. package/src/module/dashboard/entity/widget_master.entity.ts +18 -18
  96. package/src/module/dashboard/repository/dashboard.repository.ts +42 -42
  97. package/src/module/dashboard/service/dashboard.service.ts +73 -73
  98. package/src/module/dev/dev.module.ts +12 -12
  99. package/src/module/dev/service/dev.service.ts +7 -7
  100. package/src/module/enterprise/controller/organization.controller.ts +36 -36
  101. package/src/module/enterprise/enterprise.module.ts +30 -30
  102. package/src/module/enterprise/entity/enterprise.entity.ts +37 -37
  103. package/src/module/enterprise/entity/organization-app-mapping.entity.ts +13 -13
  104. package/src/module/enterprise/entity/organization.entity.ts +92 -92
  105. package/src/module/enterprise/repository/enterprise.repository.ts +31 -31
  106. package/src/module/enterprise/repository/organization.repository.ts +26 -26
  107. package/src/module/enterprise/repository/school.repository.ts +278 -278
  108. package/src/module/enterprise/service/brand.service.ts +5 -5
  109. package/src/module/enterprise/service/enterprise.service.ts +16 -16
  110. package/src/module/enterprise/service/organization-app-mapping.service.ts +4 -4
  111. package/src/module/enterprise/service/organization.service.ts +145 -145
  112. package/src/module/entity_json/controller/entity_json.controller.ts +47 -47
  113. package/src/module/entity_json/entity_json.module.ts +15 -15
  114. package/src/module/entity_json/service/entity_json.service.ts +265 -265
  115. package/src/module/filter/controller/filter.controller.ts +84 -84
  116. package/src/module/filter/dto/filter-request.dto.ts +38 -38
  117. package/src/module/filter/entity/saved-filter-detail.entity.ts +41 -41
  118. package/src/module/filter/entity/saved-filter-master.entity.ts +23 -23
  119. package/src/module/filter/filter.module.ts +31 -31
  120. package/src/module/filter/repository/saved-filter.repository.ts +168 -168
  121. package/src/module/filter/service/filter-evaluator.service.ts +86 -86
  122. package/src/module/filter/service/filter.service.ts +1051 -1051
  123. package/src/module/filter/service/saved-filter.service.ts +170 -170
  124. package/src/module/ics/controller/ics.controller.ts +21 -21
  125. package/src/module/ics/dto/ics.dto.ts +55 -55
  126. package/src/module/ics/ics.module.ts +13 -13
  127. package/src/module/ics/service/ics.service.ts +57 -57
  128. package/src/module/integration/controller/calender-event.controller.ts +31 -31
  129. package/src/module/integration/controller/integration.controller.ts +662 -662
  130. package/src/module/integration/controller/wrapper.controller.ts +37 -37
  131. package/src/module/integration/dto/create-config.dto.ts +526 -526
  132. package/src/module/integration/entity/integration-config.entity.ts +112 -112
  133. package/src/module/integration/entity/integration-entity-mapper.entity.ts +14 -14
  134. package/src/module/integration/entity/integration-source.entity.ts +17 -17
  135. package/src/module/integration/entity/user-integration.entity.ts +71 -71
  136. package/src/module/integration/examples/usage.example.ts +338 -338
  137. package/src/module/integration/factories/base.factory.ts +7 -7
  138. package/src/module/integration/factories/email.factory.ts +49 -49
  139. package/src/module/integration/factories/integration.factory.ts +121 -121
  140. package/src/module/integration/factories/sms.factory.ts +51 -51
  141. package/src/module/integration/factories/telephone.factory.ts +41 -41
  142. package/src/module/integration/factories/whatsapp.factory.ts +56 -56
  143. package/src/module/integration/integration.module.ts +110 -110
  144. package/src/module/integration/service/calendar-event.service.ts +118 -118
  145. package/src/module/integration/service/integration-entity-mapper.service.ts +17 -17
  146. package/src/module/integration/service/integration-queue.service.ts +229 -229
  147. package/src/module/integration/service/integration.service.ts +2633 -2633
  148. package/src/module/integration/service/oauth.service.ts +224 -224
  149. package/src/module/integration/service/wrapper.service.ts +701 -701
  150. package/src/module/integration/strategies/email/gmail-api.strategy.ts +280 -280
  151. package/src/module/integration/strategies/email/outlook-api.strategy.ts +44 -44
  152. package/src/module/integration/strategies/email/outlook.strategy.ts +64 -64
  153. package/src/module/integration/strategies/email/sendgrid-api.strategy.ts +260 -260
  154. package/src/module/integration/strategies/integration.strategy.ts +97 -97
  155. package/src/module/integration/strategies/sms/gupshup-sms.strategy.ts +146 -146
  156. package/src/module/integration/strategies/sms/msg91-sms.strategy.ts +164 -164
  157. package/src/module/integration/strategies/sms/tubelight-sms.strategy.ts +163 -163
  158. package/src/module/integration/strategies/telephone/ozonetel-voice.strategy.ts +238 -238
  159. package/src/module/integration/strategies/telephone/tubelight-voice.strategy.ts +210 -210
  160. package/src/module/integration/strategies/whatsapp/gupshup-whatsapp.strategy.ts +359 -359
  161. package/src/module/integration/strategies/whatsapp/tubelight-whatsapp.strategy.ts +372 -372
  162. package/src/module/integration/strategies/whatsapp/whatsapp-cloud.strategy.ts +403 -403
  163. package/src/module/integration/strategies/whatsapp/whatsapp.strategy.ts +57 -57
  164. package/src/module/layout/controller/layout.controller.ts +47 -47
  165. package/src/module/layout/entity/header-items.entity.ts +28 -28
  166. package/src/module/layout/entity/header-section.entity.ts +19 -19
  167. package/src/module/layout/layout.module.ts +21 -21
  168. package/src/module/layout/repository/header-items.repository.ts +18 -18
  169. package/src/module/layout/repository/header-section.repository.ts +22 -22
  170. package/src/module/layout/service/header-section.service.ts +25 -25
  171. package/src/module/layout_preference/controller/layout_preference.controller.ts +73 -73
  172. package/src/module/layout_preference/entity/layout_preference.entity.ts +28 -28
  173. package/src/module/layout_preference/layout_preference.module.ts +22 -22
  174. package/src/module/layout_preference/repository/layout_preference.repository.ts +65 -65
  175. package/src/module/layout_preference/service/layout_preference.service.ts +191 -191
  176. package/src/module/lead/controller/lead.controller.ts +30 -30
  177. package/src/module/lead/lead.module.ts +14 -14
  178. package/src/module/lead/repository/lead.repository.ts +41 -41
  179. package/src/module/lead/service/lead.service.ts +54 -54
  180. package/src/module/linked_attributes/controller/linked_attributes.controller.ts +10 -10
  181. package/src/module/linked_attributes/entity/linked_attribute.entity.ts +48 -48
  182. package/src/module/linked_attributes/linked_attributes.module.ts +16 -16
  183. package/src/module/linked_attributes/repository/linked_attribute.repository.ts +12 -12
  184. package/src/module/linked_attributes/service/linked_attributes.service.ts +22 -22
  185. package/src/module/listmaster/controller/list-master.controller.ts +230 -230
  186. package/src/module/listmaster/entity/list-master-items.entity.ts +43 -43
  187. package/src/module/listmaster/entity/list-master.entity.ts +33 -33
  188. package/src/module/listmaster/listmaster.module.ts +46 -46
  189. package/src/module/listmaster/repository/list-master-items.repository.ts +169 -169
  190. package/src/module/listmaster/repository/list-master.repository.ts +46 -46
  191. package/src/module/listmaster/service/list-master-engine.ts +19 -19
  192. package/src/module/listmaster/service/list-master-extension.interface.ts +4 -4
  193. package/src/module/listmaster/service/list-master-item.service.ts +292 -292
  194. package/src/module/listmaster/service/list-master-registry.ts +15 -15
  195. package/src/module/listmaster/service/list-master.service.ts +535 -535
  196. package/src/module/mapper/controller/field-mapper.controller.ts +76 -76
  197. package/src/module/mapper/controller/mapper.controller.ts +20 -20
  198. package/src/module/mapper/dto/field-mapper.dto.ts +14 -14
  199. package/src/module/mapper/entity/field-lovs.entity.ts +19 -19
  200. package/src/module/mapper/entity/field-mapper.entity.ts +53 -53
  201. package/src/module/mapper/entity/mapper.entity.ts +16 -16
  202. package/src/module/mapper/mapper.module.ts +34 -34
  203. package/src/module/mapper/repository/field-lovs.repository.ts +35 -35
  204. package/src/module/mapper/repository/field-mapper.repository.ts +42 -42
  205. package/src/module/mapper/repository/mapper.repository.ts +15 -15
  206. package/src/module/mapper/service/field-mapper.service.ts +271 -271
  207. package/src/module/mapper/service/mapper.service.ts +79 -79
  208. package/src/module/master/controller/master.controller.ts +74 -74
  209. package/src/module/master/service/master.service.ts +483 -483
  210. package/src/module/meta/controller/app-master.controller.ts +38 -38
  211. package/src/module/meta/controller/attribute-master.controller.ts +86 -86
  212. package/src/module/meta/controller/entity-dynamic.controller.ts +125 -125
  213. package/src/module/meta/controller/entity-master.controller.ts +41 -41
  214. package/src/module/meta/controller/entity-relation.controller.ts +36 -36
  215. package/src/module/meta/controller/entity.controller.ts +392 -392
  216. package/src/module/meta/controller/entity.public.controller.ts +75 -75
  217. package/src/module/meta/controller/media.controller.ts +107 -107
  218. package/src/module/meta/controller/meta.controller.ts +96 -96
  219. package/src/module/meta/controller/view-master.controller.ts +86 -86
  220. package/src/module/meta/dto/entity-list-data.dto.ts +6 -6
  221. package/src/module/meta/dto/entity-tab.dto.ts +4 -4
  222. package/src/module/meta/dto/entity-table.dto.ts +9 -9
  223. package/src/module/meta/entity/app-master.entity.ts +34 -34
  224. package/src/module/meta/entity/attribute-master.entity.ts +89 -89
  225. package/src/module/meta/entity/base-entity.entity.ts +75 -75
  226. package/src/module/meta/entity/entity-master.entity.ts +85 -85
  227. package/src/module/meta/entity/entity-relation-data.entity.ts +29 -29
  228. package/src/module/meta/entity/entity-relation.entity.ts +23 -23
  229. package/src/module/meta/entity/entity-table-column.entity.ts +61 -61
  230. package/src/module/meta/entity/entity-table.entity.ts +50 -50
  231. package/src/module/meta/entity/media-data.entity.ts +32 -32
  232. package/src/module/meta/entity/preference.entity.ts +62 -62
  233. package/src/module/meta/entity/view-master.entity.ts +41 -41
  234. package/src/module/meta/entity.module.ts +166 -166
  235. package/src/module/meta/repository/app-master.repository.ts +20 -20
  236. package/src/module/meta/repository/attribute-master.repository.ts +138 -138
  237. package/src/module/meta/repository/entity-attribute-update.repository.ts +44 -44
  238. package/src/module/meta/repository/entity-master.repository.ts +111 -111
  239. package/src/module/meta/repository/entity-table-column.repository.ts +39 -39
  240. package/src/module/meta/repository/entity-table.repository.ts +53 -53
  241. package/src/module/meta/repository/media-data.repository.ts +50 -50
  242. package/src/module/meta/repository/preference.repository.ts +20 -20
  243. package/src/module/meta/repository/user-app-mapping.repository.ts +28 -28
  244. package/src/module/meta/repository/view-master.repository.ts +42 -42
  245. package/src/module/meta/service/app-master.service.ts +37 -37
  246. package/src/module/meta/service/attribute-master.service.ts +130 -130
  247. package/src/module/meta/service/common.service.ts +9 -9
  248. package/src/module/meta/service/entity-attribute-update.service.ts +28 -28
  249. package/src/module/meta/service/entity-dynamic.service.ts +818 -818
  250. package/src/module/meta/service/entity-list.service.ts +205 -205
  251. package/src/module/meta/service/entity-master.service.ts +175 -175
  252. package/src/module/meta/service/entity-realation-data.service.ts +9 -9
  253. package/src/module/meta/service/entity-relation.service.ts +87 -87
  254. package/src/module/meta/service/entity-service-impl.service.ts +525 -525
  255. package/src/module/meta/service/entity-table-column.service.ts +39 -39
  256. package/src/module/meta/service/entity-table.service.ts +150 -150
  257. package/src/module/meta/service/entity-validation.service.ts +187 -187
  258. package/src/module/meta/service/entity.service.ts +67 -67
  259. package/src/module/meta/service/field-group.service.ts +103 -103
  260. package/src/module/meta/service/media-data.service.ts +507 -507
  261. package/src/module/meta/service/populate-meta.service.ts +193 -193
  262. package/src/module/meta/service/preference.service.ts +16 -16
  263. package/src/module/meta/service/resolver.service.ts +271 -271
  264. package/src/module/meta/service/section-master.service.ts +104 -104
  265. package/src/module/meta/service/update-form-json.service.ts +22 -22
  266. package/src/module/meta/service/user-app-mapping.service.ts +17 -17
  267. package/src/module/meta/service/view-master.service.ts +127 -127
  268. package/src/module/microservice-client/microservice-clients.module.ts +13 -13
  269. package/src/module/microservice-client/service/microservice-client-factory.ts +37 -37
  270. package/src/module/microservice-client/service/microservice-clients.ts +4 -4
  271. package/src/module/module/controller/menu.controller.ts +15 -15
  272. package/src/module/module/controller/module-access.controller.ts +134 -134
  273. package/src/module/module/entity/menu.entity.ts +43 -43
  274. package/src/module/module/entity/module-access.entity.ts +25 -25
  275. package/src/module/module/entity/module-action.entity.ts +17 -17
  276. package/src/module/module/entity/module.entity.ts +52 -52
  277. package/src/module/module/module.module.ts +42 -42
  278. package/src/module/module/repository/menu.repository.ts +184 -184
  279. package/src/module/module/repository/module-access.repository.ts +344 -344
  280. package/src/module/module/service/menu.service.ts +82 -82
  281. package/src/module/module/service/module-access.service.ts +194 -194
  282. package/src/module/notification/controller/notification.controller.ts +58 -58
  283. package/src/module/notification/controller/otp.controller.ts +117 -117
  284. package/src/module/notification/entity/notification.entity.ts +26 -26
  285. package/src/module/notification/entity/otp.entity.ts +28 -28
  286. package/src/module/notification/firebase-admin.config.ts +22 -22
  287. package/src/module/notification/notification.module.ts +69 -69
  288. package/src/module/notification/repository/otp.repository.ts +27 -27
  289. package/src/module/notification/service/email.service.ts +127 -127
  290. package/src/module/notification/service/notification.service.ts +160 -160
  291. package/src/module/notification/service/otp.service.ts +132 -132
  292. package/src/module/third-party-module/entity/third-party-api-registry.entity.ts +52 -52
  293. package/src/module/third-party-module/repository/third-party-api-registry.repository.ts +20 -20
  294. package/src/module/third-party-module/service/api-registry.service.ts +13 -13
  295. package/src/module/third-party-module/third-party.module.ts +12 -12
  296. package/src/module/user/controller/login.controller.ts +197 -197
  297. package/src/module/user/controller/user.controller.ts +40 -40
  298. package/src/module/user/dto/create-user.dto.ts +62 -62
  299. package/src/module/user/dto/update-user.dto.ts +4 -4
  300. package/src/module/user/entity/role.entity.ts +33 -33
  301. package/src/module/user/entity/user-role-mapping.entity.ts +38 -38
  302. package/src/module/user/entity/user-session.entity.ts +73 -73
  303. package/src/module/user/entity/user.entity.ts +59 -59
  304. package/src/module/user/repository/role.repository.ts +96 -96
  305. package/src/module/user/repository/user-role-mapping.repository.ts +126 -126
  306. package/src/module/user/repository/user.repository.ts +50 -50
  307. package/src/module/user/repository/userSession.repository.ts +33 -33
  308. package/src/module/user/service/login.service.ts +304 -304
  309. package/src/module/user/service/role.service.ts +189 -189
  310. package/src/module/user/service/user-role-mapping.service.ts +98 -98
  311. package/src/module/user/service/user-session.service.ts +168 -168
  312. package/src/module/user/service/user.service.ts +365 -365
  313. package/src/module/user/user.module.ts +65 -65
  314. package/src/module/workflow/controller/action-category.controller.ts +54 -54
  315. package/src/module/workflow/controller/action-resource-mapping.controller.ts +23 -23
  316. package/src/module/workflow/controller/action-template-mapping.controller.ts +35 -35
  317. package/src/module/workflow/controller/action.controller.ts +111 -111
  318. package/src/module/workflow/controller/activity-log.controller.ts +55 -55
  319. package/src/module/workflow/controller/comm-template.controller.ts +43 -43
  320. package/src/module/workflow/controller/entity-modification.controller.ts +35 -35
  321. package/src/module/workflow/controller/form-master.controller.ts +43 -43
  322. package/src/module/workflow/controller/stage-group.controller.ts +48 -48
  323. package/src/module/workflow/controller/stage.controller.ts +50 -50
  324. package/src/module/workflow/controller/task.controller.ts +77 -77
  325. package/src/module/workflow/controller/workflow-list-master.controller.ts +44 -44
  326. package/src/module/workflow/controller/workflow-meta.controller.ts +80 -80
  327. package/src/module/workflow/controller/workflow.controller.ts +67 -67
  328. package/src/module/workflow/entity/action-category.entity.ts +38 -38
  329. package/src/module/workflow/entity/action-data.entity.ts +55 -55
  330. package/src/module/workflow/entity/action-resources-mapping.entity.ts +29 -29
  331. package/src/module/workflow/entity/action-template-mapping.entity.ts +17 -17
  332. package/src/module/workflow/entity/action.entity.ts +53 -53
  333. package/src/module/workflow/entity/activity-log.entity.ts +43 -43
  334. package/src/module/workflow/entity/comm-template.entity.ts +43 -43
  335. package/src/module/workflow/entity/entity-modification.entity.ts +38 -38
  336. package/src/module/workflow/entity/form.entity.ts +25 -25
  337. package/src/module/workflow/entity/stage-action-mapping.entity.ts +17 -17
  338. package/src/module/workflow/entity/stage-group.entity.ts +23 -23
  339. package/src/module/workflow/entity/stage-movement-data.entity.ts +38 -38
  340. package/src/module/workflow/entity/stage.entity.ts +20 -20
  341. package/src/module/workflow/entity/task-data.entity.ts +88 -88
  342. package/src/module/workflow/entity/template-attach-mapper.entity.ts +30 -30
  343. package/src/module/workflow/entity/workflow-data.entity.ts +11 -11
  344. package/src/module/workflow/entity/workflow-level-mapping.entity.ts +18 -18
  345. package/src/module/workflow/entity/workflow.entity.ts +20 -20
  346. package/src/module/workflow/repository/action-category.repository.ts +79 -79
  347. package/src/module/workflow/repository/action-data.repository.ts +334 -334
  348. package/src/module/workflow/repository/action.repository.ts +323 -323
  349. package/src/module/workflow/repository/activity-log.repository.ts +148 -148
  350. package/src/module/workflow/repository/comm-template.repository.ts +149 -149
  351. package/src/module/workflow/repository/form-master.repository.ts +59 -59
  352. package/src/module/workflow/repository/stage-group.repository.ts +197 -197
  353. package/src/module/workflow/repository/stage-movement.repository.ts +244 -244
  354. package/src/module/workflow/repository/stage.repository.ts +172 -172
  355. package/src/module/workflow/repository/task.repository.ts +134 -134
  356. package/src/module/workflow/repository/workflow.repository.ts +42 -42
  357. package/src/module/workflow/service/action-category.service.ts +33 -33
  358. package/src/module/workflow/service/action-data.service.ts +62 -62
  359. package/src/module/workflow/service/action-resources-mapping.service.ts +10 -10
  360. package/src/module/workflow/service/action-template-mapping.service.ts +115 -115
  361. package/src/module/workflow/service/action.service.ts +279 -279
  362. package/src/module/workflow/service/activity-log.service.ts +107 -107
  363. package/src/module/workflow/service/comm-template.service.ts +180 -180
  364. package/src/module/workflow/service/entity-modification.service.ts +67 -67
  365. package/src/module/workflow/service/form-master.service.ts +35 -35
  366. package/src/module/workflow/service/populate-workflow.service.ts +303 -303
  367. package/src/module/workflow/service/stage-action-mapping.service.ts +5 -5
  368. package/src/module/workflow/service/stage-group.service.ts +345 -345
  369. package/src/module/workflow/service/stage.service.ts +199 -199
  370. package/src/module/workflow/service/task.service.ts +558 -555
  371. package/src/module/workflow/service/workflow-list-master.service.ts +60 -60
  372. package/src/module/workflow/service/workflow-meta.service.ts +654 -654
  373. package/src/module/workflow/service/workflow.service.ts +205 -205
  374. package/src/module/workflow/workflow.module.ts +178 -178
  375. package/src/module/workflow-automation/SCHEDULING_GUIDE.md +145 -145
  376. package/src/module/workflow-automation/controller/workflow-automation.controller.ts +43 -43
  377. package/src/module/workflow-automation/entity/workflow-automation-action.entity.ts +26 -26
  378. package/src/module/workflow-automation/entity/workflow-automation.entity.ts +40 -40
  379. package/src/module/workflow-automation/interface/action.decorator.ts +7 -7
  380. package/src/module/workflow-automation/interface/action.interface.ts +5 -5
  381. package/src/module/workflow-automation/service/action-registery.service.ts +35 -35
  382. package/src/module/workflow-automation/service/schedule-handler.service.ts +149 -149
  383. package/src/module/workflow-automation/service/workflow-automation-engine.service.ts +214 -214
  384. package/src/module/workflow-automation/service/workflow-automation.service.ts +508 -508
  385. package/src/module/workflow-automation/workflow-automation.module.ts +47 -47
  386. package/src/module/workflow-schedule/INSTALLATION.md +244 -244
  387. package/src/module/workflow-schedule/MULTI_PROJECT_GUIDE.md +196 -196
  388. package/src/module/workflow-schedule/README.md +422 -422
  389. package/src/module/workflow-schedule/constants/schedule.constants.ts +48 -48
  390. package/src/module/workflow-schedule/controller/workflow-schedule.controller.ts +255 -255
  391. package/src/module/workflow-schedule/docs/CLAUDE_CODE_GUIDE.md +510 -510
  392. package/src/module/workflow-schedule/docs/CLAUDE_CODE_PROMPT.md +362 -362
  393. package/src/module/workflow-schedule/docs/RUN_CLAUDE_CODE.sh +68 -68
  394. package/src/module/workflow-schedule/dto/create-schedule.dto.ts +147 -147
  395. package/src/module/workflow-schedule/dto/get-execution-logs.dto.ts +119 -119
  396. package/src/module/workflow-schedule/dto/update-schedule.dto.ts +96 -96
  397. package/src/module/workflow-schedule/entities/scheduled-workflow.entity.ts +148 -148
  398. package/src/module/workflow-schedule/entities/workflow-execution-log.entity.ts +154 -154
  399. package/src/module/workflow-schedule/interfaces/schedule-job-data.interface.ts +53 -53
  400. package/src/module/workflow-schedule/interfaces/workflow-schedule-options.interface.ts +12 -12
  401. package/src/module/workflow-schedule/processors/schedule.processor.ts +584 -584
  402. package/src/module/workflow-schedule/service/workflow-schedule.service.ts +600 -600
  403. package/src/module/workflow-schedule/workflow-schedule.module.ts +67 -67
  404. package/src/resources/dev.properties.yaml +31 -31
  405. package/src/resources/local.properties.yaml +27 -27
  406. package/src/resources/properties.module.ts +12 -12
  407. package/src/resources/properties.yaml.ts +11 -11
  408. package/src/resources/uat.properties.yaml +31 -31
  409. package/src/table.config.ts +130 -130
  410. package/src/utils/dto/excel-data.dto.ts +14 -14
  411. package/src/utils/dto/excelsheet-data.dto.ts +5 -5
  412. package/src/utils/service/base64util.service.ts +18 -18
  413. package/src/utils/service/clockIDGenUtil.service.ts +21 -21
  414. package/src/utils/service/codeGenerator.service.ts +22 -22
  415. package/src/utils/service/dateUtil.service.ts +17 -17
  416. package/src/utils/service/encryptUtil.service.ts +97 -97
  417. package/src/utils/service/excel-helper.service.ts +72 -72
  418. package/src/utils/service/excelUtil.service.ts +15 -15
  419. package/src/utils/service/file-util.service.ts +11 -11
  420. package/src/utils/service/json-util.service.ts +23 -23
  421. package/src/utils/service/loggingUtil.service.ts +88 -88
  422. package/src/utils/service/reflection-helper.service.ts +62 -62
  423. package/src/utils/service/wbsCodeGen.service.ts +8 -8
  424. package/src/utils/utils.module.ts +27 -27
  425. package/tsconfig.build.json +4 -4
  426. package/tsconfig.json +24 -24
@@ -31,10 +31,10 @@ let WrapperService = WrapperService_1 = class WrapperService {
31
31
  this.loggingService.log('debug', 'wrapperService', 'sendMailWrapper', `sendMailWrapper called. User: ${JSON.stringify(loggedInUser)}, Payload: ${JSON.stringify(payload)}`, [], []);
32
32
  const { level_id, level_type, organization_id } = loggedInUser;
33
33
  this.loggingService.log('debug', 'wrapperService', 'sendMailWrapper', `Fetching configs for level_id=${level_id}, level_type=${level_type}`, [], []);
34
- const configs = await this.datasource.query(`SELECT * FROM frm_integration_config
35
- WHERE level_id = $1
36
- AND level_type = $2
37
- AND status = 1
34
+ const configs = await this.datasource.query(`SELECT * FROM frm_integration_config
35
+ WHERE level_id = $1
36
+ AND level_type = $2
37
+ AND status = 1
38
38
  AND integration_type = 'EMAIL'`, [level_id, level_type]);
39
39
  this.loggingService.log('debug', 'wrapperService', 'sendMailWrapper', `Configs found: ${JSON.stringify(configs)}`, [], []);
40
40
  let templateCode;
@@ -70,9 +70,9 @@ let WrapperService = WrapperService_1 = class WrapperService {
70
70
  }
71
71
  else {
72
72
  this.loggingService.log('warn', 'wrapperService', 'sendMailWrapper', `No user-level configs found. Falling back to ORG-level`, [], []);
73
- const fallbackConfigs = await this.datasource.query(`SELECT * FROM frm_integration_config
74
- WHERE level_type = 'ORG'
75
- AND integration_type = 'EMAIL'
73
+ const fallbackConfigs = await this.datasource.query(`SELECT * FROM frm_integration_config
74
+ WHERE level_type = 'ORG'
75
+ AND integration_type = 'EMAIL'
76
76
  AND status = 1`);
77
77
  this.loggingService.log('debug', 'wrapperService', 'sendMailWrapper', `ORG-level configs: ${JSON.stringify(fallbackConfigs)}`, [], []);
78
78
  if (!fallbackConfigs || fallbackConfigs.length === 0) {
@@ -130,17 +130,17 @@ let WrapperService = WrapperService_1 = class WrapperService {
130
130
  let resolvedTemplateId = entity?.templateId;
131
131
  if (entity.template_code) {
132
132
  this.loggingService.log('debug', 'wrapperService', 'sendCommunicationWrapperService', `Looking up template for code=${entity.template_code}, level_id=${level_id}, level_type=${level_type}`, [], []);
133
- let templates = await this.datasource.query(`SELECT id FROM frm_wf_comm_template
134
- WHERE code = $1
135
- AND level_id = $2
136
- AND level_type = $3
133
+ let templates = await this.datasource.query(`SELECT id FROM frm_wf_comm_template
134
+ WHERE code = $1
135
+ AND level_id = $2
136
+ AND level_type = $3
137
137
  LIMIT 1`, [entity.template_code, level_id, level_type]);
138
138
  if (!templates || templates.length === 0) {
139
139
  this.loggingService.log('warn', 'wrapperService', 'sendCommunicationWrapperService', `No template found for ${entity.template_code} at provided level. Falling back to ORG-level.`, [], []);
140
- templates = await this.datasource.query(`SELECT id FROM frm_wf_comm_template
141
- WHERE code = $1
142
- AND level_type = 'ORG'
143
- AND organization_id = $2
140
+ templates = await this.datasource.query(`SELECT id FROM frm_wf_comm_template
141
+ WHERE code = $1
142
+ AND level_type = 'ORG'
143
+ AND organization_id = $2
144
144
  LIMIT 1`, [entity.template_code, organization_id]);
145
145
  }
146
146
  if (templates && templates.length > 0) {
@@ -206,11 +206,11 @@ let WrapperService = WrapperService_1 = class WrapperService {
206
206
  };
207
207
  }
208
208
  this.loggingService.log('log', 'wrapperService', 'scheduleMeetingWrapper', `No user-level config found, checking ORG-level...`, [], []);
209
- const orgConfigs = await this.datasource.query(`SELECT * FROM frm_integration_config
210
- WHERE level_id = 1
211
- AND level_type = 'ORG'
212
- AND integration_type = 'EMAIL'
213
- AND app_code ='DEFAULT'
209
+ const orgConfigs = await this.datasource.query(`SELECT * FROM frm_integration_config
210
+ WHERE level_id = 1
211
+ AND level_type = 'ORG'
212
+ AND integration_type = 'EMAIL'
213
+ AND app_code ='DEFAULT'
214
214
  AND status = 1`, []);
215
215
  integrationConfig = await this.integrationService.getSingleActiveConfig(1, 'ORG', 'DEFAULT', 'EMAIL');
216
216
  this.loggingService.log('debug', 'wrapperService', 'scheduleMeetingWrapper', `ORG configs found: ${JSON.stringify(orgConfigs)}`, [], []);
@@ -228,8 +228,8 @@ let WrapperService = WrapperService_1 = class WrapperService {
228
228
  }
229
229
  async getConfigCred(configId) {
230
230
  this.loggingService.log('debug', 'wrapperService', 'getConfigCred', `Fetching config JSON for configId=${configId}`, [], []);
231
- const configRes = await this.datasource.query(`SELECT config_json
232
- FROM frm_integration_config
231
+ const configRes = await this.datasource.query(`SELECT config_json
232
+ FROM frm_integration_config
233
233
  WHERE id = $1`, [configId]);
234
234
  this.loggingService.log('debug', 'wrapperService', 'getConfigCred', `Config fetch result: ${JSON.stringify(configRes)}`, [], []);
235
235
  return configRes?.[0]?.config_json || null;
@@ -237,10 +237,10 @@ let WrapperService = WrapperService_1 = class WrapperService {
237
237
  async sendIcsInvite(payload, levelId, levelType, appCode, organizationId, mapped_entities) {
238
238
  this.loggingService.log('log', 'wrapperService', 'sendIcsInvite', `Generating ICS file. Payload: ${JSON.stringify(payload)}`, [], []);
239
239
  if (payload.template_code) {
240
- let templates = await this.datasource.query(`SELECT id FROM frm_wf_comm_template
241
- WHERE code = $1
242
- AND level_id = $2
243
- AND level_type = $3
240
+ let templates = await this.datasource.query(`SELECT id FROM frm_wf_comm_template
241
+ WHERE code = $1
242
+ AND level_id = $2
243
+ AND level_type = $3
244
244
  LIMIT 1`, [payload.template_code, levelId, levelType]);
245
245
  this.logger.log(`template by code ${JSON.stringify(payload)}`);
246
246
  if (templates && templates.length > 0) {
@@ -132,8 +132,8 @@ let ListMasterItemService = class ListMasterItemService extends entity_service_i
132
132
  return `Item with name ${code} deleted successfully from type ${listType}`;
133
133
  }
134
134
  async getListSourceType(loggedInUser, source) {
135
- const data = await this.dataSource.query(`SELECT name AS label, type AS value
136
- FROM frm_list_master
135
+ const data = await this.dataSource.query(`SELECT name AS label, type AS value
136
+ FROM frm_list_master
137
137
  WHERE organization_id = $1 AND source = $2`, [loggedInUser.organization_id, source]);
138
138
  return data;
139
139
  }
@@ -107,10 +107,10 @@ let FieldMapperService = class FieldMapperService extends entity_service_impl_se
107
107
  entity_data[field.mapped_entity_type];
108
108
  }
109
109
  else {
110
- const relations = await this.datasource.query(`SELECT target_entity_id
111
- FROM frm_entity_relation_data
112
- WHERE source_entity_type = $1
113
- AND source_entity_id = $2
110
+ const relations = await this.datasource.query(`SELECT target_entity_id
111
+ FROM frm_entity_relation_data
112
+ WHERE source_entity_type = $1
113
+ AND source_entity_id = $2
114
114
  AND target_entity_type = $3`, [parent_type, parent_id, field.mapped_entity_type]);
115
115
  const targetEntityIds = relations.map((r) => r.target_entity_id);
116
116
  this.loggingService.log('debug', 'fieldMapperService', 'resolveData', `Resolved targetEntityIds: ${targetEntityIds} for entityType: ${entityType}`, [parent_type, parent_id, field.mapped_entity_type], []);
@@ -27,8 +27,8 @@ let MapperService = class MapperService extends entity_service_impl_service_1.En
27
27
  async getByMappedEntityType(mappedEntityType, loggedInUser, filter, status) {
28
28
  if (!mappedEntityType)
29
29
  return [];
30
- const mappers = await this.dataSource.query(`SELECT id, name, code, status
31
- FROM frm_mapper_master
30
+ const mappers = await this.dataSource.query(`SELECT id, name, code, status
31
+ FROM frm_mapper_master
32
32
  WHERE mapped_entity_type = $1 AND organization_id = $2 AND (-1 = $3 OR name LIKE $4 OR code LIKE $5)`, [mappedEntityType, loggedInUser.organization_id, filter || -1, `%${filter}%`, `%${filter}%`]);
33
33
  const distinctStatuses = [
34
34
  ...new Set(mappers.map((m) => m.status).filter((s) => s !== null)),
@@ -18,9 +18,9 @@ let EntityUpdateRepository = class EntityUpdateRepository {
18
18
  }
19
19
  async updateEntityAttribute(entity, config) {
20
20
  const { entityType, organization_id } = entity;
21
- const result = await this.dataSource.query(`SELECT db_table_name
22
- FROM frm_entity_master
23
- WHERE mapped_entity_type = ?
21
+ const result = await this.dataSource.query(`SELECT db_table_name
22
+ FROM frm_entity_master
23
+ WHERE mapped_entity_type = ?
24
24
  and organization_id = ?`, [config.entity_type, organization_id]);
25
25
  if (!result.length) {
26
26
  throw new Error("Entity table not found");
@@ -29,8 +29,8 @@ let EntityMasterRepository = class EntityMasterRepository {
29
29
  async getEntityById(id) {
30
30
  let data = await this.entityMasterRepository.findOne({ where: { id } });
31
31
  if (data) {
32
- let listMasterData = await this.entityMasterRepository.query(`SELECT *
33
- FROM frm_list_master_items
32
+ let listMasterData = await this.entityMasterRepository.query(`SELECT *
33
+ FROM frm_list_master_items
34
34
  where id = $1`, [data?.status]);
35
35
  data.status = listMasterData?.[0].name;
36
36
  }
@@ -81,10 +81,10 @@ let EntityMasterRepository = class EntityMasterRepository {
81
81
  }
82
82
  async getAttributesOfTypeDate(entity_type, loggedInUser) {
83
83
  const organization_id = loggedInUser.organization_id;
84
- const attributes = await this.dataSource.query(`SELECT *
85
- FROM frm_entity_attribute
86
- WHERE mapped_entity_type = $1
87
- AND data_type = 'DATE'
84
+ const attributes = await this.dataSource.query(`SELECT *
85
+ FROM frm_entity_attribute
86
+ WHERE mapped_entity_type = $1
87
+ AND data_type = 'DATE'
88
88
  AND organization_id = $2`, [entity_type, organization_id]);
89
89
  const attributeList = attributes.map((attr) => ({
90
90
  label: attr.name,
@@ -43,19 +43,19 @@ let EntityDynamicService = class EntityDynamicService {
43
43
  if (!entityData.entity_type)
44
44
  entityData.entity_type = entityType;
45
45
  }
46
- const statusList = await this.dataSource.query(`
47
- SELECT id
48
- FROM frm_list_master_items
49
- WHERE code = $1
50
- AND organization_id = $2
46
+ const statusList = await this.dataSource.query(`
47
+ SELECT id
48
+ FROM frm_list_master_items
49
+ WHERE code = $1
50
+ AND organization_id = $2
51
51
  `, [global_constant_1.STATUS_ACTIVE, organizationId]);
52
52
  if (!entityData.status)
53
53
  entityData.status = statusList[0]?.id;
54
54
  if (!entityData.code && entityData.entity_type) {
55
- const result = await this.dataSource.query(`
56
- SELECT MAX(id) AS max_seq_no
57
- FROM ${tableName}
58
- WHERE entity_type = $1
55
+ const result = await this.dataSource.query(`
56
+ SELECT MAX(id) AS max_seq_no
57
+ FROM ${tableName}
58
+ WHERE entity_type = $1
59
59
  `, [entityData.entity_type]);
60
60
  let maxSeq = Number(result?.[0]?.max_seq_no) || 0;
61
61
  maxSeq++;
@@ -97,18 +97,18 @@ let EntityDynamicService = class EntityDynamicService {
97
97
  }
98
98
  const colList = columns.map(c => `"${c}"`).join(', ');
99
99
  const placeholderList = placeholders.join(', ');
100
- const sql = `
101
- INSERT INTO ${tableName} (${colList})
102
- VALUES (${placeholderList}) RETURNING id
100
+ const sql = `
101
+ INSERT INTO ${tableName} (${colList})
102
+ VALUES (${placeholderList}) RETURNING id
103
103
  `;
104
104
  const result = await this.dataSource.query(sql, values);
105
105
  return result[0];
106
106
  }
107
107
  async createEntityWithRelation(entityType, data, loggedInUser) {
108
108
  const organizationId = loggedInUser.organization_id;
109
- const getRelation = await this.dataSource.query(`SELECT *
110
- FROM frm_entity_relation
111
- WHERE organization_id = $1
109
+ const getRelation = await this.dataSource.query(`SELECT *
110
+ FROM frm_entity_relation
111
+ WHERE organization_id = $1
112
112
  AND source_entity_type = $2`, [organizationId, entityType]);
113
113
  const { mappedEntities, ...mainData } = data;
114
114
  const createdEntityData = await this.createEntity(entityType, mainData, loggedInUser);
@@ -129,8 +129,8 @@ let EntityDynamicService = class EntityDynamicService {
129
129
  entity_type: targetEntityType,
130
130
  };
131
131
  const createdRelatedEntity = await this.createEntity(targetEntityType, itemWithRef, loggedInUser, mainID);
132
- await this.dataSource.query(`INSERT INTO frm_entity_relation_data (organization_id, source_entity_id, source_entity_type,
133
- target_entity_id, target_entity_type, relation_type)
132
+ await this.dataSource.query(`INSERT INTO frm_entity_relation_data (organization_id, source_entity_id, source_entity_type,
133
+ target_entity_id, target_entity_type, relation_type)
134
134
  VALUES ($1, $2, $3, $4, $5, $6)`, [
135
135
  organizationId,
136
136
  mainID,
@@ -152,9 +152,9 @@ let EntityDynamicService = class EntityDynamicService {
152
152
  }
153
153
  async getEntityWithRelation(entityType, id, loggedInUser) {
154
154
  const mainEntity = await this.getEntityByDataSource(entityType, id, loggedInUser);
155
- const relatedEntities = await this.dataSource.query(`SELECT *
156
- FROM frm_entity_relation_data
157
- WHERE source_entity_id = $1
155
+ const relatedEntities = await this.dataSource.query(`SELECT *
156
+ FROM frm_entity_relation_data
157
+ WHERE source_entity_id = $1
158
158
  AND target_entity_type IN (SELECT target_entity_type FROM frm_entity_relation WHERE source_entity_type = $2)`, [id, entityType]);
159
159
  const response = {
160
160
  entity_type: entityType,
@@ -184,9 +184,9 @@ let EntityDynamicService = class EntityDynamicService {
184
184
  const updatedMainEntity = await this.updateEntity(entityType, id, mainData, loggedInUser);
185
185
  const updatedRelations = {};
186
186
  if (mappedEntities) {
187
- const getRelationDefs = await this.dataSource.query(`SELECT *
188
- FROM frm_entity_relation
189
- WHERE organization_id = $1
187
+ const getRelationDefs = await this.dataSource.query(`SELECT *
188
+ FROM frm_entity_relation
189
+ WHERE organization_id = $1
190
190
  AND source_entity_type = $2`, [organizationId, entityType]);
191
191
  for (const [targetEntityType, rawEntityData] of Object.entries(mappedEntities)) {
192
192
  const relationDef = getRelationDefs.find((r) => r.target_entity_type === targetEntityType);
@@ -196,10 +196,10 @@ let EntityDynamicService = class EntityDynamicService {
196
196
  const entityArray = Array.isArray(rawEntityData)
197
197
  ? rawEntityData
198
198
  : [rawEntityData];
199
- const existingRelationsForType = await this.dataSource.query(`SELECT *
200
- FROM frm_entity_relation_data
201
- WHERE source_entity_type = $1
202
- AND source_entity_id = $2
199
+ const existingRelationsForType = await this.dataSource.query(`SELECT *
200
+ FROM frm_entity_relation_data
201
+ WHERE source_entity_type = $1
202
+ AND source_entity_id = $2
203
203
  AND target_entity_type = $3`, [entityType, id, targetEntityType]);
204
204
  const updatedEntities = [];
205
205
  for (const item of entityArray) {
@@ -214,9 +214,9 @@ let EntityDynamicService = class EntityDynamicService {
214
214
  const createdEntity = await this.createEntity(targetEntityType, item, loggedInUser, Number(id));
215
215
  targetEntityId = createdEntity.insertId || createdEntity.id;
216
216
  entityData = await this.getEntity(targetEntityType, targetEntityId, loggedInUser);
217
- await this.dataSource.query(`INSERT INTO frm_entity_relation_data
218
- (organization_id, source_entity_id, source_entity_type, target_entity_id, target_entity_type,
219
- relation_type)
217
+ await this.dataSource.query(`INSERT INTO frm_entity_relation_data
218
+ (organization_id, source_entity_id, source_entity_type, target_entity_id, target_entity_type,
219
+ relation_type)
220
220
  VALUES ($1, $2, $3, $4, $5, $6)`, [
221
221
  organizationId,
222
222
  id,
@@ -300,10 +300,10 @@ let EntityDynamicService = class EntityDynamicService {
300
300
  }
301
301
  const idPlaceholder = `$${idx}`;
302
302
  values.push(id);
303
- const updateQuery = `
304
- UPDATE ${tableName}
305
- SET ${updates.join(', ')}
306
- WHERE id = ${idPlaceholder}
303
+ const updateQuery = `
304
+ UPDATE ${tableName}
305
+ SET ${updates.join(', ')}
306
+ WHERE id = ${idPlaceholder}
307
307
  `;
308
308
  return await this.dataSource.query(updateQuery, values);
309
309
  }
@@ -314,8 +314,8 @@ let EntityDynamicService = class EntityDynamicService {
314
314
  const columns = validAttributes
315
315
  .map((attr) => `${attr.attribute_key}`)
316
316
  .join(', ');
317
- const selectQuery = `SELECT ${columns}
318
- FROM ${dataSource}
317
+ const selectQuery = `SELECT ${columns}
318
+ FROM ${dataSource}
319
319
  WHERE id = $1`;
320
320
  const result = await this.dataSource.query(selectQuery, [id]);
321
321
  if (!result.length)
@@ -344,8 +344,8 @@ let EntityDynamicService = class EntityDynamicService {
344
344
  const columns = validAttributes
345
345
  .map((attr) => `t.${attr.attribute_key}`)
346
346
  .join(', ');
347
- const selectQuery = `SELECT ${columns}
348
- FROM ${tableName} t
347
+ const selectQuery = `SELECT ${columns}
348
+ FROM ${tableName} t
349
349
  WHERE id = $1`;
350
350
  const result = await this.dataSource.query(selectQuery, [id]);
351
351
  if (!result.length)
@@ -407,16 +407,16 @@ let EntityDynamicService = class EntityDynamicService {
407
407
  async deleteEntity(entityType, id, loggedInUser) {
408
408
  const organizationId = loggedInUser.organization_id;
409
409
  const tableName = await this.getTableName(entityType, organizationId);
410
- const deleteQuery = `DELETE
411
- FROM \`${tableName}\`
410
+ const deleteQuery = `DELETE
411
+ FROM \`${tableName}\`
412
412
  WHERE id = $1`;
413
413
  const result = await this.dataSource.query(deleteQuery, [id]);
414
414
  return result;
415
415
  }
416
416
  async getEntitiesDropdownList(loggedInUser, appcode) {
417
417
  const organizationId = loggedInUser.organization_id;
418
- let query = `SELECT name as label, mapped_entity_type as value
419
- FROM frm_entity_master
418
+ let query = `SELECT name as label, mapped_entity_type as value
419
+ FROM frm_entity_master
420
420
  WHERE organization_id = $1`;
421
421
  const params = [organizationId];
422
422
  if (appcode) {
@@ -433,8 +433,8 @@ let EntityDynamicService = class EntityDynamicService {
433
433
  throw new Error(`Entity type '${entityType}' not found in frm_entity_master for org '${organizationId}'`);
434
434
  }
435
435
  const tableName = result.db_table_name;
436
- const seqResult = await this.dataSource.query(`SELECT MAX(id) AS max_seq_no
437
- FROM \`${tableName}\`
436
+ const seqResult = await this.dataSource.query(`SELECT MAX(id) AS max_seq_no
437
+ FROM \`${tableName}\`
438
438
  WHERE entity_type = $1`, [entityType]);
439
439
  let maxSeqNo = seqResult?.[0]?.max_seq_no
440
440
  ? Number(seqResult[0].max_seq_no)
@@ -75,11 +75,11 @@ let EntityListService = class EntityListService {
75
75
  }
76
76
  getQuery(source, groupByColumn) {
77
77
  if (groupByColumn) {
78
- return `SELECT ${groupByColumn} as tab_value, COUNT(1) AS tab_value_count
78
+ return `SELECT ${groupByColumn} as tab_value, COUNT(1) AS tab_value_count
79
79
  FROM ${source}`;
80
80
  }
81
81
  else {
82
- return `SELECT *
82
+ return `SELECT *
83
83
  FROM ${source}`;
84
84
  }
85
85
  }
@@ -123,7 +123,7 @@ let EntityListService = class EntityListService {
123
123
  return { query, argumentList: argsObjectList };
124
124
  }
125
125
  async getMaxSequenceNumber(tableName, parentType, parentId) {
126
- const query = `SELECT max(id) as seq_no
126
+ const query = `SELECT max(id) as seq_no
127
127
  FROM ${tableName} WHERE 1=1 `;
128
128
  const argsObjectList = [];
129
129
  const result = await this.entityManager.query(query, argsObjectList);
@@ -77,9 +77,9 @@ let EntityMasterService = class EntityMasterService {
77
77
  if (!entityMasterData) {
78
78
  throw new Error(`Entity master with mapped_entity_type "${entityType}" not found.`);
79
79
  }
80
- const attributes = await this.dataSource.query(`SELECT *
81
- FROM frm_entity_attribute
82
- WHERE mapped_entity_type = $1
80
+ const attributes = await this.dataSource.query(`SELECT *
81
+ FROM frm_entity_attribute
82
+ WHERE mapped_entity_type = $1
83
83
  AND organization_id = $2 `, [entityMasterData.mapped_entity_type, loggedInUser.organization_id]);
84
84
  entityMasterData['attribute_list'] = attributes;
85
85
  entityMasterData['operation_list'] = {
@@ -21,8 +21,8 @@ let EntityRelationService = class EntityRelationService extends entity_service_i
21
21
  this.entityMasterRepo = entityMasterRepo;
22
22
  }
23
23
  async getEntityRelations(entityType, loggedInUser, includeSelf = false) {
24
- const relations = await this.dataSource.query(`SELECT name as label, target_entity_type as value, id
25
- FROM frm_entity_relation
24
+ const relations = await this.dataSource.query(`SELECT name as label, target_entity_type as value, id
25
+ FROM frm_entity_relation
26
26
  WHERE source_entity_type = $1 AND organization_id = $2`, [entityType, loggedInUser.organization_id]);
27
27
  if (includeSelf) {
28
28
  const entity = await this.entityMasterRepo.getEntityByMappedEntityType(entityType, loggedInUser.organization_id);
@@ -53,13 +53,13 @@ let EntityRelationService = class EntityRelationService extends entity_service_i
53
53
  .join(", ");
54
54
  params.push(Number(orgId));
55
55
  const orgPlaceholder = `$${paramIndex}`;
56
- const sql = `
57
- SELECT DISTINCT source_entity_id
58
- FROM frm_entity_relation_data
59
- WHERE source_entity_type = ${sourceEntityParam}
60
- AND target_entity_type = ${targetEntityParam}
61
- AND target_entity_id IN (${idPlaceholders})
62
- AND organization_id = ${orgPlaceholder}
56
+ const sql = `
57
+ SELECT DISTINCT source_entity_id
58
+ FROM frm_entity_relation_data
59
+ WHERE source_entity_type = ${sourceEntityParam}
60
+ AND target_entity_type = ${targetEntityParam}
61
+ AND target_entity_id IN (${idPlaceholders})
62
+ AND organization_id = ${orgPlaceholder}
63
63
  `;
64
64
  const rows = await this.dataSource.query(sql, params);
65
65
  return rows.map((r) => Number(r.source_entity_id));
@@ -50,9 +50,9 @@ let EntityServiceImpl = class EntityServiceImpl {
50
50
  maxSeqNo = Number(maxSeqNo) + 1;
51
51
  entityData.code = entityData.entity_type + maxSeqNo;
52
52
  }
53
- const statusList = await repo.query(`SELECT id
54
- FROM frm_list_master_items
55
- WHERE code = $1
53
+ const statusList = await repo.query(`SELECT id
54
+ FROM frm_list_master_items
55
+ WHERE code = $1
56
56
  AND organization_id = $2`, [global_constant_1.STATUS_ACTIVE, loggedInUser?.organization_id || 0]);
57
57
  console.log('Status List:', statusList);
58
58
  console.log(`status_code,${global_constant_1.STATUS_ACTIVE},statusList, ${loggedInUser?.organization_id}`);
@@ -147,12 +147,12 @@ let ResolverService = class ResolverService {
147
147
  displayValue === '') {
148
148
  return displayValue;
149
149
  }
150
- const [attr] = await this.dataSource.query(`SELECT * FROM frm_entity_attribute
150
+ const [attr] = await this.dataSource.query(`SELECT * FROM frm_entity_attribute
151
151
  WHERE mapped_entity_type = $1 AND organization_id = $2 AND attribute_key = $3`, [entityType, loggedInUser.organization_id, attrKey]);
152
152
  if (!attr)
153
153
  return displayValue;
154
154
  if (attr.data_source_type === 'entity') {
155
- const [entityDef] = await this.dataSource.query(`SELECT * FROM frm_entity_master
155
+ const [entityDef] = await this.dataSource.query(`SELECT * FROM frm_entity_master
156
156
  WHERE mapped_entity_type = $1 AND organization_id = $2`, [attr.datasource_list, loggedInUser.organization_id]);
157
157
  if (!entityDef)
158
158
  return displayValue;
@@ -167,7 +167,7 @@ let ResolverService = class ResolverService {
167
167
  return item?.id ?? displayValue;
168
168
  }
169
169
  else if (attr.data_source_type === 'master') {
170
- const [item] = await this.dataSource.query(`SELECT id FROM frm_list_master_items
170
+ const [item] = await this.dataSource.query(`SELECT id FROM frm_list_master_items
171
171
  WHERE ${attr.data_source_attribute} = $1 AND organization_id = $2 AND listtype = $3`, [displayValue, loggedInUser.organization_id, attr.datasource_list]);
172
172
  return item?.id ?? displayValue;
173
173
  }
@@ -60,10 +60,10 @@ let MenuRepository = class MenuRepository extends typeorm_1.Repository {
60
60
  async getMenuItems(moduleCodes, appcode, levelType) {
61
61
  return await this.menuData
62
62
  .createQueryBuilder('menu')
63
- .leftJoin('sso_module', 'module', `
64
- menu.module_code = module.module_code
65
- AND LOWER(menu.appcode) = LOWER(module.appcode)
66
- AND menu.level_type = module.level_type
63
+ .leftJoin('sso_module', 'module', `
64
+ menu.module_code = module.module_code
65
+ AND LOWER(menu.appcode) = LOWER(module.appcode)
66
+ AND menu.level_type = module.level_type
67
67
  `)
68
68
  .where('menu.module_code IN (:...moduleCodes)', { moduleCodes })
69
69
  .andWhere('LOWER(menu.appcode) = LOWER(:appcode)', { appcode })
@@ -82,11 +82,11 @@ let MenuRepository = class MenuRepository extends typeorm_1.Repository {
82
82
  async resolveUserRoles(userId, appcode, levelType, levelId) {
83
83
  const repo = this.dataSource.getRepository(user_role_mapping_entity_1.UserRoleMapping);
84
84
  if (userId) {
85
- const getUserDetails = await this.dataSource.query(`
86
- SELECT * from sso_user where id = $1
85
+ const getUserDetails = await this.dataSource.query(`
86
+ SELECT * from sso_user where id = $1
87
87
  `, [userId]);
88
- const getUserUrm = await this.dataSource.query(`
89
- SELECT * from sso_user_role_mapping where user_id = $1 and appcode = $2
88
+ const getUserUrm = await this.dataSource.query(`
89
+ SELECT * from sso_user_role_mapping where user_id = $1 and appcode = $2
90
90
  `, [userId, appcode]);
91
91
  if (getUserDetails.length > 0 &&
92
92
  getUserDetails[0].organization_id === 1) {
@@ -105,10 +105,10 @@ let MenuRepository = class MenuRepository extends typeorm_1.Repository {
105
105
  if (roles.length)
106
106
  return roles.map((r) => r.urm_role_id);
107
107
  if (levelType === 'SCH') {
108
- const [sch] = await this.dataSource.query(`
109
- SELECT s.brand_id, s.organization_id
110
- FROM sso_school s
111
- WHERE s.id = $1
108
+ const [sch] = await this.dataSource.query(`
109
+ SELECT s.brand_id, s.organization_id
110
+ FROM sso_school s
111
+ WHERE s.id = $1
112
112
  `, [levelId]);
113
113
  const brandId = sch?.brand_id;
114
114
  const orgId = sch?.organization_id;
@@ -67,12 +67,12 @@ let NotificationsService = class NotificationsService {
67
67
  isReadFilter = isRead ? '1' : '0';
68
68
  }
69
69
  let paramIndex = 1;
70
- let sql = `
71
- SELECT n.*
72
- FROM frm_notification n
73
- WHERE n.user_id = $${paramIndex}
74
- AND n.level_id = $${paramIndex + 1}
75
- AND n.level_type = $${paramIndex + 2}
70
+ let sql = `
71
+ SELECT n.*
72
+ FROM frm_notification n
73
+ WHERE n.user_id = $${paramIndex}
74
+ AND n.level_id = $${paramIndex + 1}
75
+ AND n.level_type = $${paramIndex + 2}
76
76
  `;
77
77
  const params = [
78
78
  String(id),
@@ -107,10 +107,10 @@ let NotificationsService = class NotificationsService {
107
107
  }
108
108
  async markAllAsRead(loggedInUser) {
109
109
  const { id, level_id, level_type } = loggedInUser;
110
- const query = `
111
- UPDATE frm_notification
112
- SET is_read = 1
113
- WHERE user_id = $1 AND level_id = $2 AND level_type = $3 AND is_read = 0
110
+ const query = `
111
+ UPDATE frm_notification
112
+ SET is_read = 1
113
+ WHERE user_id = $1 AND level_id = $2 AND level_type = $3 AND is_read = 0
114
114
  `;
115
115
  const params = [id, level_id, level_type];
116
116
  const result = await this.dataSource.query(query, params);
@@ -57,27 +57,27 @@ let LoginController = class LoginController {
57
57
  try {
58
58
  const actualState = state.replace('gmail_config:', '');
59
59
  const result = await this.integrationService.handleGmailTokensCallback(email, googleAccessToken, googleRefreshToken, actualState);
60
- return res.send(`<html><body><script>
61
- window.opener.postMessage({ type: 'CONFIG_SUCCESS' }, '*');
62
- window.close();
60
+ return res.send(`<html><body><script>
61
+ window.opener.postMessage({ type: 'CONFIG_SUCCESS' }, '*');
62
+ window.close();
63
63
  </script> <p>Configuration successful. You can close this window.</p> </body></html>`);
64
64
  }
65
65
  catch (error) {
66
- return res.send(`
67
- <html>
68
- <body>
69
- <script>
70
- if (window.opener) {
71
- window.opener.postMessage({
72
- type: "CONFIG_FAILED",
73
- error: "${error.message || 'Something went wrong'}"
74
- }, "*");
75
- }
76
- window.close();
77
- </script>
78
- <p>Configuration failed. Please close this window.</p>
79
- </body>
80
- </html>
66
+ return res.send(`
67
+ <html>
68
+ <body>
69
+ <script>
70
+ if (window.opener) {
71
+ window.opener.postMessage({
72
+ type: "CONFIG_FAILED",
73
+ error: "${error.message || 'Something went wrong'}"
74
+ }, "*");
75
+ }
76
+ window.close();
77
+ </script>
78
+ <p>Configuration failed. Please close this window.</p>
79
+ </body>
80
+ </html>
81
81
  `);
82
82
  }
83
83
  }
@@ -76,10 +76,10 @@ let RoleService = class RoleService extends entity_service_impl_service_1.Entity
76
76
  if (!existingRole) {
77
77
  return { success: false, error: 'Role not found' };
78
78
  }
79
- const associatedUsers = await this.entityManager.query(`SELECT map.*
80
- FROM sso_user_role_mapping map
81
- JOIN sso_user usr ON map.user_id = usr.id
82
- WHERE usr.status = ${resolveStatus.id}
79
+ const associatedUsers = await this.entityManager.query(`SELECT map.*
80
+ FROM sso_user_role_mapping map
81
+ JOIN sso_user usr ON map.user_id = usr.id
82
+ WHERE usr.status = ${resolveStatus.id}
83
83
  and map.role_id = ${existingRole?.id}`);
84
84
  if (associatedUsers.length > 0) {
85
85
  return {
@@ -71,8 +71,8 @@ let UserSessionService = class UserSessionService {
71
71
  };
72
72
  let getUserDetails;
73
73
  if (currentUser) {
74
- getUserDetails = await this.dataSource.query(`
75
- SELECT * from sso_user where id = $1
74
+ getUserDetails = await this.dataSource.query(`
75
+ SELECT * from sso_user where id = $1
76
76
  `, [currentUser.id]);
77
77
  }
78
78
  if (getUserDetails[0].organization_id == 1 && payload.level_type == 'ORG') {