toridb 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md ADDED
@@ -0,0 +1,129 @@
1
+ # ToriDB Client for Node.js
2
+
3
+ A powerful, high-performance Node.js client for **ToriDB**. Supports Key-Value operations, NoSQL data structures, and a fluent SQL-like relational API.
4
+
5
+ ## 📚 Documentation
6
+
7
+ You can read the basic documentation here: [**/doc**](./doc/)
8
+
9
+ or more detailed here: [**DeepWiki**](https://deepwiki.com/UnSetSoft/ToriDB)
10
+
11
+ ## Installation
12
+
13
+ ```bash
14
+ npm install toridb
15
+ ```
16
+
17
+ ## Quick Start
18
+
19
+ ```javascript
20
+ const { ToriDB } = require('toridb');
21
+
22
+ // Initialize client (use environment variables for sensitive data!)
23
+ const db = new ToriDB(process.env.TORIDB_URI || "db://127.0.0.1:8569");
24
+
25
+ async function main() {
26
+ await db.connect();
27
+
28
+ // Simple Key-Value
29
+ await db.set("greeting", "Hello ToriDB!");
30
+ const val = await db.get("greeting");
31
+ console.log(val); // "Hello ToriDB!"
32
+
33
+ await db.disconnect();
34
+ }
35
+
36
+ main();
37
+ ```
38
+
39
+ ## Features
40
+
41
+ ### 🔑 Key-Value & TTL
42
+ ```javascript
43
+ await db.set("user:1", { name: "Alice" });
44
+ await db.get("user:1");
45
+
46
+ await db.setEx("session:temp", "data", 3600); // 1 hour TTL
47
+ await db.ttl("session:temp");
48
+
49
+ await db.incr("page_views");
50
+ await db.decr("inventory:stock");
51
+ ```
52
+
53
+ ### 📦 NoSQL Data Structures
54
+
55
+ #### Lists
56
+ ```javascript
57
+ const myList = db.list("tasks");
58
+ await myList.push("task1", "task2");
59
+ await myList.pop();
60
+ const items = await myList.range(0, -1);
61
+ ```
62
+
63
+ #### Sets
64
+ ```javascript
65
+ const mySet = db.setOf("tags");
66
+ await mySet.add("nodejs", "database");
67
+ const members = await mySet.members();
68
+ ```
69
+
70
+ #### Hashes
71
+ ```javascript
72
+ const myHash = db.hash("user:meta");
73
+ await myHash.set("theme", "dark");
74
+ const theme = await myHash.get("theme");
75
+ const all = await myHash.all();
76
+ ```
77
+
78
+ #### JSON
79
+ ```javascript
80
+ const myJson = db.json("config");
81
+ await myJson.set("$", { port: 8080, debug: true });
82
+ const port = await myJson.get("$.port");
83
+ ```
84
+
85
+ ### 📊 Relational-like Modeling & SQL Queries
86
+
87
+ Define blueprints and use a fluent API to perform complex queries.
88
+
89
+ ```javascript
90
+ const users = db.model("users", new ToriDB.Blueprint({
91
+ id: "int primary key",
92
+ name: "text",
93
+ age: "int",
94
+ data: "json"
95
+ }));
96
+
97
+ // Create
98
+ await users.create({ id: 1, name: "Tori", age: 5, data: { breed: "Shiba" } });
99
+
100
+ // Fluent Querying
101
+ const results = await users.find({ age: { ">": 3 } })
102
+ .select(["name", "age"])
103
+ .orderBy("age", "desc")
104
+ .limit(10)
105
+ .execute();
106
+
107
+ // Direct Table Query
108
+ const logs = db.table("system_logs").find({ level: "error" }).execute();
109
+ ```
110
+
111
+ ### 🛡️ System & ACL Management
112
+ ```javascript
113
+ // ACL (Never hardcode passwords!)
114
+ // WARNING: "@all" grants full administrative access.
115
+ await db.system.acl.createUser("admin_user", process.env.DB_PASS, ["@all"]);
116
+
117
+ // Create a restricted user instead
118
+ await db.system.acl.createUser("app_user", process.env.APP_PASS, ["+get", "+set"]);
119
+
120
+ // Cluster & Replication
121
+ await db.system.cluster.info();
122
+ await db.system.replication.slaveOf("192.168.1.10", 8569);
123
+
124
+ // Server Info
125
+ const info = await db.system.info();
126
+ ```
127
+
128
+ ## License
129
+ UPL-1.0
@@ -0,0 +1,682 @@
1
+ import require$$0 from 'net';
2
+
3
+ function getDefaultExportFromCjs (x) {
4
+ return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, 'default') ? x['default'] : x;
5
+ }
6
+
7
+ /**
8
+ * High-Performance RESP (REdis Serialization Protocol) Parser
9
+ * Handles Simple Strings, Errors, Integers, Bulk Strings, and Nested Arrays.
10
+ */
11
+
12
+ var resp;
13
+ var hasRequiredResp;
14
+
15
+ function requireResp () {
16
+ if (hasRequiredResp) return resp;
17
+ hasRequiredResp = 1;
18
+ class RespParser {
19
+ constructor() {
20
+ this.reset();
21
+ }
22
+
23
+ reset() {
24
+ this.buffer = Buffer.alloc(0);
25
+ }
26
+
27
+ feed(data) {
28
+ this.buffer = Buffer.concat([this.buffer, data]);
29
+ }
30
+
31
+ /**
32
+ * Tries to parse the next complete RESP value from the buffer.
33
+ * @returns {any | undefined} The parsed value or undefined if incomplete.
34
+ */
35
+ parseNext() {
36
+ if (this.buffer.length === 0) return undefined;
37
+
38
+ const result = this._decode(0);
39
+ if (result) {
40
+ this.buffer = this.buffer.slice(result.bytesRead);
41
+ return result.value;
42
+ }
43
+ return undefined;
44
+ }
45
+
46
+ _decode(offset) {
47
+ if (offset >= this.buffer.length) return null;
48
+
49
+ const prefix = this.buffer[offset];
50
+ const lineEnd = this.buffer.indexOf('\r\n', offset);
51
+ if (lineEnd === -1) return null;
52
+
53
+ const content = this.buffer.slice(offset + 1, lineEnd).toString();
54
+ const bytesBeforeData = lineEnd - offset + 2;
55
+
56
+ switch (prefix) {
57
+ case 43: // '+' Simple String
58
+ return { value: content, bytesRead: bytesBeforeData };
59
+
60
+ case 45: // '-' Error
61
+ return { value: new Error(content), bytesRead: bytesBeforeData };
62
+
63
+ case 58: // ':' Integer
64
+ return { value: parseInt(content, 10), bytesRead: bytesBeforeData };
65
+
66
+ case 36: { // '$' Bulk String
67
+ const length = parseInt(content, 10);
68
+ if (length === -1) return { value: null, bytesRead: bytesBeforeData };
69
+
70
+ const dataEnd = lineEnd + 2 + length;
71
+ if (this.buffer.length < dataEnd + 2) return null;
72
+
73
+ const value = this.buffer.slice(lineEnd + 2, dataEnd).toString();
74
+ // Verify CRLF
75
+ if (this.buffer[dataEnd] !== 13 || this.buffer[dataEnd + 1] !== 10) {
76
+ throw new Error("Invalid Bulk String terminator");
77
+ }
78
+ return { value, bytesRead: bytesBeforeData + length + 2 };
79
+ }
80
+
81
+ case 42: { // '*' Array
82
+ const count = parseInt(content, 10);
83
+ if (count === -1) return { value: null, bytesRead: bytesBeforeData };
84
+ if (count === 0) return { value: [], bytesRead: bytesBeforeData };
85
+
86
+ let totalRead = bytesBeforeData;
87
+ const items = [];
88
+ for (let i = 0; i < count; i++) {
89
+ const item = this._decode(offset + totalRead);
90
+ if (!item) return null;
91
+ items.push(item.value);
92
+ totalRead += item.bytesRead;
93
+ }
94
+ return { value: items, bytesRead: totalRead };
95
+ }
96
+
97
+ default:
98
+ // Attempt to handle unexpected data as a simple string line
99
+ return { value: content, bytesRead: bytesBeforeData };
100
+ }
101
+ }
102
+
103
+ /**
104
+ * Serializes a command into a RESP Array.
105
+ * @param {string[]} args
106
+ */
107
+ static encode(args) {
108
+ let res = `*${args.length}\r\n`;
109
+ for (const arg of args) {
110
+ const s = String(arg);
111
+ res += `$${Buffer.byteLength(s)}\r\n${s}\r\n`;
112
+ }
113
+ return Buffer.from(res);
114
+ }
115
+ }
116
+
117
+ resp = { RespParser };
118
+ return resp;
119
+ }
120
+
121
+ /**
122
+ * Command Compiler: Translates JS Objects and Types to ToriDB DSL
123
+ */
124
+
125
+ var compiler;
126
+ var hasRequiredCompiler;
127
+
128
+ function requireCompiler () {
129
+ if (hasRequiredCompiler) return compiler;
130
+ hasRequiredCompiler = 1;
131
+ class Compiler {
132
+ /**
133
+ * Translates a JS Object to a ToriDB Filter string.
134
+ * { age: { $gt: 18 }, status: 'active' } -> "age > 18 AND status = 'active'"
135
+ */
136
+ static compileFilter(filter) {
137
+ if (!filter || typeof filter !== 'object') return "";
138
+
139
+ const parts = [];
140
+ for (const [key, value] of Object.entries(filter)) {
141
+ if (key === '$or' && Array.isArray(value)) {
142
+ parts.push(`(${value.map(f => this.compileFilter(f)).join(" OR ")})`);
143
+ } else if (key === '$and' && Array.isArray(value)) {
144
+ parts.push(`(${value.map(f => this.compileFilter(f)).join(" AND ")})`);
145
+ } else if (typeof value === 'object' && value !== null) {
146
+ // Handle operators: { $gt: 10 }
147
+ for (const [op, val] of Object.entries(value)) {
148
+ const symbol = this._mapOperator(op);
149
+ parts.push(`${key} ${symbol} ${this._escape(val)}`);
150
+ }
151
+ } else {
152
+ // Basic equality
153
+ parts.push(`${key} = ${this._escape(value)}`);
154
+ }
155
+ }
156
+ return parts.join(" AND ");
157
+ }
158
+
159
+ /**
160
+ * Translates a Blueprint definition to ToriDB Table Definition format.
161
+ * { id: { type: 'INT', primary: true }, user_id: { type: 'INT', references: 'users.id' } }
162
+ * -> "id:INT:pk user_id:INT:fk(users.id)"
163
+ */
164
+ static compileBlueprint(name, blueprint) {
165
+ const cols = [];
166
+ for (const [colName, config] of Object.entries(blueprint)) {
167
+ let type = typeof config === 'string' ? config : config.type;
168
+ let pk = (config.primary || config.is_pk) ? ":pk" : "";
169
+ let fk = "";
170
+
171
+ if (config.references) {
172
+ const [refTable, refCol] = config.references.split('.');
173
+ fk = `:fk(${refTable}.${refCol})`;
174
+ }
175
+
176
+ // Auto-map JS types if not specified as SQL types
177
+ if (type === 'Number') type = 'INT';
178
+ if (type === 'String') type = 'STRING';
179
+ if (type === 'Object') type = 'JSON';
180
+ if (type === 'Boolean') type = 'BOOL';
181
+
182
+ cols.push(`${colName}:${type}${pk}${fk}`);
183
+ }
184
+ return `CREATE TABLE ${name} ${cols.join(" ")}`;
185
+ }
186
+
187
+ static _mapOperator(op) {
188
+ const maps = {
189
+ '$gt': '>', '$gte': '>=', '$lt': '<', '$lte': '<=',
190
+ '$ne': '!=', '$eq': '=', '$like': 'LIKE', '$in': 'IN'
191
+ };
192
+ return maps[op] || op;
193
+ }
194
+
195
+ static _escape(val) {
196
+ if (typeof val === 'string') {
197
+ // If it's a list for IN operator, don't wrap the whole thing in quotes
198
+ // but wrap individual elements if they are strings.
199
+ // However, the server's IN expects (val1,val2)
200
+ return `"${val.replace(/"/g, '\\"')}"`;
201
+ }
202
+ if (Array.isArray(val)) {
203
+ return `(${val.map(v => this._escape(v)).join(",")})`;
204
+ }
205
+ if (typeof val === 'object' && val !== null) return `"${JSON.stringify(val).replace(/"/g, '\\"')}"`;
206
+ return String(val);
207
+ }
208
+ }
209
+
210
+ compiler = { Compiler };
211
+ return compiler;
212
+ }
213
+
214
+ var sdk$1;
215
+ var hasRequiredSdk;
216
+
217
+ function requireSdk () {
218
+ if (hasRequiredSdk) return sdk$1;
219
+ hasRequiredSdk = 1;
220
+ const net = require$$0;
221
+ const { RespParser } = requireResp();
222
+ const { Compiler } = requireCompiler();
223
+
224
+ /**
225
+ * Main client class for interacting with ToriDB.
226
+ * Supports Key-Value, NoSQL structures (List, Set, Hash, JSON), and Relational modeling.
227
+ */
228
+ class ToriDB {
229
+ /**
230
+ * Represents a database schema definition.
231
+ */
232
+ static Blueprint = class {
233
+ /**
234
+ * @param {Object} definition - The schema definition object.
235
+ */
236
+ constructor(definition) {
237
+ this.definition = definition;
238
+ }
239
+ };
240
+
241
+ /**
242
+ * Creates a new ToriDB client instance.
243
+ * @param {string} [uri="db://127.0.0.1:8569"] - Connection URI (e.g., db://user:pass@host:port/db)
244
+ */
245
+ constructor(uri = "db://127.0.0.1:8569") {
246
+ this.host = "127.0.0.1";
247
+ this.port = 8569;
248
+ this.user = "default";
249
+ this.password = null;
250
+ this._parseUri(uri);
251
+
252
+ this.parser = new RespParser();
253
+ this.socket = new net.Socket();
254
+ this.isConnected = false;
255
+ this.pendingRequests = [];
256
+
257
+ this._setupSocket();
258
+
259
+ // Managers
260
+ this.system = new SystemManager(this);
261
+ }
262
+
263
+ /**
264
+ * Parses the connection URI.
265
+ * @param {string} uri - The connection URI to parse.
266
+ * @private
267
+ */
268
+ _parseUri(uri) {
269
+ const regex = /^db:\/\/(?:(?:([^:]+):([^@+]+)[@+])?)([^:/\?]+)(?::(\d+))?(?:(?:\/([^?]+))?)?/;
270
+ const match = uri.match(regex);
271
+ if (match) {
272
+ this.user = match[1] || "default";
273
+ this.password = match[2] || null;
274
+ this.host = match[3];
275
+ this.port = parseInt(match[4], 10) || 8569;
276
+ }
277
+ }
278
+
279
+ /**
280
+ * Sets up socket events for data handling, errors, and closure.
281
+ * @private
282
+ */
283
+ _setupSocket() {
284
+ this.socket.on('data', (data) => {
285
+ this.parser.feed(data);
286
+ let response;
287
+ while ((response = this.parser.parseNext()) !== undefined) {
288
+ const req = this.pendingRequests.shift();
289
+ if (req) {
290
+ if (response instanceof Error) req.reject(response);
291
+ else req.resolve(response);
292
+ }
293
+ }
294
+ });
295
+
296
+ this.socket.on('error', (err) => {
297
+ this.isConnected = false;
298
+ this.pendingRequests.forEach(req => req.reject(err));
299
+ this.pendingRequests = [];
300
+ });
301
+
302
+ this.socket.on('close', () => {
303
+ this.isConnected = false;
304
+ });
305
+ }
306
+
307
+ /**
308
+ * Establishes a connection to the ToriDB server.
309
+ * @returns {Promise<void>}
310
+ * @throws {Error} If connection or authentication fails.
311
+ */
312
+ async connect() {
313
+ if (this.isConnected) return;
314
+ return new Promise((resolve, reject) => {
315
+ this.socket.connect(this.port, this.host, async () => {
316
+ this.isConnected = true;
317
+ if (this.password) {
318
+ try {
319
+ await this.execute("AUTH", this.user, this.password);
320
+ } catch (e) {
321
+ this.disconnect();
322
+ return reject(new Error(`Authentication failed: ${e.message}`));
323
+ }
324
+ }
325
+ resolve();
326
+ });
327
+ this.socket.once('error', reject);
328
+ });
329
+ }
330
+
331
+ /**
332
+ * Disconnects from the ToriDB server.
333
+ */
334
+ disconnect() {
335
+ this.socket.destroy();
336
+ this.isConnected = false;
337
+ }
338
+
339
+ /**
340
+ * Executes a command on the ToriDB server.
341
+ * @param {...any} args - Command arguments.
342
+ * @returns {Promise<any>} The server response.
343
+ */
344
+ async execute(...args) {
345
+ if (!this.isConnected) await this.connect();
346
+ return new Promise((resolve, reject) => {
347
+ this.pendingRequests.push({ resolve, reject });
348
+ this.socket.write(RespParser.encode(args));
349
+ });
350
+ }
351
+
352
+ /**
353
+ * Executes a raw query string.
354
+ * @param {string} s - The query string.
355
+ * @returns {Promise<any>}
356
+ */
357
+ async query(s) {
358
+ return this.execute(...s.match(/(?:[^\s"]+|"[^"]*")+/g).map(p => p.replace(/"/g, '')));
359
+ }
360
+
361
+ // --- Key-Value & TTL ---
362
+ /**
363
+ * Retrieves the value of a key.
364
+ * @param {string} key - The key to get.
365
+ * @returns {Promise<any>}
366
+ */
367
+ async get(key) { return this.execute("GET", key); }
368
+
369
+ /**
370
+ * Sets the value of a key.
371
+ * @param {string} key - The key to set.
372
+ * @param {any} val - The value to store (objects are JSON-stringified).
373
+ * @returns {Promise<string>} OK on success.
374
+ */
375
+ async set(key, val) {
376
+ const s = typeof val === 'object' ? JSON.stringify(val) : String(val);
377
+ return this.execute("SET", key, s);
378
+ }
379
+ /**
380
+ * Sets the value of a key with an expiration time.
381
+ * @param {string} key - The key to set.
382
+ * @param {any} val - The value to store.
383
+ * @param {number} ttl - Time to live in seconds.
384
+ * @returns {Promise<string>} OK on success.
385
+ */
386
+ async setEx(key, val, ttl) {
387
+ const s = typeof val === 'object' ? JSON.stringify(val) : String(val);
388
+ return this.execute("SETEX", key, s, String(ttl));
389
+ }
390
+ /**
391
+ * Gets the remaining time to live of a key.
392
+ * @param {string} key - The key.
393
+ * @returns {Promise<number>} TTL in seconds, or -1 if no TTL, or -2 if key doesn't exist.
394
+ */
395
+ async ttl(key) { return this.execute("TTL", key); }
396
+
397
+ /**
398
+ * Increments the integer value of a key by one.
399
+ * @param {string} key - The key to increment.
400
+ * @returns {Promise<number>} The value after increment.
401
+ */
402
+ async incr(key) { return this.execute("INCR", key); }
403
+
404
+ /**
405
+ * Decrements the integer value of a key by one.
406
+ * @param {string} key - The key to decrement.
407
+ * @returns {Promise<number>} The value after decrement.
408
+ */
409
+ async decr(key) { return this.execute("DECR", key); }
410
+
411
+ // --- NoSQL Structures ---
412
+ /**
413
+ * Accesses list operations for a given key.
414
+ * @param {string} key - The list key.
415
+ * @returns {Object} An object with list operations (push, rpush, pop, rpop, range).
416
+ */
417
+ list(key) {
418
+ return {
419
+ push: (...vals) => this.execute("LPUSH", key, ...vals.map(String)),
420
+ rpush: (...vals) => this.execute("RPUSH", key, ...vals.map(String)),
421
+ pop: (count = 1) => this.execute("LPOP", key, String(count)),
422
+ rpop: (count = 1) => this.execute("RPOP", key, String(count)),
423
+ range: (start, stop) => this.execute("LRANGE", key, String(start), String(stop))
424
+ };
425
+ }
426
+
427
+ /**
428
+ * Accesses set operations for a given key.
429
+ * @param {string} key - The set key.
430
+ * @returns {Object} An object with set operations (add, members).
431
+ */
432
+ setOf(key) {
433
+ return {
434
+ add: (...members) => this.execute("SADD", key, ...members.map(String)),
435
+ members: () => this.execute("SMEMBERS", key)
436
+ };
437
+ }
438
+
439
+ /**
440
+ * Accesses hash operations for a given key.
441
+ * @param {string} key - The hash key.
442
+ * @returns {Object} An object with hash operations (set, get, all).
443
+ */
444
+ hash(key) {
445
+ return {
446
+ set: (field, val) => this.execute("HSET", key, field, String(val)),
447
+ get: (field) => this.execute("HGET", key, field),
448
+ all: () => this.execute("HGETALL", key)
449
+ };
450
+ }
451
+
452
+ /**
453
+ * Accesses sorted set operations for a given key.
454
+ * @param {string} key - The sorted set key.
455
+ * @returns {Object} An object with sorted set operations (add, range, score).
456
+ */
457
+ sortedSet(key) {
458
+ return {
459
+ add: (score, member) => this.execute("ZADD", key, String(score), member),
460
+ range: (start, stop) => this.execute("ZRANGE", key, String(start), String(stop)),
461
+ score: (member) => this.execute("ZSCORE", key, member)
462
+ };
463
+ }
464
+
465
+ /**
466
+ * Accesses JSON operations for a given key.
467
+ * @param {string} key - The JSON key.
468
+ * @returns {Object} An object with JSON operations (get, set).
469
+ */
470
+ json(key) {
471
+ return {
472
+ get: (path = "$") => this.execute("JSON.GET", key, path),
473
+ set: (path, val) => {
474
+ const s = typeof val === 'object' ? JSON.stringify(val) : JSON.stringify(val);
475
+ return this.execute("JSON.SET", key, path, s);
476
+ }
477
+ };
478
+ }
479
+
480
+ // --- Relational (Models) ---
481
+ /**
482
+ * Defines or accesses a model for relational-like operations.
483
+ * @param {string} name - The model name (table name).
484
+ * @param {ToriDB.Blueprint} blueprint - The schema definition.
485
+ * @returns {Object} An object with model operations (create, find, findById, update, delete, etc.).
486
+ */
487
+ model(name, blueprint) {
488
+ const createCmd = Compiler.compileBlueprint(name, blueprint.definition);
489
+ this.execute(...createCmd.match(/(?:[^\s"]+|"[^"]*")+/g).map(p => p.replace(/"/g, ''))).catch(() => { });
490
+
491
+ return {
492
+ create: (data) => this.execute("INSERT", name, ...Object.values(data).map(v => typeof v === 'object' ? JSON.stringify(v) : String(v))),
493
+ find: (filter) => new QueryBuilder(this, name, filter),
494
+ findById: (id) => new QueryBuilder(this, name, { id }).execute().then(r => r[0] || null),
495
+ update: (filter, data) => {
496
+ const where = Compiler.compileFilter(filter);
497
+ const [col, val] = Object.entries(data)[0];
498
+ const sVal = typeof val === 'object' ? JSON.stringify(val) : String(val);
499
+ return this.execute("UPDATE", name, "SET", col, "=", sVal, "WHERE", where);
500
+ },
501
+ delete: (filter) => this.execute("DELETE", "FROM", name, "WHERE", Compiler.compileFilter(filter)),
502
+ createIndex: (idxName, col) => this.execute("CREATE", "INDEX", idxName, "ON", name, `(${col})`),
503
+ addColumn: (col, type) => this.execute("ALTER", "TABLE", name, "ADD", `${col}:${type}`),
504
+ dropColumn: (col) => this.execute("ALTER", "TABLE", name, "DROP", col)
505
+ };
506
+ }
507
+
508
+ /**
509
+ * Accesses a table for query operations.
510
+ * @param {string} name - The table name.
511
+ * @returns {Object} An object with a find method.
512
+ */
513
+ table(name) {
514
+ return { find: (filter) => new QueryBuilder(this, name, filter) };
515
+ }
516
+ }
517
+
518
+ /**
519
+ * Manager for system-level operations (ACL, Cluster, Replication, etc.).
520
+ */
521
+ class SystemManager {
522
+ /**
523
+ * @param {ToriDB} client - The ToriDB client instance.
524
+ */
525
+ constructor(client) { this.client = client; }
526
+
527
+ /**
528
+ * Retrieves server information and statistics.
529
+ * @returns {Promise<string>}
530
+ */
531
+ async info() { return this.client.execute("INFO"); }
532
+
533
+ /**
534
+ * Synchronously saves the dataset to disk.
535
+ * @returns {Promise<string>}
536
+ */
537
+ async save() { return this.client.execute("SAVE"); }
538
+
539
+ /**
540
+ * Triggers an AOF rewrite in the background.
541
+ * @returns {Promise<string>}
542
+ */
543
+ async rewriteAof() { return this.client.execute("REWRITEAOF"); }
544
+
545
+ /**
546
+ * Accesses ACL (Access Control List) operations.
547
+ * @returns {Object} An object with ACL operations (createUser, getUser, listUsers, deleteUser).
548
+ */
549
+ get acl() {
550
+ return {
551
+ createUser: (u, p, rules) => this.client.execute("ACL", "SETUSER", u, p, ...rules),
552
+ getUser: (u) => this.client.execute("ACL", "GETUSER", u),
553
+ listUsers: () => this.client.execute("ACL", "LIST"),
554
+ deleteUser: (u) => this.client.execute("ACL", "DELUSER", u)
555
+ };
556
+ }
557
+
558
+ /**
559
+ * Accesses cluster management operations.
560
+ * @returns {Object} An object with cluster operations (meet, slots, info).
561
+ */
562
+ get cluster() {
563
+ return {
564
+ meet: (h, p) => this.client.execute("CLUSTER", "MEET", h, String(p)),
565
+ slots: () => this.client.execute("CLUSTER", "SLOTS"),
566
+ info: () => this.client.execute("CLUSTER", "INFO")
567
+ };
568
+ }
569
+
570
+ /**
571
+ * Accesses replication management operations.
572
+ * @returns {Object} An object with replication operations (slaveOf, stop).
573
+ */
574
+ get replication() {
575
+ return {
576
+ slaveOf: (h, p) => this.client.execute("REPLICAOF", h, String(p)),
577
+ stop: () => this.client.execute("REPLICAOF", "NO", "ONE")
578
+ };
579
+ }
580
+
581
+ /**
582
+ * Accesses client management operations.
583
+ * @returns {Object} An object with client operations (list, kill).
584
+ */
585
+ get clients() {
586
+ return {
587
+ list: () => this.client.execute("CLIENT", "LIST"),
588
+ kill: (addr) => this.client.execute("CLIENT", "KILL", addr)
589
+ };
590
+ }
591
+ }
592
+
593
+ /**
594
+ * Helper class for building and executing SQL-like queries.
595
+ */
596
+ class QueryBuilder {
597
+ /**
598
+ * @param {ToriDB} client - The ToriDB client instance.
599
+ * @param {string} target - The table or model name.
600
+ * @param {Object} [filter={}] - Initial filter object.
601
+ */
602
+ constructor(client, target, filter = {}) {
603
+ this.client = client;
604
+ this.target = target;
605
+ this.params = {
606
+ filter: Compiler.compileFilter(filter),
607
+ limit: null,
608
+ offset: null,
609
+ orderBy: null,
610
+ groupBy: null,
611
+ select: "*"
612
+ };
613
+ }
614
+
615
+ /**
616
+ * Specifies the fields to select.
617
+ * @param {string|string[]|Object} fields - Fields to select.
618
+ * @returns {QueryBuilder} This instance for chaining.
619
+ */
620
+ select(fields) {
621
+ if (typeof fields === 'string') this.params.select = fields;
622
+ else if (Array.isArray(fields)) this.params.select = fields.join(", ");
623
+ else if (typeof fields === 'object') {
624
+ this.params.select = Object.entries(fields).map(([k, v]) => `${v} AS ${k}`).join(", ");
625
+ }
626
+ return this;
627
+ }
628
+
629
+ /**
630
+ * Limits the number of results.
631
+ * @param {number} n - The limit count.
632
+ * @returns {QueryBuilder} This instance for chaining.
633
+ */
634
+ limit(n) { this.params.limit = n; return this; }
635
+
636
+ /**
637
+ * Offsets the results.
638
+ * @param {number} n - The offset count.
639
+ * @returns {QueryBuilder} This instance for chaining.
640
+ */
641
+ offset(n) { this.params.offset = n; return this; }
642
+
643
+ /**
644
+ * Orders the results by a column.
645
+ * @param {string} col - The column name.
646
+ * @param {string} [dir="ASC"] - Sort direction (ASC or DESC).
647
+ * @returns {QueryBuilder} This instance for chaining.
648
+ */
649
+ orderBy(col, dir = "ASC") { this.params.orderBy = `${col} ${dir.toUpperCase()}`; return this; }
650
+
651
+ /**
652
+ * Groups the results by columns.
653
+ * @param {string|string[]} cols - The columns to group by.
654
+ * @returns {QueryBuilder} This instance for chaining.
655
+ */
656
+ groupBy(cols) { this.params.groupBy = Array.isArray(cols) ? cols.join(", ") : cols; return this; }
657
+
658
+ /**
659
+ * Compiles and executes the query.
660
+ * @returns {Promise<any[]>} The query results.
661
+ */
662
+ async execute() {
663
+ const args = ["SELECT", this.params.select, "FROM", this.target];
664
+ if (this.params.filter) { args.push("WHERE"); args.push(this.params.filter); }
665
+ if (this.params.groupBy) { args.push("GROUP"); args.push("BY"); args.push(this.params.groupBy); }
666
+ if (this.params.orderBy) { args.push("ORDER"); args.push("BY"); args.push(this.params.orderBy); }
667
+ if (this.params.limit) { args.push("LIMIT"); args.push(String(this.params.limit)); }
668
+ if (this.params.offset) { args.push("OFFSET"); args.push(String(this.params.offset)); }
669
+
670
+ return this.client.execute(...args);
671
+ }
672
+ }
673
+
674
+ sdk$1 = { ToriDB };
675
+ return sdk$1;
676
+ }
677
+
678
+ var sdkExports = requireSdk();
679
+ var sdk = /*@__PURE__*/getDefaultExportFromCjs(sdkExports);
680
+
681
+ export { sdk as default };
682
+ //# sourceMappingURL=toridb.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toridb.esm.js","sources":["../src/resp.js","../src/compiler.js","../src/sdk.js","../src/sdk.js?commonjs-entry"],"sourcesContent":["/**\r\n * High-Performance RESP (REdis Serialization Protocol) Parser\r\n * Handles Simple Strings, Errors, Integers, Bulk Strings, and Nested Arrays.\r\n */\r\nclass RespParser {\r\n constructor() {\r\n this.reset();\r\n }\r\n\r\n reset() {\r\n this.buffer = Buffer.alloc(0);\r\n }\r\n\r\n feed(data) {\r\n this.buffer = Buffer.concat([this.buffer, data]);\r\n }\r\n\r\n /**\r\n * Tries to parse the next complete RESP value from the buffer.\r\n * @returns {any | undefined} The parsed value or undefined if incomplete.\r\n */\r\n parseNext() {\r\n if (this.buffer.length === 0) return undefined;\r\n\r\n const result = this._decode(0);\r\n if (result) {\r\n this.buffer = this.buffer.slice(result.bytesRead);\r\n return result.value;\r\n }\r\n return undefined;\r\n }\r\n\r\n _decode(offset) {\r\n if (offset >= this.buffer.length) return null;\r\n\r\n const prefix = this.buffer[offset];\r\n const lineEnd = this.buffer.indexOf('\\r\\n', offset);\r\n if (lineEnd === -1) return null;\r\n\r\n const content = this.buffer.slice(offset + 1, lineEnd).toString();\r\n const bytesBeforeData = lineEnd - offset + 2;\r\n\r\n switch (prefix) {\r\n case 43: // '+' Simple String\r\n return { value: content, bytesRead: bytesBeforeData };\r\n\r\n case 45: // '-' Error\r\n return { value: new Error(content), bytesRead: bytesBeforeData };\r\n\r\n case 58: // ':' Integer\r\n return { value: parseInt(content, 10), bytesRead: bytesBeforeData };\r\n\r\n case 36: { // '$' Bulk String\r\n const length = parseInt(content, 10);\r\n if (length === -1) return { value: null, bytesRead: bytesBeforeData };\r\n \r\n const dataEnd = lineEnd + 2 + length;\r\n if (this.buffer.length < dataEnd + 2) return null;\r\n \r\n const value = this.buffer.slice(lineEnd + 2, dataEnd).toString();\r\n // Verify CRLF\r\n if (this.buffer[dataEnd] !== 13 || this.buffer[dataEnd + 1] !== 10) {\r\n throw new Error(\"Invalid Bulk String terminator\");\r\n }\r\n return { value, bytesRead: bytesBeforeData + length + 2 };\r\n }\r\n\r\n case 42: { // '*' Array\r\n const count = parseInt(content, 10);\r\n if (count === -1) return { value: null, bytesRead: bytesBeforeData };\r\n if (count === 0) return { value: [], bytesRead: bytesBeforeData };\r\n\r\n let totalRead = bytesBeforeData;\r\n const items = [];\r\n for (let i = 0; i < count; i++) {\r\n const item = this._decode(offset + totalRead);\r\n if (!item) return null;\r\n items.push(item.value);\r\n totalRead += item.bytesRead;\r\n }\r\n return { value: items, bytesRead: totalRead };\r\n }\r\n\r\n default:\r\n // Attempt to handle unexpected data as a simple string line\r\n return { value: content, bytesRead: bytesBeforeData };\r\n }\r\n }\r\n\r\n /**\r\n * Serializes a command into a RESP Array.\r\n * @param {string[]} args \r\n */\r\n static encode(args) {\r\n let res = `*${args.length}\\r\\n`;\r\n for (const arg of args) {\r\n const s = String(arg);\r\n res += `$${Buffer.byteLength(s)}\\r\\n${s}\\r\\n`;\r\n }\r\n return Buffer.from(res);\r\n }\r\n}\r\n\r\nmodule.exports = { RespParser };\r\n","/**\r\n * Command Compiler: Translates JS Objects and Types to ToriDB DSL\r\n */\r\nclass Compiler {\r\n /**\r\n * Translates a JS Object to a ToriDB Filter string.\r\n * { age: { $gt: 18 }, status: 'active' } -> \"age > 18 AND status = 'active'\"\r\n */\r\n static compileFilter(filter) {\r\n if (!filter || typeof filter !== 'object') return \"\";\r\n\r\n const parts = [];\r\n for (const [key, value] of Object.entries(filter)) {\r\n if (key === '$or' && Array.isArray(value)) {\r\n parts.push(`(${value.map(f => this.compileFilter(f)).join(\" OR \")})`);\r\n } else if (key === '$and' && Array.isArray(value)) {\r\n parts.push(`(${value.map(f => this.compileFilter(f)).join(\" AND \")})`);\r\n } else if (typeof value === 'object' && value !== null) {\r\n // Handle operators: { $gt: 10 }\r\n for (const [op, val] of Object.entries(value)) {\r\n const symbol = this._mapOperator(op);\r\n parts.push(`${key} ${symbol} ${this._escape(val)}`);\r\n }\r\n } else {\r\n // Basic equality\r\n parts.push(`${key} = ${this._escape(value)}`);\r\n }\r\n }\r\n return parts.join(\" AND \");\r\n }\r\n\r\n /**\r\n * Translates a Blueprint definition to ToriDB Table Definition format.\r\n * { id: { type: 'INT', primary: true }, user_id: { type: 'INT', references: 'users.id' } }\r\n * -> \"id:INT:pk user_id:INT:fk(users.id)\"\r\n */\r\n static compileBlueprint(name, blueprint) {\r\n const cols = [];\r\n for (const [colName, config] of Object.entries(blueprint)) {\r\n let type = typeof config === 'string' ? config : config.type;\r\n let pk = (config.primary || config.is_pk) ? \":pk\" : \"\";\r\n let fk = \"\";\r\n\r\n if (config.references) {\r\n const [refTable, refCol] = config.references.split('.');\r\n fk = `:fk(${refTable}.${refCol})`;\r\n }\r\n\r\n // Auto-map JS types if not specified as SQL types\r\n if (type === 'Number') type = 'INT';\r\n if (type === 'String') type = 'STRING';\r\n if (type === 'Object') type = 'JSON';\r\n if (type === 'Boolean') type = 'BOOL';\r\n\r\n cols.push(`${colName}:${type}${pk}${fk}`);\r\n }\r\n return `CREATE TABLE ${name} ${cols.join(\" \")}`;\r\n }\r\n\r\n static _mapOperator(op) {\r\n const maps = {\r\n '$gt': '>', '$gte': '>=', '$lt': '<', '$lte': '<=',\r\n '$ne': '!=', '$eq': '=', '$like': 'LIKE', '$in': 'IN'\r\n };\r\n return maps[op] || op;\r\n }\r\n\r\n static _escape(val) {\r\n if (typeof val === 'string') {\r\n // If it's a list for IN operator, don't wrap the whole thing in quotes\r\n // but wrap individual elements if they are strings.\r\n // However, the server's IN expects (val1,val2)\r\n return `\"${val.replace(/\"/g, '\\\\\"')}\"`;\r\n }\r\n if (Array.isArray(val)) {\r\n return `(${val.map(v => this._escape(v)).join(\",\")})`;\r\n }\r\n if (typeof val === 'object' && val !== null) return `\"${JSON.stringify(val).replace(/\"/g, '\\\\\"')}\"`;\r\n return String(val);\r\n }\r\n}\r\n\r\nmodule.exports = { Compiler };\r\n","const net = require('net');\r\nconst { RespParser } = require('./resp');\r\nconst { Compiler } = require('./compiler');\r\n\r\n/**\r\n * Main client class for interacting with ToriDB.\r\n * Supports Key-Value, NoSQL structures (List, Set, Hash, JSON), and Relational modeling.\r\n */\r\nclass ToriDB {\r\n /**\r\n * Represents a database schema definition.\r\n */\r\n static Blueprint = class {\r\n /**\r\n * @param {Object} definition - The schema definition object.\r\n */\r\n constructor(definition) {\r\n this.definition = definition;\r\n }\r\n };\r\n\r\n /**\r\n * Creates a new ToriDB client instance.\r\n * @param {string} [uri=\"db://127.0.0.1:8569\"] - Connection URI (e.g., db://user:pass@host:port/db)\r\n */\r\n constructor(uri = \"db://127.0.0.1:8569\") {\r\n this.host = \"127.0.0.1\";\r\n this.port = 8569;\r\n this.user = \"default\";\r\n this.password = null;\r\n this._parseUri(uri);\r\n\r\n this.parser = new RespParser();\r\n this.socket = new net.Socket();\r\n this.isConnected = false;\r\n this.pendingRequests = [];\r\n\r\n this._setupSocket();\r\n\r\n // Managers\r\n this.system = new SystemManager(this);\r\n }\r\n\r\n /**\r\n * Parses the connection URI.\r\n * @param {string} uri - The connection URI to parse.\r\n * @private\r\n */\r\n _parseUri(uri) {\r\n const regex = /^db:\\/\\/(?:(?:([^:]+):([^@+]+)[@+])?)([^:/\\?]+)(?::(\\d+))?(?:(?:\\/([^?]+))?)?/;\r\n const match = uri.match(regex);\r\n if (match) {\r\n this.user = match[1] || \"default\";\r\n this.password = match[2] || null;\r\n this.host = match[3];\r\n this.port = parseInt(match[4], 10) || 8569;\r\n }\r\n }\r\n\r\n /**\r\n * Sets up socket events for data handling, errors, and closure.\r\n * @private\r\n */\r\n _setupSocket() {\r\n this.socket.on('data', (data) => {\r\n this.parser.feed(data);\r\n let response;\r\n while ((response = this.parser.parseNext()) !== undefined) {\r\n const req = this.pendingRequests.shift();\r\n if (req) {\r\n if (response instanceof Error) req.reject(response);\r\n else req.resolve(response);\r\n }\r\n }\r\n });\r\n\r\n this.socket.on('error', (err) => {\r\n this.isConnected = false;\r\n this.pendingRequests.forEach(req => req.reject(err));\r\n this.pendingRequests = [];\r\n });\r\n\r\n this.socket.on('close', () => {\r\n this.isConnected = false;\r\n });\r\n }\r\n\r\n /**\r\n * Establishes a connection to the ToriDB server.\r\n * @returns {Promise<void>}\r\n * @throws {Error} If connection or authentication fails.\r\n */\r\n async connect() {\r\n if (this.isConnected) return;\r\n return new Promise((resolve, reject) => {\r\n this.socket.connect(this.port, this.host, async () => {\r\n this.isConnected = true;\r\n if (this.password) {\r\n try {\r\n await this.execute(\"AUTH\", this.user, this.password);\r\n } catch (e) {\r\n this.disconnect();\r\n return reject(new Error(`Authentication failed: ${e.message}`));\r\n }\r\n }\r\n resolve();\r\n });\r\n this.socket.once('error', reject);\r\n });\r\n }\r\n\r\n /**\r\n * Disconnects from the ToriDB server.\r\n */\r\n disconnect() {\r\n this.socket.destroy();\r\n this.isConnected = false;\r\n }\r\n\r\n /**\r\n * Executes a command on the ToriDB server.\r\n * @param {...any} args - Command arguments.\r\n * @returns {Promise<any>} The server response.\r\n */\r\n async execute(...args) {\r\n if (!this.isConnected) await this.connect();\r\n return new Promise((resolve, reject) => {\r\n this.pendingRequests.push({ resolve, reject });\r\n this.socket.write(RespParser.encode(args));\r\n });\r\n }\r\n\r\n /**\r\n * Executes a raw query string.\r\n * @param {string} s - The query string.\r\n * @returns {Promise<any>}\r\n */\r\n async query(s) {\r\n return this.execute(...s.match(/(?:[^\\s\"]+|\"[^\"]*\")+/g).map(p => p.replace(/\"/g, '')));\r\n }\r\n\r\n // --- Key-Value & TTL ---\r\n /**\r\n * Retrieves the value of a key.\r\n * @param {string} key - The key to get.\r\n * @returns {Promise<any>}\r\n */\r\n async get(key) { return this.execute(\"GET\", key); }\r\n\r\n /**\r\n * Sets the value of a key.\r\n * @param {string} key - The key to set.\r\n * @param {any} val - The value to store (objects are JSON-stringified).\r\n * @returns {Promise<string>} OK on success.\r\n */\r\n async set(key, val) {\r\n const s = typeof val === 'object' ? JSON.stringify(val) : String(val);\r\n return this.execute(\"SET\", key, s);\r\n }\r\n /**\r\n * Sets the value of a key with an expiration time.\r\n * @param {string} key - The key to set.\r\n * @param {any} val - The value to store.\r\n * @param {number} ttl - Time to live in seconds.\r\n * @returns {Promise<string>} OK on success.\r\n */\r\n async setEx(key, val, ttl) {\r\n const s = typeof val === 'object' ? JSON.stringify(val) : String(val);\r\n return this.execute(\"SETEX\", key, s, String(ttl));\r\n }\r\n /**\r\n * Gets the remaining time to live of a key.\r\n * @param {string} key - The key.\r\n * @returns {Promise<number>} TTL in seconds, or -1 if no TTL, or -2 if key doesn't exist.\r\n */\r\n async ttl(key) { return this.execute(\"TTL\", key); }\r\n\r\n /**\r\n * Increments the integer value of a key by one.\r\n * @param {string} key - The key to increment.\r\n * @returns {Promise<number>} The value after increment.\r\n */\r\n async incr(key) { return this.execute(\"INCR\", key); }\r\n\r\n /**\r\n * Decrements the integer value of a key by one.\r\n * @param {string} key - The key to decrement.\r\n * @returns {Promise<number>} The value after decrement.\r\n */\r\n async decr(key) { return this.execute(\"DECR\", key); }\r\n\r\n // --- NoSQL Structures ---\r\n /**\r\n * Accesses list operations for a given key.\r\n * @param {string} key - The list key.\r\n * @returns {Object} An object with list operations (push, rpush, pop, rpop, range).\r\n */\r\n list(key) {\r\n return {\r\n push: (...vals) => this.execute(\"LPUSH\", key, ...vals.map(String)),\r\n rpush: (...vals) => this.execute(\"RPUSH\", key, ...vals.map(String)),\r\n pop: (count = 1) => this.execute(\"LPOP\", key, String(count)),\r\n rpop: (count = 1) => this.execute(\"RPOP\", key, String(count)),\r\n range: (start, stop) => this.execute(\"LRANGE\", key, String(start), String(stop))\r\n };\r\n }\r\n\r\n /**\r\n * Accesses set operations for a given key.\r\n * @param {string} key - The set key.\r\n * @returns {Object} An object with set operations (add, members).\r\n */\r\n setOf(key) {\r\n return {\r\n add: (...members) => this.execute(\"SADD\", key, ...members.map(String)),\r\n members: () => this.execute(\"SMEMBERS\", key)\r\n };\r\n }\r\n\r\n /**\r\n * Accesses hash operations for a given key.\r\n * @param {string} key - The hash key.\r\n * @returns {Object} An object with hash operations (set, get, all).\r\n */\r\n hash(key) {\r\n return {\r\n set: (field, val) => this.execute(\"HSET\", key, field, String(val)),\r\n get: (field) => this.execute(\"HGET\", key, field),\r\n all: () => this.execute(\"HGETALL\", key)\r\n };\r\n }\r\n\r\n /**\r\n * Accesses sorted set operations for a given key.\r\n * @param {string} key - The sorted set key.\r\n * @returns {Object} An object with sorted set operations (add, range, score).\r\n */\r\n sortedSet(key) {\r\n return {\r\n add: (score, member) => this.execute(\"ZADD\", key, String(score), member),\r\n range: (start, stop) => this.execute(\"ZRANGE\", key, String(start), String(stop)),\r\n score: (member) => this.execute(\"ZSCORE\", key, member)\r\n };\r\n }\r\n\r\n /**\r\n * Accesses JSON operations for a given key.\r\n * @param {string} key - The JSON key.\r\n * @returns {Object} An object with JSON operations (get, set).\r\n */\r\n json(key) {\r\n return {\r\n get: (path = \"$\") => this.execute(\"JSON.GET\", key, path),\r\n set: (path, val) => {\r\n const s = typeof val === 'object' ? JSON.stringify(val) : JSON.stringify(val);\r\n return this.execute(\"JSON.SET\", key, path, s);\r\n }\r\n };\r\n }\r\n\r\n // --- Relational (Models) ---\r\n /**\r\n * Defines or accesses a model for relational-like operations.\r\n * @param {string} name - The model name (table name).\r\n * @param {ToriDB.Blueprint} blueprint - The schema definition.\r\n * @returns {Object} An object with model operations (create, find, findById, update, delete, etc.).\r\n */\r\n model(name, blueprint) {\r\n const createCmd = Compiler.compileBlueprint(name, blueprint.definition);\r\n this.execute(...createCmd.match(/(?:[^\\s\"]+|\"[^\"]*\")+/g).map(p => p.replace(/\"/g, ''))).catch(() => { });\r\n\r\n return {\r\n create: (data) => this.execute(\"INSERT\", name, ...Object.values(data).map(v => typeof v === 'object' ? JSON.stringify(v) : String(v))),\r\n find: (filter) => new QueryBuilder(this, name, filter),\r\n findById: (id) => new QueryBuilder(this, name, { id }).execute().then(r => r[0] || null),\r\n update: (filter, data) => {\r\n const where = Compiler.compileFilter(filter);\r\n const [col, val] = Object.entries(data)[0];\r\n const sVal = typeof val === 'object' ? JSON.stringify(val) : String(val);\r\n return this.execute(\"UPDATE\", name, \"SET\", col, \"=\", sVal, \"WHERE\", where);\r\n },\r\n delete: (filter) => this.execute(\"DELETE\", \"FROM\", name, \"WHERE\", Compiler.compileFilter(filter)),\r\n createIndex: (idxName, col) => this.execute(\"CREATE\", \"INDEX\", idxName, \"ON\", name, `(${col})`),\r\n addColumn: (col, type) => this.execute(\"ALTER\", \"TABLE\", name, \"ADD\", `${col}:${type}`),\r\n dropColumn: (col) => this.execute(\"ALTER\", \"TABLE\", name, \"DROP\", col)\r\n };\r\n }\r\n\r\n /**\r\n * Accesses a table for query operations.\r\n * @param {string} name - The table name.\r\n * @returns {Object} An object with a find method.\r\n */\r\n table(name) {\r\n return { find: (filter) => new QueryBuilder(this, name, filter) };\r\n }\r\n}\r\n\r\n/**\r\n * Manager for system-level operations (ACL, Cluster, Replication, etc.).\r\n */\r\nclass SystemManager {\r\n /**\r\n * @param {ToriDB} client - The ToriDB client instance.\r\n */\r\n constructor(client) { this.client = client; }\r\n\r\n /**\r\n * Retrieves server information and statistics.\r\n * @returns {Promise<string>}\r\n */\r\n async info() { return this.client.execute(\"INFO\"); }\r\n\r\n /**\r\n * Synchronously saves the dataset to disk.\r\n * @returns {Promise<string>}\r\n */\r\n async save() { return this.client.execute(\"SAVE\"); }\r\n\r\n /**\r\n * Triggers an AOF rewrite in the background.\r\n * @returns {Promise<string>}\r\n */\r\n async rewriteAof() { return this.client.execute(\"REWRITEAOF\"); }\r\n\r\n /**\r\n * Accesses ACL (Access Control List) operations.\r\n * @returns {Object} An object with ACL operations (createUser, getUser, listUsers, deleteUser).\r\n */\r\n get acl() {\r\n return {\r\n createUser: (u, p, rules) => this.client.execute(\"ACL\", \"SETUSER\", u, p, ...rules),\r\n getUser: (u) => this.client.execute(\"ACL\", \"GETUSER\", u),\r\n listUsers: () => this.client.execute(\"ACL\", \"LIST\"),\r\n deleteUser: (u) => this.client.execute(\"ACL\", \"DELUSER\", u)\r\n };\r\n }\r\n\r\n /**\r\n * Accesses cluster management operations.\r\n * @returns {Object} An object with cluster operations (meet, slots, info).\r\n */\r\n get cluster() {\r\n return {\r\n meet: (h, p) => this.client.execute(\"CLUSTER\", \"MEET\", h, String(p)),\r\n slots: () => this.client.execute(\"CLUSTER\", \"SLOTS\"),\r\n info: () => this.client.execute(\"CLUSTER\", \"INFO\")\r\n };\r\n }\r\n\r\n /**\r\n * Accesses replication management operations.\r\n * @returns {Object} An object with replication operations (slaveOf, stop).\r\n */\r\n get replication() {\r\n return {\r\n slaveOf: (h, p) => this.client.execute(\"REPLICAOF\", h, String(p)),\r\n stop: () => this.client.execute(\"REPLICAOF\", \"NO\", \"ONE\")\r\n };\r\n }\r\n\r\n /**\r\n * Accesses client management operations.\r\n * @returns {Object} An object with client operations (list, kill).\r\n */\r\n get clients() {\r\n return {\r\n list: () => this.client.execute(\"CLIENT\", \"LIST\"),\r\n kill: (addr) => this.client.execute(\"CLIENT\", \"KILL\", addr)\r\n };\r\n }\r\n}\r\n\r\n/**\r\n * Helper class for building and executing SQL-like queries.\r\n */\r\nclass QueryBuilder {\r\n /**\r\n * @param {ToriDB} client - The ToriDB client instance.\r\n * @param {string} target - The table or model name.\r\n * @param {Object} [filter={}] - Initial filter object.\r\n */\r\n constructor(client, target, filter = {}) {\r\n this.client = client;\r\n this.target = target;\r\n this.params = {\r\n filter: Compiler.compileFilter(filter),\r\n limit: null,\r\n offset: null,\r\n orderBy: null,\r\n groupBy: null,\r\n select: \"*\"\r\n };\r\n }\r\n\r\n /**\r\n * Specifies the fields to select.\r\n * @param {string|string[]|Object} fields - Fields to select.\r\n * @returns {QueryBuilder} This instance for chaining.\r\n */\r\n select(fields) {\r\n if (typeof fields === 'string') this.params.select = fields;\r\n else if (Array.isArray(fields)) this.params.select = fields.join(\", \");\r\n else if (typeof fields === 'object') {\r\n this.params.select = Object.entries(fields).map(([k, v]) => `${v} AS ${k}`).join(\", \");\r\n }\r\n return this;\r\n }\r\n\r\n /**\r\n * Limits the number of results.\r\n * @param {number} n - The limit count.\r\n * @returns {QueryBuilder} This instance for chaining.\r\n */\r\n limit(n) { this.params.limit = n; return this; }\r\n\r\n /**\r\n * Offsets the results.\r\n * @param {number} n - The offset count.\r\n * @returns {QueryBuilder} This instance for chaining.\r\n */\r\n offset(n) { this.params.offset = n; return this; }\r\n\r\n /**\r\n * Orders the results by a column.\r\n * @param {string} col - The column name.\r\n * @param {string} [dir=\"ASC\"] - Sort direction (ASC or DESC).\r\n * @returns {QueryBuilder} This instance for chaining.\r\n */\r\n orderBy(col, dir = \"ASC\") { this.params.orderBy = `${col} ${dir.toUpperCase()}`; return this; }\r\n\r\n /**\r\n * Groups the results by columns.\r\n * @param {string|string[]} cols - The columns to group by.\r\n * @returns {QueryBuilder} This instance for chaining.\r\n */\r\n groupBy(cols) { this.params.groupBy = Array.isArray(cols) ? cols.join(\", \") : cols; return this; }\r\n\r\n /**\r\n * Compiles and executes the query.\r\n * @returns {Promise<any[]>} The query results.\r\n */\r\n async execute() {\r\n const args = [\"SELECT\", this.params.select, \"FROM\", this.target];\r\n if (this.params.filter) { args.push(\"WHERE\"); args.push(this.params.filter); }\r\n if (this.params.groupBy) { args.push(\"GROUP\"); args.push(\"BY\"); args.push(this.params.groupBy); }\r\n if (this.params.orderBy) { args.push(\"ORDER\"); args.push(\"BY\"); args.push(this.params.orderBy); }\r\n if (this.params.limit) { args.push(\"LIMIT\"); args.push(String(this.params.limit)); }\r\n if (this.params.offset) { args.push(\"OFFSET\"); args.push(String(this.params.offset)); }\r\n\r\n return this.client.execute(...args);\r\n }\r\n}\r\n\r\nmodule.exports = { ToriDB };\r\n","import { getDefaultExportFromCjs } from \"\u0000commonjsHelpers.js\";\nimport { __require as requireSdk } from \"E:\\\\proyects\\\\undb\\\\client\\\\src\\\\sdk.js\";\nvar sdkExports = requireSdk();\nexport { sdkExports as __moduleExports };\nexport default /*@__PURE__*/getDefaultExportFromCjs(sdkExports);"],"names":["require$$1","require$$2","sdk"],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,43 @@
1
+ {
2
+ "name": "toridb",
3
+ "version": "1.0.0",
4
+ "description": "ToriDB Client",
5
+ "main": "/dist/toridb.esm.js",
6
+ "scripts": {
7
+ "build": "rollup -c",
8
+ "prepublishOnly": "npm run build"
9
+ },
10
+ "files": [
11
+ "dist"
12
+ ],
13
+ "exports": {
14
+ ".": {
15
+ "import": "./dist/toridb.esm.js"
16
+ }
17
+ },
18
+ "type": "module",
19
+ "repository": {
20
+ "type": "git",
21
+ "url": "git+https://github.com/UnSetSoft/ToriDB.git"
22
+ },
23
+ "keywords": [
24
+ "nosql",
25
+ "sql",
26
+ "database"
27
+ ],
28
+ "author": "UnSetSoft",
29
+ "license": "UPL-1.0",
30
+ "bugs": {
31
+ "url": "https://github.com/UnSetSoft/ToriDB/issues"
32
+ },
33
+ "homepage": "https://github.com/UnSetSoft/ToriDB#readme",
34
+ "devDependencies": {
35
+ "@rollup/plugin-commonjs": "29.0.0",
36
+ "@rollup/plugin-node-resolve": "16.0.3",
37
+ "rollup": "4.56.0",
38
+ "standard-version": "9.5.0"
39
+ },
40
+ "engines": {
41
+ "node": ">=22"
42
+ }
43
+ }