@bhushanpawar/sqldb 1.0.0 → 1.0.2
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 +1403 -93
- package/dist/cache/cache-manager.d.ts.map +1 -1
- package/dist/cache/cache-manager.js +2 -1
- package/dist/cache/cache-manager.js.map +1 -1
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +225 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/schema-generator.d.ts +28 -0
- package/dist/cli/schema-generator.d.ts.map +1 -0
- package/dist/cli/schema-generator.js +159 -0
- package/dist/cli/schema-generator.js.map +1 -0
- package/dist/client.d.ts +32 -0
- package/dist/client.d.ts.map +1 -1
- package/dist/client.js +56 -14
- package/dist/client.js.map +1 -1
- package/dist/connection/mariadb.d.ts +21 -0
- package/dist/connection/mariadb.d.ts.map +1 -1
- package/dist/connection/mariadb.js +121 -3
- package/dist/connection/mariadb.js.map +1 -1
- package/dist/db-schema.d.ts +413 -0
- package/dist/db-schema.d.ts.map +1 -0
- package/dist/db-schema.js +1149 -0
- package/dist/db-schema.js.map +1 -0
- package/dist/discovery/dependency-graph.d.ts +3 -0
- package/dist/discovery/dependency-graph.d.ts.map +1 -1
- package/dist/discovery/dependency-graph.js +11 -0
- package/dist/discovery/dependency-graph.js.map +1 -1
- package/dist/discovery/schema-reader.d.ts +1 -1
- package/dist/discovery/schema-reader.d.ts.map +1 -1
- package/dist/discovery/schema-reader.js +48 -19
- package/dist/discovery/schema-reader.js.map +1 -1
- package/dist/index.d.ts +9 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +63 -3
- package/dist/index.js.map +1 -1
- package/dist/query/operations.d.ts +7 -0
- package/dist/query/operations.d.ts.map +1 -1
- package/dist/query/operations.js +204 -22
- package/dist/query/operations.js.map +1 -1
- package/dist/types/client.d.ts +32 -0
- package/dist/types/client.d.ts.map +1 -0
- package/dist/types/client.js +3 -0
- package/dist/types/client.js.map +1 -0
- package/dist/types/config.d.ts +3 -0
- package/dist/types/config.d.ts.map +1 -1
- package/dist/types/config.js +14 -1
- package/dist/types/config.js.map +1 -1
- package/dist/types/query.d.ts +12 -0
- package/dist/types/query.d.ts.map +1 -1
- package/dist/types/schema.d.ts +6 -0
- package/dist/types/schema.d.ts.map +1 -1
- package/dist/types/warming.d.ts +47 -0
- package/dist/types/warming.d.ts.map +1 -0
- package/dist/types/warming.js +3 -0
- package/dist/types/warming.js.map +1 -0
- package/dist/warming/auto-warming-manager.d.ts +65 -0
- package/dist/warming/auto-warming-manager.d.ts.map +1 -0
- package/dist/warming/auto-warming-manager.js +256 -0
- package/dist/warming/auto-warming-manager.js.map +1 -0
- package/dist/warming/query-stats-tracker.d.ts +53 -0
- package/dist/warming/query-stats-tracker.d.ts.map +1 -0
- package/dist/warming/query-stats-tracker.js +273 -0
- package/dist/warming/query-stats-tracker.js.map +1 -0
- package/package.json +4 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cache-manager.d.ts","sourceRoot":"","sources":["../../src/cache/cache-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAEtD,qBAAa,YAAY;IACvB,OAAO,CAAC,KAAK,CAAyB;IACtC,OAAO,CAAC,MAAM,CAAwB;IACtC,OAAO,CAAC,UAAU,CAAkB;IACpC,OAAO,CAAC,KAAK,CAIX;gBAGA,KAAK,EAAE,sBAAsB,EAC7B,MAAM,EAAE,QAAQ,CAAC,WAAW,CAAC,EAC7B,SAAS,CAAC,EAAE,MAAM;IAOd,GAAG,CAAC,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAsB5C,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;
|
|
1
|
+
{"version":3,"file":"cache-manager.d.ts","sourceRoot":"","sources":["../../src/cache/cache-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAEtD,qBAAa,YAAY;IACvB,OAAO,CAAC,KAAK,CAAyB;IACtC,OAAO,CAAC,MAAM,CAAwB;IACtC,OAAO,CAAC,UAAU,CAAkB;IACpC,OAAO,CAAC,KAAK,CAIX;gBAGA,KAAK,EAAE,sBAAsB,EAC7B,MAAM,EAAE,QAAQ,CAAC,WAAW,CAAC,EAC7B,SAAS,CAAC,EAAE,MAAM;IAOd,GAAG,CAAC,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAsB5C,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAkBzD,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAYlC,aAAa,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAe/C,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAa3C,aAAa,IAAI,eAAe;IAIhC,QAAQ,IAAI,UAAU;IAetB,UAAU,IAAI,IAAI;IAMlB,SAAS,IAAI,OAAO;IAId,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAa7B"}
|
|
@@ -37,7 +37,8 @@ class CacheManager {
|
|
|
37
37
|
return;
|
|
38
38
|
}
|
|
39
39
|
try {
|
|
40
|
-
|
|
40
|
+
// Handle BigInt serialization
|
|
41
|
+
const serialized = JSON.stringify(value, (key, val) => typeof val === 'bigint' ? val.toString() : val);
|
|
41
42
|
const ttlSeconds = ttl || this.config.defaultTTL;
|
|
42
43
|
await this.redis.set(key, serialized, ttlSeconds);
|
|
43
44
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cache-manager.js","sourceRoot":"","sources":["../../src/cache/cache-manager.ts"],"names":[],"mappings":";;;AAGA,2DAAsD;AAEtD,MAAa,YAAY;IAUvB,YACE,KAA6B,EAC7B,MAA6B,EAC7B,SAAkB;QATZ,UAAK,GAAG;YACd,IAAI,EAAE,CAAC;YACP,MAAM,EAAE,CAAC;YACT,SAAS,EAAE,CAAC;SACb,CAAC;QAOA,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,UAAU,GAAG,IAAI,mCAAe,CAAC,SAAS,CAAC,CAAC;IACnD,CAAC;IAED,KAAK,CAAC,GAAG,CAAU,GAAW;QAC5B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,EAAE,CAAC;YACtD,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAEzC,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;gBACpB,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;gBACpB,OAAO,IAAI,CAAC;YACd,CAAC;YAED,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YAClB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAM,CAAC;QACjC,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,2BAA2B,EAAE,KAAK,CAAC,CAAC;YAClD,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;YACpB,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,GAAW,EAAE,KAAU,EAAE,GAAY;QAC7C,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,EAAE,CAAC;YACtD,OAAO;QACT,CAAC;QAED,IAAI,CAAC;YACH,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"cache-manager.js","sourceRoot":"","sources":["../../src/cache/cache-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,225 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
"use strict";
|
|
3
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
4
|
+
if (k2 === undefined) k2 = k;
|
|
5
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
6
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
8
|
+
}
|
|
9
|
+
Object.defineProperty(o, k2, desc);
|
|
10
|
+
}) : (function(o, m, k, k2) {
|
|
11
|
+
if (k2 === undefined) k2 = k;
|
|
12
|
+
o[k2] = m[k];
|
|
13
|
+
}));
|
|
14
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
15
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
16
|
+
}) : function(o, v) {
|
|
17
|
+
o["default"] = v;
|
|
18
|
+
});
|
|
19
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
20
|
+
var ownKeys = function(o) {
|
|
21
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
22
|
+
var ar = [];
|
|
23
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
24
|
+
return ar;
|
|
25
|
+
};
|
|
26
|
+
return ownKeys(o);
|
|
27
|
+
};
|
|
28
|
+
return function (mod) {
|
|
29
|
+
if (mod && mod.__esModule) return mod;
|
|
30
|
+
var result = {};
|
|
31
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
32
|
+
__setModuleDefault(result, mod);
|
|
33
|
+
return result;
|
|
34
|
+
};
|
|
35
|
+
})();
|
|
36
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
37
|
+
const dotenv_1 = require("dotenv");
|
|
38
|
+
const index_1 = require("../index");
|
|
39
|
+
const fs = __importStar(require("fs"));
|
|
40
|
+
const path = __importStar(require("path"));
|
|
41
|
+
async function generateSchema(options = {}) {
|
|
42
|
+
// Load .env from current directory
|
|
43
|
+
const envPath = path.join(process.cwd(), '.env');
|
|
44
|
+
if (!fs.existsSync(envPath)) {
|
|
45
|
+
console.error('❌ Error: .env file not found in current directory');
|
|
46
|
+
console.error('');
|
|
47
|
+
console.error('Please create a .env file with the following variables:');
|
|
48
|
+
console.error(' DB_HOST=localhost');
|
|
49
|
+
console.error(' DB_PORT=3306');
|
|
50
|
+
console.error(' DB_USER=root');
|
|
51
|
+
console.error(' DB_PASSWORD=your_password');
|
|
52
|
+
console.error(' DB_DATABASE=your_database');
|
|
53
|
+
console.error(' REDIS_HOST=localhost');
|
|
54
|
+
console.error(' REDIS_PORT=6379');
|
|
55
|
+
process.exit(1);
|
|
56
|
+
}
|
|
57
|
+
(0, dotenv_1.configDotenv)({ path: envPath });
|
|
58
|
+
// Validate required env variables
|
|
59
|
+
const required = ['DB_HOST', 'DB_USER', 'DB_DATABASE'];
|
|
60
|
+
const missing = required.filter(key => !process.env[key]);
|
|
61
|
+
if (missing.length > 0) {
|
|
62
|
+
console.error(`❌ Error: Missing required environment variables: ${missing.join(', ')}`);
|
|
63
|
+
console.error('');
|
|
64
|
+
console.error('Your .env file must contain:');
|
|
65
|
+
console.error(' DB_HOST=localhost');
|
|
66
|
+
console.error(' DB_PORT=3306');
|
|
67
|
+
console.error(' DB_USER=root');
|
|
68
|
+
console.error(' DB_PASSWORD=your_password');
|
|
69
|
+
console.error(' DB_DATABASE=your_database');
|
|
70
|
+
console.error(' REDIS_HOST=localhost (optional)');
|
|
71
|
+
console.error(' REDIS_PORT=6379 (optional)');
|
|
72
|
+
process.exit(1);
|
|
73
|
+
}
|
|
74
|
+
console.log('🔍 Connecting to database and discovering schema...\n');
|
|
75
|
+
try {
|
|
76
|
+
const config = {
|
|
77
|
+
mariadb: {
|
|
78
|
+
host: process.env.DB_HOST,
|
|
79
|
+
port: parseInt(process.env.DB_PORT || '3306'),
|
|
80
|
+
user: process.env.DB_USER,
|
|
81
|
+
password: process.env.DB_PASSWORD || '',
|
|
82
|
+
database: process.env.DB_DATABASE,
|
|
83
|
+
connectionLimit: 10,
|
|
84
|
+
},
|
|
85
|
+
cache: {
|
|
86
|
+
enabled: !!process.env.REDIS_HOST,
|
|
87
|
+
},
|
|
88
|
+
discovery: {
|
|
89
|
+
autoDiscover: true,
|
|
90
|
+
},
|
|
91
|
+
logging: {
|
|
92
|
+
level: 'error',
|
|
93
|
+
},
|
|
94
|
+
};
|
|
95
|
+
// Only add Redis config if REDIS_HOST is provided
|
|
96
|
+
if (process.env.REDIS_HOST) {
|
|
97
|
+
config.redis = {
|
|
98
|
+
host: process.env.REDIS_HOST,
|
|
99
|
+
port: parseInt(process.env.REDIS_PORT || '6379'),
|
|
100
|
+
keyPrefix: 'schema_gen:',
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
const db = await (0, index_1.createSmartDB)(config);
|
|
104
|
+
const tables = db.getDiscoveredTables();
|
|
105
|
+
console.log(`✅ Discovered ${tables.length} tables\n`);
|
|
106
|
+
// Generate schema
|
|
107
|
+
console.log('📝 Generating TypeScript schema...\n');
|
|
108
|
+
const schema = db.generateSchema({
|
|
109
|
+
interfaceName: options.interfaceName || 'DatabaseSchema',
|
|
110
|
+
includeComments: options.includeComments !== false,
|
|
111
|
+
nullableFields: true,
|
|
112
|
+
withExample: options.withExample || false,
|
|
113
|
+
});
|
|
114
|
+
// Determine output path
|
|
115
|
+
const outputPath = options.output || path.join(process.cwd(), 'db-schema.ts');
|
|
116
|
+
fs.writeFileSync(outputPath, schema);
|
|
117
|
+
console.log(`💾 Schema saved to: ${outputPath}\n`);
|
|
118
|
+
// Show preview
|
|
119
|
+
const lines = schema.split('\n');
|
|
120
|
+
console.log('📄 Preview (first 30 lines):');
|
|
121
|
+
console.log('─'.repeat(80));
|
|
122
|
+
console.log(lines.slice(0, 30).join('\n'));
|
|
123
|
+
if (lines.length > 30) {
|
|
124
|
+
console.log(`\n... (${lines.length - 30} more lines)`);
|
|
125
|
+
}
|
|
126
|
+
console.log('─'.repeat(80));
|
|
127
|
+
console.log('');
|
|
128
|
+
// Show usage
|
|
129
|
+
console.log('🚀 Next steps:\n');
|
|
130
|
+
console.log('1. Import and use in your code:\n');
|
|
131
|
+
console.log(' import { createSmartDB, SmartDBWithTables } from "@bhushanpawar/sqldb";');
|
|
132
|
+
console.log(' import { DatabaseSchema } from "./db-schema";\n');
|
|
133
|
+
console.log(' type DB = SmartDBWithTables<DatabaseSchema>;');
|
|
134
|
+
console.log(' const db = await createSmartDB(config) as DB;\n');
|
|
135
|
+
console.log(' // Full type safety!');
|
|
136
|
+
const sampleTables = tables.slice(0, 3);
|
|
137
|
+
for (const table of sampleTables) {
|
|
138
|
+
console.log(` const ${table} = await db.${table}.findMany();`);
|
|
139
|
+
}
|
|
140
|
+
console.log('');
|
|
141
|
+
await db.close();
|
|
142
|
+
}
|
|
143
|
+
catch (error) {
|
|
144
|
+
console.error('❌ Error:', error.message);
|
|
145
|
+
process.exit(1);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
async function main() {
|
|
149
|
+
const args = process.argv.slice(2);
|
|
150
|
+
const command = args[0];
|
|
151
|
+
if (!command || command === '--help' || command === '-h') {
|
|
152
|
+
console.log('');
|
|
153
|
+
console.log('SmartDB CLI - Database Schema Generator');
|
|
154
|
+
console.log('');
|
|
155
|
+
console.log('Usage:');
|
|
156
|
+
console.log(' npx @bhushanpawar/sqldb --generate-schema [options]');
|
|
157
|
+
console.log('');
|
|
158
|
+
console.log('Commands:');
|
|
159
|
+
console.log(' --generate-schema Generate TypeScript schema from database');
|
|
160
|
+
console.log('');
|
|
161
|
+
console.log('Options:');
|
|
162
|
+
console.log(' --output <path> Output file path (default: ./db-schema.ts)');
|
|
163
|
+
console.log(' --interface <name> Interface name (default: DatabaseSchema)');
|
|
164
|
+
console.log(' --no-comments Disable JSDoc comments');
|
|
165
|
+
console.log(' --with-example Include usage example');
|
|
166
|
+
console.log(' --help, -h Show this help message');
|
|
167
|
+
console.log('');
|
|
168
|
+
console.log('Environment Variables (.env file required):');
|
|
169
|
+
console.log(' DB_HOST MariaDB host (required)');
|
|
170
|
+
console.log(' DB_PORT MariaDB port (default: 3306)');
|
|
171
|
+
console.log(' DB_USER MariaDB user (required)');
|
|
172
|
+
console.log(' DB_PASSWORD MariaDB password');
|
|
173
|
+
console.log(' DB_DATABASE Database name (required)');
|
|
174
|
+
console.log(' REDIS_HOST Redis host (optional)');
|
|
175
|
+
console.log(' REDIS_PORT Redis port (default: 6379)');
|
|
176
|
+
console.log('');
|
|
177
|
+
console.log('Examples:');
|
|
178
|
+
console.log(' # Generate schema with defaults');
|
|
179
|
+
console.log(' npx @bhushanpawar/sqldb --generate-schema');
|
|
180
|
+
console.log('');
|
|
181
|
+
console.log(' # Generate with custom output path');
|
|
182
|
+
console.log(' npx @bhushanpawar/sqldb --generate-schema --output src/types/db.ts');
|
|
183
|
+
console.log('');
|
|
184
|
+
console.log(' # Generate with custom interface name and example');
|
|
185
|
+
console.log(' npx @bhushanpawar/sqldb --generate-schema --interface MyDB --with-example');
|
|
186
|
+
console.log('');
|
|
187
|
+
process.exit(0);
|
|
188
|
+
}
|
|
189
|
+
if (command === '--generate-schema') {
|
|
190
|
+
const options = {};
|
|
191
|
+
// Parse options
|
|
192
|
+
for (let i = 1; i < args.length; i++) {
|
|
193
|
+
const arg = args[i];
|
|
194
|
+
switch (arg) {
|
|
195
|
+
case '--output':
|
|
196
|
+
options.output = args[++i];
|
|
197
|
+
break;
|
|
198
|
+
case '--interface':
|
|
199
|
+
options.interfaceName = args[++i];
|
|
200
|
+
break;
|
|
201
|
+
case '--no-comments':
|
|
202
|
+
options.includeComments = false;
|
|
203
|
+
break;
|
|
204
|
+
case '--with-example':
|
|
205
|
+
options.withExample = true;
|
|
206
|
+
break;
|
|
207
|
+
default:
|
|
208
|
+
console.error(`Unknown option: ${arg}`);
|
|
209
|
+
console.error('Run with --help to see available options');
|
|
210
|
+
process.exit(1);
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
await generateSchema(options);
|
|
214
|
+
}
|
|
215
|
+
else {
|
|
216
|
+
console.error(`Unknown command: ${command}`);
|
|
217
|
+
console.error('Run with --help to see available commands');
|
|
218
|
+
process.exit(1);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
main().catch((error) => {
|
|
222
|
+
console.error('Fatal error:', error);
|
|
223
|
+
process.exit(1);
|
|
224
|
+
});
|
|
225
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { SmartDBClient } from '../client';
|
|
2
|
+
export interface GenerateSchemaOptions {
|
|
3
|
+
outputPath?: string;
|
|
4
|
+
interfaceName?: string;
|
|
5
|
+
includeComments?: boolean;
|
|
6
|
+
nullableFields?: boolean;
|
|
7
|
+
}
|
|
8
|
+
export declare class SchemaGenerator {
|
|
9
|
+
private client;
|
|
10
|
+
constructor(client: SmartDBClient);
|
|
11
|
+
/**
|
|
12
|
+
* Generate TypeScript interface from discovered schema
|
|
13
|
+
*/
|
|
14
|
+
generateTypeScriptInterface(options?: GenerateSchemaOptions): string;
|
|
15
|
+
/**
|
|
16
|
+
* Map SQL data types to TypeScript types
|
|
17
|
+
*/
|
|
18
|
+
private mapSQLTypeToTypeScript;
|
|
19
|
+
/**
|
|
20
|
+
* Generate schema with SmartDBWithTables type
|
|
21
|
+
*/
|
|
22
|
+
generateCompleteSchema(options?: GenerateSchemaOptions): string;
|
|
23
|
+
/**
|
|
24
|
+
* Generate schema with usage example
|
|
25
|
+
*/
|
|
26
|
+
generateWithExample(options?: GenerateSchemaOptions): string;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=schema-generator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema-generator.d.ts","sourceRoot":"","sources":["../../src/cli/schema-generator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAG1C,MAAM,WAAW,qBAAqB;IACpC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,cAAc,CAAC,EAAE,OAAO,CAAC;CAC1B;AAED,qBAAa,eAAe;IAC1B,OAAO,CAAC,MAAM,CAAgB;gBAElB,MAAM,EAAE,aAAa;IAIjC;;OAEG;IACH,2BAA2B,CAAC,OAAO,GAAE,qBAA0B,GAAG,MAAM;IA8FxE;;OAEG;IACH,OAAO,CAAC,sBAAsB;IAwC9B;;OAEG;IACH,sBAAsB,CAAC,OAAO,GAAE,qBAA0B,GAAG,MAAM;IAenE;;OAEG;IACH,mBAAmB,CAAC,OAAO,GAAE,qBAA0B,GAAG,MAAM;CA0BjE"}
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SchemaGenerator = void 0;
|
|
4
|
+
class SchemaGenerator {
|
|
5
|
+
constructor(client) {
|
|
6
|
+
this.client = client;
|
|
7
|
+
}
|
|
8
|
+
/**
|
|
9
|
+
* Generate TypeScript interface from discovered schema
|
|
10
|
+
*/
|
|
11
|
+
generateTypeScriptInterface(options = {}) {
|
|
12
|
+
const { interfaceName = 'DatabaseSchema', includeComments = true, nullableFields = true, } = options;
|
|
13
|
+
const tables = this.client.getDiscoveredTables();
|
|
14
|
+
const lines = [];
|
|
15
|
+
// Add header comment
|
|
16
|
+
if (includeComments) {
|
|
17
|
+
lines.push('/**');
|
|
18
|
+
lines.push(' * Auto-generated database schema');
|
|
19
|
+
lines.push(` * Generated on: ${new Date().toISOString()}`);
|
|
20
|
+
lines.push(` * Total tables: ${tables.length}`);
|
|
21
|
+
lines.push(' */');
|
|
22
|
+
}
|
|
23
|
+
// Start interface
|
|
24
|
+
lines.push(`export interface ${interfaceName} {`);
|
|
25
|
+
// Generate type for each table
|
|
26
|
+
for (const tableName of tables.sort()) {
|
|
27
|
+
const schema = this.client.getTableSchema(tableName);
|
|
28
|
+
if (!schema) {
|
|
29
|
+
continue;
|
|
30
|
+
}
|
|
31
|
+
if (includeComments) {
|
|
32
|
+
lines.push(` /**`);
|
|
33
|
+
lines.push(` * Table: ${tableName}`);
|
|
34
|
+
if (schema.primaryKey) {
|
|
35
|
+
lines.push(` * Primary key: ${schema.primaryKey}`);
|
|
36
|
+
}
|
|
37
|
+
lines.push(` */`);
|
|
38
|
+
}
|
|
39
|
+
lines.push(` ${tableName}: {`);
|
|
40
|
+
// Generate fields
|
|
41
|
+
for (const column of schema.columns) {
|
|
42
|
+
const tsType = this.mapSQLTypeToTypeScript(column.dataType);
|
|
43
|
+
const nullable = nullableFields && column.isNullable ? ' | null' : '';
|
|
44
|
+
const optional = column.isNullable ? '?' : '';
|
|
45
|
+
if (includeComments) {
|
|
46
|
+
const commentParts = [];
|
|
47
|
+
// Add column type
|
|
48
|
+
commentParts.push(`@type ${column.columnType}`);
|
|
49
|
+
// Add character max length
|
|
50
|
+
if (column.characterMaximumLength) {
|
|
51
|
+
commentParts.push(`@maxLength ${column.characterMaximumLength}`);
|
|
52
|
+
}
|
|
53
|
+
// Add numeric precision and scale
|
|
54
|
+
if (column.numericPrecision !== null && column.numericPrecision !== undefined) {
|
|
55
|
+
if (column.numericScale !== null && column.numericScale !== undefined) {
|
|
56
|
+
commentParts.push(`@precision ${column.numericPrecision},${column.numericScale}`);
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
commentParts.push(`@precision ${column.numericPrecision}`);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
// Add default value
|
|
63
|
+
if (column.columnDefault !== null) {
|
|
64
|
+
commentParts.push(`@default ${column.columnDefault}`);
|
|
65
|
+
}
|
|
66
|
+
// Add extra info (auto_increment, etc.)
|
|
67
|
+
if (column.extra) {
|
|
68
|
+
commentParts.push(`@extra ${column.extra}`);
|
|
69
|
+
}
|
|
70
|
+
if (commentParts.length > 0) {
|
|
71
|
+
lines.push(` /** ${commentParts.join(' | ')} */`);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
lines.push(` ${column.columnName}${optional}: ${tsType}${nullable};`);
|
|
75
|
+
}
|
|
76
|
+
lines.push(` };`);
|
|
77
|
+
lines.push('');
|
|
78
|
+
}
|
|
79
|
+
lines.push('}');
|
|
80
|
+
return lines.join('\n');
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Map SQL data types to TypeScript types
|
|
84
|
+
*/
|
|
85
|
+
mapSQLTypeToTypeScript(sqlType) {
|
|
86
|
+
const type = sqlType.toLowerCase();
|
|
87
|
+
// UUID types
|
|
88
|
+
if (type.includes('uuid')) {
|
|
89
|
+
return 'string';
|
|
90
|
+
}
|
|
91
|
+
// Numeric types
|
|
92
|
+
if (type.includes('int') || type.includes('decimal') || type.includes('float') ||
|
|
93
|
+
type.includes('double') || type.includes('numeric')) {
|
|
94
|
+
return 'number';
|
|
95
|
+
}
|
|
96
|
+
// String types
|
|
97
|
+
if (type.includes('char') || type.includes('text') || type.includes('varchar') ||
|
|
98
|
+
type.includes('binary') || type.includes('blob') || type.includes('enum') ||
|
|
99
|
+
type.includes('set')) {
|
|
100
|
+
return 'string';
|
|
101
|
+
}
|
|
102
|
+
// Date/Time types
|
|
103
|
+
if (type.includes('date') || type.includes('time') || type.includes('year')) {
|
|
104
|
+
return 'Date';
|
|
105
|
+
}
|
|
106
|
+
// Boolean
|
|
107
|
+
if (type.includes('bool') || type.includes('bit')) {
|
|
108
|
+
return 'boolean';
|
|
109
|
+
}
|
|
110
|
+
// JSON
|
|
111
|
+
if (type.includes('json')) {
|
|
112
|
+
return 'any';
|
|
113
|
+
}
|
|
114
|
+
// Default to any for unknown types
|
|
115
|
+
return 'any';
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Generate schema with SmartDBWithTables type
|
|
119
|
+
*/
|
|
120
|
+
generateCompleteSchema(options = {}) {
|
|
121
|
+
const interfaceName = options.interfaceName || 'DatabaseSchema';
|
|
122
|
+
const interfaceCode = this.generateTypeScriptInterface(options);
|
|
123
|
+
const lines = [];
|
|
124
|
+
lines.push("import { SmartDBWithTables } from '@bhushanpawar/sqldb';");
|
|
125
|
+
lines.push('');
|
|
126
|
+
lines.push(interfaceCode);
|
|
127
|
+
lines.push('');
|
|
128
|
+
lines.push(`// Type for your database client`);
|
|
129
|
+
lines.push(`export type DB = SmartDBWithTables<${interfaceName}>;`);
|
|
130
|
+
return lines.join('\n');
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Generate schema with usage example
|
|
134
|
+
*/
|
|
135
|
+
generateWithExample(options = {}) {
|
|
136
|
+
const schemaCode = this.generateCompleteSchema(options);
|
|
137
|
+
const lines = [];
|
|
138
|
+
lines.push(schemaCode);
|
|
139
|
+
lines.push('');
|
|
140
|
+
lines.push('/**');
|
|
141
|
+
lines.push(' * Usage example:');
|
|
142
|
+
lines.push(' *');
|
|
143
|
+
lines.push(" * import { createSmartDB } from '@bhushanpawar/sqldb';");
|
|
144
|
+
lines.push(' * import { DB } from "./db-schema";');
|
|
145
|
+
lines.push(' *');
|
|
146
|
+
lines.push(' * const db = await createSmartDB(config) as DB;');
|
|
147
|
+
lines.push(' *');
|
|
148
|
+
lines.push(' * // Now you have full type safety:');
|
|
149
|
+
// Add example for first few tables
|
|
150
|
+
const tables = this.client.getDiscoveredTables().slice(0, 3);
|
|
151
|
+
for (const tableName of tables) {
|
|
152
|
+
lines.push(` * const ${tableName} = await db.${tableName}.findMany();`);
|
|
153
|
+
}
|
|
154
|
+
lines.push(' */');
|
|
155
|
+
return lines.join('\n');
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
exports.SchemaGenerator = SchemaGenerator;
|
|
159
|
+
//# sourceMappingURL=schema-generator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema-generator.js","sourceRoot":"","sources":["../../src/cli/schema-generator.ts"],"names":[],"mappings":"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"}
|
package/dist/client.d.ts
CHANGED
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import { SmartDBConfig } from './types/config';
|
|
2
2
|
import { TableOperations, QueryMetadata } from './types/query';
|
|
3
|
+
import { TableSchema } from './types/schema';
|
|
3
4
|
import { DependencyGraph } from './discovery/dependency-graph';
|
|
4
5
|
import { CacheManager } from './cache/cache-manager';
|
|
5
6
|
import { InvalidationManager } from './cache/invalidation';
|
|
6
7
|
import { HooksManager } from './hooks/hooks-manager';
|
|
7
8
|
import { InMemoryQueryTracker } from './query/query-tracker';
|
|
9
|
+
import { WarmingStats } from './types/warming';
|
|
8
10
|
export declare class SmartDBClient {
|
|
9
11
|
private config;
|
|
10
12
|
private dbManager;
|
|
@@ -16,8 +18,11 @@ export declare class SmartDBClient {
|
|
|
16
18
|
private tableProxyFactory;
|
|
17
19
|
hooks: HooksManager;
|
|
18
20
|
queryTracker: InMemoryQueryTracker;
|
|
21
|
+
private statsTracker?;
|
|
22
|
+
private warmingManager?;
|
|
19
23
|
private initialized;
|
|
20
24
|
private discoveredTables;
|
|
25
|
+
private tableSchemas;
|
|
21
26
|
constructor(config: SmartDBConfig);
|
|
22
27
|
initialize(): Promise<void>;
|
|
23
28
|
private discoverSchema;
|
|
@@ -27,6 +32,7 @@ export declare class SmartDBClient {
|
|
|
27
32
|
getInvalidationManager(): InvalidationManager;
|
|
28
33
|
getDependencyGraph(): DependencyGraph;
|
|
29
34
|
getDiscoveredTables(): string[];
|
|
35
|
+
getTableSchema(tableName: string): TableSchema | undefined;
|
|
30
36
|
getQueries(correlationId?: string): QueryMetadata[];
|
|
31
37
|
clearQueries(correlationId?: string): void;
|
|
32
38
|
healthCheck(): Promise<{
|
|
@@ -34,7 +40,33 @@ export declare class SmartDBClient {
|
|
|
34
40
|
redis: boolean;
|
|
35
41
|
overall: boolean;
|
|
36
42
|
}>;
|
|
43
|
+
/**
|
|
44
|
+
* Generate TypeScript interface from database schema
|
|
45
|
+
*/
|
|
46
|
+
generateSchema(options?: {
|
|
47
|
+
interfaceName?: string;
|
|
48
|
+
includeComments?: boolean;
|
|
49
|
+
nullableFields?: boolean;
|
|
50
|
+
withExample?: boolean;
|
|
51
|
+
}): string;
|
|
37
52
|
close(): Promise<void>;
|
|
53
|
+
/**
|
|
54
|
+
* Get auto-warming statistics
|
|
55
|
+
*/
|
|
56
|
+
getWarmingStats(): WarmingStats | null;
|
|
57
|
+
/**
|
|
58
|
+
* Manually trigger cache warming
|
|
59
|
+
*/
|
|
60
|
+
warmCache(): Promise<WarmingStats | undefined>;
|
|
61
|
+
/**
|
|
62
|
+
* Get query statistics summary
|
|
63
|
+
*/
|
|
64
|
+
getQueryStatsSummary(): Promise<{
|
|
65
|
+
totalQueries: number;
|
|
66
|
+
totalAccesses: number;
|
|
67
|
+
tableCount: number;
|
|
68
|
+
avgAccessCount: number;
|
|
69
|
+
} | null>;
|
|
38
70
|
private log;
|
|
39
71
|
}
|
|
40
72
|
//# sourceMappingURL=client.d.ts.map
|
package/dist/client.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EAKd,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAK7C,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAI3D,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAG7D,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,qBAAa,aAAa;IACxB,OAAO,CAAC,MAAM,CAAgB;IAC9B,OAAO,CAAC,SAAS,CAA4B;IAC7C,OAAO,CAAC,YAAY,CAA0B;IAC9C,OAAO,CAAC,YAAY,CAAgB;IACpC,OAAO,CAAC,mBAAmB,CAAuB;IAClD,OAAO,CAAC,eAAe,CAAmB;IAC1C,OAAO,CAAC,YAAY,CAAgB;IACpC,OAAO,CAAC,iBAAiB,CAAqB;IACvC,KAAK,EAAG,YAAY,CAAC;IACrB,YAAY,EAAE,oBAAoB,CAAC;IAG1C,OAAO,CAAC,YAAY,CAAC,CAAoB;IACzC,OAAO,CAAC,cAAc,CAAC,CAAqB;IAE5C,OAAO,CAAC,WAAW,CAAkB;IACrC,OAAO,CAAC,gBAAgB,CAA0B;IAClD,OAAO,CAAC,YAAY,CAAuC;gBAE/C,MAAM,EAAE,aAAa;IAW3B,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;YAwEnB,cAAc;IA6BtB,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;IAYpC,kBAAkB,CAAC,CAAC,GAAG,GAAG,EAAE,SAAS,EAAE,MAAM,GAAG,eAAe,CAAC,CAAC,CAAC;IAiBlE,eAAe,IAAI,YAAY;IAI/B,sBAAsB,IAAI,mBAAmB;IAI7C,kBAAkB,IAAI,eAAe;IAIrC,mBAAmB,IAAI,MAAM,EAAE;IAI/B,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,WAAW,GAAG,SAAS;IAI1D,UAAU,CAAC,aAAa,CAAC,EAAE,MAAM,GAAG,aAAa,EAAE;IAInD,YAAY,CAAC,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI;IAIpC,WAAW,IAAI,OAAO,CAAC;QAC3B,OAAO,EAAE,OAAO,CAAC;QACjB,KAAK,EAAE,OAAO,CAAC;QACf,OAAO,EAAE,OAAO,CAAC;KAClB,CAAC;IAWF;;OAEG;IACH,cAAc,CAAC,OAAO,CAAC,EAAE;QACvB,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,eAAe,CAAC,EAAE,OAAO,CAAC;QAC1B,cAAc,CAAC,EAAE,OAAO,CAAC;QACzB,WAAW,CAAC,EAAE,OAAO,CAAC;KACvB,GAAG,MAAM;IAWJ,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAiB5B;;OAEG;IACH,eAAe,IAAI,YAAY,GAAG,IAAI;IAItC;;OAEG;IACG,SAAS,IAAI,OAAO,CAAC,YAAY,GAAG,SAAS,CAAC;IAOpD;;OAEG;IACG,oBAAoB,IAAI,OAAO,CAAC;QACpC,YAAY,EAAE,MAAM,CAAC;QACrB,aAAa,EAAE,MAAM,CAAC;QACtB,UAAU,EAAE,MAAM,CAAC;QACnB,cAAc,EAAE,MAAM,CAAC;KACxB,GAAG,IAAI,CAAC;IAOT,OAAO,CAAC,GAAG;CAKZ"}
|