@solidxai/core 0.1.2 → 0.1.5-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 (469) hide show
  1. package/.claude/settings.local.json +8 -0
  2. package/dist/commands/run-tests.command.d.ts +37 -0
  3. package/dist/commands/run-tests.command.d.ts.map +1 -0
  4. package/dist/commands/run-tests.command.js +345 -0
  5. package/dist/commands/run-tests.command.js.map +1 -0
  6. package/dist/commands/test-data.command.d.ts +6 -6
  7. package/dist/commands/test-data.command.d.ts.map +1 -1
  8. package/dist/commands/test-data.command.js +25 -25
  9. package/dist/commands/test-data.command.js.map +1 -1
  10. package/dist/commands/test.command.d.ts +5 -0
  11. package/dist/commands/test.command.d.ts.map +1 -0
  12. package/dist/commands/test.command.js +26 -0
  13. package/dist/commands/test.command.js.map +1 -0
  14. package/dist/constants/error-messages.d.ts +1 -0
  15. package/dist/constants/error-messages.d.ts.map +1 -1
  16. package/dist/constants/error-messages.js +1 -0
  17. package/dist/constants/error-messages.js.map +1 -1
  18. package/dist/constants.d.ts +3 -3
  19. package/dist/constants.d.ts.map +1 -1
  20. package/dist/constants.js +12 -12
  21. package/dist/constants.js.map +1 -1
  22. package/dist/controllers/otp-authentication.controller.d.ts +1 -4
  23. package/dist/controllers/otp-authentication.controller.d.ts.map +1 -1
  24. package/dist/controllers/otp-authentication.controller.js +1 -1
  25. package/dist/controllers/role-metadata.controller.d.ts +1 -0
  26. package/dist/controllers/role-metadata.controller.d.ts.map +1 -1
  27. package/dist/controllers/role-metadata.controller.js +15 -0
  28. package/dist/controllers/role-metadata.controller.js.map +1 -1
  29. package/dist/controllers/service.controller.d.ts +0 -9
  30. package/dist/controllers/service.controller.d.ts.map +1 -1
  31. package/dist/controllers/service.controller.js +0 -45
  32. package/dist/controllers/service.controller.js.map +1 -1
  33. package/dist/dtos/basic-filters.dto.d.ts.map +1 -1
  34. package/dist/dtos/basic-filters.dto.js.map +1 -1
  35. package/dist/dtos/create-email-template.dto.d.ts.map +1 -1
  36. package/dist/dtos/create-email-template.dto.js.map +1 -1
  37. package/dist/dtos/create-list-of-values.dto.d.ts.map +1 -1
  38. package/dist/dtos/create-list-of-values.dto.js.map +1 -1
  39. package/dist/dtos/create-menu-item-metadata.dto.d.ts.map +1 -1
  40. package/dist/dtos/create-menu-item-metadata.dto.js.map +1 -1
  41. package/dist/dtos/create-role-metadata.dto.d.ts.map +1 -1
  42. package/dist/dtos/create-role-metadata.dto.js.map +1 -1
  43. package/dist/dtos/create-scheduled-job.dto.d.ts.map +1 -1
  44. package/dist/dtos/create-scheduled-job.dto.js.map +1 -1
  45. package/dist/dtos/create-security-rule.dto.d.ts.map +1 -1
  46. package/dist/dtos/create-security-rule.dto.js.map +1 -1
  47. package/dist/dtos/create-sms-template.dto.d.ts.map +1 -1
  48. package/dist/dtos/create-sms-template.dto.js.map +1 -1
  49. package/dist/dtos/create-user.dto.d.ts +1 -0
  50. package/dist/dtos/create-user.dto.d.ts.map +1 -1
  51. package/dist/dtos/create-user.dto.js +2 -1
  52. package/dist/dtos/create-user.dto.js.map +1 -1
  53. package/dist/dtos/create-view-metadata.dto.d.ts.map +1 -1
  54. package/dist/dtos/create-view-metadata.dto.js.map +1 -1
  55. package/dist/dtos/otp-sign-in.dto.d.ts +1 -1
  56. package/dist/dtos/otp-sign-in.dto.d.ts.map +1 -1
  57. package/dist/dtos/otp-sign-in.dto.js +2 -2
  58. package/dist/dtos/otp-sign-in.dto.js.map +1 -1
  59. package/dist/dtos/otp-sign-up.dto.d.ts +2 -2
  60. package/dist/dtos/otp-sign-up.dto.d.ts.map +1 -1
  61. package/dist/dtos/otp-sign-up.dto.js +2 -2
  62. package/dist/dtos/otp-sign-up.dto.js.map +1 -1
  63. package/dist/dtos/resolve-s3-url.dto.d.ts +2 -5
  64. package/dist/dtos/resolve-s3-url.dto.d.ts.map +1 -1
  65. package/dist/dtos/resolve-s3-url.dto.js +1 -13
  66. package/dist/dtos/resolve-s3-url.dto.js.map +1 -1
  67. package/dist/dtos/sign-up.dto.d.ts.map +1 -1
  68. package/dist/dtos/sign-up.dto.js.map +1 -1
  69. package/dist/dtos/update-email-template.dto.d.ts.map +1 -1
  70. package/dist/dtos/update-email-template.dto.js.map +1 -1
  71. package/dist/dtos/update-list-of-values.dto.d.ts.map +1 -1
  72. package/dist/dtos/update-list-of-values.dto.js.map +1 -1
  73. package/dist/dtos/update-menu-item-metadata.dto.d.ts.map +1 -1
  74. package/dist/dtos/update-menu-item-metadata.dto.js.map +1 -1
  75. package/dist/dtos/update-scheduled-job.dto.d.ts.map +1 -1
  76. package/dist/dtos/update-scheduled-job.dto.js.map +1 -1
  77. package/dist/dtos/update-security-rule.dto.d.ts.map +1 -1
  78. package/dist/dtos/update-security-rule.dto.js.map +1 -1
  79. package/dist/dtos/update-sms-template.dto.d.ts.map +1 -1
  80. package/dist/dtos/update-sms-template.dto.js.map +1 -1
  81. package/dist/dtos/update-view-metadata.dto.d.ts.map +1 -1
  82. package/dist/dtos/update-view-metadata.dto.js.map +1 -1
  83. package/dist/entities/user.entity.d.ts +1 -0
  84. package/dist/entities/user.entity.d.ts.map +1 -1
  85. package/dist/entities/user.entity.js +6 -1
  86. package/dist/entities/user.entity.js.map +1 -1
  87. package/dist/helpers/field-crud-managers/ManyToManyRelationFieldCrudManager.d.ts +2 -0
  88. package/dist/helpers/field-crud-managers/ManyToManyRelationFieldCrudManager.d.ts.map +1 -1
  89. package/dist/helpers/field-crud-managers/ManyToManyRelationFieldCrudManager.js +33 -23
  90. package/dist/helpers/field-crud-managers/ManyToManyRelationFieldCrudManager.js.map +1 -1
  91. package/dist/helpers/field-crud-managers/OneToManyRelationFieldCrudManager.d.ts +3 -0
  92. package/dist/helpers/field-crud-managers/OneToManyRelationFieldCrudManager.d.ts.map +1 -1
  93. package/dist/helpers/field-crud-managers/OneToManyRelationFieldCrudManager.js +36 -23
  94. package/dist/helpers/field-crud-managers/OneToManyRelationFieldCrudManager.js.map +1 -1
  95. package/dist/helpers/security.helper.js +1 -0
  96. package/dist/helpers/security.helper.js.map +1 -1
  97. package/dist/index.d.ts +3 -4
  98. package/dist/index.d.ts.map +1 -1
  99. package/dist/index.js +3 -4
  100. package/dist/index.js.map +1 -1
  101. package/dist/repository/solid-base.repository.d.ts +10 -1
  102. package/dist/repository/solid-base.repository.d.ts.map +1 -1
  103. package/dist/repository/solid-base.repository.js +109 -0
  104. package/dist/repository/solid-base.repository.js.map +1 -1
  105. package/dist/seeders/module-metadata-seeder.service.d.ts +2 -0
  106. package/dist/seeders/module-metadata-seeder.service.d.ts.map +1 -1
  107. package/dist/seeders/module-metadata-seeder.service.js +142 -91
  108. package/dist/seeders/module-metadata-seeder.service.js.map +1 -1
  109. package/dist/seeders/module-test-data.service.d.ts.map +1 -1
  110. package/dist/seeders/module-test-data.service.js +3 -3
  111. package/dist/seeders/module-test-data.service.js.map +1 -1
  112. package/dist/seeders/permission-metadata-seeder.service.d.ts +1 -1
  113. package/dist/seeders/permission-metadata-seeder.service.d.ts.map +1 -1
  114. package/dist/seeders/permission-metadata-seeder.service.js +1 -1
  115. package/dist/seeders/permission-metadata-seeder.service.js.map +1 -1
  116. package/dist/seeders/seed-data/solid-core-metadata.json +12 -25
  117. package/dist/services/authentication.service.d.ts +22 -8
  118. package/dist/services/authentication.service.d.ts.map +1 -1
  119. package/dist/services/authentication.service.js +228 -214
  120. package/dist/services/authentication.service.js.map +1 -1
  121. package/dist/services/chatter-message.service.d.ts +2 -0
  122. package/dist/services/chatter-message.service.d.ts.map +1 -1
  123. package/dist/services/chatter-message.service.js +18 -2
  124. package/dist/services/chatter-message.service.js.map +1 -1
  125. package/dist/services/crud-helper.service.d.ts +4 -0
  126. package/dist/services/crud-helper.service.d.ts.map +1 -1
  127. package/dist/services/crud-helper.service.js +66 -32
  128. package/dist/services/crud-helper.service.js.map +1 -1
  129. package/dist/services/crud.service.d.ts.map +1 -1
  130. package/dist/services/crud.service.js +7 -4
  131. package/dist/services/crud.service.js.map +1 -1
  132. package/dist/services/field-metadata.service.d.ts.map +1 -1
  133. package/dist/services/field-metadata.service.js.map +1 -1
  134. package/dist/services/file/disk-file.service.d.ts +0 -2
  135. package/dist/services/file/disk-file.service.d.ts.map +1 -1
  136. package/dist/services/file/disk-file.service.js +7 -16
  137. package/dist/services/file/disk-file.service.js.map +1 -1
  138. package/dist/services/file/index.d.ts +1 -0
  139. package/dist/services/file/index.d.ts.map +1 -1
  140. package/dist/services/file/index.js +1 -0
  141. package/dist/services/file/index.js.map +1 -1
  142. package/dist/services/file/storage-path-builder.d.ts +17 -0
  143. package/dist/services/file/storage-path-builder.d.ts.map +1 -0
  144. package/dist/{seeders/sms-template-seeder.service.js → services/file/storage-path-builder.js} +45 -35
  145. package/dist/services/file/storage-path-builder.js.map +1 -0
  146. package/dist/services/media.service.d.ts +1 -1
  147. package/dist/services/media.service.d.ts.map +1 -1
  148. package/dist/services/media.service.js +45 -6
  149. package/dist/services/media.service.js.map +1 -1
  150. package/dist/services/mediaStorageProviders/file-s3-storage-provider.js.map +1 -1
  151. package/dist/services/mediaStorageProviders/file-storage-provider.d.ts.map +1 -1
  152. package/dist/services/mediaStorageProviders/file-storage-provider.js +46 -7
  153. package/dist/services/mediaStorageProviders/file-storage-provider.js.map +1 -1
  154. package/dist/services/module-metadata.service.d.ts +4 -6
  155. package/dist/services/module-metadata.service.d.ts.map +1 -1
  156. package/dist/services/module-metadata.service.js +16 -14
  157. package/dist/services/module-metadata.service.js.map +1 -1
  158. package/dist/services/queues/common.d.ts +3 -0
  159. package/dist/services/queues/common.d.ts.map +1 -0
  160. package/dist/services/queues/common.js +39 -0
  161. package/dist/services/queues/common.js.map +1 -0
  162. package/dist/services/queues/database-publisher.service.d.ts.map +1 -1
  163. package/dist/services/queues/database-publisher.service.js +3 -1
  164. package/dist/services/queues/database-publisher.service.js.map +1 -1
  165. package/dist/services/queues/database-subscriber.service.d.ts.map +1 -1
  166. package/dist/services/queues/database-subscriber.service.js +5 -2
  167. package/dist/services/queues/database-subscriber.service.js.map +1 -1
  168. package/dist/services/queues/rabbitmq-publisher.service.d.ts.map +1 -1
  169. package/dist/services/queues/rabbitmq-publisher.service.js +13 -6
  170. package/dist/services/queues/rabbitmq-publisher.service.js.map +1 -1
  171. package/dist/services/queues/rabbitmq-subscriber.service.d.ts.map +1 -1
  172. package/dist/services/queues/rabbitmq-subscriber.service.js +9 -5
  173. package/dist/services/queues/rabbitmq-subscriber.service.js.map +1 -1
  174. package/dist/services/setting.service.d.ts +3 -2
  175. package/dist/services/setting.service.d.ts.map +1 -1
  176. package/dist/services/setting.service.js +7 -4
  177. package/dist/services/setting.service.js.map +1 -1
  178. package/dist/services/settings/default-settings-provider.service.d.ts +24 -2
  179. package/dist/services/settings/default-settings-provider.service.d.ts.map +1 -1
  180. package/dist/services/settings/default-settings-provider.service.js +8 -6
  181. package/dist/services/settings/default-settings-provider.service.js.map +1 -1
  182. package/dist/solid-core.module.d.ts +3 -1
  183. package/dist/solid-core.module.d.ts.map +1 -1
  184. package/dist/solid-core.module.js +49 -9
  185. package/dist/solid-core.module.js.map +1 -1
  186. package/dist/testing/__examples__/register-example-specs.d.ts +3 -0
  187. package/dist/testing/__examples__/register-example-specs.d.ts.map +1 -0
  188. package/dist/testing/__examples__/register-example-specs.js +8 -0
  189. package/dist/testing/__examples__/register-example-specs.js.map +1 -0
  190. package/dist/testing/__examples__/specs/custom-health.spec.d.ts +17 -0
  191. package/dist/testing/__examples__/specs/custom-health.spec.d.ts.map +1 -0
  192. package/dist/testing/__examples__/specs/custom-health.spec.js +30 -0
  193. package/dist/testing/__examples__/specs/custom-health.spec.js.map +1 -0
  194. package/dist/testing/adapters/api/api-adapter.d.ts +9 -0
  195. package/dist/testing/adapters/api/api-adapter.d.ts.map +1 -0
  196. package/dist/testing/adapters/api/api-adapter.js +76 -0
  197. package/dist/testing/adapters/api/api-adapter.js.map +1 -0
  198. package/dist/testing/adapters/api/api.types.d.ts +14 -0
  199. package/dist/testing/adapters/api/api.types.d.ts.map +1 -0
  200. package/dist/testing/adapters/api/api.types.js +3 -0
  201. package/dist/testing/adapters/api/api.types.js.map +1 -0
  202. package/dist/testing/adapters/ui/playwright-adapter.d.ts +14 -0
  203. package/dist/testing/adapters/ui/playwright-adapter.d.ts.map +1 -0
  204. package/dist/testing/adapters/ui/playwright-adapter.js +80 -0
  205. package/dist/testing/adapters/ui/playwright-adapter.js.map +1 -0
  206. package/dist/testing/adapters/ui/ui.types.d.ts +5 -0
  207. package/dist/testing/adapters/ui/ui.types.d.ts.map +1 -0
  208. package/dist/testing/adapters/ui/ui.types.js +3 -0
  209. package/dist/testing/adapters/ui/ui.types.js.map +1 -0
  210. package/dist/testing/contracts/runtime-context.types.d.ts +35 -0
  211. package/dist/testing/contracts/runtime-context.types.d.ts.map +1 -0
  212. package/dist/testing/contracts/runtime-context.types.js +3 -0
  213. package/dist/testing/contracts/runtime-context.types.js.map +1 -0
  214. package/dist/testing/contracts/test-spec.types.d.ts +21 -0
  215. package/dist/testing/contracts/test-spec.types.d.ts.map +1 -0
  216. package/dist/testing/contracts/test-spec.types.js +3 -0
  217. package/dist/testing/contracts/test-spec.types.js.map +1 -0
  218. package/dist/testing/contracts/testing-metadata.types.d.ts +41 -0
  219. package/dist/testing/contracts/testing-metadata.types.d.ts.map +1 -0
  220. package/dist/testing/contracts/testing-metadata.types.js +3 -0
  221. package/dist/testing/contracts/testing-metadata.types.js.map +1 -0
  222. package/dist/testing/core/interpolation.d.ts +4 -0
  223. package/dist/testing/core/interpolation.d.ts.map +1 -0
  224. package/dist/testing/core/interpolation.js +180 -0
  225. package/dist/testing/core/interpolation.js.map +1 -0
  226. package/dist/testing/core/normalize-steps.d.ts +7 -0
  227. package/dist/testing/core/normalize-steps.d.ts.map +1 -0
  228. package/dist/testing/core/normalize-steps.js +20 -0
  229. package/dist/testing/core/normalize-steps.js.map +1 -0
  230. package/dist/testing/core/resource-store.d.ts +8 -0
  231. package/dist/testing/core/resource-store.d.ts.map +1 -0
  232. package/dist/testing/core/resource-store.js +41 -0
  233. package/dist/testing/core/resource-store.js.map +1 -0
  234. package/dist/testing/core/spec-registry.d.ts +10 -0
  235. package/dist/testing/core/spec-registry.d.ts.map +1 -0
  236. package/dist/testing/core/spec-registry.js +32 -0
  237. package/dist/testing/core/spec-registry.js.map +1 -0
  238. package/dist/testing/core/step-registry.d.ts +10 -0
  239. package/dist/testing/core/step-registry.d.ts.map +1 -0
  240. package/dist/testing/core/step-registry.js +26 -0
  241. package/dist/testing/core/step-registry.js.map +1 -0
  242. package/dist/testing/core/testing-engine.d.ts +14 -0
  243. package/dist/testing/core/testing-engine.d.ts.map +1 -0
  244. package/dist/testing/core/testing-engine.js +97 -0
  245. package/dist/testing/core/testing-engine.js.map +1 -0
  246. package/dist/testing/core/timeout.d.ts +2 -0
  247. package/dist/testing/core/timeout.d.ts.map +1 -0
  248. package/dist/testing/core/timeout.js +18 -0
  249. package/dist/testing/core/timeout.js.map +1 -0
  250. package/dist/testing/reporter/attachments.d.ts +4 -0
  251. package/dist/testing/reporter/attachments.d.ts.map +1 -0
  252. package/dist/testing/reporter/attachments.js +25 -0
  253. package/dist/testing/reporter/attachments.js.map +1 -0
  254. package/dist/testing/reporter/console-reporter.d.ts +45 -0
  255. package/dist/testing/reporter/console-reporter.d.ts.map +1 -0
  256. package/dist/testing/reporter/console-reporter.js +189 -0
  257. package/dist/testing/reporter/console-reporter.js.map +1 -0
  258. package/dist/testing/reporter/reporter.types.d.ts +37 -0
  259. package/dist/testing/reporter/reporter.types.d.ts.map +1 -0
  260. package/dist/testing/reporter/reporter.types.js +3 -0
  261. package/dist/testing/reporter/reporter.types.js.map +1 -0
  262. package/dist/testing/runner/lifecycle.d.ts +9 -0
  263. package/dist/testing/runner/lifecycle.d.ts.map +1 -0
  264. package/dist/testing/runner/lifecycle.js +33 -0
  265. package/dist/testing/runner/lifecycle.js.map +1 -0
  266. package/dist/testing/runner/run-from-metadata.d.ts +24 -0
  267. package/dist/testing/runner/run-from-metadata.d.ts.map +1 -0
  268. package/dist/testing/runner/run-from-metadata.js +70 -0
  269. package/dist/testing/runner/run-from-metadata.js.map +1 -0
  270. package/dist/testing/runner/scenario-filter.d.ts +9 -0
  271. package/dist/testing/runner/scenario-filter.d.ts.map +1 -0
  272. package/dist/testing/runner/scenario-filter.js +22 -0
  273. package/dist/testing/runner/scenario-filter.js.map +1 -0
  274. package/dist/testing/steps/api/auth.step.d.ts +3 -0
  275. package/dist/testing/steps/api/auth.step.d.ts.map +1 -0
  276. package/dist/testing/steps/api/auth.step.js +38 -0
  277. package/dist/testing/steps/api/auth.step.js.map +1 -0
  278. package/dist/testing/steps/api/index.d.ts +3 -0
  279. package/dist/testing/steps/api/index.d.ts.map +1 -0
  280. package/dist/testing/steps/api/index.js +10 -0
  281. package/dist/testing/steps/api/index.js.map +1 -0
  282. package/dist/testing/steps/api/request.step.d.ts +3 -0
  283. package/dist/testing/steps/api/request.step.d.ts.map +1 -0
  284. package/dist/testing/steps/api/request.step.js +281 -0
  285. package/dist/testing/steps/api/request.step.js.map +1 -0
  286. package/dist/testing/steps/assert/http.step.d.ts +3 -0
  287. package/dist/testing/steps/assert/http.step.d.ts.map +1 -0
  288. package/dist/testing/steps/assert/http.step.js +27 -0
  289. package/dist/testing/steps/assert/http.step.js.map +1 -0
  290. package/dist/testing/steps/assert/index.d.ts +3 -0
  291. package/dist/testing/steps/assert/index.d.ts.map +1 -0
  292. package/dist/testing/steps/assert/index.js +12 -0
  293. package/dist/testing/steps/assert/index.js.map +1 -0
  294. package/dist/testing/steps/assert/jsonpath.step.d.ts +3 -0
  295. package/dist/testing/steps/assert/jsonpath.step.d.ts.map +1 -0
  296. package/dist/testing/steps/assert/jsonpath.step.js +40 -0
  297. package/dist/testing/steps/assert/jsonpath.step.js.map +1 -0
  298. package/dist/testing/steps/assert/primitives.step.d.ts +3 -0
  299. package/dist/testing/steps/assert/primitives.step.d.ts.map +1 -0
  300. package/dist/testing/steps/assert/primitives.step.js +43 -0
  301. package/dist/testing/steps/assert/primitives.step.js.map +1 -0
  302. package/dist/testing/steps/test/index.d.ts +3 -0
  303. package/dist/testing/steps/test/index.d.ts.map +1 -0
  304. package/dist/testing/steps/test/index.js +8 -0
  305. package/dist/testing/steps/test/index.js.map +1 -0
  306. package/dist/testing/steps/test/test-spec.step.d.ts +3 -0
  307. package/dist/testing/steps/test/test-spec.step.d.ts.map +1 -0
  308. package/dist/testing/steps/test/test-spec.step.js +41 -0
  309. package/dist/testing/steps/test/test-spec.step.js.map +1 -0
  310. package/dist/testing/steps/ui/actions.step.d.ts +3 -0
  311. package/dist/testing/steps/ui/actions.step.d.ts.map +1 -0
  312. package/dist/testing/steps/ui/actions.step.js +31 -0
  313. package/dist/testing/steps/ui/actions.step.js.map +1 -0
  314. package/dist/testing/steps/ui/assertions.step.d.ts +3 -0
  315. package/dist/testing/steps/ui/assertions.step.d.ts.map +1 -0
  316. package/dist/testing/steps/ui/assertions.step.js +41 -0
  317. package/dist/testing/steps/ui/assertions.step.js.map +1 -0
  318. package/dist/testing/steps/ui/form.step.d.ts +3 -0
  319. package/dist/testing/steps/ui/form.step.d.ts.map +1 -0
  320. package/dist/testing/steps/ui/form.step.js +34 -0
  321. package/dist/testing/steps/ui/form.step.js.map +1 -0
  322. package/dist/testing/steps/ui/index.d.ts +3 -0
  323. package/dist/testing/steps/ui/index.d.ts.map +1 -0
  324. package/dist/testing/steps/ui/index.js +14 -0
  325. package/dist/testing/steps/ui/index.js.map +1 -0
  326. package/dist/testing/steps/ui/navigation.step.d.ts +3 -0
  327. package/dist/testing/steps/ui/navigation.step.d.ts.map +1 -0
  328. package/dist/testing/steps/ui/navigation.step.js +39 -0
  329. package/dist/testing/steps/ui/navigation.step.js.map +1 -0
  330. package/dist/testing/steps/util/index.d.ts +3 -0
  331. package/dist/testing/steps/util/index.d.ts.map +1 -0
  332. package/dist/testing/steps/util/index.js +12 -0
  333. package/dist/testing/steps/util/index.js.map +1 -0
  334. package/dist/testing/steps/util/log.step.d.ts +3 -0
  335. package/dist/testing/steps/util/log.step.d.ts.map +1 -0
  336. package/dist/testing/steps/util/log.step.js +18 -0
  337. package/dist/testing/steps/util/log.step.js.map +1 -0
  338. package/dist/testing/steps/util/require.step.d.ts +3 -0
  339. package/dist/testing/steps/util/require.step.d.ts.map +1 -0
  340. package/dist/testing/steps/util/require.step.js +16 -0
  341. package/dist/testing/steps/util/require.step.js.map +1 -0
  342. package/dist/testing/steps/util/sleep.step.d.ts +3 -0
  343. package/dist/testing/steps/util/sleep.step.d.ts.map +1 -0
  344. package/dist/testing/steps/util/sleep.step.js +13 -0
  345. package/dist/testing/steps/util/sleep.step.js.map +1 -0
  346. package/docs/test-data-workflow.md +51 -11
  347. package/package.json +10 -2
  348. package/src/commands/run-tests.command.ts +278 -0
  349. package/src/commands/test-data.command.ts +26 -26
  350. package/src/commands/test.command.ts +14 -0
  351. package/src/constants/error-messages.ts +1 -0
  352. package/src/constants.ts +3 -3
  353. package/src/controllers/role-metadata.controller.ts +26 -18
  354. package/src/controllers/service.controller.ts +58 -59
  355. package/src/dtos/basic-filters.dto.ts +0 -2
  356. package/src/dtos/create-email-template.dto.ts +7 -0
  357. package/src/dtos/create-list-of-values.dto.ts +7 -0
  358. package/src/dtos/create-menu-item-metadata.dto.ts +12 -1
  359. package/src/dtos/create-role-metadata.dto.ts +9 -0
  360. package/src/dtos/create-scheduled-job.dto.ts +14 -0
  361. package/src/dtos/create-security-rule.dto.ts +6 -0
  362. package/src/dtos/create-sms-template.dto.ts +6 -0
  363. package/src/dtos/create-user.dto.ts +1 -0
  364. package/src/dtos/create-view-metadata.dto.ts +11 -0
  365. package/src/dtos/otp-sign-in.dto.ts +3 -3
  366. package/src/dtos/otp-sign-up.dto.ts +3 -3
  367. package/src/dtos/resolve-s3-url.dto.ts +2 -12
  368. package/src/dtos/sign-up.dto.ts +0 -2
  369. package/src/dtos/update-email-template.dto.ts +6 -0
  370. package/src/dtos/update-list-of-values.dto.ts +8 -0
  371. package/src/dtos/update-menu-item-metadata.dto.ts +12 -0
  372. package/src/dtos/update-scheduled-job.dto.ts +15 -0
  373. package/src/dtos/update-security-rule.dto.ts +7 -0
  374. package/src/dtos/update-sms-template.dto.ts +32 -32
  375. package/src/dtos/update-view-metadata.dto.ts +12 -0
  376. package/src/entities/user.entity.ts +3 -0
  377. package/src/helpers/field-crud-managers/ManyToManyRelationFieldCrudManager.ts +43 -32
  378. package/src/helpers/field-crud-managers/OneToManyRelationFieldCrudManager.ts +45 -33
  379. package/src/helpers/security.helper.ts +1 -1
  380. package/src/index.ts +3 -4
  381. package/src/repository/solid-base.repository.ts +172 -1
  382. package/src/seeders/module-metadata-seeder.service.ts +191 -150
  383. package/src/seeders/module-test-data.service.ts +5 -3
  384. package/src/seeders/permission-metadata-seeder.service.ts +1 -4
  385. package/src/seeders/seed-data/solid-core-metadata.json +12 -25
  386. package/src/services/authentication.service.ts +268 -266
  387. package/src/services/chatter-message.service.ts +18 -1
  388. package/src/services/crud-helper.service.ts +79 -36
  389. package/src/services/crud.service.ts +10 -4
  390. package/src/services/field-metadata.service.ts +0 -71
  391. package/src/services/file/disk-file.service.ts +8 -18
  392. package/src/services/file/index.ts +1 -0
  393. package/src/services/file/storage-path-builder.ts +56 -0
  394. package/src/services/media.service.ts +13 -7
  395. package/src/services/mediaStorageProviders/file-s3-storage-provider.ts +1 -1
  396. package/src/services/mediaStorageProviders/file-storage-provider.ts +13 -8
  397. package/src/services/module-metadata.service.ts +18 -15
  398. package/src/services/queues/common.ts +75 -0
  399. package/src/services/queues/database-publisher.service.ts +4 -1
  400. package/src/services/queues/database-subscriber.service.ts +5 -3
  401. package/src/services/queues/rabbitmq-publisher.service.ts +17 -7
  402. package/src/services/queues/rabbitmq-subscriber.service.ts +9 -5
  403. package/src/services/setting.service.ts +5 -3
  404. package/src/services/settings/default-settings-provider.service.ts +5 -3
  405. package/src/solid-core.module.ts +20 -12
  406. package/src/testing/README.md +364 -0
  407. package/src/testing/__examples__/register-example-specs.ts +6 -0
  408. package/src/testing/__examples__/specs/custom-health.spec.ts +29 -0
  409. package/src/testing/__examples__/testing.sample.json +82 -0
  410. package/src/testing/adapters/api/api-adapter.ts +85 -0
  411. package/src/testing/adapters/api/api.types.ts +15 -0
  412. package/src/testing/adapters/ui/playwright-adapter.ts +54 -0
  413. package/src/testing/adapters/ui/ui.types.ts +4 -0
  414. package/src/testing/contracts/runtime-context.types.ts +36 -0
  415. package/src/testing/contracts/test-spec.types.ts +24 -0
  416. package/src/testing/contracts/testing-metadata.types.ts +46 -0
  417. package/src/testing/core/interpolation.ts +189 -0
  418. package/src/testing/core/normalize-steps.ts +21 -0
  419. package/src/testing/core/resource-store.ts +38 -0
  420. package/src/testing/core/spec-registry.ts +33 -0
  421. package/src/testing/core/step-registry.ts +27 -0
  422. package/src/testing/core/testing-engine.ts +127 -0
  423. package/src/testing/core/timeout.ts +19 -0
  424. package/src/testing/reporter/attachments.ts +25 -0
  425. package/src/testing/reporter/console-reporter.ts +229 -0
  426. package/src/testing/reporter/reporter.types.ts +36 -0
  427. package/src/testing/runner/lifecycle.ts +31 -0
  428. package/src/testing/runner/run-from-metadata.ts +87 -0
  429. package/src/testing/runner/scenario-filter.ts +33 -0
  430. package/src/testing/steps/api/auth.step.ts +66 -0
  431. package/src/testing/steps/api/index.ts +10 -0
  432. package/src/testing/steps/api/request.step.ts +358 -0
  433. package/src/testing/steps/assert/http.step.ts +33 -0
  434. package/src/testing/steps/assert/index.ts +12 -0
  435. package/src/testing/steps/assert/jsonpath.step.ts +50 -0
  436. package/src/testing/steps/assert/primitives.step.ts +69 -0
  437. package/src/testing/steps/test/index.ts +8 -0
  438. package/src/testing/steps/test/test-spec.step.ts +52 -0
  439. package/src/testing/steps/ui/actions.step.ts +36 -0
  440. package/src/testing/steps/ui/assertions.step.ts +54 -0
  441. package/src/testing/steps/ui/form.step.ts +39 -0
  442. package/src/testing/steps/ui/index.ts +12 -0
  443. package/src/testing/steps/ui/navigation.step.ts +53 -0
  444. package/src/testing/steps/util/index.ts +10 -0
  445. package/src/testing/steps/util/log.step.ts +19 -0
  446. package/src/testing/steps/util/require.step.ts +16 -0
  447. package/src/testing/steps/util/sleep.step.ts +15 -0
  448. package/tsconfig.json +35 -25
  449. package/tsconfig.tests.json +14 -0
  450. package/dist/passport-strategies/local.strategy.d.ts +0 -15
  451. package/dist/passport-strategies/local.strategy.d.ts.map +0 -1
  452. package/dist/passport-strategies/local.strategy.js +0 -44
  453. package/dist/passport-strategies/local.strategy.js.map +0 -1
  454. package/dist/seeders/email-template-seeder.service.d.ts +0 -10
  455. package/dist/seeders/email-template-seeder.service.d.ts.map +0 -1
  456. package/dist/seeders/email-template-seeder.service.js +0 -84
  457. package/dist/seeders/email-template-seeder.service.js.map +0 -1
  458. package/dist/seeders/sms-template-seeder.service.d.ts +0 -10
  459. package/dist/seeders/sms-template-seeder.service.d.ts.map +0 -1
  460. package/dist/seeders/sms-template-seeder.service.js.map +0 -1
  461. package/dist/seeders/user-seeder.service.d.ts +0 -10
  462. package/dist/seeders/user-seeder.service.d.ts.map +0 -1
  463. package/dist/seeders/user-seeder.service.js +0 -44
  464. package/dist/seeders/user-seeder.service.js.map +0 -1
  465. package/dist/tsconfig.tsbuildinfo +0 -1
  466. package/src/passport-strategies/local.strategy.ts +0 -28
  467. package/src/seeders/email-template-seeder.service.ts +0 -49
  468. package/src/seeders/sms-template-seeder.service.ts +0 -50
  469. package/src/seeders/user-seeder.service.ts +0 -33
@@ -13,9 +13,11 @@ import {
13
13
  FindOptionsWhere,
14
14
  QueryRunner,
15
15
  Repository,
16
- SelectQueryBuilder
16
+ SelectQueryBuilder,
17
+ UpdateResult
17
18
  } from 'typeorm';
18
19
  import { SecurityRuleRepository } from './security-rule.repository';
20
+ import { PickKeysByType } from 'typeorm/common/PickKeysByType';
19
21
 
20
22
  export class SolidBaseRepository<T extends CommonEntity> extends Repository<T> {
21
23
  protected readonly logger: Logger;
@@ -132,4 +134,173 @@ export class SolidBaseRepository<T extends CommonEntity> extends Repository<T> {
132
134
 
133
135
  return qb.getManyAndCount();
134
136
  }
137
+
138
+ /**
139
+ * Security-aware count(): applies security rules before counting.
140
+ */
141
+ override async count(options?: FindManyOptions<T>): Promise<number> {
142
+ const alias = this.modelSingularName();
143
+ const qb = await this.createSecurityRuleAwareQueryBuilder(alias);
144
+
145
+ if (options) {
146
+ qb.setFindOptions(options);
147
+ }
148
+
149
+ return qb.getCount();
150
+ }
151
+
152
+ /**
153
+ * Security-aware countBy(): convenience wrapper routed through count().
154
+ */
155
+ override async countBy(where: FindOptionsWhere<T> | FindOptionsWhere<T>[]): Promise<number> {
156
+ return this.count({ where });
157
+ }
158
+
159
+ /**
160
+ * Security-aware average(): applies security rules before computing the average.
161
+ */
162
+ override async average(columnName: PickKeysByType<T, number>, where?: FindOptionsWhere<T> | FindOptionsWhere<T>[]): Promise<number | null> {
163
+ const alias = this.modelSingularName();
164
+ const qb = await this.createSecurityRuleAwareQueryBuilder(alias);
165
+
166
+ if (where) {
167
+ qb.setFindOptions({ where });
168
+ }
169
+
170
+ const result = await qb
171
+ .select(`AVG(CAST(${alias}.${String(columnName)} AS FLOAT))`, 'avg')
172
+ .getRawOne<{ avg: string | number | null }>();
173
+
174
+ if (result?.avg === null || result?.avg === undefined) {
175
+ return null;
176
+ }
177
+
178
+ return typeof result.avg === 'number'
179
+ ? result.avg
180
+ : parseFloat(result.avg);
181
+ }
182
+
183
+ /**
184
+ * Security-aware sum(): applies security rules before computing the sum.
185
+ */
186
+ override async sum(columnName: PickKeysByType<T, number>, where?: FindOptionsWhere<T> | FindOptionsWhere<T>[]): Promise<number | null> {
187
+ const alias = this.modelSingularName();
188
+ const qb = await this.createSecurityRuleAwareQueryBuilder(alias);
189
+
190
+ if (where) {
191
+ qb.setFindOptions({ where });
192
+ }
193
+
194
+ const result = await qb
195
+ .select(`SUM(CAST(${alias}.${String(columnName)} AS FLOAT))`, 'sum')
196
+ .getRawOne<{ sum: string | number | null }>();
197
+
198
+ if (result?.sum === null || result?.sum === undefined) {
199
+ return null;
200
+ }
201
+
202
+ return typeof result.sum === 'number'
203
+ ? result.sum
204
+ : parseFloat(result.sum);
205
+ }
206
+
207
+ /**
208
+ * Security-aware minimum(): applies security rules before computing the minimum.
209
+ */
210
+ override async minimum(columnName: PickKeysByType<T, number>, where?: FindOptionsWhere<T> | FindOptionsWhere<T>[]): Promise<number | null> {
211
+ const alias = this.modelSingularName();
212
+ const qb = await this.createSecurityRuleAwareQueryBuilder(alias);
213
+
214
+ if (where) {
215
+ qb.setFindOptions({ where });
216
+ }
217
+
218
+ const result = await qb
219
+ .select(`MIN(CAST(${alias}.${String(columnName)} AS FLOAT))`, 'min')
220
+ .getRawOne<{ min: string | number | null }>();
221
+
222
+ if (result?.min === null || result?.min === undefined) {
223
+ return null;
224
+ }
225
+
226
+ return typeof result.min === 'number'
227
+ ? result.min
228
+ : parseFloat(result.min);
229
+ }
230
+
231
+ /**
232
+ * Security-aware maximum(): applies security rules before computing the maximum.
233
+ */
234
+ override async maximum(columnName: PickKeysByType<T, number>, where?: FindOptionsWhere<T> | FindOptionsWhere<T>[]): Promise<number | null> {
235
+ const alias = this.modelSingularName();
236
+ const qb = await this.createSecurityRuleAwareQueryBuilder(alias);
237
+
238
+ if (where) {
239
+ qb.setFindOptions({ where });
240
+ }
241
+
242
+ const result = await qb
243
+ .select(`MAX(CAST(${alias}.${String(columnName)} AS FLOAT))`, 'max')
244
+ .getRawOne<{ max: string | number | null }>();
245
+
246
+ if (result?.max === null || result?.max === undefined) {
247
+ return null;
248
+ }
249
+
250
+ return typeof result.max === 'number'
251
+ ? result.max
252
+ : parseFloat(result.max);
253
+ }
254
+
255
+ /**
256
+ * Security-aware increment(): increments a column by a given value for all matching rows.
257
+ * Security rules are applied to determine which rows the user is allowed to modify.
258
+ */
259
+ override async increment(where: FindOptionsWhere<T>, propertyPath: string, value: string | number,): Promise<UpdateResult> {
260
+ const alias = this.modelSingularName();
261
+ const qb = await this.createSecurityRuleAwareQueryBuilder(alias);
262
+
263
+ qb.setFindOptions({ where });
264
+
265
+ const rows = await qb.select(`${alias}.id`).getMany();
266
+ const ids = rows.map((r) => (r as any).id);
267
+
268
+ if (ids.length === 0) {
269
+ return { raw: [], affected: 0, generatedMaps: [] };
270
+ }
271
+
272
+ return this.manager
273
+ .createQueryBuilder()
274
+ .update(this.metadata.target)
275
+ .set({ [propertyPath]: () => `${propertyPath} + :value` } as any)
276
+ .whereInIds(ids)
277
+ .setParameter('value', value)
278
+ .execute();
279
+ }
280
+
281
+ /**
282
+ * Security-aware decrement(): decrements a column by a given value for all matching rows.
283
+ * Security rules are applied to determine which rows the user is allowed to modify.
284
+ */
285
+ override async decrement(where: FindOptionsWhere<T>, propertyPath: string, value: string | number,): Promise<UpdateResult> {
286
+ const alias = this.modelSingularName();
287
+ const qb = await this.createSecurityRuleAwareQueryBuilder(alias);
288
+
289
+ qb.setFindOptions({ where });
290
+
291
+ const rows = await qb.select(`${alias}.id`).getMany();
292
+ const ids = rows.map((r) => (r as any).id);
293
+
294
+ if (ids.length === 0) {
295
+ return { raw: [], affected: 0, generatedMaps: [] };
296
+ }
297
+
298
+ return this.manager
299
+ .createQueryBuilder()
300
+ .update(this.metadata.target)
301
+ .set({ [propertyPath]: () => `${propertyPath} - :value` } as any)
302
+ .whereInIds(ids)
303
+ .setParameter('value', value)
304
+ .execute();
305
+ }
135
306
  }
@@ -31,8 +31,8 @@ import { ViewMetadataService } from '../services/view-metadata.service';
31
31
  import solidCoreMetadata from './seed-data/solid-core-metadata.json';
32
32
  import { SystemFieldsSeederService } from './system-fields-seeder.service';
33
33
  // import { CreateScheduledJobDto } from 'src/dtos/create-scheduled-job.dto';
34
- import { ActionMetadata, MENU_ROLE_JOIN_TABLE_NAME, MENU_ROLE_JOIN_TABLE_NAME_MENU_COL, MENU_ROLE_JOIN_TABLE_NAME_ROLE_COL, MenuItemMetadata, ModuleMetadata, RoleMetadata, SignUpDto } from 'src';
35
- import { ADMIN_ROLE_NAME } from 'src/dtos/create-role-metadata.dto';
34
+ import { ActionMetadata, DEFAULT_SA_PASSWORD, MENU_ROLE_JOIN_TABLE_NAME, MENU_ROLE_JOIN_TABLE_NAME_MENU_COL, MENU_ROLE_JOIN_TABLE_NAME_ROLE_COL, MenuItemMetadata, ModuleMetadata, RoleMetadata, SignUpDto } from 'src';
35
+ import { ADMIN_ROLE_NAME, CreateRoleMetadataDto } from 'src/dtos/create-role-metadata.dto';
36
36
  import { CreateSavedFiltersDto } from 'src/dtos/create-saved-filters.dto';
37
37
  import { CreateScheduledJobDto } from 'src/dtos/create-scheduled-job.dto';
38
38
  import { PermissionMetadataRepository } from 'src/repository/permission-metadata.repository';
@@ -90,134 +90,152 @@ export class ModuleMetadataSeederService {
90
90
  ) { }
91
91
 
92
92
  async seed(conf?: any) {
93
- this.enablePruning = Boolean(conf?.pruneMetadata);
94
- console.log(this.enablePruning ? '▶ Pruning enabled: metadata not present in JSON will be removed.' : '▶ Pruning disabled: existing metadata will be kept.');
95
-
96
- // Global seeding steps i.e across all modules
97
- await this.seedGlobalMetadata();
98
-
99
- // Module specific seeding steps.
100
- // Get all the module metadata files which needs to be seeded.
101
- const seedDataFiles = this.seedDataFiles;
102
- this.logger.debug(`Found seed data for modules: ${seedDataFiles.map(s => s.moduleMetadata?.name)}`);
103
-
104
- /**
105
- * -------------------------------------------------------------
106
- * Selective module seeding via: solid seed --modules-to-seed onboarding,reports
107
- * -------------------------------------------------------------
108
- */
93
+ let currentModule = 'global';
94
+ let currentStep = 'bootstrap';
109
95
  let modulesToSeed: string[] | null = null;
110
96
 
111
- if (conf && Array.isArray(conf.modulesToSeed)) {
112
- modulesToSeed = conf.modulesToSeed;
113
- console.log(`▶ Selective seeding enabled. Modules to seed: ${modulesToSeed.join(', ')}`);
114
- this.logger.log(`Selective seeding enabled. Modules to seed: ${modulesToSeed.join(', ')}`);
115
- } else {
116
- console.log(`▶ No modulesToSeed provided. Seeding ALL modules.`);
117
- this.logger.log(`No modulesToSeed provided. Seeding ALL modules.`);
118
- }
97
+ try {
98
+ this.enablePruning = Boolean(conf?.pruneMetadata);
99
+ console.log(this.enablePruning ? '▶ Pruning enabled: metadata not present in JSON will be removed.' : '▶ Pruning disabled: existing metadata will be kept.');
100
+
101
+ // Global seeding steps i.e across all modules
102
+ currentStep = 'seedGlobalMetadata';
103
+ await this.seedGlobalMetadata();
104
+
105
+ // Module specific seeding steps.
106
+ // Get all the module metadata files which needs to be seeded.
107
+ const seedDataFiles = this.seedDataFiles;
108
+ this.logger.debug(`Found seed data for modules: ${seedDataFiles.map(s => s.moduleMetadata?.name)}`);
109
+
110
+ /**
111
+ * -------------------------------------------------------------
112
+ * Selective module seeding via: solid seed --modules-to-seed onboarding,reports
113
+ * -------------------------------------------------------------
114
+ */
115
+ currentStep = 'resolveModulesToSeed';
116
+ if (conf && Array.isArray(conf.modulesToSeed)) {
117
+ modulesToSeed = conf.modulesToSeed;
118
+ console.log(`▶ Selective seeding enabled. Modules to seed: ${modulesToSeed.join(', ')}`);
119
+ this.logger.log(`Selective seeding enabled. Modules to seed: ${modulesToSeed.join(', ')}`);
120
+ } else {
121
+ console.log(`▶ No modulesToSeed provided. Seeding ALL modules.`);
122
+ this.logger.log(`No modulesToSeed provided. Seeding ALL modules.`);
123
+ }
119
124
 
120
- // Filter modules if needed
121
- const filteredSeedDataFiles = modulesToSeed ? seedDataFiles.filter((file) => modulesToSeed.includes(file.moduleMetadata?.name)) : seedDataFiles;
125
+ // Filter modules if needed
126
+ const filteredSeedDataFiles = modulesToSeed ? seedDataFiles.filter((file) => modulesToSeed.includes(file.moduleMetadata?.name)) : seedDataFiles;
122
127
 
123
- if (filteredSeedDataFiles.length === 0) {
124
- this.logger.warn(`No modules matched the provided modulesToSeed list.`);
125
- return;
126
- }
128
+ if (filteredSeedDataFiles.length === 0) {
129
+ this.logger.warn(`No modules matched the provided modulesToSeed list.`);
130
+ return;
131
+ }
132
+
133
+ // let usersDetail;
134
+ // For each module metadata file, we will process the seeding steps one by one.
135
+ for (let i = 0; i < filteredSeedDataFiles.length; i++) {
136
+ const overallMetadata = filteredSeedDataFiles[i];
137
+ const moduleMetadata: CreateModuleMetadataDto = overallMetadata.moduleMetadata;
138
+ currentModule = moduleMetadata?.name ?? 'unknown';
139
+
140
+ console.log(`▶ Seeding Metadata for Module: ${moduleMetadata.name}`);
141
+ this.logger.log(`Seeding Metadata for Module: ${moduleMetadata.name}`);
142
+
143
+ // Process module metadata first.
144
+ currentStep = 'seedModuleModelFields';
145
+ this.logger.log(`Seeding Module / Model / Fields`);
146
+ const moduleModelFieldCounts = await this.seedModuleModelFields(moduleMetadata);
147
+ console.log(`${this.formatSeedResult(moduleMetadata.name, 'Module/Model/Fields', moduleModelFieldCounts)}`);
148
+
149
+ currentStep = 'seedMediaStorageProviders';
150
+ this.logger.log(`Seeding Media Storage Providers`);
151
+ const mediaStorageCounts = await this.seedMediaStorageProviders(overallMetadata.mediaStorageProviders);
152
+ console.log(`${this.formatSeedResult(moduleMetadata.name, 'Media Storage Providers', mediaStorageCounts)}`);
153
+
154
+ currentStep = 'seedRoles';
155
+ this.logger.log(`Seeding Roles`);
156
+ const roleCounts = await this.seedRoles(overallMetadata);
157
+ console.log(`${this.formatSeedResult(moduleMetadata.name, 'Roles', roleCounts)}`);
158
+
159
+ currentStep = 'seedUsers';
160
+ this.logger.log(`Seeding Users`);
161
+ const userCounts = await this.seedUsers(overallMetadata);
162
+ console.log(`${this.formatSeedResult(moduleMetadata.name, 'Users', userCounts)}`);
163
+
164
+ currentStep = 'seedViews';
165
+ this.logger.log(`Seeding Views`);
166
+ const viewCounts = await this.seedViews(overallMetadata);
167
+ console.log(`${this.formatSeedResult(moduleMetadata.name, 'Views', viewCounts)}`);
168
+
169
+ currentStep = 'seedActions';
170
+ this.logger.log(`Seeding Actions`);
171
+ const actionCounts = await this.seedActions(overallMetadata);
172
+ console.log(`${this.formatSeedResult(moduleMetadata.name, 'Actions', actionCounts)}`);
173
+
174
+ currentStep = 'seedMenus';
175
+ this.logger.log(`Seeding Menus`);
176
+ const menuCounts = await this.seedMenus(overallMetadata);
177
+ console.log(`${this.formatSeedResult(moduleMetadata.name, 'Menus', menuCounts)}`);
178
+
179
+ currentStep = 'seedEmailTemplates';
180
+ this.logger.log(`Seeding Email Templates`);
181
+ const emailTemplateCounts = await this.seedEmailTemplates(overallMetadata, moduleMetadata.name);
182
+ console.log(`${this.formatSeedResult(moduleMetadata.name, 'Email Templates', emailTemplateCounts)}`);
183
+
184
+ currentStep = 'seedSmsTemplates';
185
+ this.logger.log(`Seeding Sms Templates`);
186
+ const smsTemplateCounts = await this.seedSmsTemplates(overallMetadata, moduleMetadata.name);
187
+ console.log(`${this.formatSeedResult(moduleMetadata.name, 'Sms Templates', smsTemplateCounts)}`);
188
+
189
+ currentStep = 'seedSecurityRules';
190
+ this.logger.log(`Seeding Security Rules`);
191
+ const securityRuleCounts = await this.seedSecurityRules(overallMetadata);
192
+ console.log(`${this.formatSeedResult(moduleMetadata.name, 'Security Rules', securityRuleCounts)}`);
193
+
194
+ currentStep = 'seedListOfValues';
195
+ this.logger.log(`Seeding List Of Values`);
196
+ const lovCounts = await this.seedListOfValues(moduleMetadata, overallMetadata);
197
+ console.log(`${this.formatSeedResult(moduleMetadata.name, 'List Of Values', lovCounts)}`);
198
+
199
+ currentStep = 'seedDashboards';
200
+ this.logger.log(`Seeding Dashboards`);
201
+ const dashboardCounts = await this.seedDashboards(moduleMetadata, overallMetadata);
202
+ console.log(`${this.formatSeedResult(moduleMetadata.name, 'Dashboards', dashboardCounts)}`);
203
+
204
+ currentStep = 'seedScheduledJobs';
205
+ this.logger.log(`Seeding Scheduled Jobs`);
206
+ const scheduledJobCounts = await this.seedScheduledJobs(moduleMetadata, overallMetadata);
207
+ console.log(`${this.formatSeedResult(moduleMetadata.name, 'Scheduled Jobs', scheduledJobCounts)}`);
208
+
209
+ currentStep = 'seedSavedFilters';
210
+ this.logger.log(`Seeding Saved Filters`);
211
+ const savedFilterCounts = await this.seedSavedFilters(moduleMetadata, overallMetadata);
212
+ console.log(`${this.formatSeedResult(moduleMetadata.name, 'Saved Filters', savedFilterCounts)}`);
213
+
214
+ currentStep = 'seedModelSequences';
215
+ this.logger.log(`Seeding Model Sequences`);
216
+ const modelSequenceCounts = await this.seedModelSequences(overallMetadata);
217
+ console.log(`${this.formatSeedResult(moduleMetadata.name, 'Model Sequences', modelSequenceCounts)}`);
218
+ }
127
219
 
128
- // let usersDetail;
129
- // For each module metadata file, we will process the seeding steps one by one.
130
- for (let i = 0; i < filteredSeedDataFiles.length; i++) {
131
- const overallMetadata = filteredSeedDataFiles[i];
132
- const moduleMetadata: CreateModuleMetadataDto = overallMetadata.moduleMetadata;
133
- console.log(`▶ Seeding Metadata for Module: ${moduleMetadata.name}`);
134
- this.logger.log(`Seeding Metadata for Module: ${moduleMetadata.name}`);
135
-
136
- // Process module metadata first.
137
- this.logger.log(`Seeding Module / Model / Fields`);
138
- const moduleModelFieldCounts = await this.seedModuleModelFields(moduleMetadata);
139
- console.log(`${this.formatSeedResult(moduleMetadata.name, 'Module/Model/Fields', moduleModelFieldCounts)}`);
140
-
141
- // Media Storage provider templates
142
- this.logger.log(`Seeding Media Storage Providers`);
143
- const mediaStorageCounts = await this.seedMediaStorageProviders(overallMetadata.mediaStorageProviders);
144
- console.log(`${this.formatSeedResult(moduleMetadata.name, 'Media Storage Providers', mediaStorageCounts)}`);
145
-
146
- // Custom role handling
147
- this.logger.log(`Seeding Roles`);
148
- const roleCounts = await this.seedRoles(overallMetadata);
149
- console.log(`${this.formatSeedResult(moduleMetadata.name, 'Roles', roleCounts)}`);
150
-
151
- // Custom user handling
152
- this.logger.log(`Seeding Users`);
153
- const userCounts = await this.seedUsers(overallMetadata);
154
- console.log(`${this.formatSeedResult(moduleMetadata.name, 'Users', userCounts)}`);
155
-
156
- // Application Module View handling
157
- this.logger.log(`Seeding Views`);
158
- const viewCounts = await this.seedViews(overallMetadata);
159
- console.log(`${this.formatSeedResult(moduleMetadata.name, 'Views', viewCounts)}`);
160
-
161
- // Application Module Action handling
162
- this.logger.log(`Seeding Actions`);
163
- const actionCounts = await this.seedActions(overallMetadata);
164
- console.log(`${this.formatSeedResult(moduleMetadata.name, 'Actions', actionCounts)}`);
165
-
166
- // Application Module Menu handling
167
- this.logger.log(`Seeding Menus`);
168
- const menuCounts = await this.seedMenus(overallMetadata);
169
- console.log(`${this.formatSeedResult(moduleMetadata.name, 'Menus', menuCounts)}`);
170
-
171
- // Email templates
172
- this.logger.log(`Seeding Email Templates`);
173
- const emailTemplateCounts = await this.seedEmailTemplates(overallMetadata, moduleMetadata.name);
174
- console.log(`${this.formatSeedResult(moduleMetadata.name, 'Email Templates', emailTemplateCounts)}`);
175
-
176
- // Sms templates
177
- this.logger.log(`Seeding Sms Templates`);
178
- const smsTemplateCounts = await this.seedSmsTemplates(overallMetadata, moduleMetadata.name);
179
- console.log(`${this.formatSeedResult(moduleMetadata.name, 'Sms Templates', smsTemplateCounts)}`);
180
-
181
- // Security rules
182
- this.logger.log(`Seeding Security Rules`);
183
- const securityRuleCounts = await this.seedSecurityRules(overallMetadata);
184
- console.log(`${this.formatSeedResult(moduleMetadata.name, 'Security Rules', securityRuleCounts)}`);
185
-
186
- // List Of Values
187
- this.logger.log(`Seeding List Of Values`);
188
- const lovCounts = await this.seedListOfValues(moduleMetadata, overallMetadata);
189
- console.log(`${this.formatSeedResult(moduleMetadata.name, 'List Of Values', lovCounts)}`);
190
-
191
- // Dashboards
192
- this.logger.log(`Seeding Dashboards`);
193
- const dashboardCounts = await this.seedDashboards(moduleMetadata, overallMetadata);
194
- console.log(`${this.formatSeedResult(moduleMetadata.name, 'Dashboards', dashboardCounts)}`);
195
-
196
- // Scheduled Jobs
197
- this.logger.log(`Seeding Scheduled Jobs`);
198
- const scheduledJobCounts = await this.seedScheduledJobs(moduleMetadata, overallMetadata);
199
- console.log(`${this.formatSeedResult(moduleMetadata.name, 'Scheduled Jobs', scheduledJobCounts)}`);
200
-
201
- // Saved Filters
202
- this.logger.log(`Seeding Saved Filters`);
203
- const savedFilterCounts = await this.seedSavedFilters(moduleMetadata, overallMetadata);
204
- console.log(`${this.formatSeedResult(moduleMetadata.name, 'Saved Filters', savedFilterCounts)}`);
205
-
206
- // Model Sequences
207
- this.logger.log(`Seeding Model Sequences`);
208
- const modelSequenceCounts = await this.seedModelSequences(overallMetadata);
209
- console.log(`${this.formatSeedResult(moduleMetadata.name, 'Model Sequences', modelSequenceCounts)}`);
210
- }
211
-
212
- // Setup default roles with permissions.
213
- await this.setupDefaultRolesWithPermissions();
214
-
215
- // Add a console log indicating seeding is finished. This needs to be console.log so that it looks proper when this code is run via CLI.
216
- console.log(`✔ Seeding completed.`);
217
- //this.logger.log(`All Seeders finished`);
218
-
219
- //FIXME: Handle displaying the created users credentials in a better way.
220
- // this.logger.log(`Newly created username is: ${usersDetail?.length > 0 ? usersDetail[0]?.username : ''} and password is ${usersDetail?.length > 0 ? usersDetail[0]?.password : ''}`);
220
+ currentModule = 'global';
221
+ currentStep = 'setupDefaultRolesWithPermissions';
222
+ await this.setupDefaultRolesWithPermissions();
223
+
224
+ // Add a console log indicating seeding is finished. This needs to be console.log so that it looks proper when this code is run via CLI.
225
+ console.log(`✔ Seeding completed.`);
226
+ //this.logger.log(`All Seeders finished`);
227
+
228
+ //FIXME: Handle displaying the created users credentials in a better way.
229
+ // this.logger.log(`Newly created username is: ${usersDetail?.length > 0 ? usersDetail[0]?.username : ''} and password is ${usersDetail?.length > 0 ? usersDetail[0]?.password : ''}`);
230
+ } catch (error) {
231
+ this.logSeedFailureForCli(error, {
232
+ moduleName: currentModule,
233
+ step: currentStep,
234
+ pruneEnabled: this.enablePruning,
235
+ modulesToSeed,
236
+ });
237
+ throw error;
238
+ }
221
239
  }
222
240
 
223
241
  private async seedScheduledJobs(moduleMetadata: CreateModuleMetadataDto, overallMetadata: any): Promise<{ pruned: number; upserted: number }> {
@@ -403,7 +421,6 @@ export class ModuleMetadataSeederService {
403
421
  await this.systemFieldsSeederService.seed();
404
422
  }
405
423
 
406
-
407
424
  // OK
408
425
  private async seedPermissions() {
409
426
 
@@ -768,7 +785,7 @@ export class ModuleMetadataSeederService {
768
785
  }
769
786
 
770
787
  // OK
771
- private async handleSeedUsers(users) {
788
+ private async handleSeedUsers(users: SignUpDto[]) {
772
789
  if (!users) {
773
790
  return;
774
791
  }
@@ -777,33 +794,12 @@ export class ModuleMetadataSeederService {
777
794
  const user: SignUpDto = users[l];
778
795
  let exisitingUser = await this.userService.findOneByUsername(user.username);
779
796
  if (!exisitingUser) {
780
- let generatedAdminPassword: string | null = null;
781
797
  if (user.username === 'sa') {
782
- generatedAdminPassword = uuidv4();
783
- user.password = generatedAdminPassword;
798
+ user.password = DEFAULT_SA_PASSWORD;
784
799
  }
785
800
 
786
801
  exisitingUser = await this.authenticationService.signUp(user);
787
802
  this.logger.log(`Newly created user ${user.username}`);
788
-
789
- // Surface the generated SA password clearly to the operator.
790
- if (generatedAdminPassword) {
791
- const banner = [
792
- '',
793
- '============================================================',
794
- ' SYSTEM ADMIN USER CREATED',
795
- '------------------------------------------------------------',
796
- ' Username : sa',
797
- ` Password : ${generatedAdminPassword}`,
798
- '',
799
- ' Copy and store this password securely now.',
800
- ' It is shown only once during seeding.',
801
- '============================================================',
802
- ''
803
- ].join('\n');
804
- // Use console.log to ensure visibility even if logger formatting changes.
805
- console.log(banner);
806
- }
807
803
  }
808
804
  //FIXME: Create the user roles assignment logic here.
809
805
  // now add Roles to user.
@@ -879,7 +875,6 @@ export class ModuleMetadataSeederService {
879
875
  return { pruned, upserted };
880
876
  }
881
877
 
882
-
883
878
  private async handleSeedSecurityRules(rulesDto: CreateSecurityRuleDto[]) {
884
879
  if (!rulesDto || rulesDto.length === 0) {
885
880
  this.logger.debug(`No security rules found to seed`);
@@ -929,10 +924,30 @@ export class ModuleMetadataSeederService {
929
924
  return;
930
925
  }
931
926
  for (const dto of createSavedFilterDto) {
927
+ this.validateSavedFilterQueryJsonWrapper(dto);
932
928
  await this.savedFiltersRepo.upsertWithDto({ ...dto, filterQueryJson: JSON.stringify(dto.filterQueryJson) });
933
929
  }
934
930
  }
935
931
 
932
+ private validateSavedFilterQueryJsonWrapper(dto: CreateSavedFiltersDto): void {
933
+ const filterName = dto?.name ?? '<unnamed>';
934
+ const filterQueryJson = dto?.filterQueryJson;
935
+ const baseErrorMessage =
936
+ `Invalid saved filter "${filterName}": filterQueryJson must be wrapped with a top-level "$or" or "$and". ` +
937
+ `Example: {"$or":[{"employeeStatus":{"$eq":"Active"}}]}`;
938
+
939
+ if (!filterQueryJson || typeof filterQueryJson !== 'object' || Array.isArray(filterQueryJson)) {
940
+ throw new Error(baseErrorMessage);
941
+ }
942
+
943
+ const topLevelKeys = Object.keys(filterQueryJson);
944
+ const hasLogicalWrapper = topLevelKeys.includes('$or') || topLevelKeys.includes('$and');
945
+ if (!hasLogicalWrapper) {
946
+ const receivedKeys = topLevelKeys.length > 0 ? topLevelKeys.join(', ') : '(none)';
947
+ throw new Error(`${baseErrorMessage}. Received top-level keys: ${receivedKeys}`);
948
+ }
949
+ }
950
+
936
951
  private async handleSeedModelSequences(modelSequencesDto: CreateModelSequenceDto[]) {
937
952
  if (!modelSequencesDto || modelSequencesDto.length === 0) {
938
953
  this.logger.debug(`No Model Sequences found to seed`);
@@ -1515,6 +1530,32 @@ export class ModuleMetadataSeederService {
1515
1530
  // return answer.trim().toLowerCase().startsWith('y');
1516
1531
  // }
1517
1532
 
1533
+ private logSeedFailureForCli(
1534
+ error: unknown,
1535
+ context: { moduleName: string; step: string; pruneEnabled: boolean; modulesToSeed: string[] | null }
1536
+ ): void {
1537
+ const err = error instanceof Error ? error : new Error(String(error));
1538
+ const stackLines = (err.stack ?? '')
1539
+ .split('\n')
1540
+ .slice(0, 8)
1541
+ .map((line) => line.trim())
1542
+ .filter(Boolean);
1543
+ const logPayload = {
1544
+ module: context.moduleName,
1545
+ step: context.step,
1546
+ pruneEnabled: context.pruneEnabled,
1547
+ modulesToSeed: context.modulesToSeed?.length ? context.modulesToSeed : 'ALL',
1548
+ error: {
1549
+ name: err.name,
1550
+ message: err.message,
1551
+ stackPreview: stackLines.length > 0 ? stackLines : undefined,
1552
+ },
1553
+ };
1554
+
1555
+ console.log('✖ Seeding failed');
1556
+ console.log(JSON.stringify(logPayload, null, 2));
1557
+ }
1558
+
1518
1559
  private formatSeedResult(moduleName: string, label: string, counts: { pruned: number; upserted: number }): string {
1519
1560
  if (this.enablePruning) {
1520
1561
  return `✔ [${moduleName}] ${label} seeded (pruned ${counts.pruned}, upserted ${counts.upserted})`;
@@ -185,8 +185,10 @@ export class ModuleTestDataService {
185
185
  throw new Error('Module metadata missing from test data payload.');
186
186
  }
187
187
 
188
- const testData: Array<{ modelUserKey: string; data: Record<string, any> }> = overallMetadata.testData ?? [];
189
- if (testData.length === 0) {
188
+ // console.log(JSON.stringify(moduleMetadata, null, 2));
189
+
190
+ const testingData: Array<{ modelUserKey: string; data: Record<string, any> }> = overallMetadata?.testing?.data ?? [];
191
+ if (testingData.length === 0) {
190
192
  this.logger.debug(`No test data found for ${moduleMetadata.name}`);
191
193
  return;
192
194
  }
@@ -195,7 +197,7 @@ export class ModuleTestDataService {
195
197
  (moduleMetadata.models ?? []).map((m) => [m.singularName, m]),
196
198
  );
197
199
 
198
- for (const entry of testData) {
200
+ for (const entry of testingData) {
199
201
  const modelUserKey = entry.modelUserKey;
200
202
  const modelDef = modelsByName.get(modelUserKey);
201
203
  if (!modelDef) {
@@ -1,10 +1,7 @@
1
1
  import { forwardRef, Inject, Injectable, Logger } from '@nestjs/common';
2
- import { InjectRepository } from '@nestjs/typeorm';
3
- import { Repository } from 'typeorm';
4
2
  import { SolidRegistry } from 'src/helpers/solid-registry';
5
- import { PermissionMetadata } from '../entities/permission-metadata.entity';
6
- import { RoleMetadataService } from '../services/role-metadata.service';
7
3
  import { PermissionMetadataRepository } from 'src/repository/permission-metadata.repository';
4
+ import { RoleMetadataService } from '../services/role-metadata.service';
8
5
 
9
6
  @Injectable()
10
7
  export class PermissionMetadataSeederService {