rez_core 4.0.122 → 4.0.123

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 (405) hide show
  1. package/.prettierrc +3 -3
  2. package/.vscode/extensions.json +5 -0
  3. package/README.md +99 -99
  4. package/dist/config/config.module.js +2 -2
  5. package/dist/config/config.module.js.map +1 -1
  6. package/dist/config/database.config.d.ts +1 -1
  7. package/dist/config/database.config.js +12 -15
  8. package/dist/config/database.config.js.map +1 -1
  9. package/dist/module/auth/guards/role.guard.js +3 -3
  10. package/dist/module/auth/services/auth.service.js +2 -2
  11. package/dist/module/filter/repository/saved-filter.repository.js +4 -4
  12. package/dist/module/filter/service/filter-evaluator.service.js +2 -2
  13. package/dist/module/filter/service/filter.service.js +22 -22
  14. package/dist/module/integration/entity/integration-config.entity.js +3 -3
  15. package/dist/module/integration/entity/integration-config.entity.js.map +1 -1
  16. package/dist/module/integration/entity/user-integration.entity.js +3 -3
  17. package/dist/module/integration/entity/user-integration.entity.js.map +1 -1
  18. package/dist/module/integration/examples/usage.example.js +9 -9
  19. package/dist/module/integration/service/integration.service.js +1 -1
  20. package/dist/module/integration/service/wrapper.service.js +25 -25
  21. package/dist/module/listmaster/service/list-master-item.service.js +2 -2
  22. package/dist/module/mapper/entity/field-mapper.entity.js +1 -1
  23. package/dist/module/mapper/entity/field-mapper.entity.js.map +1 -1
  24. package/dist/module/mapper/service/field-mapper.service.js +4 -4
  25. package/dist/module/mapper/service/mapper.service.js +2 -2
  26. package/dist/module/meta/entity/entity-master.entity.js +1 -1
  27. package/dist/module/meta/entity/entity-master.entity.js.map +1 -1
  28. package/dist/module/meta/service/attribute-master.service.js +1 -1
  29. package/dist/module/meta/service/attribute-master.service.js.map +1 -1
  30. package/dist/module/meta/service/entity-dynamic.service.js +9 -9
  31. package/dist/module/meta/service/entity-list.service.js +3 -3
  32. package/dist/module/meta/service/entity-master.service.js +3 -3
  33. package/dist/module/meta/service/entity-relation.service.js +11 -11
  34. package/dist/module/meta/service/entity-service-impl.service.js +3 -3
  35. package/dist/module/meta/service/resolver.service.js +3 -3
  36. package/dist/module/module/repository/menu.repository.js +12 -12
  37. package/dist/module/notification/service/notification.service.js +9 -9
  38. package/dist/module/user/controller/login.controller.js +18 -18
  39. package/dist/module/user/service/role.service.js +4 -4
  40. package/dist/module/user/service/user-session.service.js +2 -2
  41. package/dist/module/workflow/entity/comm-template.entity.js +1 -1
  42. package/dist/module/workflow/entity/comm-template.entity.js.map +1 -1
  43. package/dist/module/workflow/repository/action.repository.js +20 -20
  44. package/dist/module/workflow/repository/comm-template.repository.js +6 -6
  45. package/dist/module/workflow/repository/form-master.repository.js +2 -2
  46. package/dist/module/workflow/repository/stage-group.repository.js +23 -23
  47. package/dist/module/workflow/repository/stage-movement.repository.js +15 -15
  48. package/dist/module/workflow/repository/stage.repository.js +8 -8
  49. package/dist/module/workflow/service/action-template-mapping.service.js +22 -22
  50. package/dist/module/workflow/service/action.service.js +7 -7
  51. package/dist/module/workflow/service/entity-modification.service.js +6 -6
  52. package/dist/module/workflow/service/stage-group.service.js +2 -2
  53. package/dist/module/workflow/service/stage.service.js +2 -2
  54. package/dist/module/workflow/service/task.service.js +28 -28
  55. package/dist/module/workflow/service/workflow-list-master.service.js +15 -15
  56. package/dist/module/workflow/service/workflow-meta.service.js +50 -38
  57. package/dist/module/workflow/service/workflow-meta.service.js.map +1 -1
  58. package/dist/module/workflow/service/workflow.service.js +2 -2
  59. package/dist/tsconfig.build.tsbuildinfo +1 -1
  60. package/dist/utils/service/reflection-helper.service.js +2 -2
  61. package/docs/modules/event-driven-integration-design.md +91 -91
  62. package/docs/modules/integration.md +250 -250
  63. package/eslint.config.mjs +34 -34
  64. package/nest-cli.json +14 -14
  65. package/package.json +119 -120
  66. package/src/app.controller.ts +12 -12
  67. package/src/app.module.ts +52 -52
  68. package/src/app.service.ts +8 -8
  69. package/src/config/config.module.ts +18 -17
  70. package/src/config/database.config.ts +23 -47
  71. package/src/constant/global.constant.ts +67 -67
  72. package/src/core.module.ts +81 -81
  73. package/src/decorators/roles.decorator.ts +7 -7
  74. package/src/dtos/response.dto.ts +6 -6
  75. package/src/dtos/response.ts +5 -5
  76. package/src/index.ts +1 -1
  77. package/src/module/auth/auth.module.ts +49 -49
  78. package/src/module/auth/controller/auth.controller.ts +28 -28
  79. package/src/module/auth/guards/google-auth.guard.ts +9 -9
  80. package/src/module/auth/guards/jwt.guard.ts +22 -22
  81. package/src/module/auth/guards/role.guard.ts +68 -68
  82. package/src/module/auth/services/auth.service.ts +50 -50
  83. package/src/module/auth/services/jwt.service.ts +11 -11
  84. package/src/module/auth/strategies/google.strategy.ts +54 -54
  85. package/src/module/auth/strategies/jwt.strategy.ts +58 -58
  86. package/src/module/auth/strategies/local.strategy.ts +13 -13
  87. package/src/module/dashboard/controller/dashboard.controller.ts +36 -36
  88. package/src/module/dashboard/dashboard.module.ts +21 -21
  89. package/src/module/dashboard/entity/dashboard_page_data.entity.ts +27 -27
  90. package/src/module/dashboard/entity/widget_master.entity.ts +18 -18
  91. package/src/module/dashboard/repository/dashboard.repository.ts +42 -42
  92. package/src/module/dashboard/service/dashboard.service.ts +73 -73
  93. package/src/module/dev/dev.module.ts +12 -12
  94. package/src/module/dev/service/dev.service.ts +7 -7
  95. package/src/module/enterprise/controller/organization.controller.ts +36 -36
  96. package/src/module/enterprise/enterprise.module.ts +30 -30
  97. package/src/module/enterprise/entity/enterprise.entity.ts +37 -37
  98. package/src/module/enterprise/entity/organization-app-mapping.entity.ts +13 -13
  99. package/src/module/enterprise/entity/organization.entity.ts +92 -92
  100. package/src/module/enterprise/repository/enterprise.repository.ts +31 -31
  101. package/src/module/enterprise/repository/organization.repository.ts +26 -26
  102. package/src/module/enterprise/repository/school.repository.ts +278 -278
  103. package/src/module/enterprise/service/brand.service.ts +5 -5
  104. package/src/module/enterprise/service/enterprise.service.ts +16 -16
  105. package/src/module/enterprise/service/organization-app-mapping.service.ts +4 -4
  106. package/src/module/enterprise/service/organization.service.ts +145 -145
  107. package/src/module/filter/controller/filter.controller.ts +84 -84
  108. package/src/module/filter/dto/filter-request.dto.ts +38 -38
  109. package/src/module/filter/entity/saved-filter-detail.entity.ts +41 -41
  110. package/src/module/filter/entity/saved-filter-master.entity.ts +23 -23
  111. package/src/module/filter/filter.module.ts +31 -31
  112. package/src/module/filter/repository/saved-filter.repository.ts +168 -168
  113. package/src/module/filter/service/filter-evaluator.service.ts +86 -86
  114. package/src/module/filter/service/filter.service.ts +1005 -1005
  115. package/src/module/filter/service/saved-filter.service.ts +170 -170
  116. package/src/module/ics/controller/ics.controller.ts +21 -21
  117. package/src/module/ics/dto/ics.dto.ts +55 -55
  118. package/src/module/ics/ics.module.ts +13 -13
  119. package/src/module/ics/service/ics.service.ts +57 -57
  120. package/src/module/integration/controller/calender-event.controller.ts +31 -31
  121. package/src/module/integration/controller/integration.controller.ts +662 -662
  122. package/src/module/integration/controller/wrapper.controller.ts +37 -37
  123. package/src/module/integration/dto/create-config.dto.ts +526 -526
  124. package/src/module/integration/entity/integration-config.entity.ts +112 -112
  125. package/src/module/integration/entity/integration-entity-mapper.entity.ts +14 -14
  126. package/src/module/integration/entity/integration-source.entity.ts +17 -17
  127. package/src/module/integration/entity/user-integration.entity.ts +71 -71
  128. package/src/module/integration/examples/usage.example.ts +338 -338
  129. package/src/module/integration/factories/base.factory.ts +7 -7
  130. package/src/module/integration/factories/email.factory.ts +49 -49
  131. package/src/module/integration/factories/integration.factory.ts +121 -121
  132. package/src/module/integration/factories/sms.factory.ts +51 -51
  133. package/src/module/integration/factories/telephone.factory.ts +41 -41
  134. package/src/module/integration/factories/whatsapp.factory.ts +56 -56
  135. package/src/module/integration/integration.module.ts +110 -110
  136. package/src/module/integration/service/calendar-event.service.ts +118 -118
  137. package/src/module/integration/service/integration-entity-mapper.service.ts +17 -17
  138. package/src/module/integration/service/integration-queue.service.ts +229 -229
  139. package/src/module/integration/service/integration.service.ts +2633 -2633
  140. package/src/module/integration/service/oauth.service.ts +224 -224
  141. package/src/module/integration/service/wrapper.service.ts +493 -493
  142. package/src/module/integration/strategies/email/gmail-api.strategy.ts +280 -280
  143. package/src/module/integration/strategies/email/outlook-api.strategy.ts +44 -44
  144. package/src/module/integration/strategies/email/outlook.strategy.ts +64 -64
  145. package/src/module/integration/strategies/email/sendgrid-api.strategy.ts +260 -260
  146. package/src/module/integration/strategies/integration.strategy.ts +97 -97
  147. package/src/module/integration/strategies/sms/gupshup-sms.strategy.ts +146 -146
  148. package/src/module/integration/strategies/sms/msg91-sms.strategy.ts +164 -164
  149. package/src/module/integration/strategies/sms/tubelight-sms.strategy.ts +163 -163
  150. package/src/module/integration/strategies/telephone/ozonetel-voice.strategy.ts +238 -238
  151. package/src/module/integration/strategies/telephone/tubelight-voice.strategy.ts +210 -210
  152. package/src/module/integration/strategies/whatsapp/gupshup-whatsapp.strategy.ts +359 -359
  153. package/src/module/integration/strategies/whatsapp/tubelight-whatsapp.strategy.ts +372 -372
  154. package/src/module/integration/strategies/whatsapp/whatsapp-cloud.strategy.ts +403 -403
  155. package/src/module/integration/strategies/whatsapp/whatsapp.strategy.ts +57 -57
  156. package/src/module/layout/controller/layout.controller.ts +47 -47
  157. package/src/module/layout/entity/header-items.entity.ts +28 -28
  158. package/src/module/layout/entity/header-section.entity.ts +19 -19
  159. package/src/module/layout/layout.module.ts +21 -21
  160. package/src/module/layout/repository/header-items.repository.ts +18 -18
  161. package/src/module/layout/repository/header-section.repository.ts +22 -22
  162. package/src/module/layout/service/header-section.service.ts +25 -25
  163. package/src/module/layout_preference/controller/layout_preference.controller.ts +73 -73
  164. package/src/module/layout_preference/entity/layout_preference.entity.ts +28 -28
  165. package/src/module/layout_preference/layout_preference.module.ts +22 -22
  166. package/src/module/layout_preference/repository/layout_preference.repository.ts +65 -65
  167. package/src/module/layout_preference/service/layout_preference.service.ts +191 -191
  168. package/src/module/lead/controller/lead.controller.ts +30 -30
  169. package/src/module/lead/lead.module.ts +14 -14
  170. package/src/module/lead/repository/lead.repository.ts +41 -41
  171. package/src/module/lead/service/lead.service.ts +54 -54
  172. package/src/module/listmaster/controller/list-master.controller.ts +230 -230
  173. package/src/module/listmaster/entity/list-master-items.entity.ts +43 -43
  174. package/src/module/listmaster/entity/list-master.entity.ts +33 -33
  175. package/src/module/listmaster/listmaster.module.ts +46 -46
  176. package/src/module/listmaster/repository/list-master-items.repository.ts +169 -169
  177. package/src/module/listmaster/repository/list-master.repository.ts +46 -46
  178. package/src/module/listmaster/service/list-master-engine.ts +19 -19
  179. package/src/module/listmaster/service/list-master-extension.interface.ts +4 -4
  180. package/src/module/listmaster/service/list-master-item.service.ts +292 -292
  181. package/src/module/listmaster/service/list-master-registry.ts +15 -15
  182. package/src/module/listmaster/service/list-master.service.ts +535 -535
  183. package/src/module/mapper/controller/field-mapper.controller.ts +76 -76
  184. package/src/module/mapper/controller/mapper.controller.ts +20 -20
  185. package/src/module/mapper/dto/field-mapper.dto.ts +14 -14
  186. package/src/module/mapper/entity/field-lovs.entity.ts +19 -19
  187. package/src/module/mapper/entity/field-mapper.entity.ts +53 -53
  188. package/src/module/mapper/entity/mapper.entity.ts +16 -16
  189. package/src/module/mapper/mapper.module.ts +34 -34
  190. package/src/module/mapper/repository/field-lovs.repository.ts +35 -35
  191. package/src/module/mapper/repository/field-mapper.repository.ts +42 -42
  192. package/src/module/mapper/repository/mapper.repository.ts +15 -15
  193. package/src/module/mapper/service/field-mapper.service.ts +266 -266
  194. package/src/module/mapper/service/mapper.service.ts +79 -79
  195. package/src/module/master/controller/master.controller.ts +74 -74
  196. package/src/module/master/service/master.service.ts +483 -483
  197. package/src/module/meta/controller/app-master.controller.ts +38 -38
  198. package/src/module/meta/controller/attribute-master.controller.ts +66 -66
  199. package/src/module/meta/controller/entity-dynamic.controller.ts +125 -125
  200. package/src/module/meta/controller/entity-master.controller.ts +28 -28
  201. package/src/module/meta/controller/entity-relation.controller.ts +36 -36
  202. package/src/module/meta/controller/entity.controller.ts +392 -392
  203. package/src/module/meta/controller/entity.public.controller.ts +75 -75
  204. package/src/module/meta/controller/media.controller.ts +107 -107
  205. package/src/module/meta/controller/meta.controller.ts +96 -96
  206. package/src/module/meta/controller/view-master.controller.ts +86 -86
  207. package/src/module/meta/dto/entity-list-data.dto.ts +6 -6
  208. package/src/module/meta/dto/entity-tab.dto.ts +4 -4
  209. package/src/module/meta/dto/entity-table.dto.ts +9 -9
  210. package/src/module/meta/entity/app-master.entity.ts +34 -34
  211. package/src/module/meta/entity/attribute-master.entity.ts +89 -89
  212. package/src/module/meta/entity/base-entity.entity.ts +75 -75
  213. package/src/module/meta/entity/entity-master.entity.ts +85 -85
  214. package/src/module/meta/entity/entity-relation-data.entity.ts +29 -29
  215. package/src/module/meta/entity/entity-relation.entity.ts +23 -23
  216. package/src/module/meta/entity/entity-table-column.entity.ts +61 -61
  217. package/src/module/meta/entity/entity-table.entity.ts +50 -50
  218. package/src/module/meta/entity/media-data.entity.ts +32 -32
  219. package/src/module/meta/entity/preference.entity.ts +62 -62
  220. package/src/module/meta/entity/view-master.entity.ts +41 -41
  221. package/src/module/meta/entity.module.ts +158 -158
  222. package/src/module/meta/repository/app-master.repository.ts +20 -20
  223. package/src/module/meta/repository/attribute-master.repository.ts +118 -118
  224. package/src/module/meta/repository/entity-master.repository.ts +69 -69
  225. package/src/module/meta/repository/entity-table-column.repository.ts +39 -39
  226. package/src/module/meta/repository/entity-table.repository.ts +53 -53
  227. package/src/module/meta/repository/media-data.repository.ts +50 -50
  228. package/src/module/meta/repository/preference.repository.ts +20 -20
  229. package/src/module/meta/repository/user-app-mapping.repository.ts +28 -28
  230. package/src/module/meta/repository/view-master.repository.ts +42 -42
  231. package/src/module/meta/service/app-master.service.ts +37 -37
  232. package/src/module/meta/service/attribute-master.service.ts +126 -126
  233. package/src/module/meta/service/common.service.ts +9 -9
  234. package/src/module/meta/service/entity-dynamic.service.ts +819 -819
  235. package/src/module/meta/service/entity-list.service.ts +205 -205
  236. package/src/module/meta/service/entity-master.service.ts +169 -169
  237. package/src/module/meta/service/entity-realation-data.service.ts +9 -9
  238. package/src/module/meta/service/entity-relation.service.ts +69 -69
  239. package/src/module/meta/service/entity-service-impl.service.ts +525 -525
  240. package/src/module/meta/service/entity-table-column.service.ts +39 -39
  241. package/src/module/meta/service/entity-table.service.ts +150 -150
  242. package/src/module/meta/service/entity-validation.service.ts +187 -187
  243. package/src/module/meta/service/entity.service.ts +67 -67
  244. package/src/module/meta/service/field-group.service.ts +103 -103
  245. package/src/module/meta/service/media-data.service.ts +507 -507
  246. package/src/module/meta/service/populate-meta.service.ts +193 -193
  247. package/src/module/meta/service/preference.service.ts +16 -16
  248. package/src/module/meta/service/resolver.service.ts +267 -267
  249. package/src/module/meta/service/section-master.service.ts +104 -104
  250. package/src/module/meta/service/update-form-json.service.ts +22 -22
  251. package/src/module/meta/service/user-app-mapping.service.ts +17 -17
  252. package/src/module/meta/service/view-master.service.ts +127 -127
  253. package/src/module/microservice-client/microservice-clients.module.ts +13 -13
  254. package/src/module/microservice-client/service/microservice-client-factory.ts +37 -37
  255. package/src/module/microservice-client/service/microservice-clients.ts +4 -4
  256. package/src/module/module/controller/menu.controller.ts +15 -15
  257. package/src/module/module/controller/module-access.controller.ts +134 -134
  258. package/src/module/module/entity/menu.entity.ts +43 -43
  259. package/src/module/module/entity/module-access.entity.ts +25 -25
  260. package/src/module/module/entity/module-action.entity.ts +17 -17
  261. package/src/module/module/entity/module.entity.ts +52 -52
  262. package/src/module/module/module.module.ts +42 -42
  263. package/src/module/module/repository/menu.repository.ts +184 -184
  264. package/src/module/module/repository/module-access.repository.ts +344 -344
  265. package/src/module/module/service/menu.service.ts +82 -82
  266. package/src/module/module/service/module-access.service.ts +209 -209
  267. package/src/module/notification/controller/notification.controller.ts +58 -58
  268. package/src/module/notification/controller/otp.controller.ts +117 -117
  269. package/src/module/notification/entity/notification.entity.ts +26 -26
  270. package/src/module/notification/entity/otp.entity.ts +28 -28
  271. package/src/module/notification/firebase-admin.config.ts +22 -22
  272. package/src/module/notification/notification.module.ts +69 -69
  273. package/src/module/notification/repository/otp.repository.ts +27 -27
  274. package/src/module/notification/service/email.service.ts +127 -127
  275. package/src/module/notification/service/notification.service.ts +163 -163
  276. package/src/module/notification/service/otp.service.ts +132 -132
  277. package/src/module/third-party-module/entity/third-party-api-registry.entity.ts +52 -52
  278. package/src/module/third-party-module/repository/third-party-api-registry.repository.ts +20 -20
  279. package/src/module/third-party-module/service/api-registry.service.ts +13 -13
  280. package/src/module/third-party-module/third-party.module.ts +12 -12
  281. package/src/module/user/controller/login.controller.ts +197 -197
  282. package/src/module/user/controller/user.controller.ts +40 -40
  283. package/src/module/user/dto/create-user.dto.ts +62 -62
  284. package/src/module/user/dto/update-user.dto.ts +4 -4
  285. package/src/module/user/entity/role.entity.ts +33 -33
  286. package/src/module/user/entity/user-role-mapping.entity.ts +38 -38
  287. package/src/module/user/entity/user-session.entity.ts +73 -73
  288. package/src/module/user/entity/user.entity.ts +59 -59
  289. package/src/module/user/repository/role.repository.ts +96 -96
  290. package/src/module/user/repository/user-role-mapping.repository.ts +126 -126
  291. package/src/module/user/repository/user.repository.ts +50 -50
  292. package/src/module/user/repository/userSession.repository.ts +33 -33
  293. package/src/module/user/service/login.service.ts +304 -304
  294. package/src/module/user/service/role.service.ts +189 -189
  295. package/src/module/user/service/user-role-mapping.service.ts +98 -98
  296. package/src/module/user/service/user-session.service.ts +168 -168
  297. package/src/module/user/service/user.service.ts +365 -365
  298. package/src/module/user/user.module.ts +65 -65
  299. package/src/module/workflow/controller/action-category.controller.ts +54 -54
  300. package/src/module/workflow/controller/action-resource-mapping.controller.ts +23 -23
  301. package/src/module/workflow/controller/action-template-mapping.controller.ts +35 -35
  302. package/src/module/workflow/controller/action.controller.ts +111 -111
  303. package/src/module/workflow/controller/activity-log.controller.ts +55 -55
  304. package/src/module/workflow/controller/comm-template.controller.ts +43 -43
  305. package/src/module/workflow/controller/entity-modification.controller.ts +35 -35
  306. package/src/module/workflow/controller/form-master.controller.ts +43 -43
  307. package/src/module/workflow/controller/stage-group.controller.ts +48 -48
  308. package/src/module/workflow/controller/stage.controller.ts +50 -50
  309. package/src/module/workflow/controller/task.controller.ts +77 -77
  310. package/src/module/workflow/controller/workflow-list-master.controller.ts +44 -44
  311. package/src/module/workflow/controller/workflow-meta.controller.ts +80 -80
  312. package/src/module/workflow/controller/workflow.controller.ts +67 -67
  313. package/src/module/workflow/entity/action-category.entity.ts +38 -38
  314. package/src/module/workflow/entity/action-data.entity.ts +55 -55
  315. package/src/module/workflow/entity/action-resources-mapping.entity.ts +29 -29
  316. package/src/module/workflow/entity/action-template-mapping.entity.ts +17 -17
  317. package/src/module/workflow/entity/action.entity.ts +50 -50
  318. package/src/module/workflow/entity/activity-log.entity.ts +43 -43
  319. package/src/module/workflow/entity/comm-template.entity.ts +43 -43
  320. package/src/module/workflow/entity/entity-modification.entity.ts +38 -38
  321. package/src/module/workflow/entity/form.entity.ts +25 -25
  322. package/src/module/workflow/entity/stage-action-mapping.entity.ts +17 -17
  323. package/src/module/workflow/entity/stage-group.entity.ts +23 -23
  324. package/src/module/workflow/entity/stage-movement-data.entity.ts +38 -38
  325. package/src/module/workflow/entity/stage.entity.ts +20 -20
  326. package/src/module/workflow/entity/task-data.entity.ts +88 -88
  327. package/src/module/workflow/entity/template-attach-mapper.entity.ts +30 -30
  328. package/src/module/workflow/entity/workflow-data.entity.ts +11 -11
  329. package/src/module/workflow/entity/workflow-level-mapping.entity.ts +18 -18
  330. package/src/module/workflow/entity/workflow.entity.ts +20 -20
  331. package/src/module/workflow/repository/action-category.repository.ts +79 -79
  332. package/src/module/workflow/repository/action-data.repository.ts +333 -333
  333. package/src/module/workflow/repository/action.repository.ts +323 -323
  334. package/src/module/workflow/repository/activity-log.repository.ts +148 -148
  335. package/src/module/workflow/repository/comm-template.repository.ts +149 -149
  336. package/src/module/workflow/repository/form-master.repository.ts +59 -59
  337. package/src/module/workflow/repository/stage-group.repository.ts +176 -176
  338. package/src/module/workflow/repository/stage-movement.repository.ts +244 -244
  339. package/src/module/workflow/repository/stage.repository.ts +172 -172
  340. package/src/module/workflow/repository/task.repository.ts +127 -127
  341. package/src/module/workflow/repository/workflow.repository.ts +42 -42
  342. package/src/module/workflow/service/action-category.service.ts +33 -33
  343. package/src/module/workflow/service/action-data.service.ts +62 -62
  344. package/src/module/workflow/service/action-resources-mapping.service.ts +10 -10
  345. package/src/module/workflow/service/action-template-mapping.service.ts +106 -106
  346. package/src/module/workflow/service/action.service.ts +279 -279
  347. package/src/module/workflow/service/activity-log.service.ts +107 -107
  348. package/src/module/workflow/service/comm-template.service.ts +180 -180
  349. package/src/module/workflow/service/entity-modification.service.ts +67 -67
  350. package/src/module/workflow/service/form-master.service.ts +35 -35
  351. package/src/module/workflow/service/populate-workflow.service.ts +303 -303
  352. package/src/module/workflow/service/stage-action-mapping.service.ts +5 -5
  353. package/src/module/workflow/service/stage-group.service.ts +319 -319
  354. package/src/module/workflow/service/stage.service.ts +199 -199
  355. package/src/module/workflow/service/task.service.ts +560 -560
  356. package/src/module/workflow/service/workflow-list-master.service.ts +60 -60
  357. package/src/module/workflow/service/workflow-meta.service.ts +654 -640
  358. package/src/module/workflow/service/workflow.service.ts +205 -205
  359. package/src/module/workflow/workflow.module.ts +176 -176
  360. package/src/module/workflow-automation/controller/workflow-automation.controller.ts +21 -21
  361. package/src/module/workflow-automation/entity/workflow-automation-action.entity.ts +26 -26
  362. package/src/module/workflow-automation/entity/workflow-automation.entity.ts +35 -35
  363. package/src/module/workflow-automation/interface/action.decorator.ts +7 -7
  364. package/src/module/workflow-automation/interface/action.interface.ts +5 -5
  365. package/src/module/workflow-automation/service/action-registery.service.ts +35 -35
  366. package/src/module/workflow-automation/service/workflow-automation-engine.service.ts +214 -214
  367. package/src/module/workflow-automation/service/workflow-automation.service.ts +347 -347
  368. package/src/module/workflow-automation/workflow-automation.module.ts +34 -34
  369. package/src/resources/dev.properties.yaml +30 -31
  370. package/src/resources/local.properties.yaml +27 -27
  371. package/src/resources/properties.module.ts +12 -12
  372. package/src/resources/properties.yaml.ts +11 -11
  373. package/src/resources/uat.properties.yaml +31 -31
  374. package/src/table.config.ts +126 -126
  375. package/src/utils/dto/excel-data.dto.ts +14 -14
  376. package/src/utils/dto/excelsheet-data.dto.ts +5 -5
  377. package/src/utils/service/base64util.service.ts +18 -18
  378. package/src/utils/service/clockIDGenUtil.service.ts +21 -21
  379. package/src/utils/service/codeGenerator.service.ts +22 -22
  380. package/src/utils/service/dateUtil.service.ts +17 -17
  381. package/src/utils/service/encryptUtil.service.ts +97 -97
  382. package/src/utils/service/excel-helper.service.ts +72 -72
  383. package/src/utils/service/excelUtil.service.ts +15 -15
  384. package/src/utils/service/file-util.service.ts +11 -11
  385. package/src/utils/service/json-util.service.ts +23 -23
  386. package/src/utils/service/loggingUtil.service.ts +34 -34
  387. package/src/utils/service/reflection-helper.service.ts +62 -62
  388. package/src/utils/service/wbsCodeGen.service.ts +8 -8
  389. package/src/utils/utils.module.ts +25 -25
  390. package/tsconfig.build.json +4 -4
  391. package/tsconfig.json +24 -24
  392. package/.claude/settings.local.json +0 -26
  393. package/.idea/250218_nodejs_core.iml +0 -9
  394. package/.idea/codeStyles/Project.xml +0 -59
  395. package/.idea/codeStyles/codeStyleConfig.xml +0 -5
  396. package/.idea/copilot.data.migration.agent.xml +0 -6
  397. package/.idea/copilot.data.migration.ask.xml +0 -6
  398. package/.idea/copilot.data.migration.ask2agent.xml +0 -6
  399. package/.idea/copilot.data.migration.edit.xml +0 -6
  400. package/.idea/inspectionProfiles/Project_Default.xml +0 -6
  401. package/.idea/misc.xml +0 -6
  402. package/.idea/modules.xml +0 -8
  403. package/.idea/prettier.xml +0 -6
  404. package/.idea/vcs.xml +0 -6
  405. package/server.log +0 -850
@@ -1,304 +1,304 @@
1
- import { BadRequestException, Inject, Injectable } from '@nestjs/common';
2
- import { ConfigService } from '@nestjs/config';
3
- import { InjectRepository } from '@nestjs/typeorm';
4
- import {
5
- INVITATION_STATUS_ACCEPTED,
6
- STATUS_ACTIVE,
7
- } from 'src/constant/global.constant';
8
- import { OrganizationRepository } from 'src/module/enterprise/repository/organization.repository';
9
- import { ListMasterService } from 'src/module/listmaster/service/list-master.service';
10
- import { DataSource, Not, Repository, IsNull } from 'typeorm';
11
- import { EncryptUtilService } from '../../../utils/service/encryptUtil.service';
12
- import { Role } from '../entity/role.entity';
13
- import { UserRoleMapping } from '../entity/user-role-mapping.entity';
14
- import { UserData } from '../entity/user.entity';
15
- import { UserSessionService } from './user-session.service';
16
- import { UserService } from './user.service';
17
- import { JwtAuthService } from 'src/module/auth/services/jwt.service';
18
-
19
- @Injectable()
20
- export class LoginService {
21
- constructor(
22
- @Inject('UserService') private readonly userService: UserService,
23
- private userSessionService: UserSessionService,
24
- private configService: ConfigService,
25
- @InjectRepository(UserRoleMapping)
26
- private readonly userRoleMappingRepository: Repository<UserRoleMapping>,
27
- @InjectRepository(Role)
28
- private readonly roleRepo: Repository<Role>,
29
- private readonly dataSource: DataSource,
30
- private readonly organizationRepository: OrganizationRepository,
31
- @Inject('ListMasterService')
32
- private readonly listMasterService: ListMasterService,
33
- private readonly jwtAuthService: JwtAuthService,
34
- @InjectRepository(UserData)
35
- private readonly userRepository: Repository<UserData>,
36
- ) {}
37
-
38
- masterKey: string = this.configService.get('MASTER_KEY') || '';
39
- masterIv: string = this.configService.get('MASTER_IV') || '';
40
-
41
- async login(data: { email_id: string; password?: string; is_otp?: boolean }) {
42
- const { email_id, password, is_otp = false } = data;
43
-
44
- let organization;
45
-
46
- // 🔹 Step 2: Find the user by email + organization check
47
- const user = await this.userService.findByEmailId(email_id);
48
-
49
- if (!user || (organization && user.organization_id !== organization.id)) {
50
- return {
51
- success: false,
52
- message: 'User not found in organization.',
53
- };
54
- }
55
-
56
- // 🔹 Step 3: Verify org status
57
- const userOrgData = await this.organizationRepository.findOrganizationById(
58
- user.organization_id,
59
- );
60
-
61
- const resolveStatus = await this.listMasterService.getResolvedListCode(
62
- STATUS_ACTIVE,
63
- user?.organization_id || 0,
64
- );
65
-
66
- if (
67
- user.status != resolveStatus.id ||
68
- userOrgData?.status != resolveStatus.id
69
- ) {
70
- return {
71
- success: false,
72
- message:
73
- 'Your account or organization is inactive. Please contact admin.',
74
- };
75
- }
76
-
77
- // 🔹 Step 4: Verify password if not OTP
78
- if (!is_otp) {
79
- const encryptedPassword = EncryptUtilService.encryptGCM(
80
- password,
81
- this.masterKey,
82
- this.masterIv,
83
- );
84
-
85
- if (encryptedPassword !== user.password) {
86
- return {
87
- success: false,
88
- message: 'Oops! Your password is incorrect.',
89
- type: 'password',
90
- };
91
- }
92
- }
93
-
94
- // 🔹 Step 5: App access check
95
- let appcode = user.last_app_access;
96
-
97
- if (!user.last_app_access || user.last_app_access == '') {
98
- await this.userService.setDefaultLastAccess(user.id, appcode);
99
- }
100
-
101
- const whereCondition: any = { user_id: user.id };
102
-
103
- if (appcode && appcode !== '') {
104
- whereCondition.appcode = appcode;
105
- }
106
-
107
- const roleMappings = await this.userRoleMappingRepository.find({
108
- where: whereCondition,
109
- });
110
-
111
- if (!roleMappings.length) {
112
- return {
113
- success: false,
114
- message: 'You do not have access to this application.',
115
- };
116
- }
117
-
118
- // 🔹 Step 6: Resolve default access
119
- const defaultAccess = await this.getDefaultAccess(user, roleMappings);
120
-
121
- await this.userService.setLastLevelTypeAndId(
122
- user.id,
123
- defaultAccess.level_type,
124
- defaultAccess.level_id,
125
- defaultAccess.appcode,
126
- );
127
-
128
- const token = await this.userSessionService.createSession(
129
- user,
130
- defaultAccess.appcode,
131
- defaultAccess,
132
- );
133
-
134
- // 🔹 Step 7: Update first login + invitation status
135
- const resolvedInvitationStatus =
136
- await this.listMasterService.getResolvedListCode(
137
- INVITATION_STATUS_ACCEPTED,
138
- user?.organization_id || 0,
139
- );
140
-
141
- if (user.is_firstlogin === 1) {
142
- user.invitation_status = resolvedInvitationStatus.id;
143
- user.is_firstlogin = 0;
144
- const { password, ...userWithoutPassword } = user;
145
- await this.userService.updateEntity(userWithoutPassword, user);
146
- }
147
-
148
- // 🔹 Step 8: Return response
149
-
150
- const org = await this.organizationRepository.findOrganizationById(
151
- user.organization_id,
152
- );
153
- let slug: string;
154
- if (org) {
155
- slug = org.slug;
156
- } else {
157
- return {
158
- success: false,
159
- message: 'Organization not found for the user.',
160
- };
161
- }
162
-
163
- return {
164
- success: true,
165
- accessToken: token,
166
- appcode: defaultAccess.appcode,
167
- level_type: defaultAccess.level_type,
168
- level_id: defaultAccess.level_id,
169
- slug: slug,
170
- };
171
- }
172
-
173
- async formLogin(body: any): Promise<any> {
174
- if (body) {
175
- const { entity_type, entity_id } = body;
176
-
177
- const entityData = await this.dataSource.query(
178
- `SELECT level_id, level_type, organization_id FROM ether_core.crm_lead where id = ${entity_id}`,
179
- );
180
-
181
- if (entityData.length > 0) {
182
- const level_id = entityData[0].level_id;
183
- const level_type = entityData[0].level_type;
184
- const organization_id = entityData[0].organization_id;
185
-
186
- const token = await this.jwtAuthService.generateJwt({
187
- level_id: level_id,
188
- level_type: level_type,
189
- organization_id: organization_id,
190
- });
191
-
192
- return {
193
- success: true,
194
- accessToken: token,
195
- };
196
- }
197
- }
198
- }
199
-
200
- private async getDefaultAccess(
201
- user: any,
202
- roleMappings: any[],
203
- ): Promise<{ level_type: string; level_id: string; appcode: string }> {
204
- const orgAccess = roleMappings.find((r) => r.level_type === 'ORG');
205
- const brnAccesses = roleMappings.filter((r) => r.level_type === 'BRN');
206
- const schAccesses = roleMappings.filter((r) => r.level_type === 'SCH');
207
-
208
- let validURM;
209
-
210
- validURM = roleMappings.some(
211
- (r) => r.level_type == 'ORG' && r.level_id == user.organization_id,
212
- );
213
-
214
- if (!validURM) {
215
- validURM = roleMappings.some(
216
- (r) =>
217
- r.level_type === user.last_level_type &&
218
- r.level_id === user.last_level_id,
219
- );
220
- }
221
-
222
- if (user.last_level_type && user.last_level_id && validURM) {
223
- return {
224
- level_type: user.last_level_type,
225
- level_id: user.last_level_id,
226
- appcode: user.last_app_access,
227
- };
228
- }
229
-
230
- if (orgAccess) {
231
- return {
232
- level_type: 'ORG',
233
- level_id: orgAccess.level_id,
234
- appcode: orgAccess.appcode,
235
- };
236
- }
237
-
238
- if (brnAccesses.length) {
239
- const brandId = brnAccesses[0].level_id;
240
-
241
- const rows = await this.dataSource.query(
242
- `SELECT id FROM sso_school WHERE brand_id = ? ORDER BY id ASC LIMIT 1`,
243
- [brandId],
244
- );
245
-
246
- if (rows.length) {
247
- return {
248
- level_type: 'SCH',
249
- level_id: rows[0].id,
250
- appcode: brnAccesses[0].appcode,
251
- };
252
- } else {
253
- throw new BadRequestException(
254
- 'User has BRN access but no schools found under that brand.',
255
- );
256
- }
257
- }
258
-
259
- if (schAccesses.length) {
260
- return {
261
- level_type: 'SCH',
262
- level_id: schAccesses[0].level_id,
263
- appcode: schAccesses[0].appcode,
264
- };
265
- }
266
-
267
- throw new BadRequestException(
268
- 'User does not have ORG, BRN, or SCH access for this app.',
269
- );
270
- }
271
-
272
- async loginWithGoogle(data: {
273
- email: string;
274
- subdomain?: string;
275
- fcm_token?: string;
276
- ip?: string;
277
- browser?: string;
278
- os?: string;
279
- }) {
280
- const { email } = data;
281
- const user = await this.userService.findByEmailId(email);
282
-
283
- if (!user) {
284
- return new BadRequestException('User not found');
285
- }
286
-
287
- // Create session (Same as JWT login flow)
288
- return await this.login({
289
- email_id: email,
290
- is_otp: true,
291
- });
292
- }
293
-
294
- async logout(sessionKey: string) {
295
- const userSession =
296
- await this.userSessionService.findBySessionKey(sessionKey);
297
- if (userSession) {
298
- userSession.is_session_loggedout = 1;
299
- userSession.logout_time = new Date();
300
- await this.userSessionService.updateSession(userSession);
301
- return { message: 'Logged out successfully' };
302
- }
303
- }
304
- }
1
+ import { BadRequestException, Inject, Injectable } from '@nestjs/common';
2
+ import { ConfigService } from '@nestjs/config';
3
+ import { InjectRepository } from '@nestjs/typeorm';
4
+ import {
5
+ INVITATION_STATUS_ACCEPTED,
6
+ STATUS_ACTIVE,
7
+ } from 'src/constant/global.constant';
8
+ import { OrganizationRepository } from 'src/module/enterprise/repository/organization.repository';
9
+ import { ListMasterService } from 'src/module/listmaster/service/list-master.service';
10
+ import { DataSource, Not, Repository, IsNull } from 'typeorm';
11
+ import { EncryptUtilService } from '../../../utils/service/encryptUtil.service';
12
+ import { Role } from '../entity/role.entity';
13
+ import { UserRoleMapping } from '../entity/user-role-mapping.entity';
14
+ import { UserData } from '../entity/user.entity';
15
+ import { UserSessionService } from './user-session.service';
16
+ import { UserService } from './user.service';
17
+ import { JwtAuthService } from 'src/module/auth/services/jwt.service';
18
+
19
+ @Injectable()
20
+ export class LoginService {
21
+ constructor(
22
+ @Inject('UserService') private readonly userService: UserService,
23
+ private userSessionService: UserSessionService,
24
+ private configService: ConfigService,
25
+ @InjectRepository(UserRoleMapping)
26
+ private readonly userRoleMappingRepository: Repository<UserRoleMapping>,
27
+ @InjectRepository(Role)
28
+ private readonly roleRepo: Repository<Role>,
29
+ private readonly dataSource: DataSource,
30
+ private readonly organizationRepository: OrganizationRepository,
31
+ @Inject('ListMasterService')
32
+ private readonly listMasterService: ListMasterService,
33
+ private readonly jwtAuthService: JwtAuthService,
34
+ @InjectRepository(UserData)
35
+ private readonly userRepository: Repository<UserData>,
36
+ ) {}
37
+
38
+ masterKey: string = this.configService.get('MASTER_KEY') || '';
39
+ masterIv: string = this.configService.get('MASTER_IV') || '';
40
+
41
+ async login(data: { email_id: string; password?: string; is_otp?: boolean }) {
42
+ const { email_id, password, is_otp = false } = data;
43
+
44
+ let organization;
45
+
46
+ // 🔹 Step 2: Find the user by email + organization check
47
+ const user = await this.userService.findByEmailId(email_id);
48
+
49
+ if (!user || (organization && user.organization_id !== organization.id)) {
50
+ return {
51
+ success: false,
52
+ message: 'User not found in organization.',
53
+ };
54
+ }
55
+
56
+ // 🔹 Step 3: Verify org status
57
+ const userOrgData = await this.organizationRepository.findOrganizationById(
58
+ user.organization_id,
59
+ );
60
+
61
+ const resolveStatus = await this.listMasterService.getResolvedListCode(
62
+ STATUS_ACTIVE,
63
+ user?.organization_id || 0,
64
+ );
65
+
66
+ if (
67
+ user.status != resolveStatus.id ||
68
+ userOrgData?.status != resolveStatus.id
69
+ ) {
70
+ return {
71
+ success: false,
72
+ message:
73
+ 'Your account or organization is inactive. Please contact admin.',
74
+ };
75
+ }
76
+
77
+ // 🔹 Step 4: Verify password if not OTP
78
+ if (!is_otp) {
79
+ const encryptedPassword = EncryptUtilService.encryptGCM(
80
+ password,
81
+ this.masterKey,
82
+ this.masterIv,
83
+ );
84
+
85
+ if (encryptedPassword !== user.password) {
86
+ return {
87
+ success: false,
88
+ message: 'Oops! Your password is incorrect.',
89
+ type: 'password',
90
+ };
91
+ }
92
+ }
93
+
94
+ // 🔹 Step 5: App access check
95
+ let appcode = user.last_app_access;
96
+
97
+ if (!user.last_app_access || user.last_app_access == '') {
98
+ await this.userService.setDefaultLastAccess(user.id, appcode);
99
+ }
100
+
101
+ const whereCondition: any = { user_id: user.id };
102
+
103
+ if (appcode && appcode !== '') {
104
+ whereCondition.appcode = appcode;
105
+ }
106
+
107
+ const roleMappings = await this.userRoleMappingRepository.find({
108
+ where: whereCondition,
109
+ });
110
+
111
+ if (!roleMappings.length) {
112
+ return {
113
+ success: false,
114
+ message: 'You do not have access to this application.',
115
+ };
116
+ }
117
+
118
+ // 🔹 Step 6: Resolve default access
119
+ const defaultAccess = await this.getDefaultAccess(user, roleMappings);
120
+
121
+ await this.userService.setLastLevelTypeAndId(
122
+ user.id,
123
+ defaultAccess.level_type,
124
+ defaultAccess.level_id,
125
+ defaultAccess.appcode,
126
+ );
127
+
128
+ const token = await this.userSessionService.createSession(
129
+ user,
130
+ defaultAccess.appcode,
131
+ defaultAccess,
132
+ );
133
+
134
+ // 🔹 Step 7: Update first login + invitation status
135
+ const resolvedInvitationStatus =
136
+ await this.listMasterService.getResolvedListCode(
137
+ INVITATION_STATUS_ACCEPTED,
138
+ user?.organization_id || 0,
139
+ );
140
+
141
+ if (user.is_firstlogin === 1) {
142
+ user.invitation_status = resolvedInvitationStatus.id;
143
+ user.is_firstlogin = 0;
144
+ const { password, ...userWithoutPassword } = user;
145
+ await this.userService.updateEntity(userWithoutPassword, user);
146
+ }
147
+
148
+ // 🔹 Step 8: Return response
149
+
150
+ const org = await this.organizationRepository.findOrganizationById(
151
+ user.organization_id,
152
+ );
153
+ let slug: string;
154
+ if (org) {
155
+ slug = org.slug;
156
+ } else {
157
+ return {
158
+ success: false,
159
+ message: 'Organization not found for the user.',
160
+ };
161
+ }
162
+
163
+ return {
164
+ success: true,
165
+ accessToken: token,
166
+ appcode: defaultAccess.appcode,
167
+ level_type: defaultAccess.level_type,
168
+ level_id: defaultAccess.level_id,
169
+ slug: slug,
170
+ };
171
+ }
172
+
173
+ async formLogin(body: any): Promise<any> {
174
+ if (body) {
175
+ const { entity_type, entity_id } = body;
176
+
177
+ const entityData = await this.dataSource.query(
178
+ `SELECT level_id, level_type, organization_id FROM ether_core.crm_lead where id = ${entity_id}`,
179
+ );
180
+
181
+ if (entityData.length > 0) {
182
+ const level_id = entityData[0].level_id;
183
+ const level_type = entityData[0].level_type;
184
+ const organization_id = entityData[0].organization_id;
185
+
186
+ const token = await this.jwtAuthService.generateJwt({
187
+ level_id: level_id,
188
+ level_type: level_type,
189
+ organization_id: organization_id,
190
+ });
191
+
192
+ return {
193
+ success: true,
194
+ accessToken: token,
195
+ };
196
+ }
197
+ }
198
+ }
199
+
200
+ private async getDefaultAccess(
201
+ user: any,
202
+ roleMappings: any[],
203
+ ): Promise<{ level_type: string; level_id: string; appcode: string }> {
204
+ const orgAccess = roleMappings.find((r) => r.level_type === 'ORG');
205
+ const brnAccesses = roleMappings.filter((r) => r.level_type === 'BRN');
206
+ const schAccesses = roleMappings.filter((r) => r.level_type === 'SCH');
207
+
208
+ let validURM;
209
+
210
+ validURM = roleMappings.some(
211
+ (r) => r.level_type == 'ORG' && r.level_id == user.organization_id,
212
+ );
213
+
214
+ if (!validURM) {
215
+ validURM = roleMappings.some(
216
+ (r) =>
217
+ r.level_type === user.last_level_type &&
218
+ r.level_id === user.last_level_id,
219
+ );
220
+ }
221
+
222
+ if (user.last_level_type && user.last_level_id && validURM) {
223
+ return {
224
+ level_type: user.last_level_type,
225
+ level_id: user.last_level_id,
226
+ appcode: user.last_app_access,
227
+ };
228
+ }
229
+
230
+ if (orgAccess) {
231
+ return {
232
+ level_type: 'ORG',
233
+ level_id: orgAccess.level_id,
234
+ appcode: orgAccess.appcode,
235
+ };
236
+ }
237
+
238
+ if (brnAccesses.length) {
239
+ const brandId = brnAccesses[0].level_id;
240
+
241
+ const rows = await this.dataSource.query(
242
+ `SELECT id FROM sso_school WHERE brand_id = ? ORDER BY id ASC LIMIT 1`,
243
+ [brandId],
244
+ );
245
+
246
+ if (rows.length) {
247
+ return {
248
+ level_type: 'SCH',
249
+ level_id: rows[0].id,
250
+ appcode: brnAccesses[0].appcode,
251
+ };
252
+ } else {
253
+ throw new BadRequestException(
254
+ 'User has BRN access but no schools found under that brand.',
255
+ );
256
+ }
257
+ }
258
+
259
+ if (schAccesses.length) {
260
+ return {
261
+ level_type: 'SCH',
262
+ level_id: schAccesses[0].level_id,
263
+ appcode: schAccesses[0].appcode,
264
+ };
265
+ }
266
+
267
+ throw new BadRequestException(
268
+ 'User does not have ORG, BRN, or SCH access for this app.',
269
+ );
270
+ }
271
+
272
+ async loginWithGoogle(data: {
273
+ email: string;
274
+ subdomain?: string;
275
+ fcm_token?: string;
276
+ ip?: string;
277
+ browser?: string;
278
+ os?: string;
279
+ }) {
280
+ const { email } = data;
281
+ const user = await this.userService.findByEmailId(email);
282
+
283
+ if (!user) {
284
+ return new BadRequestException('User not found');
285
+ }
286
+
287
+ // Create session (Same as JWT login flow)
288
+ return await this.login({
289
+ email_id: email,
290
+ is_otp: true,
291
+ });
292
+ }
293
+
294
+ async logout(sessionKey: string) {
295
+ const userSession =
296
+ await this.userSessionService.findBySessionKey(sessionKey);
297
+ if (userSession) {
298
+ userSession.is_session_loggedout = 1;
299
+ userSession.logout_time = new Date();
300
+ await this.userSessionService.updateSession(userSession);
301
+ return { message: 'Logged out successfully' };
302
+ }
303
+ }
304
+ }