@sparkleideas/swarm 3.0.0-alpha.6-patch.25 → 3.0.0-alpha.6-patch.27

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 (126) hide show
  1. package/dist/agent-pool.d.ts +52 -0
  2. package/dist/agent-pool.d.ts.map +1 -0
  3. package/dist/agent-pool.js +365 -0
  4. package/dist/agent-pool.js.map +1 -0
  5. package/dist/application/commands/create-task.command.d.ts +64 -0
  6. package/dist/application/commands/create-task.command.d.ts.map +1 -0
  7. package/dist/application/commands/create-task.command.js +77 -0
  8. package/dist/application/commands/create-task.command.js.map +1 -0
  9. package/dist/application/commands/spawn-agent.command.d.ts +63 -0
  10. package/dist/application/commands/spawn-agent.command.d.ts.map +1 -0
  11. package/dist/application/commands/spawn-agent.command.js +74 -0
  12. package/dist/application/commands/spawn-agent.command.js.map +1 -0
  13. package/dist/application/index.d.ts +9 -0
  14. package/dist/application/index.d.ts.map +1 -0
  15. package/dist/application/index.js +11 -0
  16. package/dist/application/index.js.map +1 -0
  17. package/dist/application/services/swarm-application-service.d.ts +112 -0
  18. package/dist/application/services/swarm-application-service.d.ts.map +1 -0
  19. package/dist/application/services/swarm-application-service.js +153 -0
  20. package/dist/application/services/swarm-application-service.js.map +1 -0
  21. package/dist/attention-coordinator.d.ts +212 -0
  22. package/dist/attention-coordinator.d.ts.map +1 -0
  23. package/dist/attention-coordinator.js +667 -0
  24. package/dist/attention-coordinator.js.map +1 -0
  25. package/dist/consensus/byzantine.d.ts +63 -0
  26. package/dist/consensus/byzantine.d.ts.map +1 -0
  27. package/dist/consensus/byzantine.js +316 -0
  28. package/dist/consensus/byzantine.js.map +1 -0
  29. package/dist/consensus/gossip.d.ts +69 -0
  30. package/dist/consensus/gossip.d.ts.map +1 -0
  31. package/dist/consensus/gossip.js +378 -0
  32. package/dist/consensus/gossip.js.map +1 -0
  33. package/dist/consensus/index.d.ts +49 -0
  34. package/dist/consensus/index.d.ts.map +1 -0
  35. package/dist/consensus/index.js +203 -0
  36. package/dist/consensus/index.js.map +1 -0
  37. package/dist/consensus/raft.d.ts +62 -0
  38. package/dist/consensus/raft.d.ts.map +1 -0
  39. package/dist/consensus/raft.js +324 -0
  40. package/dist/consensus/raft.js.map +1 -0
  41. package/dist/coordination/agent-registry.d.ts +68 -0
  42. package/dist/coordination/agent-registry.d.ts.map +1 -0
  43. package/dist/coordination/agent-registry.js +412 -0
  44. package/dist/coordination/agent-registry.js.map +1 -0
  45. package/dist/coordination/index.d.ts +8 -0
  46. package/dist/coordination/index.d.ts.map +1 -0
  47. package/dist/coordination/index.js +8 -0
  48. package/dist/coordination/index.js.map +1 -0
  49. package/dist/coordination/swarm-hub.d.ts +150 -0
  50. package/dist/coordination/swarm-hub.d.ts.map +1 -0
  51. package/dist/coordination/swarm-hub.js +617 -0
  52. package/dist/coordination/swarm-hub.js.map +1 -0
  53. package/dist/coordination/task-orchestrator.d.ts +96 -0
  54. package/dist/coordination/task-orchestrator.d.ts.map +1 -0
  55. package/dist/coordination/task-orchestrator.js +412 -0
  56. package/dist/coordination/task-orchestrator.js.map +1 -0
  57. package/dist/domain/entities/agent.d.ts +151 -0
  58. package/dist/domain/entities/agent.d.ts.map +1 -0
  59. package/dist/domain/entities/agent.js +280 -0
  60. package/dist/domain/entities/agent.js.map +1 -0
  61. package/dist/domain/entities/task.d.ts +133 -0
  62. package/dist/domain/entities/task.d.ts.map +1 -0
  63. package/dist/domain/entities/task.js +261 -0
  64. package/dist/domain/entities/task.js.map +1 -0
  65. package/dist/domain/index.d.ts +11 -0
  66. package/dist/domain/index.d.ts.map +1 -0
  67. package/dist/domain/index.js +11 -0
  68. package/dist/domain/index.js.map +1 -0
  69. package/dist/domain/repositories/agent-repository.interface.d.ts +57 -0
  70. package/dist/domain/repositories/agent-repository.interface.d.ts.map +1 -0
  71. package/dist/domain/repositories/agent-repository.interface.js +9 -0
  72. package/dist/domain/repositories/agent-repository.interface.js.map +1 -0
  73. package/dist/domain/repositories/task-repository.interface.d.ts +61 -0
  74. package/dist/domain/repositories/task-repository.interface.d.ts.map +1 -0
  75. package/dist/domain/repositories/task-repository.interface.js +9 -0
  76. package/dist/domain/repositories/task-repository.interface.js.map +1 -0
  77. package/dist/domain/services/coordination-service.d.ts +84 -0
  78. package/dist/domain/services/coordination-service.d.ts.map +1 -0
  79. package/dist/domain/services/coordination-service.js +231 -0
  80. package/dist/domain/services/coordination-service.js.map +1 -0
  81. package/dist/federation-hub.d.ts +284 -0
  82. package/dist/federation-hub.d.ts.map +1 -0
  83. package/dist/federation-hub.js +692 -0
  84. package/dist/federation-hub.js.map +1 -0
  85. package/dist/index.d.ts +107 -0
  86. package/dist/index.d.ts.map +1 -0
  87. package/dist/index.js +142 -0
  88. package/dist/index.js.map +1 -0
  89. package/dist/message-bus.d.ts +48 -0
  90. package/dist/message-bus.d.ts.map +1 -0
  91. package/dist/message-bus.js +499 -0
  92. package/dist/message-bus.js.map +1 -0
  93. package/dist/queen-coordinator.d.ts +577 -0
  94. package/dist/queen-coordinator.d.ts.map +1 -0
  95. package/dist/queen-coordinator.js +1308 -0
  96. package/dist/queen-coordinator.js.map +1 -0
  97. package/dist/shared/events.d.ts +63 -0
  98. package/dist/shared/events.d.ts.map +1 -0
  99. package/dist/shared/events.js +203 -0
  100. package/dist/shared/events.js.map +1 -0
  101. package/dist/shared/types.d.ts +212 -0
  102. package/dist/shared/types.d.ts.map +1 -0
  103. package/dist/shared/types.js +22 -0
  104. package/dist/shared/types.js.map +1 -0
  105. package/dist/topology-manager.d.ts +62 -0
  106. package/dist/topology-manager.d.ts.map +1 -0
  107. package/dist/topology-manager.js +538 -0
  108. package/dist/topology-manager.js.map +1 -0
  109. package/dist/types.d.ts +353 -0
  110. package/dist/types.d.ts.map +1 -0
  111. package/dist/types.js +43 -0
  112. package/dist/types.js.map +1 -0
  113. package/dist/unified-coordinator.d.ts +260 -0
  114. package/dist/unified-coordinator.d.ts.map +1 -0
  115. package/dist/unified-coordinator.js +1460 -0
  116. package/dist/unified-coordinator.js.map +1 -0
  117. package/dist/workers/index.d.ts +29 -0
  118. package/dist/workers/index.d.ts.map +1 -0
  119. package/dist/workers/index.js +49 -0
  120. package/dist/workers/index.js.map +1 -0
  121. package/dist/workers/worker-dispatch.d.ts +239 -0
  122. package/dist/workers/worker-dispatch.d.ts.map +1 -0
  123. package/dist/workers/worker-dispatch.js +846 -0
  124. package/dist/workers/worker-dispatch.js.map +1 -0
  125. package/package.json +1 -1
  126. package/tsconfig.build.tsbuildinfo +1 -0
@@ -0,0 +1,499 @@
1
+ /**
2
+ * V3 Message Bus
3
+ * High-performance inter-agent communication system
4
+ * Target: 1000+ messages/second throughput
5
+ */
6
+ import { EventEmitter } from 'events';
7
+ import { SWARM_CONSTANTS, } from './types.js';
8
+ // ============================================================================
9
+ // High-Performance Deque Implementation
10
+ // O(1) push/pop from both ends using circular buffer
11
+ // ============================================================================
12
+ class Deque {
13
+ buffer;
14
+ head = 0;
15
+ tail = 0;
16
+ count = 0;
17
+ capacity;
18
+ constructor(initialCapacity = 16) {
19
+ this.capacity = initialCapacity;
20
+ this.buffer = new Array(this.capacity);
21
+ }
22
+ get length() {
23
+ return this.count;
24
+ }
25
+ grow() {
26
+ const newCapacity = this.capacity * 2;
27
+ const newBuffer = new Array(newCapacity);
28
+ // Copy elements in order
29
+ for (let i = 0; i < this.count; i++) {
30
+ newBuffer[i] = this.buffer[(this.head + i) % this.capacity];
31
+ }
32
+ this.buffer = newBuffer;
33
+ this.head = 0;
34
+ this.tail = this.count;
35
+ this.capacity = newCapacity;
36
+ }
37
+ pushBack(item) {
38
+ if (this.count === this.capacity) {
39
+ this.grow();
40
+ }
41
+ this.buffer[this.tail] = item;
42
+ this.tail = (this.tail + 1) % this.capacity;
43
+ this.count++;
44
+ }
45
+ popFront() {
46
+ if (this.count === 0) {
47
+ return undefined;
48
+ }
49
+ const item = this.buffer[this.head];
50
+ this.buffer[this.head] = undefined; // Help GC
51
+ this.head = (this.head + 1) % this.capacity;
52
+ this.count--;
53
+ return item;
54
+ }
55
+ peekFront() {
56
+ if (this.count === 0) {
57
+ return undefined;
58
+ }
59
+ return this.buffer[this.head];
60
+ }
61
+ clear() {
62
+ this.buffer = new Array(this.capacity);
63
+ this.head = 0;
64
+ this.tail = 0;
65
+ this.count = 0;
66
+ }
67
+ // Find and remove first matching element - O(n) but rarely used
68
+ findAndRemove(predicate) {
69
+ for (let i = 0; i < this.count; i++) {
70
+ const idx = (this.head + i) % this.capacity;
71
+ const item = this.buffer[idx];
72
+ if (item !== undefined && predicate(item)) {
73
+ // Shift remaining elements (O(n) but acceptable for rare operations)
74
+ for (let j = i; j < this.count - 1; j++) {
75
+ const currentIdx = (this.head + j) % this.capacity;
76
+ const nextIdx = (this.head + j + 1) % this.capacity;
77
+ this.buffer[currentIdx] = this.buffer[nextIdx];
78
+ }
79
+ this.tail = (this.tail - 1 + this.capacity) % this.capacity;
80
+ this.buffer[this.tail] = undefined;
81
+ this.count--;
82
+ return item;
83
+ }
84
+ }
85
+ return undefined;
86
+ }
87
+ find(predicate) {
88
+ for (let i = 0; i < this.count; i++) {
89
+ const idx = (this.head + i) % this.capacity;
90
+ const item = this.buffer[idx];
91
+ if (item !== undefined && predicate(item)) {
92
+ return item;
93
+ }
94
+ }
95
+ return undefined;
96
+ }
97
+ *[Symbol.iterator]() {
98
+ for (let i = 0; i < this.count; i++) {
99
+ const item = this.buffer[(this.head + i) % this.capacity];
100
+ if (item !== undefined) {
101
+ yield item;
102
+ }
103
+ }
104
+ }
105
+ }
106
+ const PRIORITY_ORDER = ['urgent', 'high', 'normal', 'low'];
107
+ class PriorityMessageQueue {
108
+ queues = new Map();
109
+ totalCount = 0;
110
+ constructor() {
111
+ for (const priority of PRIORITY_ORDER) {
112
+ this.queues.set(priority, new Deque());
113
+ }
114
+ }
115
+ get length() {
116
+ return this.totalCount;
117
+ }
118
+ enqueue(entry) {
119
+ const priority = entry.message.priority;
120
+ const queue = this.queues.get(priority);
121
+ queue.pushBack(entry);
122
+ this.totalCount++;
123
+ }
124
+ dequeue() {
125
+ // Dequeue from highest priority non-empty queue
126
+ for (const priority of PRIORITY_ORDER) {
127
+ const queue = this.queues.get(priority);
128
+ if (queue.length > 0) {
129
+ this.totalCount--;
130
+ return queue.popFront();
131
+ }
132
+ }
133
+ return undefined;
134
+ }
135
+ // Find and remove first low/normal priority entry for overflow handling
136
+ removeLowestPriority() {
137
+ // Check low priority first, then normal
138
+ for (const priority of ['low', 'normal']) {
139
+ const queue = this.queues.get(priority);
140
+ if (queue.length > 0) {
141
+ this.totalCount--;
142
+ return queue.popFront();
143
+ }
144
+ }
145
+ // Fall back to any queue
146
+ for (const priority of PRIORITY_ORDER) {
147
+ const queue = this.queues.get(priority);
148
+ if (queue.length > 0) {
149
+ this.totalCount--;
150
+ return queue.popFront();
151
+ }
152
+ }
153
+ return undefined;
154
+ }
155
+ clear() {
156
+ for (const queue of this.queues.values()) {
157
+ queue.clear();
158
+ }
159
+ this.totalCount = 0;
160
+ }
161
+ find(predicate) {
162
+ for (const queue of this.queues.values()) {
163
+ const found = queue.find(predicate);
164
+ if (found) {
165
+ return found;
166
+ }
167
+ }
168
+ return undefined;
169
+ }
170
+ }
171
+ export class MessageBus extends EventEmitter {
172
+ config;
173
+ queues = new Map();
174
+ subscriptions = new Map();
175
+ pendingAcks = new Map();
176
+ processingInterval;
177
+ statsInterval;
178
+ messageCounter = 0;
179
+ stats;
180
+ startTime = new Date();
181
+ // Circular buffer for message history (max 60 entries for 60 seconds)
182
+ messageHistory = [];
183
+ messageHistoryIndex = 0;
184
+ static MAX_HISTORY_SIZE = 60;
185
+ constructor(config = {}) {
186
+ super();
187
+ this.config = {
188
+ maxQueueSize: config.maxQueueSize ?? SWARM_CONSTANTS.MAX_QUEUE_SIZE,
189
+ processingIntervalMs: config.processingIntervalMs ?? 10,
190
+ ackTimeoutMs: config.ackTimeoutMs ?? 5000,
191
+ retryAttempts: config.retryAttempts ?? SWARM_CONSTANTS.MAX_RETRIES,
192
+ enablePersistence: config.enablePersistence ?? false,
193
+ compressionEnabled: config.compressionEnabled ?? false,
194
+ };
195
+ this.stats = {
196
+ totalMessages: 0,
197
+ messagesPerSecond: 0,
198
+ avgLatencyMs: 0,
199
+ queueDepth: 0,
200
+ ackRate: 1.0,
201
+ errorRate: 0,
202
+ };
203
+ }
204
+ async initialize(config) {
205
+ if (config) {
206
+ this.config = { ...this.config, ...config };
207
+ }
208
+ this.startProcessing();
209
+ this.startStatsCollection();
210
+ this.emit('initialized');
211
+ }
212
+ async shutdown() {
213
+ if (this.processingInterval) {
214
+ clearInterval(this.processingInterval);
215
+ this.processingInterval = undefined;
216
+ }
217
+ if (this.statsInterval) {
218
+ clearInterval(this.statsInterval);
219
+ this.statsInterval = undefined;
220
+ }
221
+ // Clear all pending acks
222
+ for (const [, pending] of this.pendingAcks) {
223
+ clearTimeout(pending.timeout);
224
+ }
225
+ this.pendingAcks.clear();
226
+ // Clear all queues
227
+ this.queues.clear();
228
+ this.subscriptions.clear();
229
+ this.messageHistory = [];
230
+ this.emit('shutdown');
231
+ }
232
+ generateMessageId() {
233
+ this.messageCounter++;
234
+ return `msg_${Date.now()}_${this.messageCounter.toString(36)}`;
235
+ }
236
+ async send(message) {
237
+ const fullMessage = {
238
+ ...message,
239
+ id: this.generateMessageId(),
240
+ timestamp: new Date(),
241
+ };
242
+ return this.enqueue(fullMessage);
243
+ }
244
+ async broadcast(message) {
245
+ const fullMessage = {
246
+ ...message,
247
+ id: this.generateMessageId(),
248
+ timestamp: new Date(),
249
+ to: 'broadcast',
250
+ };
251
+ return this.enqueue(fullMessage);
252
+ }
253
+ async enqueue(message) {
254
+ const startTime = performance.now();
255
+ if (message.to === 'broadcast') {
256
+ // Broadcast to all subscribed agents
257
+ for (const [agentId, subscription] of this.subscriptions) {
258
+ if (agentId !== message.from) {
259
+ this.addToQueue(agentId, message);
260
+ }
261
+ }
262
+ }
263
+ else {
264
+ this.addToQueue(message.to, message);
265
+ }
266
+ this.stats.totalMessages++;
267
+ const latency = performance.now() - startTime;
268
+ this.updateLatencyStats(latency);
269
+ this.emit('message.enqueued', { messageId: message.id, to: message.to });
270
+ return message.id;
271
+ }
272
+ addToQueue(agentId, message) {
273
+ if (!this.queues.has(agentId)) {
274
+ this.queues.set(agentId, new PriorityMessageQueue());
275
+ }
276
+ const queue = this.queues.get(agentId);
277
+ // Check queue size limit - O(1) removal of lowest priority
278
+ if (queue.length >= this.config.maxQueueSize) {
279
+ queue.removeLowestPriority();
280
+ }
281
+ // O(1) priority-aware insertion
282
+ const entry = {
283
+ message,
284
+ attempts: 0,
285
+ enqueuedAt: new Date(),
286
+ };
287
+ queue.enqueue(entry);
288
+ }
289
+ subscribe(agentId, callback, filter) {
290
+ this.subscriptions.set(agentId, {
291
+ agentId,
292
+ callback,
293
+ filter,
294
+ });
295
+ // Initialize queue for this agent
296
+ if (!this.queues.has(agentId)) {
297
+ this.queues.set(agentId, new PriorityMessageQueue());
298
+ }
299
+ this.emit('subscription.added', { agentId });
300
+ }
301
+ unsubscribe(agentId) {
302
+ this.subscriptions.delete(agentId);
303
+ this.queues.delete(agentId);
304
+ this.emit('subscription.removed', { agentId });
305
+ }
306
+ async acknowledge(ack) {
307
+ const pending = this.pendingAcks.get(ack.messageId);
308
+ if (!pending) {
309
+ return;
310
+ }
311
+ clearTimeout(pending.timeout);
312
+ this.pendingAcks.delete(ack.messageId);
313
+ if (!ack.received && ack.error) {
314
+ this.handleAckFailure(pending.message, ack.error);
315
+ }
316
+ this.emit('message.acknowledged', {
317
+ messageId: ack.messageId,
318
+ success: ack.received
319
+ });
320
+ }
321
+ startProcessing() {
322
+ this.processingInterval = setInterval(() => {
323
+ this.processQueues();
324
+ }, this.config.processingIntervalMs);
325
+ }
326
+ processQueues() {
327
+ const now = Date.now();
328
+ for (const [agentId, queue] of this.queues) {
329
+ const subscription = this.subscriptions.get(agentId);
330
+ if (!subscription) {
331
+ continue;
332
+ }
333
+ // Process messages in batch for better throughput
334
+ const batchSize = Math.min(10, queue.length);
335
+ const batch = [];
336
+ for (let i = 0; i < batchSize && queue.length > 0; i++) {
337
+ // O(1) dequeue from highest priority queue
338
+ const entry = queue.dequeue();
339
+ if (!entry)
340
+ break;
341
+ // Check TTL
342
+ if (now - entry.message.timestamp.getTime() > entry.message.ttlMs) {
343
+ this.emit('message.expired', { messageId: entry.message.id });
344
+ continue;
345
+ }
346
+ // Check filter
347
+ if (subscription.filter && !subscription.filter.includes(entry.message.type)) {
348
+ continue;
349
+ }
350
+ batch.push(entry);
351
+ }
352
+ // Deliver batch
353
+ for (const entry of batch) {
354
+ this.deliverMessage(subscription, entry);
355
+ }
356
+ }
357
+ }
358
+ deliverMessage(subscription, entry) {
359
+ const message = entry.message;
360
+ try {
361
+ // Set up ack timeout if required
362
+ if (message.requiresAck) {
363
+ const timeout = setTimeout(() => {
364
+ this.handleAckTimeout(message);
365
+ }, this.config.ackTimeoutMs);
366
+ this.pendingAcks.set(message.id, { message, timeout });
367
+ }
368
+ // Deliver asynchronously
369
+ setImmediate(() => {
370
+ try {
371
+ subscription.callback(message);
372
+ this.emit('message.delivered', {
373
+ messageId: message.id,
374
+ to: subscription.agentId
375
+ });
376
+ }
377
+ catch (error) {
378
+ this.handleDeliveryError(message, entry, error);
379
+ }
380
+ });
381
+ }
382
+ catch (error) {
383
+ this.handleDeliveryError(message, entry, error);
384
+ }
385
+ }
386
+ handleAckTimeout(message) {
387
+ this.pendingAcks.delete(message.id);
388
+ this.stats.ackRate = Math.max(0, this.stats.ackRate - 0.01);
389
+ this.emit('message.ack_timeout', { messageId: message.id });
390
+ }
391
+ handleAckFailure(message, error) {
392
+ this.stats.errorRate += 0.01;
393
+ this.emit('message.ack_failed', { messageId: message.id, error });
394
+ }
395
+ handleDeliveryError(message, entry, error) {
396
+ entry.attempts++;
397
+ entry.lastAttemptAt = new Date();
398
+ if (entry.attempts < this.config.retryAttempts) {
399
+ // Re-queue for retry
400
+ this.addToQueue(message.to, message);
401
+ this.emit('message.retry', {
402
+ messageId: message.id,
403
+ attempt: entry.attempts
404
+ });
405
+ }
406
+ else {
407
+ this.stats.errorRate += 0.01;
408
+ this.emit('message.failed', {
409
+ messageId: message.id,
410
+ error: error.message
411
+ });
412
+ }
413
+ }
414
+ startStatsCollection() {
415
+ this.statsInterval = setInterval(() => {
416
+ this.calculateMessagesPerSecond();
417
+ }, 1000);
418
+ }
419
+ calculateMessagesPerSecond() {
420
+ const now = Date.now();
421
+ const entry = { timestamp: now, count: this.stats.totalMessages };
422
+ // Use circular buffer pattern - O(1) instead of O(n) filter
423
+ if (this.messageHistory.length < MessageBus.MAX_HISTORY_SIZE) {
424
+ this.messageHistory.push(entry);
425
+ }
426
+ else {
427
+ this.messageHistory[this.messageHistoryIndex] = entry;
428
+ this.messageHistoryIndex = (this.messageHistoryIndex + 1) % MessageBus.MAX_HISTORY_SIZE;
429
+ }
430
+ // Calculate messages per second from history
431
+ if (this.messageHistory.length >= 2) {
432
+ // Find oldest valid entry (within last 60 seconds)
433
+ let oldest = entry;
434
+ for (const h of this.messageHistory) {
435
+ if (h.timestamp < oldest.timestamp && now - h.timestamp < 60000) {
436
+ oldest = h;
437
+ }
438
+ }
439
+ const seconds = (now - oldest.timestamp) / 1000;
440
+ const messages = entry.count - oldest.count;
441
+ this.stats.messagesPerSecond = seconds > 0 ? messages / seconds : 0;
442
+ }
443
+ // Update queue depth
444
+ this.stats.queueDepth = this.getQueueDepth();
445
+ }
446
+ updateLatencyStats(latencyMs) {
447
+ // Exponential moving average
448
+ const alpha = 0.1;
449
+ this.stats.avgLatencyMs = alpha * latencyMs + (1 - alpha) * this.stats.avgLatencyMs;
450
+ }
451
+ getStats() {
452
+ return { ...this.stats };
453
+ }
454
+ getQueueDepth() {
455
+ let total = 0;
456
+ for (const queue of this.queues.values()) {
457
+ total += queue.length;
458
+ }
459
+ return total;
460
+ }
461
+ // Direct message retrieval for agents (pull mode)
462
+ getMessages(agentId) {
463
+ const queue = this.queues.get(agentId);
464
+ if (!queue) {
465
+ return [];
466
+ }
467
+ const now = Date.now();
468
+ const messages = [];
469
+ // O(1) per dequeue operation
470
+ while (queue.length > 0) {
471
+ const entry = queue.dequeue();
472
+ if (!entry)
473
+ break;
474
+ if (now - entry.message.timestamp.getTime() <= entry.message.ttlMs) {
475
+ messages.push(entry.message);
476
+ }
477
+ }
478
+ return messages;
479
+ }
480
+ // Query pending messages for an agent
481
+ hasPendingMessages(agentId) {
482
+ const queue = this.queues.get(agentId);
483
+ return queue !== undefined && queue.length > 0;
484
+ }
485
+ // Get message by ID
486
+ getMessage(messageId) {
487
+ for (const queue of this.queues.values()) {
488
+ const entry = queue.find(e => e.message.id === messageId);
489
+ if (entry) {
490
+ return entry.message;
491
+ }
492
+ }
493
+ return undefined;
494
+ }
495
+ }
496
+ export function createMessageBus(config) {
497
+ return new MessageBus(config);
498
+ }
499
+ //# sourceMappingURL=message-bus.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"message-bus.js","sourceRoot":"","sources":["../src/message-bus.ts"],"names":[],"mappings":"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"}