@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.
- package/dist/controllers/action-metadata.controller.js +1 -1
- package/dist/controllers/action-metadata.controller.js.map +1 -1
- package/dist/controllers/facebook-authentication.controller.js +1 -1
- package/dist/controllers/facebook-authentication.controller.js.map +1 -1
- package/dist/controllers/google-authentication.controller.js +1 -1
- package/dist/controllers/google-authentication.controller.js.map +1 -1
- package/dist/controllers/menu-item-metadata.controller.js +1 -1
- package/dist/controllers/menu-item-metadata.controller.js.map +1 -1
- package/dist/controllers/microsoft-authentication.controller.js +1 -1
- package/dist/controllers/microsoft-authentication.controller.js.map +1 -1
- package/dist/controllers/mq-message-queue.controller.js +1 -1
- package/dist/controllers/mq-message-queue.controller.js.map +1 -1
- package/dist/controllers/mq-message.controller.js +1 -1
- package/dist/controllers/mq-message.controller.js.map +1 -1
- package/dist/controllers/view-metadata.controller.js +1 -1
- package/dist/controllers/view-metadata.controller.js.map +1 -1
- package/dist/entities/chatter-message-details.entity.d.ts.map +1 -1
- package/dist/entities/chatter-message-details.entity.js +0 -1
- package/dist/entities/chatter-message-details.entity.js.map +1 -1
- package/dist/helpers/field-crud-managers/BigIntFieldCrudManager.js.map +1 -1
- package/dist/helpers/field-crud-managers/SelectionDynamicFieldCrudManager.js.map +1 -1
- package/dist/helpers/module-metadata-helper.service.js.map +1 -1
- package/dist/jobs/database/chatter-queue-subscriber-database.service.d.ts.map +1 -1
- package/dist/jobs/database/chatter-queue-subscriber-database.service.js +3 -3
- package/dist/jobs/database/chatter-queue-subscriber-database.service.js.map +1 -1
- package/dist/jobs/database/trigger-mcp-client-subscriber-database.service.js.map +1 -1
- package/dist/jobs/rabbitmq/chatter-queue-subscriber.service.d.ts.map +1 -1
- package/dist/jobs/rabbitmq/chatter-queue-subscriber.service.js +3 -3
- package/dist/jobs/rabbitmq/chatter-queue-subscriber.service.js.map +1 -1
- package/dist/jobs/redis/chatter-queue-subscriber-redis.service.d.ts.map +1 -1
- package/dist/jobs/redis/chatter-queue-subscriber-redis.service.js +3 -3
- package/dist/jobs/redis/chatter-queue-subscriber-redis.service.js.map +1 -1
- package/dist/repository/security-rule.repository.js.map +1 -1
- package/dist/seeders/module-metadata-seeder.service.js.map +1 -1
- package/dist/seeders/permission-metadata-seeder.service.js.map +1 -1
- package/dist/seeders/seed-data/solid-core-metadata.json +13 -2
- package/dist/services/authentication.service.d.ts.map +1 -1
- package/dist/services/authentication.service.js +5 -5
- package/dist/services/authentication.service.js.map +1 -1
- package/dist/services/chatter-message.service.d.ts +6 -3
- package/dist/services/chatter-message.service.d.ts.map +1 -1
- package/dist/services/chatter-message.service.js +23 -35
- package/dist/services/chatter-message.service.js.map +1 -1
- package/dist/services/crud.service.js.map +1 -1
- package/dist/services/csv.service.js.map +1 -1
- package/dist/services/dashboard.service.js.map +1 -1
- package/dist/services/database/database-bootstrap.service.js.map +1 -1
- package/dist/services/excel.service.js.map +1 -1
- package/dist/services/export-transaction.service.js.map +1 -1
- package/dist/services/field-metadata.service.js.map +1 -1
- package/dist/services/fixtures.service.js.map +1 -1
- package/dist/services/import-transaction.service.js.map +1 -1
- package/dist/services/list-of-values.service.js.map +1 -1
- package/dist/services/model-metadata.service.d.ts.map +1 -1
- package/dist/services/model-metadata.service.js +3 -13
- package/dist/services/model-metadata.service.js.map +1 -1
- package/dist/services/module-metadata.service.js.map +1 -1
- package/dist/services/queues/database-publisher.service.js +3 -3
- package/dist/services/queues/database-publisher.service.js.map +1 -1
- package/dist/services/queues/database-subscriber.service.js.map +1 -1
- package/dist/services/queues/rabbitmq-publisher.service.js +3 -3
- package/dist/services/queues/rabbitmq-publisher.service.js.map +1 -1
- package/dist/services/queues/rabbitmq-subscriber.service.js.map +1 -1
- package/dist/services/queues/redis-publisher.service.d.ts.map +1 -1
- package/dist/services/queues/redis-publisher.service.js +4 -1
- package/dist/services/queues/redis-publisher.service.js.map +1 -1
- package/dist/services/queues/redis-subscriber.service.js.map +1 -1
- package/dist/services/role-metadata.service.js.map +1 -1
- package/dist/services/scheduled-jobs/scheduler.service.js.map +1 -1
- package/dist/services/settings/default-settings-provider.service.d.ts +58 -8
- package/dist/services/settings/default-settings-provider.service.d.ts.map +1 -1
- package/dist/services/settings/default-settings-provider.service.js +21 -4
- package/dist/services/settings/default-settings-provider.service.js.map +1 -1
- package/dist/services/sms/TwilioSMSService.js.map +1 -1
- package/dist/services/solid-introspect.service.js.map +1 -1
- package/dist/services/user-activity-history.service.js.map +1 -1
- package/dist/services/view-metadata.service.d.ts.map +1 -1
- package/dist/services/view-metadata.service.js +17 -2
- package/dist/services/view-metadata.service.js.map +1 -1
- package/dist/subscribers/computed-entity-field.subscriber.js.map +1 -1
- package/dist/subscribers/security-rule.subscriber.d.ts.map +1 -1
- package/dist/subscribers/security-rule.subscriber.js.map +1 -1
- package/dist/subscribers/view-metadata.subscriber.js.map +1 -1
- package/dist/testing/core/testing-engine.js.map +1 -1
- package/dist/testing/reporter/webhook-reporter.js.map +1 -1
- package/dist-tests/api/authenticate.spec.js +119 -0
- package/dist-tests/api/authenticate.spec.js.map +1 -0
- package/dist-tests/api/crud-service.findOne.cityMaster.spec.js +97 -0
- package/dist-tests/api/crud-service.findOne.cityMaster.spec.js.map +1 -0
- package/dist-tests/api/ping.spec.js +21 -0
- package/dist-tests/api/ping.spec.js.map +1 -0
- package/dist-tests/helpers/auth.js +41 -0
- package/dist-tests/helpers/auth.js.map +1 -0
- package/dist-tests/helpers/env.js +11 -0
- package/dist-tests/helpers/env.js.map +1 -0
- package/docs/grouping-enhancements.md +89 -0
- package/docs/java-spring/README.md +3 -0
- package/docs/java-spring/solid-core-module-deep-dive-report.md +1317 -0
- package/docs/seed-changes.md +65 -0
- package/docs/test-data-workflow.md +200 -0
- package/docs/type-declaration-import-issue.md +24 -0
- package/package.json +1 -1
- package/src/controllers/action-metadata.controller.ts +1 -1
- package/src/controllers/facebook-authentication.controller.ts +1 -1
- package/src/controllers/google-authentication.controller.ts +1 -1
- package/src/controllers/menu-item-metadata.controller.ts +1 -1
- package/src/controllers/microsoft-authentication.controller.ts +1 -1
- package/src/controllers/mq-message-queue.controller.ts +1 -1
- package/src/controllers/mq-message.controller.ts +1 -1
- package/src/controllers/view-metadata.controller.ts +1 -1
- package/src/entities/chatter-message-details.entity.ts +1 -2
- package/src/helpers/field-crud-managers/BigIntFieldCrudManager.ts +1 -1
- package/src/helpers/field-crud-managers/SelectionDynamicFieldCrudManager.ts +1 -1
- package/src/helpers/module-metadata-helper.service.ts +1 -1
- package/src/jobs/database/chatter-queue-subscriber-database.service.ts +4 -2
- package/src/jobs/database/trigger-mcp-client-subscriber-database.service.ts +1 -1
- package/src/jobs/rabbitmq/chatter-queue-subscriber.service.ts +4 -2
- package/src/jobs/redis/chatter-queue-subscriber-redis.service.ts +10 -3
- package/src/repository/security-rule.repository.ts +1 -1
- package/src/seeders/module-metadata-seeder.service.ts +4 -4
- package/src/seeders/permission-metadata-seeder.service.ts +1 -1
- package/src/seeders/seed-data/solid-core-metadata.json +13 -2
- package/src/services/authentication.service.ts +19 -31
- package/src/services/chatter-message.service.ts +28 -38
- package/src/services/crud.service.ts +1 -1
- package/src/services/csv.service.ts +1 -1
- package/src/services/dashboard.service.ts +1 -1
- package/src/services/database/database-bootstrap.service.ts +1 -1
- package/src/services/excel.service.ts +1 -1
- package/src/services/export-transaction.service.ts +2 -2
- package/src/services/field-metadata.service.ts +1 -1
- package/src/services/fixtures.service.ts +2 -2
- package/src/services/import-transaction.service.ts +2 -2
- package/src/services/list-of-values.service.ts +1 -1
- package/src/services/model-metadata.service.ts +22 -21
- package/src/services/module-metadata.service.ts +7 -7
- package/src/services/queues/database-publisher.service.ts +4 -4
- package/src/services/queues/database-subscriber.service.ts +1 -1
- package/src/services/queues/rabbitmq-publisher.service.ts +7 -7
- package/src/services/queues/rabbitmq-subscriber.service.ts +8 -8
- package/src/services/queues/redis-publisher.service.ts +7 -4
- package/src/services/queues/redis-subscriber.service.ts +4 -4
- package/src/services/role-metadata.service.ts +1 -1
- package/src/services/scheduled-jobs/scheduler.service.ts +5 -5
- package/src/services/settings/default-settings-provider.service.ts +21 -4
- package/src/services/sms/TwilioSMSService.ts +2 -2
- package/src/services/solid-introspect.service.ts +2 -2
- package/src/services/user-activity-history.service.ts +1 -1
- package/src/services/view-metadata.service.ts +25 -8
- package/src/subscribers/computed-entity-field.subscriber.ts +1 -1
- package/src/subscribers/security-rule.subscriber.ts +8 -8
- package/src/subscribers/view-metadata.subscriber.ts +1 -1
- package/src/testing/core/testing-engine.ts +2 -2
- package/src/testing/reporter/webhook-reporter.ts +1 -1
- package/.claude/settings.local.json +0 -15
- 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
|
+
"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('
|
|
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("
|
|
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("
|
|
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('
|
|
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("
|
|
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('
|
|
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('
|
|
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('
|
|
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,
|
|
36
|
+
await this.chatterMessageService.postAuditMessageOnInsert(p.after, p.modelName, false, p.userId);
|
|
37
37
|
break;
|
|
38
38
|
case 'update':
|
|
39
|
-
await this.chatterMessageService.postAuditMessageOnUpdate(
|
|
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.
|
|
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
|
);
|
|
@@ -11552,7 +11552,7 @@
|
|
|
11552
11552
|
"enableGlobalSearch": true,
|
|
11553
11553
|
"create": true,
|
|
11554
11554
|
"edit": true,
|
|
11555
|
-
"delete":
|
|
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
|
]
|