rez_core 4.0.98 → 4.0.100

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 (385) hide show
  1. package/.prettierrc +3 -3
  2. package/.vscode/extensions.json +5 -0
  3. package/README.md +99 -99
  4. package/dist/module/auth/guards/role.guard.js +3 -3
  5. package/dist/module/auth/services/auth.service.js +2 -2
  6. package/dist/module/filter/repository/saved-filter.repository.js +4 -4
  7. package/dist/module/filter/service/filter-evaluator.service.js +2 -2
  8. package/dist/module/filter/service/filter.service.js +22 -22
  9. package/dist/module/integration/examples/usage.example.js +9 -9
  10. package/dist/module/integration/service/integration.service.js +1 -1
  11. package/dist/module/integration/service/wrapper.service.js +25 -25
  12. package/dist/module/listmaster/service/list-master-item.service.js +2 -2
  13. package/dist/module/mapper/service/field-mapper.service.js +4 -4
  14. package/dist/module/mapper/service/mapper.service.js +2 -2
  15. package/dist/module/meta/service/entity-dynamic.service.js +25 -20
  16. package/dist/module/meta/service/entity-dynamic.service.js.map +1 -1
  17. package/dist/module/meta/service/entity-list.service.js +3 -3
  18. package/dist/module/meta/service/entity-master.service.js +3 -3
  19. package/dist/module/meta/service/entity-relation.service.js +11 -11
  20. package/dist/module/meta/service/entity-service-impl.service.js +3 -3
  21. package/dist/module/meta/service/resolver.service.js +3 -3
  22. package/dist/module/module/repository/menu.repository.js +12 -12
  23. package/dist/module/notification/service/notification.service.js +9 -9
  24. package/dist/module/user/controller/login.controller.js +18 -18
  25. package/dist/module/user/service/role.service.js +4 -4
  26. package/dist/module/user/service/user-session.service.js +2 -2
  27. package/dist/module/workflow/repository/action.repository.js +20 -20
  28. package/dist/module/workflow/repository/comm-template.repository.js +6 -6
  29. package/dist/module/workflow/repository/form-master.repository.js +2 -2
  30. package/dist/module/workflow/repository/stage-group.repository.js +23 -23
  31. package/dist/module/workflow/repository/stage-movement.repository.js +15 -15
  32. package/dist/module/workflow/repository/stage.repository.js +8 -8
  33. package/dist/module/workflow/service/action-template-mapping.service.js +22 -22
  34. package/dist/module/workflow/service/action.service.js +7 -7
  35. package/dist/module/workflow/service/entity-modification.service.js +6 -6
  36. package/dist/module/workflow/service/stage-group.service.js +2 -2
  37. package/dist/module/workflow/service/stage.service.js +2 -2
  38. package/dist/module/workflow/service/task.service.js +28 -28
  39. package/dist/module/workflow/service/workflow-list-master.service.js +15 -15
  40. package/dist/module/workflow/service/workflow-meta.service.js +35 -35
  41. package/dist/module/workflow/service/workflow.service.js +2 -2
  42. package/dist/tsconfig.build.tsbuildinfo +1 -1
  43. package/dist/utils/service/reflection-helper.service.js +2 -2
  44. package/docs/modules/event-driven-integration-design.md +91 -91
  45. package/docs/modules/integration.md +250 -250
  46. package/eslint.config.mjs +34 -34
  47. package/nest-cli.json +14 -14
  48. package/package.json +118 -118
  49. package/src/app.controller.ts +12 -12
  50. package/src/app.module.ts +49 -49
  51. package/src/app.service.ts +8 -8
  52. package/src/config/config.module.ts +18 -18
  53. package/src/config/database.config.ts +23 -23
  54. package/src/constant/global.constant.ts +67 -67
  55. package/src/core.module.ts +81 -81
  56. package/src/decorators/roles.decorator.ts +7 -7
  57. package/src/dtos/response.dto.ts +6 -6
  58. package/src/dtos/response.ts +5 -5
  59. package/src/index.ts +1 -1
  60. package/src/module/auth/auth.module.ts +49 -49
  61. package/src/module/auth/controller/auth.controller.ts +28 -28
  62. package/src/module/auth/guards/google-auth.guard.ts +9 -9
  63. package/src/module/auth/guards/jwt.guard.ts +22 -22
  64. package/src/module/auth/guards/role.guard.ts +68 -68
  65. package/src/module/auth/services/auth.service.ts +50 -50
  66. package/src/module/auth/services/jwt.service.ts +11 -11
  67. package/src/module/auth/strategies/google.strategy.ts +54 -54
  68. package/src/module/auth/strategies/jwt.strategy.ts +58 -58
  69. package/src/module/auth/strategies/local.strategy.ts +13 -13
  70. package/src/module/dashboard/controller/dashboard.controller.ts +36 -36
  71. package/src/module/dashboard/dashboard.module.ts +21 -21
  72. package/src/module/dashboard/entity/dashboard_page_data.entity.ts +27 -27
  73. package/src/module/dashboard/entity/widget_master.entity.ts +18 -18
  74. package/src/module/dashboard/repository/dashboard.repository.ts +42 -42
  75. package/src/module/dashboard/service/dashboard.service.ts +73 -73
  76. package/src/module/dev/dev.module.ts +12 -12
  77. package/src/module/dev/service/dev.service.ts +7 -7
  78. package/src/module/enterprise/controller/organization.controller.ts +36 -36
  79. package/src/module/enterprise/enterprise.module.ts +30 -30
  80. package/src/module/enterprise/entity/enterprise.entity.ts +37 -37
  81. package/src/module/enterprise/entity/organization-app-mapping.entity.ts +13 -13
  82. package/src/module/enterprise/entity/organization.entity.ts +92 -92
  83. package/src/module/enterprise/repository/enterprise.repository.ts +31 -31
  84. package/src/module/enterprise/repository/organization.repository.ts +26 -26
  85. package/src/module/enterprise/repository/school.repository.ts +278 -278
  86. package/src/module/enterprise/service/brand.service.ts +5 -5
  87. package/src/module/enterprise/service/enterprise.service.ts +16 -16
  88. package/src/module/enterprise/service/organization-app-mapping.service.ts +4 -4
  89. package/src/module/enterprise/service/organization.service.ts +145 -145
  90. package/src/module/filter/controller/filter.controller.ts +84 -84
  91. package/src/module/filter/dto/filter-request.dto.ts +38 -38
  92. package/src/module/filter/entity/saved-filter-detail.entity.ts +41 -41
  93. package/src/module/filter/entity/saved-filter-master.entity.ts +23 -23
  94. package/src/module/filter/filter.module.ts +31 -31
  95. package/src/module/filter/repository/saved-filter.repository.ts +168 -168
  96. package/src/module/filter/service/filter-evaluator.service.ts +86 -86
  97. package/src/module/filter/service/filter.service.ts +941 -941
  98. package/src/module/filter/service/saved-filter.service.ts +170 -170
  99. package/src/module/ics/controller/ics.controller.ts +21 -21
  100. package/src/module/ics/dto/ics.dto.ts +55 -55
  101. package/src/module/ics/ics.module.ts +13 -13
  102. package/src/module/ics/service/ics.service.ts +57 -57
  103. package/src/module/integration/controller/calender-event.controller.ts +31 -31
  104. package/src/module/integration/controller/integration.controller.ts +662 -662
  105. package/src/module/integration/controller/wrapper.controller.ts +37 -37
  106. package/src/module/integration/dto/create-config.dto.ts +526 -526
  107. package/src/module/integration/entity/integration-config.entity.ts +112 -112
  108. package/src/module/integration/entity/integration-entity-mapper.entity.ts +14 -14
  109. package/src/module/integration/entity/integration-source.entity.ts +17 -17
  110. package/src/module/integration/entity/user-integration.entity.ts +71 -71
  111. package/src/module/integration/examples/usage.example.ts +338 -338
  112. package/src/module/integration/factories/base.factory.ts +7 -7
  113. package/src/module/integration/factories/email.factory.ts +49 -49
  114. package/src/module/integration/factories/integration.factory.ts +121 -121
  115. package/src/module/integration/factories/sms.factory.ts +51 -51
  116. package/src/module/integration/factories/telephone.factory.ts +41 -41
  117. package/src/module/integration/factories/whatsapp.factory.ts +56 -56
  118. package/src/module/integration/integration.module.ts +110 -110
  119. package/src/module/integration/service/calendar-event.service.ts +118 -118
  120. package/src/module/integration/service/integration-entity-mapper.service.ts +17 -17
  121. package/src/module/integration/service/integration-queue.service.ts +229 -229
  122. package/src/module/integration/service/integration.service.ts +2633 -2633
  123. package/src/module/integration/service/oauth.service.ts +224 -224
  124. package/src/module/integration/service/wrapper.service.ts +493 -493
  125. package/src/module/integration/strategies/email/gmail-api.strategy.ts +280 -280
  126. package/src/module/integration/strategies/email/outlook-api.strategy.ts +44 -44
  127. package/src/module/integration/strategies/email/outlook.strategy.ts +64 -64
  128. package/src/module/integration/strategies/email/sendgrid-api.strategy.ts +260 -260
  129. package/src/module/integration/strategies/integration.strategy.ts +97 -97
  130. package/src/module/integration/strategies/sms/gupshup-sms.strategy.ts +146 -146
  131. package/src/module/integration/strategies/sms/msg91-sms.strategy.ts +164 -164
  132. package/src/module/integration/strategies/sms/tubelight-sms.strategy.ts +163 -163
  133. package/src/module/integration/strategies/telephone/ozonetel-voice.strategy.ts +238 -238
  134. package/src/module/integration/strategies/telephone/tubelight-voice.strategy.ts +210 -210
  135. package/src/module/integration/strategies/whatsapp/gupshup-whatsapp.strategy.ts +359 -359
  136. package/src/module/integration/strategies/whatsapp/tubelight-whatsapp.strategy.ts +372 -372
  137. package/src/module/integration/strategies/whatsapp/whatsapp-cloud.strategy.ts +403 -403
  138. package/src/module/integration/strategies/whatsapp/whatsapp.strategy.ts +57 -57
  139. package/src/module/layout/controller/layout.controller.ts +47 -47
  140. package/src/module/layout/entity/header-items.entity.ts +28 -28
  141. package/src/module/layout/entity/header-section.entity.ts +19 -19
  142. package/src/module/layout/layout.module.ts +21 -21
  143. package/src/module/layout/repository/header-items.repository.ts +18 -18
  144. package/src/module/layout/repository/header-section.repository.ts +22 -22
  145. package/src/module/layout/service/header-section.service.ts +25 -25
  146. package/src/module/layout_preference/controller/layout_preference.controller.ts +73 -73
  147. package/src/module/layout_preference/entity/layout_preference.entity.ts +28 -28
  148. package/src/module/layout_preference/layout_preference.module.ts +22 -22
  149. package/src/module/layout_preference/repository/layout_preference.repository.ts +65 -65
  150. package/src/module/layout_preference/service/layout_preference.service.ts +184 -184
  151. package/src/module/lead/controller/lead.controller.ts +30 -30
  152. package/src/module/lead/lead.module.ts +14 -14
  153. package/src/module/lead/repository/lead.repository.ts +41 -41
  154. package/src/module/lead/service/lead.service.ts +54 -54
  155. package/src/module/listmaster/controller/list-master.controller.ts +187 -187
  156. package/src/module/listmaster/entity/list-master-items.entity.ts +43 -43
  157. package/src/module/listmaster/entity/list-master.entity.ts +33 -33
  158. package/src/module/listmaster/listmaster.module.ts +44 -44
  159. package/src/module/listmaster/repository/list-master-items.repository.ts +169 -169
  160. package/src/module/listmaster/repository/list-master.repository.ts +46 -46
  161. package/src/module/listmaster/service/list-master-engine.ts +19 -19
  162. package/src/module/listmaster/service/list-master-extension.interface.ts +4 -4
  163. package/src/module/listmaster/service/list-master-item.service.ts +292 -292
  164. package/src/module/listmaster/service/list-master-registry.ts +15 -15
  165. package/src/module/listmaster/service/list-master.service.ts +441 -441
  166. package/src/module/mapper/controller/field-mapper.controller.ts +76 -76
  167. package/src/module/mapper/controller/mapper.controller.ts +20 -20
  168. package/src/module/mapper/dto/field-mapper.dto.ts +14 -14
  169. package/src/module/mapper/entity/field-lovs.entity.ts +19 -19
  170. package/src/module/mapper/entity/field-mapper.entity.ts +53 -53
  171. package/src/module/mapper/entity/mapper.entity.ts +16 -16
  172. package/src/module/mapper/mapper.module.ts +34 -34
  173. package/src/module/mapper/repository/field-lovs.repository.ts +35 -35
  174. package/src/module/mapper/repository/field-mapper.repository.ts +42 -42
  175. package/src/module/mapper/repository/mapper.repository.ts +15 -15
  176. package/src/module/mapper/service/field-mapper.service.ts +266 -266
  177. package/src/module/mapper/service/mapper.service.ts +79 -79
  178. package/src/module/master/controller/master.controller.ts +74 -74
  179. package/src/module/master/service/master.service.ts +483 -483
  180. package/src/module/meta/controller/app-master.controller.ts +38 -38
  181. package/src/module/meta/controller/attribute-master.controller.ts +66 -66
  182. package/src/module/meta/controller/entity-dynamic.controller.ts +125 -125
  183. package/src/module/meta/controller/entity-master.controller.ts +28 -28
  184. package/src/module/meta/controller/entity-relation.controller.ts +36 -36
  185. package/src/module/meta/controller/entity.controller.ts +392 -392
  186. package/src/module/meta/controller/entity.public.controller.ts +75 -75
  187. package/src/module/meta/controller/media.controller.ts +107 -107
  188. package/src/module/meta/controller/meta.controller.ts +96 -96
  189. package/src/module/meta/controller/view-master.controller.ts +86 -86
  190. package/src/module/meta/dto/entity-list-data.dto.ts +6 -6
  191. package/src/module/meta/dto/entity-tab.dto.ts +4 -4
  192. package/src/module/meta/dto/entity-table.dto.ts +9 -9
  193. package/src/module/meta/entity/app-master.entity.ts +34 -34
  194. package/src/module/meta/entity/attribute-master.entity.ts +89 -89
  195. package/src/module/meta/entity/base-entity.entity.ts +75 -75
  196. package/src/module/meta/entity/entity-master.entity.ts +85 -85
  197. package/src/module/meta/entity/entity-relation-data.entity.ts +29 -29
  198. package/src/module/meta/entity/entity-relation.entity.ts +23 -23
  199. package/src/module/meta/entity/entity-table-column.entity.ts +61 -61
  200. package/src/module/meta/entity/entity-table.entity.ts +50 -50
  201. package/src/module/meta/entity/media-data.entity.ts +32 -32
  202. package/src/module/meta/entity/preference.entity.ts +62 -62
  203. package/src/module/meta/entity/view-master.entity.ts +41 -41
  204. package/src/module/meta/entity.module.ts +158 -158
  205. package/src/module/meta/repository/app-master.repository.ts +20 -20
  206. package/src/module/meta/repository/attribute-master.repository.ts +110 -110
  207. package/src/module/meta/repository/entity-master.repository.ts +69 -69
  208. package/src/module/meta/repository/entity-table-column.repository.ts +39 -39
  209. package/src/module/meta/repository/entity-table.repository.ts +53 -53
  210. package/src/module/meta/repository/media-data.repository.ts +50 -50
  211. package/src/module/meta/repository/preference.repository.ts +20 -20
  212. package/src/module/meta/repository/user-app-mapping.repository.ts +28 -28
  213. package/src/module/meta/repository/view-master.repository.ts +42 -42
  214. package/src/module/meta/service/app-master.service.ts +37 -37
  215. package/src/module/meta/service/attribute-master.service.ts +117 -117
  216. package/src/module/meta/service/common.service.ts +9 -9
  217. package/src/module/meta/service/entity-dynamic.service.ts +818 -809
  218. package/src/module/meta/service/entity-list.service.ts +205 -205
  219. package/src/module/meta/service/entity-master.service.ts +169 -169
  220. package/src/module/meta/service/entity-realation-data.service.ts +9 -9
  221. package/src/module/meta/service/entity-relation.service.ts +69 -69
  222. package/src/module/meta/service/entity-service-impl.service.ts +525 -525
  223. package/src/module/meta/service/entity-table-column.service.ts +39 -39
  224. package/src/module/meta/service/entity-table.service.ts +150 -150
  225. package/src/module/meta/service/entity-validation.service.ts +187 -187
  226. package/src/module/meta/service/entity.service.ts +67 -67
  227. package/src/module/meta/service/field-group.service.ts +103 -103
  228. package/src/module/meta/service/media-data.service.ts +507 -507
  229. package/src/module/meta/service/populate-meta.service.ts +193 -193
  230. package/src/module/meta/service/preference.service.ts +16 -16
  231. package/src/module/meta/service/resolver.service.ts +267 -267
  232. package/src/module/meta/service/section-master.service.ts +104 -104
  233. package/src/module/meta/service/update-form-json.service.ts +22 -22
  234. package/src/module/meta/service/user-app-mapping.service.ts +17 -17
  235. package/src/module/meta/service/view-master.service.ts +127 -127
  236. package/src/module/module/controller/menu.controller.ts +15 -15
  237. package/src/module/module/controller/module-access.controller.ts +134 -134
  238. package/src/module/module/entity/menu.entity.ts +43 -43
  239. package/src/module/module/entity/module-access.entity.ts +25 -25
  240. package/src/module/module/entity/module-action.entity.ts +17 -17
  241. package/src/module/module/entity/module.entity.ts +52 -52
  242. package/src/module/module/module.module.ts +42 -42
  243. package/src/module/module/repository/menu.repository.ts +184 -184
  244. package/src/module/module/repository/module-access.repository.ts +344 -344
  245. package/src/module/module/service/menu.service.ts +82 -82
  246. package/src/module/module/service/module-access.service.ts +209 -209
  247. package/src/module/notification/controller/notification.controller.ts +58 -58
  248. package/src/module/notification/controller/otp.controller.ts +117 -117
  249. package/src/module/notification/entity/notification.entity.ts +26 -26
  250. package/src/module/notification/entity/otp.entity.ts +28 -28
  251. package/src/module/notification/firebase-admin.config.ts +22 -22
  252. package/src/module/notification/notification.module.ts +69 -69
  253. package/src/module/notification/repository/otp.repository.ts +27 -27
  254. package/src/module/notification/service/email.service.ts +127 -127
  255. package/src/module/notification/service/notification.service.ts +163 -163
  256. package/src/module/notification/service/otp.service.ts +132 -132
  257. package/src/module/third-party-module/entity/third-party-api-registry.entity.ts +52 -52
  258. package/src/module/third-party-module/repository/third-party-api-registry.repository.ts +20 -20
  259. package/src/module/third-party-module/service/api-registry.service.ts +13 -13
  260. package/src/module/third-party-module/third-party.module.ts +12 -12
  261. package/src/module/user/controller/login.controller.ts +197 -197
  262. package/src/module/user/controller/user.controller.ts +40 -40
  263. package/src/module/user/dto/create-user.dto.ts +62 -62
  264. package/src/module/user/dto/update-user.dto.ts +4 -4
  265. package/src/module/user/entity/role.entity.ts +33 -33
  266. package/src/module/user/entity/user-role-mapping.entity.ts +38 -38
  267. package/src/module/user/entity/user-session.entity.ts +73 -73
  268. package/src/module/user/entity/user.entity.ts +59 -59
  269. package/src/module/user/repository/role.repository.ts +96 -96
  270. package/src/module/user/repository/user-role-mapping.repository.ts +126 -126
  271. package/src/module/user/repository/user.repository.ts +50 -50
  272. package/src/module/user/repository/userSession.repository.ts +33 -33
  273. package/src/module/user/service/login.service.ts +284 -284
  274. package/src/module/user/service/role.service.ts +189 -189
  275. package/src/module/user/service/user-role-mapping.service.ts +98 -98
  276. package/src/module/user/service/user-session.service.ts +168 -168
  277. package/src/module/user/service/user.service.ts +365 -365
  278. package/src/module/user/user.module.ts +65 -65
  279. package/src/module/workflow/controller/action-category.controller.ts +54 -54
  280. package/src/module/workflow/controller/action-resource-mapping.controller.ts +23 -23
  281. package/src/module/workflow/controller/action-template-mapping.controller.ts +35 -35
  282. package/src/module/workflow/controller/action.controller.ts +111 -111
  283. package/src/module/workflow/controller/activity-log.controller.ts +55 -55
  284. package/src/module/workflow/controller/comm-template.controller.ts +43 -43
  285. package/src/module/workflow/controller/entity-modification.controller.ts +35 -35
  286. package/src/module/workflow/controller/form-master.controller.ts +43 -43
  287. package/src/module/workflow/controller/stage-group.controller.ts +48 -48
  288. package/src/module/workflow/controller/stage.controller.ts +50 -50
  289. package/src/module/workflow/controller/task.controller.ts +77 -77
  290. package/src/module/workflow/controller/workflow-list-master.controller.ts +44 -44
  291. package/src/module/workflow/controller/workflow-meta.controller.ts +80 -80
  292. package/src/module/workflow/controller/workflow.controller.ts +67 -67
  293. package/src/module/workflow/entity/action-category.entity.ts +38 -38
  294. package/src/module/workflow/entity/action-data.entity.ts +55 -55
  295. package/src/module/workflow/entity/action-resources-mapping.entity.ts +29 -29
  296. package/src/module/workflow/entity/action-template-mapping.entity.ts +17 -17
  297. package/src/module/workflow/entity/action.entity.ts +50 -50
  298. package/src/module/workflow/entity/activity-log.entity.ts +43 -43
  299. package/src/module/workflow/entity/comm-template.entity.ts +43 -43
  300. package/src/module/workflow/entity/entity-modification.entity.ts +38 -38
  301. package/src/module/workflow/entity/form.entity.ts +25 -25
  302. package/src/module/workflow/entity/stage-action-mapping.entity.ts +17 -17
  303. package/src/module/workflow/entity/stage-group.entity.ts +23 -23
  304. package/src/module/workflow/entity/stage-movement-data.entity.ts +38 -38
  305. package/src/module/workflow/entity/stage.entity.ts +20 -20
  306. package/src/module/workflow/entity/task-data.entity.ts +88 -88
  307. package/src/module/workflow/entity/template-attach-mapper.entity.ts +30 -30
  308. package/src/module/workflow/entity/workflow-data.entity.ts +11 -11
  309. package/src/module/workflow/entity/workflow-level-mapping.entity.ts +18 -18
  310. package/src/module/workflow/entity/workflow.entity.ts +20 -20
  311. package/src/module/workflow/repository/action-category.repository.ts +79 -79
  312. package/src/module/workflow/repository/action-data.repository.ts +333 -333
  313. package/src/module/workflow/repository/action.repository.ts +323 -323
  314. package/src/module/workflow/repository/activity-log.repository.ts +148 -148
  315. package/src/module/workflow/repository/comm-template.repository.ts +149 -149
  316. package/src/module/workflow/repository/form-master.repository.ts +59 -59
  317. package/src/module/workflow/repository/stage-group.repository.ts +176 -176
  318. package/src/module/workflow/repository/stage-movement.repository.ts +244 -244
  319. package/src/module/workflow/repository/stage.repository.ts +172 -172
  320. package/src/module/workflow/repository/task.repository.ts +127 -127
  321. package/src/module/workflow/repository/workflow.repository.ts +42 -42
  322. package/src/module/workflow/service/action-category.service.ts +33 -33
  323. package/src/module/workflow/service/action-data.service.ts +62 -62
  324. package/src/module/workflow/service/action-resources-mapping.service.ts +10 -10
  325. package/src/module/workflow/service/action-template-mapping.service.ts +106 -106
  326. package/src/module/workflow/service/action.service.ts +279 -279
  327. package/src/module/workflow/service/activity-log.service.ts +107 -107
  328. package/src/module/workflow/service/comm-template.service.ts +180 -180
  329. package/src/module/workflow/service/entity-modification.service.ts +67 -67
  330. package/src/module/workflow/service/form-master.service.ts +35 -35
  331. package/src/module/workflow/service/populate-workflow.service.ts +303 -303
  332. package/src/module/workflow/service/stage-action-mapping.service.ts +5 -5
  333. package/src/module/workflow/service/stage-group.service.ts +319 -319
  334. package/src/module/workflow/service/stage.service.ts +199 -199
  335. package/src/module/workflow/service/task.service.ts +560 -560
  336. package/src/module/workflow/service/workflow-list-master.service.ts +60 -60
  337. package/src/module/workflow/service/workflow-meta.service.ts +640 -640
  338. package/src/module/workflow/service/workflow.service.ts +205 -205
  339. package/src/module/workflow/workflow.module.ts +176 -176
  340. package/src/module/workflow-automation/controller/workflow-automation.controller.ts +21 -21
  341. package/src/module/workflow-automation/entity/workflow-automation-action.entity.ts +26 -26
  342. package/src/module/workflow-automation/entity/workflow-automation.entity.ts +35 -35
  343. package/src/module/workflow-automation/interface/action.decorator.ts +7 -7
  344. package/src/module/workflow-automation/interface/action.interface.ts +5 -5
  345. package/src/module/workflow-automation/service/action-registery.service.ts +35 -35
  346. package/src/module/workflow-automation/service/workflow-automation-engine.service.ts +214 -214
  347. package/src/module/workflow-automation/service/workflow-automation.service.ts +347 -347
  348. package/src/module/workflow-automation/workflow-automation.module.ts +34 -34
  349. package/src/resources/dev.properties.yaml +30 -30
  350. package/src/resources/local.properties.yaml +27 -27
  351. package/src/resources/properties.module.ts +12 -12
  352. package/src/resources/properties.yaml.ts +11 -11
  353. package/src/resources/uat.properties.yaml +31 -31
  354. package/src/table.config.ts +126 -126
  355. package/src/utils/dto/excel-data.dto.ts +14 -14
  356. package/src/utils/dto/excelsheet-data.dto.ts +5 -5
  357. package/src/utils/service/base64util.service.ts +18 -18
  358. package/src/utils/service/clockIDGenUtil.service.ts +21 -21
  359. package/src/utils/service/codeGenerator.service.ts +22 -22
  360. package/src/utils/service/dateUtil.service.ts +17 -17
  361. package/src/utils/service/encryptUtil.service.ts +97 -97
  362. package/src/utils/service/excel-helper.service.ts +72 -72
  363. package/src/utils/service/excelUtil.service.ts +15 -15
  364. package/src/utils/service/file-util.service.ts +11 -11
  365. package/src/utils/service/json-util.service.ts +23 -23
  366. package/src/utils/service/loggingUtil.service.ts +34 -34
  367. package/src/utils/service/reflection-helper.service.ts +62 -62
  368. package/src/utils/service/wbsCodeGen.service.ts +8 -8
  369. package/src/utils/utils.module.ts +25 -25
  370. package/tsconfig.build.json +4 -4
  371. package/tsconfig.json +24 -24
  372. package/.claude/settings.local.json +0 -26
  373. package/.idea/250218_nodejs_core.iml +0 -9
  374. package/.idea/codeStyles/Project.xml +0 -59
  375. package/.idea/codeStyles/codeStyleConfig.xml +0 -5
  376. package/.idea/copilot.data.migration.agent.xml +0 -6
  377. package/.idea/copilot.data.migration.ask.xml +0 -6
  378. package/.idea/copilot.data.migration.ask2agent.xml +0 -6
  379. package/.idea/copilot.data.migration.edit.xml +0 -6
  380. package/.idea/inspectionProfiles/Project_Default.xml +0 -6
  381. package/.idea/misc.xml +0 -6
  382. package/.idea/modules.xml +0 -8
  383. package/.idea/prettier.xml +0 -6
  384. package/.idea/vcs.xml +0 -6
  385. package/server.log +0 -850
@@ -1,662 +1,662 @@
1
- import {
2
- BadRequestException,
3
- Body,
4
- Controller,
5
- Get,
6
- HttpCode,
7
- HttpStatus,
8
- Param,
9
- ParseIntPipe,
10
- Post,
11
- Query,
12
- Req,
13
- UseGuards,
14
- } from '@nestjs/common';
15
- import { IntegrationService } from '../service/integration.service';
16
- import {
17
- BulkMessageDto,
18
- CheckAgentStatusDto,
19
- CreateConfigDto,
20
- CreateUserIntegrationDto,
21
- GenericSendMessageDto,
22
- GetIntegrationTemplatesDto,
23
- SendGridTemplatesDto,
24
- SendGridVerifiedSendersDto,
25
- UpdateConfigDto,
26
- UpdateUserIntegrationDto,
27
- } from '../dto/create-config.dto';
28
- import { JwtAuthGuard } from 'src/module/auth/guards/jwt.guard';
29
-
30
- export class ScheduledMessageDto extends GenericSendMessageDto {
31
- scheduleFor: Date;
32
- timezone?: string;
33
- }
34
-
35
- @Controller('integration')
36
- export class IntegrationController {
37
- constructor(private readonly integrationService: IntegrationService) {}
38
-
39
- @Post('send')
40
- @HttpCode(HttpStatus.OK)
41
- async sendMessage(@Body() sendMessageDto: GenericSendMessageDto) {
42
- try {
43
- return await this.integrationService.sendGenericMessage(sendMessageDto);
44
- } catch (error) {
45
- throw new BadRequestException({
46
- success: false,
47
- error: 'SEND_MESSAGE_ERROR',
48
- message: error.message || 'Failed to send message',
49
- code: 'MESSAGE_SEND_ERROR',
50
- });
51
- }
52
- }
53
-
54
- @Post('send/bulk')
55
- @HttpCode(HttpStatus.OK)
56
- async sendBulkMessage(@Body() bulkMessageDto: BulkMessageDto) {
57
- try {
58
- return await this.integrationService.sendBulkMessage(bulkMessageDto);
59
- } catch (error) {
60
- throw new BadRequestException({
61
- success: false,
62
- error: 'SEND_BULK_MESSAGE_ERROR',
63
- message: error.message || 'Failed to send bulk messages',
64
- code: 'BULK_MESSAGE_SEND_ERROR',
65
- });
66
- }
67
- }
68
-
69
- @Post('send/scheduled')
70
- @HttpCode(HttpStatus.OK)
71
- async scheduleMessage(@Body() scheduledMessageDto: ScheduledMessageDto) {
72
- try {
73
- return await this.integrationService.scheduleMessage(scheduledMessageDto);
74
- } catch (error) {
75
- throw new BadRequestException({
76
- success: false,
77
- error: 'SCHEDULE_MESSAGE_ERROR',
78
- message: error.message || 'Failed to schedule message',
79
- code: 'MESSAGE_SCHEDULE_ERROR',
80
- });
81
- }
82
- }
83
-
84
- @Post('send/template')
85
- @HttpCode(HttpStatus.OK)
86
- async sendTemplateMessage(
87
- @Body()
88
- templateMessage: {
89
- levelId: number;
90
- levelType: string;
91
- app_code: string;
92
- to: string | string[];
93
- templateId: string;
94
- variables: Record<string, any>;
95
- type?: 'EMAIL' | 'SMS' | 'WA' | 'TELEPHONE';
96
- },
97
- ) {
98
- try {
99
- return await this.integrationService.sendTemplateMessage(templateMessage);
100
- } catch (error) {
101
- throw new BadRequestException({
102
- success: false,
103
- error: 'SEND_TEMPLATE_MESSAGE_ERROR',
104
- message: error.message || 'Failed to send template message',
105
- code: 'TEMPLATE_MESSAGE_SEND_ERROR',
106
- });
107
- }
108
- }
109
-
110
- @Post('check-agent-status')
111
- @HttpCode(HttpStatus.OK)
112
- async checkAgentStatus(@Body() checkAgentStatusDto: CheckAgentStatusDto) {
113
- try {
114
- const result = await this.integrationService.checkAgentStatus(
115
- checkAgentStatusDto.levelId,
116
- checkAgentStatusDto.levelType,
117
- checkAgentStatusDto.app_code,
118
- checkAgentStatusDto.user_id,
119
- checkAgentStatusDto.type || 'TELEPHONE',
120
- );
121
-
122
- return result;
123
- } catch (error) {
124
- throw new BadRequestException({
125
- success: false,
126
- error: 'CHECK_AGENT_STATUS_ERROR',
127
- message: error.message || 'Failed to check agent status',
128
- code: 'AGENT_STATUS_ERROR',
129
- });
130
- }
131
- }
132
-
133
- @Post('config')
134
- @HttpCode(HttpStatus.OK)
135
- async createConfig(@Body() createConfigDto: CreateConfigDto) {
136
- try {
137
- const result = await this.integrationService.createIntegrationConfig(
138
- createConfigDto.levelId,
139
- createConfigDto.levelType,
140
- createConfigDto.app_code,
141
- createConfigDto.integration_type as
142
- | 'EMAIL'
143
- | 'SMS'
144
- | 'WA'
145
- | 'TELEPHONE',
146
- createConfigDto.integration_provider,
147
- createConfigDto.integration_source_id,
148
- createConfigDto.config,
149
- createConfigDto.priority,
150
- createConfigDto.is_default,
151
- );
152
-
153
- return result;
154
- } catch (error) {
155
- // Handle validation errors with BadRequest status
156
- if (
157
- error.message?.includes('active') &&
158
- error.message?.includes('configuration already exists')
159
- ) {
160
- throw new BadRequestException({
161
- success: false,
162
- error: 'DUPLICATE_CONFIGURATION',
163
- message: error.message,
164
- code: 'VALIDATION_ERROR',
165
- });
166
- }
167
-
168
- // Handle unsupported combination errors
169
- if (error.message?.includes('Unsupported combination')) {
170
- throw new BadRequestException({
171
- success: false,
172
- error: 'UNSUPPORTED_COMBINATION',
173
- message: error.message,
174
- code: 'VALIDATION_ERROR',
175
- });
176
- }
177
-
178
- // Handle OAuth redirect responses (return as success with OAuth info)
179
- if (error.authUrl && error.state) {
180
- return {
181
- success: false,
182
- requiresOAuth: true,
183
- authUrl: error.authUrl,
184
- state: error.state,
185
- message: error.message || 'OAuth authorization required',
186
- };
187
- }
188
-
189
- // Handle other errors as BadRequest
190
- throw new BadRequestException({
191
- success: false,
192
- error: 'CONFIGURATION_ERROR',
193
- message:
194
- error.message || 'Failed to create communication configuration',
195
- code: 'INTERNAL_ERROR',
196
- });
197
- }
198
- }
199
-
200
- @Get('supported-combinations')
201
- async getSupportedCombinations() {
202
- try {
203
- return await this.integrationService.getSupportedCombinations();
204
- } catch (error) {
205
- throw new BadRequestException({
206
- success: false,
207
- error: 'GET_COMBINATIONS_ERROR',
208
- message: error.message || 'Failed to get supported combinations',
209
- code: 'FETCH_ERROR',
210
- });
211
- }
212
- }
213
-
214
- @Get('level/:id/:type/configs')
215
- async getLevelConfigs(
216
- @Param('id', ParseIntPipe) levelId: number,
217
- @Param('type') levelType: string,
218
- @Query('app_code') app_code?: string,
219
- @Query('communication_config_type')
220
- configType?: 'WA' | 'SMS' | 'EMAIL' | 'TELEPHONE',
221
- @Query('provider') provider?: string,
222
- ) {
223
- try {
224
- return await this.integrationService.getLevelConfigs(levelId, levelType, {
225
- app_code,
226
- integration_type: configType,
227
- integration_provider: provider,
228
- });
229
- } catch (error) {
230
- throw new BadRequestException({
231
- success: false,
232
- error: 'GET_LEVEL_CONFIGS_ERROR',
233
- message: error.message || 'Failed to get level configurations',
234
- code: 'FETCH_ERROR',
235
- });
236
- }
237
- }
238
-
239
- @Get('config/:id')
240
- async getIntegrationConfigById(@Param('id', ParseIntPipe) hubId: number) {
241
- try {
242
- const config =
243
- await this.integrationService.getIntegrationConfigById(hubId);
244
-
245
- if (!config) {
246
- throw new BadRequestException({
247
- success: false,
248
- error: 'NOT_FOUND',
249
- message: 'Communication configuration not found',
250
- code: 'CONFIGURATION_NOT_FOUND',
251
- });
252
- }
253
-
254
- return {
255
- success: true,
256
- data: config,
257
- };
258
- } catch (error) {
259
- if (error instanceof BadRequestException) {
260
- throw error;
261
- }
262
-
263
- throw new BadRequestException({
264
- success: false,
265
- error: 'FETCH_ERROR',
266
- message: error.message || 'Failed to fetch communication configuration',
267
- code: 'INTERNAL_ERROR',
268
- });
269
- }
270
- }
271
-
272
- @Post('config/:id/update')
273
- @HttpCode(HttpStatus.OK)
274
- async activateConfig(
275
- @Param('id', ParseIntPipe) hubId: number,
276
- @Query('status') status: string,
277
- ) {
278
- try {
279
- const statusNumber = parseInt(status, 10);
280
- if (isNaN(statusNumber) || (statusNumber !== 0 && statusNumber !== 1)) {
281
- throw new BadRequestException('Status must be 0 or 1');
282
- }
283
-
284
- await this.integrationService.updateConfigStatus(hubId, statusNumber);
285
- return {
286
- success: true,
287
- message: 'Configuration updated successfully',
288
- };
289
- } catch (error) {
290
- throw new BadRequestException({
291
- success: false,
292
- error: 'UPDATE_STATUS_ERROR',
293
- });
294
- }
295
- }
296
-
297
- @Post('sendgrid/verified-senders')
298
- @HttpCode(HttpStatus.OK)
299
- async getSendGridVerifiedSenders(@Body() dto: SendGridVerifiedSendersDto) {
300
- try {
301
- return await this.integrationService.getSendGridVerifiedSenders(dto.apiKey);
302
- } catch (error) {
303
- throw new BadRequestException({
304
- success: false,
305
- error: 'GET_SENDGRID_SENDERS_ERROR',
306
- message: error.message || 'Failed to get SendGrid verified senders',
307
- code: 'SENDGRID_ERROR',
308
- });
309
- }
310
- }
311
-
312
- @Post('sendgrid/templates')
313
- @HttpCode(HttpStatus.OK)
314
- async getSendGridTemplates(@Body() dto: SendGridTemplatesDto) {
315
- try {
316
- return await this.integrationService.getSendGridTemplates(
317
- dto.levelId,
318
- dto.levelType,
319
- dto.app_code,
320
- );
321
- } catch (error) {
322
- throw new BadRequestException({
323
- success: false,
324
- error: 'GET_SENDGRID_TEMPLATES_ERROR',
325
- message: error.message || 'Failed to get SendGrid templates',
326
- code: 'SENDGRID_ERROR',
327
- });
328
- }
329
- }
330
-
331
- @Post('templates')
332
- @HttpCode(HttpStatus.OK)
333
- async getIntegrationTemplates(@Body() dto: GetIntegrationTemplatesDto) {
334
- try {
335
- return await this.integrationService.getIntegrationTemplates(
336
- dto.levelId,
337
- dto.levelType,
338
- dto.app_code,
339
- dto.integration_type,
340
- );
341
- } catch (error) {
342
- throw new BadRequestException({
343
- success: false,
344
- error: 'GET_TEMPLATES_ERROR',
345
- message: error.message || 'Failed to get templates',
346
- code: 'INTEGRATION_TEMPLATES_ERROR',
347
- });
348
- }
349
- }
350
-
351
- @Post('config/delete/:configId')
352
- @HttpCode(HttpStatus.OK)
353
- async disconnectConfig(@Param('configId', ParseIntPipe) configId: number) {
354
- try {
355
- await this.integrationService.deleteConfiguration(configId);
356
-
357
- return {
358
- success: true,
359
- message: 'Communication configuration deleted successfully',
360
- };
361
- } catch (error) {
362
- throw new BadRequestException({
363
- success: false,
364
- error: 'DELETE_ERROR',
365
- message:
366
- error.message || 'Failed to delete communication configuration',
367
- code: 'CONFIGURATION_ERROR',
368
- });
369
- }
370
- }
371
-
372
- @Post('config/update/:hubId')
373
- @HttpCode(HttpStatus.OK)
374
- async updateConfig(
375
- @Param('hubId', ParseIntPipe) hubId: number,
376
- @Body() updateDto: UpdateConfigDto,
377
- ) {
378
- try {
379
- const result = await this.integrationService.updateConfiguration(
380
- hubId,
381
- updateDto,
382
- );
383
-
384
- return {
385
- success: true,
386
- message: 'Communication configuration updated successfully',
387
- data: result,
388
- };
389
- } catch (error) {
390
- throw new BadRequestException({
391
- success: false,
392
- error: 'UPDATE_ERROR',
393
- message:
394
- error.message || 'Failed to update communication configuration',
395
- code: 'CONFIGURATION_ERROR',
396
- });
397
- }
398
- }
399
-
400
- // UserIntegration Management Endpoints
401
-
402
- @Post('user-integration')
403
- @HttpCode(HttpStatus.OK)
404
- async createUserIntegration(@Body() createDto: CreateUserIntegrationDto) {
405
- try {
406
- const result =
407
- await this.integrationService.createUserIntegration(createDto);
408
- return {
409
- success: true,
410
- message: 'User integration mapping created successfully',
411
- data: result,
412
- };
413
- } catch (error) {
414
- throw new BadRequestException({
415
- success: false,
416
- error: 'CREATE_USER_INTEGRATION_ERROR',
417
- message: error.message || 'Failed to create user integration mapping',
418
- code: 'USER_INTEGRATION_ERROR',
419
- });
420
- }
421
- }
422
-
423
- @Post('user-integration/bulk')
424
- @HttpCode(HttpStatus.OK)
425
- async bulkCreateUserIntegration(@Body() userIntegrations: CreateUserIntegrationDto[]) {
426
- try {
427
- const result =
428
- await this.integrationService.bulkCreateUserIntegration({ user_integrations: userIntegrations });
429
- return {
430
- success: true,
431
- message: `Bulk user integration completed: ${result.summary.created} created, ${result.summary.updated} updated, ${result.summary.failed} failed`,
432
- data: result,
433
- };
434
- } catch (error) {
435
- throw new BadRequestException({
436
- success: false,
437
- error: 'BULK_CREATE_USER_INTEGRATION_ERROR',
438
- message: error.message || 'Failed to bulk create user integration mappings',
439
- code: 'USER_INTEGRATION_ERROR',
440
- });
441
- }
442
- }
443
-
444
- @Get('user-integration/user/:userId')
445
- async getUserIntegrations(@Param('userId', ParseIntPipe) userId: number) {
446
- try {
447
- const result = await this.integrationService.getUserIntegrations(userId);
448
- return {
449
- success: true,
450
- data: result,
451
- };
452
- } catch (error) {
453
- throw new BadRequestException({
454
- success: false,
455
- error: 'GET_USER_INTEGRATIONS_ERROR',
456
- message: error.message || 'Failed to fetch user integrations',
457
- code: 'USER_INTEGRATION_ERROR',
458
- });
459
- }
460
- }
461
-
462
- @Get('user-integration/config/:configId')
463
- async getConfigUserIntegrations(
464
- @Param('configId', ParseIntPipe) configId: number,
465
- ) {
466
- try {
467
- const result =
468
- await this.integrationService.getConfigUserIntegrations(configId);
469
- return {
470
- success: true,
471
- data: result,
472
- };
473
- } catch (error) {
474
- throw new BadRequestException({
475
- success: false,
476
- error: 'GET_CONFIG_USER_INTEGRATIONS_ERROR',
477
- message: error.message || 'Failed to fetch config user integrations',
478
- code: 'USER_INTEGRATION_ERROR',
479
- });
480
- }
481
- }
482
-
483
- @Post('user-integration/:id')
484
- @HttpCode(HttpStatus.OK)
485
- async updateUserIntegration(
486
- @Param('id', ParseIntPipe) id: number,
487
- @Body() updateDto: UpdateUserIntegrationDto,
488
- ) {
489
- try {
490
- const result = await this.integrationService.updateUserIntegration(
491
- id,
492
- updateDto,
493
- );
494
- return {
495
- success: true,
496
- message: 'User integration mapping updated successfully',
497
- data: result,
498
- };
499
- } catch (error) {
500
- throw new BadRequestException({
501
- success: false,
502
- error: 'UPDATE_USER_INTEGRATION_ERROR',
503
- message: error.message || 'Failed to update user integration mapping',
504
- code: 'USER_INTEGRATION_ERROR',
505
- });
506
- }
507
- }
508
-
509
- @Post('user-integration/delete/:id')
510
- @HttpCode(HttpStatus.OK)
511
- async deleteUserIntegration(@Param('id', ParseIntPipe) id: number) {
512
- try {
513
- await this.integrationService.deleteUserIntegration(id);
514
- return {
515
- success: true,
516
- message: 'User integration mapping deleted successfully',
517
- };
518
- } catch (error) {
519
- throw new BadRequestException({
520
- success: false,
521
- error: 'DELETE_USER_INTEGRATION_ERROR',
522
- message: error.message || 'Failed to delete user integration mapping',
523
- code: 'USER_INTEGRATION_ERROR',
524
- });
525
- }
526
- }
527
-
528
- @Get('user-integration/:userId/:configId')
529
- async getUserIntegrationByUserAndConfig(
530
- @Param('userId', ParseIntPipe) userId: number,
531
- @Param('configId', ParseIntPipe) configId: number,
532
- ) {
533
- try {
534
- const result =
535
- await this.integrationService.getUserIntegrationByUserAndConfig(
536
- userId,
537
- configId,
538
- );
539
- return {
540
- success: true,
541
- data: result,
542
- };
543
- } catch (error) {
544
- throw new BadRequestException({
545
- success: false,
546
- error: 'GET_USER_INTEGRATION_ERROR',
547
- message: error.message || 'Failed to fetch user integration mapping',
548
- code: 'USER_INTEGRATION_ERROR',
549
- });
550
- }
551
- }
552
-
553
- @Get('getAll')
554
- @UseGuards(JwtAuthGuard)
555
- async getAllIntegration(
556
- @Req() req: Request & { user: any },
557
- @Query('integration_type')
558
- integration_type?: 'EMAIL' | 'SMS' | 'WA' | 'TELEPHONE',
559
- ) {
560
- try {
561
- const loggedInUser = req.user.userData;
562
-
563
- const allIntegrationData =
564
- await this.integrationService.getAllIntegrationData(
565
- loggedInUser,
566
- integration_type,
567
- );
568
-
569
- return allIntegrationData;
570
- } catch (error) {
571
- throw new BadRequestException({
572
- success: false,
573
- error: 'GET_ALL_INTEGRATIONS_ERROR',
574
- message: error.message || 'Failed to get all integrations',
575
- code: 'FETCH_ERROR',
576
- });
577
- }
578
- }
579
-
580
- @Get('provider-urls')
581
- getProviderUrls(
582
- @Query('integration_type')
583
- integration_type?: 'EMAIL' | 'SMS' | 'WA' | 'TELEPHONE',
584
- @Query('integration_provider') integration_provider?: string,
585
- ) {
586
- if (integration_type === 'TELEPHONE' && integration_provider) {
587
- if (integration_provider.toLowerCase() == 'ozonetel') {
588
- return {
589
- success: true,
590
- data: {
591
- baseUrl: 'https://in1-ccaas-api.ozonetel.com',
592
- agentLoginUrl: 'https://agent.cloudagent.ozonetel.com/login',
593
- },
594
- };
595
- } else if (integration_provider.toLowerCase() == 'tubelight') {
596
- return {
597
- success: true,
598
- data: {
599
- baseUrl: 'https://portal.tubelightcommunications.com',
600
- agentLoginUrl: 'https://dashboard.hellotubelight.com/sign-in',
601
- },
602
- };
603
- }
604
- } else if (integration_type === 'WA' && integration_provider) {
605
- if (integration_provider.toLowerCase() == 'tubelight') {
606
- return {
607
- success: true,
608
- data: {
609
- baseUrl: 'https://portal.tubelightcommunications.com',
610
- agentLoginUrl: 'https://dashboard.hellotubelight.com/sign-in',
611
- },
612
- };
613
- } else if (integration_provider.toLowerCase() == 'gupshup') {
614
- return {
615
- success: true,
616
- data: {
617
- baseUrl: 'https://api.gupshup.io',
618
- agentLoginUrl: 'https://login.gupshup.io/u/login',
619
- },
620
- };
621
- }
622
- }
623
- }
624
-
625
- @Get('active-config')
626
- async getActiveConfig(
627
- @Query('level_id', ParseIntPipe) levelId: number,
628
- @Query('level_type') levelType: string,
629
- @Query('app_code') appCode: string,
630
- @Query('integration_type')
631
- integrationType: 'EMAIL' | 'SMS' | 'WA' | 'TELEPHONE',
632
- ) {
633
- try {
634
- const config = await this.integrationService.getSingleActiveConfig(
635
- levelId,
636
- levelType,
637
- appCode,
638
- integrationType,
639
- );
640
-
641
- if (!config) {
642
- return {
643
- success: false,
644
- message: 'No active configuration found',
645
- data: null,
646
- };
647
- }
648
-
649
- return {
650
- success: true,
651
- data: config,
652
- };
653
- } catch (error) {
654
- throw new BadRequestException({
655
- success: false,
656
- error: 'GET_ACTIVE_CONFIG_ERROR',
657
- message: error.message || 'Failed to fetch active configuration',
658
- code: 'FETCH_ERROR',
659
- });
660
- }
661
- }
662
- }
1
+ import {
2
+ BadRequestException,
3
+ Body,
4
+ Controller,
5
+ Get,
6
+ HttpCode,
7
+ HttpStatus,
8
+ Param,
9
+ ParseIntPipe,
10
+ Post,
11
+ Query,
12
+ Req,
13
+ UseGuards,
14
+ } from '@nestjs/common';
15
+ import { IntegrationService } from '../service/integration.service';
16
+ import {
17
+ BulkMessageDto,
18
+ CheckAgentStatusDto,
19
+ CreateConfigDto,
20
+ CreateUserIntegrationDto,
21
+ GenericSendMessageDto,
22
+ GetIntegrationTemplatesDto,
23
+ SendGridTemplatesDto,
24
+ SendGridVerifiedSendersDto,
25
+ UpdateConfigDto,
26
+ UpdateUserIntegrationDto,
27
+ } from '../dto/create-config.dto';
28
+ import { JwtAuthGuard } from 'src/module/auth/guards/jwt.guard';
29
+
30
+ export class ScheduledMessageDto extends GenericSendMessageDto {
31
+ scheduleFor: Date;
32
+ timezone?: string;
33
+ }
34
+
35
+ @Controller('integration')
36
+ export class IntegrationController {
37
+ constructor(private readonly integrationService: IntegrationService) {}
38
+
39
+ @Post('send')
40
+ @HttpCode(HttpStatus.OK)
41
+ async sendMessage(@Body() sendMessageDto: GenericSendMessageDto) {
42
+ try {
43
+ return await this.integrationService.sendGenericMessage(sendMessageDto);
44
+ } catch (error) {
45
+ throw new BadRequestException({
46
+ success: false,
47
+ error: 'SEND_MESSAGE_ERROR',
48
+ message: error.message || 'Failed to send message',
49
+ code: 'MESSAGE_SEND_ERROR',
50
+ });
51
+ }
52
+ }
53
+
54
+ @Post('send/bulk')
55
+ @HttpCode(HttpStatus.OK)
56
+ async sendBulkMessage(@Body() bulkMessageDto: BulkMessageDto) {
57
+ try {
58
+ return await this.integrationService.sendBulkMessage(bulkMessageDto);
59
+ } catch (error) {
60
+ throw new BadRequestException({
61
+ success: false,
62
+ error: 'SEND_BULK_MESSAGE_ERROR',
63
+ message: error.message || 'Failed to send bulk messages',
64
+ code: 'BULK_MESSAGE_SEND_ERROR',
65
+ });
66
+ }
67
+ }
68
+
69
+ @Post('send/scheduled')
70
+ @HttpCode(HttpStatus.OK)
71
+ async scheduleMessage(@Body() scheduledMessageDto: ScheduledMessageDto) {
72
+ try {
73
+ return await this.integrationService.scheduleMessage(scheduledMessageDto);
74
+ } catch (error) {
75
+ throw new BadRequestException({
76
+ success: false,
77
+ error: 'SCHEDULE_MESSAGE_ERROR',
78
+ message: error.message || 'Failed to schedule message',
79
+ code: 'MESSAGE_SCHEDULE_ERROR',
80
+ });
81
+ }
82
+ }
83
+
84
+ @Post('send/template')
85
+ @HttpCode(HttpStatus.OK)
86
+ async sendTemplateMessage(
87
+ @Body()
88
+ templateMessage: {
89
+ levelId: number;
90
+ levelType: string;
91
+ app_code: string;
92
+ to: string | string[];
93
+ templateId: string;
94
+ variables: Record<string, any>;
95
+ type?: 'EMAIL' | 'SMS' | 'WA' | 'TELEPHONE';
96
+ },
97
+ ) {
98
+ try {
99
+ return await this.integrationService.sendTemplateMessage(templateMessage);
100
+ } catch (error) {
101
+ throw new BadRequestException({
102
+ success: false,
103
+ error: 'SEND_TEMPLATE_MESSAGE_ERROR',
104
+ message: error.message || 'Failed to send template message',
105
+ code: 'TEMPLATE_MESSAGE_SEND_ERROR',
106
+ });
107
+ }
108
+ }
109
+
110
+ @Post('check-agent-status')
111
+ @HttpCode(HttpStatus.OK)
112
+ async checkAgentStatus(@Body() checkAgentStatusDto: CheckAgentStatusDto) {
113
+ try {
114
+ const result = await this.integrationService.checkAgentStatus(
115
+ checkAgentStatusDto.levelId,
116
+ checkAgentStatusDto.levelType,
117
+ checkAgentStatusDto.app_code,
118
+ checkAgentStatusDto.user_id,
119
+ checkAgentStatusDto.type || 'TELEPHONE',
120
+ );
121
+
122
+ return result;
123
+ } catch (error) {
124
+ throw new BadRequestException({
125
+ success: false,
126
+ error: 'CHECK_AGENT_STATUS_ERROR',
127
+ message: error.message || 'Failed to check agent status',
128
+ code: 'AGENT_STATUS_ERROR',
129
+ });
130
+ }
131
+ }
132
+
133
+ @Post('config')
134
+ @HttpCode(HttpStatus.OK)
135
+ async createConfig(@Body() createConfigDto: CreateConfigDto) {
136
+ try {
137
+ const result = await this.integrationService.createIntegrationConfig(
138
+ createConfigDto.levelId,
139
+ createConfigDto.levelType,
140
+ createConfigDto.app_code,
141
+ createConfigDto.integration_type as
142
+ | 'EMAIL'
143
+ | 'SMS'
144
+ | 'WA'
145
+ | 'TELEPHONE',
146
+ createConfigDto.integration_provider,
147
+ createConfigDto.integration_source_id,
148
+ createConfigDto.config,
149
+ createConfigDto.priority,
150
+ createConfigDto.is_default,
151
+ );
152
+
153
+ return result;
154
+ } catch (error) {
155
+ // Handle validation errors with BadRequest status
156
+ if (
157
+ error.message?.includes('active') &&
158
+ error.message?.includes('configuration already exists')
159
+ ) {
160
+ throw new BadRequestException({
161
+ success: false,
162
+ error: 'DUPLICATE_CONFIGURATION',
163
+ message: error.message,
164
+ code: 'VALIDATION_ERROR',
165
+ });
166
+ }
167
+
168
+ // Handle unsupported combination errors
169
+ if (error.message?.includes('Unsupported combination')) {
170
+ throw new BadRequestException({
171
+ success: false,
172
+ error: 'UNSUPPORTED_COMBINATION',
173
+ message: error.message,
174
+ code: 'VALIDATION_ERROR',
175
+ });
176
+ }
177
+
178
+ // Handle OAuth redirect responses (return as success with OAuth info)
179
+ if (error.authUrl && error.state) {
180
+ return {
181
+ success: false,
182
+ requiresOAuth: true,
183
+ authUrl: error.authUrl,
184
+ state: error.state,
185
+ message: error.message || 'OAuth authorization required',
186
+ };
187
+ }
188
+
189
+ // Handle other errors as BadRequest
190
+ throw new BadRequestException({
191
+ success: false,
192
+ error: 'CONFIGURATION_ERROR',
193
+ message:
194
+ error.message || 'Failed to create communication configuration',
195
+ code: 'INTERNAL_ERROR',
196
+ });
197
+ }
198
+ }
199
+
200
+ @Get('supported-combinations')
201
+ async getSupportedCombinations() {
202
+ try {
203
+ return await this.integrationService.getSupportedCombinations();
204
+ } catch (error) {
205
+ throw new BadRequestException({
206
+ success: false,
207
+ error: 'GET_COMBINATIONS_ERROR',
208
+ message: error.message || 'Failed to get supported combinations',
209
+ code: 'FETCH_ERROR',
210
+ });
211
+ }
212
+ }
213
+
214
+ @Get('level/:id/:type/configs')
215
+ async getLevelConfigs(
216
+ @Param('id', ParseIntPipe) levelId: number,
217
+ @Param('type') levelType: string,
218
+ @Query('app_code') app_code?: string,
219
+ @Query('communication_config_type')
220
+ configType?: 'WA' | 'SMS' | 'EMAIL' | 'TELEPHONE',
221
+ @Query('provider') provider?: string,
222
+ ) {
223
+ try {
224
+ return await this.integrationService.getLevelConfigs(levelId, levelType, {
225
+ app_code,
226
+ integration_type: configType,
227
+ integration_provider: provider,
228
+ });
229
+ } catch (error) {
230
+ throw new BadRequestException({
231
+ success: false,
232
+ error: 'GET_LEVEL_CONFIGS_ERROR',
233
+ message: error.message || 'Failed to get level configurations',
234
+ code: 'FETCH_ERROR',
235
+ });
236
+ }
237
+ }
238
+
239
+ @Get('config/:id')
240
+ async getIntegrationConfigById(@Param('id', ParseIntPipe) hubId: number) {
241
+ try {
242
+ const config =
243
+ await this.integrationService.getIntegrationConfigById(hubId);
244
+
245
+ if (!config) {
246
+ throw new BadRequestException({
247
+ success: false,
248
+ error: 'NOT_FOUND',
249
+ message: 'Communication configuration not found',
250
+ code: 'CONFIGURATION_NOT_FOUND',
251
+ });
252
+ }
253
+
254
+ return {
255
+ success: true,
256
+ data: config,
257
+ };
258
+ } catch (error) {
259
+ if (error instanceof BadRequestException) {
260
+ throw error;
261
+ }
262
+
263
+ throw new BadRequestException({
264
+ success: false,
265
+ error: 'FETCH_ERROR',
266
+ message: error.message || 'Failed to fetch communication configuration',
267
+ code: 'INTERNAL_ERROR',
268
+ });
269
+ }
270
+ }
271
+
272
+ @Post('config/:id/update')
273
+ @HttpCode(HttpStatus.OK)
274
+ async activateConfig(
275
+ @Param('id', ParseIntPipe) hubId: number,
276
+ @Query('status') status: string,
277
+ ) {
278
+ try {
279
+ const statusNumber = parseInt(status, 10);
280
+ if (isNaN(statusNumber) || (statusNumber !== 0 && statusNumber !== 1)) {
281
+ throw new BadRequestException('Status must be 0 or 1');
282
+ }
283
+
284
+ await this.integrationService.updateConfigStatus(hubId, statusNumber);
285
+ return {
286
+ success: true,
287
+ message: 'Configuration updated successfully',
288
+ };
289
+ } catch (error) {
290
+ throw new BadRequestException({
291
+ success: false,
292
+ error: 'UPDATE_STATUS_ERROR',
293
+ });
294
+ }
295
+ }
296
+
297
+ @Post('sendgrid/verified-senders')
298
+ @HttpCode(HttpStatus.OK)
299
+ async getSendGridVerifiedSenders(@Body() dto: SendGridVerifiedSendersDto) {
300
+ try {
301
+ return await this.integrationService.getSendGridVerifiedSenders(dto.apiKey);
302
+ } catch (error) {
303
+ throw new BadRequestException({
304
+ success: false,
305
+ error: 'GET_SENDGRID_SENDERS_ERROR',
306
+ message: error.message || 'Failed to get SendGrid verified senders',
307
+ code: 'SENDGRID_ERROR',
308
+ });
309
+ }
310
+ }
311
+
312
+ @Post('sendgrid/templates')
313
+ @HttpCode(HttpStatus.OK)
314
+ async getSendGridTemplates(@Body() dto: SendGridTemplatesDto) {
315
+ try {
316
+ return await this.integrationService.getSendGridTemplates(
317
+ dto.levelId,
318
+ dto.levelType,
319
+ dto.app_code,
320
+ );
321
+ } catch (error) {
322
+ throw new BadRequestException({
323
+ success: false,
324
+ error: 'GET_SENDGRID_TEMPLATES_ERROR',
325
+ message: error.message || 'Failed to get SendGrid templates',
326
+ code: 'SENDGRID_ERROR',
327
+ });
328
+ }
329
+ }
330
+
331
+ @Post('templates')
332
+ @HttpCode(HttpStatus.OK)
333
+ async getIntegrationTemplates(@Body() dto: GetIntegrationTemplatesDto) {
334
+ try {
335
+ return await this.integrationService.getIntegrationTemplates(
336
+ dto.levelId,
337
+ dto.levelType,
338
+ dto.app_code,
339
+ dto.integration_type,
340
+ );
341
+ } catch (error) {
342
+ throw new BadRequestException({
343
+ success: false,
344
+ error: 'GET_TEMPLATES_ERROR',
345
+ message: error.message || 'Failed to get templates',
346
+ code: 'INTEGRATION_TEMPLATES_ERROR',
347
+ });
348
+ }
349
+ }
350
+
351
+ @Post('config/delete/:configId')
352
+ @HttpCode(HttpStatus.OK)
353
+ async disconnectConfig(@Param('configId', ParseIntPipe) configId: number) {
354
+ try {
355
+ await this.integrationService.deleteConfiguration(configId);
356
+
357
+ return {
358
+ success: true,
359
+ message: 'Communication configuration deleted successfully',
360
+ };
361
+ } catch (error) {
362
+ throw new BadRequestException({
363
+ success: false,
364
+ error: 'DELETE_ERROR',
365
+ message:
366
+ error.message || 'Failed to delete communication configuration',
367
+ code: 'CONFIGURATION_ERROR',
368
+ });
369
+ }
370
+ }
371
+
372
+ @Post('config/update/:hubId')
373
+ @HttpCode(HttpStatus.OK)
374
+ async updateConfig(
375
+ @Param('hubId', ParseIntPipe) hubId: number,
376
+ @Body() updateDto: UpdateConfigDto,
377
+ ) {
378
+ try {
379
+ const result = await this.integrationService.updateConfiguration(
380
+ hubId,
381
+ updateDto,
382
+ );
383
+
384
+ return {
385
+ success: true,
386
+ message: 'Communication configuration updated successfully',
387
+ data: result,
388
+ };
389
+ } catch (error) {
390
+ throw new BadRequestException({
391
+ success: false,
392
+ error: 'UPDATE_ERROR',
393
+ message:
394
+ error.message || 'Failed to update communication configuration',
395
+ code: 'CONFIGURATION_ERROR',
396
+ });
397
+ }
398
+ }
399
+
400
+ // UserIntegration Management Endpoints
401
+
402
+ @Post('user-integration')
403
+ @HttpCode(HttpStatus.OK)
404
+ async createUserIntegration(@Body() createDto: CreateUserIntegrationDto) {
405
+ try {
406
+ const result =
407
+ await this.integrationService.createUserIntegration(createDto);
408
+ return {
409
+ success: true,
410
+ message: 'User integration mapping created successfully',
411
+ data: result,
412
+ };
413
+ } catch (error) {
414
+ throw new BadRequestException({
415
+ success: false,
416
+ error: 'CREATE_USER_INTEGRATION_ERROR',
417
+ message: error.message || 'Failed to create user integration mapping',
418
+ code: 'USER_INTEGRATION_ERROR',
419
+ });
420
+ }
421
+ }
422
+
423
+ @Post('user-integration/bulk')
424
+ @HttpCode(HttpStatus.OK)
425
+ async bulkCreateUserIntegration(@Body() userIntegrations: CreateUserIntegrationDto[]) {
426
+ try {
427
+ const result =
428
+ await this.integrationService.bulkCreateUserIntegration({ user_integrations: userIntegrations });
429
+ return {
430
+ success: true,
431
+ message: `Bulk user integration completed: ${result.summary.created} created, ${result.summary.updated} updated, ${result.summary.failed} failed`,
432
+ data: result,
433
+ };
434
+ } catch (error) {
435
+ throw new BadRequestException({
436
+ success: false,
437
+ error: 'BULK_CREATE_USER_INTEGRATION_ERROR',
438
+ message: error.message || 'Failed to bulk create user integration mappings',
439
+ code: 'USER_INTEGRATION_ERROR',
440
+ });
441
+ }
442
+ }
443
+
444
+ @Get('user-integration/user/:userId')
445
+ async getUserIntegrations(@Param('userId', ParseIntPipe) userId: number) {
446
+ try {
447
+ const result = await this.integrationService.getUserIntegrations(userId);
448
+ return {
449
+ success: true,
450
+ data: result,
451
+ };
452
+ } catch (error) {
453
+ throw new BadRequestException({
454
+ success: false,
455
+ error: 'GET_USER_INTEGRATIONS_ERROR',
456
+ message: error.message || 'Failed to fetch user integrations',
457
+ code: 'USER_INTEGRATION_ERROR',
458
+ });
459
+ }
460
+ }
461
+
462
+ @Get('user-integration/config/:configId')
463
+ async getConfigUserIntegrations(
464
+ @Param('configId', ParseIntPipe) configId: number,
465
+ ) {
466
+ try {
467
+ const result =
468
+ await this.integrationService.getConfigUserIntegrations(configId);
469
+ return {
470
+ success: true,
471
+ data: result,
472
+ };
473
+ } catch (error) {
474
+ throw new BadRequestException({
475
+ success: false,
476
+ error: 'GET_CONFIG_USER_INTEGRATIONS_ERROR',
477
+ message: error.message || 'Failed to fetch config user integrations',
478
+ code: 'USER_INTEGRATION_ERROR',
479
+ });
480
+ }
481
+ }
482
+
483
+ @Post('user-integration/:id')
484
+ @HttpCode(HttpStatus.OK)
485
+ async updateUserIntegration(
486
+ @Param('id', ParseIntPipe) id: number,
487
+ @Body() updateDto: UpdateUserIntegrationDto,
488
+ ) {
489
+ try {
490
+ const result = await this.integrationService.updateUserIntegration(
491
+ id,
492
+ updateDto,
493
+ );
494
+ return {
495
+ success: true,
496
+ message: 'User integration mapping updated successfully',
497
+ data: result,
498
+ };
499
+ } catch (error) {
500
+ throw new BadRequestException({
501
+ success: false,
502
+ error: 'UPDATE_USER_INTEGRATION_ERROR',
503
+ message: error.message || 'Failed to update user integration mapping',
504
+ code: 'USER_INTEGRATION_ERROR',
505
+ });
506
+ }
507
+ }
508
+
509
+ @Post('user-integration/delete/:id')
510
+ @HttpCode(HttpStatus.OK)
511
+ async deleteUserIntegration(@Param('id', ParseIntPipe) id: number) {
512
+ try {
513
+ await this.integrationService.deleteUserIntegration(id);
514
+ return {
515
+ success: true,
516
+ message: 'User integration mapping deleted successfully',
517
+ };
518
+ } catch (error) {
519
+ throw new BadRequestException({
520
+ success: false,
521
+ error: 'DELETE_USER_INTEGRATION_ERROR',
522
+ message: error.message || 'Failed to delete user integration mapping',
523
+ code: 'USER_INTEGRATION_ERROR',
524
+ });
525
+ }
526
+ }
527
+
528
+ @Get('user-integration/:userId/:configId')
529
+ async getUserIntegrationByUserAndConfig(
530
+ @Param('userId', ParseIntPipe) userId: number,
531
+ @Param('configId', ParseIntPipe) configId: number,
532
+ ) {
533
+ try {
534
+ const result =
535
+ await this.integrationService.getUserIntegrationByUserAndConfig(
536
+ userId,
537
+ configId,
538
+ );
539
+ return {
540
+ success: true,
541
+ data: result,
542
+ };
543
+ } catch (error) {
544
+ throw new BadRequestException({
545
+ success: false,
546
+ error: 'GET_USER_INTEGRATION_ERROR',
547
+ message: error.message || 'Failed to fetch user integration mapping',
548
+ code: 'USER_INTEGRATION_ERROR',
549
+ });
550
+ }
551
+ }
552
+
553
+ @Get('getAll')
554
+ @UseGuards(JwtAuthGuard)
555
+ async getAllIntegration(
556
+ @Req() req: Request & { user: any },
557
+ @Query('integration_type')
558
+ integration_type?: 'EMAIL' | 'SMS' | 'WA' | 'TELEPHONE',
559
+ ) {
560
+ try {
561
+ const loggedInUser = req.user.userData;
562
+
563
+ const allIntegrationData =
564
+ await this.integrationService.getAllIntegrationData(
565
+ loggedInUser,
566
+ integration_type,
567
+ );
568
+
569
+ return allIntegrationData;
570
+ } catch (error) {
571
+ throw new BadRequestException({
572
+ success: false,
573
+ error: 'GET_ALL_INTEGRATIONS_ERROR',
574
+ message: error.message || 'Failed to get all integrations',
575
+ code: 'FETCH_ERROR',
576
+ });
577
+ }
578
+ }
579
+
580
+ @Get('provider-urls')
581
+ getProviderUrls(
582
+ @Query('integration_type')
583
+ integration_type?: 'EMAIL' | 'SMS' | 'WA' | 'TELEPHONE',
584
+ @Query('integration_provider') integration_provider?: string,
585
+ ) {
586
+ if (integration_type === 'TELEPHONE' && integration_provider) {
587
+ if (integration_provider.toLowerCase() == 'ozonetel') {
588
+ return {
589
+ success: true,
590
+ data: {
591
+ baseUrl: 'https://in1-ccaas-api.ozonetel.com',
592
+ agentLoginUrl: 'https://agent.cloudagent.ozonetel.com/login',
593
+ },
594
+ };
595
+ } else if (integration_provider.toLowerCase() == 'tubelight') {
596
+ return {
597
+ success: true,
598
+ data: {
599
+ baseUrl: 'https://portal.tubelightcommunications.com',
600
+ agentLoginUrl: 'https://dashboard.hellotubelight.com/sign-in',
601
+ },
602
+ };
603
+ }
604
+ } else if (integration_type === 'WA' && integration_provider) {
605
+ if (integration_provider.toLowerCase() == 'tubelight') {
606
+ return {
607
+ success: true,
608
+ data: {
609
+ baseUrl: 'https://portal.tubelightcommunications.com',
610
+ agentLoginUrl: 'https://dashboard.hellotubelight.com/sign-in',
611
+ },
612
+ };
613
+ } else if (integration_provider.toLowerCase() == 'gupshup') {
614
+ return {
615
+ success: true,
616
+ data: {
617
+ baseUrl: 'https://api.gupshup.io',
618
+ agentLoginUrl: 'https://login.gupshup.io/u/login',
619
+ },
620
+ };
621
+ }
622
+ }
623
+ }
624
+
625
+ @Get('active-config')
626
+ async getActiveConfig(
627
+ @Query('level_id', ParseIntPipe) levelId: number,
628
+ @Query('level_type') levelType: string,
629
+ @Query('app_code') appCode: string,
630
+ @Query('integration_type')
631
+ integrationType: 'EMAIL' | 'SMS' | 'WA' | 'TELEPHONE',
632
+ ) {
633
+ try {
634
+ const config = await this.integrationService.getSingleActiveConfig(
635
+ levelId,
636
+ levelType,
637
+ appCode,
638
+ integrationType,
639
+ );
640
+
641
+ if (!config) {
642
+ return {
643
+ success: false,
644
+ message: 'No active configuration found',
645
+ data: null,
646
+ };
647
+ }
648
+
649
+ return {
650
+ success: true,
651
+ data: config,
652
+ };
653
+ } catch (error) {
654
+ throw new BadRequestException({
655
+ success: false,
656
+ error: 'GET_ACTIVE_CONFIG_ERROR',
657
+ message: error.message || 'Failed to fetch active configuration',
658
+ code: 'FETCH_ERROR',
659
+ });
660
+ }
661
+ }
662
+ }