@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/transform.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transform.d.ts","sourceRoot":"","sources":["../src/transform.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAGH,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"transform.d.ts","sourceRoot":"","sources":["../src/transform.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAGH,OAAO,KAAK,EACX,QAAQ,EACR,YAAY,EACZ,iBAAiB,EACjB,mBAAmB,EAEnB,MAAM,cAAc,CAAC;AACtB,OAAO,KAAK,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AA4EhE,MAAM,WAAW,wBAAwB;IACxC,2CAA2C;IAC3C,WAAW,EAAE,mBAAmB,EAAE,CAAC;IACnC,yDAAyD;IACzD,iBAAiB,EAAE,GAAG,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IAC1C,8CAA8C;IAC9C,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,CAAC,QAAQ,CAAC,KAAK,IAAI,CAAC;CAC3C;AAED,MAAM,WAAW,uBAAuB;IACvC,KAAK,EAAE,YAAY,GAAG,IAAI,CAAC;IAC3B,OAAO,EAAE,OAAO,CAAC;IACjB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,KAAK,CAAC,EAAE,KAAK,CAAC;CACd;AAqDD;;GAEG;AACH,wBAAsB,wBAAwB,CAC7C,KAAK,EAAE,YAAY,EACnB,OAAO,EAAE,gBAAgB,EACzB,aAAa,EAAE,iBAAiB,EAAE,EAClC,OAAO,EAAE,wBAAwB,GAC/B,OAAO,CAAC,uBAAuB,CAAC,CA6GlC"}
|
package/dist/transform.js
CHANGED
|
@@ -60,6 +60,44 @@ function runScript(scriptPath, event, context, timeoutMs) {
|
|
|
60
60
|
}
|
|
61
61
|
});
|
|
62
62
|
}
|
|
63
|
+
/**
|
|
64
|
+
* Apply the on_error policy when a transform fails.
|
|
65
|
+
* Returns a pipeline result to short-circuit the pipeline, or undefined to continue.
|
|
66
|
+
*/
|
|
67
|
+
function applyErrorPolicy(policy, transformName, error, event, durationMs, options) {
|
|
68
|
+
if (policy === 'drop') {
|
|
69
|
+
options.onLog?.({
|
|
70
|
+
phase: 'transform.error_drop',
|
|
71
|
+
transform: transformName,
|
|
72
|
+
event_id: event.id,
|
|
73
|
+
trace_id: event.trace_id,
|
|
74
|
+
error: error.message,
|
|
75
|
+
duration_ms: durationMs,
|
|
76
|
+
});
|
|
77
|
+
return { event: null, dropped: true, dropTransform: transformName, error };
|
|
78
|
+
}
|
|
79
|
+
if (policy === 'halt') {
|
|
80
|
+
options.onLog?.({
|
|
81
|
+
phase: 'transform.error_halt',
|
|
82
|
+
transform: transformName,
|
|
83
|
+
event_id: event.id,
|
|
84
|
+
trace_id: event.trace_id,
|
|
85
|
+
error: error.message,
|
|
86
|
+
duration_ms: durationMs,
|
|
87
|
+
});
|
|
88
|
+
throw new TransformError(transformName, `Transform "${transformName}" failed with halt policy: ${error.message}`);
|
|
89
|
+
}
|
|
90
|
+
// policy === 'pass' (default): fail-open, continue with current event
|
|
91
|
+
options.onLog?.({
|
|
92
|
+
phase: 'transform.error',
|
|
93
|
+
transform: transformName,
|
|
94
|
+
event_id: event.id,
|
|
95
|
+
trace_id: event.trace_id,
|
|
96
|
+
error: error.message,
|
|
97
|
+
duration_ms: durationMs,
|
|
98
|
+
});
|
|
99
|
+
return undefined;
|
|
100
|
+
}
|
|
63
101
|
/**
|
|
64
102
|
* Execute a transform pipeline for a route.
|
|
65
103
|
*/
|
|
@@ -77,6 +115,7 @@ export async function executeTransformPipeline(event, context, transformRefs, op
|
|
|
77
115
|
event_id: current.id,
|
|
78
116
|
trace_id: current.trace_id,
|
|
79
117
|
});
|
|
118
|
+
const policy = ref.on_error ?? def.on_error ?? 'pass';
|
|
80
119
|
if (def.type === 'script' && def.script) {
|
|
81
120
|
const result = await runScript(def.script, current, context, def.timeout_ms ?? DEFAULT_TIMEOUT_MS);
|
|
82
121
|
const durationMs = Date.now() - startTime;
|
|
@@ -91,15 +130,9 @@ export async function executeTransformPipeline(event, context, transformRefs, op
|
|
|
91
130
|
return { event: null, dropped: true, dropTransform: def.name };
|
|
92
131
|
}
|
|
93
132
|
if (result.error) {
|
|
94
|
-
options
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
event_id: current.id,
|
|
98
|
-
trace_id: current.trace_id,
|
|
99
|
-
error: result.error.message,
|
|
100
|
-
duration_ms: durationMs,
|
|
101
|
-
});
|
|
102
|
-
// fail-open: continue with current event
|
|
133
|
+
const errorResult = applyErrorPolicy(policy, def.name, result.error, current, durationMs, options);
|
|
134
|
+
if (errorResult)
|
|
135
|
+
return errorResult;
|
|
103
136
|
}
|
|
104
137
|
if (result.event) {
|
|
105
138
|
current = result.event;
|
|
@@ -141,15 +174,9 @@ export async function executeTransformPipeline(event, context, transformRefs, op
|
|
|
141
174
|
}
|
|
142
175
|
catch (err) {
|
|
143
176
|
const durationMs = Date.now() - startTime;
|
|
144
|
-
options
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
event_id: current.id,
|
|
148
|
-
trace_id: current.trace_id,
|
|
149
|
-
error: err.message,
|
|
150
|
-
duration_ms: durationMs,
|
|
151
|
-
});
|
|
152
|
-
// fail-open: continue with current event
|
|
177
|
+
const errorResult = applyErrorPolicy(policy, def.name, err, current, durationMs, options);
|
|
178
|
+
if (errorResult)
|
|
179
|
+
return errorResult;
|
|
153
180
|
}
|
|
154
181
|
}
|
|
155
182
|
}
|
package/dist/transform.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transform.js","sourceRoot":"","sources":["../src/transform.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"transform.js","sourceRoot":"","sources":["../src/transform.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAS9C,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAE7C,gFAAgF;AAEhF,MAAM,kBAAkB,GAAG,MAAM,CAAC;AAQlC,SAAS,SAAS,CACjB,UAAkB,EAClB,KAAmB,EACnB,OAAyB,EACzB,SAAiB;IAEjB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC9B,MAAM,GAAG,GAA2B;YACnC,GAAI,OAAO,CAAC,GAA8B;YAC1C,cAAc,EAAE,OAAO,CAAC,MAAM;YAC9B,cAAc,EAAE,OAAO,CAAC,MAAM;YAC9B,kBAAkB,EAAE,OAAO,CAAC,SAAS;YACrC,gBAAgB,EAAE,KAAK,CAAC,EAAE;YAC1B,aAAa,EAAE,OAAO,CAAC,SAAS;SAChC,CAAC;QAEF,MAAM,KAAK,GAAG,QAAQ,CACrB,UAAU,EACV,EAAE,EACF,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,EAAE,SAAS,EAAE,EAAE,GAAG,IAAI,GAAG,IAAI,EAAE,EACxD,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE;YAC1B,IAAI,KAAK,EAAE,CAAC;gBACX,wEAAwE;gBACxE,kDAAkD;gBAClD,MAAM,WAAW,GAAG,KAA2C,CAAC;gBAChE,MAAM,QAAQ,GAAG,OAAO,WAAW,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;gBAChF,4BAA4B;gBAC5B,IAAI,QAAQ,KAAK,CAAC,EAAE,CAAC;oBACpB,OAAO,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;oBACxC,OAAO;gBACR,CAAC;gBACD,gEAAgE;gBAChE,OAAO,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAc,EAAE,CAAC,CAAC;gBAC1D,OAAO;YACR,CAAC;YAED,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,EAAE,CAAC;YAC9B,IAAI,CAAC,OAAO,EAAE,CAAC;gBACd,sBAAsB;gBACtB,OAAO,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;gBACxC,OAAO;YACR,CAAC;YAED,IAAI,CAAC;gBACJ,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAiB,CAAC;gBACrD,OAAO,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;YAC9C,CAAC;YAAC,OAAO,QAAQ,EAAE,CAAC;gBACnB,2BAA2B;gBAC3B,OAAO,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,QAAiB,EAAE,CAAC,CAAC;YAC9D,CAAC;QACF,CAAC,CACD,CAAC;QAEF,4BAA4B;QAC5B,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;YACjB,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;YACzC,KAAK,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;QACnB,CAAC;IACF,CAAC,CAAC,CAAC;AACJ,CAAC;AAoBD;;;GAGG;AACH,SAAS,gBAAgB,CACxB,MAA4B,EAC5B,aAAqB,EACrB,KAAY,EACZ,KAAmB,EACnB,UAAkB,EAClB,OAAiC;IAEjC,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;QACvB,OAAO,CAAC,KAAK,EAAE,CAAC;YACf,KAAK,EAAE,sBAAsB;YAC7B,SAAS,EAAE,aAAa;YACxB,QAAQ,EAAE,KAAK,CAAC,EAAE;YAClB,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,KAAK,EAAE,KAAK,CAAC,OAAO;YACpB,WAAW,EAAE,UAAU;SACvB,CAAC,CAAC;QACH,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,aAAa,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC;IAC5E,CAAC;IAED,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;QACvB,OAAO,CAAC,KAAK,EAAE,CAAC;YACf,KAAK,EAAE,sBAAsB;YAC7B,SAAS,EAAE,aAAa;YACxB,QAAQ,EAAE,KAAK,CAAC,EAAE;YAClB,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,KAAK,EAAE,KAAK,CAAC,OAAO;YACpB,WAAW,EAAE,UAAU;SACvB,CAAC,CAAC;QACH,MAAM,IAAI,cAAc,CACvB,aAAa,EACb,cAAc,aAAa,8BAA8B,KAAK,CAAC,OAAO,EAAE,CACxE,CAAC;IACH,CAAC;IAED,sEAAsE;IACtE,OAAO,CAAC,KAAK,EAAE,CAAC;QACf,KAAK,EAAE,iBAAiB;QACxB,SAAS,EAAE,aAAa;QACxB,QAAQ,EAAE,KAAK,CAAC,EAAE;QAClB,QAAQ,EAAE,KAAK,CAAC,QAAQ;QACxB,KAAK,EAAE,KAAK,CAAC,OAAO;QACpB,WAAW,EAAE,UAAU;KACvB,CAAC,CAAC;IACH,OAAO,SAAS,CAAC;AAClB,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,wBAAwB,CAC7C,KAAmB,EACnB,OAAyB,EACzB,aAAkC,EAClC,OAAiC;IAEjC,IAAI,OAAO,GAAiB,KAAK,CAAC;IAElC,KAAK,MAAM,GAAG,IAAI,aAAa,EAAE,CAAC;QACjC,MAAM,GAAG,GAAG,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC;QAChE,IAAI,CAAC,GAAG,EAAE,CAAC;YACV,MAAM,IAAI,cAAc,CAAC,GAAG,CAAC,GAAG,EAAE,cAAc,GAAG,CAAC,GAAG,4BAA4B,CAAC,CAAC;QACtF,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAE7B,OAAO,CAAC,KAAK,EAAE,CAAC;YACf,KAAK,EAAE,iBAAiB;YACxB,SAAS,EAAE,GAAG,CAAC,IAAI;YACnB,QAAQ,EAAE,OAAO,CAAC,EAAE;YACpB,QAAQ,EAAE,OAAO,CAAC,QAAQ;SAC1B,CAAC,CAAC;QAEH,MAAM,MAAM,GAAyB,GAAG,CAAC,QAAQ,IAAI,GAAG,CAAC,QAAQ,IAAI,MAAM,CAAC;QAE5E,IAAI,GAAG,CAAC,IAAI,KAAK,QAAQ,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;YACzC,MAAM,MAAM,GAAG,MAAM,SAAS,CAC7B,GAAG,CAAC,MAAM,EACV,OAAO,EACP,OAAO,EACP,GAAG,CAAC,UAAU,IAAI,kBAAkB,CACpC,CAAC;YAEF,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;YAE1C,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;gBACpB,OAAO,CAAC,KAAK,EAAE,CAAC;oBACf,KAAK,EAAE,gBAAgB;oBACvB,SAAS,EAAE,GAAG,CAAC,IAAI;oBACnB,QAAQ,EAAE,OAAO,CAAC,EAAE;oBACpB,QAAQ,EAAE,OAAO,CAAC,QAAQ;oBAC1B,WAAW,EAAE,UAAU;iBACvB,CAAC,CAAC;gBACH,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,aAAa,EAAE,GAAG,CAAC,IAAI,EAAE,CAAC;YAChE,CAAC;YAED,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;gBAClB,MAAM,WAAW,GAAG,gBAAgB,CACnC,MAAM,EACN,GAAG,CAAC,IAAI,EACR,MAAM,CAAC,KAAK,EACZ,OAAO,EACP,UAAU,EACV,OAAO,CACP,CAAC;gBACF,IAAI,WAAW;oBAAE,OAAO,WAAW,CAAC;YACrC,CAAC;YAED,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;gBAClB,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC;YACxB,CAAC;YAED,OAAO,CAAC,KAAK,EAAE,CAAC;gBACf,KAAK,EAAE,gBAAgB;gBACvB,SAAS,EAAE,GAAG,CAAC,IAAI;gBACnB,QAAQ,EAAE,OAAO,CAAC,EAAE;gBACpB,QAAQ,EAAE,OAAO,CAAC,QAAQ;gBAC1B,WAAW,EAAE,UAAU;aACvB,CAAC,CAAC;QACJ,CAAC;aAAM,IAAI,GAAG,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YACnC,MAAM,SAAS,GAAG,OAAO,CAAC,iBAAiB,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC1D,IAAI,CAAC,SAAS,EAAE,CAAC;gBAChB,MAAM,IAAI,cAAc,CAAC,GAAG,CAAC,IAAI,EAAE,sBAAsB,GAAG,CAAC,IAAI,cAAc,CAAC,CAAC;YAClF,CAAC;YAED,IAAI,CAAC;gBACJ,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,OAAO,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;gBACzD,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;gBAE1C,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;oBACrB,OAAO,CAAC,KAAK,EAAE,CAAC;wBACf,KAAK,EAAE,gBAAgB;wBACvB,SAAS,EAAE,GAAG,CAAC,IAAI;wBACnB,QAAQ,EAAE,OAAO,CAAC,EAAE;wBACpB,QAAQ,EAAE,OAAO,CAAC,QAAQ;wBAC1B,WAAW,EAAE,UAAU;qBACvB,CAAC,CAAC;oBACH,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,aAAa,EAAE,GAAG,CAAC,IAAI,EAAE,CAAC;gBAChE,CAAC;gBAED,OAAO,GAAG,MAAM,CAAC;gBACjB,OAAO,CAAC,KAAK,EAAE,CAAC;oBACf,KAAK,EAAE,gBAAgB;oBACvB,SAAS,EAAE,GAAG,CAAC,IAAI;oBACnB,QAAQ,EAAE,OAAO,CAAC,EAAE;oBACpB,QAAQ,EAAE,OAAO,CAAC,QAAQ;oBAC1B,WAAW,EAAE,UAAU;iBACvB,CAAC,CAAC;YACJ,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACd,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;gBAC1C,MAAM,WAAW,GAAG,gBAAgB,CACnC,MAAM,EACN,GAAG,CAAC,IAAI,EACR,GAAY,EACZ,OAAO,EACP,UAAU,EACV,OAAO,CACP,CAAC;gBACF,IAAI,WAAW;oBAAE,OAAO,WAAW,CAAC;YACrC,CAAC;QACF,CAAC;IACF,CAAC;IAED,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;AAC3C,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@orgloop/core",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.6",
|
|
4
4
|
"description": "OrgLoop runtime engine — library-first event routing",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -15,7 +15,7 @@
|
|
|
15
15
|
"ajv": "^8.17.0",
|
|
16
16
|
"js-yaml": "^4.1.0",
|
|
17
17
|
"uuid": "^11.0.0",
|
|
18
|
-
"@orgloop/sdk": "0.1.
|
|
18
|
+
"@orgloop/sdk": "0.1.6"
|
|
19
19
|
},
|
|
20
20
|
"devDependencies": {
|
|
21
21
|
"@types/js-yaml": "^4.0.9",
|