@solidxai/core 0.1.6 → 0.1.8-beta.0

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 (784) hide show
  1. package/CHANGELOG.md +71 -0
  2. package/dist/controllers/dashboard-layout.controller.d.ts +47 -0
  3. package/dist/controllers/dashboard-layout.controller.d.ts.map +1 -0
  4. package/dist/controllers/dashboard-layout.controller.js +204 -0
  5. package/dist/controllers/dashboard-layout.controller.js.map +1 -0
  6. package/dist/controllers/scheduled-job.controller.d.ts +1 -0
  7. package/dist/controllers/scheduled-job.controller.d.ts.map +1 -1
  8. package/dist/controllers/scheduled-job.controller.js +12 -0
  9. package/dist/controllers/scheduled-job.controller.js.map +1 -1
  10. package/dist/dtos/create-dashboard-layout.dto.d.ts +8 -0
  11. package/dist/dtos/create-dashboard-layout.dto.d.ts.map +1 -0
  12. package/dist/dtos/create-dashboard-layout.dto.js +53 -0
  13. package/dist/dtos/create-dashboard-layout.dto.js.map +1 -0
  14. package/dist/dtos/create-dashboard-variable.dto.d.ts +1 -0
  15. package/dist/dtos/create-dashboard-variable.dto.d.ts.map +1 -1
  16. package/dist/dtos/create-dashboard-variable.dto.js +7 -1
  17. package/dist/dtos/create-dashboard-variable.dto.js.map +1 -1
  18. package/dist/dtos/update-dashboard-layout.dto.d.ts +8 -0
  19. package/dist/dtos/update-dashboard-layout.dto.d.ts.map +1 -0
  20. package/dist/dtos/update-dashboard-layout.dto.js +53 -0
  21. package/dist/dtos/update-dashboard-layout.dto.js.map +1 -0
  22. package/dist/dtos/update-dashboard-variable.dto.d.ts +1 -0
  23. package/dist/dtos/update-dashboard-variable.dto.d.ts.map +1 -1
  24. package/dist/dtos/update-dashboard-variable.dto.js +7 -1
  25. package/dist/dtos/update-dashboard-variable.dto.js.map +1 -1
  26. package/dist/entities/action-metadata.entity.d.ts.map +1 -1
  27. package/dist/entities/action-metadata.entity.js.map +1 -1
  28. package/dist/entities/ai-interaction.entity.d.ts.map +1 -1
  29. package/dist/entities/ai-interaction.entity.js +5 -4
  30. package/dist/entities/ai-interaction.entity.js.map +1 -1
  31. package/dist/entities/chatter-message-details.entity.d.ts +1 -0
  32. package/dist/entities/chatter-message-details.entity.d.ts.map +1 -1
  33. package/dist/entities/chatter-message-details.entity.js +9 -4
  34. package/dist/entities/chatter-message-details.entity.js.map +1 -1
  35. package/dist/entities/chatter-message.entity.d.ts.map +1 -1
  36. package/dist/entities/chatter-message.entity.js +4 -3
  37. package/dist/entities/chatter-message.entity.js.map +1 -1
  38. package/dist/entities/common.entity.js +1 -1
  39. package/dist/entities/common.entity.js.map +1 -1
  40. package/dist/entities/dashboard-layout.entity.d.ts +9 -0
  41. package/dist/entities/dashboard-layout.entity.d.ts.map +1 -0
  42. package/dist/entities/dashboard-layout.entity.js +41 -0
  43. package/dist/entities/dashboard-layout.entity.js.map +1 -0
  44. package/dist/entities/dashboard-question-sql-dataset-config.entity.d.ts.map +1 -1
  45. package/dist/entities/dashboard-question-sql-dataset-config.entity.js +5 -4
  46. package/dist/entities/dashboard-question-sql-dataset-config.entity.js.map +1 -1
  47. package/dist/entities/dashboard-question.entity.d.ts.map +1 -1
  48. package/dist/entities/dashboard-question.entity.js +5 -4
  49. package/dist/entities/dashboard-question.entity.js.map +1 -1
  50. package/dist/entities/dashboard-variable.entity.d.ts +1 -0
  51. package/dist/entities/dashboard-variable.entity.d.ts.map +1 -1
  52. package/dist/entities/dashboard-variable.entity.js +10 -4
  53. package/dist/entities/dashboard-variable.entity.js.map +1 -1
  54. package/dist/entities/dashboard.entity.d.ts +2 -0
  55. package/dist/entities/dashboard.entity.d.ts.map +1 -1
  56. package/dist/entities/dashboard.entity.js +9 -3
  57. package/dist/entities/dashboard.entity.js.map +1 -1
  58. package/dist/entities/email-attachment.entity.d.ts.map +1 -1
  59. package/dist/entities/email-attachment.entity.js +2 -1
  60. package/dist/entities/email-attachment.entity.js.map +1 -1
  61. package/dist/entities/email-template.entity.js +1 -1
  62. package/dist/entities/email-template.entity.js.map +1 -1
  63. package/dist/entities/export-transaction.entity.d.ts.map +1 -1
  64. package/dist/entities/export-transaction.entity.js +2 -1
  65. package/dist/entities/export-transaction.entity.js.map +1 -1
  66. package/dist/entities/field-metadata.entity.js +2 -2
  67. package/dist/entities/field-metadata.entity.js.map +1 -1
  68. package/dist/entities/import-transaction-error-log.entity.d.ts.map +1 -1
  69. package/dist/entities/import-transaction-error-log.entity.js +3 -2
  70. package/dist/entities/import-transaction-error-log.entity.js.map +1 -1
  71. package/dist/entities/import-transaction.entity.d.ts.map +1 -1
  72. package/dist/entities/import-transaction.entity.js +2 -1
  73. package/dist/entities/import-transaction.entity.js.map +1 -1
  74. package/dist/entities/legacy-common.entity.d.ts.map +1 -1
  75. package/dist/entities/legacy-common.entity.js +1 -1
  76. package/dist/entities/legacy-common.entity.js.map +1 -1
  77. package/dist/entities/mq-message-queue.entity.d.ts.map +1 -1
  78. package/dist/entities/mq-message-queue.entity.js.map +1 -1
  79. package/dist/entities/mq-message.entity.d.ts.map +1 -1
  80. package/dist/entities/mq-message.entity.js +5 -3
  81. package/dist/entities/mq-message.entity.js.map +1 -1
  82. package/dist/entities/saved-filters.entity.d.ts.map +1 -1
  83. package/dist/entities/saved-filters.entity.js +3 -2
  84. package/dist/entities/saved-filters.entity.js.map +1 -1
  85. package/dist/entities/security-rule.entity.d.ts.map +1 -1
  86. package/dist/entities/security-rule.entity.js +2 -1
  87. package/dist/entities/security-rule.entity.js.map +1 -1
  88. package/dist/entities/sms-template.entity.js +1 -1
  89. package/dist/entities/sms-template.entity.js.map +1 -1
  90. package/dist/entities/user-view-metadata.entity.d.ts.map +1 -1
  91. package/dist/entities/user-view-metadata.entity.js +2 -1
  92. package/dist/entities/user-view-metadata.entity.js.map +1 -1
  93. package/dist/entities/user.entity.d.ts.map +1 -1
  94. package/dist/entities/user.entity.js +2 -0
  95. package/dist/entities/user.entity.js.map +1 -1
  96. package/dist/entities/view-metadata.entity.d.ts.map +1 -1
  97. package/dist/entities/view-metadata.entity.js.map +1 -1
  98. package/dist/helpers/bootstrap.helper.d.ts +14 -0
  99. package/dist/helpers/bootstrap.helper.d.ts.map +1 -0
  100. package/dist/helpers/bootstrap.helper.js +132 -0
  101. package/dist/helpers/bootstrap.helper.js.map +1 -0
  102. package/dist/helpers/cache.helper.d.ts +2 -0
  103. package/dist/helpers/cache.helper.d.ts.map +1 -0
  104. package/dist/helpers/cache.helper.js +8 -0
  105. package/dist/helpers/cache.helper.js.map +1 -0
  106. package/dist/helpers/cors.helper.d.ts.map +1 -1
  107. package/dist/helpers/cors.helper.js +13 -4
  108. package/dist/helpers/cors.helper.js.map +1 -1
  109. package/dist/helpers/field-crud-managers/SelectionDynamicFieldCrudManager.d.ts +2 -2
  110. package/dist/helpers/field-crud-managers/SelectionDynamicFieldCrudManager.d.ts.map +1 -1
  111. package/dist/helpers/field-crud-managers/SelectionDynamicFieldCrudManager.js +8 -5
  112. package/dist/helpers/field-crud-managers/SelectionDynamicFieldCrudManager.js.map +1 -1
  113. package/dist/helpers/solid-registry.d.ts +3 -0
  114. package/dist/helpers/solid-registry.d.ts.map +1 -1
  115. package/dist/helpers/solid-registry.js +7 -0
  116. package/dist/helpers/solid-registry.js.map +1 -1
  117. package/dist/helpers/typeorm-db-helper.d.ts.map +1 -1
  118. package/dist/helpers/typeorm-db-helper.js +21 -0
  119. package/dist/helpers/typeorm-db-helper.js.map +1 -1
  120. package/dist/index.d.ts +56 -15
  121. package/dist/index.d.ts.map +1 -1
  122. package/dist/index.js +56 -15
  123. package/dist/index.js.map +1 -1
  124. package/dist/interfaces.d.ts +8 -2
  125. package/dist/interfaces.d.ts.map +1 -1
  126. package/dist/interfaces.js +1 -0
  127. package/dist/interfaces.js.map +1 -1
  128. package/dist/jobs/database/chatter-queue-options-database.d.ts +8 -0
  129. package/dist/jobs/database/chatter-queue-options-database.d.ts.map +1 -0
  130. package/dist/jobs/database/chatter-queue-options-database.js +10 -0
  131. package/dist/jobs/database/chatter-queue-options-database.js.map +1 -0
  132. package/dist/jobs/database/chatter-queue-publisher-database.service.d.ts +12 -0
  133. package/dist/jobs/database/chatter-queue-publisher-database.service.d.ts.map +1 -0
  134. package/dist/jobs/database/chatter-queue-publisher-database.service.js +39 -0
  135. package/dist/jobs/database/chatter-queue-publisher-database.service.js.map +1 -0
  136. package/dist/jobs/database/chatter-queue-subscriber-database.service.d.ts +19 -0
  137. package/dist/jobs/database/chatter-queue-subscriber-database.service.d.ts.map +1 -0
  138. package/dist/jobs/database/chatter-queue-subscriber-database.service.js +62 -0
  139. package/dist/jobs/database/chatter-queue-subscriber-database.service.js.map +1 -0
  140. package/dist/jobs/{api-email-publisher.service.d.ts → rabbitmq/api-email-publisher.service.d.ts} +1 -1
  141. package/dist/jobs/rabbitmq/api-email-publisher.service.d.ts.map +1 -0
  142. package/dist/jobs/{api-email-publisher.service.js → rabbitmq/api-email-publisher.service.js} +3 -3
  143. package/dist/jobs/rabbitmq/api-email-publisher.service.js.map +1 -0
  144. package/dist/jobs/{api-email-queue-options.d.ts → rabbitmq/api-email-queue-options.d.ts} +1 -1
  145. package/dist/jobs/rabbitmq/api-email-queue-options.d.ts.map +1 -0
  146. package/dist/jobs/{api-email-queue-options.js → rabbitmq/api-email-queue-options.js} +1 -1
  147. package/dist/jobs/rabbitmq/api-email-queue-options.js.map +1 -0
  148. package/dist/jobs/{api-email-subscriber.service.d.ts → rabbitmq/api-email-subscriber.service.d.ts} +2 -2
  149. package/dist/jobs/rabbitmq/api-email-subscriber.service.d.ts.map +1 -0
  150. package/dist/jobs/{api-email-subscriber.service.js → rabbitmq/api-email-subscriber.service.js} +4 -4
  151. package/dist/jobs/rabbitmq/api-email-subscriber.service.js.map +1 -0
  152. package/dist/jobs/{chatter-queue-options.d.ts → rabbitmq/chatter-queue-options.d.ts} +1 -1
  153. package/dist/jobs/rabbitmq/chatter-queue-options.d.ts.map +1 -0
  154. package/dist/jobs/{chatter-queue-options.js → rabbitmq/chatter-queue-options.js} +2 -2
  155. package/dist/jobs/rabbitmq/chatter-queue-options.js.map +1 -0
  156. package/dist/jobs/rabbitmq/chatter-queue-publisher.service.d.ts +22 -0
  157. package/dist/jobs/rabbitmq/chatter-queue-publisher.service.d.ts.map +1 -0
  158. package/dist/jobs/{chatter-queue-publisher.service.js → rabbitmq/chatter-queue-publisher.service.js} +8 -8
  159. package/dist/jobs/rabbitmq/chatter-queue-publisher.service.js.map +1 -0
  160. package/dist/jobs/{chatter-queue-subscriber.service.d.ts → rabbitmq/chatter-queue-subscriber.service.d.ts} +7 -7
  161. package/dist/jobs/rabbitmq/chatter-queue-subscriber.service.d.ts.map +1 -0
  162. package/dist/jobs/rabbitmq/chatter-queue-subscriber.service.js +59 -0
  163. package/dist/jobs/rabbitmq/chatter-queue-subscriber.service.js.map +1 -0
  164. package/dist/jobs/rabbitmq/computed-field-evaluation-publisher.service.d.ts.map +1 -0
  165. package/dist/jobs/{computed-field-evaluation-publisher.service.js → rabbitmq/computed-field-evaluation-publisher.service.js} +3 -3
  166. package/dist/jobs/rabbitmq/computed-field-evaluation-publisher.service.js.map +1 -0
  167. package/dist/jobs/{computed-field-evaluation-queue-options.d.ts → rabbitmq/computed-field-evaluation-queue-options.d.ts} +3 -1
  168. package/dist/jobs/rabbitmq/computed-field-evaluation-queue-options.d.ts.map +1 -0
  169. package/dist/jobs/{computed-field-evaluation-queue-options.js → rabbitmq/computed-field-evaluation-queue-options.js} +3 -1
  170. package/dist/jobs/rabbitmq/computed-field-evaluation-queue-options.js.map +1 -0
  171. package/dist/jobs/rabbitmq/computed-field-evaluation-subscriber.service.d.ts.map +1 -0
  172. package/dist/jobs/{computed-field-evaluation-subscriber.service.js → rabbitmq/computed-field-evaluation-subscriber.service.js} +5 -5
  173. package/dist/jobs/rabbitmq/computed-field-evaluation-subscriber.service.js.map +1 -0
  174. package/dist/jobs/{generate-code-publisher.service.d.ts → rabbitmq/generate-code-publisher.service.d.ts} +3 -3
  175. package/dist/jobs/rabbitmq/generate-code-publisher.service.d.ts.map +1 -0
  176. package/dist/jobs/{generate-code-publisher.service.js → rabbitmq/generate-code-publisher.service.js} +3 -3
  177. package/dist/jobs/rabbitmq/generate-code-publisher.service.js.map +1 -0
  178. package/dist/jobs/rabbitmq/generate-code-queue-options.d.ts +8 -0
  179. package/dist/jobs/rabbitmq/generate-code-queue-options.d.ts.map +1 -0
  180. package/dist/jobs/{generate-code-queue-options.js → rabbitmq/generate-code-queue-options.js} +1 -1
  181. package/dist/jobs/rabbitmq/generate-code-queue-options.js.map +1 -0
  182. package/dist/jobs/rabbitmq/generate-code-subscriber.service.d.ts.map +1 -0
  183. package/dist/jobs/{generate-code-subscriber.service.js → rabbitmq/generate-code-subscriber.service.js} +6 -6
  184. package/dist/jobs/rabbitmq/generate-code-subscriber.service.js.map +1 -0
  185. package/dist/jobs/{msg91-otp-publisher.service.d.ts → rabbitmq/msg91-otp-publisher.service.d.ts} +1 -1
  186. package/dist/jobs/rabbitmq/msg91-otp-publisher.service.d.ts.map +1 -0
  187. package/dist/jobs/{msg91-otp-publisher.service.js → rabbitmq/msg91-otp-publisher.service.js} +3 -3
  188. package/dist/jobs/rabbitmq/msg91-otp-publisher.service.js.map +1 -0
  189. package/dist/jobs/{msg91-otp-queue-options.d.ts → rabbitmq/msg91-otp-queue-options.d.ts} +1 -1
  190. package/dist/jobs/rabbitmq/msg91-otp-queue-options.d.ts.map +1 -0
  191. package/dist/jobs/{msg91-otp-queue-options.js → rabbitmq/msg91-otp-queue-options.js} +1 -1
  192. package/dist/jobs/rabbitmq/msg91-otp-queue-options.js.map +1 -0
  193. package/dist/jobs/{msg91-otp-subscriber.service.d.ts → rabbitmq/msg91-otp-subscriber.service.d.ts} +1 -1
  194. package/dist/jobs/rabbitmq/msg91-otp-subscriber.service.d.ts.map +1 -0
  195. package/dist/jobs/{msg91-otp-subscriber.service.js → rabbitmq/msg91-otp-subscriber.service.js} +5 -5
  196. package/dist/jobs/rabbitmq/msg91-otp-subscriber.service.js.map +1 -0
  197. package/dist/jobs/{msg91-sms-publisher.service.d.ts → rabbitmq/msg91-sms-publisher.service.d.ts} +1 -1
  198. package/dist/jobs/rabbitmq/msg91-sms-publisher.service.d.ts.map +1 -0
  199. package/dist/jobs/{msg91-sms-publisher.service.js → rabbitmq/msg91-sms-publisher.service.js} +3 -3
  200. package/dist/jobs/rabbitmq/msg91-sms-publisher.service.js.map +1 -0
  201. package/dist/jobs/{msg91-sms-queue-options.d.ts → rabbitmq/msg91-sms-queue-options.d.ts} +1 -1
  202. package/dist/jobs/rabbitmq/msg91-sms-queue-options.d.ts.map +1 -0
  203. package/dist/jobs/{msg91-sms-queue-options.js → rabbitmq/msg91-sms-queue-options.js} +1 -1
  204. package/dist/jobs/rabbitmq/msg91-sms-queue-options.js.map +1 -0
  205. package/dist/jobs/{msg91-sms-subscriber.service.d.ts → rabbitmq/msg91-sms-subscriber.service.d.ts} +1 -1
  206. package/dist/jobs/rabbitmq/msg91-sms-subscriber.service.d.ts.map +1 -0
  207. package/dist/jobs/{msg91-sms-subscriber.service.js → rabbitmq/msg91-sms-subscriber.service.js} +5 -5
  208. package/dist/jobs/rabbitmq/msg91-sms-subscriber.service.js.map +1 -0
  209. package/dist/jobs/{msg91-whatsapp-publisher.service.d.ts → rabbitmq/msg91-whatsapp-publisher.service.d.ts} +1 -1
  210. package/dist/jobs/rabbitmq/msg91-whatsapp-publisher.service.d.ts.map +1 -0
  211. package/dist/jobs/{msg91-whatsapp-publisher.service.js → rabbitmq/msg91-whatsapp-publisher.service.js} +3 -3
  212. package/dist/jobs/rabbitmq/msg91-whatsapp-publisher.service.js.map +1 -0
  213. package/dist/jobs/{msg91-whatsapp-queue-options.d.ts → rabbitmq/msg91-whatsapp-queue-options.d.ts} +1 -1
  214. package/dist/jobs/rabbitmq/msg91-whatsapp-queue-options.d.ts.map +1 -0
  215. package/dist/jobs/{msg91-whatsapp-queue-options.js → rabbitmq/msg91-whatsapp-queue-options.js} +1 -1
  216. package/dist/jobs/rabbitmq/msg91-whatsapp-queue-options.js.map +1 -0
  217. package/dist/jobs/{msg91-whatsapp-subscriber.service.d.ts → rabbitmq/msg91-whatsapp-subscriber.service.d.ts} +2 -2
  218. package/dist/jobs/rabbitmq/msg91-whatsapp-subscriber.service.d.ts.map +1 -0
  219. package/dist/jobs/{msg91-whatsapp-subscriber.service.js → rabbitmq/msg91-whatsapp-subscriber.service.js} +4 -4
  220. package/dist/jobs/rabbitmq/msg91-whatsapp-subscriber.service.js.map +1 -0
  221. package/dist/jobs/{smtp-email-publisher.service.d.ts → rabbitmq/smtp-email-publisher.service.d.ts} +1 -1
  222. package/dist/jobs/rabbitmq/smtp-email-publisher.service.d.ts.map +1 -0
  223. package/dist/jobs/{smtp-email-publisher.service.js → rabbitmq/smtp-email-publisher.service.js} +3 -3
  224. package/dist/jobs/rabbitmq/smtp-email-publisher.service.js.map +1 -0
  225. package/dist/jobs/{smtp-email-queue-options.d.ts → rabbitmq/smtp-email-queue-options.d.ts} +1 -1
  226. package/dist/jobs/rabbitmq/smtp-email-queue-options.d.ts.map +1 -0
  227. package/dist/jobs/{smtp-email-queue-options.js → rabbitmq/smtp-email-queue-options.js} +1 -1
  228. package/dist/jobs/rabbitmq/smtp-email-queue-options.js.map +1 -0
  229. package/dist/jobs/{smtp-email-subscriber.service.d.ts → rabbitmq/smtp-email-subscriber.service.d.ts} +2 -2
  230. package/dist/jobs/rabbitmq/smtp-email-subscriber.service.d.ts.map +1 -0
  231. package/dist/jobs/{smtp-email-subscriber.service.js → rabbitmq/smtp-email-subscriber.service.js} +4 -4
  232. package/dist/jobs/rabbitmq/smtp-email-subscriber.service.js.map +1 -0
  233. package/dist/jobs/{test-queue-options.d.ts → rabbitmq/test-queue-options.d.ts} +1 -1
  234. package/dist/jobs/rabbitmq/test-queue-options.d.ts.map +1 -0
  235. package/dist/jobs/{test-queue-options.js → rabbitmq/test-queue-options.js} +1 -1
  236. package/dist/jobs/rabbitmq/test-queue-options.js.map +1 -0
  237. package/dist/jobs/{test-queue-publisher.service.d.ts → rabbitmq/test-queue-publisher.service.d.ts} +3 -3
  238. package/dist/jobs/rabbitmq/test-queue-publisher.service.d.ts.map +1 -0
  239. package/dist/jobs/{test-queue-publisher.service.js → rabbitmq/test-queue-publisher.service.js} +3 -3
  240. package/dist/jobs/rabbitmq/test-queue-publisher.service.js.map +1 -0
  241. package/dist/jobs/{test-queue-subscriber.service.d.ts → rabbitmq/test-queue-subscriber.service.d.ts} +3 -3
  242. package/dist/jobs/rabbitmq/test-queue-subscriber.service.d.ts.map +1 -0
  243. package/dist/jobs/{test-queue-subscriber.service.js → rabbitmq/test-queue-subscriber.service.js} +3 -3
  244. package/dist/jobs/rabbitmq/test-queue-subscriber.service.js.map +1 -0
  245. package/dist/jobs/{three60-whatsapp-publisher.service.d.ts → rabbitmq/three60-whatsapp-publisher.service.d.ts} +1 -1
  246. package/dist/jobs/rabbitmq/three60-whatsapp-publisher.service.d.ts.map +1 -0
  247. package/dist/jobs/{three60-whatsapp-publisher.service.js → rabbitmq/three60-whatsapp-publisher.service.js} +3 -3
  248. package/dist/jobs/rabbitmq/three60-whatsapp-publisher.service.js.map +1 -0
  249. package/dist/jobs/{three60-whatsapp-queue-options.d.ts → rabbitmq/three60-whatsapp-queue-options.d.ts} +1 -1
  250. package/dist/jobs/rabbitmq/three60-whatsapp-queue-options.d.ts.map +1 -0
  251. package/dist/jobs/{three60-whatsapp-queue-options.js → rabbitmq/three60-whatsapp-queue-options.js} +1 -1
  252. package/dist/jobs/rabbitmq/three60-whatsapp-queue-options.js.map +1 -0
  253. package/dist/jobs/{three60-whatsapp-subscriber.service.d.ts → rabbitmq/three60-whatsapp-subscriber.service.d.ts} +1 -1
  254. package/dist/jobs/rabbitmq/three60-whatsapp-subscriber.service.d.ts.map +1 -0
  255. package/dist/jobs/{three60-whatsapp-subscriber.service.js → rabbitmq/three60-whatsapp-subscriber.service.js} +4 -4
  256. package/dist/jobs/rabbitmq/three60-whatsapp-subscriber.service.js.map +1 -0
  257. package/dist/jobs/{trigger-mcp-client-publisher.service.d.ts → rabbitmq/trigger-mcp-client-publisher.service.d.ts} +1 -1
  258. package/dist/jobs/rabbitmq/trigger-mcp-client-publisher.service.d.ts.map +1 -0
  259. package/dist/jobs/{trigger-mcp-client-publisher.service.js → rabbitmq/trigger-mcp-client-publisher.service.js} +3 -3
  260. package/dist/jobs/rabbitmq/trigger-mcp-client-publisher.service.js.map +1 -0
  261. package/dist/jobs/{trigger-mcp-client-queue-options.d.ts → rabbitmq/trigger-mcp-client-queue-options.d.ts} +1 -1
  262. package/dist/jobs/rabbitmq/trigger-mcp-client-queue-options.d.ts.map +1 -0
  263. package/dist/jobs/{trigger-mcp-client-queue-options.js → rabbitmq/trigger-mcp-client-queue-options.js} +1 -1
  264. package/dist/jobs/rabbitmq/trigger-mcp-client-queue-options.js.map +1 -0
  265. package/dist/jobs/{trigger-mcp-client-subscriber.service.d.ts → rabbitmq/trigger-mcp-client-subscriber.service.d.ts} +2 -2
  266. package/dist/jobs/rabbitmq/trigger-mcp-client-subscriber.service.d.ts.map +1 -0
  267. package/dist/jobs/{trigger-mcp-client-subscriber.service.js → rabbitmq/trigger-mcp-client-subscriber.service.js} +5 -5
  268. package/dist/jobs/rabbitmq/trigger-mcp-client-subscriber.service.js.map +1 -0
  269. package/dist/jobs/{twilio-sms-publisher.service.d.ts → rabbitmq/twilio-sms-publisher.service.d.ts} +1 -1
  270. package/dist/jobs/rabbitmq/twilio-sms-publisher.service.d.ts.map +1 -0
  271. package/dist/jobs/{twilio-sms-publisher.service.js → rabbitmq/twilio-sms-publisher.service.js} +3 -3
  272. package/dist/jobs/rabbitmq/twilio-sms-publisher.service.js.map +1 -0
  273. package/dist/jobs/{twilio-sms-queue-options.d.ts → rabbitmq/twilio-sms-queue-options.d.ts} +1 -1
  274. package/dist/jobs/rabbitmq/twilio-sms-queue-options.d.ts.map +1 -0
  275. package/dist/jobs/{twilio-sms-queue-options.js → rabbitmq/twilio-sms-queue-options.js} +1 -1
  276. package/dist/jobs/rabbitmq/twilio-sms-queue-options.js.map +1 -0
  277. package/dist/jobs/{twilio-sms-subscriber.service.d.ts → rabbitmq/twilio-sms-subscriber.service.d.ts} +1 -1
  278. package/dist/jobs/rabbitmq/twilio-sms-subscriber.service.d.ts.map +1 -0
  279. package/dist/jobs/{twilio-sms-subscriber.service.js → rabbitmq/twilio-sms-subscriber.service.js} +6 -6
  280. package/dist/jobs/rabbitmq/twilio-sms-subscriber.service.js.map +1 -0
  281. package/dist/jobs/redis/api-email-publisher-redis.service.d.ts +11 -0
  282. package/dist/jobs/redis/api-email-publisher-redis.service.d.ts.map +1 -0
  283. package/dist/jobs/redis/api-email-publisher-redis.service.js +39 -0
  284. package/dist/jobs/redis/api-email-publisher-redis.service.js.map +1 -0
  285. package/dist/jobs/redis/api-email-queue-options-redis.d.ts +8 -0
  286. package/dist/jobs/redis/api-email-queue-options-redis.d.ts.map +1 -0
  287. package/dist/jobs/redis/api-email-queue-options-redis.js +10 -0
  288. package/dist/jobs/redis/api-email-queue-options-redis.js.map +1 -0
  289. package/dist/jobs/redis/api-email-subscriber-redis.service.d.ts +15 -0
  290. package/dist/jobs/redis/api-email-subscriber-redis.service.d.ts.map +1 -0
  291. package/dist/jobs/redis/api-email-subscriber-redis.service.js +45 -0
  292. package/dist/jobs/redis/api-email-subscriber-redis.service.js.map +1 -0
  293. package/dist/jobs/redis/chatter-queue-options-redis.d.ts +8 -0
  294. package/dist/jobs/redis/chatter-queue-options-redis.d.ts.map +1 -0
  295. package/dist/jobs/redis/chatter-queue-options-redis.js +10 -0
  296. package/dist/jobs/redis/chatter-queue-options-redis.js.map +1 -0
  297. package/dist/jobs/redis/chatter-queue-publisher-redis.service.d.ts +11 -0
  298. package/dist/jobs/redis/chatter-queue-publisher-redis.service.d.ts.map +1 -0
  299. package/dist/jobs/redis/chatter-queue-publisher-redis.service.js +39 -0
  300. package/dist/jobs/redis/chatter-queue-publisher-redis.service.js.map +1 -0
  301. package/dist/jobs/redis/chatter-queue-subscriber-redis.service.d.ts +17 -0
  302. package/dist/jobs/redis/chatter-queue-subscriber-redis.service.d.ts.map +1 -0
  303. package/dist/jobs/{chatter-queue-subscriber.service.js → redis/chatter-queue-subscriber-redis.service.js} +18 -18
  304. package/dist/jobs/redis/chatter-queue-subscriber-redis.service.js.map +1 -0
  305. package/dist/jobs/redis/computed-field-evaluation-publisher-redis.service.d.ts +12 -0
  306. package/dist/jobs/redis/computed-field-evaluation-publisher-redis.service.d.ts.map +1 -0
  307. package/dist/jobs/redis/computed-field-evaluation-publisher-redis.service.js +39 -0
  308. package/dist/jobs/redis/computed-field-evaluation-publisher-redis.service.js.map +1 -0
  309. package/dist/jobs/redis/computed-field-evaluation-queue-options-redis.d.ts +9 -0
  310. package/dist/jobs/redis/computed-field-evaluation-queue-options-redis.d.ts.map +1 -0
  311. package/dist/jobs/redis/computed-field-evaluation-queue-options-redis.js +11 -0
  312. package/dist/jobs/redis/computed-field-evaluation-queue-options-redis.js.map +1 -0
  313. package/dist/jobs/redis/computed-field-evaluation-subscriber-redis.service.d.ts +19 -0
  314. package/dist/jobs/redis/computed-field-evaluation-subscriber-redis.service.d.ts.map +1 -0
  315. package/dist/jobs/redis/computed-field-evaluation-subscriber-redis.service.js +63 -0
  316. package/dist/jobs/redis/computed-field-evaluation-subscriber-redis.service.js.map +1 -0
  317. package/dist/jobs/redis/generate-code-publisher-redis.service.d.ts +11 -0
  318. package/dist/jobs/redis/generate-code-publisher-redis.service.d.ts.map +1 -0
  319. package/dist/jobs/redis/generate-code-publisher-redis.service.js +39 -0
  320. package/dist/jobs/redis/generate-code-publisher-redis.service.js.map +1 -0
  321. package/dist/jobs/redis/generate-code-queue-options-redis.d.ts +8 -0
  322. package/dist/jobs/redis/generate-code-queue-options-redis.d.ts.map +1 -0
  323. package/dist/jobs/redis/generate-code-queue-options-redis.js +10 -0
  324. package/dist/jobs/redis/generate-code-queue-options-redis.js.map +1 -0
  325. package/dist/jobs/redis/generate-code-subscriber-redis.service.d.ts +18 -0
  326. package/dist/jobs/redis/generate-code-subscriber-redis.service.d.ts.map +1 -0
  327. package/dist/jobs/redis/generate-code-subscriber-redis.service.js +70 -0
  328. package/dist/jobs/redis/generate-code-subscriber-redis.service.js.map +1 -0
  329. package/dist/jobs/redis/msg91-otp-publisher-redis.service.d.ts +11 -0
  330. package/dist/jobs/redis/msg91-otp-publisher-redis.service.d.ts.map +1 -0
  331. package/dist/jobs/redis/msg91-otp-publisher-redis.service.js +39 -0
  332. package/dist/jobs/redis/msg91-otp-publisher-redis.service.js.map +1 -0
  333. package/dist/jobs/redis/msg91-otp-queue-options-redis.d.ts +8 -0
  334. package/dist/jobs/redis/msg91-otp-queue-options-redis.d.ts.map +1 -0
  335. package/dist/jobs/redis/msg91-otp-queue-options-redis.js +10 -0
  336. package/dist/jobs/redis/msg91-otp-queue-options-redis.js.map +1 -0
  337. package/dist/jobs/redis/msg91-otp-subscriber-redis.service.d.ts +15 -0
  338. package/dist/jobs/redis/msg91-otp-subscriber-redis.service.d.ts.map +1 -0
  339. package/dist/jobs/redis/msg91-otp-subscriber-redis.service.js +47 -0
  340. package/dist/jobs/redis/msg91-otp-subscriber-redis.service.js.map +1 -0
  341. package/dist/jobs/redis/msg91-sms-publisher-redis.service.d.ts +11 -0
  342. package/dist/jobs/redis/msg91-sms-publisher-redis.service.d.ts.map +1 -0
  343. package/dist/jobs/redis/msg91-sms-publisher-redis.service.js +39 -0
  344. package/dist/jobs/redis/msg91-sms-publisher-redis.service.js.map +1 -0
  345. package/dist/jobs/redis/msg91-sms-queue-options-redis.d.ts +8 -0
  346. package/dist/jobs/redis/msg91-sms-queue-options-redis.d.ts.map +1 -0
  347. package/dist/jobs/redis/msg91-sms-queue-options-redis.js +10 -0
  348. package/dist/jobs/redis/msg91-sms-queue-options-redis.js.map +1 -0
  349. package/dist/jobs/redis/msg91-sms-subscriber-redis.service.d.ts +15 -0
  350. package/dist/jobs/redis/msg91-sms-subscriber-redis.service.d.ts.map +1 -0
  351. package/dist/jobs/redis/msg91-sms-subscriber-redis.service.js +47 -0
  352. package/dist/jobs/redis/msg91-sms-subscriber-redis.service.js.map +1 -0
  353. package/dist/jobs/redis/msg91-whatsapp-publisher-redis.service.d.ts +11 -0
  354. package/dist/jobs/redis/msg91-whatsapp-publisher-redis.service.d.ts.map +1 -0
  355. package/dist/jobs/redis/msg91-whatsapp-publisher-redis.service.js +39 -0
  356. package/dist/jobs/redis/msg91-whatsapp-publisher-redis.service.js.map +1 -0
  357. package/dist/jobs/redis/msg91-whatsapp-queue-options-redis.d.ts +8 -0
  358. package/dist/jobs/redis/msg91-whatsapp-queue-options-redis.d.ts.map +1 -0
  359. package/dist/jobs/redis/msg91-whatsapp-queue-options-redis.js +10 -0
  360. package/dist/jobs/redis/msg91-whatsapp-queue-options-redis.js.map +1 -0
  361. package/dist/jobs/redis/msg91-whatsapp-subscriber-redis.service.d.ts +15 -0
  362. package/dist/jobs/redis/msg91-whatsapp-subscriber-redis.service.d.ts.map +1 -0
  363. package/dist/jobs/redis/msg91-whatsapp-subscriber-redis.service.js +45 -0
  364. package/dist/jobs/redis/msg91-whatsapp-subscriber-redis.service.js.map +1 -0
  365. package/dist/jobs/redis/smtp-email-publisher-redis.service.d.ts +11 -0
  366. package/dist/jobs/redis/smtp-email-publisher-redis.service.d.ts.map +1 -0
  367. package/dist/jobs/redis/smtp-email-publisher-redis.service.js +39 -0
  368. package/dist/jobs/redis/smtp-email-publisher-redis.service.js.map +1 -0
  369. package/dist/jobs/redis/smtp-email-queue-options-redis.d.ts +8 -0
  370. package/dist/jobs/redis/smtp-email-queue-options-redis.d.ts.map +1 -0
  371. package/dist/jobs/redis/smtp-email-queue-options-redis.js +10 -0
  372. package/dist/jobs/redis/smtp-email-queue-options-redis.js.map +1 -0
  373. package/dist/jobs/redis/smtp-email-subscriber-redis.service.d.ts +15 -0
  374. package/dist/jobs/redis/smtp-email-subscriber-redis.service.d.ts.map +1 -0
  375. package/dist/jobs/redis/smtp-email-subscriber-redis.service.js +45 -0
  376. package/dist/jobs/redis/smtp-email-subscriber-redis.service.js.map +1 -0
  377. package/dist/jobs/{generate-code-queue-options.d.ts → redis/test-queue-options-redis.d.ts} +2 -2
  378. package/dist/jobs/redis/test-queue-options-redis.d.ts.map +1 -0
  379. package/dist/jobs/redis/test-queue-options-redis.js +10 -0
  380. package/dist/jobs/redis/test-queue-options-redis.js.map +1 -0
  381. package/dist/jobs/redis/test-queue-publisher-redis.service.d.ts +11 -0
  382. package/dist/jobs/redis/test-queue-publisher-redis.service.d.ts.map +1 -0
  383. package/dist/jobs/redis/test-queue-publisher-redis.service.js +39 -0
  384. package/dist/jobs/redis/test-queue-publisher-redis.service.js.map +1 -0
  385. package/dist/jobs/redis/test-queue-subscriber-redis.service.d.ts +14 -0
  386. package/dist/jobs/redis/test-queue-subscriber-redis.service.d.ts.map +1 -0
  387. package/dist/jobs/redis/test-queue-subscriber-redis.service.js +56 -0
  388. package/dist/jobs/redis/test-queue-subscriber-redis.service.js.map +1 -0
  389. package/dist/jobs/redis/three60-whatsapp-publisher-redis.service.d.ts +11 -0
  390. package/dist/jobs/redis/three60-whatsapp-publisher-redis.service.d.ts.map +1 -0
  391. package/dist/jobs/redis/three60-whatsapp-publisher-redis.service.js +39 -0
  392. package/dist/jobs/redis/three60-whatsapp-publisher-redis.service.js.map +1 -0
  393. package/dist/jobs/redis/three60-whatsapp-queue-options-redis.d.ts +8 -0
  394. package/dist/jobs/redis/three60-whatsapp-queue-options-redis.d.ts.map +1 -0
  395. package/dist/jobs/redis/three60-whatsapp-queue-options-redis.js +10 -0
  396. package/dist/jobs/redis/three60-whatsapp-queue-options-redis.js.map +1 -0
  397. package/dist/jobs/redis/three60-whatsapp-subscriber-redis.service.d.ts +15 -0
  398. package/dist/jobs/redis/three60-whatsapp-subscriber-redis.service.d.ts.map +1 -0
  399. package/dist/jobs/redis/three60-whatsapp-subscriber-redis.service.js +45 -0
  400. package/dist/jobs/redis/three60-whatsapp-subscriber-redis.service.js.map +1 -0
  401. package/dist/jobs/redis/trigger-mcp-client-publisher-redis.service.d.ts +11 -0
  402. package/dist/jobs/redis/trigger-mcp-client-publisher-redis.service.d.ts.map +1 -0
  403. package/dist/jobs/redis/trigger-mcp-client-publisher-redis.service.js +39 -0
  404. package/dist/jobs/redis/trigger-mcp-client-publisher-redis.service.js.map +1 -0
  405. package/dist/jobs/redis/trigger-mcp-client-queue-options-redis.d.ts +8 -0
  406. package/dist/jobs/redis/trigger-mcp-client-queue-options-redis.d.ts.map +1 -0
  407. package/dist/jobs/redis/trigger-mcp-client-queue-options-redis.js +10 -0
  408. package/dist/jobs/redis/trigger-mcp-client-queue-options-redis.js.map +1 -0
  409. package/dist/jobs/redis/trigger-mcp-client-subscriber-redis.service.d.ts +18 -0
  410. package/dist/jobs/redis/trigger-mcp-client-subscriber-redis.service.d.ts.map +1 -0
  411. package/dist/jobs/redis/trigger-mcp-client-subscriber-redis.service.js +103 -0
  412. package/dist/jobs/redis/trigger-mcp-client-subscriber-redis.service.js.map +1 -0
  413. package/dist/jobs/redis/twilio-sms-publisher-redis.service.d.ts +11 -0
  414. package/dist/jobs/redis/twilio-sms-publisher-redis.service.d.ts.map +1 -0
  415. package/dist/jobs/redis/twilio-sms-publisher-redis.service.js +39 -0
  416. package/dist/jobs/redis/twilio-sms-publisher-redis.service.js.map +1 -0
  417. package/dist/jobs/redis/twilio-sms-queue-options-redis.d.ts +8 -0
  418. package/dist/jobs/redis/twilio-sms-queue-options-redis.d.ts.map +1 -0
  419. package/dist/jobs/redis/twilio-sms-queue-options-redis.js +10 -0
  420. package/dist/jobs/redis/twilio-sms-queue-options-redis.js.map +1 -0
  421. package/dist/jobs/redis/twilio-sms-subscriber-redis.service.d.ts +17 -0
  422. package/dist/jobs/redis/twilio-sms-subscriber-redis.service.d.ts.map +1 -0
  423. package/dist/jobs/redis/twilio-sms-subscriber-redis.service.js +50 -0
  424. package/dist/jobs/redis/twilio-sms-subscriber-redis.service.js.map +1 -0
  425. package/dist/repository/dashboard-layout.repository.d.ts +12 -0
  426. package/dist/repository/dashboard-layout.repository.d.ts.map +1 -0
  427. package/dist/repository/dashboard-layout.repository.js +34 -0
  428. package/dist/repository/dashboard-layout.repository.js.map +1 -0
  429. package/dist/repository/model-metadata.repository.d.ts +6 -1
  430. package/dist/repository/model-metadata.repository.d.ts.map +1 -1
  431. package/dist/repository/model-metadata.repository.js +41 -2
  432. package/dist/repository/model-metadata.repository.js.map +1 -1
  433. package/dist/seeders/module-metadata-seeder.service.js +4 -4
  434. package/dist/seeders/module-metadata-seeder.service.js.map +1 -1
  435. package/dist/seeders/seed-data/solid-core-metadata.json +502 -66
  436. package/dist/services/authentication.service.d.ts.map +1 -1
  437. package/dist/services/authentication.service.js +45 -21
  438. package/dist/services/authentication.service.js.map +1 -1
  439. package/dist/services/chatter-message.service.d.ts +4 -4
  440. package/dist/services/chatter-message.service.d.ts.map +1 -1
  441. package/dist/services/chatter-message.service.js +59 -9
  442. package/dist/services/chatter-message.service.js.map +1 -1
  443. package/dist/services/computed-fields/entity/sequence-num-computed-field-provider.d.ts +7 -3
  444. package/dist/services/computed-fields/entity/sequence-num-computed-field-provider.d.ts.map +1 -1
  445. package/dist/services/computed-fields/entity/sequence-num-computed-field-provider.js +61 -22
  446. package/dist/services/computed-fields/entity/sequence-num-computed-field-provider.js.map +1 -1
  447. package/dist/services/crud.service.js +1 -1
  448. package/dist/services/crud.service.js.map +1 -1
  449. package/dist/services/dashboard-layout.service.d.ts +20 -0
  450. package/dist/services/dashboard-layout.service.d.ts.map +1 -0
  451. package/dist/services/dashboard-layout.service.js +120 -0
  452. package/dist/services/dashboard-layout.service.js.map +1 -0
  453. package/dist/services/dashboard-question.service.d.ts +4 -0
  454. package/dist/services/dashboard-question.service.d.ts.map +1 -1
  455. package/dist/services/dashboard-question.service.js +22 -8
  456. package/dist/services/dashboard-question.service.js.map +1 -1
  457. package/dist/services/dashboard.service.d.ts +2 -0
  458. package/dist/services/dashboard.service.d.ts.map +1 -1
  459. package/dist/services/dashboard.service.js +4 -0
  460. package/dist/services/dashboard.service.js.map +1 -1
  461. package/dist/services/model-metadata.service.d.ts +3 -1
  462. package/dist/services/model-metadata.service.d.ts.map +1 -1
  463. package/dist/services/model-metadata.service.js +122 -8
  464. package/dist/services/model-metadata.service.js.map +1 -1
  465. package/dist/services/permission-metadata.service.d.ts +5 -1
  466. package/dist/services/permission-metadata.service.d.ts.map +1 -1
  467. package/dist/services/permission-metadata.service.js +66 -20
  468. package/dist/services/permission-metadata.service.js.map +1 -1
  469. package/dist/services/question-data-providers/chartjs-sql-data-provider.service.d.ts +2 -4
  470. package/dist/services/question-data-providers/chartjs-sql-data-provider.service.d.ts.map +1 -1
  471. package/dist/services/question-data-providers/chartjs-sql-data-provider.service.js +2 -1
  472. package/dist/services/question-data-providers/chartjs-sql-data-provider.service.js.map +1 -1
  473. package/dist/services/question-data-providers/interfaces.d.ts +1 -0
  474. package/dist/services/question-data-providers/interfaces.d.ts.map +1 -0
  475. package/dist/services/question-data-providers/interfaces.js +1 -0
  476. package/dist/services/question-data-providers/interfaces.js.map +1 -0
  477. package/dist/services/question-data-providers/prime-react-datatable-sql-data-provider.service.d.ts +2 -5
  478. package/dist/services/question-data-providers/prime-react-datatable-sql-data-provider.service.d.ts.map +1 -1
  479. package/dist/services/question-data-providers/prime-react-datatable-sql-data-provider.service.js +2 -1
  480. package/dist/services/question-data-providers/prime-react-datatable-sql-data-provider.service.js.map +1 -1
  481. package/dist/services/question-data-providers/prime-react-meter-group-sql-data-provider.service.d.ts +2 -5
  482. package/dist/services/question-data-providers/prime-react-meter-group-sql-data-provider.service.d.ts.map +1 -1
  483. package/dist/services/question-data-providers/prime-react-meter-group-sql-data-provider.service.js +2 -1
  484. package/dist/services/question-data-providers/prime-react-meter-group-sql-data-provider.service.js.map +1 -1
  485. package/dist/services/queues/database-subscriber.service.d.ts +4 -2
  486. package/dist/services/queues/database-subscriber.service.d.ts.map +1 -1
  487. package/dist/services/queues/database-subscriber.service.js +15 -2
  488. package/dist/services/queues/database-subscriber.service.js.map +1 -1
  489. package/dist/services/queues/publisher-factory.service.d.ts.map +1 -1
  490. package/dist/services/queues/publisher-factory.service.js +4 -7
  491. package/dist/services/queues/publisher-factory.service.js.map +1 -1
  492. package/dist/services/queues/rabbitmq-publisher.service.d.ts +1 -0
  493. package/dist/services/queues/rabbitmq-publisher.service.d.ts.map +1 -1
  494. package/dist/services/queues/rabbitmq-publisher.service.js +6 -1
  495. package/dist/services/queues/rabbitmq-publisher.service.js.map +1 -1
  496. package/dist/services/queues/rabbitmq-subscriber.service.d.ts +9 -3
  497. package/dist/services/queues/rabbitmq-subscriber.service.d.ts.map +1 -1
  498. package/dist/services/queues/rabbitmq-subscriber.service.js +93 -10
  499. package/dist/services/queues/rabbitmq-subscriber.service.js.map +1 -1
  500. package/dist/services/queues/redis-publisher.service.d.ts +18 -0
  501. package/dist/services/queues/redis-publisher.service.d.ts.map +1 -1
  502. package/dist/services/queues/redis-publisher.service.js +86 -0
  503. package/dist/services/queues/redis-publisher.service.js.map +1 -1
  504. package/dist/services/queues/redis-subscriber.service.d.ts +26 -0
  505. package/dist/services/queues/redis-subscriber.service.d.ts.map +1 -1
  506. package/dist/services/queues/redis-subscriber.service.js +182 -0
  507. package/dist/services/queues/redis-subscriber.service.js.map +1 -1
  508. package/dist/services/request-context.service.d.ts +2 -1
  509. package/dist/services/request-context.service.d.ts.map +1 -1
  510. package/dist/services/request-context.service.js.map +1 -1
  511. package/dist/services/scheduled-job.service.d.ts +6 -1
  512. package/dist/services/scheduled-job.service.d.ts.map +1 -1
  513. package/dist/services/scheduled-job.service.js +26 -2
  514. package/dist/services/scheduled-job.service.js.map +1 -1
  515. package/dist/services/scheduled-jobs/scheduler.interface.d.ts +2 -0
  516. package/dist/services/scheduled-jobs/scheduler.interface.d.ts.map +1 -1
  517. package/dist/services/scheduled-jobs/scheduler.interface.js.map +1 -1
  518. package/dist/services/scheduled-jobs/scheduler.service.d.ts +6 -2
  519. package/dist/services/scheduled-jobs/scheduler.service.d.ts.map +1 -1
  520. package/dist/services/scheduled-jobs/scheduler.service.js +75 -17
  521. package/dist/services/scheduled-jobs/scheduler.service.js.map +1 -1
  522. package/dist/services/selection-providers/list-of-dashboard-question-providers-selection-provider.service.d.ts.map +1 -1
  523. package/dist/services/selection-providers/list-of-dashboard-question-providers-selection-provider.service.js +4 -1
  524. package/dist/services/selection-providers/list-of-dashboard-question-providers-selection-provider.service.js.map +1 -1
  525. package/dist/services/solid-introspect.service.d.ts +6 -1
  526. package/dist/services/solid-introspect.service.d.ts.map +1 -1
  527. package/dist/services/solid-introspect.service.js +27 -2
  528. package/dist/services/solid-introspect.service.js.map +1 -1
  529. package/dist/services/solid-ts-morph.service.d.ts +9 -0
  530. package/dist/services/solid-ts-morph.service.d.ts.map +1 -1
  531. package/dist/services/solid-ts-morph.service.js +76 -0
  532. package/dist/services/solid-ts-morph.service.js.map +1 -1
  533. package/dist/solid-core.module.d.ts.map +1 -1
  534. package/dist/solid-core.module.js +86 -22
  535. package/dist/solid-core.module.js.map +1 -1
  536. package/dist/subscribers/audit.subscriber.d.ts +10 -7
  537. package/dist/subscribers/audit.subscriber.d.ts.map +1 -1
  538. package/dist/subscribers/audit.subscriber.js +58 -85
  539. package/dist/subscribers/audit.subscriber.js.map +1 -1
  540. package/dist/subscribers/computed-entity-field.subscriber.js +3 -1
  541. package/dist/subscribers/computed-entity-field.subscriber.js.map +1 -1
  542. package/dist/subscribers/created-by-updated-by.subscriber.d.ts +0 -1
  543. package/dist/subscribers/created-by-updated-by.subscriber.d.ts.map +1 -1
  544. package/dist/subscribers/created-by-updated-by.subscriber.js +3 -13
  545. package/dist/subscribers/created-by-updated-by.subscriber.js.map +1 -1
  546. package/dist/transformers/typeorm/local-date-time-transformer.d.ts +4 -4
  547. package/dist/transformers/typeorm/local-date-time-transformer.d.ts.map +1 -1
  548. package/dist/transformers/typeorm/local-date-time-transformer.js +25 -28
  549. package/dist/transformers/typeorm/local-date-time-transformer.js.map +1 -1
  550. package/dist/winston.logger.d.ts.map +1 -1
  551. package/dist/winston.logger.js +2 -1
  552. package/dist/winston.logger.js.map +1 -1
  553. package/package.json +3 -1
  554. package/sql/default/mariadb/proc_CleanupModelMetadata.sql +153 -0
  555. package/sql/default/mariadb/proc_CleanupModuleMetadata.sql +56 -0
  556. package/sql/default/mysql/proc_CleanupModelMetadata.sql +153 -0
  557. package/sql/default/mysql/proc_CleanupModuleMetadata.sql +56 -0
  558. package/src/controllers/dashboard-layout.controller.ts +106 -0
  559. package/src/controllers/scheduled-job.controller.ts +6 -0
  560. package/src/dtos/create-dashboard-layout.dto.ts +31 -0
  561. package/src/dtos/create-dashboard-variable.dto.ts +4 -0
  562. package/src/dtos/update-dashboard-layout.dto.ts +30 -0
  563. package/src/dtos/update-dashboard-variable.dto.ts +5 -1
  564. package/src/entities/action-metadata.entity.ts +3 -2
  565. package/src/entities/ai-interaction.entity.ts +5 -4
  566. package/src/entities/chatter-message-details.entity.ts +7 -3
  567. package/src/entities/chatter-message.entity.ts +4 -3
  568. package/src/entities/common.entity.ts +2 -2
  569. package/src/entities/dashboard-layout.entity.ts +18 -0
  570. package/src/entities/dashboard-question-sql-dataset-config.entity.ts +5 -4
  571. package/src/entities/dashboard-question.entity.ts +5 -4
  572. package/src/entities/dashboard-variable.entity.ts +9 -4
  573. package/src/entities/dashboard.entity.ts +7 -2
  574. package/src/entities/email-attachment.entity.ts +2 -1
  575. package/src/entities/email-template.entity.ts +1 -1
  576. package/src/entities/export-transaction.entity.ts +2 -1
  577. package/src/entities/field-metadata.entity.ts +2 -2
  578. package/src/entities/import-transaction-error-log.entity.ts +3 -2
  579. package/src/entities/import-transaction.entity.ts +2 -1
  580. package/src/entities/legacy-common.entity.ts +3 -4
  581. package/src/entities/mq-message-queue.entity.ts +8 -8
  582. package/src/entities/mq-message.entity.ts +5 -3
  583. package/src/entities/saved-filters.entity.ts +3 -2
  584. package/src/entities/security-rule.entity.ts +2 -1
  585. package/src/entities/sms-template.entity.ts +1 -1
  586. package/src/entities/user-view-metadata.entity.ts +2 -1
  587. package/src/entities/user.entity.ts +37 -2
  588. package/src/entities/view-metadata.entity.ts +3 -0
  589. package/src/helpers/bootstrap.helper.ts +222 -0
  590. package/src/helpers/cache.helper.ts +5 -0
  591. package/src/helpers/cors.helper.ts +26 -6
  592. package/src/helpers/field-crud-managers/SelectionDynamicFieldCrudManager.ts +9 -6
  593. package/src/helpers/solid-registry.ts +10 -5
  594. package/src/helpers/typeorm-db-helper.ts +26 -0
  595. package/src/index.ts +57 -15
  596. package/src/interfaces.ts +12 -2
  597. package/src/jobs/database/chatter-queue-options-database.ts +9 -0
  598. package/src/jobs/database/chatter-queue-publisher-database.service.ts +24 -0
  599. package/src/jobs/database/chatter-queue-subscriber-database.service.ts +53 -0
  600. package/src/jobs/{api-email-publisher.service.ts → rabbitmq/api-email-publisher.service.ts} +1 -1
  601. package/src/jobs/{api-email-queue-options.ts → rabbitmq/api-email-queue-options.ts} +1 -1
  602. package/src/jobs/{api-email-subscriber.service.ts → rabbitmq/api-email-subscriber.service.ts} +2 -2
  603. package/src/jobs/{chatter-queue-options.ts → rabbitmq/chatter-queue-options.ts} +2 -2
  604. package/src/jobs/rabbitmq/chatter-queue-publisher.service.ts +37 -0
  605. package/src/jobs/{chatter-queue-subscriber.service.ts → rabbitmq/chatter-queue-subscriber.service.ts} +16 -11
  606. package/src/jobs/{computed-field-evaluation-publisher.service.ts → rabbitmq/computed-field-evaluation-publisher.service.ts} +1 -1
  607. package/src/jobs/{computed-field-evaluation-queue-options.ts → rabbitmq/computed-field-evaluation-queue-options.ts} +3 -1
  608. package/src/jobs/{generate-code-publisher.service.ts → rabbitmq/generate-code-publisher.service.ts} +3 -3
  609. package/src/jobs/{generate-code-queue-options.ts → rabbitmq/generate-code-queue-options.ts} +1 -1
  610. package/src/jobs/{msg91-otp-publisher.service.ts → rabbitmq/msg91-otp-publisher.service.ts} +1 -1
  611. package/src/jobs/{msg91-otp-queue-options.ts → rabbitmq/msg91-otp-queue-options.ts} +2 -2
  612. package/src/jobs/{msg91-otp-subscriber.service.ts → rabbitmq/msg91-otp-subscriber.service.ts} +2 -2
  613. package/src/jobs/{msg91-sms-publisher.service.ts → rabbitmq/msg91-sms-publisher.service.ts} +1 -1
  614. package/src/jobs/{msg91-sms-queue-options.ts → rabbitmq/msg91-sms-queue-options.ts} +2 -2
  615. package/src/jobs/{msg91-sms-subscriber.service.ts → rabbitmq/msg91-sms-subscriber.service.ts} +2 -2
  616. package/src/jobs/{msg91-whatsapp-publisher.service.ts → rabbitmq/msg91-whatsapp-publisher.service.ts} +1 -1
  617. package/src/jobs/{msg91-whatsapp-queue-options.ts → rabbitmq/msg91-whatsapp-queue-options.ts} +1 -1
  618. package/src/jobs/{msg91-whatsapp-subscriber.service.ts → rabbitmq/msg91-whatsapp-subscriber.service.ts} +2 -2
  619. package/src/jobs/{smtp-email-publisher.service.ts → rabbitmq/smtp-email-publisher.service.ts} +1 -1
  620. package/src/jobs/{smtp-email-queue-options.ts → rabbitmq/smtp-email-queue-options.ts} +1 -1
  621. package/src/jobs/{smtp-email-subscriber.service.ts → rabbitmq/smtp-email-subscriber.service.ts} +2 -2
  622. package/src/jobs/{test-queue-options.ts → rabbitmq/test-queue-options.ts} +1 -1
  623. package/src/jobs/{test-queue-publisher.service.ts → rabbitmq/test-queue-publisher.service.ts} +3 -3
  624. package/src/jobs/{test-queue-subscriber.service.ts → rabbitmq/test-queue-subscriber.service.ts} +3 -3
  625. package/src/jobs/{three60-whatsapp-publisher.service.ts → rabbitmq/three60-whatsapp-publisher.service.ts} +1 -1
  626. package/src/jobs/{three60-whatsapp-queue-options.ts → rabbitmq/three60-whatsapp-queue-options.ts} +1 -1
  627. package/src/jobs/{three60-whatsapp-subscriber.service.ts → rabbitmq/three60-whatsapp-subscriber.service.ts} +1 -1
  628. package/src/jobs/{trigger-mcp-client-publisher.service.ts → rabbitmq/trigger-mcp-client-publisher.service.ts} +2 -2
  629. package/src/jobs/{trigger-mcp-client-queue-options.ts → rabbitmq/trigger-mcp-client-queue-options.ts} +1 -1
  630. package/src/jobs/{trigger-mcp-client-subscriber.service.ts → rabbitmq/trigger-mcp-client-subscriber.service.ts} +2 -2
  631. package/src/jobs/{twilio-sms-publisher.service.ts → rabbitmq/twilio-sms-publisher.service.ts} +1 -1
  632. package/src/jobs/{twilio-sms-queue-options.ts → rabbitmq/twilio-sms-queue-options.ts} +1 -1
  633. package/src/jobs/{twilio-sms-subscriber.service.ts → rabbitmq/twilio-sms-subscriber.service.ts} +1 -1
  634. package/src/jobs/redis/api-email-publisher-redis.service.ts +23 -0
  635. package/src/jobs/redis/api-email-queue-options-redis.ts +9 -0
  636. package/src/jobs/redis/api-email-subscriber-redis.service.ts +30 -0
  637. package/src/jobs/redis/chatter-queue-options-redis.ts +9 -0
  638. package/src/jobs/redis/chatter-queue-publisher-redis.service.ts +23 -0
  639. package/src/jobs/redis/chatter-queue-subscriber-redis.service.ts +46 -0
  640. package/src/jobs/redis/computed-field-evaluation-publisher-redis.service.ts +24 -0
  641. package/src/jobs/redis/computed-field-evaluation-queue-options-redis.ts +10 -0
  642. package/src/jobs/redis/computed-field-evaluation-subscriber-redis.service.ts +48 -0
  643. package/src/jobs/redis/generate-code-publisher-redis.service.ts +23 -0
  644. package/src/jobs/redis/generate-code-queue-options-redis.ts +9 -0
  645. package/src/jobs/redis/generate-code-subscriber-redis.service.ts +57 -0
  646. package/src/jobs/redis/msg91-otp-publisher-redis.service.ts +23 -0
  647. package/src/jobs/redis/msg91-otp-queue-options-redis.ts +9 -0
  648. package/src/jobs/redis/msg91-otp-subscriber-redis.service.ts +32 -0
  649. package/src/jobs/redis/msg91-sms-publisher-redis.service.ts +23 -0
  650. package/src/jobs/redis/msg91-sms-queue-options-redis.ts +9 -0
  651. package/src/jobs/redis/msg91-sms-subscriber-redis.service.ts +32 -0
  652. package/src/jobs/redis/msg91-whatsapp-publisher-redis.service.ts +23 -0
  653. package/src/jobs/redis/msg91-whatsapp-queue-options-redis.ts +9 -0
  654. package/src/jobs/redis/msg91-whatsapp-subscriber-redis.service.ts +30 -0
  655. package/src/jobs/redis/smtp-email-publisher-redis.service.ts +23 -0
  656. package/src/jobs/redis/smtp-email-queue-options-redis.ts +9 -0
  657. package/src/jobs/redis/smtp-email-subscriber-redis.service.ts +30 -0
  658. package/src/jobs/redis/test-queue-options-redis.ts +9 -0
  659. package/src/jobs/redis/test-queue-publisher-redis.service.ts +24 -0
  660. package/src/jobs/redis/test-queue-subscriber-redis.service.ts +44 -0
  661. package/src/jobs/redis/three60-whatsapp-publisher-redis.service.ts +23 -0
  662. package/src/jobs/redis/three60-whatsapp-queue-options-redis.ts +9 -0
  663. package/src/jobs/redis/three60-whatsapp-subscriber-redis.service.ts +30 -0
  664. package/src/jobs/redis/trigger-mcp-client-publisher-redis.service.ts +23 -0
  665. package/src/jobs/redis/trigger-mcp-client-queue-options-redis.ts +9 -0
  666. package/src/jobs/redis/trigger-mcp-client-subscriber-redis.service.ts +98 -0
  667. package/src/jobs/redis/twilio-sms-publisher-redis.service.ts +23 -0
  668. package/src/jobs/redis/twilio-sms-queue-options-redis.ts +9 -0
  669. package/src/jobs/redis/twilio-sms-subscriber-redis.service.ts +34 -0
  670. package/src/repository/dashboard-layout.repository.ts +17 -0
  671. package/src/repository/model-metadata.repository.ts +45 -2
  672. package/src/seeders/module-metadata-seeder.service.ts +5 -5
  673. package/src/seeders/seed-data/solid-core-metadata.json +503 -67
  674. package/src/services/authentication.service.ts +47 -24
  675. package/src/services/chatter-message.service.ts +67 -9
  676. package/src/services/computed-fields/entity/sequence-num-computed-field-provider.ts +79 -40
  677. package/src/services/crud.service.ts +1 -1
  678. package/src/services/dashboard-layout.service.ts +111 -0
  679. package/src/services/dashboard-question.service.ts +23 -4
  680. package/src/services/dashboard.service.ts +7 -0
  681. package/src/services/model-metadata.service.ts +131 -50
  682. package/src/services/permission-metadata.service.ts +73 -20
  683. package/src/services/question-data-providers/chartjs-sql-data-provider.service.ts +3 -7
  684. package/src/services/question-data-providers/interfaces.ts +0 -0
  685. package/src/services/question-data-providers/prime-react-datatable-sql-data-provider.service.ts +4 -8
  686. package/src/services/question-data-providers/prime-react-meter-group-sql-data-provider.service.ts +4 -8
  687. package/src/services/queues/database-subscriber.service.ts +19 -2
  688. package/src/services/queues/publisher-factory.service.ts +9 -7
  689. package/src/services/queues/rabbitmq-publisher.service.ts +8 -2
  690. package/src/services/queues/rabbitmq-subscriber.service.ts +139 -11
  691. package/src/services/queues/redis-publisher.service.ts +94 -0
  692. package/src/services/queues/redis-subscriber.service.ts +208 -0
  693. package/src/services/request-context.service.ts +2 -1
  694. package/src/services/scheduled-job.service.ts +31 -2
  695. package/src/services/scheduled-jobs/scheduler.interface.ts +4 -1
  696. package/src/services/scheduled-jobs/scheduler.service.ts +82 -20
  697. package/src/services/selection-providers/list-of-dashboard-question-providers-selection-provider.service.ts +4 -1
  698. package/src/services/solid-introspect.service.ts +28 -0
  699. package/src/services/solid-ts-morph.service.ts +98 -0
  700. package/src/solid-core.module.ts +91 -24
  701. package/src/subscribers/audit.subscriber.ts +63 -271
  702. package/src/subscribers/computed-entity-field.subscriber.ts +3 -3
  703. package/src/subscribers/created-by-updated-by.subscriber.ts +22 -16
  704. package/src/transformers/typeorm/local-date-time-transformer.ts +41 -33
  705. package/src/winston.logger.ts +2 -1
  706. package/dist/jobs/api-email-publisher.service.d.ts.map +0 -1
  707. package/dist/jobs/api-email-publisher.service.js.map +0 -1
  708. package/dist/jobs/api-email-queue-options.d.ts.map +0 -1
  709. package/dist/jobs/api-email-queue-options.js.map +0 -1
  710. package/dist/jobs/api-email-subscriber.service.d.ts.map +0 -1
  711. package/dist/jobs/api-email-subscriber.service.js.map +0 -1
  712. package/dist/jobs/chatter-queue-options.d.ts.map +0 -1
  713. package/dist/jobs/chatter-queue-options.js.map +0 -1
  714. package/dist/jobs/chatter-queue-publisher.service.d.ts +0 -22
  715. package/dist/jobs/chatter-queue-publisher.service.d.ts.map +0 -1
  716. package/dist/jobs/chatter-queue-publisher.service.js.map +0 -1
  717. package/dist/jobs/chatter-queue-subscriber.service.d.ts.map +0 -1
  718. package/dist/jobs/chatter-queue-subscriber.service.js.map +0 -1
  719. package/dist/jobs/computed-field-evaluation-publisher.service.d.ts.map +0 -1
  720. package/dist/jobs/computed-field-evaluation-publisher.service.js.map +0 -1
  721. package/dist/jobs/computed-field-evaluation-queue-options.d.ts.map +0 -1
  722. package/dist/jobs/computed-field-evaluation-queue-options.js.map +0 -1
  723. package/dist/jobs/computed-field-evaluation-subscriber.service.d.ts.map +0 -1
  724. package/dist/jobs/computed-field-evaluation-subscriber.service.js.map +0 -1
  725. package/dist/jobs/generate-code-publisher.service.d.ts.map +0 -1
  726. package/dist/jobs/generate-code-publisher.service.js.map +0 -1
  727. package/dist/jobs/generate-code-queue-options.d.ts.map +0 -1
  728. package/dist/jobs/generate-code-queue-options.js.map +0 -1
  729. package/dist/jobs/generate-code-subscriber.service.d.ts.map +0 -1
  730. package/dist/jobs/generate-code-subscriber.service.js.map +0 -1
  731. package/dist/jobs/msg91-otp-publisher.service.d.ts.map +0 -1
  732. package/dist/jobs/msg91-otp-publisher.service.js.map +0 -1
  733. package/dist/jobs/msg91-otp-queue-options.d.ts.map +0 -1
  734. package/dist/jobs/msg91-otp-queue-options.js.map +0 -1
  735. package/dist/jobs/msg91-otp-subscriber.service.d.ts.map +0 -1
  736. package/dist/jobs/msg91-otp-subscriber.service.js.map +0 -1
  737. package/dist/jobs/msg91-sms-publisher.service.d.ts.map +0 -1
  738. package/dist/jobs/msg91-sms-publisher.service.js.map +0 -1
  739. package/dist/jobs/msg91-sms-queue-options.d.ts.map +0 -1
  740. package/dist/jobs/msg91-sms-queue-options.js.map +0 -1
  741. package/dist/jobs/msg91-sms-subscriber.service.d.ts.map +0 -1
  742. package/dist/jobs/msg91-sms-subscriber.service.js.map +0 -1
  743. package/dist/jobs/msg91-whatsapp-publisher.service.d.ts.map +0 -1
  744. package/dist/jobs/msg91-whatsapp-publisher.service.js.map +0 -1
  745. package/dist/jobs/msg91-whatsapp-queue-options.d.ts.map +0 -1
  746. package/dist/jobs/msg91-whatsapp-queue-options.js.map +0 -1
  747. package/dist/jobs/msg91-whatsapp-subscriber.service.d.ts.map +0 -1
  748. package/dist/jobs/msg91-whatsapp-subscriber.service.js.map +0 -1
  749. package/dist/jobs/smtp-email-publisher.service.d.ts.map +0 -1
  750. package/dist/jobs/smtp-email-publisher.service.js.map +0 -1
  751. package/dist/jobs/smtp-email-queue-options.d.ts.map +0 -1
  752. package/dist/jobs/smtp-email-queue-options.js.map +0 -1
  753. package/dist/jobs/smtp-email-subscriber.service.d.ts.map +0 -1
  754. package/dist/jobs/smtp-email-subscriber.service.js.map +0 -1
  755. package/dist/jobs/test-queue-options.d.ts.map +0 -1
  756. package/dist/jobs/test-queue-options.js.map +0 -1
  757. package/dist/jobs/test-queue-publisher.service.d.ts.map +0 -1
  758. package/dist/jobs/test-queue-publisher.service.js.map +0 -1
  759. package/dist/jobs/test-queue-subscriber.service.d.ts.map +0 -1
  760. package/dist/jobs/test-queue-subscriber.service.js.map +0 -1
  761. package/dist/jobs/three60-whatsapp-publisher.service.d.ts.map +0 -1
  762. package/dist/jobs/three60-whatsapp-publisher.service.js.map +0 -1
  763. package/dist/jobs/three60-whatsapp-queue-options.d.ts.map +0 -1
  764. package/dist/jobs/three60-whatsapp-queue-options.js.map +0 -1
  765. package/dist/jobs/three60-whatsapp-subscriber.service.d.ts.map +0 -1
  766. package/dist/jobs/three60-whatsapp-subscriber.service.js.map +0 -1
  767. package/dist/jobs/trigger-mcp-client-publisher.service.d.ts.map +0 -1
  768. package/dist/jobs/trigger-mcp-client-publisher.service.js.map +0 -1
  769. package/dist/jobs/trigger-mcp-client-queue-options.d.ts.map +0 -1
  770. package/dist/jobs/trigger-mcp-client-queue-options.js.map +0 -1
  771. package/dist/jobs/trigger-mcp-client-subscriber.service.d.ts.map +0 -1
  772. package/dist/jobs/trigger-mcp-client-subscriber.service.js.map +0 -1
  773. package/dist/jobs/twilio-sms-publisher.service.d.ts.map +0 -1
  774. package/dist/jobs/twilio-sms-publisher.service.js.map +0 -1
  775. package/dist/jobs/twilio-sms-queue-options.d.ts.map +0 -1
  776. package/dist/jobs/twilio-sms-queue-options.js.map +0 -1
  777. package/dist/jobs/twilio-sms-subscriber.service.d.ts.map +0 -1
  778. package/dist/jobs/twilio-sms-subscriber.service.js.map +0 -1
  779. package/src/jobs/chatter-queue-publisher.service.ts +0 -37
  780. /package/dist/jobs/{computed-field-evaluation-publisher.service.d.ts → rabbitmq/computed-field-evaluation-publisher.service.d.ts} +0 -0
  781. /package/dist/jobs/{computed-field-evaluation-subscriber.service.d.ts → rabbitmq/computed-field-evaluation-subscriber.service.d.ts} +0 -0
  782. /package/dist/jobs/{generate-code-subscriber.service.d.ts → rabbitmq/generate-code-subscriber.service.d.ts} +0 -0
  783. /package/src/jobs/{computed-field-evaluation-subscriber.service.ts → rabbitmq/computed-field-evaluation-subscriber.service.ts} +0 -0
  784. /package/src/jobs/{generate-code-subscriber.service.ts → rabbitmq/generate-code-subscriber.service.ts} +0 -0
@@ -1,32 +1,20 @@
1
- import { forwardRef, Inject, Injectable, Scope } from '@nestjs/common';
2
- import { ModelMetadataHelperService } from 'src/helpers/model-metadata-helper.service';
1
+ import { Injectable, Logger, Scope } from '@nestjs/common';
3
2
  import { lowerFirst } from 'src/helpers/string.helper';
4
- import { ModelMetadataRepository } from 'src/repository/model-metadata.repository';
3
+ import { SolidRegistry } from 'src/helpers/solid-registry';
5
4
  import { DataSource, EntityMetadata, EntitySubscriberInterface, InsertEvent, RemoveEvent, UpdateEvent } from 'typeorm';
6
- import { ChatterMessageService } from '../services/chatter-message.service';
7
-
8
-
9
- type DeferredCall =
10
- | { kind: 'insert'; args: Parameters<ChatterMessageService['postAuditMessageOnInsert']> }
11
- | { kind: 'update'; args: Parameters<ChatterMessageService['postAuditMessageOnUpdate']> }
12
- | { kind: 'delete'; args: Parameters<ChatterMessageService['postAuditMessageOnDelete']> };
5
+ import { AuditQueuePayload } from 'src/jobs/rabbitmq/chatter-queue-publisher.service';
6
+ import { RequestContextService } from 'src/services/request-context.service';
7
+ import { PublisherFactory } from 'src/services/queues/publisher-factory.service';
13
8
 
14
9
  @Injectable({scope: Scope.TRANSIENT})
15
- // @EventSubscriber()
16
10
  export class AuditSubscriber implements EntitySubscriberInterface {
11
+ private readonly logger = new Logger(AuditSubscriber.name);
17
12
  private dataSource: DataSource;
18
13
  constructor(
19
- // @InjectDataSource()
20
- // private readonly dataSource: DataSource,
21
- private readonly chatterMessageService: ChatterMessageService,
22
- // @InjectRepository(ModelMetadata)
23
- // private readonly modelMetadataRepo: Repository<ModelMetadata>,
24
- @Inject(forwardRef(() => ModelMetadataRepository))
25
- private readonly modelMetadataRepo: ModelMetadataRepository,
26
- private readonly modelMetadataHelperService: ModelMetadataHelperService,
27
- ) {
28
- // this.dataSource.subscribers.push(this);
29
- }
14
+ private readonly publisherFactory: PublisherFactory<AuditQueuePayload>,
15
+ private readonly solidRegistry: SolidRegistry,
16
+ private readonly requestContextService: RequestContextService,
17
+ ) { }
30
18
 
31
19
  bindToDataSource(dataSource: DataSource) {
32
20
  this.dataSource = dataSource;
@@ -34,90 +22,61 @@ export class AuditSubscriber implements EntitySubscriberInterface {
34
22
  }
35
23
 
36
24
  // Per-transaction buffer (auto-GC when queryRunner is gone)
37
- private perTxn = new WeakMap<any, DeferredCall[]>();
25
+ private perTxn = new WeakMap<any, AuditQueuePayload[]>();
38
26
 
39
- private enqueue(event: { queryRunner: any }, call: DeferredCall) {
27
+ private enqueue(event: { queryRunner: any }, payload: AuditQueuePayload) {
40
28
  const qr = event.queryRunner;
41
29
  const arr = this.perTxn.get(qr) ?? [];
42
- arr.push(call);
30
+ arr.push(payload);
43
31
  this.perTxn.set(qr, arr);
44
32
  }
45
33
 
46
- private async shouldTrackAudit(entity: any, metadata: EntityMetadata): Promise<boolean> {
47
- const model = await this.modelMetadataRepo.findOne({
48
- where: {
49
- singularName: lowerFirst(metadata.name)
50
- },
51
- relations: {
52
- fields: true,
53
- module: true
54
- }
55
- });
56
-
57
- if (!model || !model.enableAuditTracking) {
58
- return false;
59
- }
60
-
61
- const modelFields = await this.modelMetadataHelperService.loadFieldHierarchy(model.singularName)
62
-
63
- const auditFields = modelFields.filter(field =>
64
- field.enableAuditTracking &&
65
- !['mediaSingle', 'mediaMultiple', 'richText', 'json'].includes(field.type) &&
66
- !(field.type === 'relation' && field.relationType === 'one-to-many')
67
- );
68
-
69
- if (auditFields.length === 0) {
70
- return false;
71
- }
72
-
73
- // if (!entity) {
74
- // console.warn(`[AuditSubscriber] Skipping audit for ${metadata.name} – entity is undefined or null`);
75
- // return false;
76
- // }
34
+ private shouldTrackAudit(metadata: EntityMetadata): boolean {
35
+ return this.solidRegistry.isAuditableModel(lowerFirst(metadata.name));
36
+ }
77
37
 
78
- return entity && auditFields.some(field => {
79
- const fieldValue = entity[field.name];
80
- return fieldValue !== undefined && fieldValue !== null;
81
- });
38
+ private activeUserId(): number | null {
39
+ return this.requestContextService.getActiveUser()?.sub ?? null;
82
40
  }
83
41
 
84
42
  async afterInsert(event: InsertEvent<any>) {
85
- if (await this.shouldTrackAudit(event.entity, event.metadata)) {
86
- // await this.chatterMessageService.postAuditMessageOnInsert(event.entity, event.metadata);
87
- this.enqueue(event, {
88
- kind: 'insert',
89
- args: [event.entity, event.metadata] as Parameters<ChatterMessageService['postAuditMessageOnInsert']>,
90
- });
91
- }
43
+ if (!this.shouldTrackAudit(event.metadata)) return;
44
+ this.enqueue(event, {
45
+ eventType: 'insert',
46
+ modelName: event.metadata.name,
47
+ entityId: event.entity?.id ?? null,
48
+ occurredAt: new Date().toISOString(),
49
+ after: event.entity ?? null,
50
+ userId: this.activeUserId(),
51
+ });
92
52
  }
93
53
 
94
54
  async afterUpdate(event: UpdateEvent<any>) {
95
- if (await this.shouldTrackAudit(event.entity, event.metadata)) {
96
- // await this.chatterMessageService.postAuditMessageOnUpdate(event.entity, event.metadata, event.databaseEntity, event.updatedColumns || []);
97
- this.enqueue(event, {
98
- kind: 'update',
99
- args: [
100
- event.entity, // entity (after)
101
- event.metadata,
102
- event.databaseEntity, // entity (before)
103
- event.updatedColumns ?? [],
104
- ] as Parameters<ChatterMessageService['postAuditMessageOnUpdate']>,
105
- });
106
- }
55
+ if (!this.shouldTrackAudit(event.metadata)) return;
56
+ this.enqueue(event, {
57
+ eventType: 'update',
58
+ modelName: event.metadata.name,
59
+ entityId: event.entity?.id ?? null,
60
+ occurredAt: new Date().toISOString(),
61
+ after: event.entity ?? null,
62
+ // databaseEntity is only populated when the entity was fetched first (save() path).
63
+ // QueryBuilder update() leaves this undefined; postAuditMessageOnUpdate guards for it.
64
+ before: event.databaseEntity ?? null,
65
+ updatedColumnNames: (event.updatedColumns ?? []).map(c => c.propertyName),
66
+ userId: this.activeUserId(),
67
+ });
107
68
  }
108
69
 
109
70
  async afterRemove(event: RemoveEvent<any>) {
110
- if (await this.shouldTrackAudit(event.entity, event.metadata)) {
111
- // await this.chatterMessageService.postAuditMessageOnDelete(event.entity, event.metadata, event.databaseEntity);
112
- this.enqueue(event, {
113
- kind: 'delete',
114
- args: [
115
- event.entity,
116
- event.metadata,
117
- event.databaseEntity,
118
- ] as Parameters<ChatterMessageService['postAuditMessageOnDelete']>,
119
- });
120
- }
71
+ if (!this.shouldTrackAudit(event.metadata)) return;
72
+ this.enqueue(event, {
73
+ eventType: 'delete',
74
+ modelName: event.metadata.name,
75
+ entityId: event.databaseEntity?.id ?? null,
76
+ occurredAt: new Date().toISOString(),
77
+ before: event.databaseEntity,
78
+ userId: this.activeUserId(),
79
+ });
121
80
  }
122
81
 
123
82
  // --------- transaction lifecycle ----------
@@ -125,191 +84,24 @@ export class AuditSubscriber implements EntitySubscriberInterface {
125
84
  const batch = this.perTxn.get(event.queryRunner) ?? [];
126
85
  this.perTxn.delete(event.queryRunner);
127
86
 
128
- // Now we’re OUTSIDE the DB transaction — safe to do I/O/DB writes inside chatter service.
129
- for (const item of batch) {
130
- try {
131
- switch (item.kind) {
132
- case 'insert': await this.chatterMessageService.postAuditMessageOnInsert(...item.args); break;
133
- case 'update': await this.chatterMessageService.postAuditMessageOnUpdate(...item.args); break;
134
- case 'delete': await this.chatterMessageService.postAuditMessageOnDelete(...item.args); break;
135
- }
136
- } catch (e) {
137
- // Best effort: log and continue; your core txn was already committed
138
- // Optionally: send to a generic error logger/metric here
87
+ // Now outside the DB transaction — safe to publish to the queue.
88
+ // allSettled: publish in parallel; a single failure does not block the rest.
89
+ const results = await Promise.allSettled(
90
+ batch.map(payload => this.publisherFactory.publish({ payload }, 'ChatterQueuePublisher'))
91
+ );
92
+
93
+ results.forEach((result, i) => {
94
+ if (result.status === 'rejected') {
95
+ this.logger.error(
96
+ `Failed to publish audit event for ${batch[i].modelName}#${batch[i].entityId}`,
97
+ result.reason,
98
+ );
139
99
  }
140
- }
100
+ });
141
101
  }
142
102
 
143
103
  afterTransactionRollback(event: { queryRunner: any }) {
144
- // Drop buffered calls; the write never happened
104
+ // Drop buffered payloads; the write never happened.
145
105
  this.perTxn.delete(event.queryRunner);
146
106
  }
147
107
  }
148
-
149
- // import { DataSource, EntityMetadata, EntitySubscriberInterface, EventSubscriber, InsertEvent, RemoveEvent, UpdateEvent } from 'typeorm';
150
- // import { Injectable } from '@nestjs/common';
151
- // import { InjectDataSource, InjectRepository } from '@nestjs/typeorm';
152
- // import { Repository } from 'typeorm';
153
- // import { ModelMetadata } from '../entities/model-metadata.entity';
154
- // import { lowerFirst } from 'src/helpers/string.helper';
155
- // import { ModelMetadataHelperService } from 'src/helpers/model-metadata-helper.service';
156
- // import { ChatterMessagePayload } from 'src/jobs/chatter-queue-publisher.service';
157
- // import { RequestContextService } from 'src/services/request-context.service';
158
- // import { PublisherFactory } from 'src/services/queues/publisher-factory.service';
159
-
160
- // @EventSubscriber()
161
- // @Injectable()
162
- // export class AuditSubscriber implements EntitySubscriberInterface {
163
- // private perTxn = new WeakMap<any, ChatterMessagePayload[]>();
164
-
165
- // constructor(
166
- // @InjectDataSource() private readonly dataSource: DataSource,
167
- // @InjectRepository(ModelMetadata) private readonly modelMetadataRepo: Repository<ModelMetadata>,
168
- // private readonly modelMetadataHelperService: ModelMetadataHelperService,
169
- // private readonly requestContext: RequestContextService,
170
- // private readonly publisherFactory: PublisherFactory<any>
171
- // ) {
172
- // this.dataSource.subscribers.push(this);
173
- // }
174
-
175
- // // --- small cache to avoid metadata queries on every row ---
176
- // private modelCache = new Map<string, { enable: boolean; fields: Array<{ name: string; enableAuditTracking: boolean; type: string; relationType?: string }>; ts: number }>();
177
- // private cacheTTLms = 60_000;
178
-
179
- // private async shouldTrackAudit(entity: any, metadata: EntityMetadata): Promise<{ enable: boolean; auditFields?: string[] }> {
180
- // const key = metadata.name;
181
- // const now = Date.now();
182
- // const cached = this.modelCache.get(key);
183
- // if (cached && (now - cached.ts) < this.cacheTTLms) {
184
- // if (!cached.enable) return { enable: false };
185
- // const fields = cached.fields.filter(f =>
186
- // f.enableAuditTracking &&
187
- // !['mediaSingle', 'mediaMultiple', 'computed', 'richText', 'json'].includes(f.type) &&
188
- // !(f.type === 'relation' && f.relationType === 'one-to-many')
189
- // );
190
- // const present = fields.map(f => f.name).filter(n => entity?.[n] !== undefined);
191
- // return { enable: present.length > 0, auditFields: present };
192
- // }
193
-
194
- // const model = await this.modelMetadataRepo.findOne({
195
- // where: { singularName: lowerFirst(metadata.name) },
196
- // relations: { fields: true, module: true },
197
- // });
198
- // const enable = !!model?.enableAuditTracking;
199
- // const fields = model?.fields ?? [];
200
- // this.modelCache.set(key, { enable, fields, ts: now });
201
-
202
- // if (!enable) return { enable: false };
203
- // const filtered = fields.filter(f =>
204
- // f.enableAuditTracking &&
205
- // !['mediaSingle', 'mediaMultiple', 'computed', 'richText', 'json'].includes(f.type) &&
206
- // !(f.type === 'relation' && f.relationType === 'one-to-many')
207
- // );
208
- // const present = filtered.map(f => f.name).filter(n => entity?.[n] !== undefined);
209
- // return { enable: present.length > 0, auditFields: present };
210
- // }
211
-
212
- // private push(event: { queryRunner: any }, msg: ChatterMessagePayload) {
213
- // const arr = this.perTxn.get(event.queryRunner) ?? [];
214
- // arr.push(msg);
215
- // this.perTxn.set(event.queryRunner, arr);
216
- // }
217
-
218
- // async afterInsert(event: InsertEvent<any>) {
219
- // if (!event.entity) return;
220
- // const enable = await this.shouldTrackAudit(event.entity, event.metadata);
221
- // if (!enable) return;
222
-
223
- // const payload: ChatterMessagePayload = {
224
- // eventType: 'insert',
225
- // model: event.metadata.name,
226
- // entityId: String(event.entity.id ?? event.entity.uuid ?? ''),
227
- // occurredAt: new Date().toISOString(),
228
- // after: this.safeCopy(event.entity),
229
- // userId: this.getUserId(),
230
- // };
231
- // this.push(event, payload);
232
- // }
233
-
234
- // async afterUpdate(event: UpdateEvent<any>) {
235
- // // Updated entity may be null if you used raw query; fall back to databaseEntity
236
- // const current = event.entity ?? {};
237
- // const before = event.databaseEntity ?? {};
238
- // const { enable, auditFields } = await this.shouldTrackAudit(current, event.metadata);
239
- // if (!enable) return;
240
-
241
- // const changedCols = (event.updatedColumns || []).map(c => c.propertyName);
242
- // const payload: ChatterMessagePayload = {
243
- // eventType: 'update',
244
- // model: event.metadata.name,
245
- // entityId: String((current as any).id ?? (before as any).id ?? ''),
246
- // occurredAt: new Date().toISOString(),
247
- // before: this.pick(before, auditFields || changedCols),
248
- // after: this.pick(current, auditFields || changedCols),
249
- // diff: changedCols,
250
- // userId: this.getUserId(),
251
- // };
252
- // this.push(event, payload);
253
- // }
254
-
255
- // async afterRemove(event: RemoveEvent<any>) {
256
- // const base = event.entity ?? event.databaseEntity;
257
- // if (!base) return;
258
-
259
- // const { enable } = await this.shouldTrackAudit(base, event.metadata);
260
- // if (!enable) return;
261
-
262
- // const payload: ChatterMessagePayload = {
263
- // eventType: 'delete',
264
- // model: event.metadata.name,
265
- // entityId: String((base as any).id ?? ''),
266
- // occurredAt: new Date().toISOString(),
267
- // before: this.safeCopy(base),
268
- // userId: this.getUserId(),
269
- // };
270
- // this.push(event, payload);
271
- // }
272
-
273
- // // Publish AFTER the transaction commits -> no idle-in-transaction
274
- // async afterTransactionCommit(event: { queryRunner: any }) {
275
- // const batch = this.perTxn.get(event.queryRunner) ?? [];
276
- // this.perTxn.delete(event.queryRunner);
277
- // for (const msg of batch) {
278
- // try {
279
- // await this.publisherFactory.publish({ payload: msg, parentEntity: msg.model, parentEntityId: msg.entityId }, 'ChatterQueuePublisher');
280
- // } catch (err) {
281
- // // log + optionally send to a DLQ or retry queue
282
- // // do NOT throw; commit already happened
283
- // // your RabbitMqPublisher likely tracks failures in MqMessage tables anyway
284
- // }
285
- // }
286
- // }
287
-
288
- // afterTransactionRollback(event: { queryRunner: any }) {
289
- // this.perTxn.delete(event.queryRunner);
290
- // }
291
-
292
- // // --- small helpers to keep payloads JSON-safe and small ---
293
- // private safeCopy(obj: any) {
294
- // try {
295
- // return JSON.parse(JSON.stringify(obj));
296
- // } catch {
297
- // return {}; // strip circular refs
298
- // }
299
- // }
300
-
301
- // private pick(obj: any, keys: string[]) {
302
- // const out: any = {};
303
- // for (const k of keys) out[k] = obj?.[k];
304
- // return this.safeCopy(out);
305
- // }
306
-
307
- // private getUserId(): string | null {
308
-
309
- // const activeUser = this.requestContext.getActiveUser();
310
- // if (activeUser?.sub)
311
- // return String(activeUser.sub);
312
- // }
313
-
314
-
315
- // }
@@ -78,9 +78,9 @@ export class ComputedEntityFieldSubscriber implements EntitySubscriberInterface
78
78
  modelName
79
79
  );
80
80
  //TODO: We can add a feature i.e dependsOn, where we can check if the computed field depends on other computed fields and evaluate them first
81
- await Promise.all(
82
- computedFieldsTobeEvaluated.map(c => this.evaluateComputedField(this.attachContext(c, eventContext), entity, currentOperation))
83
- )
81
+ for (const computedField of computedFieldsTobeEvaluated) {
82
+ await this.evaluateComputedField(this.attachContext(computedField, eventContext), entity, currentOperation);
83
+ }
84
84
  }
85
85
 
86
86
  private handleComputedFieldEvaluationJob(entity: any, currentOperation: ComputedFieldTriggerOperation, modelName: string, eventContext?: TypeOrmEventContext) {
@@ -1,11 +1,9 @@
1
1
  import { Injectable, Scope } from "@nestjs/common";
2
2
  import { InjectDataSource } from "@nestjs/typeorm";
3
- import { User } from "src/entities/user.entity";
4
- import { ActiveUserData } from "src/interfaces/active-user-data.interface";
5
3
  import { RequestContextService } from "src/services/request-context.service";
6
- import { DataSource, EntitySubscriberInterface, EventSubscriber, InsertEvent, UpdateEvent } from "typeorm";
4
+ import { DataSource, EntitySubscriberInterface, InsertEvent, UpdateEvent } from "typeorm";
7
5
 
8
- @Injectable({scope: Scope.TRANSIENT})
6
+ @Injectable({ scope: Scope.TRANSIENT })
9
7
  // @EventSubscriber()
10
8
  export class CreatedByUpdatedBySubscriber implements EntitySubscriberInterface {
11
9
  private dataSource: DataSource;
@@ -30,7 +28,7 @@ export class CreatedByUpdatedBySubscriber implements EntitySubscriberInterface {
30
28
  await this.stampUserField(event, false);
31
29
  }
32
30
 
33
- private async stampUserField(event: InsertEvent<any> | UpdateEvent<any>, isInsert: boolean){
31
+ private async stampUserField(event: InsertEvent<any> | UpdateEvent<any>, isInsert: boolean) {
34
32
  if (!event.entity) {
35
33
  return;
36
34
  }
@@ -40,21 +38,29 @@ export class CreatedByUpdatedBySubscriber implements EntitySubscriberInterface {
40
38
  return;
41
39
  }
42
40
 
43
- const loadedUser = await this.loadUser(activeUserOrUndefined as unknown as ActiveUserData);
41
+ // const loadedUser = await this.loadUser(activeUserOrUndefined as unknown as ActiveUserData);
42
+ // if (isInsert) {
43
+ // event.entity.createdBy = loadedUser?.id;
44
+ // event.entity.updatedBy = loadedUser?.id; // For insert, we set both createdBy and updatedBy to the same user
45
+ // }
46
+ // else {
47
+ // event.entity.updatedBy = loadedUser?.id;
48
+ // }
49
+
44
50
  if (isInsert) {
45
- event.entity.createdBy = loadedUser?.id;
46
- event.entity.updatedBy = loadedUser?.id; // For insert, we set both createdBy and updatedBy to the same user
51
+ event.entity.createdBy = activeUserOrUndefined?.sub;
52
+ event.entity.updatedBy = activeUserOrUndefined?.sub; // For insert, we set both createdBy and updatedBy to the same user
47
53
  }
48
54
  else {
49
- event.entity.updatedBy = loadedUser?.id;
55
+ event.entity.updatedBy = activeUserOrUndefined?.sub;
50
56
  }
51
57
  }
52
58
 
53
- private async loadUser(activeUser: ActiveUserData): Promise<User> {
54
- const userRepo = this.defaultDataSource.getRepository(User); // Assuming 'User' is the entity name for users in your application
55
- const loadedUser = await userRepo.findOne({
56
- where: { id: activeUser.sub }, // Assuming 'sub' is the user ID in the JWT token
57
- });
58
- return loadedUser;;
59
- }
59
+ // private async loadUser(activeUser: ActiveUserData): Promise<User> {
60
+ // const userRepo = this.defaultDataSource.getRepository(User); // Assuming 'User' is the entity name for users in your application
61
+ // const loadedUser = await userRepo.findOne({
62
+ // where: { id: activeUser.sub }, // Assuming 'sub' is the user ID in the JWT token
63
+ // });
64
+ // return loadedUser;;
65
+ // }
60
66
  }
@@ -20,59 +20,67 @@ function dateToUtcComponentString(d: Date): string {
20
20
  const ss = pad(d.getUTCSeconds());
21
21
  const ms = pad(d.getUTCMilliseconds(), 3);
22
22
 
23
- // A naive timestamp string representing the DB wall-clock components
23
+ // A "naive" timestamp string representing the DB wall-clock components
24
24
  return `${yyyy}-${mm}-${dd} ${hh}:${mi}:${ss}.${ms}`;
25
25
  }
26
26
 
27
- export const LocalDateTimeTransformer: ValueTransformer & { utc: ValueTransformer } = {
28
- // DB → Entity
29
- from(value: Date | string | null | undefined): Date | null | undefined {
27
+ function getWallClockConfig(): { tz: string; wallTimeMode: boolean } {
28
+ return {
29
+ tz: process.env.SOLIDX_WALL_TIME_TIMEZONE || process.env.SOLIDX_TIMEZONE || "UTC",
30
+ wallTimeMode: (process.env.SOLIDX_TIME_STORED_AS_WALL_TIME || "").toLowerCase() === "true",
31
+ };
32
+ }
33
+
34
+ /**
35
+ * Returns a dayjs instance positioned at the wall-clock time for the given Date.
36
+ * - Wall-clock mode ON: dayjs in the configured timezone (components = wall-clock components)
37
+ * - Wall-clock mode OFF: dayjs in UTC
38
+ * Counterpart to serializeDate — use this to format/display a date value correctly.
39
+ */
40
+ export function parseDate(date: Date): dayjs.Dayjs {
41
+ const { tz, wallTimeMode } = getWallClockConfig();
42
+ if (!wallTimeMode) return dayjs.utc(date);
43
+ return dayjs(date).tz(tz);
44
+ }
30
45
 
31
- const SOLIDX_WALL_TIME_TZ = process.env.SOLIDX_WALL_TIME_TIMEZONE || process.env.SOLIDX_TIMEZONE || "UTC";
32
- const SOLIDX_TIME_STORED_AS_WALL_TIME = (process.env.SOLIDX_TIME_STORED_AS_WALL_TIME || "").toLowerCase() === "true";
46
+ /**
47
+ * Converts a Date to a string for storage in plain text columns (e.g. audit values).
48
+ * - Wall-clock mode ON: "YYYY-MM-DD HH:mm:ss.SSS" in the configured timezone (no Z suffix)
49
+ * - Wall-clock mode OFF: ISO 8601 UTC string with Z suffix
50
+ * The presence/absence of the Z suffix lets consumers distinguish the two cases.
51
+ */
52
+ export function serializeDate(date: Date): string {
53
+ const { wallTimeMode } = getWallClockConfig();
54
+ if (!wallTimeMode) return date.toISOString();
55
+ return parseDate(date).format("YYYY-MM-DD HH:mm:ss.SSS");
56
+ }
33
57
 
34
- // critical... super important to return undefined here
58
+ export const LocalDateTimeTransformer: ValueTransformer = {
59
+ // DB -> Entity
60
+ from(value: Date | string | null | undefined): Date | null | undefined {
61
+ // critical... super important to return undefined here
35
62
  if (value === undefined) return undefined;
36
63
  if (value === null) return null;
37
64
 
38
- if (!SOLIDX_TIME_STORED_AS_WALL_TIME) {
65
+ const { tz, wallTimeMode } = getWallClockConfig();
66
+
67
+ if (!wallTimeMode) {
39
68
  return dayjs(value).toDate();
40
69
  }
41
70
 
42
71
  const naive = value instanceof Date ? dateToUtcComponentString(value) : String(value);
43
- return dayjs.tz(naive, SOLIDX_WALL_TIME_TZ).utc().toDate();
72
+ return dayjs.tz(naive, tz).utc().toDate();
44
73
  },
45
74
 
46
- // Entity DB
75
+ // Entity -> DB
47
76
  to(value: Date | null | undefined): Date | null | undefined {
48
-
49
- const SOLIDX_WALL_TIME_TZ = process.env.SOLIDX_WALL_TIME_TIMEZONE || process.env.SOLIDX_TIMEZONE || "UTC";
50
- const SOLIDX_TIME_STORED_AS_WALL_TIME = (process.env.SOLIDX_TIME_STORED_AS_WALL_TIME || "").toLowerCase() === "true";
51
-
52
- // critical... super important to return undefined here
77
+ // critical... super important to return undefined here
53
78
  if (value === undefined) return undefined;
54
79
  if (value === null) return null;
55
80
 
56
- if (!SOLIDX_TIME_STORED_AS_WALL_TIME) {
57
- return dayjs(value).toDate();
58
- }
59
-
60
- const wallTimeStr = dayjs(value).tz(SOLIDX_WALL_TIME_TZ).format("YYYY-MM-DD HH:mm:ss.SSS");
81
+ const wallTimeStr = serializeDate(value);
61
82
  return dayjs.utc(wallTimeStr).toDate();
62
83
  },
63
84
 
64
- utc: {
65
- from(value: Date | string | null | undefined): Date | null | undefined {
66
- if (value === undefined) return undefined;
67
- if (value === null) return null;
68
- return dayjs(value).toDate();
69
- },
70
- to(value: Date | null | undefined): Date | null | undefined {
71
- if (value === undefined) return undefined;
72
- if (value === null) return null;
73
- return dayjs(value).toDate();
74
- }
75
- }
76
85
  };
77
86
 
78
- export const UtcDateTimeTransformer = LocalDateTimeTransformer.utc;
@@ -4,9 +4,10 @@ import { Logger } from 'winston';
4
4
  import { Inject } from '@nestjs/common';
5
5
  import { WINSTON_MODULE_PROVIDER } from 'nest-winston';
6
6
  import * as winston from 'winston';
7
+ import { Environment } from './decorators/disallow-in-production.decorator';
7
8
 
8
9
  export const WinstonLoggerConfig = {
9
- level: 'debug', // Allow all log levels for debugging
10
+ level: process.env.LOG_LEVEL || (process.env.ENV === Environment.Production ? 'warn' : 'debug'),
10
11
  format: winston.format.combine(
11
12
  winston.format.timestamp(),
12
13
  winston.format.errors({ stack: true }),
@@ -1 +0,0 @@
1
- {"version":3,"file":"api-email-publisher.service.d.ts","sourceRoot":"","sources":["../../src/jobs/api-email-publisher.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,iBAAiB,EAAE,MAAM,gDAAgD,CAAC;AAEnF,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAC;AAC9E,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AAEpD,qBACa,sBAAuB,SAAQ,iBAAiB,CAAC,GAAG,CAAC;IAE1D,SAAS,CAAC,QAAQ,CAAC,gBAAgB,EAAE,gBAAgB;IACrD,SAAS,CAAC,QAAQ,CAAC,qBAAqB,EAAE,qBAAqB;gBAD5C,gBAAgB,EAAE,gBAAgB,EAClC,qBAAqB,EAAE,qBAAqB;IAKnE,OAAO,IAAI,mBAAmB;CAKjC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"api-email-publisher.service.js","sourceRoot":"","sources":["../../src/jobs/api-email-publisher.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA4C;AAE5C,8FAAmF;AACnF,wFAAyD;AACzD,mFAA8E;AAC9E,uEAAmE;AAI5D,IAAM,sBAAsB,GAA5B,MAAM,sBAAuB,SAAQ,8CAAsB;IAC9D,YACuB,gBAAkC,EAClC,qBAA4C;QAE/D,KAAK,CAAC,gBAAgB,EAAE,qBAAqB,CAAC,CAAC;QAH5B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,0BAAqB,GAArB,qBAAqB,CAAuB;IAGnE,CAAC;IAED,OAAO;QACH,OAAO;YACH,GAAG,iCAAgB;SACtB,CAAA;IACL,CAAC;CACJ,CAAA;AAbY,wDAAsB;iCAAtB,sBAAsB;IADlC,IAAA,mBAAU,GAAE;qCAGgC,qCAAgB;QACX,gDAAqB;GAH1D,sBAAsB,CAalC","sourcesContent":["import { Injectable } from '@nestjs/common';\n\nimport { RabbitMqPublisher } from 'src/services/queues/rabbitmq-publisher.service';\nimport mailQueueOptions from './api-email-queue-options';\nimport { MqMessageQueueService } from 'src/services/mq-message-queue.service';\nimport { MqMessageService } from 'src/services/mq-message.service';\nimport { QueuesModuleOptions } from \"../interfaces\";\n\n@Injectable()\nexport class ApiEmailQueuePublisher extends RabbitMqPublisher<any> {\n constructor(\n protected readonly mqMessageService: MqMessageService,\n protected readonly mqMessageQueueService: MqMessageQueueService,\n ) {\n super(mqMessageService, mqMessageQueueService);\n }\n\n options(): QueuesModuleOptions {\n return {\n ...mailQueueOptions\n }\n }\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"api-email-queue-options.d.ts","sourceRoot":"","sources":["../../src/jobs/api-email-queue-options.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;;;;;;AAI3C,wBAIE"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"api-email-queue-options.js","sourceRoot":"","sources":["../../src/jobs/api-email-queue-options.ts"],"names":[],"mappings":";;AACA,8CAA2C;AAE3C,MAAM,mBAAmB,GAAG,sBAAsB,CAAC;AAEnD,kBAAe;IACX,IAAI,EAAE,mBAAmB;IACzB,IAAI,EAAE,uBAAU,CAAC,QAAQ;IACzB,SAAS,EAAE,mBAAmB;CACjC,CAAC","sourcesContent":["import { QueueMessage } from 'src/interfaces/mq';\nimport { BrokerType } from \"../interfaces\";\n\nconst API_MAIL_QUEUE_NAME = 'solid_api_mail_queue';\n\nexport default {\n name: API_MAIL_QUEUE_NAME,\n type: BrokerType.RabbitMQ,\n queueName: API_MAIL_QUEUE_NAME,\n};\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"api-email-subscriber.service.d.ts","sourceRoot":"","sources":["../../src/jobs/api-email-subscriber.service.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,kBAAkB,EAAE,MAAM,iDAAiD,CAAC;AACrF,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,mBAAmB,EAAE,MAAM,wCAAwC,CAAC;AAC7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAC;AAC9E,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AAEpD,qBACa,uBAAwB,SAAQ,kBAAkB,CAAC,GAAG,CAAC;IAE5D,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,QAAQ,CAAC,gBAAgB,EAAE,gBAAgB;IAC3C,QAAQ,CAAC,qBAAqB,EAAE,qBAAqB;gBAFpC,YAAY,EAAE,mBAAmB,EACzC,gBAAgB,EAAE,gBAAgB,EAClC,qBAAqB,EAAE,qBAAqB;IAKzD,OAAO,IAAI,mBAAmB;IAM9B,SAAS,CAAC,OAAO,EAAE,YAAY,CAAC,GAAG,CAAC;CAGvC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"api-email-subscriber.service.js","sourceRoot":"","sources":["../../src/jobs/api-email-subscriber.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA4C;AAE5C,wFAAyD;AACzD,gGAAqF;AAErF,kFAA6E;AAC7E,uEAAmE;AACnE,mFAA8E;AAIvE,IAAM,uBAAuB,GAA7B,MAAM,uBAAwB,SAAQ,gDAAuB;IAChE,YACqB,YAAiC,EACzC,gBAAkC,EAClC,qBAA4C;QAErD,KAAK,CAAC,gBAAgB,EAAE,qBAAqB,CAAC,CAAC;QAJ9B,iBAAY,GAAZ,YAAY,CAAqB;QACzC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,0BAAqB,GAArB,qBAAqB,CAAuB;IAGzD,CAAC;IAED,OAAO;QACH,OAAO;YACH,GAAG,iCAAgB;SACtB,CAAA;IACL,CAAC;IAED,SAAS,CAAC,OAA0B;QAChC,IAAI,CAAC,YAAY,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC;IACtD,CAAC;CACJ,CAAA;AAlBY,0DAAuB;kCAAvB,uBAAuB;IADnC,IAAA,mBAAU,GAAE;qCAG0B,2CAAmB;QACvB,qCAAgB;QACX,gDAAqB;GAJhD,uBAAuB,CAkBnC","sourcesContent":["import { Injectable } from '@nestjs/common';\n\nimport mailQueueOptions from './api-email-queue-options';\nimport { RabbitMqSubscriber } from 'src/services/queues/rabbitmq-subscriber.service';\nimport { QueueMessage } from 'src/interfaces/mq';\nimport { ElasticEmailService } from '../services/mail/elastic-email.service';\nimport { MqMessageService } from 'src/services/mq-message.service';\nimport { MqMessageQueueService } from 'src/services/mq-message-queue.service';\nimport { QueuesModuleOptions } from \"../interfaces\";\n\n@Injectable()\nexport class ApiEmailQueueSubscriber extends RabbitMqSubscriber<any> {\n constructor(\n private readonly emailService: ElasticEmailService,\n readonly mqMessageService: MqMessageService,\n readonly mqMessageQueueService: MqMessageQueueService,\n ) {\n super(mqMessageService, mqMessageQueueService);\n }\n\n options(): QueuesModuleOptions {\n return {\n ...mailQueueOptions\n }\n }\n\n subscribe(message: QueueMessage<any>) {\n this.emailService.sendEmailSynchronously(message);\n }\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"chatter-queue-options.d.ts","sourceRoot":"","sources":["../../src/jobs/chatter-queue-options.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;;;;;;AAI3C,wBAIE"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"chatter-queue-options.js","sourceRoot":"","sources":["../../src/jobs/chatter-queue-options.ts"],"names":[],"mappings":";;AAAA,8CAA2C;AAE3C,MAAM,UAAU,GAAG,qBAAqB,CAAC;AAEzC,kBAAe;IACX,IAAI,EAAE,UAAU;IAChB,IAAI,EAAE,uBAAU,CAAC,QAAQ;IACzB,SAAS,EAAE,UAAU;CACxB,CAAC","sourcesContent":["import { BrokerType } from \"../interfaces\";\n\nconst QUEUE_NAME = 'solid_chatter_queue';\n\nexport default {\n name: QUEUE_NAME,\n type: BrokerType.RabbitMQ,\n queueName: QUEUE_NAME,\n};\n"]}
@@ -1,22 +0,0 @@
1
- import { RabbitMqPublisher } from 'src/services/queues/rabbitmq-publisher.service';
2
- import { MqMessageQueueService } from '../services/mq-message-queue.service';
3
- import { MqMessageService } from '../services/mq-message.service';
4
- import { QueuesModuleOptions } from "../interfaces";
5
- export type ChatterEventType = 'insert' | 'update' | 'delete';
6
- export interface ChatterMessagePayload {
7
- eventType: ChatterEventType;
8
- model: string;
9
- entityId: string;
10
- occurredAt: string;
11
- before?: any;
12
- after?: any;
13
- diff?: string[];
14
- userId?: string | null;
15
- }
16
- export declare class ChatterQueuePublisher extends RabbitMqPublisher<any> {
17
- protected readonly mqMessageService: MqMessageService;
18
- protected readonly mqMessageQueueService: MqMessageQueueService;
19
- constructor(mqMessageService: MqMessageService, mqMessageQueueService: MqMessageQueueService);
20
- options(): QueuesModuleOptions;
21
- }
22
- //# sourceMappingURL=chatter-queue-publisher.service.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"chatter-queue-publisher.service.d.ts","sourceRoot":"","sources":["../../src/jobs/chatter-queue-publisher.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,iBAAiB,EAAE,MAAM,gDAAgD,CAAC;AAEnF,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAC7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AAGpD,MAAM,MAAM,gBAAgB,GAAG,QAAQ,GAAG,QAAQ,GAAG,QAAQ,CAAC;AAE9D,MAAM,WAAW,qBAAqB;IAClC,SAAS,EAAE,gBAAgB,CAAC;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,GAAG,CAAC;IACb,KAAK,CAAC,EAAE,GAAG,CAAC;IACZ,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC1B;AAED,qBACa,qBAAsB,SAAQ,iBAAiB,CAAC,GAAG,CAAC;IAEzD,SAAS,CAAC,QAAQ,CAAC,gBAAgB,EAAE,gBAAgB;IACrD,SAAS,CAAC,QAAQ,CAAC,qBAAqB,EAAE,qBAAqB;gBAD5C,gBAAgB,EAAE,gBAAgB,EAClC,qBAAqB,EAAE,qBAAqB;IAKnE,OAAO,IAAI,mBAAmB;CAKjC"}