rez_core 6.5.32 → 6.5.33

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 (400) 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/dist/app.module.js +3 -3
  15. package/dist/app.module.js.map +1 -1
  16. package/dist/constant/status.constant.d.ts +4 -0
  17. package/dist/constant/status.constant.js +9 -0
  18. package/dist/constant/status.constant.js.map +1 -0
  19. package/dist/core.module.js +60 -38
  20. package/dist/core.module.js.map +1 -1
  21. package/dist/module/auth/strategies/jwt.strategy.d.ts +2 -1
  22. package/dist/module/auth/strategies/jwt.strategy.js +3 -2
  23. package/dist/module/auth/strategies/jwt.strategy.js.map +1 -1
  24. package/dist/module/dashboard/dashboard.module.js +1 -1
  25. package/dist/module/dashboard/dashboard.module.js.map +1 -1
  26. package/dist/module/dashboard/service/dashboard.service.js +2 -3
  27. package/dist/module/dashboard/service/dashboard.service.js.map +1 -1
  28. package/dist/module/enterprise/controller/enterprise.controller.d.ts +12 -0
  29. package/dist/module/enterprise/controller/enterprise.controller.js +57 -0
  30. package/dist/module/enterprise/controller/enterprise.controller.js.map +1 -0
  31. package/dist/module/enterprise/controller/meta.controller.d.ts +9 -0
  32. package/dist/module/enterprise/controller/meta.controller.js +43 -0
  33. package/dist/module/enterprise/controller/meta.controller.js.map +1 -0
  34. package/dist/module/enterprise/controller/organization.controller.d.ts +12 -4
  35. package/dist/module/enterprise/controller/organization.controller.js +64 -8
  36. package/dist/module/enterprise/controller/organization.controller.js.map +1 -1
  37. package/dist/module/enterprise/enterprise.module.js +10 -15
  38. package/dist/module/enterprise/enterprise.module.js.map +1 -1
  39. package/dist/module/enterprise/entity/enterprise.entity.d.ts +1 -3
  40. package/dist/module/enterprise/entity/enterprise.entity.js +4 -12
  41. package/dist/module/enterprise/entity/enterprise.entity.js.map +1 -1
  42. package/dist/module/enterprise/entity/organization-app-mapping.entity.d.ts +6 -1
  43. package/dist/module/enterprise/entity/organization-app-mapping.entity.js +21 -4
  44. package/dist/module/enterprise/entity/organization-app-mapping.entity.js.map +1 -1
  45. package/dist/module/enterprise/entity/organization.entity.d.ts +3 -18
  46. package/dist/module/enterprise/entity/organization.entity.js +8 -74
  47. package/dist/module/enterprise/entity/organization.entity.js.map +1 -1
  48. package/dist/module/enterprise/repository/enterprise.repository.d.ts +4 -2
  49. package/dist/module/enterprise/repository/enterprise.repository.js +19 -4
  50. package/dist/module/enterprise/repository/enterprise.repository.js.map +1 -1
  51. package/dist/module/enterprise/service/brand-profile.service.d.ts +0 -0
  52. package/dist/module/enterprise/service/brand-profile.service.js +1 -0
  53. package/dist/module/enterprise/service/brand-profile.service.js.map +1 -0
  54. package/dist/module/enterprise/service/brand.service.d.ts +0 -3
  55. package/dist/module/enterprise/service/brand.service.js +0 -17
  56. package/dist/module/enterprise/service/brand.service.js.map +1 -1
  57. package/dist/module/enterprise/service/enterprise.service.d.ts +2 -2
  58. package/dist/module/enterprise/service/enterprise.service.js +4 -4
  59. package/dist/module/enterprise/service/enterprise.service.js.map +1 -1
  60. package/dist/module/enterprise/service/organization.service.d.ts +4 -4
  61. package/dist/module/enterprise/service/organization.service.js +101 -24
  62. package/dist/module/enterprise/service/organization.service.js.map +1 -1
  63. package/dist/module/enterprise/service/populate-meta.service.d.ts +9 -0
  64. package/dist/module/{meta → enterprise}/service/populate-meta.service.js +2 -8
  65. package/dist/module/enterprise/service/populate-meta.service.js.map +1 -0
  66. package/dist/module/enterprise/service/school.service.d.ts +0 -0
  67. package/dist/module/enterprise/service/school.service.js +1 -0
  68. package/dist/module/enterprise/service/school.service.js.map +1 -0
  69. package/dist/module/entity_json/controller/entity_json.controller.d.ts +9 -2
  70. package/dist/module/entity_json/controller/entity_json.controller.js.map +1 -1
  71. package/dist/module/entity_json/entity/entityJson.entity.d.ts +1 -2
  72. package/dist/module/entity_json/entity/entityJson.entity.js +1 -5
  73. package/dist/module/entity_json/entity/entityJson.entity.js.map +1 -1
  74. package/dist/module/entity_json/entity_json.module.js +2 -7
  75. package/dist/module/entity_json/entity_json.module.js.map +1 -1
  76. package/dist/module/entity_json/service/entity_json.service.d.ts +10 -2
  77. package/dist/module/entity_json/service/entity_json.service.js +23 -98
  78. package/dist/module/entity_json/service/entity_json.service.js.map +1 -1
  79. package/dist/module/filter/controller/filter.controller.d.ts +0 -12
  80. package/dist/module/filter/controller/filter.controller.js +1 -1
  81. package/dist/module/filter/controller/filter.controller.js.map +1 -1
  82. package/dist/module/filter/filter.module.js +2 -11
  83. package/dist/module/filter/filter.module.js.map +1 -1
  84. package/dist/module/filter/service/filter.service.d.ts +2 -38
  85. package/dist/module/filter/service/filter.service.js +50 -43
  86. package/dist/module/filter/service/filter.service.js.map +1 -1
  87. package/dist/module/filter/service/saved-filter.service.d.ts +2 -3
  88. package/dist/module/filter/service/saved-filter.service.js +18 -14
  89. package/dist/module/filter/service/saved-filter.service.js.map +1 -1
  90. package/dist/module/integration/service/integration.service.d.ts +0 -1
  91. package/dist/module/integration/service/integration.service.js +1 -2
  92. package/dist/module/integration/service/integration.service.js.map +1 -1
  93. package/dist/module/integration/service/wrapper.service.js +0 -1
  94. package/dist/module/integration/service/wrapper.service.js.map +1 -1
  95. package/dist/module/layout/controller/layout.controller.d.ts +1 -3
  96. package/dist/module/layout/controller/layout.controller.js +3 -7
  97. package/dist/module/layout/controller/layout.controller.js.map +1 -1
  98. package/dist/module/layout/entity/header-section.entity.d.ts +0 -2
  99. package/dist/module/layout/entity/header-section.entity.js +0 -8
  100. package/dist/module/layout/entity/header-section.entity.js.map +1 -1
  101. package/dist/module/layout/layout.module.js +1 -2
  102. package/dist/module/layout/layout.module.js.map +1 -1
  103. package/dist/module/layout/repository/header-section.repository.d.ts +0 -1
  104. package/dist/module/layout/repository/header-section.repository.js +0 -5
  105. package/dist/module/layout/repository/header-section.repository.js.map +1 -1
  106. package/dist/module/layout/service/header-section.service.d.ts +1 -1
  107. package/dist/module/layout/service/header-section.service.js +1 -1
  108. package/dist/module/layout/service/header-section.service.js.map +1 -1
  109. package/dist/module/linked_attributes/controller/linked_attributes.controller.d.ts +0 -41
  110. package/dist/module/linked_attributes/controller/linked_attributes.controller.js +0 -90
  111. package/dist/module/linked_attributes/controller/linked_attributes.controller.js.map +1 -1
  112. package/dist/module/linked_attributes/linked_attributes.module.js +1 -8
  113. package/dist/module/linked_attributes/linked_attributes.module.js.map +1 -1
  114. package/dist/module/linked_attributes/service/linked_attributes.service.d.ts +1 -65
  115. package/dist/module/linked_attributes/service/linked_attributes.service.js +2 -287
  116. package/dist/module/linked_attributes/service/linked_attributes.service.js.map +1 -1
  117. package/dist/module/listmaster/service/list-master.service.js +1 -8
  118. package/dist/module/listmaster/service/list-master.service.js.map +1 -1
  119. package/dist/module/meta/controller/meta.controller.d.ts +1 -6
  120. package/dist/module/meta/controller/meta.controller.js +1 -19
  121. package/dist/module/meta/controller/meta.controller.js.map +1 -1
  122. package/dist/module/meta/entity/app-master.entity.d.ts +8 -4
  123. package/dist/module/meta/entity/app-master.entity.js +30 -12
  124. package/dist/module/meta/entity/app-master.entity.js.map +1 -1
  125. package/dist/module/meta/entity/entity-master.entity.d.ts +0 -1
  126. package/dist/module/meta/entity/entity-master.entity.js +1 -8
  127. package/dist/module/meta/entity/entity-master.entity.js.map +1 -1
  128. package/dist/module/meta/entity.module.js +2 -5
  129. package/dist/module/meta/entity.module.js.map +1 -1
  130. package/dist/module/meta/repository/app-master.repository.js +1 -1
  131. package/dist/module/meta/repository/app-master.repository.js.map +1 -1
  132. package/dist/module/meta/service/attribute-master.service.d.ts +1 -6
  133. package/dist/module/meta/service/attribute-master.service.js +2 -22
  134. package/dist/module/meta/service/attribute-master.service.js.map +1 -1
  135. package/dist/module/meta/service/entity-master.service.js +0 -1
  136. package/dist/module/meta/service/entity-master.service.js.map +1 -1
  137. package/dist/module/meta/service/entity-relation.service.d.ts +3 -4
  138. package/dist/module/meta/service/entity-relation.service.js +4 -10
  139. package/dist/module/meta/service/entity-relation.service.js.map +1 -1
  140. package/dist/module/meta/service/entity-service-impl.service.d.ts +1 -1
  141. package/dist/module/meta/service/entity-service-impl.service.js +10 -14
  142. package/dist/module/meta/service/entity-service-impl.service.js.map +1 -1
  143. package/dist/module/meta/service/entity-table.service.d.ts +4 -5
  144. package/dist/module/meta/service/entity-table.service.js +25 -25
  145. package/dist/module/meta/service/entity-table.service.js.map +1 -1
  146. package/dist/module/meta/service/resolver.service.d.ts +1 -1
  147. package/dist/module/meta/service/resolver.service.js +3 -6
  148. package/dist/module/meta/service/resolver.service.js.map +1 -1
  149. package/dist/module/module/controller/menu.controller.js +2 -2
  150. package/dist/module/module/controller/menu.controller.js.map +1 -1
  151. package/dist/module/module/controller/module-access.controller.d.ts +3 -4
  152. package/dist/module/module/controller/module-access.controller.js +15 -10
  153. package/dist/module/module/controller/module-access.controller.js.map +1 -1
  154. package/dist/module/module/entity/menu.entity.d.ts +6 -4
  155. package/dist/module/module/entity/menu.entity.js +16 -12
  156. package/dist/module/module/entity/menu.entity.js.map +1 -1
  157. package/dist/module/module/entity/module-access.entity.d.ts +15 -0
  158. package/dist/module/module/entity/module-access.entity.js +50 -0
  159. package/dist/module/module/entity/module-access.entity.js.map +1 -1
  160. package/dist/module/module/entity/module-action.entity.d.ts +4 -2
  161. package/dist/module/module/entity/module-action.entity.js +11 -6
  162. package/dist/module/module/entity/module-action.entity.js.map +1 -1
  163. package/dist/module/module/entity/module.entity.d.ts +3 -5
  164. package/dist/module/module/entity/module.entity.js +8 -18
  165. package/dist/module/module/entity/module.entity.js.map +1 -1
  166. package/dist/module/module/module.module.d.ts +1 -1
  167. package/dist/module/module/module.module.js +5 -7
  168. package/dist/module/module/module.module.js.map +1 -1
  169. package/dist/module/module/repository/menu.repository.d.ts +4 -4
  170. package/dist/module/module/repository/menu.repository.js +17 -27
  171. package/dist/module/module/repository/menu.repository.js.map +1 -1
  172. package/dist/module/module/repository/module-access.repository.d.ts +7 -7
  173. package/dist/module/module/repository/module-access.repository.js +86 -48
  174. package/dist/module/module/repository/module-access.repository.js.map +1 -1
  175. package/dist/module/module/service/menu.service.d.ts +3 -5
  176. package/dist/module/module/service/menu.service.js +9 -12
  177. package/dist/module/module/service/menu.service.js.map +1 -1
  178. package/dist/module/module/service/module-access.service.d.ts +8 -11
  179. package/dist/module/module/service/module-access.service.js +24 -26
  180. package/dist/module/module/service/module-access.service.js.map +1 -1
  181. package/dist/module/notification/entity/notification.entity.d.ts +17 -2
  182. package/dist/module/notification/entity/notification.entity.js +68 -2
  183. package/dist/module/notification/entity/notification.entity.js.map +1 -1
  184. package/dist/module/notification/notification.module.js +0 -2
  185. package/dist/module/notification/notification.module.js.map +1 -1
  186. package/dist/module/notification/service/notification.service.d.ts +1 -3
  187. package/dist/module/notification/service/notification.service.js +2 -5
  188. package/dist/module/notification/service/notification.service.js.map +1 -1
  189. package/dist/module/notification/service/otp.service.js +0 -1
  190. package/dist/module/notification/service/otp.service.js.map +1 -1
  191. package/dist/module/user/controller/login.controller.d.ts +1 -3
  192. package/dist/module/user/controller/login.controller.js +2 -6
  193. package/dist/module/user/controller/login.controller.js.map +1 -1
  194. package/dist/module/user/controller/user.controller.d.ts +0 -2
  195. package/dist/module/user/controller/user.controller.js +0 -13
  196. package/dist/module/user/controller/user.controller.js.map +1 -1
  197. package/dist/module/user/dto/create-user.dto.d.ts +6 -3
  198. package/dist/module/user/dto/create-user.dto.js +17 -11
  199. package/dist/module/user/dto/create-user.dto.js.map +1 -1
  200. package/dist/module/user/entity/role.entity.d.ts +18 -6
  201. package/dist/module/user/entity/role.entity.js +64 -19
  202. package/dist/module/user/entity/role.entity.js.map +1 -1
  203. package/dist/module/user/entity/user-role-mapping.entity.d.ts +10 -0
  204. package/dist/module/user/entity/user-role-mapping.entity.js +33 -1
  205. package/dist/module/user/entity/user-role-mapping.entity.js.map +1 -1
  206. package/dist/module/user/entity/user-session.entity.d.ts +0 -2
  207. package/dist/module/user/entity/user-session.entity.js +2 -20
  208. package/dist/module/user/entity/user-session.entity.js.map +1 -1
  209. package/dist/module/user/entity/user.entity.d.ts +17 -5
  210. package/dist/module/user/entity/user.entity.js +61 -15
  211. package/dist/module/user/entity/user.entity.js.map +1 -1
  212. package/dist/module/user/repository/role.repository.d.ts +6 -2
  213. package/dist/module/user/repository/role.repository.js +16 -8
  214. package/dist/module/user/repository/role.repository.js.map +1 -1
  215. package/dist/module/user/repository/user-role-mapping.repository.d.ts +1 -0
  216. package/dist/module/user/repository/user-role-mapping.repository.js +3 -0
  217. package/dist/module/user/repository/user-role-mapping.repository.js.map +1 -1
  218. package/dist/module/user/repository/user.repository.d.ts +4 -2
  219. package/dist/module/user/repository/user.repository.js +19 -7
  220. package/dist/module/user/repository/user.repository.js.map +1 -1
  221. package/dist/module/user/repository/userSession.repository.d.ts +1 -0
  222. package/dist/module/user/repository/userSession.repository.js +3 -0
  223. package/dist/module/user/repository/userSession.repository.js.map +1 -1
  224. package/dist/module/user/service/login.service.d.ts +3 -5
  225. package/dist/module/user/service/login.service.js +43 -42
  226. package/dist/module/user/service/login.service.js.map +1 -1
  227. package/dist/module/user/service/role.service.d.ts +24 -11
  228. package/dist/module/user/service/role.service.js +42 -38
  229. package/dist/module/user/service/role.service.js.map +1 -1
  230. package/dist/module/user/service/user-role-mapping.service.d.ts +2 -0
  231. package/dist/module/user/service/user-role-mapping.service.js +6 -0
  232. package/dist/module/user/service/user-role-mapping.service.js.map +1 -1
  233. package/dist/module/user/service/user-session.service.d.ts +3 -4
  234. package/dist/module/user/service/user-session.service.js +10 -11
  235. package/dist/module/user/service/user-session.service.js.map +1 -1
  236. package/dist/module/user/service/user.service.d.ts +29 -22
  237. package/dist/module/user/service/user.service.js +44 -59
  238. package/dist/module/user/service/user.service.js.map +1 -1
  239. package/dist/module/user/user.module.js +1 -7
  240. package/dist/module/user/user.module.js.map +1 -1
  241. package/dist/module/workflow/repository/action-data.repository.d.ts +1 -1
  242. package/dist/module/workflow/repository/action-data.repository.js +6 -8
  243. package/dist/module/workflow/repository/action-data.repository.js.map +1 -1
  244. package/dist/module/workflow/repository/action.repository.d.ts +1 -1
  245. package/dist/module/workflow/repository/action.repository.js +10 -10
  246. package/dist/module/workflow/repository/action.repository.js.map +1 -1
  247. package/dist/module/workflow/repository/form-master.repository.d.ts +1 -1
  248. package/dist/module/workflow/repository/form-master.repository.js +2 -2
  249. package/dist/module/workflow/repository/form-master.repository.js.map +1 -1
  250. package/dist/module/workflow/service/action-data.service.js +1 -2
  251. package/dist/module/workflow/service/action-data.service.js.map +1 -1
  252. package/dist/module/workflow/service/action.service.js +2 -2
  253. package/dist/module/workflow/service/action.service.js.map +1 -1
  254. package/dist/module/workflow/service/comm-template.service.js +0 -2
  255. package/dist/module/workflow/service/comm-template.service.js.map +1 -1
  256. package/dist/module/workflow/service/entity-modification.service.js +0 -1
  257. package/dist/module/workflow/service/entity-modification.service.js.map +1 -1
  258. package/dist/module/workflow/service/form-master.service.js +2 -2
  259. package/dist/module/workflow/service/form-master.service.js.map +1 -1
  260. package/dist/module/workflow/service/populate-workflow.service.d.ts +1 -1
  261. package/dist/module/workflow/service/populate-workflow.service.js +1 -1
  262. package/dist/module/workflow/service/populate-workflow.service.js.map +1 -1
  263. package/dist/module/workflow/service/task.service.js +0 -3
  264. package/dist/module/workflow/service/task.service.js.map +1 -1
  265. package/dist/module/workflow/service/workflow-meta.service.js +2 -7
  266. package/dist/module/workflow/service/workflow-meta.service.js.map +1 -1
  267. package/dist/module/workflow/service/workflow.service.js +2 -2
  268. package/dist/module/workflow/service/workflow.service.js.map +1 -1
  269. package/dist/module/workflow/workflow.module.js +2 -0
  270. package/dist/module/workflow/workflow.module.js.map +1 -1
  271. package/dist/module/workflow-automation/service/workflow-automation.service.js +11 -6
  272. package/dist/module/workflow-automation/service/workflow-automation.service.js.map +1 -1
  273. package/dist/module/workflow-automation/workflow-automation.module.js +3 -1
  274. package/dist/module/workflow-automation/workflow-automation.module.js.map +1 -1
  275. package/dist/module/workflow-schedule/service/workflow-schedule.service.js +0 -2
  276. package/dist/module/workflow-schedule/service/workflow-schedule.service.js.map +1 -1
  277. package/dist/table.config.d.ts +2 -4
  278. package/dist/table.config.js +0 -2
  279. package/dist/table.config.js.map +1 -1
  280. package/dist/tsconfig.build.tsbuildinfo +1 -1
  281. package/package.json +2 -2
  282. package/server.log +850 -0
  283. package/src/app.module.ts +5 -5
  284. package/src/constant/status.constant.ts +4 -0
  285. package/src/core.module.ts +55 -44
  286. package/src/module/auth/strategies/jwt.strategy.ts +4 -2
  287. package/src/module/dashboard/dashboard.module.ts +3 -3
  288. package/src/module/dashboard/service/dashboard.service.ts +2 -3
  289. package/src/module/enterprise/controller/enterprise.controller.ts +40 -0
  290. package/src/module/enterprise/controller/meta.controller.ts +23 -0
  291. package/src/module/enterprise/controller/organization.controller.ts +60 -4
  292. package/src/module/enterprise/enterprise.module.ts +16 -18
  293. package/src/module/enterprise/entity/enterprise.entity.ts +5 -11
  294. package/src/module/enterprise/entity/organization-app-mapping.entity.ts +18 -4
  295. package/src/module/enterprise/entity/organization.entity.ts +9 -59
  296. package/src/module/enterprise/repository/enterprise.repository.ts +26 -4
  297. package/src/module/enterprise/service/brand-profile.service.ts +10 -0
  298. package/src/module/enterprise/service/brand.service.ts +75 -5
  299. package/src/module/enterprise/service/enterprise.service.ts +10 -4
  300. package/src/module/enterprise/service/organization.service.ts +140 -23
  301. package/src/module/{meta → enterprise}/service/populate-meta.service.ts +2 -5
  302. package/src/module/enterprise/service/school.service.ts +5 -0
  303. package/src/module/entity_json/controller/entity_json.controller.ts +0 -13
  304. package/src/module/entity_json/entity/entityJson.entity.ts +1 -4
  305. package/src/module/entity_json/entity_json.module.ts +5 -9
  306. package/src/module/entity_json/service/entity_json.service.ts +49 -233
  307. package/src/module/filter/controller/filter.controller.ts +3 -1
  308. package/src/module/filter/filter.module.ts +3 -12
  309. package/src/module/filter/service/filter.service.ts +73 -130
  310. package/src/module/filter/service/saved-filter.service.ts +26 -16
  311. package/src/module/integration/service/integration.service.ts +2 -6
  312. package/src/module/integration/service/wrapper.service.ts +0 -1
  313. package/src/module/layout/controller/layout.controller.ts +1 -8
  314. package/src/module/layout/entity/header-section.entity.ts +0 -6
  315. package/src/module/layout/layout.module.ts +1 -1
  316. package/src/module/layout/repository/header-section.repository.ts +0 -6
  317. package/src/module/layout/service/header-section.service.ts +1 -1
  318. package/src/module/linked_attributes/controller/linked_attributes.controller.ts +0 -100
  319. package/src/module/linked_attributes/linked_attributes.module.ts +2 -9
  320. package/src/module/linked_attributes/service/linked_attributes.service.ts +3 -578
  321. package/src/module/listmaster/service/list-master.service.ts +1 -9
  322. package/src/module/meta/controller/meta.controller.ts +3 -25
  323. package/src/module/meta/entity/app-master.entity.ts +22 -9
  324. package/src/module/meta/entity/entity-master.entity.ts +3 -9
  325. package/src/module/meta/entity.module.ts +5 -6
  326. package/src/module/meta/repository/app-master.repository.ts +1 -1
  327. package/src/module/meta/service/attribute-master.service.ts +1 -31
  328. package/src/module/meta/service/entity-master.service.ts +0 -1
  329. package/src/module/meta/service/entity-relation.service.ts +6 -10
  330. package/src/module/meta/service/entity-service-impl.service.ts +19 -14
  331. package/src/module/meta/service/entity-table.service.ts +20 -15
  332. package/src/module/meta/service/entity.service.ts +1 -0
  333. package/src/module/meta/service/resolver.service.ts +0 -4
  334. package/src/module/module/controller/menu.controller.ts +2 -2
  335. package/src/module/module/controller/module-access.controller.ts +16 -11
  336. package/src/module/module/entity/menu.entity.ts +14 -10
  337. package/src/module/module/entity/module-access.entity.ts +41 -1
  338. package/src/module/module/entity/module-action.entity.ts +10 -6
  339. package/src/module/module/entity/module.entity.ts +7 -14
  340. package/src/module/module/module.module.ts +2 -3
  341. package/src/module/module/repository/menu.repository.ts +19 -31
  342. package/src/module/module/repository/module-access.repository.ts +100 -63
  343. package/src/module/module/service/menu.service.ts +11 -13
  344. package/src/module/module/service/module-access.service.ts +26 -38
  345. package/src/module/notification/entity/notification.entity.ts +53 -3
  346. package/src/module/notification/notification.module.ts +0 -2
  347. package/src/module/notification/service/notification.service.ts +0 -1
  348. package/src/module/notification/service/otp.service.ts +4 -3
  349. package/src/module/user/controller/login.controller.ts +7 -8
  350. package/src/module/user/controller/user.controller.ts +0 -9
  351. package/src/module/user/dto/create-user.dto.ts +19 -6
  352. package/src/module/user/entity/role.entity.ts +59 -16
  353. package/src/module/user/entity/user-role-mapping.entity.ts +29 -3
  354. package/src/module/user/entity/user-session.entity.ts +3 -19
  355. package/src/module/user/entity/user.entity.ts +48 -13
  356. package/src/module/user/repository/role.repository.ts +24 -12
  357. package/src/module/user/repository/user-role-mapping.repository.ts +5 -1
  358. package/src/module/user/repository/user.repository.ts +28 -8
  359. package/src/module/user/repository/userSession.repository.ts +5 -1
  360. package/src/module/user/service/login.service.ts +47 -51
  361. package/src/module/user/service/role.service.ts +53 -60
  362. package/src/module/user/service/user-role-mapping.service.ts +23 -1
  363. package/src/module/user/service/user-session.service.ts +14 -11
  364. package/src/module/user/service/user.service.ts +63 -95
  365. package/src/module/user/user.module.ts +3 -5
  366. package/src/module/workflow/repository/action-data.repository.ts +6 -8
  367. package/src/module/workflow/repository/action.repository.ts +11 -11
  368. package/src/module/workflow/repository/form-master.repository.ts +2 -2
  369. package/src/module/workflow/service/action-data.service.ts +3 -2
  370. package/src/module/workflow/service/action.service.ts +2 -2
  371. package/src/module/workflow/service/comm-template.service.ts +0 -2
  372. package/src/module/workflow/service/entity-modification.service.ts +0 -1
  373. package/src/module/workflow/service/form-master.service.ts +2 -2
  374. package/src/module/workflow/service/populate-workflow.service.ts +1 -1
  375. package/src/module/workflow/service/task.service.ts +0 -3
  376. package/src/module/workflow/service/workflow-meta.service.ts +2 -7
  377. package/src/module/workflow/service/workflow.service.ts +2 -2
  378. package/src/module/workflow/workflow.module.ts +2 -0
  379. package/src/module/workflow-automation/service/workflow-automation.service.ts +19 -7
  380. package/src/module/workflow-automation/workflow-automation.module.ts +4 -3
  381. package/src/module/workflow-schedule/service/workflow-schedule.service.ts +0 -2
  382. package/src/resources/dev.properties.yaml +2 -2
  383. package/src/table.config.ts +0 -2
  384. package/dist/migrations/1732612800000-AddEntityJsonGinIndex.d.ts +0 -6
  385. package/dist/migrations/1732612800000-AddEntityJsonGinIndex.js +0 -32
  386. package/dist/migrations/1732612800000-AddEntityJsonGinIndex.js.map +0 -1
  387. package/dist/module/filter/service/flatjson-filter.service.d.ts +0 -32
  388. package/dist/module/filter/service/flatjson-filter.service.js +0 -632
  389. package/dist/module/filter/service/flatjson-filter.service.js.map +0 -1
  390. package/dist/module/linked_attributes/dto/create-linked-attribute-smart.dto.d.ts +0 -13
  391. package/dist/module/linked_attributes/dto/create-linked-attribute-smart.dto.js +0 -64
  392. package/dist/module/linked_attributes/dto/create-linked-attribute-smart.dto.js.map +0 -1
  393. package/dist/module/meta/service/populate-meta.service.d.ts +0 -13
  394. package/dist/module/meta/service/populate-meta.service.js.map +0 -1
  395. package/src/migrations/1732612800000-AddEntityJsonGinIndex.ts +0 -41
  396. package/src/module/entity_json/docs/FlatJson_Filterin_System.md +0 -2804
  397. package/src/module/filter/service/flatjson-filter.service.ts +0 -903
  398. package/src/module/filter/test/flatjson-filter.service.spec.ts +0 -415
  399. package/src/module/linked_attributes/dto/create-linked-attribute-smart.dto.ts +0 -54
  400. package/src/module/linked_attributes/test/linked-attributes.service.spec.ts +0 -244
@@ -1,415 +0,0 @@
1
- import { Test, TestingModule } from '@nestjs/testing';
2
- import { FlatjsonFilterService } from '../service/flatjson-filter.service';
3
- import { EntityManager } from 'typeorm';
4
- import { EntityMasterService } from 'src/module/meta/service/entity-master.service';
5
- import { AttributeMasterService } from 'src/module/meta/service/attribute-master.service';
6
- import { ResolverService } from 'src/module/meta/service/resolver.service';
7
- import { LoggingService } from 'src/utils/service/loggingUtil.service';
8
- import { ConfigService } from '@nestjs/config';
9
- import { SavedFilterRepositoryService } from '../repository/saved-filter.repository';
10
-
11
- describe('FlatjsonFilterService - Phase 2 Tests', () => {
12
- let service: FlatjsonFilterService;
13
-
14
- const mockEntityManager = {
15
- getRepository: jest.fn(),
16
- };
17
-
18
- const mockEntityMasterService = {};
19
- const mockAttributeMasterService = {
20
- findAttributesByMappedEntityType: jest.fn(),
21
- };
22
- const mockResolverService = {
23
- resolveEntitiesByIds: jest.fn(),
24
- };
25
- const mockLoggingService = {
26
- log: jest.fn(),
27
- };
28
- const mockConfigService = {};
29
- const mockSavedFilterRepositoryService = {
30
- getDetailsByCode: jest.fn(),
31
- };
32
-
33
- beforeEach(async () => {
34
- const module: TestingModule = await Test.createTestingModule({
35
- providers: [
36
- FlatjsonFilterService,
37
- { provide: EntityManager, useValue: mockEntityManager },
38
- { provide: EntityMasterService, useValue: mockEntityMasterService },
39
- {
40
- provide: AttributeMasterService,
41
- useValue: mockAttributeMasterService,
42
- },
43
- { provide: ResolverService, useValue: mockResolverService },
44
- { provide: LoggingService, useValue: mockLoggingService },
45
- { provide: ConfigService, useValue: mockConfigService },
46
- {
47
- provide: SavedFilterRepositoryService,
48
- useValue: mockSavedFilterRepositoryService,
49
- },
50
- ],
51
- }).compile();
52
-
53
- service = module.get<FlatjsonFilterService>(FlatjsonFilterService);
54
- });
55
-
56
- afterEach(() => {
57
- jest.clearAllMocks();
58
- });
59
-
60
- describe('Task 2.3: Text Conditions', () => {
61
- it('should build equal condition for text', () => {
62
- const condition = service['buildTextCondition'](
63
- 'LEAD__name',
64
- 'equal',
65
- 'John',
66
- 'param1',
67
- );
68
-
69
- expect(condition).not.toBeNull();
70
- expect(condition?.query).toContain("json_data->>'LEAD__name'");
71
- expect(condition?.query).toContain('=');
72
- expect(condition?.params.param1).toBe('john'); // lowercase
73
- });
74
-
75
- it('should build contains condition with LIKE', () => {
76
- const condition = service['buildTextCondition'](
77
- 'LEAD__name',
78
- 'contains',
79
- 'John',
80
- 'param1',
81
- );
82
-
83
- expect(condition?.query).toContain('LIKE');
84
- expect(condition?.params.param1).toBe('%john%');
85
- });
86
-
87
- it('should build starts_with condition', () => {
88
- const condition = service['buildTextCondition'](
89
- 'LEAD__name',
90
- 'starts_with',
91
- 'John',
92
- 'param1',
93
- );
94
-
95
- expect(condition?.params.param1).toBe('john%');
96
- });
97
-
98
- it('should build ends_with condition', () => {
99
- const condition = service['buildTextCondition'](
100
- 'LEAD__name',
101
- 'ends_with',
102
- 'Smith',
103
- 'param1',
104
- );
105
-
106
- expect(condition?.params.param1).toBe('%smith');
107
- });
108
-
109
- it('should build empty condition', () => {
110
- const condition = service['buildTextCondition'](
111
- 'LEAD__name',
112
- 'empty',
113
- null,
114
- 'param1',
115
- );
116
-
117
- expect(condition?.query).toContain('IS NULL');
118
- expect(Object.keys(condition?.params || {})).toHaveLength(0);
119
- });
120
- });
121
-
122
- describe('Task 2.4: Number Conditions', () => {
123
- it('should build equal condition for numbers', () => {
124
- const condition = service['buildNumberCondition'](
125
- 'LEAD__age',
126
- 'equal',
127
- 25,
128
- 'param1',
129
- );
130
-
131
- expect(condition?.query).toContain('::numeric');
132
- expect(condition?.query).toContain('=');
133
- expect(condition?.params.param1).toBe(25);
134
- });
135
-
136
- it('should build greater_than condition', () => {
137
- const condition = service['buildNumberCondition'](
138
- 'LEAD__age',
139
- 'greater_than',
140
- 18,
141
- 'param1',
142
- );
143
-
144
- expect(condition?.query).toContain('>');
145
- expect(condition?.params.param1).toBe(18);
146
- });
147
-
148
- it('should build between condition with array', () => {
149
- const condition = service['buildNumberCondition'](
150
- 'LEAD__age',
151
- 'between',
152
- [18, 65],
153
- 'param1',
154
- );
155
-
156
- expect(condition?.query).toContain('BETWEEN');
157
- expect(condition?.params.param1_min).toBe(18);
158
- expect(condition?.params.param1_max).toBe(65);
159
- });
160
-
161
- it('should build between condition with string', () => {
162
- const condition = service['buildNumberCondition'](
163
- 'LEAD__age',
164
- 'between',
165
- '18, 65',
166
- 'param1',
167
- );
168
-
169
- expect(condition?.query).toContain('BETWEEN');
170
- expect(condition?.params.param1_min).toBe(18);
171
- expect(condition?.params.param1_max).toBe(65);
172
- });
173
- });
174
-
175
- describe('Task 2.5: Date Conditions', () => {
176
- it('should build equal condition for dates', () => {
177
- const condition = service['buildDateCondition'](
178
- 'LEAD__created_date',
179
- 'equal',
180
- '2024-01-01',
181
- 'param1',
182
- );
183
-
184
- expect(condition?.query).toContain('::bigint');
185
- expect(condition?.query).toContain('=');
186
- expect(typeof condition?.params.param1).toBe('number');
187
- });
188
-
189
- it('should build before condition', () => {
190
- const condition = service['buildDateCondition'](
191
- 'LEAD__created_date',
192
- 'before',
193
- '2024-12-31',
194
- 'param1',
195
- );
196
-
197
- expect(condition?.query).toContain('<');
198
- });
199
-
200
- it('should build between condition for dates', () => {
201
- const condition = service['buildDateCondition'](
202
- 'LEAD__created_date',
203
- 'between',
204
- ['2024-01-01', '2024-12-31'],
205
- 'param1',
206
- );
207
-
208
- expect(condition?.query).toContain('BETWEEN');
209
- expect(condition?.params.param1_start).toBeDefined();
210
- expect(condition?.params.param1_end).toBeDefined();
211
- });
212
-
213
- it('should build today condition', () => {
214
- const condition = service['buildDateCondition'](
215
- 'LEAD__created_date',
216
- 'today',
217
- null,
218
- 'param1',
219
- );
220
-
221
- expect(condition?.query).toContain('BETWEEN');
222
- expect(condition?.params.param1_start).toBeDefined();
223
- expect(condition?.params.param1_end).toBeDefined();
224
- });
225
-
226
- it('should build in_last_day condition', () => {
227
- const condition = service['buildDateCondition'](
228
- 'LEAD__created_date',
229
- 'in_last_day',
230
- 7,
231
- 'param1',
232
- );
233
-
234
- expect(condition?.query).toContain('BETWEEN');
235
- });
236
- });
237
-
238
- describe('Task 2.6: Select/Multiselect Conditions', () => {
239
- it('should build equal condition for select', () => {
240
- const condition = service['buildSelectCondition'](
241
- 'LEAD__status',
242
- 'equal',
243
- 'NEW',
244
- 'param1',
245
- );
246
-
247
- expect(condition?.query).toContain("json_data->>'LEAD__status'");
248
- expect(condition?.params.param1).toBe('NEW');
249
- });
250
-
251
- it('should build IN condition for array values', () => {
252
- const condition = service['buildSelectCondition'](
253
- 'LEAD__status',
254
- 'equal',
255
- ['NEW', 'ACTIVE'],
256
- 'param1',
257
- );
258
-
259
- expect(condition?.query).toContain('ANY');
260
- expect(Array.isArray(condition?.params.param1)).toBe(true);
261
- });
262
-
263
- it('should build contains condition for multiselect', () => {
264
- const condition = service['buildMultiSelectCondition'](
265
- 'LEAD__languages',
266
- 'contains',
267
- 'hindi',
268
- 'param1',
269
- );
270
-
271
- expect(condition?.query).toContain('?');
272
- expect(condition?.params.param1).toBe('hindi');
273
- });
274
-
275
- it('should build contains_all condition', () => {
276
- const condition = service['buildMultiSelectCondition'](
277
- 'LEAD__languages',
278
- 'contains_all',
279
- ['hindi', 'english'],
280
- 'param1',
281
- );
282
-
283
- expect(condition?.query).toContain('?&');
284
- expect(Array.isArray(condition?.params.param1)).toBe(true);
285
- });
286
-
287
- it('should build contains_any condition', () => {
288
- const condition = service['buildMultiSelectCondition'](
289
- 'LEAD__languages',
290
- 'contains_any',
291
- ['hindi', 'english'],
292
- 'param1',
293
- );
294
-
295
- expect(condition?.query).toContain('?|');
296
- });
297
-
298
- it('should handle comma-separated string input', () => {
299
- const condition = service['buildMultiSelectCondition'](
300
- 'LEAD__languages',
301
- 'contains_any',
302
- 'hindi, english, tamil',
303
- 'param1',
304
- );
305
-
306
- expect(Array.isArray(condition?.params.param1)).toBe(true);
307
- expect(condition?.params.param1).toHaveLength(3);
308
- });
309
- });
310
-
311
- describe('Task 2.9: Sorting', () => {
312
- it('should apply numeric sorting for number fields', () => {
313
- const mockQb = {
314
- orderBy: jest.fn().mockReturnThis(),
315
- addOrderBy: jest.fn().mockReturnThis(),
316
- };
317
-
318
- const attributeMetaMap = {
319
- age: {
320
- data_type: 'number',
321
- flat_json_key: 'LEAD__age',
322
- mapped_entity_type: 'LEAD',
323
- },
324
- };
325
-
326
- const sortby = [{ sortColum: 'age', sortType: 'DESC' }];
327
-
328
- service['applyJsonbSorting'](mockQb as any, sortby, attributeMetaMap);
329
-
330
- expect(mockQb.orderBy).toHaveBeenCalled();
331
- const call = mockQb.orderBy.mock.calls[0];
332
- expect(call[0]).toContain('::numeric');
333
- expect(call[1]).toBe('DESC');
334
- });
335
-
336
- it('should apply bigint sorting for date fields', () => {
337
- const mockQb = {
338
- orderBy: jest.fn().mockReturnThis(),
339
- };
340
-
341
- const attributeMetaMap = {
342
- created_date: {
343
- data_type: 'date',
344
- flat_json_key: 'LEAD__created_date',
345
- mapped_entity_type: 'LEAD',
346
- },
347
- };
348
-
349
- const sortby = [{ sortColum: 'created_date', sortType: 'ASC' }];
350
-
351
- service['applyJsonbSorting'](mockQb as any, sortby, attributeMetaMap);
352
-
353
- const call = mockQb.orderBy.mock.calls[0];
354
- expect(call[0]).toContain('::bigint');
355
- });
356
-
357
- it('should apply text sorting for text fields', () => {
358
- const mockQb = {
359
- orderBy: jest.fn().mockReturnThis(),
360
- };
361
-
362
- const attributeMetaMap = {
363
- name: {
364
- data_type: 'text',
365
- flat_json_key: 'LEAD__name',
366
- mapped_entity_type: 'LEAD',
367
- },
368
- };
369
-
370
- const sortby = [{ sortColum: 'name', sortType: 'ASC' }];
371
-
372
- service['applyJsonbSorting'](mockQb as any, sortby, attributeMetaMap);
373
-
374
- const call = mockQb.orderBy.mock.calls[0];
375
- expect(call[0]).not.toContain('::');
376
- expect(call[0]).toContain("->>"); // Text extraction
377
- });
378
- });
379
-
380
- describe('Edge Cases', () => {
381
- it('should handle NULL values in text conditions', () => {
382
- const condition = service['buildTextCondition'](
383
- 'LEAD__name',
384
- 'equal',
385
- null,
386
- 'param1',
387
- );
388
-
389
- expect(condition).not.toBeNull();
390
- expect(condition?.params.param1).toBe('');
391
- });
392
-
393
- it('should return null for unsupported operators', () => {
394
- const condition = service['buildTextCondition'](
395
- 'LEAD__name',
396
- 'invalid_operator',
397
- 'test',
398
- 'param1',
399
- );
400
-
401
- expect(condition).toBeNull();
402
- });
403
-
404
- it('should handle empty array in multiselect', () => {
405
- const condition = service['buildMultiSelectCondition'](
406
- 'LEAD__languages',
407
- 'contains',
408
- [],
409
- 'param1',
410
- );
411
-
412
- expect(condition?.query).toBe('1=1'); // Always true
413
- });
414
- });
415
- });
@@ -1,54 +0,0 @@
1
- import {
2
- IsString,
3
- IsNotEmpty,
4
- IsArray,
5
- IsOptional,
6
- IsBoolean,
7
- ValidateNested,
8
- } from 'class-validator';
9
- import { Type } from 'class-transformer';
10
-
11
- export class FilterConditionDto {
12
- @IsString()
13
- @IsNotEmpty()
14
- filter_attribute: string;
15
-
16
- @IsString()
17
- @IsNotEmpty()
18
- filter_operator: string;
19
-
20
- @IsNotEmpty()
21
- filter_value: any;
22
- }
23
-
24
- export class CreateLinkedAttributeSmartDto {
25
- @IsString()
26
- @IsNotEmpty()
27
- field_name: string;
28
-
29
- @IsString()
30
- @IsNotEmpty()
31
- mapped_entity_type: string;
32
-
33
- @IsString()
34
- @IsNotEmpty()
35
- applicable_entity_type: string;
36
-
37
- @IsString()
38
- @IsNotEmpty()
39
- applicable_attribute_key: string;
40
-
41
- @IsString()
42
- @IsNotEmpty()
43
- saved_filter_code: string;
44
-
45
- // @IsArray()
46
- // @IsOptional()
47
- // @ValidateNested({ each: true })
48
- // @Type(() => FilterConditionDto)
49
- // filter_conditions?: FilterConditionDto[];
50
-
51
- @IsBoolean()
52
- @IsOptional()
53
- backfill?: boolean;
54
- }
@@ -1,244 +0,0 @@
1
- import { Test, TestingModule } from '@nestjs/testing';
2
- import { LinkedAttributesService } from '../service/linked_attributes.service';
3
- import { DataSource } from 'typeorm';
4
- import { EntityMasterService } from 'src/module/meta/service/entity-master.service';
5
- import { AttributeMasterService } from 'src/module/meta/service/attribute-master.service';
6
- import { SavedFilterService } from 'src/module/filter/service/saved-filter.service';
7
- import { SavedFilterDetailRepository } from 'src/module/filter/repository/saved.filter-detail.repository';
8
- import { EntityJSONService } from 'src/module/entity_json/service/entity_json.service';
9
-
10
- describe('LinkedAttributesService - Phase 1 Tests', () => {
11
- let service: LinkedAttributesService;
12
- let dataSource: DataSource;
13
- let entityMasterService: EntityMasterService;
14
- let attributeMasterService: AttributeMasterService;
15
-
16
- const mockDataSource = {
17
- getRepository: jest.fn(),
18
- transaction: jest.fn(),
19
- };
20
-
21
- const mockEntityMasterService = {
22
- getEntityData: jest.fn(),
23
- };
24
-
25
- const mockAttributeMasterService = {
26
- findAttributesByMappedEntityType: jest.fn(),
27
- };
28
-
29
- const mockSavedFilterService = {
30
- createEntity: jest.fn(),
31
- };
32
-
33
- const mockSavedFilterDetailRepository = {
34
- findByMappedFilterCode: jest.fn(),
35
- };
36
-
37
- const mockEntityJSONService = {
38
- updateEntityJSON: jest.fn(),
39
- };
40
-
41
- const mockLoggedInUser = {
42
- id: 1,
43
- organization_id: 100,
44
- level_type: 'ORG',
45
- level_id: 100,
46
- };
47
-
48
- beforeEach(async () => {
49
- const module: TestingModule = await Test.createTestingModule({
50
- providers: [
51
- LinkedAttributesService,
52
- { provide: DataSource, useValue: mockDataSource },
53
- { provide: EntityMasterService, useValue: mockEntityMasterService },
54
- {
55
- provide: AttributeMasterService,
56
- useValue: mockAttributeMasterService,
57
- },
58
- { provide: 'SavedFilterService', useValue: mockSavedFilterService },
59
- {
60
- provide: SavedFilterDetailRepository,
61
- useValue: mockSavedFilterDetailRepository,
62
- },
63
- { provide: EntityJSONService, useValue: mockEntityJSONService },
64
- ],
65
- }).compile();
66
-
67
- service = module.get<LinkedAttributesService>(LinkedAttributesService);
68
- dataSource = module.get<DataSource>(DataSource);
69
- });
70
-
71
- afterEach(() => {
72
- jest.clearAllMocks();
73
- });
74
-
75
- describe('Task 1.1: generateAttributeKey', () => {
76
- it('should generate correct attribute key format', () => {
77
- const result = service.generateAttributeKey('LFMG', 'name', 1);
78
- expect(result).toBe('LFMG__name__1');
79
- });
80
-
81
- it('should handle different sequences', () => {
82
- expect(service.generateAttributeKey('LFMG', 'name', 1)).toBe(
83
- 'LFMG__name__1',
84
- );
85
- expect(service.generateAttributeKey('LFMG', 'name', 2)).toBe(
86
- 'LFMG__name__2',
87
- );
88
- expect(service.generateAttributeKey('LFMG', 'name', 99)).toBe(
89
- 'LFMG__name__99',
90
- );
91
- });
92
-
93
- it('should throw error for empty entity_type', () => {
94
- expect(() => service.generateAttributeKey('', 'name', 1)).toThrow(
95
- 'applicable_entity_type is required and cannot be empty',
96
- );
97
- });
98
-
99
- it('should throw error for empty attribute_key', () => {
100
- expect(() => service.generateAttributeKey('LFMG', '', 1)).toThrow(
101
- 'applicable_attribute_key is required and cannot be empty',
102
- );
103
- });
104
-
105
- it('should throw error for invalid sequence', () => {
106
- expect(() => service.generateAttributeKey('LFMG', 'name', 0)).toThrow(
107
- 'sequence must be a positive integer greater than 0',
108
- );
109
- expect(() => service.generateAttributeKey('LFMG', 'name', -1)).toThrow(
110
- 'sequence must be a positive integer greater than 0',
111
- );
112
- expect(() => service.generateAttributeKey('LFMG', 'name', 1.5)).toThrow(
113
- 'sequence must be a positive integer greater than 0',
114
- );
115
- });
116
-
117
- it('should trim whitespace from inputs', () => {
118
- expect(() =>
119
- service.generateAttributeKey(' ', 'name', 1),
120
- ).toThrow();
121
- expect(() =>
122
- service.generateAttributeKey('LFMG', ' ', 1),
123
- ).toThrow();
124
- });
125
- });
126
-
127
- describe('Task 1.2: Validation Engine', () => {
128
- it('should validate required fields', async () => {
129
- const payload = {
130
- field_name: '',
131
- mapped_entity_type: 'LEAD',
132
- applicable_entity_type: 'LFMG',
133
- applicable_attribute_key: 'name',
134
- organization_id: 100,
135
- };
136
-
137
- const result = await service.validateLinkedAttribute(
138
- payload,
139
- mockLoggedInUser,
140
- );
141
-
142
- expect(result.valid).toBe(false);
143
- expect(result.errors).toContain(
144
- "Required field 'field_name' is missing or empty",
145
- );
146
- });
147
-
148
- it('should validate entity type exists', async () => {
149
- mockEntityMasterService.getEntityData.mockRejectedValue(
150
- new Error('Not found'),
151
- );
152
-
153
- const payload = {
154
- field_name: 'Father Name',
155
- mapped_entity_type: 'INVALID',
156
- applicable_entity_type: 'LFMG',
157
- applicable_attribute_key: 'name',
158
- organization_id: 100,
159
- };
160
-
161
- const result = await service.validateLinkedAttribute(
162
- payload,
163
- mockLoggedInUser,
164
- );
165
-
166
- expect(result.valid).toBe(false);
167
- expect(
168
- result.errors.some((e) => e.includes('does not exist')),
169
- ).toBe(true);
170
- });
171
-
172
- it('should pass validation for valid payload', async () => {
173
- // Mock successful validations
174
- mockEntityMasterService.getEntityData
175
- .mockResolvedValueOnce({ id: 1 }) // mapped_entity_type
176
- .mockResolvedValueOnce({ id: 2 }); // applicable_entity_type
177
-
178
- mockAttributeMasterService.findAttributesByMappedEntityType.mockResolvedValue(
179
- [{ attribute_key: 'name' }],
180
- );
181
-
182
- const mockRepository = {
183
- createQueryBuilder: jest.fn().mockReturnValue({
184
- where: jest.fn().mockReturnThis(),
185
- andWhere: jest.fn().mockReturnThis(),
186
- getOne: jest.fn().mockResolvedValue(null), // No duplicate
187
- }),
188
- };
189
-
190
- mockDataSource.getRepository.mockReturnValue(mockRepository);
191
-
192
- const payload = {
193
- field_name: 'Father Name',
194
- mapped_entity_type: 'LEAD',
195
- applicable_entity_type: 'LFMG',
196
- applicable_attribute_key: 'name',
197
- organization_id: 100,
198
- };
199
-
200
- const result = await service.validateLinkedAttribute(
201
- payload,
202
- mockLoggedInUser,
203
- );
204
-
205
- expect(result.valid).toBe(true);
206
- expect(result.errors).toHaveLength(0);
207
- });
208
- });
209
-
210
- describe('Task 1.4: Smart Create Method', () => {
211
- it('should throw BadRequestException on validation failure', async () => {
212
- // Mock validation failure
213
- mockEntityMasterService.getEntityData.mockRejectedValue(
214
- new Error('Not found'),
215
- );
216
-
217
- const dto = {
218
- field_name: 'Father Name',
219
- mapped_entity_type: 'INVALID',
220
- applicable_entity_type: 'LFMG',
221
- applicable_attribute_key: 'name',
222
- };
223
-
224
- await expect(
225
- service.createLinkedAttributeSmart(dto, mockLoggedInUser),
226
- ).rejects.toThrow();
227
- });
228
- });
229
-
230
- describe('Integration Tests', () => {
231
- it('should handle end-to-end attribute key generation', () => {
232
- // Test the full flow: sequence 1, 2, 3
233
- expect(service.generateAttributeKey('LFMG', 'name', 1)).toBe(
234
- 'LFMG__name__1',
235
- );
236
- expect(service.generateAttributeKey('LFMG', 'email', 1)).toBe(
237
- 'LFMG__email__1',
238
- );
239
- expect(service.generateAttributeKey('CONTACT', 'phone', 1)).toBe(
240
- 'CONTACT__phone__1',
241
- );
242
- });
243
- });
244
- });