@solidxai/core 0.1.10-beta.3 → 0.1.10-beta.4

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 (156) hide show
  1. package/dist/controllers/action-metadata.controller.js +1 -1
  2. package/dist/controllers/action-metadata.controller.js.map +1 -1
  3. package/dist/controllers/facebook-authentication.controller.js +1 -1
  4. package/dist/controllers/facebook-authentication.controller.js.map +1 -1
  5. package/dist/controllers/google-authentication.controller.js +1 -1
  6. package/dist/controllers/google-authentication.controller.js.map +1 -1
  7. package/dist/controllers/menu-item-metadata.controller.js +1 -1
  8. package/dist/controllers/menu-item-metadata.controller.js.map +1 -1
  9. package/dist/controllers/microsoft-authentication.controller.js +1 -1
  10. package/dist/controllers/microsoft-authentication.controller.js.map +1 -1
  11. package/dist/controllers/mq-message-queue.controller.js +1 -1
  12. package/dist/controllers/mq-message-queue.controller.js.map +1 -1
  13. package/dist/controllers/mq-message.controller.js +1 -1
  14. package/dist/controllers/mq-message.controller.js.map +1 -1
  15. package/dist/controllers/view-metadata.controller.js +1 -1
  16. package/dist/controllers/view-metadata.controller.js.map +1 -1
  17. package/dist/entities/chatter-message-details.entity.d.ts.map +1 -1
  18. package/dist/entities/chatter-message-details.entity.js +0 -1
  19. package/dist/entities/chatter-message-details.entity.js.map +1 -1
  20. package/dist/helpers/field-crud-managers/BigIntFieldCrudManager.js.map +1 -1
  21. package/dist/helpers/field-crud-managers/SelectionDynamicFieldCrudManager.js.map +1 -1
  22. package/dist/helpers/module-metadata-helper.service.js.map +1 -1
  23. package/dist/jobs/database/chatter-queue-subscriber-database.service.d.ts.map +1 -1
  24. package/dist/jobs/database/chatter-queue-subscriber-database.service.js +3 -3
  25. package/dist/jobs/database/chatter-queue-subscriber-database.service.js.map +1 -1
  26. package/dist/jobs/database/trigger-mcp-client-subscriber-database.service.js.map +1 -1
  27. package/dist/jobs/rabbitmq/chatter-queue-subscriber.service.d.ts.map +1 -1
  28. package/dist/jobs/rabbitmq/chatter-queue-subscriber.service.js +3 -3
  29. package/dist/jobs/rabbitmq/chatter-queue-subscriber.service.js.map +1 -1
  30. package/dist/jobs/redis/chatter-queue-subscriber-redis.service.d.ts.map +1 -1
  31. package/dist/jobs/redis/chatter-queue-subscriber-redis.service.js +3 -3
  32. package/dist/jobs/redis/chatter-queue-subscriber-redis.service.js.map +1 -1
  33. package/dist/repository/security-rule.repository.js.map +1 -1
  34. package/dist/seeders/module-metadata-seeder.service.js.map +1 -1
  35. package/dist/seeders/permission-metadata-seeder.service.js.map +1 -1
  36. package/dist/seeders/seed-data/solid-core-metadata.json +13 -2
  37. package/dist/services/authentication.service.d.ts.map +1 -1
  38. package/dist/services/authentication.service.js +5 -5
  39. package/dist/services/authentication.service.js.map +1 -1
  40. package/dist/services/chatter-message.service.d.ts +6 -3
  41. package/dist/services/chatter-message.service.d.ts.map +1 -1
  42. package/dist/services/chatter-message.service.js +23 -35
  43. package/dist/services/chatter-message.service.js.map +1 -1
  44. package/dist/services/crud.service.js.map +1 -1
  45. package/dist/services/csv.service.js.map +1 -1
  46. package/dist/services/dashboard.service.js.map +1 -1
  47. package/dist/services/database/database-bootstrap.service.js.map +1 -1
  48. package/dist/services/excel.service.js.map +1 -1
  49. package/dist/services/export-transaction.service.js.map +1 -1
  50. package/dist/services/field-metadata.service.js.map +1 -1
  51. package/dist/services/fixtures.service.js.map +1 -1
  52. package/dist/services/import-transaction.service.js.map +1 -1
  53. package/dist/services/list-of-values.service.js.map +1 -1
  54. package/dist/services/model-metadata.service.d.ts.map +1 -1
  55. package/dist/services/model-metadata.service.js +3 -13
  56. package/dist/services/model-metadata.service.js.map +1 -1
  57. package/dist/services/module-metadata.service.js.map +1 -1
  58. package/dist/services/queues/database-publisher.service.js +3 -3
  59. package/dist/services/queues/database-publisher.service.js.map +1 -1
  60. package/dist/services/queues/database-subscriber.service.js.map +1 -1
  61. package/dist/services/queues/rabbitmq-publisher.service.js +3 -3
  62. package/dist/services/queues/rabbitmq-publisher.service.js.map +1 -1
  63. package/dist/services/queues/rabbitmq-subscriber.service.js.map +1 -1
  64. package/dist/services/queues/redis-publisher.service.d.ts.map +1 -1
  65. package/dist/services/queues/redis-publisher.service.js +4 -1
  66. package/dist/services/queues/redis-publisher.service.js.map +1 -1
  67. package/dist/services/queues/redis-subscriber.service.js.map +1 -1
  68. package/dist/services/role-metadata.service.js.map +1 -1
  69. package/dist/services/scheduled-jobs/scheduler.service.js.map +1 -1
  70. package/dist/services/settings/default-settings-provider.service.d.ts +58 -8
  71. package/dist/services/settings/default-settings-provider.service.d.ts.map +1 -1
  72. package/dist/services/settings/default-settings-provider.service.js +21 -4
  73. package/dist/services/settings/default-settings-provider.service.js.map +1 -1
  74. package/dist/services/sms/TwilioSMSService.js.map +1 -1
  75. package/dist/services/solid-introspect.service.js.map +1 -1
  76. package/dist/services/user-activity-history.service.js.map +1 -1
  77. package/dist/services/view-metadata.service.d.ts.map +1 -1
  78. package/dist/services/view-metadata.service.js +17 -2
  79. package/dist/services/view-metadata.service.js.map +1 -1
  80. package/dist/subscribers/computed-entity-field.subscriber.js.map +1 -1
  81. package/dist/subscribers/security-rule.subscriber.d.ts.map +1 -1
  82. package/dist/subscribers/security-rule.subscriber.js.map +1 -1
  83. package/dist/subscribers/view-metadata.subscriber.js.map +1 -1
  84. package/dist/testing/core/testing-engine.js.map +1 -1
  85. package/dist/testing/reporter/webhook-reporter.js.map +1 -1
  86. package/dist-tests/api/authenticate.spec.js +119 -0
  87. package/dist-tests/api/authenticate.spec.js.map +1 -0
  88. package/dist-tests/api/crud-service.findOne.cityMaster.spec.js +97 -0
  89. package/dist-tests/api/crud-service.findOne.cityMaster.spec.js.map +1 -0
  90. package/dist-tests/api/ping.spec.js +21 -0
  91. package/dist-tests/api/ping.spec.js.map +1 -0
  92. package/dist-tests/helpers/auth.js +41 -0
  93. package/dist-tests/helpers/auth.js.map +1 -0
  94. package/dist-tests/helpers/env.js +11 -0
  95. package/dist-tests/helpers/env.js.map +1 -0
  96. package/docs/grouping-enhancements.md +89 -0
  97. package/docs/java-spring/README.md +3 -0
  98. package/docs/java-spring/solid-core-module-deep-dive-report.md +1317 -0
  99. package/docs/seed-changes.md +65 -0
  100. package/docs/test-data-workflow.md +200 -0
  101. package/docs/type-declaration-import-issue.md +24 -0
  102. package/package.json +1 -1
  103. package/src/controllers/action-metadata.controller.ts +1 -1
  104. package/src/controllers/facebook-authentication.controller.ts +1 -1
  105. package/src/controllers/google-authentication.controller.ts +1 -1
  106. package/src/controllers/menu-item-metadata.controller.ts +1 -1
  107. package/src/controllers/microsoft-authentication.controller.ts +1 -1
  108. package/src/controllers/mq-message-queue.controller.ts +1 -1
  109. package/src/controllers/mq-message.controller.ts +1 -1
  110. package/src/controllers/view-metadata.controller.ts +1 -1
  111. package/src/entities/chatter-message-details.entity.ts +1 -2
  112. package/src/helpers/field-crud-managers/BigIntFieldCrudManager.ts +1 -1
  113. package/src/helpers/field-crud-managers/SelectionDynamicFieldCrudManager.ts +1 -1
  114. package/src/helpers/module-metadata-helper.service.ts +1 -1
  115. package/src/jobs/database/chatter-queue-subscriber-database.service.ts +4 -2
  116. package/src/jobs/database/trigger-mcp-client-subscriber-database.service.ts +1 -1
  117. package/src/jobs/rabbitmq/chatter-queue-subscriber.service.ts +4 -2
  118. package/src/jobs/redis/chatter-queue-subscriber-redis.service.ts +10 -3
  119. package/src/repository/security-rule.repository.ts +1 -1
  120. package/src/seeders/module-metadata-seeder.service.ts +4 -4
  121. package/src/seeders/permission-metadata-seeder.service.ts +1 -1
  122. package/src/seeders/seed-data/solid-core-metadata.json +13 -2
  123. package/src/services/authentication.service.ts +19 -31
  124. package/src/services/chatter-message.service.ts +28 -38
  125. package/src/services/crud.service.ts +1 -1
  126. package/src/services/csv.service.ts +1 -1
  127. package/src/services/dashboard.service.ts +1 -1
  128. package/src/services/database/database-bootstrap.service.ts +1 -1
  129. package/src/services/excel.service.ts +1 -1
  130. package/src/services/export-transaction.service.ts +2 -2
  131. package/src/services/field-metadata.service.ts +1 -1
  132. package/src/services/fixtures.service.ts +2 -2
  133. package/src/services/import-transaction.service.ts +2 -2
  134. package/src/services/list-of-values.service.ts +1 -1
  135. package/src/services/model-metadata.service.ts +22 -21
  136. package/src/services/module-metadata.service.ts +7 -7
  137. package/src/services/queues/database-publisher.service.ts +4 -4
  138. package/src/services/queues/database-subscriber.service.ts +1 -1
  139. package/src/services/queues/rabbitmq-publisher.service.ts +7 -7
  140. package/src/services/queues/rabbitmq-subscriber.service.ts +8 -8
  141. package/src/services/queues/redis-publisher.service.ts +7 -4
  142. package/src/services/queues/redis-subscriber.service.ts +4 -4
  143. package/src/services/role-metadata.service.ts +1 -1
  144. package/src/services/scheduled-jobs/scheduler.service.ts +5 -5
  145. package/src/services/settings/default-settings-provider.service.ts +21 -4
  146. package/src/services/sms/TwilioSMSService.ts +2 -2
  147. package/src/services/solid-introspect.service.ts +2 -2
  148. package/src/services/user-activity-history.service.ts +1 -1
  149. package/src/services/view-metadata.service.ts +25 -8
  150. package/src/subscribers/computed-entity-field.subscriber.ts +1 -1
  151. package/src/subscribers/security-rule.subscriber.ts +8 -8
  152. package/src/subscribers/view-metadata.subscriber.ts +1 -1
  153. package/src/testing/core/testing-engine.ts +2 -2
  154. package/src/testing/reporter/webhook-reporter.ts +1 -1
  155. package/.claude/settings.local.json +0 -15
  156. package/src/services/1.js +0 -6
@@ -0,0 +1,65 @@
1
+ # Seeding Enhancements Summary
2
+
3
+ ## Overview
4
+ This document summarizes the changes made to seeding behavior in `solid-core`:
5
+ - Metadata pruning support across targets.
6
+ - CLI flags for selective modules and pruning.
7
+
8
+ ## Pruning Support
9
+ Pruning is now available for most metadata targets. When enabled, records present in the DB but missing from JSON are removed. This is done in two phases:
10
+ 1. Identify records in DB not present in JSON.
11
+ 2. Delete those records before normal upsert seeding.
12
+
13
+ ### Targets with Pruning
14
+ - Module models + fields (with model-level pruning).
15
+ - Views, actions, menus (with join cleanup).
16
+ - Security rules, list of values, dashboards.
17
+ - Scheduled jobs, saved filters, model sequences.
18
+ - Permissions (also clears role-permission join table).
19
+
20
+ ### Targets WITHOUT Pruning (conservative)
21
+ - Module metadata itself
22
+ - Media storage providers
23
+ - Roles
24
+ - Users
25
+ - Email templates
26
+ - SMS templates
27
+ - System fields (global)
28
+ - Default settings (global)
29
+
30
+ ### Pruning Mode
31
+ Pruning runs **only** when `--prune` is provided. If omitted, pruning is skipped.
32
+
33
+ ## CLI Changes
34
+ ### Modules to Seed
35
+ `--conf` was removed. Use:
36
+ ```
37
+ --modules-to-seed venue,reports
38
+ ```
39
+ This passes `modulesToSeed` to the seeder as an array.
40
+
41
+ ## Sample Commands
42
+ ### Default seeding
43
+ ```
44
+ npx @solidxai/solidctl seed
45
+ ```
46
+
47
+ ### Select modules only
48
+ ```
49
+ npx @solidxai/solidctl seed --modules-to-seed venue,reports
50
+ ```
51
+
52
+ ### Pruning enabled
53
+ ```
54
+ npx @solidxai/solidctl seed --modules-to-seed venue --prune
55
+ ```
56
+
57
+ ### Pruning enabled (all modules)
58
+ ```
59
+ npx @solidxai/solidctl seed --prune
60
+ ```
61
+
62
+ ## Files Touched (Key)
63
+ - `src/seeders/module-metadata-seeder.service.ts`
64
+ - `src/commands/seed.command.ts`
65
+ - `src/repository/solid-base.repository.ts` (added `findOneByUserKey`)
@@ -0,0 +1,200 @@
1
+ # Test Data Workflow
2
+
3
+ This document describes the end-to-end workflow for creating isolated test databases, seeding metadata, loading test data, and tearing everything down.
4
+
5
+ ## Overview
6
+ The workflow is designed to:
7
+ - Create one **test database per configured datasource** in the project.
8
+ - Point the app to those new databases via `.env` updates.
9
+ - Seed all metadata into the fresh databases.
10
+ - Load model-specific `testData` entries from module metadata JSON files.
11
+ - Cleanly reverse everything at the end.
12
+
13
+ The commands below are the canonical flow.
14
+
15
+ ---
16
+
17
+ ## Step 1: Create test datasources
18
+
19
+ Command:
20
+ ```
21
+ npx @solidxai/solidctl test data --setup
22
+ ```
23
+
24
+ What this does:
25
+ - Reads all configured datasources from the Solid registry (`SolidRegistry.getSolidDatabaseModules()`), and uses their `name()` values.
26
+ - Generates a unique **run name** (two words, underscore-separated, e.g. `steady_wolf`).
27
+ - Builds a **timestamped database name** per datasource:
28
+ - `<datasource>_<timestamp>_<runName>`
29
+ - Backs up the current `.env` into `.env.backup.<runName>`.
30
+ - Rewrites `.env` in-place with new `*_DATABASE_NAME` values.
31
+ - Creates the databases/schemas using TypeORM and the configured connection info.
32
+ - Writes a `.solidx-test-manifest` with the run name + database names so the teardown can reverse everything later.
33
+
34
+ Example output:
35
+ ```
36
+ ▶ Running solid test data
37
+ Creating test datasource environment file and manifest.
38
+ Backed up .env to .env.backup.steady_wolf and applied new test datasource names to .env.
39
+ Creating test database/schema "default_20260201234402_steady_wolf" on datasource "default"...
40
+
41
+ ============================================================
42
+ TEST DATASOURCE ENVIRONMENT CREATED
43
+ ------------------------------------------------------------
44
+ Run name : steady_wolf
45
+ Env backup : .env.backup.steady_wolf
46
+
47
+ Test databases/schemas created:
48
+ - default: default_20260201234402_steady_wolf
49
+
50
+ Next steps:
51
+ 1) Using updated .env with test datasource names
52
+ 2) Run solid seed as usual
53
+ 3) Proceed with loading the test data for each module
54
+ 4) Run the test cases
55
+ 5) Tear down
56
+ ============================================================
57
+
58
+ ✔ solid test data completed
59
+ ```
60
+
61
+ Rationale:
62
+ - The `.env` rewrite guarantees the app connects to fresh databases without changing code.
63
+ - The manifest records the run so deletion is safe and deterministic.
64
+
65
+ ---
66
+
67
+ ## Step 2: Seed metadata into the new databases
68
+
69
+ Command:
70
+ ```
71
+ npx @solidxai/solidctl seed
72
+ ```
73
+
74
+ What this does:
75
+ - Seeds full module metadata into the **fresh test databases**.
76
+ - Generates the `sa` user if needed and prints its password.
77
+ - Ensures all models, fields, roles, permissions, views, actions, etc. exist before loading test data.
78
+
79
+ Example output (truncated):
80
+ ```
81
+ ▶ Running solid seed
82
+ ▶ Pruning disabled: existing metadata will be kept.
83
+ ▶ No modulesToSeed provided. Seeding ALL modules.
84
+ ▶ Seeding Metadata for Module: solid-core
85
+ ✔ [solid-core] Module/Model/Fields seeded (upserted 376)
86
+ ...
87
+ ✔ Seeding completed.
88
+ ✔ solid seed completed
89
+ ```
90
+
91
+ Rationale:
92
+ - Test data relies on model metadata and relationships; this ensures the schema and reference data are ready.
93
+
94
+ ---
95
+
96
+ ## Step 3: Load test data
97
+
98
+ Command:
99
+ ```
100
+ npx @solidxai/solidctl test data --load
101
+ ```
102
+
103
+ What this does:
104
+ - Reads all module metadata files (or a subset if `--modules-to-test` is provided).
105
+ - Looks for `testData` arrays in each metadata file.
106
+ - Resolves the correct repository for each model (repository name pattern: `<ModelName>Repository`).
107
+ - Performs **upsert-style** inserts using the model’s `userKeyFieldUserKey`.
108
+ - Resolves many-to-one relations using `${fieldName}UserKey`.
109
+
110
+ Example output:
111
+ ```
112
+ ▶ Running solid test data
113
+ Test data setup for all modules.
114
+ Processing test data for module: solid-core
115
+ ✔ Test data setup complete for module: solid-core
116
+ Processing test data for module: venue
117
+ ✔ Test data setup complete for module: venue
118
+ ✔ solid test data completed
119
+ ```
120
+
121
+ Rationale:
122
+ - This keeps test fixtures human-readable and tied to module metadata.
123
+
124
+ ---
125
+
126
+
127
+ ## Step 4: Run Tests
128
+ ```
129
+ npx @solidxai/solidctl test run --module venue --api-base-url http://localhost:3000 --ui-base-url http://localhost:5173 --headless false
130
+ ```
131
+
132
+ ```
133
+ npx @solidxai/solidctl test run --module venue --list-specs
134
+ ```
135
+
136
+ What this does:
137
+ - Loads `testing.scenarios` from the module metadata file.
138
+ - Applies `--scenario-ids` or `--include-tags` filtering if provided.
139
+ - Boots API and UI adapters with the supplied base URLs.
140
+ - Registers any custom test specs listed in `testing.specs`.
141
+ - Executes scenarios in order with fail‑fast behavior.
142
+
143
+ Useful variants:
144
+ ```
145
+ npx @solidxai/solidctl test run --module venue --scenario-ids api-authenticate-success,api-create-states
146
+ ```
147
+
148
+ ```
149
+ npx @solidxai/solidctl test run --module venue --include-tags smoke
150
+ ```
151
+
152
+ ```
153
+ npx @solidxai/solidctl test run --module venue --api-base-url http://localhost:3000 --headless true
154
+ ```
155
+
156
+ ```
157
+ npx @solidxai/solidctl test run --module venue --headless false
158
+ ```
159
+
160
+ Notes:
161
+ - If your scenario depends on a previous scenario’s `saveAs` output (e.g., `loginSuccess`), ensure the auth scenario runs first.
162
+ - For UI tests, `--ui-base-url` should point to a running frontend server.
163
+ - `--list-specs` prints registered custom `test.spec` ids and exits.
164
+
165
+
166
+ ## Step 5: Tear everything down
167
+
168
+ Command:
169
+ ```
170
+ npx @solidxai/solidctl test data --teardown
171
+ ```
172
+
173
+ What this does:
174
+ - Restores `.env` from the latest `.env.backup.<runName>`.
175
+ - Deletes all `.env.backup.<runName>` files created by the workflow.
176
+ - Drops each test database/schema recorded in `.solidx-test-manifest`.
177
+ - Deletes the manifest file.
178
+
179
+ Example output:
180
+ ```
181
+ ▶ Running solid test data
182
+ Deleting test datasource environment and databases.
183
+ Dropping test database/schema "default_20260201234402_steady_wolf" on datasource "default"...
184
+ ✔ Test datasource env files and manifest deleted; test databases dropped.
185
+ ✔ solid test data completed
186
+ ```
187
+
188
+ Rationale:
189
+ - Keeps the local environment clean and restores the original `.env` safely.
190
+
191
+ ---
192
+
193
+ ## Optional: Limit modules for test data load
194
+
195
+ You can restrict test data loading to a subset of modules:
196
+ ```
197
+ npx @solidxai/solidctl test data --load --modules-to-test venue,reports
198
+ ```
199
+
200
+ Only the listed modules are processed.
@@ -0,0 +1,24 @@
1
+ # Issue: Consumer sees `Property 'id' does not exist on type 'VenueUser'`
2
+
3
+ ## Summary
4
+ The published declaration files in `dist/` import internal types using `src/...` module specifiers. In a consuming project, TypeScript resolves those imports against the consumer's `src` path (or fails), which can cause `User` to extend a different `CommonEntity` that does not define `id`. This leads to `Property 'id' does not exist on type 'VenueUser'` even though `CommonEntity` in the library defines it.
5
+
6
+ ## Evidence
7
+ - `dist/entities/user.entity.d.ts` starts with:
8
+ - `import { CommonEntity } from "src/entities/common.entity";`
9
+ - `dist/entities/common.entity.d.ts` correctly contains:
10
+ - `id: number;`
11
+
12
+ Because the import is `src/...`, the consumer may resolve it to their own `src` tree instead of the library's `dist` types.
13
+
14
+ ## Root Cause
15
+ Library declarations are not portable because internal imports are using absolute `src/...` aliases. These aliases are not part of Node module resolution, so consumers resolve them differently.
16
+
17
+ ## Fix Options
18
+ 1. **Preferred:** Replace internal imports in `src/` with relative paths so emitted `.d.ts` files are portable.
19
+ 2. **Alternative:** Keep `src/*` aliases but add a post-build step (e.g., `tsc-alias`) to rewrite `dist/**/*.d.ts` imports to relative paths.
20
+
21
+ ## Next Steps
22
+ - Decide on option 1 or 2.
23
+ - Rebuild and verify `dist/**/*.d.ts` no longer import from `src/...`.
24
+ - Publish a new package version and ensure the consuming app resolves `User` and `CommonEntity` from the same package instance.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@solidxai/core",
3
- "version": "0.1.10-beta.3",
3
+ "version": "0.1.10-beta.4",
4
4
  "description": "This module is a NestJS module containing all the required core providers required by a Solid application",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -7,7 +7,7 @@ import { UpdateActionMetadataDto } from '../dtos/update-action-metadata.dto';
7
7
  import { SolidRequestContextDto } from 'src/dtos/solid-request-context.dto';
8
8
  import { SolidRequestContextDecorator } from 'src/decorators/solid-request-context.decorator';
9
9
 
10
- @ApiTags('App Builder')
10
+ @ApiTags('Solid Core')
11
11
  @Controller('action-metadata') //FIXME: Change this to the model plural name
12
12
  export class ActionMetadataController {
13
13
  constructor(private readonly service: ActionMetadataService) { }
@@ -24,7 +24,7 @@ import { UserService } from "../services/user.service";
24
24
  import type { SolidCoreSetting } from "../services/settings/default-settings-provider.service";
25
25
 
26
26
  @Auth(AuthType.None)
27
- @ApiTags("Iam")
27
+ @ApiTags("Solid Core")
28
28
  @Controller("iam/facebook")
29
29
  export class FacebookAuthenticationController {
30
30
  constructor(
@@ -16,7 +16,7 @@ import type { SolidCoreSetting } from "src/services/settings/default-settings-pr
16
16
 
17
17
  @Auth(AuthType.None)
18
18
  @Controller('iam/google')
19
- @ApiTags("Iam")
19
+ @ApiTags("Solid Core")
20
20
  // @UseGuards(ThrottlerGuard)
21
21
  // @SkipThrottle({ login: false, short: false, burst: true, sustained: true }) //Enable the login throttle only
22
22
  export class GoogleAuthenticationController {
@@ -9,7 +9,7 @@ import { ActiveUserData } from 'src/interfaces/active-user-data.interface';
9
9
  import { SolidRequestContextDto } from 'src/dtos/solid-request-context.dto';
10
10
  import { SolidRequestContextDecorator } from 'src/decorators/solid-request-context.decorator';
11
11
 
12
- @ApiTags('App Builder')
12
+ @ApiTags('Solid Core')
13
13
  @Controller('menu-item-metadata') //FIXME: Change this to the model plural name
14
14
  export class MenuItemMetadataController {
15
15
  constructor(private readonly service: MenuItemMetadataService) { }
@@ -24,7 +24,7 @@ import { UserService } from "../services/user.service";
24
24
  import type { SolidCoreSetting } from "../services/settings/default-settings-provider.service";
25
25
 
26
26
  @Auth(AuthType.None)
27
- @ApiTags("Iam")
27
+ @ApiTags("Solid Core")
28
28
  @Controller("iam/microsoft")
29
29
  export class MicrosoftAuthenticationController {
30
30
  constructor(
@@ -7,7 +7,7 @@ import { MqMessageQueueService } from '../services/mq-message-queue.service';
7
7
  import { SolidRequestContextDto } from 'src/dtos/solid-request-context.dto';
8
8
  import { SolidRequestContextDecorator } from 'src/decorators/solid-request-context.decorator';
9
9
 
10
- @ApiTags('Queues')
10
+ @ApiTags('Solid Core')
11
11
  @Controller('mq-message-queue') //FIXME: Change this to the model plural name
12
12
  export class MqMessageQueueController {
13
13
  constructor(protected readonly service: MqMessageQueueService) { }
@@ -7,7 +7,7 @@ import { AnyFilesInterceptor } from '@nestjs/platform-express';
7
7
  import { SolidRequestContextDecorator } from 'src/decorators/solid-request-context.decorator';
8
8
  import { SolidRequestContextDto } from 'src/dtos/solid-request-context.dto';
9
9
 
10
- @ApiTags('Queues')
10
+ @ApiTags('Solid Core')
11
11
  @Controller('mq-message') //FIXME: Change this to the model plural name
12
12
  export class MqMessageController {
13
13
  constructor(protected readonly service: MqMessageService) { }
@@ -9,7 +9,7 @@ import { SolidRequestContextDto } from 'src/dtos/solid-request-context.dto';
9
9
  import { ActiveUser } from 'src/decorators/active-user.decorator';
10
10
  import { ActiveUserData } from 'src/interfaces/active-user-data.interface';
11
11
 
12
- @ApiTags('App Builder')
12
+ @ApiTags('Solid Core')
13
13
  @Controller('view-metadata') //FIXME: Change this to the model plural name
14
14
  export class ViewMetadataController {
15
15
  constructor(private readonly service: ViewMetadataService) { }
@@ -18,7 +18,6 @@ export class ChatterMessageDetails extends CommonEntity {
18
18
  @Column({ type: "varchar", nullable: true })
19
19
  oldValueDisplay: string;
20
20
 
21
- @Index()
22
21
  @Column({ type: "varchar", nullable: true })
23
22
  newValueDisplay: string;
24
23
 
@@ -30,4 +29,4 @@ export class ChatterMessageDetails extends CommonEntity {
30
29
 
31
30
  @Column({ type: "varchar", nullable: true })
32
31
  fieldType: string;
33
- }
32
+ }
@@ -20,7 +20,7 @@ export class BigIntFieldCrudManager implements FieldCrudManager {
20
20
  if (typeof fieldValue === 'string' || typeof fieldValue === 'number') {
21
21
  fieldValue = BigInt(fieldValue);
22
22
  }
23
- } catch (err) {
23
+ } catch (err: any) {
24
24
  return [{ field: this.options.fieldName, error: 'Invalid numeric value' }];
25
25
  }
26
26
  }
@@ -119,7 +119,7 @@ export class SelectionDynamicFieldCrudManager implements FieldCrudManager {
119
119
  }
120
120
  return false;
121
121
  }
122
- catch (error) {
122
+ catch (error: any) {
123
123
  // Use the values method as a fallback, if the value method is not implemented
124
124
  const values = await providerInstance.values('', ctxt);
125
125
  const isValid = values.some(v => v.value === fieldValue);
@@ -23,7 +23,7 @@ export class ModuleMetadataHelperService {
23
23
  const fileContent = await fs.readFile(configFilePath, 'utf8');
24
24
  return JSON.parse(fileContent);
25
25
  }
26
- catch (error) {
26
+ catch (error: any) {
27
27
  this.logger.error(`module metadata configuration non existent at: ${configFilePath}`);
28
28
  }
29
29
 
@@ -35,7 +35,7 @@ export class ChatterQueueSubscriberDatabase extends DatabaseSubscriber<AuditQueu
35
35
 
36
36
  switch (p.eventType) {
37
37
  case 'insert':
38
- await this.chatterMessageService.postAuditMessageOnInsert(p.after, p.modelName);
38
+ await this.chatterMessageService.postAuditMessageOnInsert(p.after, p.modelName, false, p.userId);
39
39
  break;
40
40
  case 'update':
41
41
  await this.chatterMessageService.postAuditMessageOnUpdate(
@@ -43,10 +43,12 @@ export class ChatterQueueSubscriberDatabase extends DatabaseSubscriber<AuditQueu
43
43
  p.modelName,
44
44
  p.before,
45
45
  (p.updatedColumnNames ?? []).map(n => ({ propertyName: n })),
46
+ false,
47
+ p.userId,
46
48
  );
47
49
  break;
48
50
  case 'delete':
49
- await this.chatterMessageService.postAuditMessageOnDelete(p.modelName, p.before);
51
+ await this.chatterMessageService.postAuditMessageOnDelete(p.modelName, p.before, false, p.userId);
50
52
  break;
51
53
  }
52
54
  }
@@ -60,7 +60,7 @@ export class TriggerMcpClientSubscriberDatabase extends DatabaseSubscriber<Trigg
60
60
  // Fallback
61
61
  nestedResponse = String(raw);
62
62
  }
63
- } catch (err) {
63
+ } catch (err: any) {
64
64
  this.triggerMcpClientSubscriberLogger.error("Error processing AI response:", err);
65
65
  nestedResponse = `Error handling response: ${err?.message || String(err)}`;
66
66
  }
@@ -33,7 +33,7 @@ export class ChatterQueueSubscriberRabbitmq extends RabbitMqSubscriber<AuditQueu
33
33
 
34
34
  switch (p.eventType) {
35
35
  case 'insert':
36
- await this.chatterMessageService.postAuditMessageOnInsert(p.after, p.modelName);
36
+ await this.chatterMessageService.postAuditMessageOnInsert(p.after, p.modelName, false, p.userId);
37
37
  break;
38
38
  case 'update':
39
39
  await this.chatterMessageService.postAuditMessageOnUpdate(
@@ -41,10 +41,12 @@ export class ChatterQueueSubscriberRabbitmq extends RabbitMqSubscriber<AuditQueu
41
41
  p.modelName,
42
42
  p.before,
43
43
  (p.updatedColumnNames ?? []).map(n => ({ propertyName: n })),
44
+ false,
45
+ p.userId,
44
46
  );
45
47
  break;
46
48
  case 'delete':
47
- await this.chatterMessageService.postAuditMessageOnDelete(p.modelName, p.before);
49
+ await this.chatterMessageService.postAuditMessageOnDelete(p.modelName, p.before, false, p.userId);
48
50
  break;
49
51
  }
50
52
  }
@@ -33,13 +33,20 @@ export class ChatterQueueSubscriberRedis extends RedisSubscriber<any> {
33
33
 
34
34
  switch (p.eventType) {
35
35
  case 'insert':
36
- await this.chatterMessageService.postAuditMessageOnInsert(p.after, { name: p.modelName } as any);
36
+ await this.chatterMessageService.postAuditMessageOnInsert(p.after, p.modelName, false, p.userId);
37
37
  break;
38
38
  case 'update':
39
- await this.chatterMessageService.postAuditMessageOnUpdate(p.after, { name: p.modelName } as any, p.before, (p.updatedColumnNames || []).map(n => ({ propertyName: n })));
39
+ await this.chatterMessageService.postAuditMessageOnUpdate(
40
+ p.after,
41
+ p.modelName,
42
+ p.before,
43
+ (p.updatedColumnNames || []).map(n => ({ propertyName: n })),
44
+ false,
45
+ p.userId,
46
+ );
40
47
  break;
41
48
  case 'delete':
42
- await this.chatterMessageService.postAuditMessageOnDelete(p.before, { name: p.modelName } as any, p.before);
49
+ await this.chatterMessageService.postAuditMessageOnDelete(p.modelName, p.before, false, p.userId);
43
50
  break;
44
51
  }
45
52
  }
@@ -56,7 +56,7 @@ export class SecurityRuleRepository extends SolidBaseRepository<SecurityRule> {
56
56
 
57
57
  evaluatedRules.push(evaluatedRule);
58
58
 
59
- } catch (error) {
59
+ } catch (error: any) {
60
60
  this.logger.error(`Error parsing security rule: ${rule.securityRuleConfig}`, error);
61
61
  this.logger.error(error.stack);
62
62
  throw error;
@@ -238,7 +238,7 @@ export class ModuleMetadataSeederService {
238
238
 
239
239
  //FIXME: Handle displaying the created users credentials in a better way.
240
240
  // this.logger.log(`Newly created username is: ${usersDetail?.length > 0 ? usersDetail[0]?.username : ''} and password is ${usersDetail?.length > 0 ? usersDetail[0]?.password : ''}`);
241
- } catch (error) {
241
+ } catch (error: any) {
242
242
  this.logSeedFailureForCli(error, {
243
243
  moduleName: currentModule,
244
244
  step: currentStep,
@@ -463,7 +463,7 @@ export class ModuleMetadataSeederService {
463
463
  await this.createPermissionIfNotExists(permissionName);
464
464
  }
465
465
 
466
- } catch (error) {
466
+ } catch (error: any) {
467
467
  this.logger.error(error);
468
468
  }
469
469
  }
@@ -544,7 +544,7 @@ export class ModuleMetadataSeederService {
544
544
  moduleRoot = path.dirname(
545
545
  require.resolve('@solidxai/core/package.json'),
546
546
  );
547
- } catch (err) {
547
+ } catch (err: any) {
548
548
  this.logger.debug(
549
549
  'Could not resolve @solidxai/core from node_modules, assuming local execution',
550
550
  );
@@ -610,7 +610,7 @@ export class ModuleMetadataSeederService {
610
610
  moduleRoot = path.dirname(
611
611
  require.resolve('@solidxai/core/package.json'),
612
612
  );
613
- } catch (err) {
613
+ } catch (err: any) {
614
614
  this.logger.debug(
615
615
  'Could not resolve @solidxai/core from node_modules, assuming local execution',
616
616
  );
@@ -52,7 +52,7 @@ export class PermissionMetadataSeederService {
52
52
  }
53
53
  }
54
54
 
55
- } catch (error) {
55
+ } catch (error: any) {
56
56
  this.logger.error(error);
57
57
  }
58
58
  }
@@ -11552,7 +11552,7 @@
11552
11552
  "enableGlobalSearch": true,
11553
11553
  "create": true,
11554
11554
  "edit": true,
11555
- "delete": false
11555
+ "delete": true
11556
11556
  },
11557
11557
  "children": [
11558
11558
  {
@@ -11570,7 +11570,18 @@
11570
11570
  "name": "name",
11571
11571
  "label": "Name",
11572
11572
  "sortable": true,
11573
- "filterable": true
11573
+ "filterable": true,
11574
+ "isSearchable": true
11575
+ }
11576
+ },
11577
+ {
11578
+ "type": "field",
11579
+ "attrs": {
11580
+ "name": "description",
11581
+ "label": "Description",
11582
+ "sortable": true,
11583
+ "filterable": true,
11584
+ "isSearchable": true
11574
11585
  }
11575
11586
  }
11576
11587
  ]