@orgloop/core 0.1.4 → 0.1.6
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 +51 -17
- package/dist/engine.d.ts +26 -19
- package/dist/engine.d.ts.map +1 -1
- package/dist/engine.js +68 -356
- package/dist/engine.js.map +1 -1
- package/dist/errors.d.ts +11 -0
- package/dist/errors.d.ts.map +1 -1
- package/dist/errors.js +22 -0
- package/dist/errors.js.map +1 -1
- package/dist/http.d.ts +19 -1
- package/dist/http.d.ts.map +1 -1
- package/dist/http.js +107 -2
- package/dist/http.js.map +1 -1
- package/dist/index.d.ts +8 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +6 -1
- package/dist/index.js.map +1 -1
- package/dist/logger.d.ts +5 -1
- package/dist/logger.d.ts.map +1 -1
- package/dist/logger.js +15 -5
- package/dist/logger.js.map +1 -1
- package/dist/module-instance.d.ts +76 -0
- package/dist/module-instance.d.ts.map +1 -0
- package/dist/module-instance.js +185 -0
- package/dist/module-instance.js.map +1 -0
- package/dist/registry.d.ts +23 -0
- package/dist/registry.d.ts.map +1 -0
- package/dist/registry.js +42 -0
- package/dist/registry.js.map +1 -0
- package/dist/runtime.d.ts +81 -0
- package/dist/runtime.d.ts.map +1 -0
- package/dist/runtime.js +519 -0
- package/dist/runtime.js.map +1 -0
- package/dist/scheduler.d.ts +11 -2
- package/dist/scheduler.d.ts.map +1 -1
- package/dist/scheduler.js +44 -6
- package/dist/scheduler.js.map +1 -1
- package/dist/transform.d.ts.map +1 -1
- package/dist/transform.js +45 -18
- package/dist/transform.js.map +1 -1
- package/package.json +2 -2
package/dist/runtime.js
ADDED
|
@@ -0,0 +1,519 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Runtime — the long-lived host process.
|
|
3
|
+
*
|
|
4
|
+
* Owns shared infrastructure (bus, scheduler, logger, webhook server)
|
|
5
|
+
* and manages modules through a registry. Modules are loaded/unloaded
|
|
6
|
+
* independently without affecting each other.
|
|
7
|
+
*/
|
|
8
|
+
import { EventEmitter } from 'node:events';
|
|
9
|
+
import { readFile } from 'node:fs/promises';
|
|
10
|
+
import { generateTraceId } from '@orgloop/sdk';
|
|
11
|
+
import { InMemoryBus } from './bus.js';
|
|
12
|
+
import { ConnectorError, DeliveryError, ModuleNotFoundError, RuntimeError } from './errors.js';
|
|
13
|
+
import { DEFAULT_HTTP_PORT, WebhookServer } from './http.js';
|
|
14
|
+
import { LoggerManager } from './logger.js';
|
|
15
|
+
import { ModuleInstance } from './module-instance.js';
|
|
16
|
+
import { ModuleRegistry } from './registry.js';
|
|
17
|
+
import { matchRoutes } from './router.js';
|
|
18
|
+
import { Scheduler } from './scheduler.js';
|
|
19
|
+
import { InMemoryCheckpointStore } from './store.js';
|
|
20
|
+
import { executeTransformPipeline } from './transform.js';
|
|
21
|
+
// ─── Runtime Class ───────────────────────────────────────────────────────────
|
|
22
|
+
class Runtime extends EventEmitter {
|
|
23
|
+
// Shared infrastructure
|
|
24
|
+
bus;
|
|
25
|
+
scheduler = new Scheduler();
|
|
26
|
+
loggerManager;
|
|
27
|
+
registry = new ModuleRegistry();
|
|
28
|
+
webhookServer;
|
|
29
|
+
// Running state
|
|
30
|
+
running = false;
|
|
31
|
+
httpStarted = false;
|
|
32
|
+
startedAt = 0;
|
|
33
|
+
httpPort;
|
|
34
|
+
dataDir;
|
|
35
|
+
// Circuit breaker
|
|
36
|
+
circuitBreakerOpts;
|
|
37
|
+
circuitRetryTimers = new Map();
|
|
38
|
+
// Stored configs for reload
|
|
39
|
+
moduleConfigs = new Map();
|
|
40
|
+
moduleLoadOptions = new Map();
|
|
41
|
+
constructor(options) {
|
|
42
|
+
super();
|
|
43
|
+
this.bus = options?.bus ?? new InMemoryBus();
|
|
44
|
+
this.loggerManager = options?.loggerManager ?? new LoggerManager();
|
|
45
|
+
this.httpPort =
|
|
46
|
+
options?.httpPort ??
|
|
47
|
+
(process.env.ORGLOOP_PORT
|
|
48
|
+
? Number.parseInt(process.env.ORGLOOP_PORT, 10)
|
|
49
|
+
: DEFAULT_HTTP_PORT);
|
|
50
|
+
this.dataDir = options?.dataDir;
|
|
51
|
+
this.circuitBreakerOpts = {
|
|
52
|
+
failureThreshold: options?.circuitBreaker?.failureThreshold ?? 5,
|
|
53
|
+
retryAfterMs: options?.circuitBreaker?.retryAfterMs ?? 60_000,
|
|
54
|
+
};
|
|
55
|
+
this.webhookServer = new WebhookServer((event) => this.inject(event));
|
|
56
|
+
}
|
|
57
|
+
// ─── Lifecycle ───────────────────────────────────────────────────────────
|
|
58
|
+
async start() {
|
|
59
|
+
if (this.running)
|
|
60
|
+
return;
|
|
61
|
+
// Start scheduler
|
|
62
|
+
this.scheduler.start((sourceId, moduleName) => this.pollSource(sourceId, moduleName));
|
|
63
|
+
this.running = true;
|
|
64
|
+
this.startedAt = Date.now();
|
|
65
|
+
await this.emitLog('runtime.start', { result: 'started' });
|
|
66
|
+
}
|
|
67
|
+
/** Start the HTTP server for webhooks and control API. */
|
|
68
|
+
async startHttpServer() {
|
|
69
|
+
if (this.httpStarted)
|
|
70
|
+
return;
|
|
71
|
+
this.webhookServer.runtime = this;
|
|
72
|
+
await this.webhookServer.start(this.httpPort);
|
|
73
|
+
this.httpStarted = true;
|
|
74
|
+
}
|
|
75
|
+
/** Whether the HTTP server is currently running. */
|
|
76
|
+
isHttpStarted() {
|
|
77
|
+
return this.httpStarted;
|
|
78
|
+
}
|
|
79
|
+
async stop() {
|
|
80
|
+
if (!this.running)
|
|
81
|
+
return;
|
|
82
|
+
await this.emitLog('runtime.stop', { result: 'stopping' });
|
|
83
|
+
// Deactivate and shutdown all modules
|
|
84
|
+
for (const mod of this.registry.list()) {
|
|
85
|
+
try {
|
|
86
|
+
mod.deactivate();
|
|
87
|
+
this.scheduler.removeSources(mod.name);
|
|
88
|
+
await mod.shutdown();
|
|
89
|
+
}
|
|
90
|
+
catch {
|
|
91
|
+
// Non-blocking
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
// Stop webhook server
|
|
95
|
+
if (this.httpStarted) {
|
|
96
|
+
await this.webhookServer.stop();
|
|
97
|
+
this.httpStarted = false;
|
|
98
|
+
}
|
|
99
|
+
// Stop scheduler
|
|
100
|
+
this.scheduler.stop();
|
|
101
|
+
// Clear circuit breaker timers
|
|
102
|
+
for (const timer of this.circuitRetryTimers.values()) {
|
|
103
|
+
clearTimeout(timer);
|
|
104
|
+
}
|
|
105
|
+
this.circuitRetryTimers.clear();
|
|
106
|
+
// Flush and shutdown loggers
|
|
107
|
+
await this.loggerManager.flush();
|
|
108
|
+
await this.loggerManager.shutdown();
|
|
109
|
+
this.running = false;
|
|
110
|
+
}
|
|
111
|
+
// ─── Module Management ───────────────────────────────────────────────────
|
|
112
|
+
async loadModule(config, options) {
|
|
113
|
+
const checkpointStore = options?.checkpointStore ?? new InMemoryCheckpointStore();
|
|
114
|
+
const mod = new ModuleInstance(config, {
|
|
115
|
+
sources: options?.sources ?? new Map(),
|
|
116
|
+
actors: options?.actors ?? new Map(),
|
|
117
|
+
transforms: options?.transforms ?? new Map(),
|
|
118
|
+
loggers: options?.loggers ?? new Map(),
|
|
119
|
+
checkpointStore,
|
|
120
|
+
});
|
|
121
|
+
// Initialize all connectors
|
|
122
|
+
await mod.initialize();
|
|
123
|
+
// Activate and register before adding to scheduler
|
|
124
|
+
// (so the first poll finds the module in the registry)
|
|
125
|
+
mod.activate();
|
|
126
|
+
this.registry.register(mod);
|
|
127
|
+
// Add module loggers to shared LoggerManager (tagged with module name)
|
|
128
|
+
for (const [, logger] of mod.getLoggers()) {
|
|
129
|
+
this.loggerManager.addLogger(logger, mod.name);
|
|
130
|
+
}
|
|
131
|
+
// Register poll sources with shared scheduler
|
|
132
|
+
const defaultInterval = config.defaults?.poll_interval ?? '5m';
|
|
133
|
+
let hasWebhooks = false;
|
|
134
|
+
for (const srcCfg of config.sources) {
|
|
135
|
+
const connector = mod.getSource(srcCfg.id);
|
|
136
|
+
if (!connector)
|
|
137
|
+
continue;
|
|
138
|
+
if (typeof connector.webhook === 'function') {
|
|
139
|
+
// Webhook-based source: register with shared server
|
|
140
|
+
this.webhookServer.addHandler(srcCfg.id, connector.webhook());
|
|
141
|
+
hasWebhooks = true;
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
// Poll-based source: register with shared scheduler
|
|
145
|
+
const interval = srcCfg.poll?.interval ?? defaultInterval;
|
|
146
|
+
this.scheduler.addSource(srcCfg.id, interval, mod.name);
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
// Start HTTP server on demand when webhook sources are present
|
|
150
|
+
if (hasWebhooks && !this.httpStarted) {
|
|
151
|
+
await this.startHttpServer();
|
|
152
|
+
}
|
|
153
|
+
// Store config and options for reload
|
|
154
|
+
this.moduleConfigs.set(config.name, config);
|
|
155
|
+
if (options) {
|
|
156
|
+
this.moduleLoadOptions.set(config.name, options);
|
|
157
|
+
}
|
|
158
|
+
await this.emitLog('module.active', {
|
|
159
|
+
result: `module "${config.name}" loaded`,
|
|
160
|
+
module: config.name,
|
|
161
|
+
});
|
|
162
|
+
return mod.status();
|
|
163
|
+
}
|
|
164
|
+
async unloadModule(name) {
|
|
165
|
+
const mod = this.registry.get(name);
|
|
166
|
+
if (!mod) {
|
|
167
|
+
throw new ModuleNotFoundError(name);
|
|
168
|
+
}
|
|
169
|
+
await this.emitLog('module.unloading', {
|
|
170
|
+
result: `unloading module "${name}"`,
|
|
171
|
+
module: name,
|
|
172
|
+
});
|
|
173
|
+
// Deactivate
|
|
174
|
+
mod.deactivate();
|
|
175
|
+
// Remove sources from scheduler
|
|
176
|
+
this.scheduler.removeSources(name);
|
|
177
|
+
// Remove webhook handlers for module sources
|
|
178
|
+
for (const srcCfg of mod.config.sources) {
|
|
179
|
+
this.webhookServer.removeHandler(srcCfg.id);
|
|
180
|
+
}
|
|
181
|
+
// Shutdown module resources
|
|
182
|
+
await mod.shutdown();
|
|
183
|
+
// Remove loggers by module tag
|
|
184
|
+
this.loggerManager.removeLoggersByTag(name);
|
|
185
|
+
// Unregister from registry
|
|
186
|
+
this.registry.unregister(name);
|
|
187
|
+
// Clean stored config
|
|
188
|
+
this.moduleConfigs.delete(name);
|
|
189
|
+
this.moduleLoadOptions.delete(name);
|
|
190
|
+
await this.emitLog('module.removed', {
|
|
191
|
+
result: `module "${name}" removed`,
|
|
192
|
+
module: name,
|
|
193
|
+
});
|
|
194
|
+
}
|
|
195
|
+
async reloadModule(name) {
|
|
196
|
+
const config = this.moduleConfigs.get(name);
|
|
197
|
+
if (!config) {
|
|
198
|
+
throw new ModuleNotFoundError(name);
|
|
199
|
+
}
|
|
200
|
+
const options = this.moduleLoadOptions.get(name);
|
|
201
|
+
await this.unloadModule(name);
|
|
202
|
+
await this.loadModule(config, options);
|
|
203
|
+
}
|
|
204
|
+
// ─── Event Processing ────────────────────────────────────────────────────
|
|
205
|
+
async inject(event, moduleName) {
|
|
206
|
+
const resolved = event.trace_id ? event : { ...event, trace_id: generateTraceId() };
|
|
207
|
+
if (moduleName) {
|
|
208
|
+
const mod = this.registry.get(moduleName);
|
|
209
|
+
if (!mod) {
|
|
210
|
+
throw new ModuleNotFoundError(moduleName);
|
|
211
|
+
}
|
|
212
|
+
await this.processEvent(resolved, mod);
|
|
213
|
+
}
|
|
214
|
+
else {
|
|
215
|
+
// Process through all active modules
|
|
216
|
+
for (const mod of this.registry.list()) {
|
|
217
|
+
if (mod.getState() === 'active') {
|
|
218
|
+
await this.processEvent(resolved, mod);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
async processEvent(event, mod) {
|
|
224
|
+
this.emit('event', event);
|
|
225
|
+
await this.emitLog('source.emit', {
|
|
226
|
+
event_id: event.id,
|
|
227
|
+
trace_id: event.trace_id,
|
|
228
|
+
source: event.source,
|
|
229
|
+
event_type: event.type,
|
|
230
|
+
module: mod.name,
|
|
231
|
+
});
|
|
232
|
+
// Write to bus (WAL)
|
|
233
|
+
await this.bus.publish(event);
|
|
234
|
+
// Match routes from this module
|
|
235
|
+
const matched = matchRoutes(event, mod.getRoutes());
|
|
236
|
+
if (matched.length === 0) {
|
|
237
|
+
await this.emitLog('route.no_match', {
|
|
238
|
+
event_id: event.id,
|
|
239
|
+
trace_id: event.trace_id,
|
|
240
|
+
source: event.source,
|
|
241
|
+
module: mod.name,
|
|
242
|
+
});
|
|
243
|
+
await this.bus.ack(event.id);
|
|
244
|
+
return;
|
|
245
|
+
}
|
|
246
|
+
// Process each matched route
|
|
247
|
+
for (const match of matched) {
|
|
248
|
+
const { route } = match;
|
|
249
|
+
await this.emitLog('route.match', {
|
|
250
|
+
event_id: event.id,
|
|
251
|
+
trace_id: event.trace_id,
|
|
252
|
+
route: route.name,
|
|
253
|
+
source: event.source,
|
|
254
|
+
target: route.then.actor,
|
|
255
|
+
module: mod.name,
|
|
256
|
+
});
|
|
257
|
+
// Run transform pipeline
|
|
258
|
+
let transformedEvent = event;
|
|
259
|
+
if (route.transforms && route.transforms.length > 0) {
|
|
260
|
+
const pipelineOptions = {
|
|
261
|
+
definitions: mod.config.transforms,
|
|
262
|
+
packageTransforms: mod.getTransformsMap(),
|
|
263
|
+
onLog: (partial) => {
|
|
264
|
+
void this.emitLog(partial.phase ?? 'transform.start', {
|
|
265
|
+
...partial,
|
|
266
|
+
event_id: partial.event_id ?? event.id,
|
|
267
|
+
trace_id: partial.trace_id ?? event.trace_id,
|
|
268
|
+
route: route.name,
|
|
269
|
+
module: mod.name,
|
|
270
|
+
});
|
|
271
|
+
},
|
|
272
|
+
};
|
|
273
|
+
const context = {
|
|
274
|
+
source: event.source,
|
|
275
|
+
target: route.then.actor,
|
|
276
|
+
eventType: event.type,
|
|
277
|
+
routeName: route.name,
|
|
278
|
+
};
|
|
279
|
+
try {
|
|
280
|
+
const result = await executeTransformPipeline(event, context, route.transforms, pipelineOptions);
|
|
281
|
+
if (result.dropped || !result.event) {
|
|
282
|
+
continue; // Skip delivery for this route
|
|
283
|
+
}
|
|
284
|
+
transformedEvent = result.event;
|
|
285
|
+
}
|
|
286
|
+
catch (err) {
|
|
287
|
+
// halt policy throws TransformError — emit error and skip delivery
|
|
288
|
+
this.emit('error', err);
|
|
289
|
+
continue;
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
// Deliver to actor
|
|
293
|
+
await this.deliverToActor(transformedEvent, route.name, route.then.actor, route, mod);
|
|
294
|
+
}
|
|
295
|
+
// Ack the event after all routes processed
|
|
296
|
+
await this.bus.ack(event.id);
|
|
297
|
+
}
|
|
298
|
+
async deliverToActor(event, routeName, actorId, route, mod) {
|
|
299
|
+
const actor = mod.getActor(actorId);
|
|
300
|
+
if (!actor) {
|
|
301
|
+
const error = new DeliveryError(actorId, routeName, `Actor "${actorId}" not found`);
|
|
302
|
+
this.emit('error', error);
|
|
303
|
+
return;
|
|
304
|
+
}
|
|
305
|
+
await this.emitLog('deliver.attempt', {
|
|
306
|
+
event_id: event.id,
|
|
307
|
+
trace_id: event.trace_id,
|
|
308
|
+
route: routeName,
|
|
309
|
+
target: actorId,
|
|
310
|
+
module: mod.name,
|
|
311
|
+
});
|
|
312
|
+
const startTime = Date.now();
|
|
313
|
+
try {
|
|
314
|
+
// Build delivery config
|
|
315
|
+
const deliveryConfig = {
|
|
316
|
+
...(route.then.config ?? {}),
|
|
317
|
+
};
|
|
318
|
+
// Resolve launch prompt if configured
|
|
319
|
+
if (route.with?.prompt_file) {
|
|
320
|
+
try {
|
|
321
|
+
const promptContent = await readFile(route.with.prompt_file, 'utf-8');
|
|
322
|
+
deliveryConfig.launch_prompt = promptContent;
|
|
323
|
+
deliveryConfig.launch_prompt_file = route.with.prompt_file;
|
|
324
|
+
}
|
|
325
|
+
catch {
|
|
326
|
+
// Non-fatal: log but continue delivery
|
|
327
|
+
}
|
|
328
|
+
}
|
|
329
|
+
const result = await actor.deliver(event, deliveryConfig);
|
|
330
|
+
const durationMs = Date.now() - startTime;
|
|
331
|
+
if (result.status === 'delivered') {
|
|
332
|
+
await this.emitLog('deliver.success', {
|
|
333
|
+
event_id: event.id,
|
|
334
|
+
trace_id: event.trace_id,
|
|
335
|
+
route: routeName,
|
|
336
|
+
target: actorId,
|
|
337
|
+
duration_ms: durationMs,
|
|
338
|
+
module: mod.name,
|
|
339
|
+
});
|
|
340
|
+
this.emit('delivery', {
|
|
341
|
+
event,
|
|
342
|
+
route: routeName,
|
|
343
|
+
actor: actorId,
|
|
344
|
+
status: 'delivered',
|
|
345
|
+
});
|
|
346
|
+
}
|
|
347
|
+
else {
|
|
348
|
+
await this.emitLog('deliver.failure', {
|
|
349
|
+
event_id: event.id,
|
|
350
|
+
trace_id: event.trace_id,
|
|
351
|
+
route: routeName,
|
|
352
|
+
target: actorId,
|
|
353
|
+
duration_ms: durationMs,
|
|
354
|
+
error: result.error?.message ?? result.status,
|
|
355
|
+
module: mod.name,
|
|
356
|
+
});
|
|
357
|
+
this.emit('delivery', {
|
|
358
|
+
event,
|
|
359
|
+
route: routeName,
|
|
360
|
+
actor: actorId,
|
|
361
|
+
status: result.status,
|
|
362
|
+
});
|
|
363
|
+
}
|
|
364
|
+
}
|
|
365
|
+
catch (err) {
|
|
366
|
+
const durationMs = Date.now() - startTime;
|
|
367
|
+
const error = new DeliveryError(actorId, routeName, 'Delivery failed', { cause: err });
|
|
368
|
+
this.emit('error', error);
|
|
369
|
+
await this.emitLog('deliver.failure', {
|
|
370
|
+
event_id: event.id,
|
|
371
|
+
trace_id: event.trace_id,
|
|
372
|
+
route: routeName,
|
|
373
|
+
target: actorId,
|
|
374
|
+
duration_ms: durationMs,
|
|
375
|
+
error: error.message,
|
|
376
|
+
module: mod.name,
|
|
377
|
+
});
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
// ─── Source Polling ───────────────────────────────────────────────────────
|
|
381
|
+
async pollSource(sourceId, moduleName) {
|
|
382
|
+
if (!moduleName)
|
|
383
|
+
return;
|
|
384
|
+
const mod = this.registry.get(moduleName);
|
|
385
|
+
if (!mod || mod.getState() !== 'active')
|
|
386
|
+
return;
|
|
387
|
+
const connector = mod.getSource(sourceId);
|
|
388
|
+
if (!connector)
|
|
389
|
+
return;
|
|
390
|
+
const healthState = mod.getHealthState(sourceId);
|
|
391
|
+
if (!healthState)
|
|
392
|
+
return;
|
|
393
|
+
// Circuit breaker: skip poll if circuit is open
|
|
394
|
+
if (healthState.circuitOpen) {
|
|
395
|
+
return;
|
|
396
|
+
}
|
|
397
|
+
healthState.lastPollAttempt = new Date().toISOString();
|
|
398
|
+
try {
|
|
399
|
+
const store = mod.getCheckpointStore();
|
|
400
|
+
const checkpoint = await store.get(sourceId);
|
|
401
|
+
const result = await connector.poll(checkpoint);
|
|
402
|
+
// Save checkpoint
|
|
403
|
+
if (result.checkpoint) {
|
|
404
|
+
await store.set(sourceId, result.checkpoint);
|
|
405
|
+
}
|
|
406
|
+
// Record successful poll
|
|
407
|
+
healthState.lastSuccessfulPoll = new Date().toISOString();
|
|
408
|
+
healthState.lastError = null;
|
|
409
|
+
healthState.totalEventsEmitted += result.events.length;
|
|
410
|
+
// If recovering from errors, log recovery
|
|
411
|
+
if (healthState.consecutiveErrors > 0) {
|
|
412
|
+
await this.emitLog('source.circuit_close', {
|
|
413
|
+
source: sourceId,
|
|
414
|
+
result: `recovered after ${healthState.consecutiveErrors} consecutive errors`,
|
|
415
|
+
module: moduleName,
|
|
416
|
+
});
|
|
417
|
+
}
|
|
418
|
+
healthState.consecutiveErrors = 0;
|
|
419
|
+
healthState.status = 'healthy';
|
|
420
|
+
// Process each event through the module
|
|
421
|
+
for (const event of result.events) {
|
|
422
|
+
const enriched = event.trace_id ? event : { ...event, trace_id: generateTraceId() };
|
|
423
|
+
await this.processEvent(enriched, mod);
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
catch (err) {
|
|
427
|
+
const error = new ConnectorError(sourceId, 'Poll failed', { cause: err });
|
|
428
|
+
this.emit('error', error);
|
|
429
|
+
healthState.consecutiveErrors++;
|
|
430
|
+
healthState.lastError = err instanceof Error ? err.message : String(err);
|
|
431
|
+
// Update health status
|
|
432
|
+
if (healthState.consecutiveErrors >= this.circuitBreakerOpts.failureThreshold) {
|
|
433
|
+
healthState.status = 'unhealthy';
|
|
434
|
+
healthState.circuitOpen = true;
|
|
435
|
+
await this.emitLog('source.circuit_open', {
|
|
436
|
+
source: sourceId,
|
|
437
|
+
error: healthState.lastError,
|
|
438
|
+
result: `${healthState.consecutiveErrors} consecutive failures — polling paused, will retry in ${Math.round(this.circuitBreakerOpts.retryAfterMs / 1000)}s`,
|
|
439
|
+
module: moduleName,
|
|
440
|
+
});
|
|
441
|
+
// Schedule a retry after backoff
|
|
442
|
+
this.scheduleCircuitRetry(sourceId, moduleName);
|
|
443
|
+
}
|
|
444
|
+
else {
|
|
445
|
+
healthState.status = 'degraded';
|
|
446
|
+
await this.emitLog('system.error', {
|
|
447
|
+
source: sourceId,
|
|
448
|
+
error: error.message,
|
|
449
|
+
module: moduleName,
|
|
450
|
+
});
|
|
451
|
+
}
|
|
452
|
+
}
|
|
453
|
+
}
|
|
454
|
+
scheduleCircuitRetry(sourceId, moduleName) {
|
|
455
|
+
const timerKey = `${moduleName}/${sourceId}`;
|
|
456
|
+
const existing = this.circuitRetryTimers.get(timerKey);
|
|
457
|
+
if (existing)
|
|
458
|
+
clearTimeout(existing);
|
|
459
|
+
const timer = setTimeout(async () => {
|
|
460
|
+
this.circuitRetryTimers.delete(timerKey);
|
|
461
|
+
if (!this.running)
|
|
462
|
+
return;
|
|
463
|
+
const mod = this.registry.get(moduleName);
|
|
464
|
+
if (!mod || mod.getState() !== 'active')
|
|
465
|
+
return;
|
|
466
|
+
const healthState = mod.getHealthState(sourceId);
|
|
467
|
+
if (!healthState || !healthState.circuitOpen)
|
|
468
|
+
return;
|
|
469
|
+
await this.emitLog('source.circuit_retry', {
|
|
470
|
+
source: sourceId,
|
|
471
|
+
result: 'attempting recovery poll',
|
|
472
|
+
module: moduleName,
|
|
473
|
+
});
|
|
474
|
+
// Temporarily allow poll by opening the circuit
|
|
475
|
+
healthState.circuitOpen = false;
|
|
476
|
+
await this.pollSource(sourceId, moduleName);
|
|
477
|
+
}, this.circuitBreakerOpts.retryAfterMs);
|
|
478
|
+
this.circuitRetryTimers.set(timerKey, timer);
|
|
479
|
+
}
|
|
480
|
+
// ─── RuntimeControl Implementation ───────────────────────────────────────
|
|
481
|
+
status() {
|
|
482
|
+
return {
|
|
483
|
+
running: this.running,
|
|
484
|
+
pid: process.pid,
|
|
485
|
+
uptime_ms: this.running ? Date.now() - this.startedAt : 0,
|
|
486
|
+
httpPort: this.httpPort,
|
|
487
|
+
modules: this.registry.list().map((m) => m.status()),
|
|
488
|
+
};
|
|
489
|
+
}
|
|
490
|
+
listModules() {
|
|
491
|
+
return this.registry.list().map((m) => m.status());
|
|
492
|
+
}
|
|
493
|
+
getModuleStatus(name) {
|
|
494
|
+
const mod = this.registry.get(name);
|
|
495
|
+
return mod?.status();
|
|
496
|
+
}
|
|
497
|
+
// ─── Logging ─────────────────────────────────────────────────────────────
|
|
498
|
+
async emitLog(phase, fields) {
|
|
499
|
+
const entry = {
|
|
500
|
+
timestamp: new Date().toISOString(),
|
|
501
|
+
event_id: fields.event_id ?? '',
|
|
502
|
+
trace_id: fields.trace_id ?? '',
|
|
503
|
+
phase,
|
|
504
|
+
source: fields.source,
|
|
505
|
+
target: fields.target,
|
|
506
|
+
route: fields.route,
|
|
507
|
+
transform: fields.transform,
|
|
508
|
+
event_type: fields.event_type,
|
|
509
|
+
result: fields.result,
|
|
510
|
+
duration_ms: fields.duration_ms,
|
|
511
|
+
error: fields.error,
|
|
512
|
+
metadata: fields.metadata,
|
|
513
|
+
module: fields.module,
|
|
514
|
+
};
|
|
515
|
+
await this.loggerManager.log(entry);
|
|
516
|
+
}
|
|
517
|
+
}
|
|
518
|
+
export { Runtime };
|
|
519
|
+
//# sourceMappingURL=runtime.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtime.js","sourceRoot":"","sources":["../src/runtime.ts"],"names":[],"mappings":"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"}
|
package/dist/scheduler.d.ts
CHANGED
|
@@ -4,15 +4,24 @@
|
|
|
4
4
|
* Schedules poll operations for sources based on their configured intervals.
|
|
5
5
|
* Graceful start/stop with interval cleanup.
|
|
6
6
|
*/
|
|
7
|
-
export type PollCallback = (sourceId: string) => Promise<void>;
|
|
7
|
+
export type PollCallback = (sourceId: string, moduleName?: string) => Promise<void>;
|
|
8
8
|
export declare class Scheduler {
|
|
9
9
|
private readonly sources;
|
|
10
10
|
private running;
|
|
11
11
|
private pollCallback;
|
|
12
12
|
/**
|
|
13
13
|
* Register a source to be polled at the given interval.
|
|
14
|
+
* If the scheduler is already running, starts polling immediately.
|
|
14
15
|
*/
|
|
15
|
-
addSource(sourceId: string, interval: string): void;
|
|
16
|
+
addSource(sourceId: string, interval: string, moduleName?: string): void;
|
|
17
|
+
/**
|
|
18
|
+
* Remove a single source by ID and clear its interval.
|
|
19
|
+
*/
|
|
20
|
+
removeSource(sourceId: string): void;
|
|
21
|
+
/**
|
|
22
|
+
* Remove all sources belonging to a given module.
|
|
23
|
+
*/
|
|
24
|
+
removeSources(moduleName: string): void;
|
|
16
25
|
/**
|
|
17
26
|
* Start polling all registered sources.
|
|
18
27
|
*/
|
package/dist/scheduler.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scheduler.d.ts","sourceRoot":"","sources":["../src/scheduler.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,MAAM,MAAM,YAAY,GAAG,CAAC,QAAQ,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"scheduler.d.ts","sourceRoot":"","sources":["../src/scheduler.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,MAAM,MAAM,YAAY,GAAG,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;AASpF,qBAAa,SAAS;IACrB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAyB;IACjD,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,YAAY,CAA6B;IAEjD;;;OAGG;IACH,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI;IAcxE;;OAEG;IACH,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAWpC;;OAEG;IACH,aAAa,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI;IAavC;;OAEG;IACH,KAAK,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI;YAerB,QAAQ;IAStB;;OAEG;IACH,IAAI,IAAI,IAAI;IAUZ,IAAI,SAAS,IAAI,OAAO,CAEvB;CACD"}
|
package/dist/scheduler.js
CHANGED
|
@@ -11,10 +11,48 @@ export class Scheduler {
|
|
|
11
11
|
pollCallback = null;
|
|
12
12
|
/**
|
|
13
13
|
* Register a source to be polled at the given interval.
|
|
14
|
+
* If the scheduler is already running, starts polling immediately.
|
|
14
15
|
*/
|
|
15
|
-
addSource(sourceId, interval) {
|
|
16
|
+
addSource(sourceId, interval, moduleName) {
|
|
16
17
|
const intervalMs = parseDuration(interval);
|
|
17
|
-
|
|
18
|
+
const source = { sourceId, intervalMs, moduleName, timer: null };
|
|
19
|
+
this.sources.push(source);
|
|
20
|
+
// If scheduler is already running, start polling this source immediately
|
|
21
|
+
if (this.running && this.pollCallback) {
|
|
22
|
+
void this.safePoll(source.sourceId, source.moduleName);
|
|
23
|
+
source.timer = setInterval(() => {
|
|
24
|
+
void this.safePoll(source.sourceId, source.moduleName);
|
|
25
|
+
}, source.intervalMs);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Remove a single source by ID and clear its interval.
|
|
30
|
+
*/
|
|
31
|
+
removeSource(sourceId) {
|
|
32
|
+
const idx = this.sources.findIndex((s) => s.sourceId === sourceId);
|
|
33
|
+
if (idx === -1)
|
|
34
|
+
return;
|
|
35
|
+
const source = this.sources[idx];
|
|
36
|
+
if (source.timer) {
|
|
37
|
+
clearInterval(source.timer);
|
|
38
|
+
source.timer = null;
|
|
39
|
+
}
|
|
40
|
+
this.sources.splice(idx, 1);
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Remove all sources belonging to a given module.
|
|
44
|
+
*/
|
|
45
|
+
removeSources(moduleName) {
|
|
46
|
+
for (let i = this.sources.length - 1; i >= 0; i--) {
|
|
47
|
+
if (this.sources[i].moduleName === moduleName) {
|
|
48
|
+
const source = this.sources[i];
|
|
49
|
+
if (source.timer) {
|
|
50
|
+
clearInterval(source.timer);
|
|
51
|
+
source.timer = null;
|
|
52
|
+
}
|
|
53
|
+
this.sources.splice(i, 1);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
18
56
|
}
|
|
19
57
|
/**
|
|
20
58
|
* Start polling all registered sources.
|
|
@@ -26,18 +64,18 @@ export class Scheduler {
|
|
|
26
64
|
this.pollCallback = callback;
|
|
27
65
|
for (const source of this.sources) {
|
|
28
66
|
// Run first poll immediately
|
|
29
|
-
void this.safePoll(source.sourceId);
|
|
67
|
+
void this.safePoll(source.sourceId, source.moduleName);
|
|
30
68
|
// Then schedule recurring polls
|
|
31
69
|
source.timer = setInterval(() => {
|
|
32
|
-
void this.safePoll(source.sourceId);
|
|
70
|
+
void this.safePoll(source.sourceId, source.moduleName);
|
|
33
71
|
}, source.intervalMs);
|
|
34
72
|
}
|
|
35
73
|
}
|
|
36
|
-
async safePoll(sourceId) {
|
|
74
|
+
async safePoll(sourceId, moduleName) {
|
|
37
75
|
if (!this.pollCallback)
|
|
38
76
|
return;
|
|
39
77
|
try {
|
|
40
|
-
await this.pollCallback(sourceId);
|
|
78
|
+
await this.pollCallback(sourceId, moduleName);
|
|
41
79
|
}
|
|
42
80
|
catch {
|
|
43
81
|
// Errors handled upstream; scheduler keeps going
|
package/dist/scheduler.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scheduler.js","sourceRoot":"","sources":["../src/scheduler.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"scheduler.js","sourceRoot":"","sources":["../src/scheduler.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAW7C,MAAM,OAAO,SAAS;IACJ,OAAO,GAAsB,EAAE,CAAC;IACzC,OAAO,GAAG,KAAK,CAAC;IAChB,YAAY,GAAwB,IAAI,CAAC;IAEjD;;;OAGG;IACH,SAAS,CAAC,QAAgB,EAAE,QAAgB,EAAE,UAAmB;QAChE,MAAM,UAAU,GAAG,aAAa,CAAC,QAAQ,CAAC,CAAC;QAC3C,MAAM,MAAM,GAAoB,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;QAClF,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAE1B,yEAAyE;QACzE,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACvC,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC;YACvD,MAAM,CAAC,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE;gBAC/B,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC;YACxD,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC;QACvB,CAAC;IACF,CAAC;IAED;;OAEG;IACH,YAAY,CAAC,QAAgB;QAC5B,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAC;QACnE,IAAI,GAAG,KAAK,CAAC,CAAC;YAAE,OAAO;QACvB,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QACjC,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;YAClB,aAAa,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAC5B,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;QACrB,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;IAC7B,CAAC;IAED;;OAEG;IACH,aAAa,CAAC,UAAkB;QAC/B,KAAK,IAAI,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YACnD,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,UAAU,KAAK,UAAU,EAAE,CAAC;gBAC/C,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBAC/B,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;oBAClB,aAAa,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;oBAC5B,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;gBACrB,CAAC;gBACD,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YAC3B,CAAC;QACF,CAAC;IACF,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,QAAsB;QAC3B,IAAI,IAAI,CAAC,OAAO;YAAE,OAAO;QACzB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;QAE7B,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACnC,6BAA6B;YAC7B,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC;YACvD,gCAAgC;YAChC,MAAM,CAAC,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE;gBAC/B,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC;YACxD,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC;QACvB,CAAC;IACF,CAAC;IAEO,KAAK,CAAC,QAAQ,CAAC,QAAgB,EAAE,UAAmB;QAC3D,IAAI,CAAC,IAAI,CAAC,YAAY;YAAE,OAAO;QAC/B,IAAI,CAAC;YACJ,MAAM,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;QAC/C,CAAC;QAAC,MAAM,CAAC;YACR,iDAAiD;QAClD,CAAC;IACF,CAAC;IAED;;OAEG;IACH,IAAI;QACH,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACnC,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;gBAClB,aAAa,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBAC5B,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;YACrB,CAAC;QACF,CAAC;IACF,CAAC;IAED,IAAI,SAAS;QACZ,OAAO,IAAI,CAAC,OAAO,CAAC;IACrB,CAAC;CACD"}
|