rez_core 5.0.157 → 5.0.158

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 (475) hide show
  1. package/.claude/settings.local.json +26 -0
  2. package/.idea/250218_nodejs_core.iml +8 -11
  3. package/.idea/codeStyles/Project.xml +58 -58
  4. package/.idea/codeStyles/codeStyleConfig.xml +4 -4
  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 +1 -1
  10. package/.idea/misc.xml +6 -0
  11. package/.idea/modules.xml +7 -7
  12. package/.idea/prettier.xml +5 -5
  13. package/.idea/vcs.xml +5 -5
  14. package/.prettierrc +3 -3
  15. package/README.md +99 -99
  16. package/dist/config/bull.config.js +4 -4
  17. package/dist/config/bull.config.js.map +1 -1
  18. package/dist/config/database.config.js +1 -1
  19. package/dist/config/database.config.js.map +1 -1
  20. package/dist/core.module.js +2 -5
  21. package/dist/core.module.js.map +1 -1
  22. package/dist/module/auth/guards/role.guard.js +3 -3
  23. package/dist/module/entity_json/controller/entity_json.controller.d.ts +9 -2
  24. package/dist/module/entity_json/entity/entityJson.entity.d.ts +1 -2
  25. package/dist/module/entity_json/entity/entityJson.entity.js +1 -5
  26. package/dist/module/entity_json/entity/entityJson.entity.js.map +1 -1
  27. package/dist/module/entity_json/entity_json.module.js +2 -7
  28. package/dist/module/entity_json/entity_json.module.js.map +1 -1
  29. package/dist/module/entity_json/service/entity_json.service.d.ts +10 -2
  30. package/dist/module/entity_json/service/entity_json.service.js +4 -54
  31. package/dist/module/entity_json/service/entity_json.service.js.map +1 -1
  32. package/dist/module/filter/controller/filter.controller.d.ts +0 -12
  33. package/dist/module/filter/controller/filter.controller.js +1 -1
  34. package/dist/module/filter/controller/filter.controller.js.map +1 -1
  35. package/dist/module/filter/entity/saved-filter-master.entity.d.ts +2 -1
  36. package/dist/module/filter/entity/saved-filter-master.entity.js +6 -2
  37. package/dist/module/filter/entity/saved-filter-master.entity.js.map +1 -1
  38. package/dist/module/filter/filter.module.js +2 -11
  39. package/dist/module/filter/filter.module.js.map +1 -1
  40. package/dist/module/filter/repository/saved-filter.repository.d.ts +1 -5
  41. package/dist/module/filter/repository/saved-filter.repository.js +1 -5
  42. package/dist/module/filter/repository/saved-filter.repository.js.map +1 -1
  43. package/dist/module/filter/service/filter.service.d.ts +1 -37
  44. package/dist/module/filter/service/filter.service.js +63 -51
  45. package/dist/module/filter/service/filter.service.js.map +1 -1
  46. package/dist/module/integration/examples/usage.example.js +9 -9
  47. package/dist/module/integration/service/wrapper.service.d.ts +3 -1
  48. package/dist/module/integration/service/wrapper.service.js +24 -2
  49. package/dist/module/integration/service/wrapper.service.js.map +1 -1
  50. package/dist/module/linked_attributes/controller/linked_attributes.controller.d.ts +0 -19
  51. package/dist/module/linked_attributes/controller/linked_attributes.controller.js +0 -77
  52. package/dist/module/linked_attributes/controller/linked_attributes.controller.js.map +1 -1
  53. package/dist/module/linked_attributes/linked_attributes.module.js +1 -8
  54. package/dist/module/linked_attributes/linked_attributes.module.js.map +1 -1
  55. package/dist/module/linked_attributes/service/linked_attributes.service.d.ts +1 -41
  56. package/dist/module/linked_attributes/service/linked_attributes.service.js +2 -266
  57. package/dist/module/linked_attributes/service/linked_attributes.service.js.map +1 -1
  58. package/dist/module/meta/dto/entity-table.dto.d.ts +1 -4
  59. package/dist/module/meta/dto/entity-table.dto.js.map +1 -1
  60. package/dist/module/meta/entity.module.js +2 -0
  61. package/dist/module/meta/entity.module.js.map +1 -1
  62. package/dist/module/meta/repository/attribute-master.repository.js +8 -8
  63. package/dist/module/meta/repository/entity-relation.repository.d.ts +7 -0
  64. package/dist/module/meta/repository/entity-relation.repository.js +39 -0
  65. package/dist/module/meta/repository/entity-relation.repository.js.map +1 -0
  66. package/dist/module/meta/service/entity-dynamic.service.d.ts +4 -1
  67. package/dist/module/meta/service/entity-dynamic.service.js +23 -22
  68. package/dist/module/meta/service/entity-dynamic.service.js.map +1 -1
  69. package/dist/module/meta/service/entity-list.service.js +2 -2
  70. package/dist/module/meta/service/entity-relation.service.d.ts +4 -1
  71. package/dist/module/meta/service/entity-relation.service.js +20 -14
  72. package/dist/module/meta/service/entity-relation.service.js.map +1 -1
  73. package/dist/module/meta/service/media-data.service.js +24 -11
  74. package/dist/module/meta/service/media-data.service.js.map +1 -1
  75. package/dist/module/meta/service/resolver.service.js +15 -15
  76. package/dist/module/module/repository/menu.repository.js +4 -4
  77. package/dist/module/notification/service/notification.service.js +6 -6
  78. package/dist/module/user/controller/login.controller.js +18 -18
  79. package/dist/module/workflow/repository/action.repository.js +2 -2
  80. package/dist/module/workflow/repository/stage.repository.js +8 -8
  81. package/dist/module/workflow/service/action-template-mapping.service.js +2 -2
  82. package/dist/module/workflow/service/action.service.js +7 -15
  83. package/dist/module/workflow/service/action.service.js.map +1 -1
  84. package/dist/module/workflow/service/entity-modification.service.js +2 -2
  85. package/dist/module/workflow/service/task.service.js +12 -13
  86. package/dist/module/workflow/service/task.service.js.map +1 -1
  87. package/dist/module/workflow-automation/service/schedule-handler.service.js +9 -9
  88. package/dist/table.config.d.ts +1 -3
  89. package/dist/table.config.js +0 -2
  90. package/dist/table.config.js.map +1 -1
  91. package/dist/tsconfig.build.tsbuildinfo +1 -1
  92. package/dist/utils/service/reflection-helper.service.js +2 -2
  93. package/docs/modules/event-driven-integration-design.md +91 -91
  94. package/docs/modules/integration.md +250 -250
  95. package/eslint.config.mjs +34 -34
  96. package/nest-cli.json +14 -14
  97. package/package.json +125 -125
  98. package/server.log +850 -0
  99. package/src/app.controller.ts +12 -12
  100. package/src/app.module.ts +68 -68
  101. package/src/app.service.ts +8 -8
  102. package/src/config/bull.config.ts +69 -69
  103. package/src/config/config.module.ts +17 -17
  104. package/src/config/database.config.ts +48 -48
  105. package/src/constant/global.constant.ts +67 -67
  106. package/src/core.module.ts +94 -97
  107. package/src/decorators/roles.decorator.ts +7 -7
  108. package/src/dtos/response.dto.ts +6 -6
  109. package/src/dtos/response.ts +5 -5
  110. package/src/index.ts +1 -1
  111. package/src/module/auth/auth.module.ts +49 -49
  112. package/src/module/auth/controller/auth.controller.ts +28 -28
  113. package/src/module/auth/guards/google-auth.guard.ts +9 -9
  114. package/src/module/auth/guards/jwt.guard.ts +22 -22
  115. package/src/module/auth/guards/role.guard.ts +68 -68
  116. package/src/module/auth/services/auth.service.ts +56 -56
  117. package/src/module/auth/services/jwt.service.ts +11 -11
  118. package/src/module/auth/strategies/google.strategy.ts +54 -54
  119. package/src/module/auth/strategies/jwt.strategy.ts +58 -58
  120. package/src/module/auth/strategies/local.strategy.ts +13 -13
  121. package/src/module/dashboard/controller/dashboard.controller.ts +36 -36
  122. package/src/module/dashboard/dashboard.module.ts +21 -21
  123. package/src/module/dashboard/entity/dashboard_page_data.entity.ts +27 -27
  124. package/src/module/dashboard/entity/widget_master.entity.ts +18 -18
  125. package/src/module/dashboard/repository/dashboard.repository.ts +51 -51
  126. package/src/module/dashboard/service/dashboard.service.ts +73 -73
  127. package/src/module/enterprise/controller/organization.controller.ts +36 -36
  128. package/src/module/enterprise/enterprise.module.ts +30 -30
  129. package/src/module/enterprise/entity/enterprise.entity.ts +37 -37
  130. package/src/module/enterprise/entity/organization-app-mapping.entity.ts +13 -13
  131. package/src/module/enterprise/entity/organization.entity.ts +92 -92
  132. package/src/module/enterprise/repository/enterprise.repository.ts +31 -31
  133. package/src/module/enterprise/repository/organization.repository.ts +26 -26
  134. package/src/module/enterprise/repository/school.repository.ts +272 -272
  135. package/src/module/enterprise/service/brand.service.ts +5 -5
  136. package/src/module/enterprise/service/enterprise.service.ts +16 -16
  137. package/src/module/enterprise/service/organization-app-mapping.service.ts +4 -4
  138. package/src/module/enterprise/service/organization.service.ts +145 -145
  139. package/src/module/entity_json/controller/entity_json.controller.ts +47 -47
  140. package/src/module/entity_json/entity/entityJson.entity.ts +39 -42
  141. package/src/module/entity_json/entity_json.module.ts +18 -23
  142. package/src/module/entity_json/service/entityJson.repository.ts +37 -37
  143. package/src/module/entity_json/service/entity_json.service.ts +242 -349
  144. package/src/module/export/controller/export.controller.ts +83 -83
  145. package/src/module/export/export.module.ts +14 -14
  146. package/src/module/export/service/export.service.ts +105 -105
  147. package/src/module/filter/controller/filter.controller.ts +84 -82
  148. package/src/module/filter/dto/filter-request.dto.ts +39 -39
  149. package/src/module/filter/entity/saved-filter-detail.entity.ts +41 -41
  150. package/src/module/filter/entity/saved-filter-master.entity.ts +32 -29
  151. package/src/module/filter/filter.module.ts +33 -42
  152. package/src/module/filter/repository/saved-filter.repository.ts +200 -196
  153. package/src/module/filter/repository/saved.filter-detail.repository.ts +19 -19
  154. package/src/module/filter/service/filter-evaluator.service.ts +82 -82
  155. package/src/module/filter/service/filter.service.ts +1317 -1365
  156. package/src/module/filter/service/saved-filter.service.ts +164 -164
  157. package/src/module/ics/controller/ics.controller.ts +21 -21
  158. package/src/module/ics/dto/ics.dto.ts +55 -55
  159. package/src/module/ics/ics.module.ts +13 -13
  160. package/src/module/ics/service/ics.service.ts +57 -57
  161. package/src/module/integration/controller/calender-event.controller.ts +31 -31
  162. package/src/module/integration/controller/integration.controller.ts +662 -662
  163. package/src/module/integration/controller/wrapper.controller.ts +37 -37
  164. package/src/module/integration/dto/create-config.dto.ts +526 -526
  165. package/src/module/integration/entity/integration-config.entity.ts +112 -112
  166. package/src/module/integration/entity/integration-entity-mapper.entity.ts +14 -14
  167. package/src/module/integration/entity/integration-source.entity.ts +17 -17
  168. package/src/module/integration/entity/user-integration.entity.ts +71 -71
  169. package/src/module/integration/examples/usage.example.ts +338 -338
  170. package/src/module/integration/factories/base.factory.ts +7 -7
  171. package/src/module/integration/factories/email.factory.ts +49 -49
  172. package/src/module/integration/factories/integration.factory.ts +121 -121
  173. package/src/module/integration/factories/sms.factory.ts +51 -51
  174. package/src/module/integration/factories/telephone.factory.ts +41 -41
  175. package/src/module/integration/factories/whatsapp.factory.ts +56 -56
  176. package/src/module/integration/integration.module.ts +110 -110
  177. package/src/module/integration/service/calendar-event.service.ts +118 -118
  178. package/src/module/integration/service/integration-entity-mapper.service.ts +17 -17
  179. package/src/module/integration/service/integration-queue.service.ts +229 -229
  180. package/src/module/integration/service/integration.service.ts +2634 -2634
  181. package/src/module/integration/service/oauth.service.ts +224 -224
  182. package/src/module/integration/service/wrapper.service.ts +753 -716
  183. package/src/module/integration/strategies/email/gmail-api.strategy.ts +280 -280
  184. package/src/module/integration/strategies/email/outlook-api.strategy.ts +44 -44
  185. package/src/module/integration/strategies/email/outlook.strategy.ts +64 -64
  186. package/src/module/integration/strategies/email/sendgrid-api.strategy.ts +260 -260
  187. package/src/module/integration/strategies/integration.strategy.ts +97 -97
  188. package/src/module/integration/strategies/sms/gupshup-sms.strategy.ts +146 -146
  189. package/src/module/integration/strategies/sms/msg91-sms.strategy.ts +164 -164
  190. package/src/module/integration/strategies/sms/tubelight-sms.strategy.ts +163 -163
  191. package/src/module/integration/strategies/telephone/ozonetel-voice.strategy.ts +238 -238
  192. package/src/module/integration/strategies/telephone/tubelight-voice.strategy.ts +210 -210
  193. package/src/module/integration/strategies/whatsapp/gupshup-whatsapp.strategy.ts +359 -359
  194. package/src/module/integration/strategies/whatsapp/tubelight-whatsapp.strategy.ts +372 -372
  195. package/src/module/integration/strategies/whatsapp/whatsapp-cloud.strategy.ts +403 -403
  196. package/src/module/integration/strategies/whatsapp/whatsapp.strategy.ts +57 -57
  197. package/src/module/layout/controller/layout.controller.ts +47 -47
  198. package/src/module/layout/entity/header-items.entity.ts +28 -28
  199. package/src/module/layout/entity/header-section.entity.ts +19 -19
  200. package/src/module/layout/layout.module.ts +21 -21
  201. package/src/module/layout/repository/header-items.repository.ts +18 -18
  202. package/src/module/layout/repository/header-section.repository.ts +22 -22
  203. package/src/module/layout/service/header-section.service.ts +25 -25
  204. package/src/module/layout_preference/controller/layout_preference.controller.ts +73 -73
  205. package/src/module/layout_preference/entity/layout_preference.entity.ts +28 -28
  206. package/src/module/layout_preference/layout_preference.module.ts +22 -22
  207. package/src/module/layout_preference/repository/layout_preference.repository.ts +65 -65
  208. package/src/module/layout_preference/service/layout_preference.service.ts +191 -191
  209. package/src/module/lead/controller/lead.controller.ts +30 -30
  210. package/src/module/lead/lead.module.ts +14 -14
  211. package/src/module/lead/repository/lead.repository.ts +41 -41
  212. package/src/module/lead/service/lead.service.ts +54 -54
  213. package/src/module/linked_attributes/controller/linked_attributes.controller.ts +37 -123
  214. package/src/module/linked_attributes/entity/linked_attribute.entity.ts +51 -51
  215. package/src/module/linked_attributes/linked_attributes.module.ts +16 -23
  216. package/src/module/linked_attributes/repository/linked_attribute.repository.ts +12 -12
  217. package/src/module/linked_attributes/service/linked_attributes.service.ts +75 -620
  218. package/src/module/listmaster/controller/list-master.controller.ts +230 -230
  219. package/src/module/listmaster/entity/list-master-items.entity.ts +43 -43
  220. package/src/module/listmaster/entity/list-master.entity.ts +33 -33
  221. package/src/module/listmaster/listmaster.module.ts +46 -46
  222. package/src/module/listmaster/repository/list-master-items.repository.ts +173 -173
  223. package/src/module/listmaster/repository/list-master.repository.ts +56 -56
  224. package/src/module/listmaster/service/list-master-engine.ts +19 -19
  225. package/src/module/listmaster/service/list-master-extension.interface.ts +4 -4
  226. package/src/module/listmaster/service/list-master-item.service.ts +281 -281
  227. package/src/module/listmaster/service/list-master-registry.ts +15 -15
  228. package/src/module/listmaster/service/list-master.service.ts +535 -535
  229. package/src/module/mapper/controller/field-mapper.controller.ts +76 -76
  230. package/src/module/mapper/controller/mapper.controller.ts +20 -20
  231. package/src/module/mapper/dto/field-mapper.dto.ts +14 -14
  232. package/src/module/mapper/entity/field-lovs.entity.ts +19 -19
  233. package/src/module/mapper/entity/field-mapper.entity.ts +53 -53
  234. package/src/module/mapper/entity/mapper.entity.ts +16 -16
  235. package/src/module/mapper/mapper.module.ts +35 -35
  236. package/src/module/mapper/repository/field-lovs.repository.ts +35 -35
  237. package/src/module/mapper/repository/field-mapper.repository.ts +42 -42
  238. package/src/module/mapper/repository/mapper.repository.ts +32 -32
  239. package/src/module/mapper/service/field-mapper.service.ts +269 -269
  240. package/src/module/mapper/service/mapper.service.ts +81 -81
  241. package/src/module/master/controller/master.controller.ts +74 -74
  242. package/src/module/master/service/master.service.ts +483 -483
  243. package/src/module/meta/controller/app-master.controller.ts +38 -38
  244. package/src/module/meta/controller/attribute-master.controller.ts +84 -84
  245. package/src/module/meta/controller/entity-dynamic.controller.ts +125 -125
  246. package/src/module/meta/controller/entity-master.controller.ts +41 -41
  247. package/src/module/meta/controller/entity-relation.controller.ts +36 -36
  248. package/src/module/meta/controller/entity.controller.ts +342 -342
  249. package/src/module/meta/controller/entity.public.controller.ts +75 -75
  250. package/src/module/meta/controller/media.controller.ts +135 -135
  251. package/src/module/meta/controller/meta.controller.ts +96 -96
  252. package/src/module/meta/controller/view-master.controller.ts +86 -86
  253. package/src/module/meta/dto/entity-list-data.dto.ts +6 -6
  254. package/src/module/meta/dto/entity-tab.dto.ts +4 -4
  255. package/src/module/meta/dto/entity-table.dto.ts +12 -10
  256. package/src/module/meta/entity/app-master.entity.ts +37 -37
  257. package/src/module/meta/entity/attribute-master.entity.ts +92 -92
  258. package/src/module/meta/entity/base-entity.entity.ts +75 -75
  259. package/src/module/meta/entity/entity-master.entity.ts +85 -85
  260. package/src/module/meta/entity/entity-relation-data.entity.ts +29 -29
  261. package/src/module/meta/entity/entity-relation.entity.ts +23 -23
  262. package/src/module/meta/entity/entity-table-column.entity.ts +61 -61
  263. package/src/module/meta/entity/entity-table.entity.ts +50 -50
  264. package/src/module/meta/entity/media-data.entity.ts +32 -32
  265. package/src/module/meta/entity/preference.entity.ts +62 -62
  266. package/src/module/meta/entity/view-master.entity.ts +41 -41
  267. package/src/module/meta/entity.module.ts +168 -166
  268. package/src/module/meta/repository/app-master.repository.ts +20 -20
  269. package/src/module/meta/repository/attribute-master.repository.ts +156 -156
  270. package/src/module/meta/repository/entity-attribute-update.repository.ts +48 -48
  271. package/src/module/meta/repository/entity-master.repository.ts +110 -110
  272. package/src/module/meta/repository/entity-relation.repository.ts +23 -0
  273. package/src/module/meta/repository/entity-table-column.repository.ts +39 -39
  274. package/src/module/meta/repository/entity-table.repository.ts +53 -53
  275. package/src/module/meta/repository/media-data.repository.ts +50 -50
  276. package/src/module/meta/repository/preference.repository.ts +20 -20
  277. package/src/module/meta/repository/user-app-mapping.repository.ts +28 -28
  278. package/src/module/meta/repository/view-master.repository.ts +42 -42
  279. package/src/module/meta/service/app-master.service.ts +37 -37
  280. package/src/module/meta/service/attribute-master.service.ts +130 -130
  281. package/src/module/meta/service/common.service.ts +9 -9
  282. package/src/module/meta/service/entity-attribute-update.service.ts +26 -26
  283. package/src/module/meta/service/entity-dynamic.service.ts +822 -818
  284. package/src/module/meta/service/entity-list.service.ts +201 -201
  285. package/src/module/meta/service/entity-master.service.ts +171 -171
  286. package/src/module/meta/service/entity-realation-data.service.ts +9 -9
  287. package/src/module/meta/service/entity-relation.service.ts +74 -69
  288. package/src/module/meta/service/entity-service-impl.service.ts +439 -439
  289. package/src/module/meta/service/entity-table-column.service.ts +39 -39
  290. package/src/module/meta/service/entity-table.service.ts +157 -157
  291. package/src/module/meta/service/entity-validation.service.ts +187 -187
  292. package/src/module/meta/service/entity.service.ts +59 -59
  293. package/src/module/meta/service/field-group.service.ts +103 -103
  294. package/src/module/meta/service/media-data.service.ts +591 -573
  295. package/src/module/meta/service/populate-meta.service.ts +222 -222
  296. package/src/module/meta/service/preference.service.ts +16 -16
  297. package/src/module/meta/service/resolver.service.ts +291 -291
  298. package/src/module/meta/service/section-master.service.ts +104 -104
  299. package/src/module/meta/service/update-form-json.service.ts +22 -22
  300. package/src/module/meta/service/user-app-mapping.service.ts +17 -17
  301. package/src/module/meta/service/view-master.service.ts +127 -127
  302. package/src/module/microservice-client/microservice-clients.module.ts +13 -13
  303. package/src/module/microservice-client/service/microservice-client-factory.ts +37 -37
  304. package/src/module/microservice-client/service/microservice-clients.ts +4 -4
  305. package/src/module/module/controller/menu.controller.ts +15 -15
  306. package/src/module/module/controller/module-access.controller.ts +134 -134
  307. package/src/module/module/entity/menu.entity.ts +43 -43
  308. package/src/module/module/entity/module-access.entity.ts +25 -25
  309. package/src/module/module/entity/module-action.entity.ts +17 -17
  310. package/src/module/module/entity/module.entity.ts +52 -52
  311. package/src/module/module/module.module.ts +42 -42
  312. package/src/module/module/repository/menu.repository.ts +186 -186
  313. package/src/module/module/repository/module-access.repository.ts +344 -344
  314. package/src/module/module/service/menu.service.ts +82 -82
  315. package/src/module/module/service/module-access.service.ts +199 -199
  316. package/src/module/notification/controller/notification.controller.ts +58 -58
  317. package/src/module/notification/controller/otp.controller.ts +117 -117
  318. package/src/module/notification/entity/notification.entity.ts +26 -26
  319. package/src/module/notification/entity/otp.entity.ts +28 -28
  320. package/src/module/notification/firebase-admin.config.ts +22 -22
  321. package/src/module/notification/notification.module.ts +69 -69
  322. package/src/module/notification/repository/otp.repository.ts +27 -27
  323. package/src/module/notification/service/email.service.ts +127 -127
  324. package/src/module/notification/service/notification.service.ts +164 -164
  325. package/src/module/notification/service/otp.service.ts +133 -133
  326. package/src/module/third-party-module/entity/third-party-api-registry.entity.ts +52 -52
  327. package/src/module/third-party-module/repository/third-party-api-registry.repository.ts +20 -20
  328. package/src/module/third-party-module/service/api-registry.service.ts +13 -13
  329. package/src/module/third-party-module/third-party.module.ts +12 -12
  330. package/src/module/user/controller/login.controller.ts +198 -198
  331. package/src/module/user/controller/user.controller.ts +40 -40
  332. package/src/module/user/dto/create-user.dto.ts +62 -62
  333. package/src/module/user/dto/update-user.dto.ts +4 -4
  334. package/src/module/user/entity/role.entity.ts +33 -33
  335. package/src/module/user/entity/user-role-mapping.entity.ts +38 -38
  336. package/src/module/user/entity/user-session.entity.ts +73 -73
  337. package/src/module/user/entity/user.entity.ts +59 -59
  338. package/src/module/user/repository/role.repository.ts +96 -96
  339. package/src/module/user/repository/user-role-mapping.repository.ts +126 -126
  340. package/src/module/user/repository/user.repository.ts +50 -50
  341. package/src/module/user/repository/userSession.repository.ts +33 -33
  342. package/src/module/user/service/login.service.ts +326 -326
  343. package/src/module/user/service/role.service.ts +197 -197
  344. package/src/module/user/service/user-role-mapping.service.ts +98 -98
  345. package/src/module/user/service/user-session.service.ts +200 -200
  346. package/src/module/user/service/user.service.ts +368 -368
  347. package/src/module/user/user.module.ts +65 -65
  348. package/src/module/workflow/controller/action-category.controller.ts +54 -54
  349. package/src/module/workflow/controller/action-resource-mapping.controller.ts +23 -23
  350. package/src/module/workflow/controller/action-template-mapping.controller.ts +35 -35
  351. package/src/module/workflow/controller/action.controller.ts +111 -111
  352. package/src/module/workflow/controller/activity-log.controller.ts +55 -55
  353. package/src/module/workflow/controller/comm-template.controller.ts +43 -43
  354. package/src/module/workflow/controller/entity-modification.controller.ts +35 -35
  355. package/src/module/workflow/controller/form-master.controller.ts +43 -43
  356. package/src/module/workflow/controller/stage-group.controller.ts +48 -48
  357. package/src/module/workflow/controller/stage.controller.ts +50 -50
  358. package/src/module/workflow/controller/task.controller.ts +77 -77
  359. package/src/module/workflow/controller/workflow-list-master.controller.ts +44 -44
  360. package/src/module/workflow/controller/workflow-meta.controller.ts +80 -80
  361. package/src/module/workflow/controller/workflow.controller.ts +67 -67
  362. package/src/module/workflow/entity/action-category.entity.ts +38 -38
  363. package/src/module/workflow/entity/action-data.entity.ts +55 -55
  364. package/src/module/workflow/entity/action-resources-mapping.entity.ts +29 -29
  365. package/src/module/workflow/entity/action-template-mapping.entity.ts +17 -17
  366. package/src/module/workflow/entity/action.entity.ts +53 -53
  367. package/src/module/workflow/entity/activity-log.entity.ts +43 -43
  368. package/src/module/workflow/entity/comm-template.entity.ts +43 -43
  369. package/src/module/workflow/entity/entity-modification.entity.ts +38 -38
  370. package/src/module/workflow/entity/form.entity.ts +25 -25
  371. package/src/module/workflow/entity/stage-action-mapping.entity.ts +17 -17
  372. package/src/module/workflow/entity/stage-group.entity.ts +23 -23
  373. package/src/module/workflow/entity/stage-movement-data.entity.ts +38 -38
  374. package/src/module/workflow/entity/stage.entity.ts +20 -20
  375. package/src/module/workflow/entity/task-data.entity.ts +88 -88
  376. package/src/module/workflow/entity/template-attach-mapper.entity.ts +30 -30
  377. package/src/module/workflow/entity/workflow-data.entity.ts +11 -11
  378. package/src/module/workflow/entity/workflow-level-mapping.entity.ts +18 -18
  379. package/src/module/workflow/entity/workflow.entity.ts +20 -20
  380. package/src/module/workflow/repository/action-category.repository.ts +79 -79
  381. package/src/module/workflow/repository/action-data.repository.ts +346 -346
  382. package/src/module/workflow/repository/action.repository.ts +339 -339
  383. package/src/module/workflow/repository/activity-log.repository.ts +148 -148
  384. package/src/module/workflow/repository/comm-template.repository.ts +157 -157
  385. package/src/module/workflow/repository/form-master.repository.ts +50 -50
  386. package/src/module/workflow/repository/stage-group.repository.ts +186 -186
  387. package/src/module/workflow/repository/stage-movement.repository.ts +257 -257
  388. package/src/module/workflow/repository/stage.repository.ts +160 -160
  389. package/src/module/workflow/repository/task.repository.ts +151 -151
  390. package/src/module/workflow/repository/workflow.repository.ts +42 -42
  391. package/src/module/workflow/service/action-category.service.ts +33 -33
  392. package/src/module/workflow/service/action-data.service.ts +62 -62
  393. package/src/module/workflow/service/action-resources-mapping.service.ts +10 -10
  394. package/src/module/workflow/service/action-template-mapping.service.ts +140 -140
  395. package/src/module/workflow/service/action.service.ts +302 -306
  396. package/src/module/workflow/service/activity-log.service.ts +107 -107
  397. package/src/module/workflow/service/comm-template.service.ts +180 -180
  398. package/src/module/workflow/service/entity-modification.service.ts +61 -61
  399. package/src/module/workflow/service/form-master.service.ts +35 -35
  400. package/src/module/workflow/service/populate-workflow.service.ts +320 -320
  401. package/src/module/workflow/service/stage-action-mapping.service.ts +5 -5
  402. package/src/module/workflow/service/stage-group.service.ts +344 -344
  403. package/src/module/workflow/service/stage.service.ts +207 -207
  404. package/src/module/workflow/service/task.service.ts +550 -549
  405. package/src/module/workflow/service/workflow-list-master.service.ts +68 -68
  406. package/src/module/workflow/service/workflow-meta.service.ts +639 -639
  407. package/src/module/workflow/service/workflow.service.ts +213 -213
  408. package/src/module/workflow/workflow.module.ts +180 -180
  409. package/src/module/workflow-automation/SCHEDULING_GUIDE.md +145 -145
  410. package/src/module/workflow-automation/controller/workflow-automation.controller.ts +43 -43
  411. package/src/module/workflow-automation/entity/workflow-automation-action.entity.ts +26 -26
  412. package/src/module/workflow-automation/entity/workflow-automation.entity.ts +40 -40
  413. package/src/module/workflow-automation/interface/action.decorator.ts +7 -7
  414. package/src/module/workflow-automation/interface/action.interface.ts +5 -5
  415. package/src/module/workflow-automation/service/action-registery.service.ts +35 -35
  416. package/src/module/workflow-automation/service/schedule-handler.service.ts +168 -168
  417. package/src/module/workflow-automation/service/workflow-automation-engine.service.ts +219 -219
  418. package/src/module/workflow-automation/service/workflow-automation.service.ts +515 -515
  419. package/src/module/workflow-automation/workflow-automation.module.ts +54 -54
  420. package/src/module/workflow-schedule/INSTALLATION.md +244 -244
  421. package/src/module/workflow-schedule/MULTI_PROJECT_GUIDE.md +196 -196
  422. package/src/module/workflow-schedule/README.md +422 -422
  423. package/src/module/workflow-schedule/constants/schedule.constants.ts +48 -48
  424. package/src/module/workflow-schedule/controller/workflow-schedule.controller.ts +255 -255
  425. package/src/module/workflow-schedule/docs/CLAUDE_CODE_GUIDE.md +510 -510
  426. package/src/module/workflow-schedule/docs/CLAUDE_CODE_PROMPT.md +362 -362
  427. package/src/module/workflow-schedule/docs/RUN_CLAUDE_CODE.sh +68 -68
  428. package/src/module/workflow-schedule/dto/create-schedule.dto.ts +147 -147
  429. package/src/module/workflow-schedule/dto/get-execution-logs.dto.ts +119 -119
  430. package/src/module/workflow-schedule/dto/update-schedule.dto.ts +96 -96
  431. package/src/module/workflow-schedule/entities/scheduled-workflow.entity.ts +148 -148
  432. package/src/module/workflow-schedule/entities/workflow-execution-log.entity.ts +154 -154
  433. package/src/module/workflow-schedule/interfaces/schedule-job-data.interface.ts +53 -53
  434. package/src/module/workflow-schedule/interfaces/workflow-schedule-options.interface.ts +12 -12
  435. package/src/module/workflow-schedule/processors/schedule.processor.ts +620 -620
  436. package/src/module/workflow-schedule/service/workflow-schedule.service.ts +598 -598
  437. package/src/module/workflow-schedule/workflow-schedule.module.ts +67 -67
  438. package/src/resources/dev.properties.yaml +31 -31
  439. package/src/resources/local.properties.yaml +27 -27
  440. package/src/resources/properties.module.ts +12 -12
  441. package/src/resources/properties.yaml.ts +11 -11
  442. package/src/resources/uat.properties.yaml +31 -31
  443. package/src/table.config.ts +133 -135
  444. package/src/utils/dto/excel-data.dto.ts +14 -14
  445. package/src/utils/dto/excelsheet-data.dto.ts +5 -5
  446. package/src/utils/service/base64util.service.ts +18 -18
  447. package/src/utils/service/clockIDGenUtil.service.ts +21 -21
  448. package/src/utils/service/codeGenerator.service.ts +22 -22
  449. package/src/utils/service/dateUtil.service.ts +17 -17
  450. package/src/utils/service/encryptUtil.service.ts +97 -97
  451. package/src/utils/service/excel-helper.service.ts +72 -72
  452. package/src/utils/service/excelUtil.service.ts +15 -15
  453. package/src/utils/service/file-util.service.ts +11 -11
  454. package/src/utils/service/json-util.service.ts +23 -23
  455. package/src/utils/service/loggingUtil.service.ts +88 -88
  456. package/src/utils/service/reflection-helper.service.ts +62 -62
  457. package/src/utils/service/wbsCodeGen.service.ts +8 -8
  458. package/src/utils/utils.module.ts +27 -27
  459. package/tsconfig.build.json +4 -4
  460. package/tsconfig.json +24 -24
  461. package/dist/migrations/1732612800000-AddEntityJsonGinIndex.d.ts +0 -6
  462. package/dist/migrations/1732612800000-AddEntityJsonGinIndex.js +0 -32
  463. package/dist/migrations/1732612800000-AddEntityJsonGinIndex.js.map +0 -1
  464. package/dist/module/filter/service/flatjson-filter.service.d.ts +0 -32
  465. package/dist/module/filter/service/flatjson-filter.service.js +0 -626
  466. package/dist/module/filter/service/flatjson-filter.service.js.map +0 -1
  467. package/dist/module/linked_attributes/dto/create-linked-attribute-smart.dto.d.ts +0 -13
  468. package/dist/module/linked_attributes/dto/create-linked-attribute-smart.dto.js +0 -64
  469. package/dist/module/linked_attributes/dto/create-linked-attribute-smart.dto.js.map +0 -1
  470. package/src/migrations/1732612800000-AddEntityJsonGinIndex.ts +0 -41
  471. package/src/module/entity_json/docs/FlatJson_Filterin_System.md +0 -2804
  472. package/src/module/filter/service/flatjson-filter.service.ts +0 -902
  473. package/src/module/filter/test/flatjson-filter.service.spec.ts +0 -415
  474. package/src/module/linked_attributes/dto/create-linked-attribute-smart.dto.ts +0 -54
  475. package/src/module/linked_attributes/test/linked-attributes.service.spec.ts +0 -244
@@ -1,902 +0,0 @@
1
- import { Injectable, BadRequestException, Inject, forwardRef } from '@nestjs/common';
2
- import { EntityManager, SelectQueryBuilder } from 'typeorm';
3
- import { EntityMasterService } from 'src/module/meta/service/entity-master.service';
4
- import { AttributeMasterService } from 'src/module/meta/service/attribute-master.service';
5
- import { ResolverService } from 'src/module/meta/service/resolver.service';
6
- import { LoggingService } from 'src/utils/service/loggingUtil.service';
7
- import { ConfigService } from '@nestjs/config';
8
- import {
9
- FilterRequestDto,
10
- FilterCondition,
11
- SortConfig,
12
- } from '../dto/filter-request.dto';
13
- import { EntityJson } from 'src/module/entity_json/entity/entityJson.entity';
14
- import { SavedFilterRepositoryService } from '../repository/saved-filter.repository';
15
- import { EntityJSONService } from 'src/module/entity_json/service/entity_json.service';
16
-
17
- /**
18
- * JSONB query condition structure
19
- */
20
- interface JsonbCondition {
21
- query: string;
22
- params: Record<string, any>;
23
- }
24
-
25
- @Injectable()
26
- export class FlatjsonFilterService {
27
- constructor(
28
- private readonly entityManager: EntityManager,
29
- private readonly entityMasterService: EntityMasterService,
30
- private readonly attributeMasterService: AttributeMasterService,
31
- private readonly resolverService: ResolverService,
32
- private readonly loggingService: LoggingService,
33
- private readonly configService: ConfigService,
34
- private readonly savedFilterRepositoryService: SavedFilterRepositoryService,
35
- @Inject(forwardRef(() => EntityJSONService))
36
- private readonly entityJsonService: EntityJSONService,
37
- ) {}
38
-
39
- /**
40
- * Main filtering method - queries frm_entity_json table
41
- */
42
- async applyFlatjsonFilter(dto: FilterRequestDto): Promise<any> {
43
- const {
44
- entity_type,
45
- quickFilter = [],
46
- savedFilterCode,
47
- attributeFilter = [],
48
- sortby = [],
49
- tabs,
50
- page = 1,
51
- size = 20,
52
- loggedInUser,
53
- } = dto;
54
-
55
- await this.loggingService.log(
56
- 'info',
57
- 'FlatjsonFilterService',
58
- 'applyFlatjsonFilter',
59
- `Filtering entity: ${entity_type}`,
60
- );
61
-
62
- // Step 1: Load attribute metadata for this entity
63
- let attributes =
64
- await this.entityJsonService.getAttributeForFlatJSON(
65
- entity_type,
66
- loggedInUser,
67
- 'filter_attribute',
68
- );
69
-
70
- if (!attributes?.length) {
71
- attributes =
72
- await this.attributeMasterService.findAttributesByMappedEntityType(
73
- entity_type,
74
- loggedInUser,
75
- );
76
- }
77
-
78
- attributes = attributes ?? [];
79
-
80
- const attributeMetaMap: Record<string, any> = {};
81
- attributes.forEach((attr) => {
82
- attributeMetaMap[attr.flat_json_key] = attr;
83
- });
84
-
85
- await this.loggingService.log(
86
- 'debug',
87
- 'FlatjsonFilterService',
88
- 'applyFlatjsonFilter',
89
- `Loaded ${attributes.length} attributes`,
90
- );
91
-
92
- // Step 2: Merge filters (quickFilter + savedFilter + attributeFilter)
93
- let allFilters: FilterCondition[] = [...quickFilter, ...attributeFilter];
94
-
95
- if (savedFilterCode) {
96
- const savedFilterDetails =
97
- await this.savedFilterRepositoryService.getDetailsByCode(
98
- savedFilterCode,
99
- );
100
- allFilters = [...allFilters, ...savedFilterDetails];
101
- }
102
-
103
- await this.loggingService.log(
104
- 'debug',
105
- 'FlatjsonFilterService',
106
- 'applyFlatjsonFilter',
107
- `Total filters: ${allFilters.length}`,
108
- );
109
-
110
- // Step 3: Build JSONB conditions
111
- const jsonbConditions = this.buildJsonbConditions(
112
- allFilters,
113
- attributeMetaMap,
114
- );
115
-
116
- // Step 4: Build base query
117
- const qb = this.entityManager
118
- .getRepository(EntityJson)
119
- .createQueryBuilder('ej')
120
- .where('ej.entity_type = :entity_type', { entity_type })
121
- .andWhere('ej.organization_id = :orgId', {
122
- orgId: loggedInUser.organization_id,
123
- });
124
-
125
- // Step 5: Apply JSONB conditions
126
- jsonbConditions.forEach((condition, index) => {
127
- qb.andWhere(condition.query, condition.params);
128
- });
129
-
130
- // Step 6: Apply tab filter if provided
131
- if (tabs?.columnName && tabs?.value) {
132
- const tabMeta = attributeMetaMap[tabs.columnName];
133
- if (tabMeta) {
134
- const flatJsonKey =
135
- tabMeta.flat_json_key ||
136
- `${entity_type}__${tabs.columnName}`;
137
- qb.andWhere(`json_data->>'${flatJsonKey}' = :tabValue`, {
138
- tabValue: tabs.value,
139
- });
140
- }
141
- }
142
-
143
- // Step 7: Get tab counts if needed (before pagination)
144
- let tabCounts: any[] = [];
145
- if (tabs?.columnName && !tabs?.value) {
146
- const tabMeta = attributeMetaMap[tabs.columnName];
147
- if (tabMeta) {
148
- const flatJsonKey =
149
- tabMeta.flat_json_key ||
150
- `${entity_type}__${tabs.columnName}`;
151
- tabCounts = await this.getJsonbTabCounts(
152
- entity_type,
153
- flatJsonKey,
154
- jsonbConditions,
155
- );
156
- }
157
- }
158
-
159
- // Step 8: Apply sorting
160
- if (sortby && sortby.length > 0) {
161
- this.applyJsonbSorting(qb, sortby, attributeMetaMap);
162
- } else {
163
- // Default sort by created_date DESC
164
- qb.orderBy('ej.created_at', 'DESC');
165
- }
166
-
167
- // Step 9: Get total count (before pagination)
168
- const totalCount = await qb.getCount();
169
-
170
- // Step 10: Apply pagination
171
- if (page && size) {
172
- const skip = (page - 1) * size;
173
- qb.skip(skip).take(size);
174
- }
175
-
176
- // Step 11: Execute query
177
- const results = await qb.getMany();
178
-
179
- await this.loggingService.log(
180
- 'info',
181
- 'FlatjsonFilterService',
182
- 'applyFlatjsonFilter',
183
- `Found ${totalCount} total, returning ${results.length} records`,
184
- );
185
-
186
- // // Step 12: Resolve entity IDs to full entity data
187
- // const resolvedData = await this.resolveEntityData(
188
- // results,
189
- // entity_type,
190
- // loggedInUser,
191
- // );
192
-
193
- return {
194
- data: results,
195
- total: totalCount,
196
- page: page || 1,
197
- size: size || 20,
198
- totalPages: size ? Math.ceil(totalCount / size) : 1,
199
- tabCounts: tabCounts.length > 0 ? tabCounts : undefined,
200
- };
201
- }
202
-
203
- /**
204
- * Build JSONB where clauses from filter conditions
205
- */
206
- private buildJsonbConditions(
207
- filters: FilterCondition[],
208
- attributeMetaMap: Record<string, any>,
209
- ): JsonbCondition[] {
210
- const conditions: JsonbCondition[] = [];
211
-
212
- for (const filter of filters) {
213
- const meta = attributeMetaMap[filter.filter_attribute];
214
- const condition = this.buildJsonbCondition(filter, meta);
215
-
216
- if (condition) {
217
- conditions.push(condition);
218
- } else {
219
- console.warn(
220
- `Could not build condition for filter: ${filter.filter_attribute}`,
221
- );
222
- }
223
- }
224
-
225
- return conditions;
226
- }
227
-
228
- /**
229
- * Resolve entity IDs to full entity data
230
- */
231
- private async resolveEntityData(
232
- entityJsonRecords: EntityJson[],
233
- entity_type: string,
234
- loggedInUser: any,
235
- ): Promise<any[]> {
236
- if (entityJsonRecords.length === 0) return [];
237
-
238
- const entityIds = entityJsonRecords.map((ej) => ej.entity_id);
239
-
240
- try {
241
- // Use resolver service to get full entity data
242
- const fullEntities = await this.resolverService.getResolvedData(
243
- entity_type,
244
- entityIds,
245
- loggedInUser,
246
- );
247
-
248
- // Return with json_data merged
249
- return entityJsonRecords.map((ej) => {
250
- const fullEntity = fullEntities.find((e) => e.id === ej.entity_id);
251
- return {
252
- ...fullEntity,
253
- _flatjson: ej.json_data, // Include flatjson for debugging
254
- };
255
- });
256
- } catch (error) {
257
- console.error('Error resolving entity data:', error);
258
- // Fallback: return just the entity IDs with json_data
259
- return entityJsonRecords.map((ej) => ({
260
- id: ej.entity_id,
261
- entity_type: ej.entity_type,
262
- ...ej.json_data,
263
- }));
264
- }
265
- }
266
-
267
- /**
268
- * Build a single JSONB condition based on data type
269
- */
270
- private buildJsonbCondition(
271
- filter: FilterCondition,
272
- meta: any,
273
- ): JsonbCondition | null {
274
- if (!meta) return null;
275
-
276
- const flatJsonKey =
277
- meta.flat_json_key ||
278
- `${meta.mapped_entity_type}__${filter.filter_attribute}`;
279
- const op = filter.filter_operator;
280
- const val = filter.filter_value;
281
- const key = `param_${filter.filter_attribute}_${Math.random().toString(36).substring(2, 8)}`;
282
-
283
- switch (meta.data_type) {
284
- case 'text':
285
- return this.buildTextCondition(flatJsonKey, op, val, key);
286
- case 'number':
287
- return this.buildNumberCondition(flatJsonKey, op, val, key);
288
- case 'date':
289
- return this.buildDateCondition(flatJsonKey, op, val, key);
290
- case 'select':
291
- case 'radio':
292
- return this.buildSelectCondition(flatJsonKey, op, val, key);
293
- case 'multiselect':
294
- case 'checkbox':
295
- return this.buildMultiSelectCondition(flatJsonKey, op, val, key);
296
- case 'year':
297
- return this.buildYearCondition(flatJsonKey, op, val, key);
298
- default:
299
- return null;
300
- }
301
- }
302
-
303
- /**
304
- * Build text condition (JSONB ->> operator)
305
- */
306
- private buildTextCondition(
307
- flatJsonKey: string,
308
- operator: string,
309
- value: any,
310
- paramKey: string,
311
- ): JsonbCondition | null {
312
- // Text is already stored lowercase in flatjson
313
- const lowerValue = value ? String(value).toLowerCase() : '';
314
-
315
- switch (operator) {
316
- case 'equal':
317
- return {
318
- query: `json_data->>'${flatJsonKey}' = :${paramKey}`,
319
- params: { [paramKey]: lowerValue },
320
- };
321
-
322
- case 'not_equal':
323
- return {
324
- query: `json_data->>'${flatJsonKey}' != :${paramKey}`,
325
- params: { [paramKey]: lowerValue },
326
- };
327
-
328
- case 'contains':
329
- return {
330
- query: `json_data->>'${flatJsonKey}' LIKE :${paramKey}`,
331
- params: { [paramKey]: `%${lowerValue}%` },
332
- };
333
-
334
- case 'not_contains':
335
- return {
336
- query: `json_data->>'${flatJsonKey}' NOT LIKE :${paramKey}`,
337
- params: { [paramKey]: `%${lowerValue}%` },
338
- };
339
-
340
- case 'starts_with':
341
- return {
342
- query: `json_data->>'${flatJsonKey}' LIKE :${paramKey}`,
343
- params: { [paramKey]: `${lowerValue}%` },
344
- };
345
-
346
- case 'ends_with':
347
- return {
348
- query: `json_data->>'${flatJsonKey}' LIKE :${paramKey}`,
349
- params: { [paramKey]: `%${lowerValue}` },
350
- };
351
-
352
- case 'empty':
353
- return {
354
- query: `(json_data->>'${flatJsonKey}' IS NULL OR json_data->>'${flatJsonKey}' = '')`,
355
- params: {},
356
- };
357
-
358
- case 'not_empty':
359
- return {
360
- query: `(json_data->>'${flatJsonKey}' IS NOT NULL AND json_data->>'${flatJsonKey}' != '')`,
361
- params: {},
362
- };
363
-
364
- default:
365
- console.warn(`Unsupported text operator: ${operator}`);
366
- return null;
367
- }
368
- }
369
-
370
- /**
371
- * Build number condition (JSONB ->> with ::numeric cast)
372
- */
373
- private buildNumberCondition(
374
- flatJsonKey: string,
375
- operator: string,
376
- value: any,
377
- paramKey: string,
378
- ): JsonbCondition | null {
379
- // Cast JSONB text to numeric for comparison
380
- const jsonbField = `(json_data->>'${flatJsonKey}')::numeric`;
381
-
382
- switch (operator) {
383
- case 'equal':
384
- return {
385
- query: `${jsonbField} = :${paramKey}`,
386
- params: { [paramKey]: Number(value) },
387
- };
388
-
389
- case 'not_equal':
390
- return {
391
- query: `${jsonbField} != :${paramKey}`,
392
- params: { [paramKey]: Number(value) },
393
- };
394
-
395
- case 'greater_than':
396
- return {
397
- query: `${jsonbField} > :${paramKey}`,
398
- params: { [paramKey]: Number(value) },
399
- };
400
-
401
- case 'less_than':
402
- return {
403
- query: `${jsonbField} < :${paramKey}`,
404
- params: { [paramKey]: Number(value) },
405
- };
406
-
407
- case 'greater_than_equal_to':
408
- return {
409
- query: `${jsonbField} >= :${paramKey}`,
410
- params: { [paramKey]: Number(value) },
411
- };
412
-
413
- case 'less_than_equal_to':
414
- return {
415
- query: `${jsonbField} <= :${paramKey}`,
416
- params: { [paramKey]: Number(value) },
417
- };
418
-
419
- case 'between': {
420
- // Value should be array [min, max] or string "min,max"
421
- let range: number[];
422
- if (typeof value === 'string') {
423
- range = value.split(',').map((v) => Number(v.trim()));
424
- } else if (Array.isArray(value)) {
425
- range = value.map((v) => Number(v));
426
- } else {
427
- return null;
428
- }
429
-
430
- if (range.length !== 2) return null;
431
-
432
- return {
433
- query: `${jsonbField} BETWEEN :${paramKey}_min AND :${paramKey}_max`,
434
- params: {
435
- [`${paramKey}_min`]: range[0],
436
- [`${paramKey}_max`]: range[1],
437
- },
438
- };
439
- }
440
-
441
- case 'empty':
442
- return {
443
- query: `json_data->>'${flatJsonKey}' IS NULL`,
444
- params: {},
445
- };
446
-
447
- case 'not_empty':
448
- return {
449
- query: `json_data->>'${flatJsonKey}' IS NOT NULL`,
450
- params: {},
451
- };
452
-
453
- default:
454
- console.warn(`Unsupported number operator: ${operator}`);
455
- return null;
456
- }
457
- }
458
-
459
- /**
460
- * Build date condition (JSONB ->> with ::bigint cast for epoch ms)
461
- */
462
- private buildDateCondition(
463
- flatJsonKey: string,
464
- operator: string,
465
- value: any,
466
- paramKey: string,
467
- ): JsonbCondition | null {
468
- // Dates stored as epoch milliseconds (bigint)
469
- const jsonbField = `(json_data->>'${flatJsonKey}')::bigint`;
470
-
471
- // Helper: Convert date string to epoch ms
472
- const toEpochMs = (dateStr: string): number => {
473
- return new Date(dateStr).getTime();
474
- };
475
-
476
- // Helper: Get date N days ago
477
- const daysAgo = (days: number): number => {
478
- const d = new Date();
479
- d.setDate(d.getDate() - days);
480
- return d.getTime();
481
- };
482
-
483
- // Helper: Get date N days from now
484
- const daysFromNow = (days: number): number => {
485
- const d = new Date();
486
- d.setDate(d.getDate() + days);
487
- return d.getTime();
488
- };
489
-
490
- // Helper: Subtract business days (skip weekends)
491
- const subtractBusinessDays = (days: number): number => {
492
- let d = new Date();
493
- let count = 0;
494
-
495
- while (count < days) {
496
- d.setDate(d.getDate() - 1);
497
- const day = d.getDay(); // 0=Sun, 6=Sat
498
- if (day !== 0 && day !== 6) {
499
- count++;
500
- }
501
- }
502
-
503
- return d.getTime();
504
- };
505
-
506
- const numVal = Number(value);
507
-
508
- switch (operator) {
509
- // Basic comparisons
510
- case 'equal':
511
- case 'is':
512
- return {
513
- query: `${jsonbField} = :${paramKey}`,
514
- params: { [paramKey]: toEpochMs(value) },
515
- };
516
-
517
- case 'before':
518
- case 'is_before':
519
- return {
520
- query: `${jsonbField} < :${paramKey}`,
521
- params: { [paramKey]: toEpochMs(value) },
522
- };
523
-
524
- case 'after':
525
- case 'is_after':
526
- return {
527
- query: `${jsonbField} > :${paramKey}`,
528
- params: { [paramKey]: toEpochMs(value) },
529
- };
530
-
531
- case 'is_on_or_before':
532
- return {
533
- query: `${jsonbField} <= :${paramKey}`,
534
- params: { [paramKey]: toEpochMs(value) },
535
- };
536
-
537
- case 'is_on_or_after':
538
- return {
539
- query: `${jsonbField} >= :${paramKey}`,
540
- params: { [paramKey]: toEpochMs(value) },
541
- };
542
-
543
- // Day offset logic
544
- case 'is_day_before':
545
- if (isNaN(numVal)) return null;
546
- return {
547
- query: `${jsonbField} <= :${paramKey}`,
548
- params: { [paramKey]: daysAgo(numVal) },
549
- };
550
-
551
- case 'is_day_after':
552
- if (isNaN(numVal)) return null;
553
- return {
554
- query: `${jsonbField} >= :${paramKey}`,
555
- params: { [paramKey]: daysFromNow(numVal) },
556
- };
557
-
558
- // Business days (skip weekends)
559
- case 'is_before_business_days':
560
- if (isNaN(numVal)) return null;
561
- return {
562
- query: `${jsonbField} <= :${paramKey}`,
563
- params: { [paramKey]: subtractBusinessDays(numVal) },
564
- };
565
-
566
- // Range operators
567
- case 'between': {
568
- let range: string[];
569
- if (typeof value === 'string') {
570
- range = value.split(',').map((v) => v.trim());
571
- } else if (Array.isArray(value)) {
572
- range = value;
573
- } else {
574
- return null;
575
- }
576
-
577
- if (range.length !== 2) return null;
578
-
579
- return {
580
- query: `${jsonbField} BETWEEN :${paramKey}_start AND :${paramKey}_end`,
581
- params: {
582
- [`${paramKey}_start`]: toEpochMs(range[0]),
583
- [`${paramKey}_end`]: toEpochMs(range[1]),
584
- },
585
- };
586
- }
587
-
588
- case 'in_last_day':
589
- if (isNaN(numVal)) return null;
590
- return {
591
- query: `${jsonbField} BETWEEN :${paramKey}_start AND :${paramKey}_end`,
592
- params: {
593
- [`${paramKey}_start`]: daysAgo(numVal),
594
- [`${paramKey}_end`]: Date.now(),
595
- },
596
- };
597
-
598
- case 'in_next_day':
599
- if (isNaN(numVal)) return null;
600
- return {
601
- query: `${jsonbField} BETWEEN :${paramKey}_start AND :${paramKey}_end`,
602
- params: {
603
- [`${paramKey}_start`]: Date.now(),
604
- [`${paramKey}_end`]: daysFromNow(numVal),
605
- },
606
- };
607
-
608
- // Special cases
609
- case 'today': {
610
- const todayStart = new Date().setHours(0, 0, 0, 0);
611
- const todayEnd = new Date().setHours(23, 59, 59, 999);
612
- return {
613
- query: `${jsonbField} BETWEEN :${paramKey}_start AND :${paramKey}_end`,
614
- params: {
615
- [`${paramKey}_start`]: todayStart,
616
- [`${paramKey}_end`]: todayEnd,
617
- },
618
- };
619
- }
620
-
621
- case 'empty':
622
- return {
623
- query: `json_data->>'${flatJsonKey}' IS NULL`,
624
- params: {},
625
- };
626
-
627
- case 'not_empty':
628
- return {
629
- query: `json_data->>'${flatJsonKey}' IS NOT NULL`,
630
- params: {},
631
- };
632
-
633
- default:
634
- console.warn(`Unsupported date operator: ${operator}`);
635
- return null;
636
- }
637
- }
638
-
639
- /**
640
- * Build select condition (single value)
641
- */
642
- private buildSelectCondition(
643
- flatJsonKey: string,
644
- operator: string,
645
- value: any,
646
- paramKey: string,
647
- ): JsonbCondition | null {
648
- switch (operator) {
649
- case 'equal':
650
- if (Array.isArray(value)) {
651
- // IN operator for multiple values
652
- return {
653
- query: `json_data->>'${flatJsonKey}' = ANY(:${paramKey})`,
654
- params: { [paramKey]: value.map(String) },
655
- };
656
- }
657
- return {
658
- query: `json_data->>'${flatJsonKey}' = :${paramKey}`,
659
- params: { [paramKey]: String(value) },
660
- };
661
-
662
- case 'not_equal':
663
- if (Array.isArray(value)) {
664
- // NOT IN operator
665
- return {
666
- query: `json_data->>'${flatJsonKey}' != ALL(:${paramKey})`,
667
- params: { [paramKey]: value.map(String) },
668
- };
669
- }
670
- return {
671
- query: `json_data->>'${flatJsonKey}' != :${paramKey}`,
672
- params: { [paramKey]: String(value) },
673
- };
674
-
675
- case 'in': {
676
- const inValues = Array.isArray(value) ? value : [value];
677
- return {
678
- query: `json_data->>'${flatJsonKey}' = ANY(:${paramKey})`,
679
- params: { [paramKey]: inValues.map(String) },
680
- };
681
- }
682
-
683
- case 'not_in': {
684
- const notInValues = Array.isArray(value) ? value : [value];
685
- return {
686
- query: `json_data->>'${flatJsonKey}' != ALL(:${paramKey})`,
687
- params: { [paramKey]: notInValues.map(String) },
688
- };
689
- }
690
-
691
- case 'empty':
692
- return {
693
- query: `json_data->>'${flatJsonKey}' IS NULL`,
694
- params: {},
695
- };
696
-
697
- case 'not_empty':
698
- return {
699
- query: `json_data->>'${flatJsonKey}' IS NOT NULL`,
700
- params: {},
701
- };
702
-
703
- default:
704
- console.warn(`Unsupported select operator: ${operator}`);
705
- return null;
706
- }
707
- }
708
-
709
- /**
710
- * Build multiselect condition (JSONB -> with ? operators for arrays)
711
- */
712
- private buildMultiSelectCondition(
713
- flatJsonKey: string,
714
- operator: string,
715
- value: any,
716
- paramKey: string,
717
- ): JsonbCondition | null {
718
- // Convert value to array if not already
719
- let arr: string[];
720
- if (Array.isArray(value)) {
721
- arr = value.map(String);
722
- } else if (typeof value === 'string') {
723
- arr = value.split(',').map((v) => v.trim());
724
- } else {
725
- arr = [String(value)];
726
- }
727
-
728
- if (arr.length === 0) {
729
- return { query: '1=1', params: {} }; // Always true for empty array
730
- }
731
-
732
- switch (operator) {
733
- case 'contains':
734
- case 'has':
735
- // Check if JSON array contains this element
736
- // json_data->'LEAD__languages' ? 'hindi'
737
- if (arr.length === 1) {
738
- return {
739
- query: `json_data->'${flatJsonKey}' ? :${paramKey}`,
740
- params: { [paramKey]: arr[0] },
741
- };
742
- }
743
- // For multiple values, check if contains ANY
744
- return {
745
- query: `json_data->'${flatJsonKey}' ?| ARRAY[:...${paramKey}]::text[]`,
746
- params: { [paramKey]: arr },
747
- };
748
-
749
- case 'contains_all':
750
- // Check if JSON array contains ALL elements
751
- // json_data->'LEAD__languages' ?& ARRAY['hindi', 'english']
752
- return {
753
- query: `json_data->'${flatJsonKey}' ?& ARRAY[:...${paramKey}]::text[]`,
754
- params: { [paramKey]: arr },
755
- };
756
-
757
- case 'contains_any':
758
- // Check if JSON array contains ANY element
759
- // json_data->'LEAD__languages' ?| ARRAY['hindi', 'english']
760
- return {
761
- query: `json_data->'${flatJsonKey}' ?| ARRAY[:...${paramKey}]::text[]`,
762
- params: { [paramKey]: arr },
763
- };
764
-
765
- case 'not_contains':
766
- // Check if JSON array does NOT contain element
767
- if (arr.length === 1) {
768
- return {
769
- query: `NOT (json_data->'${flatJsonKey}' ? :${paramKey})`,
770
- params: { [paramKey]: arr[0] },
771
- };
772
- }
773
- return {
774
- query: `NOT (json_data->'${flatJsonKey}' ?| ARRAY[:...${paramKey}]::text[])`,
775
- params: { [paramKey]: arr },
776
- };
777
-
778
- case 'equal':
779
- // Exact array match (order matters in PostgreSQL)
780
- return {
781
- query: `json_data->'${flatJsonKey}'::jsonb = :${paramKey}::jsonb`,
782
- params: { [paramKey]: JSON.stringify(arr) },
783
- };
784
-
785
- case 'empty':
786
- return {
787
- query: `(json_data->>'${flatJsonKey}' IS NULL OR json_data->'${flatJsonKey}' = '[]'::jsonb)`,
788
- params: {},
789
- };
790
-
791
- case 'not_empty':
792
- return {
793
- query: `(json_data->>'${flatJsonKey}' IS NOT NULL AND json_data->'${flatJsonKey}' != '[]'::jsonb)`,
794
- params: {},
795
- };
796
-
797
- default:
798
- console.warn(`Unsupported multiselect operator: ${operator}`);
799
- return null;
800
- }
801
- }
802
-
803
- /**
804
- * Build year condition
805
- */
806
- private buildYearCondition(
807
- flatJsonKey: string,
808
- operator: string,
809
- value: any,
810
- paramKey: string,
811
- ): JsonbCondition | null {
812
- // Similar to number condition
813
- return this.buildNumberCondition(flatJsonKey, operator, value, paramKey);
814
- }
815
-
816
- /**
817
- * Get tab aggregation counts from JSONB
818
- */
819
- private async getJsonbTabCounts(
820
- entity_type: string,
821
- flatJsonKey: string,
822
- whereClauses: JsonbCondition[],
823
- ): Promise<Array<{ tab_value: string; tab_value_count: number }>> {
824
- // Build a query that groups by the tab field
825
- const qb = this.entityManager
826
- .getRepository(EntityJson)
827
- .createQueryBuilder('ej')
828
- .select(`json_data->>'${flatJsonKey}'`, 'tab_value')
829
- .addSelect('COUNT(*)', 'tab_value_count')
830
- .where('ej.entity_type = :entity_type', { entity_type })
831
- .groupBy(`json_data->>'${flatJsonKey}'`);
832
-
833
- // Apply the same filter conditions (but not the tab filter itself)
834
- whereClauses.forEach((condition) => {
835
- qb.andWhere(condition.query, condition.params);
836
- });
837
-
838
- const results = await qb.getRawMany();
839
-
840
- // Filter out NULL/undefined tab values and convert count to number
841
- return results
842
- .filter((r) => r.tab_value != null && r.tab_value !== '')
843
- .map((r) => ({
844
- tab_value: r.tab_value,
845
- tab_value_count: parseInt(r.tab_value_count, 10),
846
- }))
847
- .sort((a, b) => b.tab_value_count - a.tab_value_count); // Sort by count DESC
848
- }
849
-
850
- /**
851
- * Apply sorting on JSONB fields
852
- */
853
- private applyJsonbSorting(
854
- qb: SelectQueryBuilder<EntityJson>,
855
- sortby: SortConfig[],
856
- attributeMetaMap: Record<string, any>,
857
- ): void {
858
- sortby.forEach((sort, index) => {
859
- const meta = attributeMetaMap[sort.sortColum];
860
-
861
- if (!meta) {
862
- console.warn(`No metadata found for sort column: ${sort.sortColum}`);
863
- return;
864
- }
865
-
866
- const flatJsonKey =
867
- meta.flat_json_key || `${meta.mapped_entity_type}__${sort.sortColum}`;
868
- const direction = sort.sortType === 'ASC' ? 'ASC' : 'DESC';
869
-
870
- // Apply type-specific casting for proper sorting
871
- let sortExpression: string;
872
-
873
- switch (meta.data_type) {
874
- case 'number':
875
- case 'year':
876
- // Cast to numeric for number sorting
877
- sortExpression = `(json_data->>'${flatJsonKey}')::numeric`;
878
- break;
879
-
880
- case 'date':
881
- // Cast to bigint for date sorting (epoch ms)
882
- sortExpression = `(json_data->>'${flatJsonKey}')::bigint`;
883
- break;
884
-
885
- case 'text':
886
- case 'select':
887
- case 'radio':
888
- default:
889
- // Text sorting (already lowercase)
890
- sortExpression = `json_data->>'${flatJsonKey}'`;
891
- break;
892
- }
893
-
894
- // Add to ORDER BY clause
895
- if (index === 0) {
896
- qb.orderBy(sortExpression, direction);
897
- } else {
898
- qb.addOrderBy(sortExpression, direction);
899
- }
900
- });
901
- }
902
- }