@hedystia/db 2.0.6 → 2.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (67) hide show
  1. package/dist/cache/index.mjs +12 -0
  2. package/dist/cache/index.mjs.map +1 -0
  3. package/dist/cache/manager.mjs +156 -153
  4. package/dist/cache/manager.mjs.map +1 -1
  5. package/dist/cache/memory-store.mjs +113 -111
  6. package/dist/cache/memory-store.mjs.map +1 -1
  7. package/dist/cli/commands/migrate.cjs +78 -0
  8. package/dist/cli/commands/migrate.cjs.map +1 -0
  9. package/dist/cli/commands/migrate.mjs +83 -0
  10. package/dist/cli/commands/migrate.mjs.map +1 -0
  11. package/dist/cli/commands/migration.cjs +3 -2
  12. package/dist/cli/commands/migration.cjs.map +1 -1
  13. package/dist/cli/commands/migration.mjs +4 -3
  14. package/dist/cli/commands/migration.mjs.map +1 -1
  15. package/dist/cli.cjs +44 -5
  16. package/dist/cli.cjs.map +1 -1
  17. package/dist/cli.mjs +45 -5
  18. package/dist/cli.mjs.map +1 -1
  19. package/dist/core/database.cjs +75 -29
  20. package/dist/core/database.cjs.map +1 -1
  21. package/dist/core/database.d.cts +11 -0
  22. package/dist/core/database.d.mts +11 -0
  23. package/dist/core/database.mjs +91 -34
  24. package/dist/core/database.mjs.map +1 -1
  25. package/dist/core/repository.mjs +414 -410
  26. package/dist/core/repository.mjs.map +1 -1
  27. package/dist/drivers/driver.mjs +9 -7
  28. package/dist/drivers/driver.mjs.map +1 -1
  29. package/dist/drivers/file.mjs +315 -312
  30. package/dist/drivers/file.mjs.map +1 -1
  31. package/dist/drivers/index.mjs +15 -6
  32. package/dist/drivers/index.mjs.map +1 -1
  33. package/dist/drivers/mysql.mjs +261 -256
  34. package/dist/drivers/mysql.mjs.map +1 -1
  35. package/dist/drivers/sql-compiler.mjs +4 -1
  36. package/dist/drivers/sql-compiler.mjs.map +1 -1
  37. package/dist/drivers/sqlite.cjs +12 -1
  38. package/dist/drivers/sqlite.cjs.map +1 -1
  39. package/dist/drivers/sqlite.mjs +258 -242
  40. package/dist/drivers/sqlite.mjs.map +1 -1
  41. package/dist/errors.mjs +48 -64
  42. package/dist/errors.mjs.map +1 -1
  43. package/dist/index.mjs +21 -9
  44. package/dist/index.mjs.map +1 -1
  45. package/dist/migrations/templates.cjs +4 -3
  46. package/dist/migrations/templates.cjs.map +1 -1
  47. package/dist/migrations/templates.d.cts +3 -2
  48. package/dist/migrations/templates.d.mts +3 -2
  49. package/dist/migrations/templates.mjs +4 -3
  50. package/dist/migrations/templates.mjs.map +1 -1
  51. package/dist/schema/column.mjs +155 -157
  52. package/dist/schema/column.mjs.map +1 -1
  53. package/dist/schema/columns/index.mjs +103 -171
  54. package/dist/schema/columns/index.mjs.map +1 -1
  55. package/dist/schema/index.mjs +15 -0
  56. package/dist/schema/index.mjs.map +1 -0
  57. package/dist/schema/registry.mjs +122 -119
  58. package/dist/schema/registry.mjs.map +1 -1
  59. package/dist/schema/table.mjs +4 -1
  60. package/dist/schema/table.mjs.map +1 -1
  61. package/dist/sync/synchronizer.mjs +2 -1
  62. package/dist/sync/synchronizer.mjs.map +1 -1
  63. package/dist/utils/naming.cjs +9 -0
  64. package/dist/utils/naming.cjs.map +1 -1
  65. package/dist/utils/naming.mjs +9 -1
  66. package/dist/utils/naming.mjs.map +1 -1
  67. package/package.json +1 -1
@@ -1,262 +1,278 @@
1
- import { DriverError } from "../errors.mjs";
2
- import { BaseDriver } from "./driver.mjs";
3
- import { compileColumnDef, compileCreateTable } from "./sql-compiler.mjs";
1
+ import { __esmMin } from "../_virtual/_rolldown/runtime.mjs";
2
+ import { DriverError, init_errors } from "../errors.mjs";
3
+ import { BaseDriver, init_driver } from "./driver.mjs";
4
+ import { compileColumnDef, compileCreateTable, init_sql_compiler } from "./sql-compiler.mjs";
4
5
  //#region src/drivers/sqlite.ts
5
- /**
6
- * SQLite database driver supporting multiple libraries (better-sqlite3, sqlite3, sql.js, bun:sqlite)
7
- */
8
- var SQLiteDriver = class extends BaseDriver {
9
- db = null;
10
- config;
11
- provider;
12
- constructor(config, provider) {
13
- super();
14
- this.config = config;
15
- this.provider = provider;
16
- }
17
- /**
18
- * Connect to the SQLite database
19
- */
20
- async connect() {
21
- if (this.connected) return;
22
- try {
23
- this.db = await this.getAdapter();
24
- await this.db.exec("PRAGMA journal_mode=WAL");
25
- await this.db.exec("PRAGMA foreign_keys=ON");
26
- this.connected = true;
27
- } catch (err) {
28
- throw new DriverError(`Failed to connect to SQLite database: ${err.message}`);
6
+ var SQLiteDriver;
7
+ var init_sqlite = __esmMin((() => {
8
+ init_errors();
9
+ init_driver();
10
+ init_sql_compiler();
11
+ SQLiteDriver = class extends BaseDriver {
12
+ db = null;
13
+ config;
14
+ provider;
15
+ constructor(config, provider) {
16
+ super();
17
+ this.config = config;
18
+ this.provider = provider;
29
19
  }
30
- }
31
- async getAdapter() {
32
- const provider = this.provider;
33
- if (!provider || provider === "better-sqlite3") try {
34
- const BetterSqlite3 = await import("better-sqlite3");
35
- return new (BetterSqlite3.default || BetterSqlite3)(this.config.filename);
36
- } catch (err) {
37
- if (provider === "better-sqlite3") throw err;
20
+ /**
21
+ * Connect to the SQLite database
22
+ */
23
+ async connect() {
24
+ if (this.connected) return;
25
+ try {
26
+ this.db = await this.getAdapter();
27
+ await this.db.exec("PRAGMA journal_mode=WAL");
28
+ await this.db.exec("PRAGMA foreign_keys=ON");
29
+ this.connected = true;
30
+ } catch (err) {
31
+ throw new DriverError(`Failed to connect to SQLite database: ${err.message}`);
32
+ }
38
33
  }
39
- if (!provider || provider === "sqlite3") try {
40
- const db = new (await (import("sqlite3"))).Database(this.config.filename);
41
- return {
42
- close: () => new Promise((res, rej) => db.close((err) => err ? rej(err) : res())),
43
- exec: (sql) => new Promise((res, rej) => db.exec(sql, (err) => err ? rej(err) : res())),
44
- prepare: (sql) => ({
45
- run: (...params) => new Promise((res, rej) => {
46
- db.run(sql, params, function(err) {
47
- if (err) return rej(err);
48
- res({
49
- lastInsertRowid: this.lastID,
50
- changes: this.changes
34
+ async getAdapter() {
35
+ const provider = this.provider;
36
+ if (!provider || provider === "better-sqlite3") try {
37
+ const BetterSqlite3 = await import("better-sqlite3");
38
+ return new (BetterSqlite3.default || BetterSqlite3)(this.config.filename);
39
+ } catch (err) {
40
+ if (provider === "better-sqlite3") throw err;
41
+ }
42
+ if (!provider || provider === "sqlite3") try {
43
+ const db = new (await (import("sqlite3"))).Database(this.config.filename);
44
+ return {
45
+ close: () => new Promise((res, rej) => db.close((err) => err ? rej(err) : res())),
46
+ exec: (sql) => new Promise((res, rej) => db.exec(sql, (err) => err ? rej(err) : res())),
47
+ prepare: (sql) => ({
48
+ run: (...params) => new Promise((res, rej) => {
49
+ db.run(sql, params, function(err) {
50
+ if (err) return rej(err);
51
+ res({
52
+ lastInsertRowid: this.lastID,
53
+ changes: this.changes
54
+ });
51
55
  });
52
- });
53
- }),
54
- all: (...params) => new Promise((res, rej) => {
55
- db.all(sql, params, (err, rows) => err ? rej(err) : res(rows));
56
+ }),
57
+ all: (...params) => new Promise((res, rej) => {
58
+ db.all(sql, params, (err, rows) => err ? rej(err) : res(rows));
59
+ })
56
60
  })
57
- })
58
- };
59
- } catch (err) {
60
- if (provider === "sqlite3") throw err;
61
+ };
62
+ } catch (err) {
63
+ if (provider === "sqlite3") throw err;
64
+ }
65
+ if (!provider || provider === "sql.js") try {
66
+ const SQL = await (await import("sql.js")).default();
67
+ const fs = await import("fs");
68
+ let data;
69
+ if (fs.existsSync(this.config.filename)) data = fs.readFileSync(this.config.filename);
70
+ const db = new SQL.Database(data);
71
+ return {
72
+ close: () => {
73
+ const binaryArray = db.export();
74
+ fs.writeFileSync(this.config.filename, Buffer.from(binaryArray));
75
+ db.close();
76
+ },
77
+ exec: (sql) => db.run(sql),
78
+ prepare: (sql) => {
79
+ const stmt = db.prepare(sql);
80
+ return {
81
+ run: (...params) => {
82
+ stmt.run(params);
83
+ const result = db.exec("SELECT last_insert_rowid()");
84
+ return {
85
+ lastInsertRowid: result[0]?.values[0] ? result[0].values[0][0] : 0,
86
+ changes: db.getRowsModified()
87
+ };
88
+ },
89
+ all: (...params) => {
90
+ const rows = [];
91
+ stmt.bind(params);
92
+ while (stmt.step()) rows.push(stmt.getAsObject());
93
+ return rows;
94
+ }
95
+ };
96
+ }
97
+ };
98
+ } catch (err) {
99
+ if (provider === "sql.js") throw err;
100
+ }
101
+ if (!provider || provider === "bun:sqlite") try {
102
+ const { Database } = await import("bun:sqlite");
103
+ return new Database(this.config.filename);
104
+ } catch (err) {
105
+ if (provider === "bun:sqlite") throw err;
106
+ }
107
+ throw new Error(provider ? `SQLite provider "${provider}" not found.` : "No SQLite driver found. Please install better-sqlite3, sqlite3, sql.js or run with Bun.");
61
108
  }
62
- if (!provider || provider === "sql.js") try {
63
- const SQL = await (await import("sql.js")).default();
64
- const fs = await import("fs");
65
- let data;
66
- if (fs.existsSync(this.config.filename)) data = fs.readFileSync(this.config.filename);
67
- const db = new SQL.Database(data);
68
- return {
69
- close: () => {
70
- const binaryArray = db.export();
71
- fs.writeFileSync(this.config.filename, Buffer.from(binaryArray));
72
- db.close();
73
- },
74
- exec: (sql) => db.run(sql),
75
- prepare: (sql) => {
76
- const stmt = db.prepare(sql);
109
+ /**
110
+ * Disconnect from the SQLite database
111
+ */
112
+ async disconnect() {
113
+ if (this.db) {
114
+ try {
115
+ await this.db.exec("PRAGMA wal_checkpoint(TRUNCATE)");
116
+ } catch {}
117
+ await this.db.close();
118
+ this.db = null;
119
+ this.connected = false;
120
+ }
121
+ }
122
+ /**
123
+ * Execute a SQL statement
124
+ * @param {string} sql - SQL statement
125
+ * @param {unknown[]} [params] - Query parameters
126
+ * @returns {Promise<any>} Execution result with lastInsertRowid and changes
127
+ */
128
+ async execute(sql, params = []) {
129
+ try {
130
+ const formatted = this.formatParams(params);
131
+ if (formatted.length === 0) {
132
+ await this.db.exec(sql);
77
133
  return {
78
- run: (...params) => {
79
- stmt.run(params);
80
- const result = db.exec("SELECT last_insert_rowid()");
81
- return {
82
- lastInsertRowid: result[0]?.values[0] ? result[0].values[0][0] : 0,
83
- changes: db.getRowsModified()
84
- };
85
- },
86
- all: (...params) => {
87
- const rows = [];
88
- stmt.bind(params);
89
- while (stmt.step()) rows.push(stmt.getAsObject());
90
- return rows;
91
- }
134
+ insertId: 0,
135
+ affectedRows: 0
92
136
  };
93
137
  }
94
- };
95
- } catch (err) {
96
- if (provider === "sql.js") throw err;
138
+ const result = await this.db.prepare(sql).run(...formatted);
139
+ return {
140
+ insertId: Number(result.lastInsertRowid),
141
+ affectedRows: result.changes
142
+ };
143
+ } catch (err) {
144
+ throw new DriverError(`SQLite execute error: ${err.message}`);
145
+ }
97
146
  }
98
- if (!provider || provider === "bun:sqlite") try {
99
- const { Database } = await import("bun:sqlite");
100
- return new Database(this.config.filename);
101
- } catch (err) {
102
- if (provider === "bun:sqlite") throw err;
147
+ /**
148
+ * Execute a SQL query
149
+ * @param {string} sql - SQL query
150
+ * @param {unknown[]} [params] - Query parameters
151
+ * @returns {Promise<any[]>} Query results
152
+ */
153
+ async query(sql, params = []) {
154
+ try {
155
+ return await this.db.prepare(sql).all(...this.formatParams(params));
156
+ } catch (err) {
157
+ throw new DriverError(`SQLite query error: ${err.message}`);
158
+ }
103
159
  }
104
- throw new Error(provider ? `SQLite provider "${provider}" not found.` : "No SQLite driver found. Please install better-sqlite3, sqlite3, sql.js or run with Bun.");
105
- }
106
- /**
107
- * Disconnect from the SQLite database
108
- */
109
- async disconnect() {
110
- if (this.db) {
111
- await this.db.close();
112
- this.db = null;
113
- this.connected = false;
160
+ formatParams(params) {
161
+ return params.map((p) => {
162
+ if (p instanceof Date) return p.toISOString();
163
+ return p;
164
+ });
114
165
  }
115
- }
116
- /**
117
- * Execute a SQL statement
118
- * @param {string} sql - SQL statement
119
- * @param {unknown[]} [params] - Query parameters
120
- * @returns {Promise<any>} Execution result with lastInsertRowid and changes
121
- */
122
- async execute(sql, params = []) {
123
- try {
124
- const result = await this.db.prepare(sql).run(...this.formatParams(params));
125
- return {
126
- insertId: Number(result.lastInsertRowid),
127
- affectedRows: result.changes
128
- };
129
- } catch (err) {
130
- throw new DriverError(`SQLite execute error: ${err.message}`);
166
+ /**
167
+ * Check if a table exists
168
+ * @param {string} name - Table name
169
+ * @returns {Promise<boolean>} Whether the table exists
170
+ */
171
+ async tableExists(name) {
172
+ return (await this.query("SELECT name FROM sqlite_master WHERE type='table' AND name=?", [name])).length > 0;
131
173
  }
132
- }
133
- /**
134
- * Execute a SQL query
135
- * @param {string} sql - SQL query
136
- * @param {unknown[]} [params] - Query parameters
137
- * @returns {Promise<any[]>} Query results
138
- */
139
- async query(sql, params = []) {
140
- try {
141
- return await this.db.prepare(sql).all(...this.formatParams(params));
142
- } catch (err) {
143
- throw new DriverError(`SQLite query error: ${err.message}`);
174
+ /**
175
+ * Get column metadata for a table
176
+ * @param {string} name - Table name
177
+ * @returns {Promise<ColumnMetadata[]>} Column metadata
178
+ */
179
+ async getTableColumns(name) {
180
+ return (await this.query(`PRAGMA table_info(\`${name}\`)`)).map((row) => ({
181
+ name: row.name,
182
+ type: this.mapSQLiteType(row.type),
183
+ primaryKey: row.pk === 1,
184
+ autoIncrement: row.pk === 1 && row.type.toUpperCase() === "INTEGER",
185
+ notNull: row.notnull === 1,
186
+ unique: false,
187
+ defaultValue: row.dflt_value
188
+ }));
144
189
  }
145
- }
146
- formatParams(params) {
147
- return params.map((p) => {
148
- if (p instanceof Date) return p.toISOString();
149
- return p;
150
- });
151
- }
152
- /**
153
- * Check if a table exists
154
- * @param {string} name - Table name
155
- * @returns {Promise<boolean>} Whether the table exists
156
- */
157
- async tableExists(name) {
158
- return (await this.query("SELECT name FROM sqlite_master WHERE type='table' AND name=?", [name])).length > 0;
159
- }
160
- /**
161
- * Get column metadata for a table
162
- * @param {string} name - Table name
163
- * @returns {Promise<ColumnMetadata[]>} Column metadata
164
- */
165
- async getTableColumns(name) {
166
- return (await this.query(`PRAGMA table_info(\`${name}\`)`)).map((row) => ({
167
- name: row.name,
168
- type: this.mapSQLiteType(row.type),
169
- primaryKey: row.pk === 1,
170
- autoIncrement: row.pk === 1 && row.type.toUpperCase() === "INTEGER",
171
- notNull: row.notnull === 1,
172
- unique: false,
173
- defaultValue: row.dflt_value
174
- }));
175
- }
176
- /**
177
- * Create a table from metadata
178
- * @param {TableMetadata} meta - Table metadata
179
- */
180
- async createTable(meta) {
181
- const sql = compileCreateTable(meta, "sqlite");
182
- await this.execute(sql);
183
- }
184
- /**
185
- * Drop a table
186
- * @param {string} name - Table name
187
- */
188
- async dropTable(name) {
189
- await this.execute(`DROP TABLE IF EXISTS \`${name}\``);
190
- }
191
- /**
192
- * Add a column to a table
193
- * @param {string} table - Table name
194
- * @param {ColumnMetadata} column - Column metadata
195
- */
196
- async addColumn(table, column) {
197
- const colDef = compileColumnDef(column, "sqlite");
198
- await this.execute(`ALTER TABLE \`${table}\` ADD COLUMN ${colDef}`);
199
- }
200
- /**
201
- * Drop a column from a table
202
- * @param {string} table - Table name
203
- * @param {string} name - Column name
204
- */
205
- async dropColumn(table, name) {
206
- await this.execute(`ALTER TABLE \`${table}\` DROP COLUMN \`${name}\``);
207
- }
208
- /**
209
- * Rename a column
210
- * @param {string} table - Table name
211
- * @param {string} oldName - Current name
212
- * @param {string} newName - New name
213
- */
214
- async renameColumn(table, oldName, newName) {
215
- await this.execute(`ALTER TABLE \`${table}\` RENAME COLUMN \`${oldName}\` TO \`${newName}\``);
216
- }
217
- /**
218
- * Execute within a transaction
219
- * @param {() => Promise<T>} fn - Function to execute
220
- * @returns {Promise<T>} Result
221
- */
222
- async transaction(fn) {
223
- await this.execute("BEGIN TRANSACTION");
224
- try {
225
- const result = await fn();
226
- await this.execute("COMMIT");
227
- return result;
228
- } catch (err) {
229
- await this.execute("ROLLBACK");
230
- throw err;
190
+ /**
191
+ * Create a table from metadata
192
+ * @param {TableMetadata} meta - Table metadata
193
+ */
194
+ async createTable(meta) {
195
+ const sql = compileCreateTable(meta, "sqlite");
196
+ await this.execute(sql);
231
197
  }
232
- }
233
- /**
234
- * Fetch all column metadata for all tables in the database
235
- * @returns {Promise<Record<string, ColumnMetadata[]>>} Columns grouped by table name
236
- */
237
- async getAllTableColumns() {
238
- try {
239
- const tables = await this.query("SELECT name FROM sqlite_master WHERE type='table' AND name NOT LIKE 'sqlite_%'");
240
- const result = {};
241
- for (const table of tables) {
242
- const tableName = table.name;
243
- result[tableName] = await this.getTableColumns(tableName);
198
+ /**
199
+ * Drop a table
200
+ * @param {string} name - Table name
201
+ */
202
+ async dropTable(name) {
203
+ await this.execute(`DROP TABLE IF EXISTS \`${name}\``);
204
+ }
205
+ /**
206
+ * Add a column to a table
207
+ * @param {string} table - Table name
208
+ * @param {ColumnMetadata} column - Column metadata
209
+ */
210
+ async addColumn(table, column) {
211
+ const colDef = compileColumnDef(column, "sqlite");
212
+ await this.execute(`ALTER TABLE \`${table}\` ADD COLUMN ${colDef}`);
213
+ }
214
+ /**
215
+ * Drop a column from a table
216
+ * @param {string} table - Table name
217
+ * @param {string} name - Column name
218
+ */
219
+ async dropColumn(table, name) {
220
+ await this.execute(`ALTER TABLE \`${table}\` DROP COLUMN \`${name}\``);
221
+ }
222
+ /**
223
+ * Rename a column
224
+ * @param {string} table - Table name
225
+ * @param {string} oldName - Current name
226
+ * @param {string} newName - New name
227
+ */
228
+ async renameColumn(table, oldName, newName) {
229
+ await this.execute(`ALTER TABLE \`${table}\` RENAME COLUMN \`${oldName}\` TO \`${newName}\``);
230
+ }
231
+ /**
232
+ * Execute within a transaction
233
+ * @param {() => Promise<T>} fn - Function to execute
234
+ * @returns {Promise<T>} Result
235
+ */
236
+ async transaction(fn) {
237
+ await this.execute("BEGIN TRANSACTION");
238
+ try {
239
+ const result = await fn();
240
+ await this.execute("COMMIT");
241
+ return result;
242
+ } catch (err) {
243
+ await this.execute("ROLLBACK");
244
+ throw err;
244
245
  }
245
- return result;
246
- } catch (err) {
247
- throw new DriverError(`Failed to fetch all table columns: ${err.message}`);
248
246
  }
249
- }
250
- mapSQLiteType(type) {
251
- const upper = type.toUpperCase();
252
- if (upper.includes("INT")) return "integer";
253
- if (upper.includes("CHAR") || upper.includes("TEXT") || upper.includes("CLOB")) return "text";
254
- if (upper.includes("REAL") || upper.includes("FLOAT") || upper.includes("DOUBLE")) return "float";
255
- if (upper.includes("BLOB")) return "blob";
256
- return "text";
257
- }
258
- };
247
+ /**
248
+ * Fetch all column metadata for all tables in the database
249
+ * @returns {Promise<Record<string, ColumnMetadata[]>>} Columns grouped by table name
250
+ */
251
+ async getAllTableColumns() {
252
+ try {
253
+ const tables = await this.query("SELECT name FROM sqlite_master WHERE type='table' AND name NOT LIKE 'sqlite_%'");
254
+ const result = {};
255
+ for (const table of tables) {
256
+ const tableName = table.name;
257
+ result[tableName] = await this.getTableColumns(tableName);
258
+ }
259
+ return result;
260
+ } catch (err) {
261
+ throw new DriverError(`Failed to fetch all table columns: ${err.message}`);
262
+ }
263
+ }
264
+ mapSQLiteType(type) {
265
+ const upper = type.toUpperCase();
266
+ if (upper.includes("INT")) return "integer";
267
+ if (upper.includes("CHAR") || upper.includes("TEXT") || upper.includes("CLOB")) return "text";
268
+ if (upper.includes("REAL") || upper.includes("FLOAT") || upper.includes("DOUBLE")) return "float";
269
+ if (upper.includes("BLOB")) return "blob";
270
+ return "text";
271
+ }
272
+ };
273
+ }));
259
274
  //#endregion
260
- export { SQLiteDriver };
275
+ init_sqlite();
276
+ export { SQLiteDriver, init_sqlite };
261
277
 
262
278
  //# sourceMappingURL=sqlite.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"sqlite.mjs","names":[],"sources":["../../src/drivers/sqlite.ts"],"sourcesContent":["import { DriverError } from \"../errors\";\nimport type { ColumnMetadata, SQLiteConnectionConfig, TableMetadata } from \"../types\";\nimport { BaseDriver } from \"./driver\";\nimport { compileColumnDef, compileCreateTable } from \"./sql-compiler\";\n\n/**\n * Interface for SQLite database adapters\n */\ninterface SQLiteAdapter {\n close(): void | Promise<void>;\n prepare(sql: string): SQLiteStatement;\n exec(sql: string): void | Promise<void>;\n}\n\ninterface SQLiteStatement {\n run(...params: any[]): any | Promise<any>;\n all(...params: any[]): any[] | Promise<any[]>;\n}\n\n/**\n * SQLite database driver supporting multiple libraries (better-sqlite3, sqlite3, sql.js, bun:sqlite)\n */\nexport class SQLiteDriver extends BaseDriver {\n private db: SQLiteAdapter | null = null;\n private config: SQLiteConnectionConfig;\n private provider?: \"better-sqlite3\" | \"sqlite3\" | \"sql.js\" | \"bun:sqlite\";\n\n constructor(\n config: SQLiteConnectionConfig,\n provider?: \"better-sqlite3\" | \"sqlite3\" | \"sql.js\" | \"bun:sqlite\",\n ) {\n super();\n this.config = config;\n this.provider = provider;\n }\n\n /**\n * Connect to the SQLite database\n */\n async connect(): Promise<void> {\n if (this.connected) {\n return;\n }\n\n try {\n const adapter = await this.getAdapter();\n this.db = adapter;\n await this.db.exec(\"PRAGMA journal_mode=WAL\");\n await this.db.exec(\"PRAGMA foreign_keys=ON\");\n this.connected = true;\n } catch (err: any) {\n throw new DriverError(`Failed to connect to SQLite database: ${err.message}`);\n }\n }\n\n private async getAdapter(): Promise<SQLiteAdapter> {\n const provider = this.provider;\n\n if (!provider || provider === \"better-sqlite3\") {\n try {\n const BetterSqlite3 = await import(\"better-sqlite3\");\n const Database = BetterSqlite3.default || BetterSqlite3;\n return new Database(this.config.filename) as any;\n } catch (err) {\n if (provider === \"better-sqlite3\") {\n throw err;\n }\n }\n }\n\n if (!provider || provider === \"sqlite3\") {\n try {\n const sqlite3 = await import(\"sqlite3\");\n const db = new sqlite3.Database(this.config.filename);\n\n return {\n close: () => new Promise<void>((res, rej) => db.close((err) => (err ? rej(err) : res()))),\n exec: (sql: string) =>\n new Promise<void>((res, rej) => db.exec(sql, (err) => (err ? rej(err) : res()))),\n prepare: (sql: string) => ({\n run: (...params: any[]) =>\n new Promise<{ lastInsertRowid: number; changes: number }>((res, rej) => {\n db.run(sql, params, function (this: any, err: Error | null) {\n if (err) {\n return rej(err);\n }\n res({ lastInsertRowid: this.lastID, changes: this.changes });\n });\n }),\n all: (...params: any[]) =>\n new Promise<any[]>((res, rej) => {\n db.all(sql, params, (err, rows) => (err ? rej(err) : res(rows)));\n }),\n }),\n } as any;\n } catch (err) {\n if (provider === \"sqlite3\") {\n throw err;\n }\n }\n }\n\n if (!provider || provider === \"sql.js\") {\n try {\n const initSqlJs = await import(\"sql.js\");\n const SQL = await initSqlJs.default();\n const fs = await import(\"fs\");\n let data: Buffer | undefined;\n if (fs.existsSync(this.config.filename)) {\n data = fs.readFileSync(this.config.filename);\n }\n const db = new SQL.Database(data);\n return {\n close: () => {\n const binaryArray = db.export();\n fs.writeFileSync(this.config.filename, Buffer.from(binaryArray));\n db.close();\n },\n exec: (sql: string) => db.run(sql),\n prepare: (sql: string) => {\n const stmt = db.prepare(sql);\n return {\n run: (...params: any[]) => {\n stmt.run(params);\n const result = db.exec(\"SELECT last_insert_rowid()\");\n const lastInsertRowid = result[0]?.values[0]\n ? (result[0].values[0][0] as number)\n : 0;\n return { lastInsertRowid, changes: db.getRowsModified() };\n },\n all: (...params: any[]) => {\n const rows: any[] = [];\n stmt.bind(params);\n while (stmt.step()) {\n rows.push(stmt.getAsObject());\n }\n return rows;\n },\n };\n },\n } as any;\n } catch (err) {\n if (provider === \"sql.js\") {\n throw err;\n }\n }\n }\n\n if (!provider || provider === \"bun:sqlite\") {\n try {\n const { Database } = await import(\"bun:sqlite\");\n return new Database(this.config.filename) as any;\n } catch (err) {\n if (provider === \"bun:sqlite\") {\n throw err;\n }\n }\n }\n\n throw new Error(\n provider\n ? `SQLite provider \"${provider}\" not found.`\n : \"No SQLite driver found. Please install better-sqlite3, sqlite3, sql.js or run with Bun.\",\n );\n }\n\n /**\n * Disconnect from the SQLite database\n */\n async disconnect(): Promise<void> {\n if (this.db) {\n await this.db.close();\n this.db = null;\n this.connected = false;\n }\n }\n\n /**\n * Execute a SQL statement\n * @param {string} sql - SQL statement\n * @param {unknown[]} [params] - Query parameters\n * @returns {Promise<any>} Execution result with lastInsertRowid and changes\n */\n async execute(sql: string, params: unknown[] = []): Promise<any> {\n try {\n const stmt = this.db!.prepare(sql);\n const result = await stmt.run(...this.formatParams(params));\n return {\n insertId: Number(result.lastInsertRowid),\n affectedRows: result.changes,\n };\n } catch (err: any) {\n throw new DriverError(`SQLite execute error: ${err.message}`);\n }\n }\n\n /**\n * Execute a SQL query\n * @param {string} sql - SQL query\n * @param {unknown[]} [params] - Query parameters\n * @returns {Promise<any[]>} Query results\n */\n async query(sql: string, params: unknown[] = []): Promise<any[]> {\n try {\n const stmt = this.db!.prepare(sql);\n return await stmt.all(...this.formatParams(params));\n } catch (err: any) {\n throw new DriverError(`SQLite query error: ${err.message}`);\n }\n }\n\n private formatParams(params: unknown[]): any[] {\n return params.map((p) => {\n if (p instanceof Date) {\n return p.toISOString();\n }\n return p;\n });\n }\n\n /**\n * Check if a table exists\n * @param {string} name - Table name\n * @returns {Promise<boolean>} Whether the table exists\n */\n async tableExists(name: string): Promise<boolean> {\n const rows = await this.query(\"SELECT name FROM sqlite_master WHERE type='table' AND name=?\", [\n name,\n ]);\n return rows.length > 0;\n }\n\n /**\n * Get column metadata for a table\n * @param {string} name - Table name\n * @returns {Promise<ColumnMetadata[]>} Column metadata\n */\n async getTableColumns(name: string): Promise<ColumnMetadata[]> {\n const rows = (await this.query(`PRAGMA table_info(\\`${name}\\`)`)) as any[];\n return rows.map((row: any) => ({\n name: row.name,\n type: this.mapSQLiteType(row.type),\n primaryKey: row.pk === 1,\n autoIncrement: row.pk === 1 && row.type.toUpperCase() === \"INTEGER\",\n notNull: row.notnull === 1,\n unique: false,\n defaultValue: row.dflt_value,\n }));\n }\n\n /**\n * Create a table from metadata\n * @param {TableMetadata} meta - Table metadata\n */\n async createTable(meta: TableMetadata): Promise<void> {\n const sql = compileCreateTable(meta, \"sqlite\");\n await this.execute(sql);\n }\n\n /**\n * Drop a table\n * @param {string} name - Table name\n */\n async dropTable(name: string): Promise<void> {\n await this.execute(`DROP TABLE IF EXISTS \\`${name}\\``);\n }\n\n /**\n * Add a column to a table\n * @param {string} table - Table name\n * @param {ColumnMetadata} column - Column metadata\n */\n async addColumn(table: string, column: ColumnMetadata): Promise<void> {\n const colDef = compileColumnDef(column, \"sqlite\");\n await this.execute(`ALTER TABLE \\`${table}\\` ADD COLUMN ${colDef}`);\n }\n\n /**\n * Drop a column from a table\n * @param {string} table - Table name\n * @param {string} name - Column name\n */\n async dropColumn(table: string, name: string): Promise<void> {\n await this.execute(`ALTER TABLE \\`${table}\\` DROP COLUMN \\`${name}\\``);\n }\n\n /**\n * Rename a column\n * @param {string} table - Table name\n * @param {string} oldName - Current name\n * @param {string} newName - New name\n */\n async renameColumn(table: string, oldName: string, newName: string): Promise<void> {\n await this.execute(`ALTER TABLE \\`${table}\\` RENAME COLUMN \\`${oldName}\\` TO \\`${newName}\\``);\n }\n\n /**\n * Execute within a transaction\n * @param {() => Promise<T>} fn - Function to execute\n * @returns {Promise<T>} Result\n */\n async transaction<T>(fn: () => Promise<T>): Promise<T> {\n await this.execute(\"BEGIN TRANSACTION\");\n try {\n const result = await fn();\n await this.execute(\"COMMIT\");\n return result;\n } catch (err) {\n await this.execute(\"ROLLBACK\");\n throw err;\n }\n }\n\n /**\n * Fetch all column metadata for all tables in the database\n * @returns {Promise<Record<string, ColumnMetadata[]>>} Columns grouped by table name\n */\n async getAllTableColumns(): Promise<Record<string, ColumnMetadata[]>> {\n try {\n const tables = await this.query(\n \"SELECT name FROM sqlite_master WHERE type='table' AND name NOT LIKE 'sqlite_%'\",\n );\n const result: Record<string, ColumnMetadata[]> = {};\n\n for (const table of tables) {\n const tableName = table.name;\n result[tableName] = await this.getTableColumns(tableName);\n }\n return result;\n } catch (err: any) {\n throw new DriverError(`Failed to fetch all table columns: ${err.message}`);\n }\n }\n\n private mapSQLiteType(type: string): ColumnMetadata[\"type\"] {\n const upper = type.toUpperCase();\n if (upper.includes(\"INT\")) {\n return \"integer\";\n }\n if (upper.includes(\"CHAR\") || upper.includes(\"TEXT\") || upper.includes(\"CLOB\")) {\n return \"text\";\n }\n if (upper.includes(\"REAL\") || upper.includes(\"FLOAT\") || upper.includes(\"DOUBLE\")) {\n return \"float\";\n }\n if (upper.includes(\"BLOB\")) {\n return \"blob\";\n }\n return \"text\";\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"sqlite.mjs","names":[],"sources":["../../src/drivers/sqlite.ts"],"sourcesContent":["import { DriverError } from \"../errors\";\nimport type { ColumnMetadata, SQLiteConnectionConfig, TableMetadata } from \"../types\";\nimport { BaseDriver } from \"./driver\";\nimport { compileColumnDef, compileCreateTable } from \"./sql-compiler\";\n\n/**\n * Interface for SQLite database adapters\n */\ninterface SQLiteAdapter {\n close(): void | Promise<void>;\n prepare(sql: string): SQLiteStatement;\n exec(sql: string): void | Promise<void>;\n}\n\ninterface SQLiteStatement {\n run(...params: any[]): any | Promise<any>;\n all(...params: any[]): any[] | Promise<any[]>;\n}\n\n/**\n * SQLite database driver supporting multiple libraries (better-sqlite3, sqlite3, sql.js, bun:sqlite)\n */\nexport class SQLiteDriver extends BaseDriver {\n private db: SQLiteAdapter | null = null;\n private config: SQLiteConnectionConfig;\n private provider?: \"better-sqlite3\" | \"sqlite3\" | \"sql.js\" | \"bun:sqlite\";\n\n constructor(\n config: SQLiteConnectionConfig,\n provider?: \"better-sqlite3\" | \"sqlite3\" | \"sql.js\" | \"bun:sqlite\",\n ) {\n super();\n this.config = config;\n this.provider = provider;\n }\n\n /**\n * Connect to the SQLite database\n */\n async connect(): Promise<void> {\n if (this.connected) {\n return;\n }\n\n try {\n const adapter = await this.getAdapter();\n this.db = adapter;\n await this.db.exec(\"PRAGMA journal_mode=WAL\");\n await this.db.exec(\"PRAGMA foreign_keys=ON\");\n this.connected = true;\n } catch (err: any) {\n throw new DriverError(`Failed to connect to SQLite database: ${err.message}`);\n }\n }\n\n private async getAdapter(): Promise<SQLiteAdapter> {\n const provider = this.provider;\n\n if (!provider || provider === \"better-sqlite3\") {\n try {\n const BetterSqlite3 = await import(\"better-sqlite3\");\n const Database = BetterSqlite3.default || BetterSqlite3;\n return new Database(this.config.filename) as any;\n } catch (err) {\n if (provider === \"better-sqlite3\") {\n throw err;\n }\n }\n }\n\n if (!provider || provider === \"sqlite3\") {\n try {\n const sqlite3 = await import(\"sqlite3\");\n const db = new sqlite3.Database(this.config.filename);\n\n return {\n close: () => new Promise<void>((res, rej) => db.close((err) => (err ? rej(err) : res()))),\n exec: (sql: string) =>\n new Promise<void>((res, rej) => db.exec(sql, (err) => (err ? rej(err) : res()))),\n prepare: (sql: string) => ({\n run: (...params: any[]) =>\n new Promise<{ lastInsertRowid: number; changes: number }>((res, rej) => {\n db.run(sql, params, function (this: any, err: Error | null) {\n if (err) {\n return rej(err);\n }\n res({ lastInsertRowid: this.lastID, changes: this.changes });\n });\n }),\n all: (...params: any[]) =>\n new Promise<any[]>((res, rej) => {\n db.all(sql, params, (err, rows) => (err ? rej(err) : res(rows)));\n }),\n }),\n } as any;\n } catch (err) {\n if (provider === \"sqlite3\") {\n throw err;\n }\n }\n }\n\n if (!provider || provider === \"sql.js\") {\n try {\n const initSqlJs = await import(\"sql.js\");\n const SQL = await initSqlJs.default();\n const fs = await import(\"fs\");\n let data: Buffer | undefined;\n if (fs.existsSync(this.config.filename)) {\n data = fs.readFileSync(this.config.filename);\n }\n const db = new SQL.Database(data);\n return {\n close: () => {\n const binaryArray = db.export();\n fs.writeFileSync(this.config.filename, Buffer.from(binaryArray));\n db.close();\n },\n exec: (sql: string) => db.run(sql),\n prepare: (sql: string) => {\n const stmt = db.prepare(sql);\n return {\n run: (...params: any[]) => {\n stmt.run(params);\n const result = db.exec(\"SELECT last_insert_rowid()\");\n const lastInsertRowid = result[0]?.values[0]\n ? (result[0].values[0][0] as number)\n : 0;\n return { lastInsertRowid, changes: db.getRowsModified() };\n },\n all: (...params: any[]) => {\n const rows: any[] = [];\n stmt.bind(params);\n while (stmt.step()) {\n rows.push(stmt.getAsObject());\n }\n return rows;\n },\n };\n },\n } as any;\n } catch (err) {\n if (provider === \"sql.js\") {\n throw err;\n }\n }\n }\n\n if (!provider || provider === \"bun:sqlite\") {\n try {\n const { Database } = await import(\"bun:sqlite\");\n return new Database(this.config.filename) as any;\n } catch (err) {\n if (provider === \"bun:sqlite\") {\n throw err;\n }\n }\n }\n\n throw new Error(\n provider\n ? `SQLite provider \"${provider}\" not found.`\n : \"No SQLite driver found. Please install better-sqlite3, sqlite3, sql.js or run with Bun.\",\n );\n }\n\n /**\n * Disconnect from the SQLite database\n */\n async disconnect(): Promise<void> {\n if (this.db) {\n try {\n await this.db.exec(\"PRAGMA wal_checkpoint(TRUNCATE)\");\n } catch {}\n await this.db.close();\n this.db = null;\n this.connected = false;\n }\n }\n\n /**\n * Execute a SQL statement\n * @param {string} sql - SQL statement\n * @param {unknown[]} [params] - Query parameters\n * @returns {Promise<any>} Execution result with lastInsertRowid and changes\n */\n async execute(sql: string, params: unknown[] = []): Promise<any> {\n try {\n const formatted = this.formatParams(params);\n if (formatted.length === 0) {\n await this.db!.exec(sql);\n return { insertId: 0, affectedRows: 0 };\n }\n const stmt = this.db!.prepare(sql);\n const result = await stmt.run(...formatted);\n return {\n insertId: Number(result.lastInsertRowid),\n affectedRows: result.changes,\n };\n } catch (err: any) {\n throw new DriverError(`SQLite execute error: ${err.message}`);\n }\n }\n\n /**\n * Execute a SQL query\n * @param {string} sql - SQL query\n * @param {unknown[]} [params] - Query parameters\n * @returns {Promise<any[]>} Query results\n */\n async query(sql: string, params: unknown[] = []): Promise<any[]> {\n try {\n const stmt = this.db!.prepare(sql);\n return await stmt.all(...this.formatParams(params));\n } catch (err: any) {\n throw new DriverError(`SQLite query error: ${err.message}`);\n }\n }\n\n private formatParams(params: unknown[]): any[] {\n return params.map((p) => {\n if (p instanceof Date) {\n return p.toISOString();\n }\n return p;\n });\n }\n\n /**\n * Check if a table exists\n * @param {string} name - Table name\n * @returns {Promise<boolean>} Whether the table exists\n */\n async tableExists(name: string): Promise<boolean> {\n const rows = await this.query(\"SELECT name FROM sqlite_master WHERE type='table' AND name=?\", [\n name,\n ]);\n return rows.length > 0;\n }\n\n /**\n * Get column metadata for a table\n * @param {string} name - Table name\n * @returns {Promise<ColumnMetadata[]>} Column metadata\n */\n async getTableColumns(name: string): Promise<ColumnMetadata[]> {\n const rows = (await this.query(`PRAGMA table_info(\\`${name}\\`)`)) as any[];\n return rows.map((row: any) => ({\n name: row.name,\n type: this.mapSQLiteType(row.type),\n primaryKey: row.pk === 1,\n autoIncrement: row.pk === 1 && row.type.toUpperCase() === \"INTEGER\",\n notNull: row.notnull === 1,\n unique: false,\n defaultValue: row.dflt_value,\n }));\n }\n\n /**\n * Create a table from metadata\n * @param {TableMetadata} meta - Table metadata\n */\n async createTable(meta: TableMetadata): Promise<void> {\n const sql = compileCreateTable(meta, \"sqlite\");\n await this.execute(sql);\n }\n\n /**\n * Drop a table\n * @param {string} name - Table name\n */\n async dropTable(name: string): Promise<void> {\n await this.execute(`DROP TABLE IF EXISTS \\`${name}\\``);\n }\n\n /**\n * Add a column to a table\n * @param {string} table - Table name\n * @param {ColumnMetadata} column - Column metadata\n */\n async addColumn(table: string, column: ColumnMetadata): Promise<void> {\n const colDef = compileColumnDef(column, \"sqlite\");\n await this.execute(`ALTER TABLE \\`${table}\\` ADD COLUMN ${colDef}`);\n }\n\n /**\n * Drop a column from a table\n * @param {string} table - Table name\n * @param {string} name - Column name\n */\n async dropColumn(table: string, name: string): Promise<void> {\n await this.execute(`ALTER TABLE \\`${table}\\` DROP COLUMN \\`${name}\\``);\n }\n\n /**\n * Rename a column\n * @param {string} table - Table name\n * @param {string} oldName - Current name\n * @param {string} newName - New name\n */\n async renameColumn(table: string, oldName: string, newName: string): Promise<void> {\n await this.execute(`ALTER TABLE \\`${table}\\` RENAME COLUMN \\`${oldName}\\` TO \\`${newName}\\``);\n }\n\n /**\n * Execute within a transaction\n * @param {() => Promise<T>} fn - Function to execute\n * @returns {Promise<T>} Result\n */\n async transaction<T>(fn: () => Promise<T>): Promise<T> {\n await this.execute(\"BEGIN TRANSACTION\");\n try {\n const result = await fn();\n await this.execute(\"COMMIT\");\n return result;\n } catch (err) {\n await this.execute(\"ROLLBACK\");\n throw err;\n }\n }\n\n /**\n * Fetch all column metadata for all tables in the database\n * @returns {Promise<Record<string, ColumnMetadata[]>>} Columns grouped by table name\n */\n async getAllTableColumns(): Promise<Record<string, ColumnMetadata[]>> {\n try {\n const tables = await this.query(\n \"SELECT name FROM sqlite_master WHERE type='table' AND name NOT LIKE 'sqlite_%'\",\n );\n const result: Record<string, ColumnMetadata[]> = {};\n\n for (const table of tables) {\n const tableName = table.name;\n result[tableName] = await this.getTableColumns(tableName);\n }\n return result;\n } catch (err: any) {\n throw new DriverError(`Failed to fetch all table columns: ${err.message}`);\n }\n }\n\n private mapSQLiteType(type: string): ColumnMetadata[\"type\"] {\n const upper = type.toUpperCase();\n if (upper.includes(\"INT\")) {\n return \"integer\";\n }\n if (upper.includes(\"CHAR\") || upper.includes(\"TEXT\") || upper.includes(\"CLOB\")) {\n return \"text\";\n }\n if (upper.includes(\"REAL\") || upper.includes(\"FLOAT\") || upper.includes(\"DOUBLE\")) {\n return \"float\";\n }\n if (upper.includes(\"BLOB\")) {\n return \"blob\";\n }\n return \"text\";\n }\n}\n"],"mappings":"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"}