@cheetah.js/cli 0.1.31 → 0.1.32

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.
@@ -0,0 +1,443 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.Migrator = void 0;
40
+ const core_1 = require("@cheetah.js/core");
41
+ const orm_1 = require("@cheetah.js/orm");
42
+ const orm_2 = require("@cheetah.js/orm");
43
+ const globby_1 = __importDefault(require("globby"));
44
+ const knex = __importStar(require("knex"));
45
+ const diff_calculator_1 = require("./diff-calculator");
46
+ const snapshot_manager_1 = require("./snapshot-manager");
47
+ const path = __importStar(require("path"));
48
+ const fs = __importStar(require("fs"));
49
+ class Migrator {
50
+ constructor() {
51
+ this.entities = new orm_2.EntityStorage();
52
+ this.orm = orm_1.Orm.getInstance();
53
+ if (this.orm === undefined)
54
+ this.orm = new orm_1.Orm(new core_1.LoggerService(new core_1.InjectorService()));
55
+ this.entities = orm_2.EntityStorage.getInstance();
56
+ if (this.entities === undefined)
57
+ this.entities = new orm_2.EntityStorage();
58
+ }
59
+ async startConnection(basePath = process.cwd()) {
60
+ await this.initConfigFile(basePath);
61
+ await this.initKnex();
62
+ }
63
+ async initConfigFile(basePath) {
64
+ const paths = await (0, globby_1.default)(['cheetah.config.ts'], {
65
+ absolute: true,
66
+ cwd: basePath,
67
+ });
68
+ if (paths.length === 0) {
69
+ throw new Error('Config file not found');
70
+ }
71
+ const dynamicImport = new Function('specifier', 'return import(specifier)');
72
+ const config = await dynamicImport(paths[0]);
73
+ this.config = config.default;
74
+ if (typeof this.config.entities === 'string') {
75
+ const paths = await (0, globby_1.default)(this.config.entities, {
76
+ absolute: true,
77
+ cwd: basePath,
78
+ });
79
+ for (const path of paths) {
80
+ console.log(`Importing entity from: ${path}`);
81
+ await dynamicImport(path);
82
+ }
83
+ }
84
+ await this.initOrm();
85
+ }
86
+ async initOrm() {
87
+ if (this.orm.driverInstance) {
88
+ try {
89
+ await this.orm.driverInstance.executeSql('SELECT 1');
90
+ return;
91
+ }
92
+ catch (error) {
93
+ }
94
+ }
95
+ const serv = new orm_1.OrmService(this.orm, this.entities);
96
+ await serv.onInit(this.config);
97
+ }
98
+ initKnex() {
99
+ if (this.knex) {
100
+ return;
101
+ }
102
+ this.knex = knex.default({
103
+ client: this.config.driver === orm_1.BunPgDriver ? 'pg' : 'mysql',
104
+ connection: {
105
+ host: this.config.host,
106
+ user: this.config.username,
107
+ password: this.config.password,
108
+ database: this.config.database,
109
+ uri: this.config.connectionString,
110
+ },
111
+ debug: true,
112
+ });
113
+ }
114
+ async run(diff) {
115
+ const sql = [];
116
+ for (const tableDiff of diff) {
117
+ let query;
118
+ if (tableDiff.newTable) {
119
+ query = await this.createTable(tableDiff);
120
+ }
121
+ else {
122
+ query = this.knex.schema
123
+ .withSchema(tableDiff.schema)
124
+ .table(tableDiff.tableName, (builder) => {
125
+ for (const colDiff of tableDiff.colDiffs) {
126
+ if (colDiff.actionType === 'INDEX') {
127
+ colDiff.indexTables.forEach((indexTable) => {
128
+ if (typeof indexTable.properties === 'undefined') {
129
+ builder.dropIndex([], indexTable.name);
130
+ }
131
+ else {
132
+ builder.index(indexTable.properties, indexTable.name);
133
+ }
134
+ });
135
+ }
136
+ if (colDiff.actionType === 'DELETE') {
137
+ builder.dropColumn(colDiff.colName);
138
+ continue;
139
+ }
140
+ if (colDiff.actionType === 'ALTER' &&
141
+ !colDiff.colType &&
142
+ typeof colDiff.colChanges === 'undefined')
143
+ continue;
144
+ if (typeof colDiff.colChanges?.unique !== 'undefined') {
145
+ if (colDiff.colChanges?.unique) {
146
+ builder.unique([colDiff.colName], `${tableDiff.tableName}_${colDiff.colName}_key`);
147
+ }
148
+ else {
149
+ builder.dropUnique([colDiff.colName], `${tableDiff.tableName}_${colDiff.colName}_key`);
150
+ }
151
+ }
152
+ if (typeof colDiff.colChanges?.foreignKeys !== 'undefined') {
153
+ if (colDiff.colChanges.foreignKeys.length !== 0) {
154
+ colDiff.colChanges.foreignKeys.forEach((fk) => {
155
+ builder
156
+ .foreign(colDiff.colName, `${tableDiff.tableName}_${colDiff.colName}_fk`)
157
+ .references(`${fk.referencedTableName}.${fk.referencedColumnName}`);
158
+ });
159
+ }
160
+ else {
161
+ builder.dropForeign(colDiff.colName, `${tableDiff.tableName}_${colDiff.colName}_fk`);
162
+ }
163
+ }
164
+ const columnBuilder = this.assignType(builder, colDiff, tableDiff);
165
+ if (!columnBuilder)
166
+ continue;
167
+ if (colDiff.actionType === 'ALTER') {
168
+ columnBuilder.alter({ alterNullable: false });
169
+ continue;
170
+ }
171
+ }
172
+ })
173
+ .toSQL();
174
+ }
175
+ sql.push(...query.flatMap((q) => q.sql.concat(';')));
176
+ }
177
+ return sql;
178
+ }
179
+ async createTable(tableDiff) {
180
+ return await this.knex.schema
181
+ .withSchema(tableDiff.schema)
182
+ .createTable(tableDiff.tableName, (builder) => {
183
+ for (const diff of tableDiff.colDiffs) {
184
+ if (diff.actionType === 'INDEX') {
185
+ diff.indexTables.forEach((indexTable) => {
186
+ if (typeof indexTable.properties === 'undefined') {
187
+ builder.dropIndex([], indexTable.name);
188
+ }
189
+ else {
190
+ if (indexTable.name.includes('pkey')) {
191
+ return;
192
+ }
193
+ builder.index(indexTable.properties, indexTable.name);
194
+ }
195
+ });
196
+ }
197
+ if (typeof diff.colChanges?.foreignKeys !== 'undefined') {
198
+ if (diff.colChanges.foreignKeys.length !== 0) {
199
+ diff.colChanges.foreignKeys.forEach((fk) => {
200
+ builder
201
+ .foreign(diff.colName, `${tableDiff.tableName}_${diff.colName}_fk`)
202
+ .references(`${fk.referencedTableName}.${fk.referencedColumnName}`);
203
+ });
204
+ }
205
+ else {
206
+ builder.dropForeign(diff.colName, `${tableDiff.tableName}_${diff.colName}_fk`);
207
+ }
208
+ }
209
+ this.assignType(builder, diff, tableDiff);
210
+ if (typeof diff.colChanges?.unique !== 'undefined') {
211
+ if (diff.colChanges?.unique) {
212
+ builder.unique([diff.colName], `${tableDiff.tableName}_${diff.colName}_key`);
213
+ }
214
+ else {
215
+ builder.dropUnique([diff.colName], `${tableDiff.tableName}_${diff.colName}_key`);
216
+ }
217
+ }
218
+ }
219
+ })
220
+ .toSQL();
221
+ }
222
+ assignType(builder, diff, tableDiff) {
223
+ if (diff.actionType === 'ALTER') {
224
+ if (diff.colChanges?.nullable !== undefined) {
225
+ if (diff.colChanges?.nullable) {
226
+ builder.setNullable(diff.colName);
227
+ }
228
+ }
229
+ }
230
+ if (!diff.colType)
231
+ return;
232
+ const columnName = diff.colName;
233
+ const columnType = diff.colType;
234
+ let columnBuilder;
235
+ if (diff.colChanges?.autoIncrement !== undefined) {
236
+ if (diff.colChanges?.autoIncrement) {
237
+ columnBuilder = builder.increments(diff.colName, {
238
+ primaryKey: diff.colChanges?.primary,
239
+ });
240
+ }
241
+ }
242
+ else {
243
+ switch (columnType) {
244
+ case 'varchar':
245
+ columnBuilder = builder.string(columnName, diff.colLength);
246
+ break;
247
+ case 'text':
248
+ columnBuilder = builder.text(columnName);
249
+ break;
250
+ case 'int':
251
+ case 'numeric':
252
+ case 'integer':
253
+ columnBuilder = builder.integer(columnName, diff.colLength);
254
+ break;
255
+ case 'bigint':
256
+ columnBuilder = builder.bigInteger(columnName);
257
+ break;
258
+ case 'double':
259
+ case 'float4':
260
+ case 'float':
261
+ case 'decimal':
262
+ columnBuilder = builder.decimal(columnName, diff.colChanges?.precision, diff.colChanges?.scale);
263
+ break;
264
+ case 'date':
265
+ columnBuilder = builder.date(columnName);
266
+ break;
267
+ case 'datetime':
268
+ columnBuilder = builder.datetime(columnName);
269
+ break;
270
+ case 'time':
271
+ columnBuilder = builder.time(columnName);
272
+ break;
273
+ case 'timestamp':
274
+ columnBuilder = builder.timestamp(columnName, {
275
+ precision: diff.colLength,
276
+ });
277
+ break;
278
+ case 'boolean':
279
+ columnBuilder = builder.boolean(columnName);
280
+ break;
281
+ case 'json':
282
+ columnBuilder = builder.json(columnName);
283
+ break;
284
+ case 'jsonb':
285
+ columnBuilder = builder.jsonb(columnName);
286
+ break;
287
+ case 'enum':
288
+ if (diff.actionType === 'ALTER' && diff.colChanges?.enumItems) {
289
+ columnBuilder = builder
290
+ .text(columnName)
291
+ .checkIn(diff.colChanges.enumItems ?? [], `${columnName}_check`);
292
+ }
293
+ else {
294
+ columnBuilder = builder.enum(columnName, diff.colChanges.enumItems ?? []);
295
+ }
296
+ break;
297
+ case 'array':
298
+ columnBuilder = builder.specificType(columnName, 'text[]');
299
+ break;
300
+ case 'uuid':
301
+ columnBuilder = builder.uuid(columnName);
302
+ break;
303
+ default:
304
+ columnBuilder = builder.string(columnName, diff.colLength);
305
+ break;
306
+ }
307
+ }
308
+ columnBuilder.notNullable();
309
+ if (diff.colChanges?.nullable !== undefined) {
310
+ if (diff.colChanges?.nullable) {
311
+ columnBuilder.nullable();
312
+ }
313
+ }
314
+ if (diff.colChanges?.default) {
315
+ columnBuilder.defaultTo(diff.colChanges?.default);
316
+ }
317
+ if (typeof diff.colChanges?.primary !== 'undefined') {
318
+ if (diff.colChanges?.primary) {
319
+ columnBuilder.primary();
320
+ }
321
+ else {
322
+ builder.dropPrimary();
323
+ }
324
+ }
325
+ return columnBuilder;
326
+ }
327
+ async migrate() {
328
+ await this.startConnection();
329
+ const migrationTable = 'cheetah_migrations';
330
+ const migrationDirectory = path.join(process.cwd(), this.config.migrationPath ?? 'database/migrations');
331
+ const migrationFiles = fs
332
+ .readdirSync(migrationDirectory)
333
+ .filter((file) => file.endsWith('.sql'))
334
+ .sort();
335
+ if (migrationFiles.length === 0) {
336
+ this.orm.logger.info('No migration files found');
337
+ return;
338
+ }
339
+ this.orm.driverInstance.executeSql(`CREATE TABLE IF NOT EXISTS "${migrationTable}" ("migration_file" character varying(255) NOT NULL PRIMARY KEY UNIQUE);`);
340
+ const migrated = await this.orm.driverInstance.executeSql(`SELECT * FROM "${migrationTable}" ORDER BY "migration_file" ASC;`);
341
+ const lastMigration = migrated.rows[migrated.rows.length - 1];
342
+ const lastMigrationIndex = migrationFiles.indexOf(lastMigration?.migration_file ?? '');
343
+ const migrationsToExecute = migrationFiles.slice(lastMigrationIndex + 1);
344
+ if (migrationsToExecute.length === 0) {
345
+ this.orm.logger.info('Database is up to date');
346
+ return;
347
+ }
348
+ for (const migrationFile of migrationsToExecute) {
349
+ const migrationFilePath = path.join(migrationDirectory, migrationFile);
350
+ const migrationContent = fs.readFileSync(migrationFilePath, {
351
+ encoding: 'utf-8',
352
+ });
353
+ const sqlInstructions = migrationContent
354
+ .split(';')
355
+ .filter((sql) => sql.trim().length > 0);
356
+ for (const sqlInstruction of sqlInstructions) {
357
+ await this.orm.driverInstance.executeSql(sqlInstruction);
358
+ }
359
+ await this.orm.driverInstance.executeSql(`INSERT INTO "${migrationTable}" ("migration_file") VALUES ('${migrationFile}');`);
360
+ this.orm.logger.info(`Migration executed: ${migrationFile}`);
361
+ }
362
+ }
363
+ async generateMigration(configFile = process.cwd(), onlySql = false) {
364
+ await this.startConnection(configFile);
365
+ const directory = path.join(process.cwd(), this.config.migrationPath ?? 'database/migrations');
366
+ const snapshotManager = new snapshot_manager_1.SnapshotManager(directory);
367
+ const snapshotEntities = await this.snapshotEntities();
368
+ let previousSnapshot = snapshotManager.loadSnapshot();
369
+ if (!previousSnapshot) {
370
+ previousSnapshot = await this.snapshotBd();
371
+ }
372
+ const calculator = new diff_calculator_1.DiffCalculator(this.entities, this.orm.driverInstance);
373
+ const diff = calculator.diff(previousSnapshot, snapshotEntities);
374
+ const sql = this.lastTreatment(await this.run(diff));
375
+ if (onlySql) {
376
+ return sql;
377
+ }
378
+ const fileName = `migration_${new Date().toISOString().replace(/[^\d]/g, '')}` + `.sql`;
379
+ const migrationFilePath = path.join(directory, fileName);
380
+ if (!fs.existsSync(directory)) {
381
+ fs.mkdirSync(directory, { recursive: true });
382
+ }
383
+ const migrationContent = sql.join('\n');
384
+ if (migrationContent.length === 0) {
385
+ this.orm.logger.info('No changes detected');
386
+ return;
387
+ }
388
+ else {
389
+ fs.writeFileSync(migrationFilePath, migrationContent);
390
+ this.orm.logger.info(`Migration file created: ${migrationFilePath}`);
391
+ snapshotManager.saveSnapshot(snapshotEntities);
392
+ this.orm.logger.info(`Snapshot updated: ${snapshotManager.getSnapshotPath()}`);
393
+ }
394
+ }
395
+ lastTreatment(sql) {
396
+ const getDropIndexes = sql.filter((s) => s.startsWith('drop index'));
397
+ const getDropColumns = sql.filter((s) => s.includes('drop column'));
398
+ const dropIndexes = [];
399
+ for (const dropIndex of getDropIndexes) {
400
+ const indexName = dropIndex.split(' ')[2].split('_');
401
+ let colName;
402
+ if (indexName.length === 3) {
403
+ colName = indexName[1];
404
+ }
405
+ else {
406
+ colName = indexName[0];
407
+ }
408
+ colName = colName.split('.')[1].replace(/"/g, '');
409
+ const dropColumn = getDropColumns.find((s) => s.includes(colName));
410
+ if (dropColumn) {
411
+ dropIndexes.push(dropIndex);
412
+ }
413
+ }
414
+ const sqlFiltered = sql.filter((s) => !dropIndexes.includes(s));
415
+ return sqlFiltered;
416
+ }
417
+ async snapshotBd() {
418
+ const snapshot = [];
419
+ for (const [_, values] of this.entities.entries()) {
420
+ const bd = await this.orm.driverInstance.snapshot(values.tableName);
421
+ if (!bd) {
422
+ continue;
423
+ }
424
+ snapshot.push(bd);
425
+ }
426
+ return snapshot;
427
+ }
428
+ async snapshotEntities() {
429
+ const snapshot = [];
430
+ for (const [_, values] of this.entities.entries()) {
431
+ snapshot.push(await this.entities.snapshot(values));
432
+ }
433
+ return snapshot;
434
+ }
435
+ async destroy() {
436
+ if (this.knex) {
437
+ await this.knex.destroy();
438
+ this.knex = null;
439
+ }
440
+ }
441
+ }
442
+ exports.Migrator = Migrator;
443
+ //# sourceMappingURL=migrator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"migrator.js","sourceRoot":"","sources":["../../../src/migrator/migrator.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import { SnapshotTable } from './migrator';
2
+ export declare class SnapshotManager {
3
+ private migrationPath;
4
+ private snapshotFileName;
5
+ constructor(migrationPath: string);
6
+ getSnapshotPath(): string;
7
+ loadSnapshot(): SnapshotTable[] | null;
8
+ saveSnapshot(snapshot: SnapshotTable[]): void;
9
+ snapshotExists(): boolean;
10
+ }
@@ -0,0 +1,74 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.SnapshotManager = void 0;
37
+ const fs = __importStar(require("fs"));
38
+ const path = __importStar(require("path"));
39
+ class SnapshotManager {
40
+ constructor(migrationPath) {
41
+ this.migrationPath = migrationPath;
42
+ this.snapshotFileName = 'schema-snapshot.json';
43
+ }
44
+ getSnapshotPath() {
45
+ return path.join(this.migrationPath, this.snapshotFileName);
46
+ }
47
+ loadSnapshot() {
48
+ const snapshotPath = this.getSnapshotPath();
49
+ if (!fs.existsSync(snapshotPath)) {
50
+ return null;
51
+ }
52
+ try {
53
+ const content = fs.readFileSync(snapshotPath, 'utf-8');
54
+ return JSON.parse(content);
55
+ }
56
+ catch (error) {
57
+ console.warn(`Failed to load snapshot: ${error.message}`);
58
+ return null;
59
+ }
60
+ }
61
+ saveSnapshot(snapshot) {
62
+ const snapshotPath = this.getSnapshotPath();
63
+ const directory = path.dirname(snapshotPath);
64
+ if (!fs.existsSync(directory)) {
65
+ fs.mkdirSync(directory, { recursive: true });
66
+ }
67
+ fs.writeFileSync(snapshotPath, JSON.stringify(snapshot, null, 2), 'utf-8');
68
+ }
69
+ snapshotExists() {
70
+ return fs.existsSync(this.getSnapshotPath());
71
+ }
72
+ }
73
+ exports.SnapshotManager = SnapshotManager;
74
+ //# sourceMappingURL=snapshot-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"snapshot-manager.js","sourceRoot":"","sources":["../../../src/migrator/snapshot-manager.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,uCAAyB;AACzB,2CAA6B;AAG7B,MAAa,eAAe;IAG1B,YAAoB,aAAqB;QAArB,kBAAa,GAAb,aAAa,CAAQ;QAFjC,qBAAgB,GAAG,sBAAsB,CAAC;IAEN,CAAC;IAE7C,eAAe;QACb,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAC9D,CAAC;IAED,YAAY;QACV,MAAM,YAAY,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QAE5C,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE,CAAC;YACjC,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;YACvD,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAC7B,CAAC;QAAC,OAAO,KAAU,EAAE,CAAC;YACpB,OAAO,CAAC,IAAI,CAAC,4BAA4B,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;YAC1D,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAED,YAAY,CAAC,QAAyB;QACpC,MAAM,YAAY,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QAC5C,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QAE7C,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;YAC9B,EAAE,CAAC,SAAS,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAC/C,CAAC;QAED,EAAE,CAAC,aAAa,CAAC,YAAY,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;IAC7E,CAAC;IAED,cAAc;QACZ,OAAO,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;IAC/C,CAAC;CACF;AAvCD,0CAuCC"}
@@ -0,0 +1,8 @@
1
+ import { LoggerService } from '@cheetah.js/core';
2
+ import { BunPgDriver, Orm } from '@cheetah.js/orm';
3
+ export declare let app: Orm<BunPgDriver>;
4
+ export declare const mockLogger: import("bun:test").Mock<(message: string, ...args: any[]) => void>;
5
+ export declare function startDatabase(entityFile?: string | undefined, logger?: LoggerService): Promise<void>;
6
+ export declare function purgeDatabase(schema?: string): Promise<void>;
7
+ export declare function cleanupDatabase(): Promise<void>;
8
+ export declare function execute(sql: string): Promise<any>;
@@ -0,0 +1,66 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.mockLogger = exports.app = void 0;
4
+ exports.startDatabase = startDatabase;
5
+ exports.purgeDatabase = purgeDatabase;
6
+ exports.cleanupDatabase = cleanupDatabase;
7
+ exports.execute = execute;
8
+ const core_1 = require("@cheetah.js/core");
9
+ const orm_1 = require("@cheetah.js/orm");
10
+ const bun_test_1 = require("bun:test");
11
+ const loggerInstance = new core_1.LoggerService({
12
+ applicationConfig: { logger: { level: 'info' } },
13
+ });
14
+ exports.app = orm_1.Orm.getInstance();
15
+ exports.mockLogger = (0, bun_test_1.spyOn)(loggerInstance, 'debug');
16
+ async function startDatabase(entityFile = undefined, logger = loggerInstance) {
17
+ const instance = orm_1.Orm.getInstance();
18
+ if (instance) {
19
+ exports.app = instance;
20
+ await exports.app.connect();
21
+ return;
22
+ }
23
+ console.log('Starting database...');
24
+ exports.app = new orm_1.Orm(logger);
25
+ await service.onInit({
26
+ host: 'localhost',
27
+ port: 5432,
28
+ database: 'postgres',
29
+ username: 'postgres',
30
+ password: 'postgres',
31
+ driver: orm_1.BunPgDriver,
32
+ });
33
+ }
34
+ async function purgeDatabase(schema = 'public') {
35
+ const app = orm_1.Orm.getInstance();
36
+ if (!app?.driverInstance) {
37
+ console.warn('Warning: No database instance to purge');
38
+ return;
39
+ }
40
+ try {
41
+ await app.driverInstance.executeSql(`DROP SCHEMA IF EXISTS ${schema} CASCADE; CREATE SCHEMA ${schema};`);
42
+ }
43
+ catch (error) {
44
+ console.error('Error purging database:', error);
45
+ throw error;
46
+ }
47
+ }
48
+ async function cleanupDatabase() {
49
+ const app = orm_1.Orm.getInstance();
50
+ if (app?.driverInstance) {
51
+ try {
52
+ await app.disconnect();
53
+ }
54
+ catch (error) {
55
+ console.error('Error during cleanup:', error);
56
+ }
57
+ }
58
+ }
59
+ async function execute(sql) {
60
+ const app = orm_1.Orm.getInstance();
61
+ if (!app?.driverInstance) {
62
+ throw new Error('Database not initialized. Call startDatabase() first.');
63
+ }
64
+ return await app.driverInstance.executeSql(sql);
65
+ }
66
+ //# sourceMappingURL=node-database.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"node-database.js","sourceRoot":"","sources":["../../tests/node-database.ts"],"names":[],"mappings":";;;AAUA,sCAsBC;AAED,sCAgBC;AAED,0CASC;AAED,0BAMC;AArED,2CAAiD;AACjD,yCAA8E;AAC9E,uCAAiC;AAEjC,MAAM,cAAc,GAAG,IAAI,oBAAa,CAAC;IACvC,iBAAiB,EAAE,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE;CAC1C,CAAC,CAAC;AACC,QAAA,GAAG,GAAqB,SAAG,CAAC,WAAW,EAAE,CAAC;AACxC,QAAA,UAAU,GAAG,IAAA,gBAAK,EAAC,cAAc,EAAE,OAAO,CAAC,CAAC;AAElD,KAAK,UAAU,aAAa,CACjC,aAAiC,SAAS,EAC1C,SAAwB,cAAc;IAEtC,MAAM,QAAQ,GAAG,SAAG,CAAC,WAAW,EAAE,CAAC;IACnC,IAAI,QAAQ,EAAE,CAAC;QACb,WAAG,GAAG,QAAQ,CAAC;QAEf,MAAM,WAAG,CAAC,OAAO,EAAE,CAAC;QACpB,OAAO;IACT,CAAC;IACD,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC;IACpC,WAAG,GAAG,IAAI,SAAG,CAAC,MAAM,CAAC,CAAC;IAEtB,MAAM,OAAO,CAAC,MAAM,CAAC;QACnB,IAAI,EAAE,WAAW;QACjB,IAAI,EAAE,IAAI;QACV,QAAQ,EAAE,UAAU;QACpB,QAAQ,EAAE,UAAU;QACpB,QAAQ,EAAE,UAAU;QACpB,MAAM,EAAE,iBAAW;KACpB,CAAC,CAAC;AACL,CAAC;AAEM,KAAK,UAAU,aAAa,CAAC,SAAiB,QAAQ;IAC3D,MAAM,GAAG,GAAG,SAAG,CAAC,WAAW,EAAE,CAAC;IAC9B,IAAI,CAAC,GAAG,EAAE,cAAc,EAAE,CAAC;QACzB,OAAO,CAAC,IAAI,CAAC,wCAAwC,CAAC,CAAC;QACvD,OAAO;IACT,CAAC;IAED,IAAI,CAAC;QACH,MAAM,GAAG,CAAC,cAAc,CAAC,UAAU,CACjC,yBAAyB,MAAM,2BAA2B,MAAM,GAAG,CACpE,CAAC;IACJ,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,yBAAyB,EAAE,KAAK,CAAC,CAAC;QAChD,MAAM,KAAK,CAAC;IACd,CAAC;AAEH,CAAC;AAEM,KAAK,UAAU,eAAe;IACnC,MAAM,GAAG,GAAG,SAAG,CAAC,WAAW,EAAE,CAAC;IAC9B,IAAI,GAAG,EAAE,cAAc,EAAE,CAAC;QACxB,IAAI,CAAC;YACH,MAAM,GAAG,CAAC,UAAU,EAAE,CAAC;QACzB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,uBAAuB,EAAE,KAAK,CAAC,CAAC;QAChD,CAAC;IACH,CAAC;AACH,CAAC;AAEM,KAAK,UAAU,OAAO,CAAC,GAAW;IACvC,MAAM,GAAG,GAAG,SAAG,CAAC,WAAW,EAAE,CAAC;IAC9B,IAAI,CAAC,GAAG,EAAE,cAAc,EAAE,CAAC;QACzB,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;IAC3E,CAAC;IACD,OAAO,MAAM,GAAG,CAAC,cAAc,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;AAClD,CAAC"}