@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.
- package/LICENSE +21 -0
- package/README.md +74 -0
- package/dist/database/adapters/memory.d.ts +48 -0
- package/dist/database/adapters/memory.d.ts.map +1 -0
- package/dist/database/adapters/memory.js +250 -0
- package/dist/database/adapters/memory.js.map +1 -0
- package/dist/database/adapters/mongodb.d.ts +15 -0
- package/dist/database/adapters/mongodb.d.ts.map +1 -0
- package/dist/database/adapters/mongodb.js +216 -0
- package/dist/database/adapters/mongodb.js.map +1 -0
- package/dist/database/adapters/mysql.d.ts +12 -0
- package/dist/database/adapters/mysql.d.ts.map +1 -0
- package/dist/database/adapters/mysql.js +171 -0
- package/dist/database/adapters/mysql.js.map +1 -0
- package/dist/database/adapters/postgresql.d.ts +12 -0
- package/dist/database/adapters/postgresql.d.ts.map +1 -0
- package/dist/database/adapters/postgresql.js +177 -0
- package/dist/database/adapters/postgresql.js.map +1 -0
- package/dist/database/adapters/sqlite.d.ts +15 -0
- package/dist/database/adapters/sqlite.d.ts.map +1 -0
- package/dist/database/adapters/sqlite.js +241 -0
- package/dist/database/adapters/sqlite.js.map +1 -0
- package/dist/database/connection-manager.d.ts +148 -0
- package/dist/database/connection-manager.d.ts.map +1 -0
- package/dist/database/connection-manager.js +377 -0
- package/dist/database/connection-manager.js.map +1 -0
- package/dist/database/index.d.ts +38 -0
- package/dist/database/index.d.ts.map +1 -0
- package/dist/database/index.js +63 -0
- package/dist/database/index.js.map +1 -0
- package/dist/database/middleware.d.ts +122 -0
- package/dist/database/middleware.d.ts.map +1 -0
- package/dist/database/middleware.js +403 -0
- package/dist/database/middleware.js.map +1 -0
- package/dist/database/migration.d.ts +168 -0
- package/dist/database/migration.d.ts.map +1 -0
- package/dist/database/migration.js +946 -0
- package/dist/database/migration.js.map +1 -0
- package/dist/database/model.d.ts +81 -0
- package/dist/database/model.d.ts.map +1 -0
- package/dist/database/model.js +686 -0
- package/dist/database/model.js.map +1 -0
- package/dist/database/query-builder.d.ts +136 -0
- package/dist/database/query-builder.d.ts.map +1 -0
- package/dist/database/query-builder.js +248 -0
- package/dist/database/query-builder.js.map +1 -0
- package/dist/database/utils.d.ts +196 -0
- package/dist/database/utils.d.ts.map +1 -0
- package/dist/database/utils.js +372 -0
- package/dist/database/utils.js.map +1 -0
- package/dist/index.cjs +2286 -0
- package/dist/index.cjs.map +7 -0
- package/dist/index.js +2240 -0
- package/dist/index.js.map +7 -0
- package/package.json +52 -0
- 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
|
+
[](https://www.npmjs.com/package/@coherent.js/database)
|
|
4
|
+
[](../../LICENSE)
|
|
5
|
+
[](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":"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"}
|
|
@@ -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"}
|