db-model-router 1.0.7 → 1.0.9
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/README.md +25 -4
- package/db-manager/.dbmanager.sqlite-shm +0 -0
- package/db-manager/.dbmanager.sqlite-wal +0 -0
- package/demo/.env.example +1 -0
- package/demo/app.js +2 -2
- package/demo/commons/db.js +0 -11
- package/demo/middleware/tenantIsolation.js +2 -0
- package/demo/package-lock.json +1224 -62
- package/demo/package.json +6 -3
- package/demo/routes/addresses/index.js +5 -1
- package/demo/routes/auth/index.js +1 -1
- package/demo/routes/carts/cart_items/index.js +5 -1
- package/demo/routes/carts/index.js +9 -1
- package/demo/routes/categories/index.js +5 -1
- package/demo/routes/coupons/index.js +5 -1
- package/demo/routes/index.js +1 -15
- package/demo/routes/orders/index.js +13 -1
- package/demo/routes/orders/order_items/index.js +5 -1
- package/demo/routes/orders/payments/index.js +5 -1
- package/demo/routes/orders/shipments/index.js +5 -1
- package/demo/routes/products/index.js +13 -1
- package/demo/routes/products/product_images/index.js +5 -1
- package/demo/routes/products/product_reviews/index.js +5 -1
- package/demo/routes/products/product_variants/index.js +5 -1
- package/demo/routes/roles/index.js +1 -1
- package/demo/routes/tenants/index.js +1 -1
- package/demo/routes/users/index.js +1 -1
- package/demo/routes/wishlists/index.js +5 -1
- package/demo/seeds/saas-seed.js +1 -1
- package/docs/dbmr-schema-spec.md +393 -0
- package/package.json +4 -2
- package/skill/SKILL.md +47 -4
- package/src/cli/commands/generate.js +45 -15
- package/src/cli/diff-engine.js +17 -5
- package/src/cli/generate-migration.js +207 -19
- package/src/cli/generate-route.js +156 -58
- package/src/cli/generate-saas-structure.js +8 -1
- package/src/cli/init/dependencies.js +5 -1
- package/src/cli/init/generators.js +4 -81
- package/src/cli/init.js +1 -2
- package/src/cli/saas/generate-saas-middleware.js +2 -0
- package/src/cli/saas/generate-saas-routes.js +3 -13
- package/src/cli/saas/generate-saas-tests.js +473 -0
- package/src/commons/route.js +6 -6
- /package/demo/migrations/{20260509170349_create_migrations_table.sql → 20260510193736_create_migrations_table.sql} +0 -0
- /package/demo/migrations/{20260509170349_create_saas_tables.sql → 20260510193737_create_saas_tables.sql} +0 -0
- /package/demo/migrations/{20260509170349_create_tables.sql → 20260510193737_create_tables.sql} +0 -0
package/README.md
CHANGED
|
@@ -147,14 +147,14 @@ Examples of tables that should stay top-level (not be parents of feature modules
|
|
|
147
147
|
"age": "integer",
|
|
148
148
|
"is_deleted": "boolean",
|
|
149
149
|
"created_at": "datetime",
|
|
150
|
-
"
|
|
150
|
+
"modified_at": "datetime"
|
|
151
151
|
},
|
|
152
152
|
"pk": "user_id",
|
|
153
153
|
"unique": ["email"],
|
|
154
154
|
"softDelete": "is_deleted",
|
|
155
155
|
"timestamps": {
|
|
156
156
|
"created_at": "created_at",
|
|
157
|
-
"modified_at": "
|
|
157
|
+
"modified_at": "modified_at"
|
|
158
158
|
},
|
|
159
159
|
"parent": null
|
|
160
160
|
},
|
|
@@ -209,7 +209,7 @@ Note: `comments` has `user_id` as a foreign key column but `users` is NOT its pa
|
|
|
209
209
|
|
|
210
210
|
#### Column Rules
|
|
211
211
|
|
|
212
|
-
Format: `
|
|
212
|
+
Format: `[required|]<type>[:<subtype>][|<validator>...]`
|
|
213
213
|
|
|
214
214
|
| Type | Description |
|
|
215
215
|
| ---------------- | ------------------------------------------------------------------ |
|
|
@@ -221,7 +221,28 @@ Format: `(required|)?(string|integer|numeric|boolean|object|datetime|auto_increm
|
|
|
221
221
|
| `boolean` | Boolean columns (BOOLEAN, BIT) |
|
|
222
222
|
| `object` | JSON columns (JSON, JSONB) |
|
|
223
223
|
|
|
224
|
-
Prefix with `required|` for NOT NULL constraint
|
|
224
|
+
Prefix with `required|` for NOT NULL constraint. Append `:subtype` for finer SQL type control. Append `|validator` for runtime validation rules.
|
|
225
|
+
|
|
226
|
+
**Sub-type examples:**
|
|
227
|
+
|
|
228
|
+
```
|
|
229
|
+
"description": "string:text" # TEXT instead of VARCHAR(255)
|
|
230
|
+
"body": "required|string:longtext" # LONGTEXT NOT NULL
|
|
231
|
+
"stock": "required|integer:unsigned" # INT UNSIGNED NOT NULL
|
|
232
|
+
"price": "required|numeric:decimal(10,4)" # DECIMAL(10,4) NOT NULL
|
|
233
|
+
```
|
|
234
|
+
|
|
235
|
+
**Validation examples:**
|
|
236
|
+
|
|
237
|
+
```
|
|
238
|
+
"email": "required|string|email|maxLength:255" # email format + length check
|
|
239
|
+
"phone": "string|phoneNumber" # phone number format
|
|
240
|
+
"rating": "required|integer|min:1|max:5" # range validation
|
|
241
|
+
"slug": "required|string|regex:^[a-z0-9-]+$" # pattern validation
|
|
242
|
+
"role": "required|string|in:admin,user,moderator" # enum validation
|
|
243
|
+
```
|
|
244
|
+
|
|
245
|
+
For the full column rule specification including all sub-types and validators, see [docs/dbmr-schema-spec.md](./docs/dbmr-schema-spec.md).
|
|
225
246
|
|
|
226
247
|
### Unified CLI: `db-model-router`
|
|
227
248
|
|
|
Binary file
|
|
Binary file
|
package/demo/.env.example
CHANGED
package/demo/app.js
CHANGED
|
@@ -3,7 +3,7 @@ import "./commons/db.js";
|
|
|
3
3
|
import configureSession from "./commons/session.js";
|
|
4
4
|
import applySecurity from "./commons/security.js";
|
|
5
5
|
import logger from "./middleware/logger.js";
|
|
6
|
-
import
|
|
6
|
+
import routes from "./routes/index.js";
|
|
7
7
|
import { fileURLToPath } from 'node:url';
|
|
8
8
|
import path from "path";
|
|
9
9
|
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
|
@@ -24,7 +24,7 @@ app.use(configureSession());
|
|
|
24
24
|
app.use(logger);
|
|
25
25
|
|
|
26
26
|
// Routes
|
|
27
|
-
app.use(
|
|
27
|
+
app.use(process.env.API_BASE_PATH || "/api", routes);
|
|
28
28
|
|
|
29
29
|
// Error handler
|
|
30
30
|
app.use((err, req, res, next) => {
|
package/demo/commons/db.js
CHANGED
|
@@ -9,17 +9,6 @@ dbModelRouter.db.connect({
|
|
|
9
9
|
database: process.env.DB_NAME || "./data/data.db",
|
|
10
10
|
});
|
|
11
11
|
|
|
12
|
-
// Initialize Kafka if KAFKA_BROKER is configured
|
|
13
|
-
if (process.env.KAFKA_BROKER) {
|
|
14
|
-
dbModelRouter.kafka.init().then((connected) => {
|
|
15
|
-
if (connected) {
|
|
16
|
-
console.log("[kafka] Producer connected to", process.env.KAFKA_BROKER);
|
|
17
|
-
} else {
|
|
18
|
-
console.warn("[kafka] Failed to connect to Kafka broker");
|
|
19
|
-
}
|
|
20
|
-
});
|
|
21
|
-
}
|
|
22
|
-
|
|
23
12
|
// Make db available globally across the application
|
|
24
13
|
const db = dbModelRouter.db;
|
|
25
14
|
global.db = db;
|
|
@@ -8,6 +8,8 @@
|
|
|
8
8
|
function tenantIsolation(req, res, next) {
|
|
9
9
|
const hasGlobal = req.session.permission.some((p) => p.scope === "global");
|
|
10
10
|
if (!hasGlobal) {
|
|
11
|
+
if (!req.query) req.query = {};
|
|
12
|
+
if (!req.body) req.body = {};
|
|
11
13
|
req.query.tenant_id = req.session.user.tenant_id;
|
|
12
14
|
req.body.tenant_id = req.session.user.tenant_id;
|
|
13
15
|
}
|