rez_core 4.0.136 → 4.0.138

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 (438) hide show
  1. package/.prettierrc +3 -3
  2. package/README.md +99 -99
  3. package/dist/config/config.module.js +2 -2
  4. package/dist/config/config.module.js.map +1 -1
  5. package/dist/config/database.config.d.ts +1 -1
  6. package/dist/config/database.config.js +12 -15
  7. package/dist/config/database.config.js.map +1 -1
  8. package/dist/module/auth/guards/role.guard.js +3 -3
  9. package/dist/module/auth/services/auth.service.js +3 -3
  10. package/dist/module/auth/services/auth.service.js.map +1 -1
  11. package/dist/module/enterprise/entity/organization.entity.js +1 -1
  12. package/dist/module/filter/repository/saved-filter.repository.js +4 -4
  13. package/dist/module/filter/service/filter-evaluator.service.js +2 -2
  14. package/dist/module/filter/service/filter.service.js +22 -22
  15. package/dist/module/integration/entity/integration-config.entity.js +6 -6
  16. package/dist/module/integration/entity/integration-config.entity.js.map +1 -1
  17. package/dist/module/integration/entity/integration-entity-mapper.entity.js +1 -1
  18. package/dist/module/integration/entity/integration-entity-mapper.entity.js.map +1 -1
  19. package/dist/module/integration/entity/integration-source.entity.js +4 -4
  20. package/dist/module/integration/entity/integration-source.entity.js.map +1 -1
  21. package/dist/module/integration/entity/user-integration.entity.js +4 -4
  22. package/dist/module/integration/entity/user-integration.entity.js.map +1 -1
  23. package/dist/module/integration/examples/usage.example.js +9 -9
  24. package/dist/module/integration/service/integration.service.js +1 -1
  25. package/dist/module/integration/service/wrapper.service.d.ts +3 -1
  26. package/dist/module/integration/service/wrapper.service.js +64 -61
  27. package/dist/module/integration/service/wrapper.service.js.map +1 -1
  28. package/dist/module/listmaster/entity/list-master-items.entity.js +3 -3
  29. package/dist/module/listmaster/entity/list-master-items.entity.js.map +1 -1
  30. package/dist/module/listmaster/entity/list-master.entity.js +4 -4
  31. package/dist/module/listmaster/entity/list-master.entity.js.map +1 -1
  32. package/dist/module/listmaster/service/list-master-item.service.js +2 -2
  33. package/dist/module/mapper/entity/field-mapper.entity.js +6 -6
  34. package/dist/module/mapper/entity/field-mapper.entity.js.map +1 -1
  35. package/dist/module/mapper/service/field-mapper.service.js +6 -6
  36. package/dist/module/mapper/service/field-mapper.service.js.map +1 -1
  37. package/dist/module/mapper/service/mapper.service.js +2 -2
  38. package/dist/module/meta/entity/entity-master.entity.js +1 -1
  39. package/dist/module/meta/entity/entity-master.entity.js.map +1 -1
  40. package/dist/module/meta/entity/view-master.entity.js +1 -1
  41. package/dist/module/meta/entity/view-master.entity.js.map +1 -1
  42. package/dist/module/meta/service/attribute-master.service.js +1 -1
  43. package/dist/module/meta/service/attribute-master.service.js.map +1 -1
  44. package/dist/module/meta/service/entity-dynamic.service.js +9 -9
  45. package/dist/module/meta/service/entity-list.service.js +3 -3
  46. package/dist/module/meta/service/entity-master.service.js +3 -3
  47. package/dist/module/meta/service/entity-relation.service.js +11 -11
  48. package/dist/module/meta/service/entity-service-impl.service.js +3 -3
  49. package/dist/module/meta/service/resolver.service.js +5 -5
  50. package/dist/module/meta/service/resolver.service.js.map +1 -1
  51. package/dist/module/module/repository/menu.repository.js +13 -13
  52. package/dist/module/module/repository/menu.repository.js.map +1 -1
  53. package/dist/module/notification/entity/otp.entity.js +1 -1
  54. package/dist/module/notification/entity/otp.entity.js.map +1 -1
  55. package/dist/module/notification/service/notification.service.js +9 -9
  56. package/dist/module/user/controller/login.controller.js +18 -18
  57. package/dist/module/user/entity/user-role-mapping.entity.js +1 -1
  58. package/dist/module/user/entity/user-role-mapping.entity.js.map +1 -1
  59. package/dist/module/user/service/role.service.js +4 -4
  60. package/dist/module/user/service/user-session.service.js +2 -2
  61. package/dist/module/workflow/entity/action-data.entity.js +1 -1
  62. package/dist/module/workflow/entity/action-data.entity.js.map +1 -1
  63. package/dist/module/workflow/entity/action.entity.js +1 -1
  64. package/dist/module/workflow/entity/action.entity.js.map +1 -1
  65. package/dist/module/workflow/entity/comm-template.entity.js +1 -1
  66. package/dist/module/workflow/entity/comm-template.entity.js.map +1 -1
  67. package/dist/module/workflow/repository/action.repository.js +20 -20
  68. package/dist/module/workflow/repository/comm-template.repository.js +6 -6
  69. package/dist/module/workflow/repository/form-master.repository.js +2 -2
  70. package/dist/module/workflow/repository/stage-group.repository.js +23 -23
  71. package/dist/module/workflow/repository/stage-movement.repository.js +15 -15
  72. package/dist/module/workflow/repository/stage.repository.js +8 -8
  73. package/dist/module/workflow/repository/task.repository.d.ts +3 -1
  74. package/dist/module/workflow/repository/task.repository.js +8 -3
  75. package/dist/module/workflow/repository/task.repository.js.map +1 -1
  76. package/dist/module/workflow/service/action-template-mapping.service.js +22 -22
  77. package/dist/module/workflow/service/action.service.js +7 -7
  78. package/dist/module/workflow/service/entity-modification.service.js +6 -6
  79. package/dist/module/workflow/service/stage-group.service.js +2 -2
  80. package/dist/module/workflow/service/stage.service.js +2 -2
  81. package/dist/module/workflow/service/task.service.js +36 -41
  82. package/dist/module/workflow/service/task.service.js.map +1 -1
  83. package/dist/module/workflow/service/workflow-list-master.service.js +15 -15
  84. package/dist/module/workflow/service/workflow-meta.service.js +49 -47
  85. package/dist/module/workflow/service/workflow-meta.service.js.map +1 -1
  86. package/dist/module/workflow/service/workflow.service.js +2 -2
  87. package/dist/tsconfig.build.tsbuildinfo +1 -1
  88. package/dist/utils/service/loggingUtil.service.d.ts +9 -2
  89. package/dist/utils/service/loggingUtil.service.js +65 -14
  90. package/dist/utils/service/loggingUtil.service.js.map +1 -1
  91. package/dist/utils/service/reflection-helper.service.js +2 -2
  92. package/dist/utils/utils.module.js +2 -0
  93. package/dist/utils/utils.module.js.map +1 -1
  94. package/docs/modules/event-driven-integration-design.md +91 -91
  95. package/docs/modules/integration.md +250 -250
  96. package/eslint.config.mjs +34 -34
  97. package/nest-cli.json +14 -14
  98. package/package.json +119 -120
  99. package/src/app.controller.ts +12 -12
  100. package/src/app.module.ts +52 -52
  101. package/src/app.service.ts +8 -8
  102. package/src/config/config.module.ts +18 -17
  103. package/src/config/database.config.ts +23 -47
  104. package/src/constant/global.constant.ts +67 -67
  105. package/src/core.module.ts +81 -81
  106. package/src/decorators/roles.decorator.ts +7 -7
  107. package/src/dtos/response.dto.ts +6 -6
  108. package/src/dtos/response.ts +5 -5
  109. package/src/index.ts +1 -1
  110. package/src/module/auth/auth.module.ts +49 -49
  111. package/src/module/auth/controller/auth.controller.ts +28 -28
  112. package/src/module/auth/guards/google-auth.guard.ts +9 -9
  113. package/src/module/auth/guards/jwt.guard.ts +22 -22
  114. package/src/module/auth/guards/role.guard.ts +68 -68
  115. package/src/module/auth/services/auth.service.ts +50 -50
  116. package/src/module/auth/services/jwt.service.ts +11 -11
  117. package/src/module/auth/strategies/google.strategy.ts +54 -54
  118. package/src/module/auth/strategies/jwt.strategy.ts +58 -58
  119. package/src/module/auth/strategies/local.strategy.ts +13 -13
  120. package/src/module/dashboard/controller/dashboard.controller.ts +36 -36
  121. package/src/module/dashboard/dashboard.module.ts +21 -21
  122. package/src/module/dashboard/entity/dashboard_page_data.entity.ts +27 -27
  123. package/src/module/dashboard/entity/widget_master.entity.ts +18 -18
  124. package/src/module/dashboard/repository/dashboard.repository.ts +42 -42
  125. package/src/module/dashboard/service/dashboard.service.ts +73 -73
  126. package/src/module/dev/dev.module.ts +12 -12
  127. package/src/module/dev/service/dev.service.ts +7 -7
  128. package/src/module/enterprise/controller/organization.controller.ts +36 -36
  129. package/src/module/enterprise/enterprise.module.ts +30 -30
  130. package/src/module/enterprise/entity/enterprise.entity.ts +37 -37
  131. package/src/module/enterprise/entity/organization-app-mapping.entity.ts +13 -13
  132. package/src/module/enterprise/entity/organization.entity.ts +92 -92
  133. package/src/module/enterprise/repository/enterprise.repository.ts +31 -31
  134. package/src/module/enterprise/repository/organization.repository.ts +26 -26
  135. package/src/module/enterprise/repository/school.repository.ts +278 -278
  136. package/src/module/enterprise/service/brand.service.ts +5 -5
  137. package/src/module/enterprise/service/enterprise.service.ts +16 -16
  138. package/src/module/enterprise/service/organization-app-mapping.service.ts +4 -4
  139. package/src/module/enterprise/service/organization.service.ts +145 -145
  140. package/src/module/filter/controller/filter.controller.ts +84 -84
  141. package/src/module/filter/dto/filter-request.dto.ts +38 -38
  142. package/src/module/filter/entity/saved-filter-detail.entity.ts +41 -41
  143. package/src/module/filter/entity/saved-filter-master.entity.ts +23 -23
  144. package/src/module/filter/filter.module.ts +31 -31
  145. package/src/module/filter/repository/saved-filter.repository.ts +168 -168
  146. package/src/module/filter/service/filter-evaluator.service.ts +86 -86
  147. package/src/module/filter/service/filter.service.ts +1005 -1005
  148. package/src/module/filter/service/saved-filter.service.ts +170 -170
  149. package/src/module/ics/controller/ics.controller.ts +21 -21
  150. package/src/module/ics/dto/ics.dto.ts +55 -55
  151. package/src/module/ics/ics.module.ts +13 -13
  152. package/src/module/ics/service/ics.service.ts +57 -57
  153. package/src/module/integration/controller/calender-event.controller.ts +31 -31
  154. package/src/module/integration/controller/integration.controller.ts +662 -662
  155. package/src/module/integration/controller/wrapper.controller.ts +37 -37
  156. package/src/module/integration/dto/create-config.dto.ts +526 -526
  157. package/src/module/integration/entity/integration-config.entity.ts +112 -112
  158. package/src/module/integration/entity/integration-entity-mapper.entity.ts +14 -14
  159. package/src/module/integration/entity/integration-source.entity.ts +17 -17
  160. package/src/module/integration/entity/user-integration.entity.ts +71 -71
  161. package/src/module/integration/examples/usage.example.ts +338 -338
  162. package/src/module/integration/factories/base.factory.ts +7 -7
  163. package/src/module/integration/factories/email.factory.ts +49 -49
  164. package/src/module/integration/factories/integration.factory.ts +121 -121
  165. package/src/module/integration/factories/sms.factory.ts +51 -51
  166. package/src/module/integration/factories/telephone.factory.ts +41 -41
  167. package/src/module/integration/factories/whatsapp.factory.ts +56 -56
  168. package/src/module/integration/integration.module.ts +110 -110
  169. package/src/module/integration/service/calendar-event.service.ts +118 -118
  170. package/src/module/integration/service/integration-entity-mapper.service.ts +17 -17
  171. package/src/module/integration/service/integration-queue.service.ts +229 -229
  172. package/src/module/integration/service/integration.service.ts +2633 -2633
  173. package/src/module/integration/service/oauth.service.ts +224 -224
  174. package/src/module/integration/service/wrapper.service.ts +700 -493
  175. package/src/module/integration/strategies/email/gmail-api.strategy.ts +280 -280
  176. package/src/module/integration/strategies/email/outlook-api.strategy.ts +44 -44
  177. package/src/module/integration/strategies/email/outlook.strategy.ts +64 -64
  178. package/src/module/integration/strategies/email/sendgrid-api.strategy.ts +260 -260
  179. package/src/module/integration/strategies/integration.strategy.ts +97 -97
  180. package/src/module/integration/strategies/sms/gupshup-sms.strategy.ts +146 -146
  181. package/src/module/integration/strategies/sms/msg91-sms.strategy.ts +164 -164
  182. package/src/module/integration/strategies/sms/tubelight-sms.strategy.ts +163 -163
  183. package/src/module/integration/strategies/telephone/ozonetel-voice.strategy.ts +238 -238
  184. package/src/module/integration/strategies/telephone/tubelight-voice.strategy.ts +210 -210
  185. package/src/module/integration/strategies/whatsapp/gupshup-whatsapp.strategy.ts +359 -359
  186. package/src/module/integration/strategies/whatsapp/tubelight-whatsapp.strategy.ts +372 -372
  187. package/src/module/integration/strategies/whatsapp/whatsapp-cloud.strategy.ts +403 -403
  188. package/src/module/integration/strategies/whatsapp/whatsapp.strategy.ts +57 -57
  189. package/src/module/layout/controller/layout.controller.ts +47 -47
  190. package/src/module/layout/entity/header-items.entity.ts +28 -28
  191. package/src/module/layout/entity/header-section.entity.ts +19 -19
  192. package/src/module/layout/layout.module.ts +21 -21
  193. package/src/module/layout/repository/header-items.repository.ts +18 -18
  194. package/src/module/layout/repository/header-section.repository.ts +22 -22
  195. package/src/module/layout/service/header-section.service.ts +25 -25
  196. package/src/module/layout_preference/controller/layout_preference.controller.ts +73 -73
  197. package/src/module/layout_preference/entity/layout_preference.entity.ts +28 -28
  198. package/src/module/layout_preference/layout_preference.module.ts +22 -22
  199. package/src/module/layout_preference/repository/layout_preference.repository.ts +65 -65
  200. package/src/module/layout_preference/service/layout_preference.service.ts +191 -191
  201. package/src/module/lead/controller/lead.controller.ts +30 -30
  202. package/src/module/lead/lead.module.ts +14 -14
  203. package/src/module/lead/repository/lead.repository.ts +41 -41
  204. package/src/module/lead/service/lead.service.ts +54 -54
  205. package/src/module/listmaster/controller/list-master.controller.ts +230 -230
  206. package/src/module/listmaster/entity/list-master-items.entity.ts +43 -43
  207. package/src/module/listmaster/entity/list-master.entity.ts +33 -33
  208. package/src/module/listmaster/listmaster.module.ts +46 -46
  209. package/src/module/listmaster/repository/list-master-items.repository.ts +169 -169
  210. package/src/module/listmaster/repository/list-master.repository.ts +46 -46
  211. package/src/module/listmaster/service/list-master-engine.ts +19 -19
  212. package/src/module/listmaster/service/list-master-extension.interface.ts +4 -4
  213. package/src/module/listmaster/service/list-master-item.service.ts +292 -292
  214. package/src/module/listmaster/service/list-master-registry.ts +15 -15
  215. package/src/module/listmaster/service/list-master.service.ts +535 -535
  216. package/src/module/mapper/controller/field-mapper.controller.ts +76 -76
  217. package/src/module/mapper/controller/mapper.controller.ts +20 -20
  218. package/src/module/mapper/dto/field-mapper.dto.ts +14 -14
  219. package/src/module/mapper/entity/field-lovs.entity.ts +19 -19
  220. package/src/module/mapper/entity/field-mapper.entity.ts +53 -53
  221. package/src/module/mapper/entity/mapper.entity.ts +16 -16
  222. package/src/module/mapper/mapper.module.ts +34 -34
  223. package/src/module/mapper/repository/field-lovs.repository.ts +35 -35
  224. package/src/module/mapper/repository/field-mapper.repository.ts +42 -42
  225. package/src/module/mapper/repository/mapper.repository.ts +15 -15
  226. package/src/module/mapper/service/field-mapper.service.ts +271 -266
  227. package/src/module/mapper/service/mapper.service.ts +79 -79
  228. package/src/module/master/controller/master.controller.ts +74 -74
  229. package/src/module/master/service/master.service.ts +483 -483
  230. package/src/module/meta/controller/app-master.controller.ts +38 -38
  231. package/src/module/meta/controller/attribute-master.controller.ts +66 -66
  232. package/src/module/meta/controller/entity-dynamic.controller.ts +125 -125
  233. package/src/module/meta/controller/entity-master.controller.ts +28 -28
  234. package/src/module/meta/controller/entity-relation.controller.ts +36 -36
  235. package/src/module/meta/controller/entity.controller.ts +392 -392
  236. package/src/module/meta/controller/entity.public.controller.ts +75 -75
  237. package/src/module/meta/controller/media.controller.ts +107 -107
  238. package/src/module/meta/controller/meta.controller.ts +96 -96
  239. package/src/module/meta/controller/view-master.controller.ts +86 -86
  240. package/src/module/meta/dto/entity-list-data.dto.ts +6 -6
  241. package/src/module/meta/dto/entity-tab.dto.ts +4 -4
  242. package/src/module/meta/dto/entity-table.dto.ts +9 -9
  243. package/src/module/meta/entity/app-master.entity.ts +34 -34
  244. package/src/module/meta/entity/attribute-master.entity.ts +89 -89
  245. package/src/module/meta/entity/base-entity.entity.ts +75 -75
  246. package/src/module/meta/entity/entity-master.entity.ts +85 -85
  247. package/src/module/meta/entity/entity-relation-data.entity.ts +29 -29
  248. package/src/module/meta/entity/entity-relation.entity.ts +23 -23
  249. package/src/module/meta/entity/entity-table-column.entity.ts +61 -61
  250. package/src/module/meta/entity/entity-table.entity.ts +50 -50
  251. package/src/module/meta/entity/media-data.entity.ts +32 -32
  252. package/src/module/meta/entity/preference.entity.ts +62 -62
  253. package/src/module/meta/entity/view-master.entity.ts +41 -41
  254. package/src/module/meta/entity.module.ts +158 -158
  255. package/src/module/meta/repository/app-master.repository.ts +20 -20
  256. package/src/module/meta/repository/attribute-master.repository.ts +118 -118
  257. package/src/module/meta/repository/entity-master.repository.ts +69 -69
  258. package/src/module/meta/repository/entity-table-column.repository.ts +39 -39
  259. package/src/module/meta/repository/entity-table.repository.ts +53 -53
  260. package/src/module/meta/repository/media-data.repository.ts +50 -50
  261. package/src/module/meta/repository/preference.repository.ts +20 -20
  262. package/src/module/meta/repository/user-app-mapping.repository.ts +28 -28
  263. package/src/module/meta/repository/view-master.repository.ts +42 -42
  264. package/src/module/meta/service/app-master.service.ts +37 -37
  265. package/src/module/meta/service/attribute-master.service.ts +126 -126
  266. package/src/module/meta/service/common.service.ts +9 -9
  267. package/src/module/meta/service/entity-dynamic.service.ts +819 -819
  268. package/src/module/meta/service/entity-list.service.ts +205 -205
  269. package/src/module/meta/service/entity-master.service.ts +169 -169
  270. package/src/module/meta/service/entity-realation-data.service.ts +9 -9
  271. package/src/module/meta/service/entity-relation.service.ts +69 -69
  272. package/src/module/meta/service/entity-service-impl.service.ts +525 -525
  273. package/src/module/meta/service/entity-table-column.service.ts +39 -39
  274. package/src/module/meta/service/entity-table.service.ts +150 -150
  275. package/src/module/meta/service/entity-validation.service.ts +187 -187
  276. package/src/module/meta/service/entity.service.ts +67 -67
  277. package/src/module/meta/service/field-group.service.ts +103 -103
  278. package/src/module/meta/service/media-data.service.ts +507 -507
  279. package/src/module/meta/service/populate-meta.service.ts +193 -193
  280. package/src/module/meta/service/preference.service.ts +16 -16
  281. package/src/module/meta/service/resolver.service.ts +267 -267
  282. package/src/module/meta/service/section-master.service.ts +104 -104
  283. package/src/module/meta/service/update-form-json.service.ts +22 -22
  284. package/src/module/meta/service/user-app-mapping.service.ts +17 -17
  285. package/src/module/meta/service/view-master.service.ts +127 -127
  286. package/src/module/microservice-client/microservice-clients.module.ts +13 -13
  287. package/src/module/microservice-client/service/microservice-client-factory.ts +37 -37
  288. package/src/module/microservice-client/service/microservice-clients.ts +4 -4
  289. package/src/module/module/controller/menu.controller.ts +15 -15
  290. package/src/module/module/controller/module-access.controller.ts +134 -134
  291. package/src/module/module/entity/menu.entity.ts +43 -43
  292. package/src/module/module/entity/module-access.entity.ts +25 -25
  293. package/src/module/module/entity/module-action.entity.ts +17 -17
  294. package/src/module/module/entity/module.entity.ts +52 -52
  295. package/src/module/module/module.module.ts +42 -42
  296. package/src/module/module/repository/menu.repository.ts +184 -184
  297. package/src/module/module/repository/module-access.repository.ts +344 -344
  298. package/src/module/module/service/menu.service.ts +82 -82
  299. package/src/module/module/service/module-access.service.ts +209 -209
  300. package/src/module/notification/controller/notification.controller.ts +58 -58
  301. package/src/module/notification/controller/otp.controller.ts +117 -117
  302. package/src/module/notification/entity/notification.entity.ts +26 -26
  303. package/src/module/notification/entity/otp.entity.ts +28 -28
  304. package/src/module/notification/firebase-admin.config.ts +22 -22
  305. package/src/module/notification/notification.module.ts +69 -69
  306. package/src/module/notification/repository/otp.repository.ts +27 -27
  307. package/src/module/notification/service/email.service.ts +127 -127
  308. package/src/module/notification/service/notification.service.ts +163 -163
  309. package/src/module/notification/service/otp.service.ts +132 -132
  310. package/src/module/third-party-module/entity/third-party-api-registry.entity.ts +52 -52
  311. package/src/module/third-party-module/repository/third-party-api-registry.repository.ts +20 -20
  312. package/src/module/third-party-module/service/api-registry.service.ts +13 -13
  313. package/src/module/third-party-module/third-party.module.ts +12 -12
  314. package/src/module/user/controller/login.controller.ts +197 -197
  315. package/src/module/user/controller/user.controller.ts +40 -40
  316. package/src/module/user/dto/create-user.dto.ts +62 -62
  317. package/src/module/user/dto/update-user.dto.ts +4 -4
  318. package/src/module/user/entity/role.entity.ts +33 -33
  319. package/src/module/user/entity/user-role-mapping.entity.ts +38 -38
  320. package/src/module/user/entity/user-session.entity.ts +73 -73
  321. package/src/module/user/entity/user.entity.ts +59 -59
  322. package/src/module/user/repository/role.repository.ts +96 -96
  323. package/src/module/user/repository/user-role-mapping.repository.ts +126 -126
  324. package/src/module/user/repository/user.repository.ts +50 -50
  325. package/src/module/user/repository/userSession.repository.ts +33 -33
  326. package/src/module/user/service/login.service.ts +304 -304
  327. package/src/module/user/service/role.service.ts +189 -189
  328. package/src/module/user/service/user-role-mapping.service.ts +98 -98
  329. package/src/module/user/service/user-session.service.ts +168 -168
  330. package/src/module/user/service/user.service.ts +365 -365
  331. package/src/module/user/user.module.ts +65 -65
  332. package/src/module/workflow/controller/action-category.controller.ts +54 -54
  333. package/src/module/workflow/controller/action-resource-mapping.controller.ts +23 -23
  334. package/src/module/workflow/controller/action-template-mapping.controller.ts +35 -35
  335. package/src/module/workflow/controller/action.controller.ts +111 -111
  336. package/src/module/workflow/controller/activity-log.controller.ts +55 -55
  337. package/src/module/workflow/controller/comm-template.controller.ts +43 -43
  338. package/src/module/workflow/controller/entity-modification.controller.ts +35 -35
  339. package/src/module/workflow/controller/form-master.controller.ts +43 -43
  340. package/src/module/workflow/controller/stage-group.controller.ts +48 -48
  341. package/src/module/workflow/controller/stage.controller.ts +50 -50
  342. package/src/module/workflow/controller/task.controller.ts +77 -77
  343. package/src/module/workflow/controller/workflow-list-master.controller.ts +44 -44
  344. package/src/module/workflow/controller/workflow-meta.controller.ts +80 -80
  345. package/src/module/workflow/controller/workflow.controller.ts +67 -67
  346. package/src/module/workflow/entity/action-category.entity.ts +38 -38
  347. package/src/module/workflow/entity/action-data.entity.ts +55 -55
  348. package/src/module/workflow/entity/action-resources-mapping.entity.ts +29 -29
  349. package/src/module/workflow/entity/action-template-mapping.entity.ts +17 -17
  350. package/src/module/workflow/entity/action.entity.ts +50 -50
  351. package/src/module/workflow/entity/activity-log.entity.ts +43 -43
  352. package/src/module/workflow/entity/comm-template.entity.ts +43 -43
  353. package/src/module/workflow/entity/entity-modification.entity.ts +38 -38
  354. package/src/module/workflow/entity/form.entity.ts +25 -25
  355. package/src/module/workflow/entity/stage-action-mapping.entity.ts +17 -17
  356. package/src/module/workflow/entity/stage-group.entity.ts +23 -23
  357. package/src/module/workflow/entity/stage-movement-data.entity.ts +38 -38
  358. package/src/module/workflow/entity/stage.entity.ts +20 -20
  359. package/src/module/workflow/entity/task-data.entity.ts +88 -88
  360. package/src/module/workflow/entity/template-attach-mapper.entity.ts +30 -30
  361. package/src/module/workflow/entity/workflow-data.entity.ts +11 -11
  362. package/src/module/workflow/entity/workflow-level-mapping.entity.ts +18 -18
  363. package/src/module/workflow/entity/workflow.entity.ts +20 -20
  364. package/src/module/workflow/repository/action-category.repository.ts +79 -79
  365. package/src/module/workflow/repository/action-data.repository.ts +333 -333
  366. package/src/module/workflow/repository/action.repository.ts +323 -323
  367. package/src/module/workflow/repository/activity-log.repository.ts +148 -148
  368. package/src/module/workflow/repository/comm-template.repository.ts +149 -149
  369. package/src/module/workflow/repository/form-master.repository.ts +59 -59
  370. package/src/module/workflow/repository/stage-group.repository.ts +176 -176
  371. package/src/module/workflow/repository/stage-movement.repository.ts +244 -244
  372. package/src/module/workflow/repository/stage.repository.ts +172 -172
  373. package/src/module/workflow/repository/task.repository.ts +134 -127
  374. package/src/module/workflow/repository/workflow.repository.ts +42 -42
  375. package/src/module/workflow/service/action-category.service.ts +33 -33
  376. package/src/module/workflow/service/action-data.service.ts +62 -62
  377. package/src/module/workflow/service/action-resources-mapping.service.ts +10 -10
  378. package/src/module/workflow/service/action-template-mapping.service.ts +106 -106
  379. package/src/module/workflow/service/action.service.ts +279 -279
  380. package/src/module/workflow/service/activity-log.service.ts +107 -107
  381. package/src/module/workflow/service/comm-template.service.ts +180 -180
  382. package/src/module/workflow/service/entity-modification.service.ts +67 -67
  383. package/src/module/workflow/service/form-master.service.ts +35 -35
  384. package/src/module/workflow/service/populate-workflow.service.ts +303 -303
  385. package/src/module/workflow/service/stage-action-mapping.service.ts +5 -5
  386. package/src/module/workflow/service/stage-group.service.ts +319 -319
  387. package/src/module/workflow/service/stage.service.ts +199 -199
  388. package/src/module/workflow/service/task.service.ts +547 -560
  389. package/src/module/workflow/service/workflow-list-master.service.ts +60 -60
  390. package/src/module/workflow/service/workflow-meta.service.ts +654 -640
  391. package/src/module/workflow/service/workflow.service.ts +205 -205
  392. package/src/module/workflow/workflow.module.ts +176 -176
  393. package/src/module/workflow-automation/controller/workflow-automation.controller.ts +21 -21
  394. package/src/module/workflow-automation/entity/workflow-automation-action.entity.ts +26 -26
  395. package/src/module/workflow-automation/entity/workflow-automation.entity.ts +35 -35
  396. package/src/module/workflow-automation/interface/action.decorator.ts +7 -7
  397. package/src/module/workflow-automation/interface/action.interface.ts +5 -5
  398. package/src/module/workflow-automation/service/action-registery.service.ts +35 -35
  399. package/src/module/workflow-automation/service/workflow-automation-engine.service.ts +214 -214
  400. package/src/module/workflow-automation/service/workflow-automation.service.ts +347 -347
  401. package/src/module/workflow-automation/workflow-automation.module.ts +34 -34
  402. package/src/resources/dev.properties.yaml +30 -31
  403. package/src/resources/local.properties.yaml +27 -27
  404. package/src/resources/properties.module.ts +12 -12
  405. package/src/resources/properties.yaml.ts +11 -11
  406. package/src/resources/uat.properties.yaml +31 -31
  407. package/src/table.config.ts +126 -126
  408. package/src/utils/dto/excel-data.dto.ts +14 -14
  409. package/src/utils/dto/excelsheet-data.dto.ts +5 -5
  410. package/src/utils/service/base64util.service.ts +18 -18
  411. package/src/utils/service/clockIDGenUtil.service.ts +21 -21
  412. package/src/utils/service/codeGenerator.service.ts +22 -22
  413. package/src/utils/service/dateUtil.service.ts +17 -17
  414. package/src/utils/service/encryptUtil.service.ts +97 -97
  415. package/src/utils/service/excel-helper.service.ts +72 -72
  416. package/src/utils/service/excelUtil.service.ts +15 -15
  417. package/src/utils/service/file-util.service.ts +11 -11
  418. package/src/utils/service/json-util.service.ts +23 -23
  419. package/src/utils/service/loggingUtil.service.ts +88 -34
  420. package/src/utils/service/reflection-helper.service.ts +62 -62
  421. package/src/utils/service/wbsCodeGen.service.ts +8 -8
  422. package/src/utils/utils.module.ts +27 -25
  423. package/tsconfig.build.json +4 -4
  424. package/tsconfig.json +24 -24
  425. package/.claude/settings.local.json +0 -26
  426. package/.idea/250218_nodejs_core.iml +0 -9
  427. package/.idea/codeStyles/Project.xml +0 -59
  428. package/.idea/codeStyles/codeStyleConfig.xml +0 -5
  429. package/.idea/copilot.data.migration.agent.xml +0 -6
  430. package/.idea/copilot.data.migration.ask.xml +0 -6
  431. package/.idea/copilot.data.migration.ask2agent.xml +0 -6
  432. package/.idea/copilot.data.migration.edit.xml +0 -6
  433. package/.idea/inspectionProfiles/Project_Default.xml +0 -6
  434. package/.idea/misc.xml +0 -6
  435. package/.idea/modules.xml +0 -8
  436. package/.idea/prettier.xml +0 -6
  437. package/.idea/vcs.xml +0 -6
  438. package/server.log +0 -850
@@ -1,493 +1,700 @@
1
- import { Injectable, Logger } from '@nestjs/common';
2
- import { DataSource } from 'typeorm';
3
- import { GenericMessageDto, IntegrationService } from './integration.service';
4
- import { GoogleService } from './calendar-event.service';
5
- import { IcsMeetingService } from 'src/module/ics/service/ics.service';
6
-
7
- @Injectable()
8
- export class WrapperService {
9
- private readonly logger = new Logger(WrapperService.name);
10
-
11
- constructor(
12
- private readonly datasource: DataSource,
13
- private readonly integrationService: IntegrationService,
14
- private readonly googleService: GoogleService,
15
- private readonly icsService: IcsMeetingService,
16
- ) {}
17
-
18
- /**
19
- * Wrapper for sending mail
20
- */
21
- async sendMailWrapper(payload: any, loggedInUser: any) {
22
- try {
23
- this.logger.log(
24
- `sendMailWrapper called. User: ${JSON.stringify(loggedInUser)}, Payload: ${JSON.stringify(payload)}`,
25
- );
26
-
27
- const { level_id, level_type, organization_id } = loggedInUser;
28
-
29
- // 1. Check for config at user’s level
30
- this.logger.debug(
31
- `Fetching configs for level_id=${level_id}, level_type=${level_type}`,
32
- );
33
- const configs = await this.datasource.query(
34
- `SELECT * FROM frm_integration_config
35
- WHERE level_id = ?
36
- AND level_type = ?
37
- AND status = 1
38
- AND integration_type = 'EMAIL'`,
39
- [level_id, level_type],
40
- );
41
- this.logger.debug(`Configs found: ${JSON.stringify(configs)}`);
42
-
43
- let templateCode: string | undefined;
44
-
45
- if (payload.templateCode) {
46
- this.logger.debug(
47
- `Looking up templateCode=${payload.templateCode} for current level`,
48
- );
49
- const template = await this.datasource.query(
50
- `SELECT rich_text FROM frm_wf_comm_template WHERE code = ? AND level_id = ? AND level_type = ? LIMIT 1`,
51
- [payload.templateCode, level_id, level_type],
52
- );
53
- this.logger.debug(
54
- `Template lookup result: ${JSON.stringify(template)}`,
55
- );
56
-
57
- if (template && template.length > 0) {
58
- templateCode = template[0]?.rich_text;
59
- } else {
60
- this.logger.warn(
61
- `No template found for templateCode=${payload.templateCode} and current level`,
62
- );
63
- }
64
- }
65
-
66
- let payloadSendMail: GenericMessageDto;
67
-
68
- if (configs && configs.length > 0) {
69
- this.logger.debug(`Using user-level configs`);
70
- payloadSendMail = {
71
- levelId: level_id,
72
- levelType: level_type,
73
- app_code: 'DEFAULT', // Legacy wrapper default
74
- to: payload.to,
75
- message: payload.message,
76
- subject: payload.subject,
77
- type: 'EMAIL',
78
- cc: payload.cc,
79
- bcc: payload.bcc,
80
- html: payload.html,
81
- // attachments: payload.attachments,
82
- templateId: payload.templateId,
83
- variables: payload.variables,
84
- organization_id: loggedInUser.organization_id,
85
- };
86
- } else {
87
- this.logger.warn(
88
- `No user-level configs found. Falling back to ORG-level`,
89
- );
90
- const fallbackConfigs = await this.datasource.query(
91
- `SELECT * FROM frm_integration_config
92
- WHERE level_type = 'ORG'
93
- AND integration_type = 'EMAIL'
94
- AND status = 1`,
95
- );
96
- this.logger.debug(
97
- `ORG-level configs: ${JSON.stringify(fallbackConfigs)}`,
98
- );
99
-
100
- if (!fallbackConfigs || fallbackConfigs.length === 0) {
101
- this.logger.warn('No active email communication config found');
102
- }
103
-
104
- payloadSendMail = {
105
- levelId: 1,
106
- levelType: 'ORG',
107
- app_code: 'DEFAULT', // Legacy wrapper default
108
- to: payload.to,
109
- message: payload.message,
110
- subject: payload.subject,
111
- type: 'EMAIL',
112
- cc: payload.cc,
113
- bcc: payload.bcc,
114
- html: payload.html,
115
- // attachments: payload.attachments,
116
- // templateId: payload.templateId,
117
- variables: payload.variables,
118
- organization_id: loggedInUser.organization_id,
119
- };
120
- }
121
-
122
- this.logger.debug(
123
- `Final payload for IntegrationService: ${JSON.stringify(payloadSendMail)}`,
124
- );
125
-
126
- const result =
127
- await this.integrationService.sendGenericMessage(payloadSendMail);
128
-
129
- this.logger.log(
130
- `sendMailWrapper SUCCESS. Result: ${JSON.stringify(result)}`,
131
- );
132
-
133
- return {
134
- success: true,
135
- data: result,
136
- };
137
- } catch (error: any) {
138
- this.logger.error(`sendMailWrapper ERROR: ${error.message}`, error.stack);
139
- return {
140
- success: false,
141
- error: error.message,
142
- };
143
- }
144
- }
145
-
146
- /**
147
- * Wrapper for sending communication
148
- */
149
-
150
- async sendCommunicationWrapperService(entity: any, loggedInUser: any) {
151
- try {
152
- this.logger.log(
153
- `sendCommunicationWrapper called. User: ${JSON.stringify(
154
- loggedInUser,
155
- )}, Payload: ${JSON.stringify(entity)}`,
156
- );
157
-
158
- const { level_id, level_type, appcode, organization_id } = loggedInUser;
159
-
160
- // Check if active configs exist for current user's level
161
- this.logger.debug(
162
- `Checking active ${entity.type || 'EMAIL'} configs for level_id=${level_id}, level_type=${level_type}, app_code=${appcode}`,
163
- );
164
-
165
- let configs = await this.integrationService.getActiveConfigs(
166
- level_id,
167
- level_type,
168
- appcode,
169
- entity.type || 'EMAIL',
170
- );
171
-
172
- let effectiveLevelId = level_id;
173
- let effectiveLevelType = level_type;
174
-
175
- // Fallback to ORG-level if no configs found
176
- if (!configs || configs.length === 0) {
177
- this.logger.warn(
178
- `No active configs found for ${level_type}:${level_id}, falling back to ORG-level`,
179
- );
180
-
181
- configs = await this.integrationService.getActiveConfigs(
182
- 1,
183
- 'ORG',
184
- appcode,
185
- entity.type || 'EMAIL',
186
- );
187
-
188
- effectiveLevelId = 1;
189
- effectiveLevelType = 'ORG';
190
- }
191
-
192
- if (!configs || configs.length === 0) {
193
- this.logger.error('No active configurations found at any level.');
194
- throw new Error('No active configurations found.');
195
- }
196
-
197
- // Template lookup if templateCode is provided
198
- let resolvedTemplateId = entity?.templateId;
199
-
200
- if (entity.template_code) {
201
- this.logger.debug(
202
- `Looking up template for code=${entity.template_code}, level_id=${level_id}, level_type=${level_type}`,
203
- );
204
-
205
- // Try to find template at user's level first
206
- let templates = await this.datasource.query(
207
- `SELECT id FROM frm_wf_comm_template
208
- WHERE code = ?
209
- AND level_id = ?
210
- AND level_type = ?
211
- LIMIT 1`,
212
- [entity.template_code, level_id, level_type],
213
- );
214
-
215
- // Fallback to ORG + organization_id if not found
216
- if (!templates || templates.length === 0) {
217
- this.logger.warn(
218
- `No template found for ${entity.template_code} at provided level. Falling back to ORG-level.`,
219
- );
220
-
221
- templates = await this.datasource.query(
222
- `SELECT id FROM frm_wf_comm_template
223
- WHERE code = ?
224
- AND level_type = 'ORG'
225
- AND organization_id = ?
226
- LIMIT 1`,
227
- [entity.template_code, organization_id],
228
- );
229
- }
230
-
231
- if (templates && templates.length > 0) {
232
- resolvedTemplateId = templates[0]?.id;
233
- this.logger.debug(
234
- `Template resolved for code=${entity.template_code}, id=${resolvedTemplateId}`,
235
- );
236
- } else {
237
- this.logger.warn(
238
- `No template found for code=${entity.template_code} at any level.`,
239
- );
240
- }
241
- }
242
-
243
- // Step Prepare payload for Integration Service
244
- const mailPayload = {
245
- to: entity.to,
246
- subject: entity.subject,
247
- html: entity.message,
248
- cc: entity?.cc,
249
- bcc: entity?.bcc,
250
- templateId: resolvedTemplateId, // updated with resolved ID
251
- message: entity.message,
252
- type: entity.type || 'EMAIL',
253
- levelId: effectiveLevelId,
254
- levelType: effectiveLevelType,
255
- app_code: appcode,
256
- user_id: loggedInUser.id,
257
- entity_type: entity.entity_type,
258
- entity_id: entity.entity_id,
259
- attachments: entity.attachments,
260
- mediaUrl: entity.mediaUrl,
261
- organization_id: organization_id,
262
- } as any;
263
-
264
- this.logger.debug(
265
- `Final payload for sendGenericMessage: ${JSON.stringify(mailPayload)}`,
266
- );
267
-
268
- // Step 5️⃣ Send via Integration Service
269
- const result =
270
- await this.integrationService.sendGenericMessage(mailPayload);
271
-
272
- this.logger.log(
273
- `sendCommunicationWrapper SUCCESS. Result: ${JSON.stringify(result)}`,
274
- );
275
-
276
- return result;
277
- } catch (error: any) {
278
- this.logger.error(
279
- `sendCommunicationWrapper ERROR: ${error.message}`,
280
- error.stack,
281
- );
282
- return {
283
- success: false,
284
- error: error.message,
285
- };
286
- }
287
- }
288
-
289
- /**
290
- * Wrapper for scheduling meeting
291
- */
292
-
293
- async scheduleMeetingWrapper(
294
- payload: any,
295
- loggedInUser: any,
296
- mapped_entities?: any,
297
- ) {
298
- try {
299
- this.logger.log(
300
- `scheduleMeetingWrapper called by user=${loggedInUser?.id || 'unknown'} Payload=${JSON.stringify(payload)}`,
301
- );
302
-
303
- // Normalize emails (to, cc, bcc → attendees)
304
- const cleanEmails = (arr: string[] = []) =>
305
- arr.filter((e) => e && e.trim() !== '').map((e) => e.trim());
306
-
307
- const toList = Array.isArray(payload.to) ? cleanEmails(payload.to) : [];
308
-
309
- payload.attendees = [
310
- ...toList.map((e) => ({ email: e })),
311
- ...(payload.attendees || []).flatMap((a) =>
312
- typeof a === 'string'
313
- ? [{ email: a }]
314
- : Array.isArray(a?.email)
315
- ? a.email.map((e) => ({ email: e }))
316
- : a?.email
317
- ? [{ email: a.email }]
318
- : [],
319
- ),
320
- ];
321
-
322
- let integrationConfig =
323
- await this.integrationService.getSingleActiveConfig(
324
- payload.level_id,
325
- payload.level_type,
326
- payload.app_code,
327
- 'EMAIL',
328
- );
329
-
330
- if (integrationConfig) {
331
- return {
332
- success: true,
333
- data: await this.sendIcsInvite(
334
- payload,
335
- payload.level_id,
336
- payload.level_type,
337
- payload.app_code,
338
- loggedInUser.organization_id,
339
- mapped_entities,
340
- ),
341
- };
342
- }
343
-
344
- // ---- Step 2: Check ORG-level configs ----
345
- this.logger.log(`No user-level config found, checking ORG-level...`);
346
-
347
- const orgConfigs = await this.datasource.query(
348
- `SELECT * FROM frm_integration_config
349
- WHERE level_id = 1
350
- AND level_type = 'ORG'
351
- AND integration_type = 'EMAIL'
352
- AND app_code ='DEFAULT'
353
- AND status = 1`,
354
- [],
355
- );
356
-
357
- integrationConfig = await this.integrationService.getSingleActiveConfig(
358
- 1,
359
- 'ORG',
360
- 'DEFAULT',
361
- 'EMAIL',
362
- );
363
-
364
- this.logger.debug(`ORG configs found: ${JSON.stringify(orgConfigs)}`);
365
-
366
- if (integrationConfig) {
367
- return {
368
- success: true,
369
- data: await this.sendIcsInvite(
370
- payload,
371
- 1,
372
- 'ORG',
373
- 'DEFAULT',
374
- loggedInUser.organization_id,
375
- mapped_entities,
376
- ),
377
- };
378
- }
379
- } catch (error: any) {
380
- this.logger.error(
381
- `scheduleMeetingWrapper ERROR: ${error.message}`,
382
- error.stack,
383
- );
384
- return { success: false, error: error.message };
385
- }
386
- }
387
-
388
- /**
389
- * Fetch credentials JSON by config ID
390
- */
391
- private async getConfigCred(configId: number) {
392
- this.logger.debug(`Fetching config JSON for configId=${configId}`);
393
- const configRes = await this.datasource.query(
394
- `SELECT config_json
395
- FROM frm_integration_config
396
- WHERE id = ?`,
397
- [configId],
398
- );
399
- this.logger.debug(`Config fetch result: ${JSON.stringify(configRes)}`);
400
- return configRes?.[0]?.config_json || null;
401
- }
402
-
403
- private async sendIcsInvite(
404
- payload: any,
405
- levelId: number,
406
- levelType: string,
407
- appCode: string,
408
- organizationId: number,
409
- mapped_entities?: any,
410
- ) {
411
- this.logger.log(`Generating ICS file. Payload: ${JSON.stringify(payload)}`);
412
-
413
- if (payload.template_code) {
414
- let templates = await this.datasource.query(
415
- `SELECT id FROM frm_wf_comm_template
416
- WHERE code = ?
417
- ORDER BY 1 DESC
418
- LIMIT 1`,
419
- [payload.template_code],
420
- );
421
- this.logger.log(`template by code ${JSON.stringify(payload)}`);
422
- if (templates && templates.length > 0) {
423
- payload['templateId'] = templates[0].id;
424
- }
425
- }
426
-
427
- let activeConfig = await this.integrationService.getSingleActiveConfig(
428
- levelId,
429
- levelType,
430
- appCode,
431
- 'EMAIL',
432
- );
433
- const base64String = await this.icsService.generateIcs(
434
- payload,
435
- activeConfig?.config_json,
436
- );
437
- this.logger.debug(`ICS generated (base64 length: ${base64String?.length})`);
438
-
439
- // Normalize attendees
440
- const attendeeEmails =
441
- payload.attendees?.flatMap((a) =>
442
- Array.isArray(a.email) ? a.email : [a.email],
443
- ) || [];
444
-
445
- // Combine into one list (to + attendees)
446
- const toList = Array.from(
447
- new Set(
448
- [
449
- ...(Array.isArray(payload.to)
450
- ? payload.to
451
- : payload.to
452
- ? [payload.to]
453
- : []),
454
- ...attendeeEmails,
455
- ].map((email) => email.toLowerCase().trim()),
456
- ),
457
- );
458
-
459
- const payloadSendMail: GenericMessageDto = {
460
- levelId,
461
- levelType,
462
- app_code: appCode,
463
- to: toList,
464
- message: payload.message,
465
- subject: payload.subject,
466
- type: 'EMAIL',
467
- cc: payload.cc,
468
- bcc: payload.bcc,
469
- html: payload.html,
470
- attachments: [
471
- {
472
- content: base64String,
473
- type: 'text/calendar',
474
- filename: 'invite.ics',
475
- disposition: 'attachment',
476
- },
477
- ],
478
- templateId: payload.templateId,
479
- entity_id: payload.entity_id,
480
- entity_type: payload.entity_type,
481
- organization_id: organizationId,
482
- mapped_entities,
483
- };
484
-
485
- this.logger.debug(
486
- `Final payload for ICS send: ${JSON.stringify(payloadSendMail)}`,
487
- );
488
- const result =
489
- await this.integrationService.sendGenericMessage(payloadSendMail);
490
- this.logger.log(`ICS mail send result: ${JSON.stringify(result)}`);
491
- return result;
492
- }
493
- }
1
+ import { Injectable, Logger } from '@nestjs/common';
2
+ import { DataSource } from 'typeorm';
3
+ import { GenericMessageDto, IntegrationService } from './integration.service';
4
+ import { GoogleService } from './calendar-event.service';
5
+ import { IcsMeetingService } from 'src/module/ics/service/ics.service';
6
+ import { LoggingService } from 'src/utils/service/loggingUtil.service';
7
+
8
+ @Injectable()
9
+ export class WrapperService {
10
+ private readonly logger = new Logger(WrapperService.name);
11
+
12
+ constructor(
13
+ private readonly datasource: DataSource,
14
+ private readonly integrationService: IntegrationService,
15
+ private readonly googleService: GoogleService,
16
+ private readonly icsService: IcsMeetingService,
17
+ private readonly loggingService: LoggingService,
18
+ ) {}
19
+
20
+ /**
21
+ * Wrapper for sending mail
22
+ */
23
+ async sendMailWrapper(payload: any, loggedInUser: any) {
24
+ try {
25
+ this.loggingService.log(
26
+ 'debug',
27
+ 'wrapperService',
28
+ 'sendMailWrapper',
29
+ `sendMailWrapper called. User: ${JSON.stringify(
30
+ loggedInUser,
31
+ )}, Payload: ${JSON.stringify(payload)}`,
32
+ [],
33
+ [],
34
+ );
35
+
36
+ const { level_id, level_type, organization_id } = loggedInUser;
37
+
38
+ // 1. Check for config at user’s level
39
+ this.loggingService.log(
40
+ 'debug',
41
+ 'wrapperService',
42
+ 'sendMailWrapper',
43
+ `Fetching configs for level_id=${level_id}, level_type=${level_type}`,
44
+ [],
45
+ [],
46
+ );
47
+ const configs = await this.datasource.query(
48
+ `SELECT * FROM frm_integration_config
49
+ WHERE level_id = ?
50
+ AND level_type = ?
51
+ AND status = 1
52
+ AND integration_type = 'EMAIL'`,
53
+ [level_id, level_type],
54
+ );
55
+
56
+ this.loggingService.log(
57
+ 'debug',
58
+ 'wrapperService',
59
+ 'sendMailWrapper',
60
+ `Configs found: ${JSON.stringify(configs)}`,
61
+ [],
62
+ [],
63
+ );
64
+
65
+ let templateCode: string | undefined;
66
+
67
+ if (payload.templateCode) {
68
+ this.loggingService.log(
69
+ 'debug',
70
+ 'wrapperService',
71
+ 'sendMailWrapper',
72
+ `Looking up templateCode=${payload.templateCode} for current level`,
73
+ [],
74
+ [],
75
+ );
76
+
77
+ const template = await this.datasource.query(
78
+ `SELECT rich_text FROM frm_wf_comm_template WHERE code = ? AND level_id = ? AND level_type = ? LIMIT 1`,
79
+ [payload.templateCode, level_id, level_type],
80
+ );
81
+ this.loggingService.log(
82
+ 'debug',
83
+ 'wrapperService',
84
+ 'sendMailWrapper',
85
+ `Template lookup result: ${JSON.stringify(template)}`,
86
+ [],
87
+ [],
88
+ );
89
+
90
+ if (template && template.length > 0) {
91
+ templateCode = template[0]?.rich_text;
92
+ } else {
93
+ this.loggingService.log(
94
+ 'warn',
95
+ 'wrapperService',
96
+ 'sendMailWrapper',
97
+ `No template found for templateCode=${payload.templateCode} and current level`,
98
+ [],
99
+ [],
100
+ );
101
+ }
102
+ }
103
+
104
+ let payloadSendMail: GenericMessageDto;
105
+
106
+ if (configs && configs.length > 0) {
107
+ this.loggingService.log(
108
+ 'debug',
109
+ 'wrapperService',
110
+ 'sendMailWrapper',
111
+ `Using user-level configs`,
112
+ [],
113
+ [],
114
+ );
115
+
116
+ payloadSendMail = {
117
+ levelId: level_id,
118
+ levelType: level_type,
119
+ app_code: 'DEFAULT', // Legacy wrapper default
120
+ to: payload.to,
121
+ message: payload.message,
122
+ subject: payload.subject,
123
+ type: 'EMAIL',
124
+ cc: payload.cc,
125
+ bcc: payload.bcc,
126
+ html: payload.html,
127
+ // attachments: payload.attachments,
128
+ templateId: payload.templateId,
129
+ variables: payload.variables,
130
+ organization_id: loggedInUser.organization_id,
131
+ };
132
+ } else {
133
+ this.loggingService.log(
134
+ 'warn',
135
+ 'wrapperService',
136
+ 'sendMailWrapper',
137
+ `No user-level configs found. Falling back to ORG-level`,
138
+ [],
139
+ [],
140
+ );
141
+
142
+ const fallbackConfigs = await this.datasource.query(
143
+ `SELECT * FROM frm_integration_config
144
+ WHERE level_type = 'ORG'
145
+ AND integration_type = 'EMAIL'
146
+ AND status = 1`,
147
+ );
148
+
149
+ this.loggingService.log(
150
+ 'debug',
151
+ 'wrapperService',
152
+ 'sendMailWrapper',
153
+ `ORG-level configs: ${JSON.stringify(fallbackConfigs)}`,
154
+ [],
155
+ [],
156
+ );
157
+
158
+ if (!fallbackConfigs || fallbackConfigs.length === 0) {
159
+ this.loggingService.log(
160
+ 'warn',
161
+ 'wrapperService',
162
+ 'sendMailWrapper',
163
+ 'No active email communication config found',
164
+ [],
165
+ [],
166
+ );
167
+ }
168
+
169
+ payloadSendMail = {
170
+ levelId: 1,
171
+ levelType: 'ORG',
172
+ app_code: 'DEFAULT', // Legacy wrapper default
173
+ to: payload.to,
174
+ message: payload.message,
175
+ subject: payload.subject,
176
+ type: 'EMAIL',
177
+ cc: payload.cc,
178
+ bcc: payload.bcc,
179
+ html: payload.html,
180
+ // attachments: payload.attachments,
181
+ // templateId: payload.templateId,
182
+ variables: payload.variables,
183
+ organization_id: loggedInUser.organization_id,
184
+ };
185
+ }
186
+
187
+ this.loggingService.log(
188
+ 'debug',
189
+ 'wrapperService',
190
+ 'sendMailWrapper',
191
+ `Final payload for IntegrationService: ${JSON.stringify(
192
+ payloadSendMail,
193
+ )}`,
194
+ [],
195
+ [],
196
+ );
197
+
198
+ const result =
199
+ await this.integrationService.sendGenericMessage(payloadSendMail);
200
+
201
+ this.loggingService.log(
202
+ 'log',
203
+ 'wrapperService',
204
+ 'sendMailWrapper',
205
+ `sendMailWrapper SUCCESS. Result: ${JSON.stringify(result)}`,
206
+ [],
207
+ [],
208
+ );
209
+
210
+ return {
211
+ success: true,
212
+ data: result,
213
+ };
214
+ } catch (error: any) {
215
+ this.loggingService.log(
216
+ 'error',
217
+ 'wrapperService',
218
+ 'sendMailWrapper',
219
+ `sendMailWrapper ERROR: ${error.message}`,
220
+ [],
221
+ [error.stack], // Sending stack trace as additional data
222
+ );
223
+ return {
224
+ success: false,
225
+ error: error.message,
226
+ };
227
+ }
228
+ }
229
+
230
+ /**
231
+ * Wrapper for sending communication
232
+ */
233
+
234
+ async sendCommunicationWrapperService(entity: any, loggedInUser: any) {
235
+ try {
236
+ this.loggingService.log(
237
+ 'log',
238
+ 'wrapperService',
239
+ 'sendCommunicationWrapperService',
240
+ `sendCommunicationWrapper called. User: ${JSON.stringify(
241
+ loggedInUser,
242
+ )}, Payload: ${JSON.stringify(entity)}`,
243
+ [],
244
+ [],
245
+ );
246
+
247
+ const { level_id, level_type, appcode, organization_id } = loggedInUser;
248
+
249
+ // Check if active configs exist for current user's level
250
+ this.loggingService.log(
251
+ 'debug',
252
+ 'wrapperService',
253
+ 'sendCommunicationWrapperService',
254
+ `Checking active ${
255
+ entity.type || 'EMAIL'
256
+ } configs for level_id=${level_id}, level_type=${level_type}, app_code=${appcode}`,
257
+ [],
258
+ [],
259
+ );
260
+
261
+ let configs = await this.integrationService.getActiveConfigs(
262
+ level_id,
263
+ level_type,
264
+ appcode,
265
+ entity.type || 'EMAIL',
266
+ );
267
+
268
+ let effectiveLevelId = level_id;
269
+ let effectiveLevelType = level_type;
270
+
271
+ // Fallback to ORG-level if no configs found
272
+ if (!configs || configs.length === 0) {
273
+ this.loggingService.log(
274
+ 'warn',
275
+ 'wrapperService',
276
+ 'sendCommunicationWrapperService',
277
+ `No active configs found for ${level_type}:${level_id}, falling back to ORG-level`,
278
+ [],
279
+ [],
280
+ );
281
+
282
+ configs = await this.integrationService.getActiveConfigs(
283
+ 1,
284
+ 'ORG',
285
+ appcode,
286
+ entity.type || 'EMAIL',
287
+ );
288
+
289
+ effectiveLevelId = 1;
290
+ effectiveLevelType = 'ORG';
291
+ }
292
+
293
+ if (!configs || configs.length === 0) {
294
+ this.loggingService.log(
295
+ 'error',
296
+ 'wrapperService',
297
+ 'sendCommunicationWrapperService',
298
+ 'No active configurations found at any level.',
299
+ [],
300
+ [],
301
+ );
302
+ throw new Error('No active configurations found.');
303
+ }
304
+
305
+ // Template lookup if templateCode is provided
306
+ let resolvedTemplateId = entity?.templateId;
307
+
308
+ if (entity.template_code) {
309
+ this.loggingService.log(
310
+ 'debug',
311
+ 'wrapperService',
312
+ 'sendCommunicationWrapperService',
313
+ `Looking up template for code=${entity.template_code}, level_id=${level_id}, level_type=${level_type}`,
314
+ [],
315
+ [],
316
+ );
317
+
318
+ // Try to find template at user's level first
319
+ let templates = await this.datasource.query(
320
+ `SELECT id FROM frm_wf_comm_template
321
+ WHERE code = ?
322
+ AND level_id = ?
323
+ AND level_type = ?
324
+ LIMIT 1`,
325
+ [entity.template_code, level_id, level_type],
326
+ );
327
+
328
+ // Fallback to ORG + organization_id if not found
329
+ if (!templates || templates.length === 0) {
330
+ this.loggingService.log(
331
+ 'warn',
332
+ 'wrapperService',
333
+ 'sendCommunicationWrapperService',
334
+ `No template found for ${entity.template_code} at provided level. Falling back to ORG-level.`,
335
+ [],
336
+ [],
337
+ );
338
+
339
+ templates = await this.datasource.query(
340
+ `SELECT id FROM frm_wf_comm_template
341
+ WHERE code = ?
342
+ AND level_type = 'ORG'
343
+ AND organization_id = ?
344
+ LIMIT 1`,
345
+ [entity.template_code, organization_id],
346
+ );
347
+ }
348
+
349
+ if (templates && templates.length > 0) {
350
+ resolvedTemplateId = templates[0]?.id;
351
+ this.loggingService.log(
352
+ 'debug',
353
+ 'wrapperService',
354
+ 'sendCommunicationWrapperService',
355
+ `Template resolved for code=${entity.template_code}, id=${resolvedTemplateId}`,
356
+ [],
357
+ [],
358
+ );
359
+ } else {
360
+ this.loggingService.log(
361
+ 'warn',
362
+ 'wrapperService',
363
+ 'sendCommunicationWrapperService',
364
+ `No template found for code=${entity.template_code} at any level.`,
365
+ [],
366
+ [],
367
+ );
368
+ }
369
+ }
370
+
371
+ // Step Prepare payload for Integration Service
372
+ const mailPayload = {
373
+ to: entity.to,
374
+ subject: entity.subject,
375
+ html: entity.message,
376
+ cc: entity?.cc,
377
+ bcc: entity?.bcc,
378
+ templateId: resolvedTemplateId, // updated with resolved ID
379
+ message: entity.message,
380
+ type: entity.type || 'EMAIL',
381
+ levelId: effectiveLevelId,
382
+ levelType: effectiveLevelType,
383
+ app_code: appcode,
384
+ user_id: loggedInUser.id,
385
+ entity_type: entity.entity_type,
386
+ entity_id: entity.entity_id,
387
+ attachments: entity.attachments,
388
+ mediaUrl: entity.mediaUrl,
389
+ organization_id: organization_id,
390
+ } as any;
391
+
392
+ this.loggingService.log(
393
+ 'debug',
394
+ 'wrapperService',
395
+ 'sendCommunicationWrapperService',
396
+ `Final payload for sendGenericMessage: ${JSON.stringify(mailPayload)}`,
397
+ [],
398
+ [],
399
+ );
400
+
401
+ // Step 5️⃣ Send via Integration Service
402
+ const result =
403
+ await this.integrationService.sendGenericMessage(mailPayload);
404
+
405
+ this.loggingService.log(
406
+ 'log',
407
+ 'wrapperService',
408
+ 'sendCommunicationWrapperService',
409
+ `sendCommunicationWrapper SUCCESS. Result: ${JSON.stringify(result)}`,
410
+ [],
411
+ [],
412
+ );
413
+
414
+ return result;
415
+ } catch (error: any) {
416
+ this.loggingService.log(
417
+ 'error',
418
+ 'wrapperService',
419
+ 'sendCommunicationWrapperService',
420
+ `sendCommunicationWrapper ERROR: ${error.message}`,
421
+ [],
422
+ [error.stack],
423
+ );
424
+ return {
425
+ success: false,
426
+ error: error.message,
427
+ };
428
+ }
429
+ }
430
+
431
+ /**
432
+ * Wrapper for scheduling meeting
433
+ */
434
+
435
+ async scheduleMeetingWrapper(
436
+ payload: any,
437
+ loggedInUser: any,
438
+ mapped_entities?: any,
439
+ ) {
440
+ try {
441
+ this.loggingService.log(
442
+ 'log',
443
+ 'wrapperService',
444
+ 'scheduleMeetingWrapper',
445
+ `scheduleMeetingWrapper called by user=${
446
+ loggedInUser?.id || 'unknown'
447
+ } Payload=${JSON.stringify(payload)}`,
448
+ [],
449
+ [],
450
+ );
451
+
452
+ // Normalize emails (to, cc, bcc → attendees)
453
+ const cleanEmails = (arr: string[] = []) =>
454
+ arr.filter((e) => e && e.trim() !== '').map((e) => e.trim());
455
+
456
+ const toList = Array.isArray(payload.to) ? cleanEmails(payload.to) : [];
457
+
458
+ payload.attendees = [
459
+ ...toList.map((e) => ({ email: e })),
460
+ ...(payload.attendees || []).flatMap((a) =>
461
+ typeof a === 'string'
462
+ ? [{ email: a }]
463
+ : Array.isArray(a?.email)
464
+ ? a.email.map((e) => ({ email: e }))
465
+ : a?.email
466
+ ? [{ email: a.email }]
467
+ : [],
468
+ ),
469
+ ];
470
+
471
+ let integrationConfig =
472
+ await this.integrationService.getSingleActiveConfig(
473
+ payload.level_id,
474
+ payload.level_type,
475
+ payload.app_code,
476
+ 'EMAIL',
477
+ );
478
+
479
+ if (integrationConfig) {
480
+ return {
481
+ success: true,
482
+ data: await this.sendIcsInvite(
483
+ payload,
484
+ payload.level_id,
485
+ payload.level_type,
486
+ payload.app_code,
487
+ loggedInUser.organization_id,
488
+ mapped_entities,
489
+ ),
490
+ };
491
+ }
492
+
493
+ // ---- Step 2: Check ORG-level configs ----
494
+ this.loggingService.log(
495
+ 'log',
496
+ 'wrapperService',
497
+ 'scheduleMeetingWrapper',
498
+ `No user-level config found, checking ORG-level...`,
499
+ [],
500
+ [],
501
+ );
502
+
503
+ const orgConfigs = await this.datasource.query(
504
+ `SELECT * FROM frm_integration_config
505
+ WHERE level_id = 1
506
+ AND level_type = 'ORG'
507
+ AND integration_type = 'EMAIL'
508
+ AND app_code ='DEFAULT'
509
+ AND status = 1`,
510
+ [],
511
+ );
512
+
513
+ integrationConfig = await this.integrationService.getSingleActiveConfig(
514
+ 1,
515
+ 'ORG',
516
+ 'DEFAULT',
517
+ 'EMAIL',
518
+ );
519
+
520
+ this.loggingService.log(
521
+ 'debug',
522
+ 'wrapperService',
523
+ 'scheduleMeetingWrapper',
524
+ `ORG configs found: ${JSON.stringify(orgConfigs)}`,
525
+ [],
526
+ [],
527
+ );
528
+
529
+ if (integrationConfig) {
530
+ return {
531
+ success: true,
532
+ data: await this.sendIcsInvite(
533
+ payload,
534
+ 1,
535
+ 'ORG',
536
+ 'DEFAULT',
537
+ loggedInUser.organization_id,
538
+ mapped_entities,
539
+ ),
540
+ };
541
+ }
542
+ } catch (error: any) {
543
+ this.loggingService.log(
544
+ 'error',
545
+ 'wrapperService',
546
+ 'scheduleMeetingWrapper',
547
+ `scheduleMeetingWrapper ERROR: ${error.message}`,
548
+ [],
549
+ [error.stack],
550
+ );
551
+ return { success: false, error: error.message };
552
+ }
553
+ }
554
+
555
+ /**
556
+ * Fetch credentials JSON by config ID
557
+ */
558
+ private async getConfigCred(configId: number) {
559
+ this.loggingService.log(
560
+ 'debug',
561
+ 'wrapperService',
562
+ 'getConfigCred',
563
+ `Fetching config JSON for configId=${configId}`,
564
+ [],
565
+ [],
566
+ );
567
+ const configRes = await this.datasource.query(
568
+ `SELECT config_json
569
+ FROM frm_integration_config
570
+ WHERE id = ?`,
571
+ [configId],
572
+ );
573
+ this.loggingService.log(
574
+ 'debug',
575
+ 'wrapperService',
576
+ 'getConfigCred',
577
+ `Config fetch result: ${JSON.stringify(configRes)}`,
578
+ [],
579
+ [],
580
+ );
581
+ return configRes?.[0]?.config_json || null;
582
+ }
583
+
584
+ private async sendIcsInvite(
585
+ payload: any,
586
+ levelId: number,
587
+ levelType: string,
588
+ appCode: string,
589
+ organizationId: number,
590
+ mapped_entities?: any,
591
+ ) {
592
+ this.loggingService.log(
593
+ 'log',
594
+ 'wrapperService',
595
+ 'sendIcsInvite',
596
+ `Generating ICS file. Payload: ${JSON.stringify(payload)}`,
597
+ [],
598
+ [],
599
+ );
600
+
601
+ if (payload.template_code) {
602
+ let templates = await this.datasource.query(
603
+ `SELECT id FROM frm_wf_comm_template
604
+ WHERE code = ?
605
+ ORDER BY 1 DESC
606
+ LIMIT 1`,
607
+ [payload.template_code],
608
+ );
609
+ this.logger.log(`template by code ${JSON.stringify(payload)}`);
610
+ if (templates && templates.length > 0) {
611
+ payload['templateId'] = templates[0].id;
612
+ }
613
+ }
614
+
615
+ let activeConfig = await this.integrationService.getSingleActiveConfig(
616
+ levelId,
617
+ levelType,
618
+ appCode,
619
+ 'EMAIL',
620
+ );
621
+ const base64String = await this.icsService.generateIcs(
622
+ payload,
623
+ activeConfig?.config_json,
624
+ );
625
+ this.loggingService.log(
626
+ 'debug',
627
+ 'wrapperService',
628
+ 'sendIcsInvite',
629
+ `ICS generated (base64 length: ${base64String?.length})`,
630
+ [],
631
+ [],
632
+ );
633
+
634
+ // Normalize attendees
635
+ const attendeeEmails =
636
+ payload.attendees?.flatMap((a) =>
637
+ Array.isArray(a.email) ? a.email : [a.email],
638
+ ) || [];
639
+
640
+ // Combine into one list (to + attendees)
641
+ const toList = Array.from(
642
+ new Set(
643
+ [
644
+ ...(Array.isArray(payload.to)
645
+ ? payload.to
646
+ : payload.to
647
+ ? [payload.to]
648
+ : []),
649
+ ...attendeeEmails,
650
+ ].map((email) => email.toLowerCase().trim()),
651
+ ),
652
+ );
653
+
654
+ const payloadSendMail: GenericMessageDto = {
655
+ levelId,
656
+ levelType,
657
+ app_code: appCode,
658
+ to: toList,
659
+ message: payload.message,
660
+ subject: payload.subject,
661
+ type: 'EMAIL',
662
+ cc: payload.cc,
663
+ bcc: payload.bcc,
664
+ html: payload.html,
665
+ attachments: [
666
+ {
667
+ content: base64String,
668
+ type: 'text/calendar',
669
+ filename: 'invite.ics',
670
+ disposition: 'attachment',
671
+ },
672
+ ],
673
+ templateId: payload.templateId,
674
+ entity_id: payload.entity_id,
675
+ entity_type: payload.entity_type,
676
+ organization_id: organizationId,
677
+ mapped_entities,
678
+ };
679
+
680
+ this.loggingService.log(
681
+ 'debug',
682
+ 'wrapperService',
683
+ 'sendIcsInvite',
684
+ `Final payload for ICS send: ${JSON.stringify(payloadSendMail)}`,
685
+ [],
686
+ [],
687
+ );
688
+ const result =
689
+ await this.integrationService.sendGenericMessage(payloadSendMail);
690
+ this.loggingService.log(
691
+ 'log',
692
+ 'wrapperService',
693
+ 'sendIcsInvite',
694
+ `ICS mail send result: ${JSON.stringify(result)}`,
695
+ [],
696
+ [],
697
+ );
698
+ return result;
699
+ }
700
+ }