@push.rocks/smartdb 1.0.1

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 (112) hide show
  1. package/.smartconfig.json +38 -0
  2. package/dist_ts/00_commitinfo_data.d.ts +8 -0
  3. package/dist_ts/00_commitinfo_data.js +9 -0
  4. package/dist_ts/index.d.ts +5 -0
  5. package/dist_ts/index.js +8 -0
  6. package/dist_ts/ts_local/classes.localsmartdb.d.ts +78 -0
  7. package/dist_ts/ts_local/classes.localsmartdb.js +115 -0
  8. package/dist_ts/ts_local/index.d.ts +2 -0
  9. package/dist_ts/ts_local/index.js +2 -0
  10. package/dist_ts/ts_local/plugins.d.ts +2 -0
  11. package/dist_ts/ts_local/plugins.js +3 -0
  12. package/dist_ts/ts_smartdb/engine/AggregationEngine.d.ts +66 -0
  13. package/dist_ts/ts_smartdb/engine/AggregationEngine.js +189 -0
  14. package/dist_ts/ts_smartdb/engine/IndexEngine.d.ts +97 -0
  15. package/dist_ts/ts_smartdb/engine/IndexEngine.js +678 -0
  16. package/dist_ts/ts_smartdb/engine/QueryEngine.d.ts +54 -0
  17. package/dist_ts/ts_smartdb/engine/QueryEngine.js +271 -0
  18. package/dist_ts/ts_smartdb/engine/QueryPlanner.d.ts +64 -0
  19. package/dist_ts/ts_smartdb/engine/QueryPlanner.js +308 -0
  20. package/dist_ts/ts_smartdb/engine/SessionEngine.d.ts +117 -0
  21. package/dist_ts/ts_smartdb/engine/SessionEngine.js +232 -0
  22. package/dist_ts/ts_smartdb/engine/TransactionEngine.d.ts +85 -0
  23. package/dist_ts/ts_smartdb/engine/TransactionEngine.js +287 -0
  24. package/dist_ts/ts_smartdb/engine/UpdateEngine.d.ts +47 -0
  25. package/dist_ts/ts_smartdb/engine/UpdateEngine.js +461 -0
  26. package/dist_ts/ts_smartdb/errors/SmartdbErrors.d.ts +100 -0
  27. package/dist_ts/ts_smartdb/errors/SmartdbErrors.js +155 -0
  28. package/dist_ts/ts_smartdb/index.d.ts +26 -0
  29. package/dist_ts/ts_smartdb/index.js +31 -0
  30. package/dist_ts/ts_smartdb/plugins.d.ts +10 -0
  31. package/dist_ts/ts_smartdb/plugins.js +14 -0
  32. package/dist_ts/ts_smartdb/server/CommandRouter.d.ts +87 -0
  33. package/dist_ts/ts_smartdb/server/CommandRouter.js +222 -0
  34. package/dist_ts/ts_smartdb/server/SmartdbServer.d.ts +102 -0
  35. package/dist_ts/ts_smartdb/server/SmartdbServer.js +279 -0
  36. package/dist_ts/ts_smartdb/server/WireProtocol.d.ts +117 -0
  37. package/dist_ts/ts_smartdb/server/WireProtocol.js +298 -0
  38. package/dist_ts/ts_smartdb/server/handlers/AdminHandler.d.ts +100 -0
  39. package/dist_ts/ts_smartdb/server/handlers/AdminHandler.js +668 -0
  40. package/dist_ts/ts_smartdb/server/handlers/AggregateHandler.d.ts +31 -0
  41. package/dist_ts/ts_smartdb/server/handlers/AggregateHandler.js +277 -0
  42. package/dist_ts/ts_smartdb/server/handlers/DeleteHandler.d.ts +8 -0
  43. package/dist_ts/ts_smartdb/server/handlers/DeleteHandler.js +95 -0
  44. package/dist_ts/ts_smartdb/server/handlers/FindHandler.d.ts +31 -0
  45. package/dist_ts/ts_smartdb/server/handlers/FindHandler.js +291 -0
  46. package/dist_ts/ts_smartdb/server/handlers/HelloHandler.d.ts +11 -0
  47. package/dist_ts/ts_smartdb/server/handlers/HelloHandler.js +62 -0
  48. package/dist_ts/ts_smartdb/server/handlers/IndexHandler.d.ts +20 -0
  49. package/dist_ts/ts_smartdb/server/handlers/IndexHandler.js +183 -0
  50. package/dist_ts/ts_smartdb/server/handlers/InsertHandler.d.ts +8 -0
  51. package/dist_ts/ts_smartdb/server/handlers/InsertHandler.js +79 -0
  52. package/dist_ts/ts_smartdb/server/handlers/UpdateHandler.d.ts +24 -0
  53. package/dist_ts/ts_smartdb/server/handlers/UpdateHandler.js +296 -0
  54. package/dist_ts/ts_smartdb/server/handlers/index.d.ts +8 -0
  55. package/dist_ts/ts_smartdb/server/handlers/index.js +10 -0
  56. package/dist_ts/ts_smartdb/server/index.d.ts +6 -0
  57. package/dist_ts/ts_smartdb/server/index.js +7 -0
  58. package/dist_ts/ts_smartdb/storage/FileStorageAdapter.d.ts +85 -0
  59. package/dist_ts/ts_smartdb/storage/FileStorageAdapter.js +465 -0
  60. package/dist_ts/ts_smartdb/storage/IStorageAdapter.d.ts +145 -0
  61. package/dist_ts/ts_smartdb/storage/IStorageAdapter.js +2 -0
  62. package/dist_ts/ts_smartdb/storage/MemoryStorageAdapter.d.ts +67 -0
  63. package/dist_ts/ts_smartdb/storage/MemoryStorageAdapter.js +378 -0
  64. package/dist_ts/ts_smartdb/storage/OpLog.d.ts +93 -0
  65. package/dist_ts/ts_smartdb/storage/OpLog.js +221 -0
  66. package/dist_ts/ts_smartdb/storage/WAL.d.ts +117 -0
  67. package/dist_ts/ts_smartdb/storage/WAL.js +286 -0
  68. package/dist_ts/ts_smartdb/types/interfaces.d.ts +363 -0
  69. package/dist_ts/ts_smartdb/types/interfaces.js +2 -0
  70. package/dist_ts/ts_smartdb/utils/checksum.d.ts +30 -0
  71. package/dist_ts/ts_smartdb/utils/checksum.js +77 -0
  72. package/dist_ts/ts_smartdb/utils/index.d.ts +1 -0
  73. package/dist_ts/ts_smartdb/utils/index.js +2 -0
  74. package/license +19 -0
  75. package/package.json +69 -0
  76. package/readme.md +529 -0
  77. package/ts/00_commitinfo_data.ts +8 -0
  78. package/ts/index.ts +11 -0
  79. package/ts/ts_local/classes.localsmartdb.ts +143 -0
  80. package/ts/ts_local/index.ts +2 -0
  81. package/ts/ts_local/plugins.ts +3 -0
  82. package/ts/ts_smartdb/engine/AggregationEngine.ts +283 -0
  83. package/ts/ts_smartdb/engine/IndexEngine.ts +798 -0
  84. package/ts/ts_smartdb/engine/QueryEngine.ts +301 -0
  85. package/ts/ts_smartdb/engine/QueryPlanner.ts +393 -0
  86. package/ts/ts_smartdb/engine/SessionEngine.ts +292 -0
  87. package/ts/ts_smartdb/engine/TransactionEngine.ts +351 -0
  88. package/ts/ts_smartdb/engine/UpdateEngine.ts +506 -0
  89. package/ts/ts_smartdb/errors/SmartdbErrors.ts +181 -0
  90. package/ts/ts_smartdb/index.ts +46 -0
  91. package/ts/ts_smartdb/plugins.ts +17 -0
  92. package/ts/ts_smartdb/server/CommandRouter.ts +289 -0
  93. package/ts/ts_smartdb/server/SmartdbServer.ts +354 -0
  94. package/ts/ts_smartdb/server/WireProtocol.ts +416 -0
  95. package/ts/ts_smartdb/server/handlers/AdminHandler.ts +719 -0
  96. package/ts/ts_smartdb/server/handlers/AggregateHandler.ts +342 -0
  97. package/ts/ts_smartdb/server/handlers/DeleteHandler.ts +115 -0
  98. package/ts/ts_smartdb/server/handlers/FindHandler.ts +330 -0
  99. package/ts/ts_smartdb/server/handlers/HelloHandler.ts +78 -0
  100. package/ts/ts_smartdb/server/handlers/IndexHandler.ts +207 -0
  101. package/ts/ts_smartdb/server/handlers/InsertHandler.ts +97 -0
  102. package/ts/ts_smartdb/server/handlers/UpdateHandler.ts +344 -0
  103. package/ts/ts_smartdb/server/handlers/index.ts +10 -0
  104. package/ts/ts_smartdb/server/index.ts +10 -0
  105. package/ts/ts_smartdb/storage/FileStorageAdapter.ts +562 -0
  106. package/ts/ts_smartdb/storage/IStorageAdapter.ts +208 -0
  107. package/ts/ts_smartdb/storage/MemoryStorageAdapter.ts +455 -0
  108. package/ts/ts_smartdb/storage/OpLog.ts +282 -0
  109. package/ts/ts_smartdb/storage/WAL.ts +375 -0
  110. package/ts/ts_smartdb/types/interfaces.ts +433 -0
  111. package/ts/ts_smartdb/utils/checksum.ts +88 -0
  112. package/ts/ts_smartdb/utils/index.ts +1 -0
@@ -0,0 +1,102 @@
1
+ import type { IStorageAdapter } from '../storage/IStorageAdapter.js';
2
+ /**
3
+ * Server configuration options
4
+ */
5
+ export interface ISmartdbServerOptions {
6
+ /** Port to listen on (default: 27017) - ignored if socketPath is set */
7
+ port?: number;
8
+ /** Host to bind to (default: 127.0.0.1) - ignored if socketPath is set */
9
+ host?: string;
10
+ /** Unix socket path - if set, server listens on socket instead of TCP */
11
+ socketPath?: string;
12
+ /** Storage type: 'memory' or 'file' (default: 'memory') */
13
+ storage?: 'memory' | 'file';
14
+ /** Path for file storage (required if storage is 'file') */
15
+ storagePath?: string;
16
+ /** Enable persistence for memory storage */
17
+ persistPath?: string;
18
+ /** Persistence interval in ms (default: 60000) */
19
+ persistIntervalMs?: number;
20
+ }
21
+ /**
22
+ * SmartdbServer - MongoDB Wire Protocol compatible server
23
+ *
24
+ * This server implements the MongoDB wire protocol (OP_MSG) to allow
25
+ * official MongoDB drivers to connect and perform operations.
26
+ *
27
+ * @example
28
+ * ```typescript
29
+ * import { SmartdbServer } from '@push.rocks/smartmongo/smartdb';
30
+ * import { MongoClient } from 'mongodb';
31
+ *
32
+ * const server = new SmartdbServer({ port: 27017 });
33
+ * await server.start();
34
+ *
35
+ * const client = new MongoClient('mongodb://127.0.0.1:27017');
36
+ * await client.connect();
37
+ * ```
38
+ */
39
+ export declare class SmartdbServer {
40
+ private options;
41
+ private server;
42
+ private storage;
43
+ private commandRouter;
44
+ private connections;
45
+ private connectionIdCounter;
46
+ private isRunning;
47
+ private startTime;
48
+ private useSocket;
49
+ constructor(options?: ISmartdbServerOptions);
50
+ /**
51
+ * Get the storage adapter (for testing/debugging)
52
+ */
53
+ getStorage(): IStorageAdapter;
54
+ /**
55
+ * Get server uptime in seconds
56
+ */
57
+ getUptime(): number;
58
+ /**
59
+ * Get current connection count
60
+ */
61
+ getConnectionCount(): number;
62
+ /**
63
+ * Start the server
64
+ */
65
+ start(): Promise<void>;
66
+ /**
67
+ * Stop the server
68
+ */
69
+ stop(): Promise<void>;
70
+ /**
71
+ * Handle a new client connection
72
+ */
73
+ private handleConnection;
74
+ /**
75
+ * Handle incoming data from a client
76
+ */
77
+ private handleData;
78
+ /**
79
+ * Process complete messages from the buffer
80
+ */
81
+ private processMessages;
82
+ /**
83
+ * Get the connection URI for this server
84
+ */
85
+ getConnectionUri(): string;
86
+ /**
87
+ * Get the socket path (if using Unix socket mode)
88
+ */
89
+ get socketPath(): string | undefined;
90
+ /**
91
+ * Check if the server is running
92
+ */
93
+ get running(): boolean;
94
+ /**
95
+ * Get the port the server is listening on
96
+ */
97
+ get port(): number;
98
+ /**
99
+ * Get the host the server is bound to
100
+ */
101
+ get host(): string;
102
+ }
@@ -0,0 +1,279 @@
1
+ import * as net from 'net';
2
+ import * as fs from 'fs/promises';
3
+ import * as plugins from '../plugins.js';
4
+ import { WireProtocol, OP_QUERY } from './WireProtocol.js';
5
+ import { CommandRouter } from './CommandRouter.js';
6
+ import { MemoryStorageAdapter } from '../storage/MemoryStorageAdapter.js';
7
+ import { FileStorageAdapter } from '../storage/FileStorageAdapter.js';
8
+ /**
9
+ * SmartdbServer - MongoDB Wire Protocol compatible server
10
+ *
11
+ * This server implements the MongoDB wire protocol (OP_MSG) to allow
12
+ * official MongoDB drivers to connect and perform operations.
13
+ *
14
+ * @example
15
+ * ```typescript
16
+ * import { SmartdbServer } from '@push.rocks/smartmongo/smartdb';
17
+ * import { MongoClient } from 'mongodb';
18
+ *
19
+ * const server = new SmartdbServer({ port: 27017 });
20
+ * await server.start();
21
+ *
22
+ * const client = new MongoClient('mongodb://127.0.0.1:27017');
23
+ * await client.connect();
24
+ * ```
25
+ */
26
+ export class SmartdbServer {
27
+ options;
28
+ server = null;
29
+ storage;
30
+ commandRouter;
31
+ connections = new Map();
32
+ connectionIdCounter = 0;
33
+ isRunning = false;
34
+ startTime = new Date();
35
+ useSocket;
36
+ constructor(options = {}) {
37
+ this.useSocket = !!options.socketPath;
38
+ this.options = {
39
+ port: options.port ?? 27017,
40
+ host: options.host ?? '127.0.0.1',
41
+ socketPath: options.socketPath ?? '',
42
+ storage: options.storage ?? 'memory',
43
+ storagePath: options.storagePath ?? './data',
44
+ persistPath: options.persistPath ?? '',
45
+ persistIntervalMs: options.persistIntervalMs ?? 60000,
46
+ };
47
+ // Create storage adapter
48
+ if (this.options.storage === 'file') {
49
+ this.storage = new FileStorageAdapter(this.options.storagePath);
50
+ }
51
+ else {
52
+ this.storage = new MemoryStorageAdapter({
53
+ persistPath: this.options.persistPath || undefined,
54
+ persistIntervalMs: this.options.persistPath ? this.options.persistIntervalMs : undefined,
55
+ });
56
+ }
57
+ // Create command router
58
+ this.commandRouter = new CommandRouter(this.storage, this);
59
+ }
60
+ /**
61
+ * Get the storage adapter (for testing/debugging)
62
+ */
63
+ getStorage() {
64
+ return this.storage;
65
+ }
66
+ /**
67
+ * Get server uptime in seconds
68
+ */
69
+ getUptime() {
70
+ return Math.floor((Date.now() - this.startTime.getTime()) / 1000);
71
+ }
72
+ /**
73
+ * Get current connection count
74
+ */
75
+ getConnectionCount() {
76
+ return this.connections.size;
77
+ }
78
+ /**
79
+ * Start the server
80
+ */
81
+ async start() {
82
+ if (this.isRunning) {
83
+ throw new Error('Server is already running');
84
+ }
85
+ // Initialize storage
86
+ await this.storage.initialize();
87
+ // Clean up stale socket file if using Unix socket
88
+ if (this.useSocket && this.options.socketPath) {
89
+ try {
90
+ await fs.unlink(this.options.socketPath);
91
+ }
92
+ catch (err) {
93
+ // Ignore ENOENT (file doesn't exist)
94
+ if (err.code !== 'ENOENT') {
95
+ throw err;
96
+ }
97
+ }
98
+ }
99
+ return new Promise((resolve, reject) => {
100
+ this.server = net.createServer((socket) => {
101
+ this.handleConnection(socket);
102
+ });
103
+ this.server.on('error', (err) => {
104
+ if (!this.isRunning) {
105
+ reject(err);
106
+ }
107
+ else {
108
+ console.error('Server error:', err);
109
+ }
110
+ });
111
+ if (this.useSocket && this.options.socketPath) {
112
+ // Listen on Unix socket
113
+ this.server.listen(this.options.socketPath, () => {
114
+ this.isRunning = true;
115
+ this.startTime = new Date();
116
+ resolve();
117
+ });
118
+ }
119
+ else {
120
+ // Listen on TCP
121
+ this.server.listen(this.options.port, this.options.host, () => {
122
+ this.isRunning = true;
123
+ this.startTime = new Date();
124
+ resolve();
125
+ });
126
+ }
127
+ });
128
+ }
129
+ /**
130
+ * Stop the server
131
+ */
132
+ async stop() {
133
+ if (!this.isRunning || !this.server) {
134
+ return;
135
+ }
136
+ // Close all connections
137
+ for (const conn of this.connections.values()) {
138
+ conn.socket.destroy();
139
+ }
140
+ this.connections.clear();
141
+ // Close command router (cleans up session engine, cursors, etc.)
142
+ this.commandRouter.close();
143
+ // Close storage
144
+ await this.storage.close();
145
+ return new Promise((resolve) => {
146
+ this.server.close(async () => {
147
+ this.isRunning = false;
148
+ this.server = null;
149
+ // Clean up socket file if using Unix socket
150
+ if (this.useSocket && this.options.socketPath) {
151
+ try {
152
+ await fs.unlink(this.options.socketPath);
153
+ }
154
+ catch (err) {
155
+ // Ignore ENOENT (file doesn't exist)
156
+ if (err.code !== 'ENOENT') {
157
+ console.error('Failed to remove socket file:', err);
158
+ }
159
+ }
160
+ }
161
+ resolve();
162
+ });
163
+ });
164
+ }
165
+ /**
166
+ * Handle a new client connection
167
+ */
168
+ handleConnection(socket) {
169
+ const connectionId = ++this.connectionIdCounter;
170
+ const state = {
171
+ id: connectionId,
172
+ socket,
173
+ buffer: Buffer.alloc(0),
174
+ authenticated: true, // No auth required for now
175
+ database: 'test',
176
+ };
177
+ this.connections.set(connectionId, state);
178
+ socket.on('data', (data) => {
179
+ this.handleData(state, Buffer.isBuffer(data) ? data : Buffer.from(data));
180
+ });
181
+ socket.on('close', () => {
182
+ this.connections.delete(connectionId);
183
+ });
184
+ socket.on('error', (err) => {
185
+ // Connection errors are expected when clients disconnect
186
+ this.connections.delete(connectionId);
187
+ });
188
+ }
189
+ /**
190
+ * Handle incoming data from a client
191
+ */
192
+ handleData(state, data) {
193
+ // Append new data to buffer
194
+ state.buffer = Buffer.concat([state.buffer, data]);
195
+ // Process messages from buffer
196
+ this.processMessages(state);
197
+ }
198
+ /**
199
+ * Process complete messages from the buffer
200
+ */
201
+ async processMessages(state) {
202
+ while (state.buffer.length >= 16) {
203
+ try {
204
+ const result = WireProtocol.parseMessage(state.buffer);
205
+ if (!result) {
206
+ // Not enough data for a complete message
207
+ break;
208
+ }
209
+ const { command, bytesConsumed } = result;
210
+ // Remove processed bytes from buffer
211
+ state.buffer = state.buffer.subarray(bytesConsumed);
212
+ // Process the command
213
+ const response = await this.commandRouter.route(command);
214
+ // Encode and send response
215
+ let responseBuffer;
216
+ if (command.opCode === OP_QUERY) {
217
+ // Legacy OP_QUERY gets OP_REPLY response
218
+ responseBuffer = WireProtocol.encodeOpReplyResponse(command.requestID, [response]);
219
+ }
220
+ else {
221
+ // OP_MSG gets OP_MSG response
222
+ responseBuffer = WireProtocol.encodeOpMsgResponse(command.requestID, response);
223
+ }
224
+ if (!state.socket.destroyed) {
225
+ state.socket.write(responseBuffer);
226
+ }
227
+ }
228
+ catch (error) {
229
+ // Send error response
230
+ const errorResponse = WireProtocol.encodeErrorResponse(0, // We don't have the requestID at this point
231
+ 1, error.message || 'Internal error');
232
+ if (!state.socket.destroyed) {
233
+ state.socket.write(errorResponse);
234
+ }
235
+ // Clear buffer on parse errors to avoid infinite loops
236
+ if (error.message?.includes('opCode') || error.message?.includes('section')) {
237
+ state.buffer = Buffer.alloc(0);
238
+ }
239
+ break;
240
+ }
241
+ }
242
+ }
243
+ /**
244
+ * Get the connection URI for this server
245
+ */
246
+ getConnectionUri() {
247
+ if (this.useSocket && this.options.socketPath) {
248
+ // URL-encode the socket path (replace / with %2F)
249
+ const encodedPath = encodeURIComponent(this.options.socketPath);
250
+ return `mongodb://${encodedPath}`;
251
+ }
252
+ return `mongodb://${this.options.host}:${this.options.port}`;
253
+ }
254
+ /**
255
+ * Get the socket path (if using Unix socket mode)
256
+ */
257
+ get socketPath() {
258
+ return this.useSocket ? this.options.socketPath : undefined;
259
+ }
260
+ /**
261
+ * Check if the server is running
262
+ */
263
+ get running() {
264
+ return this.isRunning;
265
+ }
266
+ /**
267
+ * Get the port the server is listening on
268
+ */
269
+ get port() {
270
+ return this.options.port;
271
+ }
272
+ /**
273
+ * Get the host the server is bound to
274
+ */
275
+ get host() {
276
+ return this.options.host;
277
+ }
278
+ }
279
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SmartdbServer.js","sourceRoot":"","sources":["../../../ts/ts_smartdb/server/SmartdbServer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,117 @@
1
+ import * as plugins from '../plugins.js';
2
+ /**
3
+ * MongoDB Wire Protocol Implementation
4
+ * Handles parsing and encoding of MongoDB wire protocol messages (OP_MSG primarily)
5
+ *
6
+ * Wire Protocol Message Format:
7
+ * - Header (16 bytes): messageLength (4), requestID (4), responseTo (4), opCode (4)
8
+ * - OP_MSG: flagBits (4), sections[], optional checksum (4)
9
+ *
10
+ * References:
11
+ * - https://www.mongodb.com/docs/manual/reference/mongodb-wire-protocol/
12
+ */
13
+ export declare const OP_REPLY = 1;
14
+ export declare const OP_UPDATE = 2001;
15
+ export declare const OP_INSERT = 2002;
16
+ export declare const OP_QUERY = 2004;
17
+ export declare const OP_GET_MORE = 2005;
18
+ export declare const OP_DELETE = 2006;
19
+ export declare const OP_KILL_CURSORS = 2007;
20
+ export declare const OP_COMPRESSED = 2012;
21
+ export declare const OP_MSG = 2013;
22
+ export declare const SECTION_BODY = 0;
23
+ export declare const SECTION_DOCUMENT_SEQUENCE = 1;
24
+ export declare const MSG_FLAG_CHECKSUM_PRESENT: number;
25
+ export declare const MSG_FLAG_MORE_TO_COME: number;
26
+ export declare const MSG_FLAG_EXHAUST_ALLOWED: number;
27
+ /**
28
+ * Parsed message header
29
+ */
30
+ export interface IMessageHeader {
31
+ messageLength: number;
32
+ requestID: number;
33
+ responseTo: number;
34
+ opCode: number;
35
+ }
36
+ /**
37
+ * Parsed OP_MSG message
38
+ */
39
+ export interface IOpMsgMessage {
40
+ header: IMessageHeader;
41
+ flagBits: number;
42
+ sections: IOpMsgSection[];
43
+ checksum?: number;
44
+ }
45
+ /**
46
+ * OP_MSG section (either body or document sequence)
47
+ */
48
+ export interface IOpMsgSection {
49
+ type: number;
50
+ payload: plugins.bson.Document;
51
+ sequenceIdentifier?: string;
52
+ documents?: plugins.bson.Document[];
53
+ }
54
+ /**
55
+ * Parsed OP_QUERY message (legacy, but used for initial handshake)
56
+ */
57
+ export interface IOpQueryMessage {
58
+ header: IMessageHeader;
59
+ flags: number;
60
+ fullCollectionName: string;
61
+ numberToSkip: number;
62
+ numberToReturn: number;
63
+ query: plugins.bson.Document;
64
+ returnFieldsSelector?: plugins.bson.Document;
65
+ }
66
+ /**
67
+ * Parsed command from any message type
68
+ */
69
+ export interface IParsedCommand {
70
+ commandName: string;
71
+ command: plugins.bson.Document;
72
+ database: string;
73
+ requestID: number;
74
+ opCode: number;
75
+ documentSequences?: Map<string, plugins.bson.Document[]>;
76
+ }
77
+ /**
78
+ * Wire Protocol parser and encoder
79
+ */
80
+ export declare class WireProtocol {
81
+ /**
82
+ * Parse a complete message from a buffer
83
+ * Returns the parsed command and the number of bytes consumed
84
+ */
85
+ static parseMessage(buffer: Buffer): {
86
+ command: IParsedCommand;
87
+ bytesConsumed: number;
88
+ } | null;
89
+ /**
90
+ * Parse message header (16 bytes)
91
+ */
92
+ private static parseHeader;
93
+ /**
94
+ * Parse OP_MSG message
95
+ */
96
+ private static parseOpMsg;
97
+ /**
98
+ * Parse OP_QUERY message (legacy, used for initial handshake)
99
+ */
100
+ private static parseOpQuery;
101
+ /**
102
+ * Encode a response as OP_MSG
103
+ */
104
+ static encodeOpMsgResponse(responseTo: number, response: plugins.bson.Document, requestID?: number): Buffer;
105
+ /**
106
+ * Encode a response as OP_REPLY (legacy, for OP_QUERY responses)
107
+ */
108
+ static encodeOpReplyResponse(responseTo: number, documents: plugins.bson.Document[], requestID?: number, cursorId?: bigint): Buffer;
109
+ /**
110
+ * Encode an error response
111
+ */
112
+ static encodeErrorResponse(responseTo: number, errorCode: number, errorMessage: string, commandName?: string): Buffer;
113
+ /**
114
+ * Get error code name from error code
115
+ */
116
+ private static getErrorCodeName;
117
+ }