@coherent.js/database 1.0.0-beta.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.
Files changed (56) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +74 -0
  3. package/dist/database/adapters/memory.d.ts +48 -0
  4. package/dist/database/adapters/memory.d.ts.map +1 -0
  5. package/dist/database/adapters/memory.js +250 -0
  6. package/dist/database/adapters/memory.js.map +1 -0
  7. package/dist/database/adapters/mongodb.d.ts +15 -0
  8. package/dist/database/adapters/mongodb.d.ts.map +1 -0
  9. package/dist/database/adapters/mongodb.js +216 -0
  10. package/dist/database/adapters/mongodb.js.map +1 -0
  11. package/dist/database/adapters/mysql.d.ts +12 -0
  12. package/dist/database/adapters/mysql.d.ts.map +1 -0
  13. package/dist/database/adapters/mysql.js +171 -0
  14. package/dist/database/adapters/mysql.js.map +1 -0
  15. package/dist/database/adapters/postgresql.d.ts +12 -0
  16. package/dist/database/adapters/postgresql.d.ts.map +1 -0
  17. package/dist/database/adapters/postgresql.js +177 -0
  18. package/dist/database/adapters/postgresql.js.map +1 -0
  19. package/dist/database/adapters/sqlite.d.ts +15 -0
  20. package/dist/database/adapters/sqlite.d.ts.map +1 -0
  21. package/dist/database/adapters/sqlite.js +241 -0
  22. package/dist/database/adapters/sqlite.js.map +1 -0
  23. package/dist/database/connection-manager.d.ts +148 -0
  24. package/dist/database/connection-manager.d.ts.map +1 -0
  25. package/dist/database/connection-manager.js +377 -0
  26. package/dist/database/connection-manager.js.map +1 -0
  27. package/dist/database/index.d.ts +38 -0
  28. package/dist/database/index.d.ts.map +1 -0
  29. package/dist/database/index.js +63 -0
  30. package/dist/database/index.js.map +1 -0
  31. package/dist/database/middleware.d.ts +122 -0
  32. package/dist/database/middleware.d.ts.map +1 -0
  33. package/dist/database/middleware.js +403 -0
  34. package/dist/database/middleware.js.map +1 -0
  35. package/dist/database/migration.d.ts +168 -0
  36. package/dist/database/migration.d.ts.map +1 -0
  37. package/dist/database/migration.js +946 -0
  38. package/dist/database/migration.js.map +1 -0
  39. package/dist/database/model.d.ts +81 -0
  40. package/dist/database/model.d.ts.map +1 -0
  41. package/dist/database/model.js +686 -0
  42. package/dist/database/model.js.map +1 -0
  43. package/dist/database/query-builder.d.ts +136 -0
  44. package/dist/database/query-builder.d.ts.map +1 -0
  45. package/dist/database/query-builder.js +248 -0
  46. package/dist/database/query-builder.js.map +1 -0
  47. package/dist/database/utils.d.ts +196 -0
  48. package/dist/database/utils.d.ts.map +1 -0
  49. package/dist/database/utils.js +372 -0
  50. package/dist/database/utils.js.map +1 -0
  51. package/dist/index.cjs +2286 -0
  52. package/dist/index.cjs.map +7 -0
  53. package/dist/index.js +2240 -0
  54. package/dist/index.js.map +7 -0
  55. package/package.json +52 -0
  56. package/types/index.d.ts +732 -0
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025 Thomas Drouvin
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,74 @@
1
+ # @coherent.js/database
2
+
3
+ [![npm version](https://img.shields.io/npm/v/@coherent.js/database.svg)](https://www.npmjs.com/package/@coherent.js/database)
4
+ [![license: MIT](https://img.shields.io/badge/license-MIT-blue.svg)](../../LICENSE)
5
+ [![Node >= 20](https://img.shields.io/badge/node-%3E%3D20-brightgreen)](https://nodejs.org)
6
+
7
+ Database utilities and adapters for Coherent.js.
8
+
9
+ - ESM-only, Node 20+
10
+ - Optional adapters for popular databases
11
+ - Designed to pair with `@coherent.js/core` and server frameworks
12
+
13
+ For a high-level overview and repository-wide instructions, see the root README: ../../README.md
14
+
15
+ ## Installation
16
+
17
+ ```bash
18
+ pnpm add @coherent.js/database
19
+ ```
20
+
21
+ Optional peer dependencies (install as needed):
22
+ - `sqlite3` (optional)
23
+
24
+ ## Quick start
25
+
26
+ JavaScript (ESM):
27
+ ```js
28
+ // Import utilities from the package's public entry once you enable a specific adapter
29
+ import db from '@coherent.js/database';
30
+
31
+ // Example sketch: connect and query (adapter-specific APIs vary)
32
+ async function example() {
33
+ // const conn = await db.connect({ url: process.env.DATABASE_URL });
34
+ // const rows = await conn.query('select 1');
35
+ }
36
+ ```
37
+
38
+ TypeScript:
39
+ ```ts
40
+ import db from '@coherent.js/database';
41
+
42
+ async function example(): Promise<void> {
43
+ // const conn = await db.connect({ url: process.env.DATABASE_URL! });
44
+ // const rows = await conn.query('select 1');
45
+ }
46
+ ```
47
+
48
+ Note: This package exposes a set of adapters and helpers. Refer to the repository docs and examples for concrete adapter APIs.
49
+
50
+ ## Development
51
+
52
+ Run tests for this package:
53
+ ```bash
54
+ pnpm --filter @coherent.js/database run test
55
+ ```
56
+
57
+ Watch mode:
58
+ ```bash
59
+ pnpm --filter @coherent.js/database run test:watch
60
+ ```
61
+
62
+ Type check:
63
+ ```bash
64
+ pnpm --filter @coherent.js/database run typecheck
65
+ ```
66
+
67
+ Build:
68
+ ```bash
69
+ pnpm --filter @coherent.js/database run build
70
+ ```
71
+
72
+ ## License
73
+
74
+ MIT © Coherent.js Team
@@ -0,0 +1,48 @@
1
+ /**
2
+ * In-Memory Database Adapter for Coherent.js
3
+ *
4
+ * @fileoverview In-memory adapter for development and testing purposes.
5
+ * Provides a simple, non-persistent storage solution.
6
+ */
7
+ /**
8
+ * In-Memory Database Adapter
9
+ *
10
+ * @class MemoryAdapter
11
+ * @description Provides in-memory database operations with a simple key-value store.
12
+ */
13
+ export class MemoryAdapter {
14
+ stores: Map<any, any>;
15
+ /**
16
+ * Create a new in-memory store
17
+ *
18
+ * @param {Object} config - Store configuration
19
+ * @returns {Promise<Object>} Store instance
20
+ */
21
+ createPool(config: Object): Promise<Object>;
22
+ /**
23
+ * Get a store by name
24
+ *
25
+ * @param {string} name - Store name
26
+ * @returns {Object|undefined} Store instance or undefined if not found
27
+ */
28
+ getStore(name?: string): Object | undefined;
29
+ /**
30
+ * Close all stores and clean up
31
+ *
32
+ * @returns {Promise<void>}
33
+ */
34
+ close(): Promise<void>;
35
+ /**
36
+ * Close the connection pool
37
+ * @param {Object} pool - The connection pool to close
38
+ * @returns {Promise<void>}
39
+ */
40
+ closePool(pool: Object): Promise<void>;
41
+ /**
42
+ * Execute a transaction
43
+ * @param {Function} callback - Transaction callback
44
+ * @returns {Promise<*>} Result of the transaction
45
+ */
46
+ transaction(callback: Function): Promise<any>;
47
+ }
48
+ //# sourceMappingURL=memory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"memory.d.ts","sourceRoot":"","sources":["../../../../../src/database/adapters/memory.js"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH;;;;;GAKG;AACH;IAEI,sBAAuB;IAGzB;;;;;OAKG;IACH,mBAHW,MAAM,GACJ,OAAO,CAAC,MAAM,CAAC,CAgM3B;IAED;;;;;OAKG;IACH,gBAHW,MAAM,GACJ,MAAM,GAAC,SAAS,CAI5B;IAED;;;;OAIG;IACH,SAFa,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;;OAIG;IACH,gBAHW,MAAM,GACJ,OAAO,CAAC,IAAI,CAAC,CAezB;IAED;;;;OAIG;IACH,iCAFa,OAAO,CAAC,GAAC,CAAC,CActB;CACF"}
@@ -0,0 +1,250 @@
1
+ /**
2
+ * In-Memory Database Adapter for Coherent.js
3
+ *
4
+ * @fileoverview In-memory adapter for development and testing purposes.
5
+ * Provides a simple, non-persistent storage solution.
6
+ */
7
+ /**
8
+ * In-Memory Database Adapter
9
+ *
10
+ * @class MemoryAdapter
11
+ * @description Provides in-memory database operations with a simple key-value store.
12
+ */
13
+ export class MemoryAdapter {
14
+ constructor() {
15
+ this.stores = new Map();
16
+ }
17
+ /**
18
+ * Create a new in-memory store
19
+ *
20
+ * @param {Object} config - Store configuration
21
+ * @returns {Promise<Object>} Store instance
22
+ */
23
+ async createPool(config) {
24
+ const collections = new Map();
25
+ const schemas = new Map();
26
+ const store = {
27
+ config,
28
+ stats: {
29
+ created: Date.now(),
30
+ operations: 0,
31
+ collections: 0,
32
+ queries: 0
33
+ },
34
+ /**
35
+ * Get a collection by name
36
+ * @private
37
+ */
38
+ _getCollection(name) {
39
+ if (!collections.has(name)) {
40
+ collections.set(name, new Map());
41
+ }
42
+ return collections.get(name);
43
+ },
44
+ /**
45
+ * Get schema for a collection
46
+ * @private
47
+ */
48
+ _getSchema(collectionName) {
49
+ return schemas.get(collectionName) || {};
50
+ },
51
+ /**
52
+ * Execute a query
53
+ * @param {string} operation - Operation type
54
+ * @param {Object} params - Query parameters
55
+ * @returns {Promise<*>} Query result
56
+ */
57
+ async query(operation, params = {}) {
58
+ this.stats.operations++;
59
+ this.stats.queries++;
60
+ const { table, where = {}, data, limit, offset, orderBy } = params;
61
+ const collection = this._getCollection(table);
62
+ switch (operation.toUpperCase()) {
63
+ case 'FIND': {
64
+ let results = Array.from(collection.values());
65
+ // Apply WHERE conditions
66
+ if (Object.keys(where).length > 0) {
67
+ results = results.filter(item => Object.entries(where).every(([key, value]) => {
68
+ if (value === undefined)
69
+ return true;
70
+ if (value === null)
71
+ return item[key] === null;
72
+ return JSON.stringify(item[key]) === JSON.stringify(value);
73
+ }));
74
+ }
75
+ // Apply ORDER BY
76
+ if (orderBy) {
77
+ let field, direction;
78
+ if (Array.isArray(orderBy)) {
79
+ [field, direction = 'ASC'] = orderBy;
80
+ }
81
+ else if (typeof orderBy === 'object') {
82
+ const entries = Object.entries(orderBy);
83
+ if (entries.length > 0) {
84
+ [field, direction] = entries[0];
85
+ }
86
+ }
87
+ else {
88
+ field = orderBy;
89
+ direction = 'ASC';
90
+ }
91
+ if (field) {
92
+ const _dir = direction.toLowerCase();
93
+ results.sort((a, b) => {
94
+ if (a[field] < b[field])
95
+ return dir === 'asc' ? -1 : 1;
96
+ if (a[field] > b[field])
97
+ return dir === 'asc' ? 1 : -1;
98
+ return 0;
99
+ });
100
+ }
101
+ }
102
+ // Apply OFFSET and LIMIT
103
+ if (offset)
104
+ results = results.slice(offset);
105
+ if (limit)
106
+ results = results.slice(0, limit);
107
+ return results;
108
+ }
109
+ case 'INSERT': {
110
+ if (!data)
111
+ throw new Error('No data provided for insert');
112
+ const id = data.id || Date.now().toString(36) + Math.random().toString(36).substr(2);
113
+ const record = { ...data, id };
114
+ collection.set(id, record);
115
+ this.stats.collections = collections.size;
116
+ return { id };
117
+ }
118
+ case 'UPDATE': {
119
+ if (!data)
120
+ throw new Error('No data provided for update');
121
+ const records = await this.query('FIND', { table, where });
122
+ const updated = [];
123
+ for (const record of records) {
124
+ const updatedRecord = { ...record, ...data };
125
+ collection.set(record.id, updatedRecord);
126
+ updated.push(updatedRecord);
127
+ }
128
+ return { affectedRows: updated.length };
129
+ }
130
+ case 'DELETE': {
131
+ const records = await this.query('FIND', { table, where });
132
+ const deleted = [];
133
+ for (const record of records) {
134
+ if (collection.delete(record.id)) {
135
+ deleted.push(record);
136
+ }
137
+ }
138
+ return { affectedRows: deleted.length };
139
+ }
140
+ case 'COUNT': {
141
+ const results = await this.query('FIND', { table, where });
142
+ return { count: results.length };
143
+ }
144
+ case 'CREATE_COLLECTION': {
145
+ const { name, schema } = params;
146
+ schemas.set(name, schema || {});
147
+ return { success: true };
148
+ }
149
+ case 'SET_SCHEMA': {
150
+ const { model, schema } = params;
151
+ schemas.set(model, schema);
152
+ return { success: true };
153
+ }
154
+ default:
155
+ throw new Error(`Unsupported operation: ${operation}`);
156
+ }
157
+ },
158
+ /**
159
+ * Get store statistics
160
+ * @returns {Object}
161
+ */
162
+ getStats() {
163
+ return {
164
+ ...this.stats,
165
+ uptime: Date.now() - this.stats.created,
166
+ collections: collections.size,
167
+ operations: this.stats.operations,
168
+ queries: this.stats.queries
169
+ };
170
+ },
171
+ /**
172
+ * Execute a transaction
173
+ * @param {Function} callback - Transaction callback
174
+ * @returns {Promise<*>} Result of the transaction
175
+ */
176
+ async transaction(callback) {
177
+ // In a real implementation, this would track changes and rollback on error
178
+ // For this simple implementation, we'll just execute the callback
179
+ try {
180
+ const result = await callback({
181
+ query: (operation, params) => this.query(operation, params)
182
+ });
183
+ return result;
184
+ }
185
+ catch (error) {
186
+ // In a real implementation, we would rollback changes here
187
+ throw error;
188
+ }
189
+ }
190
+ };
191
+ this.stores.set(config.name || 'default', store);
192
+ return store;
193
+ }
194
+ /**
195
+ * Get a store by name
196
+ *
197
+ * @param {string} name - Store name
198
+ * @returns {Object|undefined} Store instance or undefined if not found
199
+ */
200
+ getStore(name = 'default') {
201
+ return this.stores.get(name);
202
+ }
203
+ /**
204
+ * Close all stores and clean up
205
+ *
206
+ * @returns {Promise<void>}
207
+ */
208
+ async close() {
209
+ this.stores.clear();
210
+ }
211
+ /**
212
+ * Close the connection pool
213
+ * @param {Object} pool - The connection pool to close
214
+ * @returns {Promise<void>}
215
+ */
216
+ async closePool(pool) {
217
+ // For in-memory adapter, we don't need to do anything special to close the pool
218
+ // Just clear any references to allow garbage collection
219
+ if (pool) {
220
+ // Clear any collections or other resources if needed
221
+ if (pool.collections) {
222
+ pool.collections.clear();
223
+ }
224
+ if (pool.schemas) {
225
+ pool.schemas.clear();
226
+ }
227
+ }
228
+ return Promise.resolve();
229
+ }
230
+ /**
231
+ * Execute a transaction
232
+ * @param {Function} callback - Transaction callback
233
+ * @returns {Promise<*>} Result of the transaction
234
+ */
235
+ async transaction(callback) {
236
+ // In a real implementation, this would track changes and rollback on error
237
+ // For this simple implementation, we'll just execute the callback
238
+ try {
239
+ const result = await callback({
240
+ query: (operation, params) => this.query(operation, params)
241
+ });
242
+ return result;
243
+ }
244
+ catch (error) {
245
+ // In a real implementation, we would rollback changes here
246
+ throw error;
247
+ }
248
+ }
249
+ }
250
+ //# sourceMappingURL=memory.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"memory.js","sourceRoot":"","sources":["../../../../../src/database/adapters/memory.js"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ /**
2
+ * MongoDB Database Adapter for Coherent.js
3
+ *
4
+ * @fileoverview MongoDB adapter implementation with connection pooling and document operations.
5
+ */
6
+ /**
7
+ * Create a new MongoDB adapter instance
8
+ *
9
+ * @returns {Object} MongoDB adapter instance with database operations
10
+ */
11
+ export function createMongoDBAdapter(): Object;
12
+ export namespace MongoDBAdapter {
13
+ export { createMongoDBAdapter as create };
14
+ }
15
+ //# sourceMappingURL=mongodb.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mongodb.d.ts","sourceRoot":"","sources":["../../../../../src/database/adapters/mongodb.js"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH;;;;GAIG;AACH,wCAFa,MAAM,CA8NlB"}
@@ -0,0 +1,216 @@
1
+ /**
2
+ * MongoDB Database Adapter for Coherent.js
3
+ *
4
+ * @fileoverview MongoDB adapter implementation with connection pooling and document operations.
5
+ */
6
+ /**
7
+ * Create a new MongoDB adapter instance
8
+ *
9
+ * @returns {Object} MongoDB adapter instance with database operations
10
+ */
11
+ export function createMongoDBAdapter() {
12
+ let mongodb = null;
13
+ let client = null;
14
+ let db = null;
15
+ /**
16
+ * Initialize MongoDB module
17
+ *
18
+ * @private
19
+ * @returns {Promise<void>}
20
+ */
21
+ async function initializeMongoDB() {
22
+ if (!mongodb) {
23
+ try {
24
+ const mongoModule = await import('mongodb');
25
+ mongodb = mongoModule;
26
+ }
27
+ catch {
28
+ throw new Error('Failed to load mongodb module. Make sure to install it: npm install mongodb');
29
+ }
30
+ }
31
+ }
32
+ /**
33
+ * Connect to the database
34
+ *
35
+ * @param {Object} config - Database configuration
36
+ * @param {string} config.url - MongoDB connection URL
37
+ * @param {string} config.database - Database name
38
+ * @param {Object} [config.options] - MongoDB client options
39
+ * @returns {Promise<Object>} The database adapter instance
40
+ */
41
+ async function connect(config) {
42
+ await initializeMongoDB();
43
+ try {
44
+ client = new mongodb.MongoClient(config.url, config.options || {});
45
+ await client.connect();
46
+ db = client.db(config.database);
47
+ return instance;
48
+ }
49
+ catch (error) {
50
+ throw new Error(`Failed to connect to MongoDB: ${error.message}`);
51
+ }
52
+ }
53
+ /**
54
+ * Execute a query on a collection
55
+ *
56
+ * @param {string} collectionName - Name of the collection
57
+ * @param {Object} query - Query object
58
+ * @param {Object} [options] - Query options
59
+ * @returns {Promise<Array<Object>>} Query results
60
+ */
61
+ async function query(collectionName, query = {}, options = {}) {
62
+ if (!db) {
63
+ throw new Error('Database connection not established. Call connect() first.');
64
+ }
65
+ try {
66
+ const collection = db.collection(collectionName);
67
+ const cursor = collection.find(query, options);
68
+ if (options.sort) {
69
+ cursor.sort(options.sort);
70
+ }
71
+ if (options.limit) {
72
+ cursor.limit(options.limit);
73
+ }
74
+ if (options.skip) {
75
+ cursor.skip(options.skip);
76
+ }
77
+ if (options.projection) {
78
+ cursor.project(options.projection);
79
+ }
80
+ return cursor.toArray();
81
+ }
82
+ catch (error) {
83
+ throw new Error(`MongoDB query error: ${error.message}`);
84
+ }
85
+ }
86
+ /**
87
+ * Execute a database command
88
+ *
89
+ * @param {Object} command - Database command
90
+ * @returns {Promise<Object>} Command result
91
+ */
92
+ async function execute(command) {
93
+ if (!db) {
94
+ throw new Error('Database connection not established. Call connect() first.');
95
+ }
96
+ try {
97
+ return await db.command(command);
98
+ }
99
+ catch (error) {
100
+ throw new Error(`MongoDB command error: ${error.message}`);
101
+ }
102
+ }
103
+ /**
104
+ * Begin a transaction
105
+ *
106
+ * @returns {Promise<Object>} Session object for the transaction
107
+ */
108
+ async function beginTransaction() {
109
+ if (!client) {
110
+ throw new Error('Database connection not established. Call connect() first.');
111
+ }
112
+ const session = client.startSession();
113
+ session.startTransaction();
114
+ return session;
115
+ }
116
+ /**
117
+ * Commit a transaction
118
+ *
119
+ * @param {Object} session - The session object from beginTransaction
120
+ * @returns {Promise<void>}
121
+ */
122
+ async function commit(session) {
123
+ if (!session) {
124
+ throw new Error('No active transaction session');
125
+ }
126
+ try {
127
+ await session.commitTransaction();
128
+ }
129
+ finally {
130
+ await session.endSession();
131
+ }
132
+ }
133
+ /**
134
+ * Rollback a transaction
135
+ *
136
+ * @param {Object} session - The session object from beginTransaction
137
+ * @returns {Promise<void>}
138
+ */
139
+ async function rollback(session) {
140
+ if (!session) {
141
+ throw new Error('No active transaction session');
142
+ }
143
+ try {
144
+ await session.abortTransaction();
145
+ }
146
+ finally {
147
+ await session.endSession();
148
+ }
149
+ }
150
+ /**
151
+ * Disconnect from the database
152
+ *
153
+ * @returns {Promise<void>}
154
+ */
155
+ async function disconnect() {
156
+ if (client) {
157
+ await client.close();
158
+ client = null;
159
+ db = null;
160
+ }
161
+ }
162
+ /**
163
+ * Get the underlying database connection
164
+ *
165
+ * @returns {Object} The database connection
166
+ */
167
+ function getConnection() {
168
+ if (!db) {
169
+ throw new Error('Database connection not established. Call connect() first.');
170
+ }
171
+ return db;
172
+ }
173
+ /**
174
+ * Ping the database to check if connection is alive
175
+ *
176
+ * @returns {Promise<boolean>} True if connection is alive
177
+ */
178
+ async function ping() {
179
+ try {
180
+ await db.command({ ping: 1 });
181
+ return true;
182
+ }
183
+ catch {
184
+ return false;
185
+ }
186
+ }
187
+ /**
188
+ * Escape a value for MongoDB queries
189
+ *
190
+ * @param {*} value - Value to escape
191
+ * @returns {*} Escaped value
192
+ */
193
+ function escape(value) {
194
+ // MongoDB driver handles escaping internally
195
+ return value;
196
+ }
197
+ // Public API
198
+ const instance = {
199
+ connect,
200
+ query,
201
+ execute,
202
+ beginTransaction,
203
+ commit,
204
+ rollback,
205
+ disconnect,
206
+ getConnection,
207
+ ping,
208
+ escape,
209
+ // Alias for backward compatibility
210
+ run: execute
211
+ };
212
+ return instance;
213
+ }
214
+ // For backward compatibility
215
+ export const MongoDBAdapter = { create: createMongoDBAdapter };
216
+ //# sourceMappingURL=mongodb.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mongodb.js","sourceRoot":"","sources":["../../../../../src/database/adapters/mongodb.js"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH;;;;GAIG;AACH,MAAM,UAAU,oBAAoB;IAClC,IAAI,OAAO,GAAG,IAAI,CAAC;IACnB,IAAI,MAAM,GAAG,IAAI,CAAC;IAClB,IAAI,EAAE,GAAG,IAAI,CAAC;IAEd;;;;;OAKG;IACH,KAAK,UAAU,iBAAiB;QAC9B,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,IAAI,CAAC;gBACH,MAAM,WAAW,GAAG,MAAM,MAAM,CAAC,SAAS,CAAC,CAAC;gBAC5C,OAAO,GAAG,WAAW,CAAC;YACxB,CAAC;YAAC,MAAM,CAAC;gBACP,MAAM,IAAI,KAAK,CAAC,6EAA6E,CAAC,CAAC;YACjG,CAAC;QACH,CAAC;IACH,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,UAAU,OAAO,CAAC,MAAM;QAC3B,MAAM,iBAAiB,EAAE,CAAC;QAE1B,IAAI,CAAC;YACH,MAAM,GAAG,IAAI,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC;YACnE,MAAM,MAAM,CAAC,OAAO,EAAE,CAAC;YACvB,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YAChC,OAAO,QAAQ,CAAC;QAClB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,iCAAiC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;QACpE,CAAC;IACH,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,UAAU,KAAK,CAAC,cAAc,EAAE,KAAK,GAAG,EAAE,EAAE,OAAO,GAAG,EAAE;QAC3D,IAAI,CAAC,EAAE,EAAE,CAAC;YACR,MAAM,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAC;QAChF,CAAC;QAED,IAAI,CAAC;YACH,MAAM,UAAU,GAAG,EAAE,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;YACjD,MAAM,MAAM,GAAG,UAAU,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;YAE/C,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;gBACjB,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YAC5B,CAAC;YAED,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;gBAClB,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YAC9B,CAAC;YAED,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;gBACjB,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YAC5B,CAAC;YAED,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;gBACvB,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;YACrC,CAAC;YAED,OAAO,MAAM,CAAC,OAAO,EAAE,CAAC;QAC1B,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,wBAAwB,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;QAC3D,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,KAAK,UAAU,OAAO,CAAC,OAAO;QAC5B,IAAI,CAAC,EAAE,EAAE,CAAC;YACR,MAAM,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAC;QAChF,CAAC;QAED,IAAI,CAAC;YACH,OAAO,MAAM,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QACnC,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,0BAA0B,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;QAC7D,CAAC;IACH,CAAC;IAED;;;;OAIG;IACH,KAAK,UAAU,gBAAgB;QAC7B,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAC;QAChF,CAAC;QAED,MAAM,OAAO,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QACtC,OAAO,CAAC,gBAAgB,EAAE,CAAC;QAC3B,OAAO,OAAO,CAAC;IACjB,CAAC;IAED;;;;;OAKG;IACH,KAAK,UAAU,MAAM,CAAC,OAAO;QAC3B,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;QACnD,CAAC;QAED,IAAI,CAAC;YACH,MAAM,OAAO,CAAC,iBAAiB,EAAE,CAAC;QACpC,CAAC;gBAAS,CAAC;YACT,MAAM,OAAO,CAAC,UAAU,EAAE,CAAC;QAC7B,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,KAAK,UAAU,QAAQ,CAAC,OAAO;QAC7B,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;QACnD,CAAC;QAED,IAAI,CAAC;YACH,MAAM,OAAO,CAAC,gBAAgB,EAAE,CAAC;QACnC,CAAC;gBAAS,CAAC;YACT,MAAM,OAAO,CAAC,UAAU,EAAE,CAAC;QAC7B,CAAC;IACH,CAAC;IAED;;;;OAIG;IACH,KAAK,UAAU,UAAU;QACvB,IAAI,MAAM,EAAE,CAAC;YACX,MAAM,MAAM,CAAC,KAAK,EAAE,CAAC;YACrB,MAAM,GAAG,IAAI,CAAC;YACd,EAAE,GAAG,IAAI,CAAC;QACZ,CAAC;IACH,CAAC;IAED;;;;OAIG;IACH,SAAS,aAAa;QACpB,IAAI,CAAC,EAAE,EAAE,CAAC;YACR,MAAM,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAC;QAChF,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED;;;;OAIG;IACH,KAAK,UAAU,IAAI;QACjB,IAAI,CAAC;YACH,MAAM,EAAE,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC;YAC9B,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,SAAS,MAAM,CAAC,KAAK;QACnB,6CAA6C;QAC7C,OAAO,KAAK,CAAC;IACf,CAAC;IAED,aAAa;IACb,MAAM,QAAQ,GAAG;QACf,OAAO;QACP,KAAK;QACL,OAAO;QACP,gBAAgB;QAChB,MAAM;QACN,QAAQ;QACR,UAAU;QACV,aAAa;QACb,IAAI;QACJ,MAAM;QAEN,mCAAmC;QACnC,GAAG,EAAE,OAAO;KACb,CAAC;IAEF,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,6BAA6B;AAC7B,MAAM,CAAC,MAAM,cAAc,GAAG,EAAE,MAAM,EAAE,oBAAoB,EAAE,CAAC"}
@@ -0,0 +1,12 @@
1
+ /**
2
+ * MySQL Database Adapter for Coherent.js
3
+ *
4
+ * @fileoverview MySQL adapter implementation with connection pooling and transaction support.
5
+ */
6
+ /**
7
+ * Create MySQL adapter instance
8
+ *
9
+ * @returns {Object} MySQL adapter instance
10
+ */
11
+ export function createMySQLAdapter(): Object;
12
+ //# sourceMappingURL=mysql.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.d.ts","sourceRoot":"","sources":["../../../../../src/database/adapters/mysql.js"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH;;;;GAIG;AACH,sCAFa,MAAM,CAmLlB"}