rez_core 4.0.183 → 4.0.184

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 (613) hide show
  1. package/.claude/settings.local.json +26 -0
  2. package/.idea/250218_nodejs_core.iml +9 -0
  3. package/.idea/codeStyles/Project.xml +59 -0
  4. package/.idea/codeStyles/codeStyleConfig.xml +5 -0
  5. package/.idea/copilot.data.migration.agent.xml +6 -0
  6. package/.idea/copilot.data.migration.ask.xml +6 -0
  7. package/.idea/copilot.data.migration.ask2agent.xml +6 -0
  8. package/.idea/copilot.data.migration.edit.xml +6 -0
  9. package/.idea/inspectionProfiles/Project_Default.xml +6 -0
  10. package/.idea/misc.xml +6 -0
  11. package/.idea/modules.xml +8 -0
  12. package/.idea/prettier.xml +6 -0
  13. package/.idea/vcs.xml +6 -0
  14. package/.prettierrc +3 -3
  15. package/README.md +99 -99
  16. package/dist/app.module.js +0 -11
  17. package/dist/app.module.js.map +1 -1
  18. package/dist/config/config.module.js +2 -2
  19. package/dist/config/config.module.js.map +1 -1
  20. package/dist/config/database.config.d.ts +1 -1
  21. package/dist/config/database.config.js +16 -12
  22. package/dist/config/database.config.js.map +1 -1
  23. package/dist/core.module.d.ts +1 -1
  24. package/dist/core.module.js +3 -6
  25. package/dist/core.module.js.map +1 -1
  26. package/dist/main.js +1 -1
  27. package/dist/main.js.map +1 -1
  28. package/dist/module/auth/guards/role.guard.js +3 -3
  29. package/dist/module/auth/services/auth.service.js +3 -3
  30. package/dist/module/auth/services/auth.service.js.map +1 -1
  31. package/dist/module/enterprise/entity/organization.entity.js +1 -1
  32. package/dist/module/enterprise/repository/school.repository.js +3 -3
  33. package/dist/module/enterprise/repository/school.repository.js.map +1 -1
  34. package/dist/module/filter/repository/saved-filter.repository.js +4 -4
  35. package/dist/module/filter/service/filter-evaluator.service.js +3 -3
  36. package/dist/module/filter/service/filter-evaluator.service.js.map +1 -1
  37. package/dist/module/filter/service/filter.service.d.ts +4 -1
  38. package/dist/module/filter/service/filter.service.js +69 -39
  39. package/dist/module/filter/service/filter.service.js.map +1 -1
  40. package/dist/module/integration/entity/integration-config.entity.js +6 -6
  41. package/dist/module/integration/entity/integration-config.entity.js.map +1 -1
  42. package/dist/module/integration/entity/integration-entity-mapper.entity.js +1 -1
  43. package/dist/module/integration/entity/integration-entity-mapper.entity.js.map +1 -1
  44. package/dist/module/integration/entity/integration-source.entity.js +4 -4
  45. package/dist/module/integration/entity/integration-source.entity.js.map +1 -1
  46. package/dist/module/integration/entity/user-integration.entity.js +4 -4
  47. package/dist/module/integration/entity/user-integration.entity.js.map +1 -1
  48. package/dist/module/integration/examples/usage.example.js +9 -9
  49. package/dist/module/integration/service/integration.service.js +1 -1
  50. package/dist/module/integration/service/wrapper.service.d.ts +1 -3
  51. package/dist/module/integration/service/wrapper.service.js +65 -67
  52. package/dist/module/integration/service/wrapper.service.js.map +1 -1
  53. package/dist/module/listmaster/entity/list-master-items.entity.js +3 -3
  54. package/dist/module/listmaster/entity/list-master-items.entity.js.map +1 -1
  55. package/dist/module/listmaster/entity/list-master.entity.js +4 -4
  56. package/dist/module/listmaster/entity/list-master.entity.js.map +1 -1
  57. package/dist/module/listmaster/service/list-master-item.service.js +3 -3
  58. package/dist/module/listmaster/service/list-master-item.service.js.map +1 -1
  59. package/dist/module/mapper/entity/field-mapper.entity.js +6 -6
  60. package/dist/module/mapper/entity/field-mapper.entity.js.map +1 -1
  61. package/dist/module/mapper/service/field-mapper.service.js +7 -7
  62. package/dist/module/mapper/service/field-mapper.service.js.map +1 -1
  63. package/dist/module/mapper/service/mapper.service.js +4 -4
  64. package/dist/module/mapper/service/mapper.service.js.map +1 -1
  65. package/dist/module/meta/controller/attribute-master.controller.d.ts +1 -4
  66. package/dist/module/meta/controller/attribute-master.controller.js +2 -15
  67. package/dist/module/meta/controller/attribute-master.controller.js.map +1 -1
  68. package/dist/module/meta/entity/app-master.entity.d.ts +2 -2
  69. package/dist/module/meta/entity/app-master.entity.js +4 -4
  70. package/dist/module/meta/entity/entity-master.entity.js +1 -1
  71. package/dist/module/meta/entity/entity-master.entity.js.map +1 -1
  72. package/dist/module/meta/entity/view-master.entity.js +1 -1
  73. package/dist/module/meta/entity/view-master.entity.js.map +1 -1
  74. package/dist/module/meta/entity.module.js +0 -7
  75. package/dist/module/meta/entity.module.js.map +1 -1
  76. package/dist/module/meta/repository/attribute-master.repository.js +2 -2
  77. package/dist/module/meta/repository/attribute-master.repository.js.map +1 -1
  78. package/dist/module/meta/repository/entity-master.repository.js +2 -2
  79. package/dist/module/meta/repository/entity-master.repository.js.map +1 -1
  80. package/dist/module/meta/service/attribute-master.service.js +1 -1
  81. package/dist/module/meta/service/attribute-master.service.js.map +1 -1
  82. package/dist/module/meta/service/entity-dynamic.service.js +27 -27
  83. package/dist/module/meta/service/entity-dynamic.service.js.map +1 -1
  84. package/dist/module/meta/service/entity-list.service.js +3 -3
  85. package/dist/module/meta/service/entity-master.service.js +4 -4
  86. package/dist/module/meta/service/entity-master.service.js.map +1 -1
  87. package/dist/module/meta/service/entity-relation.service.js +13 -13
  88. package/dist/module/meta/service/entity-relation.service.js.map +1 -1
  89. package/dist/module/meta/service/entity-service-impl.service.js +3 -3
  90. package/dist/module/meta/service/media-data.service.js +9 -9
  91. package/dist/module/meta/service/media-data.service.js.map +1 -1
  92. package/dist/module/meta/service/resolver.service.js +19 -19
  93. package/dist/module/meta/service/resolver.service.js.map +1 -1
  94. package/dist/module/module/repository/menu.repository.js +12 -12
  95. package/dist/module/module/service/module-access.service.js +1 -1
  96. package/dist/module/module/service/module-access.service.js.map +1 -1
  97. package/dist/module/notification/entity/otp.entity.js +1 -1
  98. package/dist/module/notification/entity/otp.entity.js.map +1 -1
  99. package/dist/module/notification/service/notification.service.js +26 -22
  100. package/dist/module/notification/service/notification.service.js.map +1 -1
  101. package/dist/module/user/controller/login.controller.js +18 -18
  102. package/dist/module/user/entity/user-role-mapping.entity.js +1 -1
  103. package/dist/module/user/entity/user-role-mapping.entity.js.map +1 -1
  104. package/dist/module/user/service/login.service.js +1 -1
  105. package/dist/module/user/service/login.service.js.map +1 -1
  106. package/dist/module/user/service/role.service.js +4 -4
  107. package/dist/module/user/service/user-session.service.js +4 -4
  108. package/dist/module/user/service/user-session.service.js.map +1 -1
  109. package/dist/module/workflow/entity/action-category.entity.d.ts +1 -1
  110. package/dist/module/workflow/entity/action-category.entity.js +1 -1
  111. package/dist/module/workflow/entity/action-data.entity.js +1 -1
  112. package/dist/module/workflow/entity/action-data.entity.js.map +1 -1
  113. package/dist/module/workflow/entity/action.entity.d.ts +0 -1
  114. package/dist/module/workflow/entity/action.entity.js +1 -5
  115. package/dist/module/workflow/entity/action.entity.js.map +1 -1
  116. package/dist/module/workflow/entity/comm-template.entity.js +1 -1
  117. package/dist/module/workflow/entity/comm-template.entity.js.map +1 -1
  118. package/dist/module/workflow/entity/template-attach-mapper.entity.js +1 -1
  119. package/dist/module/workflow/entity/template-attach-mapper.entity.js.map +1 -1
  120. package/dist/module/workflow/repository/action-data.repository.js +4 -5
  121. package/dist/module/workflow/repository/action-data.repository.js.map +1 -1
  122. package/dist/module/workflow/repository/action.repository.js +21 -21
  123. package/dist/module/workflow/repository/action.repository.js.map +1 -1
  124. package/dist/module/workflow/repository/comm-template.repository.js +7 -7
  125. package/dist/module/workflow/repository/comm-template.repository.js.map +1 -1
  126. package/dist/module/workflow/repository/form-master.repository.js +3 -3
  127. package/dist/module/workflow/repository/form-master.repository.js.map +1 -1
  128. package/dist/module/workflow/repository/stage-group.repository.js +23 -23
  129. package/dist/module/workflow/repository/stage-movement.repository.js +17 -17
  130. package/dist/module/workflow/repository/stage-movement.repository.js.map +1 -1
  131. package/dist/module/workflow/repository/stage.repository.js +8 -8
  132. package/dist/module/workflow/repository/task.repository.d.ts +1 -3
  133. package/dist/module/workflow/repository/task.repository.js +5 -10
  134. package/dist/module/workflow/repository/task.repository.js.map +1 -1
  135. package/dist/module/workflow/service/action-template-mapping.service.js +22 -22
  136. package/dist/module/workflow/service/action.service.js +13 -13
  137. package/dist/module/workflow/service/action.service.js.map +1 -1
  138. package/dist/module/workflow/service/entity-modification.service.js +6 -6
  139. package/dist/module/workflow/service/populate-workflow.service.js +8 -8
  140. package/dist/module/workflow/service/populate-workflow.service.js.map +1 -1
  141. package/dist/module/workflow/service/stage-group.service.js +6 -6
  142. package/dist/module/workflow/service/stage-group.service.js.map +1 -1
  143. package/dist/module/workflow/service/stage.service.js +4 -4
  144. package/dist/module/workflow/service/stage.service.js.map +1 -1
  145. package/dist/module/workflow/service/task.service.js +54 -68
  146. package/dist/module/workflow/service/task.service.js.map +1 -1
  147. package/dist/module/workflow/service/workflow-list-master.service.js +16 -16
  148. package/dist/module/workflow/service/workflow-list-master.service.js.map +1 -1
  149. package/dist/module/workflow/service/workflow-meta.service.js +51 -53
  150. package/dist/module/workflow/service/workflow-meta.service.js.map +1 -1
  151. package/dist/module/workflow/service/workflow.service.js +5 -5
  152. package/dist/module/workflow/service/workflow.service.js.map +1 -1
  153. package/dist/module/workflow-automation/controller/workflow-automation.controller.d.ts +0 -6
  154. package/dist/module/workflow-automation/controller/workflow-automation.controller.js +0 -16
  155. package/dist/module/workflow-automation/controller/workflow-automation.controller.js.map +1 -1
  156. package/dist/module/workflow-automation/entity/workflow-automation-action.entity.d.ts +1 -1
  157. package/dist/module/workflow-automation/entity/workflow-automation-action.entity.js +1 -1
  158. package/dist/module/workflow-automation/entity/workflow-automation.entity.d.ts +0 -2
  159. package/dist/module/workflow-automation/entity/workflow-automation.entity.js +0 -8
  160. package/dist/module/workflow-automation/entity/workflow-automation.entity.js.map +1 -1
  161. package/dist/module/workflow-automation/service/workflow-automation-engine.service.d.ts +1 -1
  162. package/dist/module/workflow-automation/service/workflow-automation-engine.service.js +1 -1
  163. package/dist/module/workflow-automation/service/workflow-automation-engine.service.js.map +1 -1
  164. package/dist/module/workflow-automation/service/workflow-automation.service.d.ts +1 -13
  165. package/dist/module/workflow-automation/service/workflow-automation.service.js +6 -115
  166. package/dist/module/workflow-automation/service/workflow-automation.service.js.map +1 -1
  167. package/dist/module/workflow-automation/workflow-automation.module.js +1 -14
  168. package/dist/module/workflow-automation/workflow-automation.module.js.map +1 -1
  169. package/dist/table.config.js +1 -5
  170. package/dist/table.config.js.map +1 -1
  171. package/dist/tsconfig.build.tsbuildinfo +1 -1
  172. package/dist/utils/service/loggingUtil.service.d.ts +2 -9
  173. package/dist/utils/service/loggingUtil.service.js +14 -65
  174. package/dist/utils/service/loggingUtil.service.js.map +1 -1
  175. package/dist/utils/service/reflection-helper.service.js +3 -3
  176. package/dist/utils/service/reflection-helper.service.js.map +1 -1
  177. package/dist/utils/utils.module.js +0 -2
  178. package/dist/utils/utils.module.js.map +1 -1
  179. package/docs/modules/event-driven-integration-design.md +91 -91
  180. package/docs/modules/integration.md +250 -250
  181. package/eslint.config.mjs +34 -34
  182. package/nest-cli.json +14 -14
  183. package/package.json +120 -124
  184. package/server.log +850 -0
  185. package/src/app.controller.ts +12 -12
  186. package/src/app.module.ts +52 -66
  187. package/src/app.service.ts +8 -8
  188. package/src/config/config.module.ts +17 -18
  189. package/src/config/database.config.ts +48 -23
  190. package/src/constant/global.constant.ts +67 -67
  191. package/src/core.module.ts +81 -88
  192. package/src/decorators/roles.decorator.ts +7 -7
  193. package/src/dtos/response.dto.ts +6 -6
  194. package/src/dtos/response.ts +5 -5
  195. package/src/index.ts +1 -1
  196. package/src/module/auth/auth.module.ts +49 -49
  197. package/src/module/auth/controller/auth.controller.ts +28 -28
  198. package/src/module/auth/guards/google-auth.guard.ts +9 -9
  199. package/src/module/auth/guards/jwt.guard.ts +22 -22
  200. package/src/module/auth/guards/role.guard.ts +68 -68
  201. package/src/module/auth/services/auth.service.ts +50 -50
  202. package/src/module/auth/services/jwt.service.ts +11 -11
  203. package/src/module/auth/strategies/google.strategy.ts +54 -54
  204. package/src/module/auth/strategies/jwt.strategy.ts +58 -58
  205. package/src/module/auth/strategies/local.strategy.ts +13 -13
  206. package/src/module/dashboard/controller/dashboard.controller.ts +36 -36
  207. package/src/module/dashboard/dashboard.module.ts +21 -21
  208. package/src/module/dashboard/entity/dashboard_page_data.entity.ts +27 -27
  209. package/src/module/dashboard/entity/widget_master.entity.ts +18 -18
  210. package/src/module/dashboard/repository/dashboard.repository.ts +42 -42
  211. package/src/module/dashboard/service/dashboard.service.ts +73 -73
  212. package/src/module/dev/dev.module.ts +12 -12
  213. package/src/module/dev/service/dev.service.ts +7 -7
  214. package/src/module/enterprise/controller/organization.controller.ts +36 -36
  215. package/src/module/enterprise/enterprise.module.ts +30 -30
  216. package/src/module/enterprise/entity/enterprise.entity.ts +37 -37
  217. package/src/module/enterprise/entity/organization-app-mapping.entity.ts +13 -13
  218. package/src/module/enterprise/entity/organization.entity.ts +92 -92
  219. package/src/module/enterprise/repository/enterprise.repository.ts +31 -31
  220. package/src/module/enterprise/repository/organization.repository.ts +26 -26
  221. package/src/module/enterprise/repository/school.repository.ts +278 -278
  222. package/src/module/enterprise/service/brand.service.ts +5 -5
  223. package/src/module/enterprise/service/enterprise.service.ts +16 -16
  224. package/src/module/enterprise/service/organization-app-mapping.service.ts +4 -4
  225. package/src/module/enterprise/service/organization.service.ts +145 -145
  226. package/src/module/filter/controller/filter.controller.ts +84 -84
  227. package/src/module/filter/dto/filter-request.dto.ts +38 -38
  228. package/src/module/filter/entity/saved-filter-detail.entity.ts +41 -41
  229. package/src/module/filter/entity/saved-filter-master.entity.ts +23 -23
  230. package/src/module/filter/filter.module.ts +31 -31
  231. package/src/module/filter/repository/saved-filter.repository.ts +168 -168
  232. package/src/module/filter/service/filter-evaluator.service.ts +86 -86
  233. package/src/module/filter/service/filter.service.ts +1053 -1005
  234. package/src/module/filter/service/saved-filter.service.ts +170 -170
  235. package/src/module/ics/controller/ics.controller.ts +21 -21
  236. package/src/module/ics/dto/ics.dto.ts +55 -55
  237. package/src/module/ics/ics.module.ts +13 -13
  238. package/src/module/ics/service/ics.service.ts +57 -57
  239. package/src/module/integration/controller/calender-event.controller.ts +31 -31
  240. package/src/module/integration/controller/integration.controller.ts +662 -662
  241. package/src/module/integration/controller/wrapper.controller.ts +37 -37
  242. package/src/module/integration/dto/create-config.dto.ts +526 -526
  243. package/src/module/integration/entity/integration-config.entity.ts +112 -112
  244. package/src/module/integration/entity/integration-entity-mapper.entity.ts +14 -14
  245. package/src/module/integration/entity/integration-source.entity.ts +17 -17
  246. package/src/module/integration/entity/user-integration.entity.ts +71 -71
  247. package/src/module/integration/examples/usage.example.ts +338 -338
  248. package/src/module/integration/factories/base.factory.ts +7 -7
  249. package/src/module/integration/factories/email.factory.ts +49 -49
  250. package/src/module/integration/factories/integration.factory.ts +121 -121
  251. package/src/module/integration/factories/sms.factory.ts +51 -51
  252. package/src/module/integration/factories/telephone.factory.ts +41 -41
  253. package/src/module/integration/factories/whatsapp.factory.ts +56 -56
  254. package/src/module/integration/integration.module.ts +110 -110
  255. package/src/module/integration/service/calendar-event.service.ts +118 -118
  256. package/src/module/integration/service/integration-entity-mapper.service.ts +17 -17
  257. package/src/module/integration/service/integration-queue.service.ts +229 -229
  258. package/src/module/integration/service/integration.service.ts +2633 -2633
  259. package/src/module/integration/service/oauth.service.ts +224 -224
  260. package/src/module/integration/service/wrapper.service.ts +494 -700
  261. package/src/module/integration/strategies/email/gmail-api.strategy.ts +280 -280
  262. package/src/module/integration/strategies/email/outlook-api.strategy.ts +44 -44
  263. package/src/module/integration/strategies/email/outlook.strategy.ts +64 -64
  264. package/src/module/integration/strategies/email/sendgrid-api.strategy.ts +260 -260
  265. package/src/module/integration/strategies/integration.strategy.ts +97 -97
  266. package/src/module/integration/strategies/sms/gupshup-sms.strategy.ts +146 -146
  267. package/src/module/integration/strategies/sms/msg91-sms.strategy.ts +164 -164
  268. package/src/module/integration/strategies/sms/tubelight-sms.strategy.ts +163 -163
  269. package/src/module/integration/strategies/telephone/ozonetel-voice.strategy.ts +238 -238
  270. package/src/module/integration/strategies/telephone/tubelight-voice.strategy.ts +210 -210
  271. package/src/module/integration/strategies/whatsapp/gupshup-whatsapp.strategy.ts +359 -359
  272. package/src/module/integration/strategies/whatsapp/tubelight-whatsapp.strategy.ts +372 -372
  273. package/src/module/integration/strategies/whatsapp/whatsapp-cloud.strategy.ts +403 -403
  274. package/src/module/integration/strategies/whatsapp/whatsapp.strategy.ts +57 -57
  275. package/src/module/layout/controller/layout.controller.ts +47 -47
  276. package/src/module/layout/entity/header-items.entity.ts +28 -28
  277. package/src/module/layout/entity/header-section.entity.ts +19 -19
  278. package/src/module/layout/layout.module.ts +21 -21
  279. package/src/module/layout/repository/header-items.repository.ts +18 -18
  280. package/src/module/layout/repository/header-section.repository.ts +22 -22
  281. package/src/module/layout/service/header-section.service.ts +25 -25
  282. package/src/module/layout_preference/controller/layout_preference.controller.ts +73 -73
  283. package/src/module/layout_preference/entity/layout_preference.entity.ts +28 -28
  284. package/src/module/layout_preference/layout_preference.module.ts +22 -22
  285. package/src/module/layout_preference/repository/layout_preference.repository.ts +65 -65
  286. package/src/module/layout_preference/service/layout_preference.service.ts +191 -191
  287. package/src/module/lead/controller/lead.controller.ts +30 -30
  288. package/src/module/lead/lead.module.ts +14 -14
  289. package/src/module/lead/repository/lead.repository.ts +41 -41
  290. package/src/module/lead/service/lead.service.ts +54 -54
  291. package/src/module/listmaster/controller/list-master.controller.ts +230 -230
  292. package/src/module/listmaster/entity/list-master-items.entity.ts +43 -43
  293. package/src/module/listmaster/entity/list-master.entity.ts +33 -33
  294. package/src/module/listmaster/listmaster.module.ts +46 -46
  295. package/src/module/listmaster/repository/list-master-items.repository.ts +169 -169
  296. package/src/module/listmaster/repository/list-master.repository.ts +46 -46
  297. package/src/module/listmaster/service/list-master-engine.ts +19 -19
  298. package/src/module/listmaster/service/list-master-extension.interface.ts +4 -4
  299. package/src/module/listmaster/service/list-master-item.service.ts +292 -292
  300. package/src/module/listmaster/service/list-master-registry.ts +15 -15
  301. package/src/module/listmaster/service/list-master.service.ts +535 -535
  302. package/src/module/mapper/controller/field-mapper.controller.ts +76 -76
  303. package/src/module/mapper/controller/mapper.controller.ts +20 -20
  304. package/src/module/mapper/dto/field-mapper.dto.ts +14 -14
  305. package/src/module/mapper/entity/field-lovs.entity.ts +19 -19
  306. package/src/module/mapper/entity/field-mapper.entity.ts +53 -53
  307. package/src/module/mapper/entity/mapper.entity.ts +16 -16
  308. package/src/module/mapper/mapper.module.ts +34 -34
  309. package/src/module/mapper/repository/field-lovs.repository.ts +35 -35
  310. package/src/module/mapper/repository/field-mapper.repository.ts +42 -42
  311. package/src/module/mapper/repository/mapper.repository.ts +15 -15
  312. package/src/module/mapper/service/field-mapper.service.ts +266 -271
  313. package/src/module/mapper/service/mapper.service.ts +79 -79
  314. package/src/module/master/controller/master.controller.ts +74 -74
  315. package/src/module/master/service/master.service.ts +483 -483
  316. package/src/module/meta/controller/app-master.controller.ts +38 -38
  317. package/src/module/meta/controller/attribute-master.controller.ts +66 -74
  318. package/src/module/meta/controller/entity-dynamic.controller.ts +125 -125
  319. package/src/module/meta/controller/entity-master.controller.ts +28 -28
  320. package/src/module/meta/controller/entity-relation.controller.ts +36 -36
  321. package/src/module/meta/controller/entity.controller.ts +392 -392
  322. package/src/module/meta/controller/entity.public.controller.ts +75 -75
  323. package/src/module/meta/controller/media.controller.ts +107 -107
  324. package/src/module/meta/controller/meta.controller.ts +96 -96
  325. package/src/module/meta/controller/view-master.controller.ts +86 -86
  326. package/src/module/meta/dto/entity-list-data.dto.ts +6 -6
  327. package/src/module/meta/dto/entity-tab.dto.ts +4 -4
  328. package/src/module/meta/dto/entity-table.dto.ts +9 -9
  329. package/src/module/meta/entity/app-master.entity.ts +34 -34
  330. package/src/module/meta/entity/attribute-master.entity.ts +89 -89
  331. package/src/module/meta/entity/base-entity.entity.ts +75 -75
  332. package/src/module/meta/entity/entity-master.entity.ts +85 -85
  333. package/src/module/meta/entity/entity-relation-data.entity.ts +29 -29
  334. package/src/module/meta/entity/entity-relation.entity.ts +23 -23
  335. package/src/module/meta/entity/entity-table-column.entity.ts +61 -61
  336. package/src/module/meta/entity/entity-table.entity.ts +50 -50
  337. package/src/module/meta/entity/media-data.entity.ts +32 -32
  338. package/src/module/meta/entity/preference.entity.ts +62 -62
  339. package/src/module/meta/entity/view-master.entity.ts +41 -41
  340. package/src/module/meta/entity.module.ts +158 -166
  341. package/src/module/meta/repository/app-master.repository.ts +20 -20
  342. package/src/module/meta/repository/attribute-master.repository.ts +118 -118
  343. package/src/module/meta/repository/entity-master.repository.ts +69 -69
  344. package/src/module/meta/repository/entity-table-column.repository.ts +39 -39
  345. package/src/module/meta/repository/entity-table.repository.ts +53 -53
  346. package/src/module/meta/repository/media-data.repository.ts +50 -50
  347. package/src/module/meta/repository/preference.repository.ts +20 -20
  348. package/src/module/meta/repository/user-app-mapping.repository.ts +28 -28
  349. package/src/module/meta/repository/view-master.repository.ts +42 -42
  350. package/src/module/meta/service/app-master.service.ts +37 -37
  351. package/src/module/meta/service/attribute-master.service.ts +126 -126
  352. package/src/module/meta/service/common.service.ts +9 -9
  353. package/src/module/meta/service/entity-dynamic.service.ts +819 -819
  354. package/src/module/meta/service/entity-list.service.ts +205 -205
  355. package/src/module/meta/service/entity-master.service.ts +169 -169
  356. package/src/module/meta/service/entity-realation-data.service.ts +9 -9
  357. package/src/module/meta/service/entity-relation.service.ts +69 -69
  358. package/src/module/meta/service/entity-service-impl.service.ts +525 -525
  359. package/src/module/meta/service/entity-table-column.service.ts +39 -39
  360. package/src/module/meta/service/entity-table.service.ts +150 -150
  361. package/src/module/meta/service/entity-validation.service.ts +187 -187
  362. package/src/module/meta/service/entity.service.ts +67 -67
  363. package/src/module/meta/service/field-group.service.ts +103 -103
  364. package/src/module/meta/service/media-data.service.ts +507 -507
  365. package/src/module/meta/service/populate-meta.service.ts +193 -193
  366. package/src/module/meta/service/preference.service.ts +16 -16
  367. package/src/module/meta/service/resolver.service.ts +267 -267
  368. package/src/module/meta/service/section-master.service.ts +104 -104
  369. package/src/module/meta/service/update-form-json.service.ts +22 -22
  370. package/src/module/meta/service/user-app-mapping.service.ts +17 -17
  371. package/src/module/meta/service/view-master.service.ts +127 -127
  372. package/src/module/microservice-client/microservice-clients.module.ts +13 -13
  373. package/src/module/microservice-client/service/microservice-client-factory.ts +37 -37
  374. package/src/module/microservice-client/service/microservice-clients.ts +4 -4
  375. package/src/module/module/controller/menu.controller.ts +15 -15
  376. package/src/module/module/controller/module-access.controller.ts +134 -134
  377. package/src/module/module/entity/menu.entity.ts +43 -43
  378. package/src/module/module/entity/module-access.entity.ts +25 -25
  379. package/src/module/module/entity/module-action.entity.ts +17 -17
  380. package/src/module/module/entity/module.entity.ts +52 -52
  381. package/src/module/module/module.module.ts +42 -42
  382. package/src/module/module/repository/menu.repository.ts +184 -184
  383. package/src/module/module/repository/module-access.repository.ts +344 -344
  384. package/src/module/module/service/menu.service.ts +82 -82
  385. package/src/module/module/service/module-access.service.ts +207 -209
  386. package/src/module/notification/controller/notification.controller.ts +58 -58
  387. package/src/module/notification/controller/otp.controller.ts +117 -117
  388. package/src/module/notification/entity/notification.entity.ts +26 -26
  389. package/src/module/notification/entity/otp.entity.ts +28 -28
  390. package/src/module/notification/firebase-admin.config.ts +22 -22
  391. package/src/module/notification/notification.module.ts +69 -69
  392. package/src/module/notification/repository/otp.repository.ts +27 -27
  393. package/src/module/notification/service/email.service.ts +127 -127
  394. package/src/module/notification/service/notification.service.ts +160 -163
  395. package/src/module/notification/service/otp.service.ts +132 -132
  396. package/src/module/third-party-module/entity/third-party-api-registry.entity.ts +52 -52
  397. package/src/module/third-party-module/repository/third-party-api-registry.repository.ts +20 -20
  398. package/src/module/third-party-module/service/api-registry.service.ts +13 -13
  399. package/src/module/third-party-module/third-party.module.ts +12 -12
  400. package/src/module/user/controller/login.controller.ts +197 -197
  401. package/src/module/user/controller/user.controller.ts +40 -40
  402. package/src/module/user/dto/create-user.dto.ts +62 -62
  403. package/src/module/user/dto/update-user.dto.ts +4 -4
  404. package/src/module/user/entity/role.entity.ts +33 -33
  405. package/src/module/user/entity/user-role-mapping.entity.ts +38 -38
  406. package/src/module/user/entity/user-session.entity.ts +73 -73
  407. package/src/module/user/entity/user.entity.ts +59 -59
  408. package/src/module/user/repository/role.repository.ts +96 -96
  409. package/src/module/user/repository/user-role-mapping.repository.ts +126 -126
  410. package/src/module/user/repository/user.repository.ts +50 -50
  411. package/src/module/user/repository/userSession.repository.ts +33 -33
  412. package/src/module/user/service/login.service.ts +304 -304
  413. package/src/module/user/service/role.service.ts +189 -189
  414. package/src/module/user/service/user-role-mapping.service.ts +98 -98
  415. package/src/module/user/service/user-session.service.ts +168 -168
  416. package/src/module/user/service/user.service.ts +365 -365
  417. package/src/module/user/user.module.ts +65 -65
  418. package/src/module/workflow/controller/action-category.controller.ts +54 -54
  419. package/src/module/workflow/controller/action-resource-mapping.controller.ts +23 -23
  420. package/src/module/workflow/controller/action-template-mapping.controller.ts +35 -35
  421. package/src/module/workflow/controller/action.controller.ts +111 -111
  422. package/src/module/workflow/controller/activity-log.controller.ts +55 -55
  423. package/src/module/workflow/controller/comm-template.controller.ts +43 -43
  424. package/src/module/workflow/controller/entity-modification.controller.ts +35 -35
  425. package/src/module/workflow/controller/form-master.controller.ts +43 -43
  426. package/src/module/workflow/controller/stage-group.controller.ts +48 -48
  427. package/src/module/workflow/controller/stage.controller.ts +50 -50
  428. package/src/module/workflow/controller/task.controller.ts +77 -77
  429. package/src/module/workflow/controller/workflow-list-master.controller.ts +44 -44
  430. package/src/module/workflow/controller/workflow-meta.controller.ts +80 -80
  431. package/src/module/workflow/controller/workflow.controller.ts +67 -67
  432. package/src/module/workflow/entity/action-category.entity.ts +38 -38
  433. package/src/module/workflow/entity/action-data.entity.ts +55 -55
  434. package/src/module/workflow/entity/action-resources-mapping.entity.ts +29 -29
  435. package/src/module/workflow/entity/action-template-mapping.entity.ts +17 -17
  436. package/src/module/workflow/entity/action.entity.ts +50 -53
  437. package/src/module/workflow/entity/activity-log.entity.ts +43 -43
  438. package/src/module/workflow/entity/comm-template.entity.ts +43 -43
  439. package/src/module/workflow/entity/entity-modification.entity.ts +38 -38
  440. package/src/module/workflow/entity/form.entity.ts +25 -25
  441. package/src/module/workflow/entity/stage-action-mapping.entity.ts +17 -17
  442. package/src/module/workflow/entity/stage-group.entity.ts +23 -23
  443. package/src/module/workflow/entity/stage-movement-data.entity.ts +38 -38
  444. package/src/module/workflow/entity/stage.entity.ts +20 -20
  445. package/src/module/workflow/entity/task-data.entity.ts +88 -88
  446. package/src/module/workflow/entity/template-attach-mapper.entity.ts +30 -30
  447. package/src/module/workflow/entity/workflow-data.entity.ts +11 -11
  448. package/src/module/workflow/entity/workflow-level-mapping.entity.ts +18 -18
  449. package/src/module/workflow/entity/workflow.entity.ts +20 -20
  450. package/src/module/workflow/repository/action-category.repository.ts +79 -79
  451. package/src/module/workflow/repository/action-data.repository.ts +333 -334
  452. package/src/module/workflow/repository/action.repository.ts +323 -323
  453. package/src/module/workflow/repository/activity-log.repository.ts +148 -148
  454. package/src/module/workflow/repository/comm-template.repository.ts +149 -149
  455. package/src/module/workflow/repository/form-master.repository.ts +59 -59
  456. package/src/module/workflow/repository/stage-group.repository.ts +176 -176
  457. package/src/module/workflow/repository/stage-movement.repository.ts +244 -244
  458. package/src/module/workflow/repository/stage.repository.ts +172 -172
  459. package/src/module/workflow/repository/task.repository.ts +126 -134
  460. package/src/module/workflow/repository/workflow.repository.ts +42 -42
  461. package/src/module/workflow/service/action-category.service.ts +33 -33
  462. package/src/module/workflow/service/action-data.service.ts +62 -62
  463. package/src/module/workflow/service/action-resources-mapping.service.ts +10 -10
  464. package/src/module/workflow/service/action-template-mapping.service.ts +106 -106
  465. package/src/module/workflow/service/action.service.ts +279 -279
  466. package/src/module/workflow/service/activity-log.service.ts +107 -107
  467. package/src/module/workflow/service/comm-template.service.ts +180 -180
  468. package/src/module/workflow/service/entity-modification.service.ts +67 -67
  469. package/src/module/workflow/service/form-master.service.ts +35 -35
  470. package/src/module/workflow/service/populate-workflow.service.ts +303 -303
  471. package/src/module/workflow/service/stage-action-mapping.service.ts +5 -5
  472. package/src/module/workflow/service/stage-group.service.ts +319 -319
  473. package/src/module/workflow/service/stage.service.ts +199 -199
  474. package/src/module/workflow/service/task.service.ts +560 -569
  475. package/src/module/workflow/service/workflow-list-master.service.ts +60 -60
  476. package/src/module/workflow/service/workflow-meta.service.ts +640 -654
  477. package/src/module/workflow/service/workflow.service.ts +205 -205
  478. package/src/module/workflow/workflow.module.ts +176 -176
  479. package/src/module/workflow-automation/controller/workflow-automation.controller.ts +21 -43
  480. package/src/module/workflow-automation/entity/workflow-automation-action.entity.ts +26 -26
  481. package/src/module/workflow-automation/entity/workflow-automation.entity.ts +35 -40
  482. package/src/module/workflow-automation/interface/action.decorator.ts +7 -7
  483. package/src/module/workflow-automation/interface/action.interface.ts +5 -5
  484. package/src/module/workflow-automation/service/action-registery.service.ts +35 -35
  485. package/src/module/workflow-automation/service/workflow-automation-engine.service.ts +214 -214
  486. package/src/module/workflow-automation/service/workflow-automation.service.ts +347 -508
  487. package/src/module/workflow-automation/workflow-automation.module.ts +34 -47
  488. package/src/resources/dev.properties.yaml +31 -30
  489. package/src/resources/local.properties.yaml +27 -27
  490. package/src/resources/properties.module.ts +12 -12
  491. package/src/resources/properties.yaml.ts +11 -11
  492. package/src/resources/uat.properties.yaml +31 -31
  493. package/src/table.config.ts +126 -130
  494. package/src/utils/dto/excel-data.dto.ts +14 -14
  495. package/src/utils/dto/excelsheet-data.dto.ts +5 -5
  496. package/src/utils/service/base64util.service.ts +18 -18
  497. package/src/utils/service/clockIDGenUtil.service.ts +21 -21
  498. package/src/utils/service/codeGenerator.service.ts +22 -22
  499. package/src/utils/service/dateUtil.service.ts +17 -17
  500. package/src/utils/service/encryptUtil.service.ts +97 -97
  501. package/src/utils/service/excel-helper.service.ts +72 -72
  502. package/src/utils/service/excelUtil.service.ts +15 -15
  503. package/src/utils/service/file-util.service.ts +11 -11
  504. package/src/utils/service/json-util.service.ts +23 -23
  505. package/src/utils/service/loggingUtil.service.ts +34 -88
  506. package/src/utils/service/reflection-helper.service.ts +62 -62
  507. package/src/utils/service/wbsCodeGen.service.ts +8 -8
  508. package/src/utils/utils.module.ts +25 -27
  509. package/tsconfig.build.json +4 -4
  510. package/tsconfig.json +24 -24
  511. package/dist/config/bull.config.d.ts +0 -10
  512. package/dist/config/bull.config.js +0 -66
  513. package/dist/config/bull.config.js.map +0 -1
  514. package/dist/module/entity_json/controller/entity_json.controller.d.ts +0 -11
  515. package/dist/module/entity_json/controller/entity_json.controller.js +0 -56
  516. package/dist/module/entity_json/controller/entity_json.controller.js.map +0 -1
  517. package/dist/module/entity_json/entity_json.module.d.ts +0 -2
  518. package/dist/module/entity_json/entity_json.module.js +0 -26
  519. package/dist/module/entity_json/entity_json.module.js.map +0 -1
  520. package/dist/module/entity_json/service/entity_json.service.d.ts +0 -8
  521. package/dist/module/entity_json/service/entity_json.service.js +0 -100
  522. package/dist/module/entity_json/service/entity_json.service.js.map +0 -1
  523. package/dist/module/linked_attributes/controller/linked_attributes.controller.d.ts +0 -5
  524. package/dist/module/linked_attributes/controller/linked_attributes.controller.js +0 -29
  525. package/dist/module/linked_attributes/controller/linked_attributes.controller.js.map +0 -1
  526. package/dist/module/linked_attributes/entity/linked_attribute.entity.d.ts +0 -9
  527. package/dist/module/linked_attributes/entity/linked_attribute.entity.js +0 -70
  528. package/dist/module/linked_attributes/entity/linked_attribute.entity.js.map +0 -1
  529. package/dist/module/linked_attributes/linked_attributes.module.d.ts +0 -2
  530. package/dist/module/linked_attributes/linked_attributes.module.js +0 -29
  531. package/dist/module/linked_attributes/linked_attributes.module.js.map +0 -1
  532. package/dist/module/linked_attributes/repository/linked_attribute.repository.d.ts +0 -6
  533. package/dist/module/linked_attributes/repository/linked_attribute.repository.js +0 -31
  534. package/dist/module/linked_attributes/repository/linked_attribute.repository.js.map +0 -1
  535. package/dist/module/linked_attributes/service/linked_attributes.service.d.ts +0 -5
  536. package/dist/module/linked_attributes/service/linked_attributes.service.js +0 -34
  537. package/dist/module/linked_attributes/service/linked_attributes.service.js.map +0 -1
  538. package/dist/module/meta/repository/entity-attribute-update.repository.d.ts +0 -6
  539. package/dist/module/meta/repository/entity-attribute-update.repository.js +0 -44
  540. package/dist/module/meta/repository/entity-attribute-update.repository.js.map +0 -1
  541. package/dist/module/meta/service/entity-attribute-update.service.d.ts +0 -7
  542. package/dist/module/meta/service/entity-attribute-update.service.js +0 -36
  543. package/dist/module/meta/service/entity-attribute-update.service.js.map +0 -1
  544. package/dist/module/workflow-automation/service/schedule-handler.service.d.ts +0 -16
  545. package/dist/module/workflow-automation/service/schedule-handler.service.js +0 -109
  546. package/dist/module/workflow-automation/service/schedule-handler.service.js.map +0 -1
  547. package/dist/module/workflow-schedule/constants/schedule.constants.d.ts +0 -27
  548. package/dist/module/workflow-schedule/constants/schedule.constants.js +0 -31
  549. package/dist/module/workflow-schedule/constants/schedule.constants.js.map +0 -1
  550. package/dist/module/workflow-schedule/controller/workflow-schedule.controller.d.ts +0 -83
  551. package/dist/module/workflow-schedule/controller/workflow-schedule.controller.js +0 -220
  552. package/dist/module/workflow-schedule/controller/workflow-schedule.controller.js.map +0 -1
  553. package/dist/module/workflow-schedule/dto/create-schedule.dto.d.ts +0 -32
  554. package/dist/module/workflow-schedule/dto/create-schedule.dto.js +0 -163
  555. package/dist/module/workflow-schedule/dto/create-schedule.dto.js.map +0 -1
  556. package/dist/module/workflow-schedule/dto/get-execution-logs.dto.d.ts +0 -35
  557. package/dist/module/workflow-schedule/dto/get-execution-logs.dto.js +0 -124
  558. package/dist/module/workflow-schedule/dto/get-execution-logs.dto.js.map +0 -1
  559. package/dist/module/workflow-schedule/dto/update-schedule.dto.d.ts +0 -19
  560. package/dist/module/workflow-schedule/dto/update-schedule.dto.js +0 -106
  561. package/dist/module/workflow-schedule/dto/update-schedule.dto.js.map +0 -1
  562. package/dist/module/workflow-schedule/entities/scheduled-workflow.entity.d.ts +0 -30
  563. package/dist/module/workflow-schedule/entities/scheduled-workflow.entity.js +0 -113
  564. package/dist/module/workflow-schedule/entities/scheduled-workflow.entity.js.map +0 -1
  565. package/dist/module/workflow-schedule/entities/workflow-execution-log.entity.d.ts +0 -34
  566. package/dist/module/workflow-schedule/entities/workflow-execution-log.entity.js +0 -118
  567. package/dist/module/workflow-schedule/entities/workflow-execution-log.entity.js.map +0 -1
  568. package/dist/module/workflow-schedule/interfaces/schedule-job-data.interface.d.ts +0 -44
  569. package/dist/module/workflow-schedule/interfaces/schedule-job-data.interface.js +0 -3
  570. package/dist/module/workflow-schedule/interfaces/schedule-job-data.interface.js.map +0 -1
  571. package/dist/module/workflow-schedule/interfaces/workflow-schedule-options.interface.d.ts +0 -3
  572. package/dist/module/workflow-schedule/interfaces/workflow-schedule-options.interface.js +0 -3
  573. package/dist/module/workflow-schedule/interfaces/workflow-schedule-options.interface.js.map +0 -1
  574. package/dist/module/workflow-schedule/processors/schedule.processor.d.ts +0 -31
  575. package/dist/module/workflow-schedule/processors/schedule.processor.js +0 -409
  576. package/dist/module/workflow-schedule/processors/schedule.processor.js.map +0 -1
  577. package/dist/module/workflow-schedule/service/workflow-schedule.service.d.ts +0 -44
  578. package/dist/module/workflow-schedule/service/workflow-schedule.service.js +0 -434
  579. package/dist/module/workflow-schedule/service/workflow-schedule.service.js.map +0 -1
  580. package/dist/module/workflow-schedule/workflow-schedule.module.d.ts +0 -5
  581. package/dist/module/workflow-schedule/workflow-schedule.module.js +0 -52
  582. package/dist/module/workflow-schedule/workflow-schedule.module.js.map +0 -1
  583. package/src/config/bull.config.ts +0 -69
  584. package/src/module/entity_json/controller/entity_json.controller.ts +0 -45
  585. package/src/module/entity_json/entity_json.module.ts +0 -13
  586. package/src/module/entity_json/service/entity_json.service.ts +0 -134
  587. package/src/module/linked_attributes/controller/linked_attributes.controller.ts +0 -10
  588. package/src/module/linked_attributes/entity/linked_attribute.entity.ts +0 -48
  589. package/src/module/linked_attributes/linked_attributes.module.ts +0 -16
  590. package/src/module/linked_attributes/repository/linked_attribute.repository.ts +0 -12
  591. package/src/module/linked_attributes/service/linked_attributes.service.ts +0 -22
  592. package/src/module/meta/repository/entity-attribute-update.repository.ts +0 -44
  593. package/src/module/meta/service/entity-attribute-update.service.ts +0 -29
  594. package/src/module/workflow-automation/SCHEDULING_GUIDE.md +0 -145
  595. package/src/module/workflow-automation/service/schedule-handler.service.ts +0 -150
  596. package/src/module/workflow-schedule/INSTALLATION.md +0 -244
  597. package/src/module/workflow-schedule/MULTI_PROJECT_GUIDE.md +0 -196
  598. package/src/module/workflow-schedule/README.md +0 -422
  599. package/src/module/workflow-schedule/constants/schedule.constants.ts +0 -48
  600. package/src/module/workflow-schedule/controller/workflow-schedule.controller.ts +0 -255
  601. package/src/module/workflow-schedule/docs/CLAUDE_CODE_GUIDE.md +0 -510
  602. package/src/module/workflow-schedule/docs/CLAUDE_CODE_PROMPT.md +0 -362
  603. package/src/module/workflow-schedule/docs/RUN_CLAUDE_CODE.sh +0 -68
  604. package/src/module/workflow-schedule/dto/create-schedule.dto.ts +0 -147
  605. package/src/module/workflow-schedule/dto/get-execution-logs.dto.ts +0 -119
  606. package/src/module/workflow-schedule/dto/update-schedule.dto.ts +0 -96
  607. package/src/module/workflow-schedule/entities/scheduled-workflow.entity.ts +0 -148
  608. package/src/module/workflow-schedule/entities/workflow-execution-log.entity.ts +0 -154
  609. package/src/module/workflow-schedule/interfaces/schedule-job-data.interface.ts +0 -53
  610. package/src/module/workflow-schedule/interfaces/workflow-schedule-options.interface.ts +0 -12
  611. package/src/module/workflow-schedule/processors/schedule.processor.ts +0 -584
  612. package/src/module/workflow-schedule/service/workflow-schedule.service.ts +0 -600
  613. package/src/module/workflow-schedule/workflow-schedule.module.ts +0 -67
@@ -1,365 +1,365 @@
1
- import { RoleService } from './role.service';
2
- import {
3
- BadRequestException,
4
- ForbiddenException,
5
- Inject,
6
- Injectable,
7
- } from '@nestjs/common';
8
- import { EntityServiceImpl } from '../../meta/service/entity-service-impl.service';
9
- import { UserData } from '../entity/user.entity';
10
- import { BaseEntity } from '../../meta/entity/base-entity.entity';
11
- import { UserRepository } from '../repository/user.repository';
12
- import { EncryptUtilService } from '../../../utils/service/encryptUtil.service';
13
- import { ClockIDGenService } from '../../../utils/service/clockIDGenUtil.service';
14
- import {
15
- ENTITYTYPE_ROLE,
16
- STATUS_ACTIVE,
17
- INVITATION_STATUS_SENT,
18
- } from '../../../constant/global.constant';
19
- import { CreateUserDto } from '../dto/create-user.dto';
20
- import { UserRoleMappingService } from './user-role-mapping.service';
21
- import { UserRoleMapping } from '../entity/user-role-mapping.entity';
22
- import { EntityManager, Repository } from 'typeorm';
23
- import { UpdateUserDto } from '../dto/update-user.dto';
24
- import { ConfigService } from '@nestjs/config';
25
- // import { UserAppMappingService } from 'src/module/meta/service/user-app-mapping.service';
26
- import { ServiceResult } from 'src/dtos/response.dto';
27
- import { ListMasterService } from 'src/module/listmaster/service/list-master.service';
28
- import { OrganizationRepository } from 'src/module/enterprise/repository/organization.repository';
29
- import { InjectRepository } from '@nestjs/typeorm';
30
- import { Action } from 'src/module/workflow-automation/interface/action.interface';
31
- import { ActionHandler } from 'src/module/workflow-automation/interface/action.decorator';
32
-
33
- @Injectable()
34
- @ActionHandler('User')
35
- export class UserService extends EntityServiceImpl implements Action {
36
- constructor(
37
- private userRepository: UserRepository,
38
- private userRoleMappingService: UserRoleMappingService,
39
- private readonly clockIDGenService: ClockIDGenService,
40
- private configService: ConfigService,
41
- private readonly organizationRepository: OrganizationRepository,
42
- // private readonly userAppMappingService: UserAppMappingService,
43
- @Inject('RoleService') private readonly roleService: RoleService,
44
- @Inject('ListMasterService')
45
- private readonly listMasterService: ListMasterService,
46
- ) {
47
- super();
48
- }
49
-
50
- masterKey = this.configService.get('MASTER_KEY') || '';
51
- masterIv = this.configService.get('MASTER_IV') || '';
52
-
53
- async createEntity(
54
- entityData: BaseEntity,
55
- loggedInUser: UserData | null,
56
- manager?: EntityManager,
57
- ): Promise<ServiceResult<BaseEntity>> {
58
- const userData = entityData as CreateUserDto;
59
-
60
- let existingUser = await this.userRepository.findByEmailId(
61
- userData.email_id,
62
- loggedInUser?.organization_id,
63
- );
64
- if (existingUser) {
65
- return { success: false, error: 'User with this email already exists' };
66
- }
67
-
68
- existingUser = await this.userRepository.findByMobile(
69
- userData.mobile,
70
- loggedInUser?.organization_id,
71
- );
72
- if (existingUser) {
73
- return { success: false, error: 'User with this mobile already exists' };
74
- }
75
-
76
- const resolveStatus = await this.listMasterService.getResolvedListCode(
77
- STATUS_ACTIVE,
78
- loggedInUser?.organization_id || 0,
79
- );
80
-
81
- const resolvedInvitationStatus =
82
- await this.listMasterService.getResolvedListCode(
83
- INVITATION_STATUS_SENT,
84
- loggedInUser?.organization_id || 0,
85
- );
86
-
87
- userData.name =
88
- (userData.first_name || '') + ' ' + (userData.last_name || '');
89
- userData.password = EncryptUtilService.encryptGCM(
90
- userData.password || 'Admin@123',
91
- this.masterKey,
92
- this.masterIv,
93
- );
94
- userData.is_firstlogin = 1;
95
- userData.roles = [];
96
- userData.invitation_status = resolvedInvitationStatus.id;
97
- userData.status = resolveStatus.id || 'ACTIVE';
98
-
99
- const savedData = await super.createEntity(userData, loggedInUser);
100
-
101
- const insertPromises: Promise<UserRoleMapping | void | null | undefined>[] =
102
- [];
103
-
104
- for (const entry of userData.access || []) {
105
- const { level_type, level_ids, app_code, role_id } = entry;
106
-
107
- if (
108
- !level_type ||
109
- !Array.isArray(level_ids) ||
110
- !level_ids.length ||
111
- !app_code ||
112
- !role_id
113
- ) {
114
- return { success: false, error: 'Invalid access level entry' };
115
- }
116
-
117
- for (const levelId of level_ids) {
118
- const userRoleMapping = new UserRoleMapping(savedData.id, role_id);
119
- userRoleMapping.level_type = level_type;
120
- userRoleMapping.level_id = String(levelId);
121
- userRoleMapping.appcode = app_code;
122
- userRoleMapping.organization_id = loggedInUser?.organization_id || 0;
123
- insertPromises.push(
124
- this.userRoleMappingService.assignUserRole(userRoleMapping),
125
- );
126
- }
127
- }
128
-
129
- try {
130
- if (insertPromises.length > 0) {
131
- await Promise.all(insertPromises);
132
- }
133
- } catch (error) {
134
- console.error('Error adding access levels:', error);
135
- return { success: false, error: 'Failed to add access levels' };
136
- }
137
-
138
- return { success: true, data: savedData };
139
- }
140
-
141
- name: string = 'UserService';
142
- async execute(payload: any): Promise<any> {
143
- console.log('payload', payload);
144
- }
145
-
146
- async getEntityData(
147
- entityType: string,
148
- id: number,
149
- loggedInUser?: UserData,
150
- ): Promise<BaseEntity | null> {
151
- const user = await this.userRepository.findById(id);
152
- if (user) {
153
- const userRoleMappings: UserRoleMapping[] | null =
154
- await this.userRoleMappingService.findByUserId(id);
155
- if (userRoleMappings) {
156
- const userDto = user as unknown as CreateUserDto;
157
- const roles: any[] = [];
158
- for (const i in userRoleMappings) {
159
- const userRoleMapping = userRoleMappings[i];
160
- const roleId = userRoleMapping.role_id;
161
- const role = await super.getEntityData(
162
- ENTITYTYPE_ROLE,
163
- roleId,
164
- loggedInUser,
165
- );
166
- roles.push(role);
167
- }
168
- userDto.roles = roles;
169
- }
170
- return user;
171
- }
172
- return null;
173
- }
174
-
175
- async updateEntity(
176
- entityData: BaseEntity,
177
- loggedInUserData: UserData,
178
- ): Promise<ServiceResult<BaseEntity>> {
179
- const userDto = entityData as UpdateUserDto;
180
-
181
- const existingUser = await this.userRepository.findById(entityData.id);
182
-
183
- if (!existingUser) {
184
- return { success: false, error: 'User not found' };
185
- }
186
-
187
- if (userDto.password) {
188
- const decryptedPassword = EncryptUtilService.decryptGCM(
189
- existingUser.password,
190
- this.masterKey,
191
- this.masterIv,
192
- );
193
-
194
- if (decryptedPassword === userDto.password) {
195
- return {
196
- success: false,
197
- error: 'New password cannot be the same as the current password',
198
- };
199
- }
200
-
201
- userDto.password = EncryptUtilService.encryptGCM(
202
- userDto.password,
203
- this.masterKey,
204
- this.masterIv,
205
- );
206
- }
207
-
208
- const updatedUserData = { ...userDto } as any;
209
- delete updatedUserData.access;
210
-
211
- const savedData = await super.updateEntity(
212
- updatedUserData,
213
- loggedInUserData,
214
- );
215
-
216
- // Handle updated access levels
217
- if (userDto.access && userDto.access.length > 0) {
218
- if (loggedInUserData.level_type == 'ORG') {
219
- await this.userRoleMappingService.deleteByUserId(existingUser.id);
220
- } else {
221
- await this.userRoleMappingService.deleteByUserId(
222
- existingUser.id,
223
- loggedInUserData.level_type,
224
- loggedInUserData.level_id,
225
- );
226
- }
227
-
228
- const insertPromises: any[] = [];
229
-
230
- for (const entry of userDto.access) {
231
- const { level_type, level_ids, app_code, role_id } = entry;
232
-
233
- if (!level_type || !app_code || !role_id || !Array.isArray(level_ids)) {
234
- return { success: false, error: 'Invalid access level entry' };
235
- }
236
-
237
- for (const levelId of level_ids) {
238
- const userRoleMapping = new UserRoleMapping(savedData.id, role_id);
239
- userRoleMapping.level_type = level_type;
240
- userRoleMapping.level_id = String(levelId);
241
- userRoleMapping.appcode = app_code;
242
- userRoleMapping.organization_id =
243
- loggedInUserData?.organization_id || 0;
244
-
245
- insertPromises.push(
246
- this.userRoleMappingService.assignUserRole(userRoleMapping),
247
- );
248
- }
249
- }
250
-
251
- try {
252
- await Promise.all(insertPromises);
253
- } catch (error) {
254
- console.error('Error updating access levels:', error);
255
- return { success: false, error: 'Failed to update access levels' };
256
- }
257
- }
258
-
259
- return { success: true, data: savedData };
260
- }
261
-
262
- async findByEmailId(
263
- email_id: string,
264
- organization_id?: number,
265
- ): Promise<UserData | null> {
266
- return await this.userRepository.findByEmailId(email_id, organization_id);
267
- }
268
-
269
- async findByMobile(
270
- mobile: string,
271
- organization_id?: number,
272
- appCode?: string,
273
- ): Promise<UserData | null> {
274
- return await this.userRepository.findByMobile(
275
- mobile,
276
- organization_id,
277
- appCode,
278
- );
279
- }
280
-
281
- async setDefaultLastAccess(userId: number, appcode: string): Promise<void> {
282
- const user = await this.userRepository.findById(userId);
283
-
284
- if (!user) {
285
- throw new BadRequestException('User not found');
286
- }
287
-
288
- user.last_app_access = appcode;
289
-
290
- await this.userRepository.saveUser(user); // This persists the updated field
291
- }
292
-
293
- async setLastLevelTypeAndId(
294
- userId: number,
295
- levelType: string,
296
- levelId: string,
297
- appcode: string,
298
- ): Promise<void> {
299
- const user = await this.userRepository.findById(userId);
300
-
301
- if (!user) {
302
- throw new BadRequestException('User not found');
303
- }
304
-
305
- user.last_level_type = levelType;
306
- user.last_level_id = levelId;
307
- user.last_app_access = appcode;
308
-
309
- await this.userRepository.saveUser(user); // This persists the updated field
310
- }
311
-
312
- async checkEmailExists(data: {
313
- email_id: string;
314
- subdomain: string;
315
- }): Promise<any> {
316
- const { email_id, subdomain } = data;
317
-
318
- if (!email_id || !subdomain) {
319
- return { success: false, message: 'Email and Subdomain is required' };
320
- }
321
-
322
- let organization;
323
-
324
- if (subdomain) {
325
- organization =
326
- await this.organizationRepository.findOrganizationBySubdomain(
327
- subdomain,
328
- );
329
-
330
- if (!organization) {
331
- // throw new BadRequestException('Organization not found.');
332
- return {
333
- success: false,
334
- message: 'Organization not found.',
335
- };
336
- }
337
- }
338
-
339
- // 🔹 Step 2: Find the user by email + organization check
340
- const user = await this.userRepository.findByEmailId(email_id);
341
-
342
- if (!user || (organization && user.organization_id !== organization.id)) {
343
- // throw new BadRequestException('User not found in organization.');
344
- return {
345
- success: false,
346
- message: 'User not found in organization.',
347
- };
348
- }
349
-
350
- if (user) {
351
- return {
352
- success: true,
353
- message:
354
- 'An account already exists for this email address. Login or use a different email address to sign up.',
355
- userId: user.id,
356
- };
357
- } else {
358
- // throw new ForbiddenException('No account found with this email address.');
359
- return {
360
- success: false,
361
- message: 'No account found with this email address.',
362
- };
363
- }
364
- }
365
- }
1
+ import { RoleService } from './role.service';
2
+ import {
3
+ BadRequestException,
4
+ ForbiddenException,
5
+ Inject,
6
+ Injectable,
7
+ } from '@nestjs/common';
8
+ import { EntityServiceImpl } from '../../meta/service/entity-service-impl.service';
9
+ import { UserData } from '../entity/user.entity';
10
+ import { BaseEntity } from '../../meta/entity/base-entity.entity';
11
+ import { UserRepository } from '../repository/user.repository';
12
+ import { EncryptUtilService } from '../../../utils/service/encryptUtil.service';
13
+ import { ClockIDGenService } from '../../../utils/service/clockIDGenUtil.service';
14
+ import {
15
+ ENTITYTYPE_ROLE,
16
+ STATUS_ACTIVE,
17
+ INVITATION_STATUS_SENT,
18
+ } from '../../../constant/global.constant';
19
+ import { CreateUserDto } from '../dto/create-user.dto';
20
+ import { UserRoleMappingService } from './user-role-mapping.service';
21
+ import { UserRoleMapping } from '../entity/user-role-mapping.entity';
22
+ import { EntityManager, Repository } from 'typeorm';
23
+ import { UpdateUserDto } from '../dto/update-user.dto';
24
+ import { ConfigService } from '@nestjs/config';
25
+ // import { UserAppMappingService } from 'src/module/meta/service/user-app-mapping.service';
26
+ import { ServiceResult } from 'src/dtos/response.dto';
27
+ import { ListMasterService } from 'src/module/listmaster/service/list-master.service';
28
+ import { OrganizationRepository } from 'src/module/enterprise/repository/organization.repository';
29
+ import { InjectRepository } from '@nestjs/typeorm';
30
+ import { Action } from 'src/module/workflow-automation/interface/action.interface';
31
+ import { ActionHandler } from 'src/module/workflow-automation/interface/action.decorator';
32
+
33
+ @Injectable()
34
+ @ActionHandler('User')
35
+ export class UserService extends EntityServiceImpl implements Action {
36
+ constructor(
37
+ private userRepository: UserRepository,
38
+ private userRoleMappingService: UserRoleMappingService,
39
+ private readonly clockIDGenService: ClockIDGenService,
40
+ private configService: ConfigService,
41
+ private readonly organizationRepository: OrganizationRepository,
42
+ // private readonly userAppMappingService: UserAppMappingService,
43
+ @Inject('RoleService') private readonly roleService: RoleService,
44
+ @Inject('ListMasterService')
45
+ private readonly listMasterService: ListMasterService,
46
+ ) {
47
+ super();
48
+ }
49
+
50
+ masterKey = this.configService.get('MASTER_KEY') || '';
51
+ masterIv = this.configService.get('MASTER_IV') || '';
52
+
53
+ async createEntity(
54
+ entityData: BaseEntity,
55
+ loggedInUser: UserData | null,
56
+ manager?: EntityManager,
57
+ ): Promise<ServiceResult<BaseEntity>> {
58
+ const userData = entityData as CreateUserDto;
59
+
60
+ let existingUser = await this.userRepository.findByEmailId(
61
+ userData.email_id,
62
+ loggedInUser?.organization_id,
63
+ );
64
+ if (existingUser) {
65
+ return { success: false, error: 'User with this email already exists' };
66
+ }
67
+
68
+ existingUser = await this.userRepository.findByMobile(
69
+ userData.mobile,
70
+ loggedInUser?.organization_id,
71
+ );
72
+ if (existingUser) {
73
+ return { success: false, error: 'User with this mobile already exists' };
74
+ }
75
+
76
+ const resolveStatus = await this.listMasterService.getResolvedListCode(
77
+ STATUS_ACTIVE,
78
+ loggedInUser?.organization_id || 0,
79
+ );
80
+
81
+ const resolvedInvitationStatus =
82
+ await this.listMasterService.getResolvedListCode(
83
+ INVITATION_STATUS_SENT,
84
+ loggedInUser?.organization_id || 0,
85
+ );
86
+
87
+ userData.name =
88
+ (userData.first_name || '') + ' ' + (userData.last_name || '');
89
+ userData.password = EncryptUtilService.encryptGCM(
90
+ userData.password || 'Admin@123',
91
+ this.masterKey,
92
+ this.masterIv,
93
+ );
94
+ userData.is_firstlogin = 1;
95
+ userData.roles = [];
96
+ userData.invitation_status = resolvedInvitationStatus.id;
97
+ userData.status = resolveStatus.id || 'ACTIVE';
98
+
99
+ const savedData = await super.createEntity(userData, loggedInUser);
100
+
101
+ const insertPromises: Promise<UserRoleMapping | void | null | undefined>[] =
102
+ [];
103
+
104
+ for (const entry of userData.access || []) {
105
+ const { level_type, level_ids, app_code, role_id } = entry;
106
+
107
+ if (
108
+ !level_type ||
109
+ !Array.isArray(level_ids) ||
110
+ !level_ids.length ||
111
+ !app_code ||
112
+ !role_id
113
+ ) {
114
+ return { success: false, error: 'Invalid access level entry' };
115
+ }
116
+
117
+ for (const levelId of level_ids) {
118
+ const userRoleMapping = new UserRoleMapping(savedData.id, role_id);
119
+ userRoleMapping.level_type = level_type;
120
+ userRoleMapping.level_id = String(levelId);
121
+ userRoleMapping.appcode = app_code;
122
+ userRoleMapping.organization_id = loggedInUser?.organization_id || 0;
123
+ insertPromises.push(
124
+ this.userRoleMappingService.assignUserRole(userRoleMapping),
125
+ );
126
+ }
127
+ }
128
+
129
+ try {
130
+ if (insertPromises.length > 0) {
131
+ await Promise.all(insertPromises);
132
+ }
133
+ } catch (error) {
134
+ console.error('Error adding access levels:', error);
135
+ return { success: false, error: 'Failed to add access levels' };
136
+ }
137
+
138
+ return { success: true, data: savedData };
139
+ }
140
+
141
+ name: string = 'UserService';
142
+ async execute(payload: any): Promise<any> {
143
+ console.log('payload', payload);
144
+ }
145
+
146
+ async getEntityData(
147
+ entityType: string,
148
+ id: number,
149
+ loggedInUser?: UserData,
150
+ ): Promise<BaseEntity | null> {
151
+ const user = await this.userRepository.findById(id);
152
+ if (user) {
153
+ const userRoleMappings: UserRoleMapping[] | null =
154
+ await this.userRoleMappingService.findByUserId(id);
155
+ if (userRoleMappings) {
156
+ const userDto = user as unknown as CreateUserDto;
157
+ const roles: any[] = [];
158
+ for (const i in userRoleMappings) {
159
+ const userRoleMapping = userRoleMappings[i];
160
+ const roleId = userRoleMapping.role_id;
161
+ const role = await super.getEntityData(
162
+ ENTITYTYPE_ROLE,
163
+ roleId,
164
+ loggedInUser,
165
+ );
166
+ roles.push(role);
167
+ }
168
+ userDto.roles = roles;
169
+ }
170
+ return user;
171
+ }
172
+ return null;
173
+ }
174
+
175
+ async updateEntity(
176
+ entityData: BaseEntity,
177
+ loggedInUserData: UserData,
178
+ ): Promise<ServiceResult<BaseEntity>> {
179
+ const userDto = entityData as UpdateUserDto;
180
+
181
+ const existingUser = await this.userRepository.findById(entityData.id);
182
+
183
+ if (!existingUser) {
184
+ return { success: false, error: 'User not found' };
185
+ }
186
+
187
+ if (userDto.password) {
188
+ const decryptedPassword = EncryptUtilService.decryptGCM(
189
+ existingUser.password,
190
+ this.masterKey,
191
+ this.masterIv,
192
+ );
193
+
194
+ if (decryptedPassword === userDto.password) {
195
+ return {
196
+ success: false,
197
+ error: 'New password cannot be the same as the current password',
198
+ };
199
+ }
200
+
201
+ userDto.password = EncryptUtilService.encryptGCM(
202
+ userDto.password,
203
+ this.masterKey,
204
+ this.masterIv,
205
+ );
206
+ }
207
+
208
+ const updatedUserData = { ...userDto } as any;
209
+ delete updatedUserData.access;
210
+
211
+ const savedData = await super.updateEntity(
212
+ updatedUserData,
213
+ loggedInUserData,
214
+ );
215
+
216
+ // Handle updated access levels
217
+ if (userDto.access && userDto.access.length > 0) {
218
+ if (loggedInUserData.level_type == 'ORG') {
219
+ await this.userRoleMappingService.deleteByUserId(existingUser.id);
220
+ } else {
221
+ await this.userRoleMappingService.deleteByUserId(
222
+ existingUser.id,
223
+ loggedInUserData.level_type,
224
+ loggedInUserData.level_id,
225
+ );
226
+ }
227
+
228
+ const insertPromises: any[] = [];
229
+
230
+ for (const entry of userDto.access) {
231
+ const { level_type, level_ids, app_code, role_id } = entry;
232
+
233
+ if (!level_type || !app_code || !role_id || !Array.isArray(level_ids)) {
234
+ return { success: false, error: 'Invalid access level entry' };
235
+ }
236
+
237
+ for (const levelId of level_ids) {
238
+ const userRoleMapping = new UserRoleMapping(savedData.id, role_id);
239
+ userRoleMapping.level_type = level_type;
240
+ userRoleMapping.level_id = String(levelId);
241
+ userRoleMapping.appcode = app_code;
242
+ userRoleMapping.organization_id =
243
+ loggedInUserData?.organization_id || 0;
244
+
245
+ insertPromises.push(
246
+ this.userRoleMappingService.assignUserRole(userRoleMapping),
247
+ );
248
+ }
249
+ }
250
+
251
+ try {
252
+ await Promise.all(insertPromises);
253
+ } catch (error) {
254
+ console.error('Error updating access levels:', error);
255
+ return { success: false, error: 'Failed to update access levels' };
256
+ }
257
+ }
258
+
259
+ return { success: true, data: savedData };
260
+ }
261
+
262
+ async findByEmailId(
263
+ email_id: string,
264
+ organization_id?: number,
265
+ ): Promise<UserData | null> {
266
+ return await this.userRepository.findByEmailId(email_id, organization_id);
267
+ }
268
+
269
+ async findByMobile(
270
+ mobile: string,
271
+ organization_id?: number,
272
+ appCode?: string,
273
+ ): Promise<UserData | null> {
274
+ return await this.userRepository.findByMobile(
275
+ mobile,
276
+ organization_id,
277
+ appCode,
278
+ );
279
+ }
280
+
281
+ async setDefaultLastAccess(userId: number, appcode: string): Promise<void> {
282
+ const user = await this.userRepository.findById(userId);
283
+
284
+ if (!user) {
285
+ throw new BadRequestException('User not found');
286
+ }
287
+
288
+ user.last_app_access = appcode;
289
+
290
+ await this.userRepository.saveUser(user); // This persists the updated field
291
+ }
292
+
293
+ async setLastLevelTypeAndId(
294
+ userId: number,
295
+ levelType: string,
296
+ levelId: string,
297
+ appcode: string,
298
+ ): Promise<void> {
299
+ const user = await this.userRepository.findById(userId);
300
+
301
+ if (!user) {
302
+ throw new BadRequestException('User not found');
303
+ }
304
+
305
+ user.last_level_type = levelType;
306
+ user.last_level_id = levelId;
307
+ user.last_app_access = appcode;
308
+
309
+ await this.userRepository.saveUser(user); // This persists the updated field
310
+ }
311
+
312
+ async checkEmailExists(data: {
313
+ email_id: string;
314
+ subdomain: string;
315
+ }): Promise<any> {
316
+ const { email_id, subdomain } = data;
317
+
318
+ if (!email_id || !subdomain) {
319
+ return { success: false, message: 'Email and Subdomain is required' };
320
+ }
321
+
322
+ let organization;
323
+
324
+ if (subdomain) {
325
+ organization =
326
+ await this.organizationRepository.findOrganizationBySubdomain(
327
+ subdomain,
328
+ );
329
+
330
+ if (!organization) {
331
+ // throw new BadRequestException('Organization not found.');
332
+ return {
333
+ success: false,
334
+ message: 'Organization not found.',
335
+ };
336
+ }
337
+ }
338
+
339
+ // 🔹 Step 2: Find the user by email + organization check
340
+ const user = await this.userRepository.findByEmailId(email_id);
341
+
342
+ if (!user || (organization && user.organization_id !== organization.id)) {
343
+ // throw new BadRequestException('User not found in organization.');
344
+ return {
345
+ success: false,
346
+ message: 'User not found in organization.',
347
+ };
348
+ }
349
+
350
+ if (user) {
351
+ return {
352
+ success: true,
353
+ message:
354
+ 'An account already exists for this email address. Login or use a different email address to sign up.',
355
+ userId: user.id,
356
+ };
357
+ } else {
358
+ // throw new ForbiddenException('No account found with this email address.');
359
+ return {
360
+ success: false,
361
+ message: 'No account found with this email address.',
362
+ };
363
+ }
364
+ }
365
+ }