@tagma/sdk 0.7.3 → 0.7.5
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 +85 -57
- package/dist/approval.d.ts +2 -12
- package/dist/approval.d.ts.map +1 -1
- package/dist/approval.js +1 -90
- package/dist/approval.js.map +1 -1
- package/dist/bootstrap.d.ts +1 -1
- package/dist/bootstrap.d.ts.map +1 -1
- package/dist/completions/file-exists.js +1 -1
- package/dist/completions/file-exists.js.map +1 -1
- package/dist/completions/output-check.d.ts.map +1 -1
- package/dist/completions/output-check.js +17 -4
- package/dist/completions/output-check.js.map +1 -1
- package/dist/config.d.ts +4 -4
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +2 -2
- package/dist/config.js.map +1 -1
- package/dist/dataflow.d.ts +3 -0
- package/dist/dataflow.d.ts.map +1 -0
- package/dist/dataflow.js +2 -0
- package/dist/dataflow.js.map +1 -0
- package/dist/drivers/opencode.d.ts.map +1 -1
- package/dist/drivers/opencode.js +23 -71
- package/dist/drivers/opencode.js.map +1 -1
- package/dist/engine.d.ts +5 -56
- package/dist/engine.d.ts.map +1 -1
- package/dist/engine.js +7 -297
- package/dist/engine.js.map +1 -1
- package/dist/index.d.ts +4 -6
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -4
- package/dist/index.js.map +1 -1
- package/dist/logger.d.ts +2 -60
- package/dist/logger.d.ts.map +1 -1
- package/dist/logger.js +1 -153
- package/dist/logger.js.map +1 -1
- package/dist/middlewares/static-context.d.ts.map +1 -1
- package/dist/middlewares/static-context.js +1 -2
- package/dist/middlewares/static-context.js.map +1 -1
- package/dist/pipeline-runner.d.ts.map +1 -1
- package/dist/pipeline-runner.js +2 -2
- package/dist/pipeline-runner.js.map +1 -1
- package/dist/plugins.d.ts +2 -2
- package/dist/plugins.d.ts.map +1 -1
- package/dist/plugins.js +1 -1
- package/dist/plugins.js.map +1 -1
- package/dist/runner.d.ts +1 -35
- package/dist/runner.d.ts.map +1 -1
- package/dist/runner.js +1 -610
- package/dist/runner.js.map +1 -1
- package/dist/runtime/adapters/stdin-approval.d.ts +2 -0
- package/dist/runtime/adapters/stdin-approval.d.ts.map +1 -0
- package/dist/runtime/adapters/stdin-approval.js +2 -0
- package/dist/runtime/adapters/stdin-approval.js.map +1 -0
- package/dist/runtime/adapters/websocket-approval.d.ts +2 -0
- package/dist/runtime/adapters/websocket-approval.d.ts.map +1 -0
- package/dist/runtime/adapters/websocket-approval.js +2 -0
- package/dist/runtime/adapters/websocket-approval.js.map +1 -0
- package/dist/runtime/bun-process-runner.d.ts +2 -0
- package/dist/runtime/bun-process-runner.d.ts.map +1 -0
- package/dist/runtime/bun-process-runner.js +2 -0
- package/dist/runtime/bun-process-runner.js.map +1 -0
- package/dist/runtime.d.ts +2 -8
- package/dist/runtime.d.ts.map +1 -1
- package/dist/runtime.js +1 -7
- package/dist/runtime.js.map +1 -1
- package/dist/schema.d.ts.map +1 -1
- package/dist/schema.js +3 -4
- package/dist/schema.js.map +1 -1
- package/dist/tagma.d.ts +3 -4
- package/dist/tagma.d.ts.map +1 -1
- package/dist/tagma.js +2 -3
- package/dist/tagma.js.map +1 -1
- package/dist/triggers/file.d.ts.map +1 -1
- package/dist/triggers/file.js +74 -108
- package/dist/triggers/file.js.map +1 -1
- package/dist/triggers/manual.d.ts.map +1 -1
- package/dist/triggers/manual.js +1 -2
- package/dist/triggers/manual.js.map +1 -1
- package/dist/types.d.ts +1 -2
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +1 -12
- package/dist/types.js.map +1 -1
- package/dist/utils-api.d.ts +1 -1
- package/dist/utils-api.d.ts.map +1 -1
- package/dist/utils-api.js +1 -1
- package/dist/utils-api.js.map +1 -1
- package/dist/validate-raw.d.ts.map +1 -1
- package/dist/validate-raw.js +5 -12
- package/dist/validate-raw.js.map +1 -1
- package/package.json +20 -22
- package/dist/adapters/stdin-approval.d.ts +0 -6
- package/dist/adapters/stdin-approval.d.ts.map +0 -1
- package/dist/adapters/stdin-approval.js +0 -90
- package/dist/adapters/stdin-approval.js.map +0 -1
- package/dist/adapters/websocket-approval.d.ts +0 -28
- package/dist/adapters/websocket-approval.d.ts.map +0 -1
- package/dist/adapters/websocket-approval.js +0 -147
- package/dist/adapters/websocket-approval.js.map +0 -1
- package/dist/core/dataflow.d.ts +0 -23
- package/dist/core/dataflow.d.ts.map +0 -1
- package/dist/core/dataflow.js +0 -99
- package/dist/core/dataflow.js.map +0 -1
- package/dist/core/log-prune.d.ts +0 -16
- package/dist/core/log-prune.d.ts.map +0 -1
- package/dist/core/log-prune.js +0 -34
- package/dist/core/log-prune.js.map +0 -1
- package/dist/core/preflight.d.ts +0 -13
- package/dist/core/preflight.d.ts.map +0 -1
- package/dist/core/preflight.js +0 -61
- package/dist/core/preflight.js.map +0 -1
- package/dist/core/run-context.d.ts +0 -55
- package/dist/core/run-context.d.ts.map +0 -1
- package/dist/core/run-context.js +0 -158
- package/dist/core/run-context.js.map +0 -1
- package/dist/core/run-state.d.ts +0 -25
- package/dist/core/run-state.d.ts.map +0 -1
- package/dist/core/run-state.js +0 -93
- package/dist/core/run-state.js.map +0 -1
- package/dist/core/scheduler.d.ts +0 -13
- package/dist/core/scheduler.d.ts.map +0 -1
- package/dist/core/scheduler.js +0 -35
- package/dist/core/scheduler.js.map +0 -1
- package/dist/core/task-executor.d.ts +0 -13
- package/dist/core/task-executor.d.ts.map +0 -1
- package/dist/core/task-executor.js +0 -601
- package/dist/core/task-executor.js.map +0 -1
- package/dist/core/trigger-errors.d.ts +0 -9
- package/dist/core/trigger-errors.d.ts.map +0 -1
- package/dist/core/trigger-errors.js +0 -15
- package/dist/core/trigger-errors.js.map +0 -1
- package/dist/dag.d.ts +0 -45
- package/dist/dag.d.ts.map +0 -1
- package/dist/dag.js +0 -177
- package/dist/dag.js.map +0 -1
- package/dist/hooks.d.ts +0 -73
- package/dist/hooks.d.ts.map +0 -1
- package/dist/hooks.js +0 -106
- package/dist/hooks.js.map +0 -1
- package/dist/pipeline-definition.d.ts +0 -3
- package/dist/pipeline-definition.d.ts.map +0 -1
- package/dist/pipeline-definition.js +0 -4
- package/dist/pipeline-definition.js.map +0 -1
- package/dist/ports.d.ts +0 -196
- package/dist/ports.d.ts.map +0 -1
- package/dist/ports.js +0 -688
- package/dist/ports.js.map +0 -1
- package/dist/prompt-doc.d.ts +0 -70
- package/dist/prompt-doc.d.ts.map +0 -1
- package/dist/prompt-doc.js +0 -154
- package/dist/prompt-doc.js.map +0 -1
- package/dist/registry.d.ts +0 -67
- package/dist/registry.d.ts.map +0 -1
- package/dist/registry.js +0 -293
- package/dist/registry.js.map +0 -1
- package/dist/task-ref.d.ts +0 -55
- package/dist/task-ref.d.ts.map +0 -1
- package/dist/task-ref.js +0 -103
- package/dist/task-ref.js.map +0 -1
- package/dist/utils.d.ts +0 -13
- package/dist/utils.d.ts.map +0 -1
- package/dist/utils.js +0 -177
- package/dist/utils.js.map +0 -1
- package/src/adapters/stdin-approval.ts +0 -106
- package/src/adapters/websocket-approval.ts +0 -224
- package/src/approval.ts +0 -131
- package/src/bootstrap.ts +0 -55
- package/src/completions/exit-code.ts +0 -34
- package/src/completions/file-exists.ts +0 -66
- package/src/completions/output-check.test.ts +0 -50
- package/src/completions/output-check.ts +0 -92
- package/src/config-ops.test.ts +0 -70
- package/src/config-ops.ts +0 -328
- package/src/config.ts +0 -26
- package/src/core/dataflow.test.ts +0 -166
- package/src/core/dataflow.ts +0 -161
- package/src/core/log-prune.test.ts +0 -58
- package/src/core/log-prune.ts +0 -43
- package/src/core/preflight.test.ts +0 -49
- package/src/core/preflight.ts +0 -89
- package/src/core/run-context.test.ts +0 -256
- package/src/core/run-context.ts +0 -211
- package/src/core/run-state.test.ts +0 -98
- package/src/core/run-state.ts +0 -122
- package/src/core/scheduler.test.ts +0 -83
- package/src/core/scheduler.ts +0 -42
- package/src/core/task-executor.ts +0 -743
- package/src/core/trigger-errors.ts +0 -15
- package/src/dag.test.ts +0 -56
- package/src/dag.ts +0 -245
- package/src/drivers/opencode.ts +0 -410
- package/src/engine-ports-mixed.test.ts +0 -156
- package/src/engine-ports.test.ts +0 -166
- package/src/engine-task-type.test.ts +0 -56
- package/src/engine.ts +0 -458
- package/src/hooks.ts +0 -193
- package/src/index.ts +0 -33
- package/src/logger.ts +0 -182
- package/src/middlewares/static-context.ts +0 -49
- package/src/pipeline-definition.ts +0 -5
- package/src/pipeline-runner.test.ts +0 -91
- package/src/pipeline-runner.ts +0 -194
- package/src/plugin-registry.test.ts +0 -382
- package/src/plugins.ts +0 -21
- package/src/ports.test.ts +0 -678
- package/src/ports.ts +0 -925
- package/src/prompt-doc.test.ts +0 -174
- package/src/prompt-doc.ts +0 -169
- package/src/registry.ts +0 -353
- package/src/runner.test.ts +0 -142
- package/src/runner.ts +0 -666
- package/src/runtime.ts +0 -20
- package/src/schema-ports.test.ts +0 -172
- package/src/schema.test.ts +0 -213
- package/src/schema.ts +0 -379
- package/src/tagma.test.ts +0 -155
- package/src/tagma.ts +0 -62
- package/src/task-ref.test.ts +0 -401
- package/src/task-ref.ts +0 -121
- package/src/triggers/file.ts +0 -164
- package/src/triggers/manual.ts +0 -86
- package/src/types.ts +0 -18
- package/src/utils-api.ts +0 -8
- package/src/utils.test.ts +0 -28
- package/src/utils.ts +0 -203
- package/src/validate-raw-plugin-types.test.ts +0 -60
- package/src/validate-raw-ports.test.ts +0 -136
- package/src/validate-raw.ts +0 -852
- package/src/yaml-compiler.test.ts +0 -108
- package/src/yaml-compiler.ts +0 -110
- package/src/yaml.ts +0 -11
package/dist/index.d.ts
CHANGED
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
export { createTagma } from './tagma';
|
|
2
2
|
export type { CreateTagmaOptions, Tagma, TagmaRunOptions } from './tagma';
|
|
3
|
-
export { bunRuntime } from '
|
|
4
|
-
export type { TagmaRuntime, RunOptions as RuntimeRunOptions } from '
|
|
5
|
-
export { definePipeline } from '
|
|
6
|
-
export {
|
|
7
|
-
export { TriggerBlockedError, TriggerTimeoutError } from './engine';
|
|
8
|
-
export type { EngineResult, RunEventPayload } from './engine';
|
|
3
|
+
export { bunRuntime } from '@tagma/runtime-bun';
|
|
4
|
+
export type { TagmaRuntime, RunOptions as RuntimeRunOptions } from '@tagma/core';
|
|
5
|
+
export { definePipeline, PluginRegistry, TriggerBlockedError, TriggerTimeoutError } from '@tagma/core';
|
|
6
|
+
export type { EngineResult, RunEventPayload } from '@tagma/core';
|
|
9
7
|
export { RUN_PROTOCOL_VERSION, TASK_LOG_CAP } from './types';
|
|
10
8
|
export type { PipelineConfig, RawPipelineConfig, RawTrackConfig, RawTaskConfig, TrackConfig, TaskConfig, RunSnapshotPayload, WireRunEvent, RunTaskState, TaskLogLine, ApprovalRequestInfo, TaskStatus, ApprovalRequest, PluginCategory, PluginCapabilities, PluginSetupContext, TagmaPlugin, DriverPlugin, TriggerPlugin, CompletionPlugin, MiddlewarePlugin, RunEventPayload as PipelineRunEventPayload, } from '@tagma/types';
|
|
11
9
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AACtC,YAAY,EAAE,kBAAkB,EAAE,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAC1E,OAAO,EAAE,UAAU,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AACtC,YAAY,EAAE,kBAAkB,EAAE,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAC1E,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,YAAY,EAAE,YAAY,EAAE,UAAU,IAAI,iBAAiB,EAAE,MAAM,aAAa,CAAC;AACjF,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AACvG,YAAY,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AACjE,OAAO,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAC7D,YAAY,EACV,cAAc,EACd,iBAAiB,EACjB,cAAc,EACd,aAAa,EACb,WAAW,EACX,UAAU,EACV,kBAAkB,EAClB,YAAY,EACZ,YAAY,EACZ,WAAW,EACX,mBAAmB,EACnB,UAAU,EACV,eAAe,EACf,cAAc,EACd,kBAAkB,EAClB,kBAAkB,EAClB,WAAW,EACX,YAAY,EACZ,aAAa,EACb,gBAAgB,EAChB,gBAAgB,EAChB,eAAe,IAAI,uBAAuB,GAC3C,MAAM,cAAc,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
export { createTagma } from './tagma';
|
|
2
|
-
export { bunRuntime } from '
|
|
3
|
-
export { definePipeline } from '
|
|
4
|
-
export { PluginRegistry } from './registry';
|
|
5
|
-
export { TriggerBlockedError, TriggerTimeoutError } from './engine';
|
|
2
|
+
export { bunRuntime } from '@tagma/runtime-bun';
|
|
3
|
+
export { definePipeline, PluginRegistry, TriggerBlockedError, TriggerTimeoutError } from '@tagma/core';
|
|
6
4
|
export { RUN_PROTOCOL_VERSION, TASK_LOG_CAP } from './types';
|
|
7
5
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAEtC,OAAO,EAAE,UAAU,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAEtC,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAEhD,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAEvG,OAAO,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC"}
|
package/dist/logger.d.ts
CHANGED
|
@@ -1,61 +1,3 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
* server) use this to stream process-level detail into UIs alongside the
|
|
4
|
-
* on-disk pipeline.log. `taskId` is extracted from a `[task:<id>]` prefix
|
|
5
|
-
* when the call site passes one, or overridden explicitly via the optional
|
|
6
|
-
* `taskId` argument on `section`/`quiet` (which carry no prefix).
|
|
7
|
-
*/
|
|
8
|
-
export type LogLevel = 'info' | 'warn' | 'error' | 'debug' | 'section' | 'quiet';
|
|
9
|
-
export interface LogRecord {
|
|
10
|
-
readonly level: LogLevel;
|
|
11
|
-
readonly taskId: string | null;
|
|
12
|
-
readonly timestamp: string;
|
|
13
|
-
readonly text: string;
|
|
14
|
-
}
|
|
15
|
-
export type LogListener = (record: LogRecord) => void;
|
|
16
|
-
/**
|
|
17
|
-
* Dual-channel logger.
|
|
18
|
-
*
|
|
19
|
-
* - `info/warn/error` → console AND file (brief, user-visible events)
|
|
20
|
-
* - `debug` → file ONLY (verbose diagnostics)
|
|
21
|
-
* - `section` → file ONLY (visual separators)
|
|
22
|
-
* - `quiet` → file ONLY (bulk payload like full stdout dumps)
|
|
23
|
-
*
|
|
24
|
-
* Log file path: <workDir>/.tagma/logs/<runId>/pipeline.log (one file per pipeline run,
|
|
25
|
-
* truncated on construction). Every line is also forwarded to the optional
|
|
26
|
-
* `onLine` callback as a structured `LogRecord`, so callers that want to
|
|
27
|
-
* stream the run process over IPC/SSE don't need to tail the file.
|
|
28
|
-
*/
|
|
29
|
-
export declare class Logger {
|
|
30
|
-
private readonly filePath;
|
|
31
|
-
private readonly runDir;
|
|
32
|
-
private readonly onLine;
|
|
33
|
-
/** Persistent file descriptor for append writes (avoids open/close per line). */
|
|
34
|
-
private fd;
|
|
35
|
-
constructor(workDir: string, runId: string, onLine?: LogListener);
|
|
36
|
-
info(prefix: string, message: string): void;
|
|
37
|
-
warn(prefix: string, message: string): void;
|
|
38
|
-
error(prefix: string, message: string): void;
|
|
39
|
-
/** File-only diagnostic log line. */
|
|
40
|
-
debug(prefix: string, message: string): void;
|
|
41
|
-
/** File-only visual separator with title. */
|
|
42
|
-
section(title: string, taskId?: string | null): void;
|
|
43
|
-
/** File-only bulk payload (e.g. full stdout / stderr dumps). */
|
|
44
|
-
quiet(message: string, taskId?: string | null): void;
|
|
45
|
-
private append;
|
|
46
|
-
/** Close the persistent file handle. Called by the engine at run completion. */
|
|
47
|
-
close(): void;
|
|
48
|
-
private emit;
|
|
49
|
-
get path(): string;
|
|
50
|
-
/** Directory that holds all artifacts for this run (pipeline.log, *.stderr, etc.). */
|
|
51
|
-
get dir(): string;
|
|
52
|
-
}
|
|
53
|
-
/** Return the last `n` non-empty lines of `text`, joined with newlines. */
|
|
54
|
-
export declare function tailLines(text: string, n: number): string;
|
|
55
|
-
/**
|
|
56
|
-
* Truncate a blob to at most `maxBytes` UTF-8 bytes for log embedding,
|
|
57
|
-
* appending a marker when truncation occurred.
|
|
58
|
-
* Uses TextEncoder so CJK and emoji (multi-byte) characters are counted correctly.
|
|
59
|
-
*/
|
|
60
|
-
export declare function clip(text: string, maxBytes?: number): string;
|
|
1
|
+
export { clip, Logger, tailLines } from '@tagma/core';
|
|
2
|
+
export type { LogLevel, LogListener, LogRecord } from '@tagma/core';
|
|
61
3
|
//# sourceMappingURL=logger.d.ts.map
|
package/dist/logger.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACtD,YAAY,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC"}
|
package/dist/logger.js
CHANGED
|
@@ -1,154 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
import { mkdirSync, writeFileSync, openSync, writeSync, closeSync } from 'node:fs';
|
|
3
|
-
const TASK_PREFIX_RE = /\[task:([^\]]+)\]/;
|
|
4
|
-
function taskIdFromPrefix(prefix) {
|
|
5
|
-
const m = TASK_PREFIX_RE.exec(prefix);
|
|
6
|
-
return m ? m[1] : null;
|
|
7
|
-
}
|
|
8
|
-
/**
|
|
9
|
-
* Dual-channel logger.
|
|
10
|
-
*
|
|
11
|
-
* - `info/warn/error` → console AND file (brief, user-visible events)
|
|
12
|
-
* - `debug` → file ONLY (verbose diagnostics)
|
|
13
|
-
* - `section` → file ONLY (visual separators)
|
|
14
|
-
* - `quiet` → file ONLY (bulk payload like full stdout dumps)
|
|
15
|
-
*
|
|
16
|
-
* Log file path: <workDir>/.tagma/logs/<runId>/pipeline.log (one file per pipeline run,
|
|
17
|
-
* truncated on construction). Every line is also forwarded to the optional
|
|
18
|
-
* `onLine` callback as a structured `LogRecord`, so callers that want to
|
|
19
|
-
* stream the run process over IPC/SSE don't need to tail the file.
|
|
20
|
-
*/
|
|
21
|
-
export class Logger {
|
|
22
|
-
filePath;
|
|
23
|
-
runDir;
|
|
24
|
-
onLine;
|
|
25
|
-
/** Persistent file descriptor for append writes (avoids open/close per line). */
|
|
26
|
-
fd;
|
|
27
|
-
constructor(workDir, runId, onLine) {
|
|
28
|
-
this.runDir = resolve(workDir, '.tagma', 'logs', runId);
|
|
29
|
-
this.filePath = resolve(this.runDir, 'pipeline.log');
|
|
30
|
-
this.onLine = onLine ?? null;
|
|
31
|
-
mkdirSync(dirname(this.filePath), { recursive: true });
|
|
32
|
-
const header = `# Pipeline run ${runId} @ ${new Date().toISOString()}\n` +
|
|
33
|
-
`# Host: ${process.platform} ${process.arch} Bun: ${process.versions.bun ?? 'n/a'}\n` +
|
|
34
|
-
`# Work dir: ${workDir}\n\n`;
|
|
35
|
-
writeFileSync(this.filePath, header);
|
|
36
|
-
// Open once for all subsequent appends (O_APPEND is implied by 'a' flag)
|
|
37
|
-
this.fd = openSync(this.filePath, 'a');
|
|
38
|
-
}
|
|
39
|
-
info(prefix, message) {
|
|
40
|
-
const ts = timestamp();
|
|
41
|
-
const line = `${ts} ${prefix} ${message}`;
|
|
42
|
-
// eslint-disable-next-line no-console
|
|
43
|
-
console.log(line);
|
|
44
|
-
this.emit('info', ts, line, taskIdFromPrefix(prefix));
|
|
45
|
-
this.append(line);
|
|
46
|
-
}
|
|
47
|
-
warn(prefix, message) {
|
|
48
|
-
const ts = timestamp();
|
|
49
|
-
const line = `${ts} ${prefix} WARN: ${message}`;
|
|
50
|
-
console.warn(line);
|
|
51
|
-
this.emit('warn', ts, line, taskIdFromPrefix(prefix));
|
|
52
|
-
this.append(line);
|
|
53
|
-
}
|
|
54
|
-
error(prefix, message) {
|
|
55
|
-
const ts = timestamp();
|
|
56
|
-
const line = `${ts} ${prefix} ERROR: ${message}`;
|
|
57
|
-
console.error(line);
|
|
58
|
-
this.emit('error', ts, line, taskIdFromPrefix(prefix));
|
|
59
|
-
this.append(line);
|
|
60
|
-
}
|
|
61
|
-
/** File-only diagnostic log line. */
|
|
62
|
-
debug(prefix, message) {
|
|
63
|
-
const ts = timestamp();
|
|
64
|
-
const line = `${ts} ${prefix} DEBUG: ${message}`;
|
|
65
|
-
this.emit('debug', ts, line, taskIdFromPrefix(prefix));
|
|
66
|
-
this.append(line);
|
|
67
|
-
}
|
|
68
|
-
/** File-only visual separator with title. */
|
|
69
|
-
section(title, taskId) {
|
|
70
|
-
const ts = timestamp();
|
|
71
|
-
const text = `\n━━━ ${title} ━━━`;
|
|
72
|
-
this.emit('section', ts, text, taskId ?? null);
|
|
73
|
-
this.append(text);
|
|
74
|
-
}
|
|
75
|
-
/** File-only bulk payload (e.g. full stdout / stderr dumps). */
|
|
76
|
-
quiet(message, taskId) {
|
|
77
|
-
const ts = timestamp();
|
|
78
|
-
this.emit('quiet', ts, message, taskId ?? null);
|
|
79
|
-
this.append(message);
|
|
80
|
-
}
|
|
81
|
-
append(line) {
|
|
82
|
-
if (this.fd === null)
|
|
83
|
-
return;
|
|
84
|
-
try {
|
|
85
|
-
const data = line.endsWith('\n') ? line : line + '\n';
|
|
86
|
-
writeSync(this.fd, data);
|
|
87
|
-
}
|
|
88
|
-
catch {
|
|
89
|
-
// Swallow log write failures; engine correctness shouldn't depend on logging.
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
/** Close the persistent file handle. Called by the engine at run completion. */
|
|
93
|
-
close() {
|
|
94
|
-
if (this.fd !== null) {
|
|
95
|
-
try {
|
|
96
|
-
closeSync(this.fd);
|
|
97
|
-
}
|
|
98
|
-
catch {
|
|
99
|
-
/* already closed */
|
|
100
|
-
}
|
|
101
|
-
this.fd = null;
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
emit(level, ts, text, taskId) {
|
|
105
|
-
if (!this.onLine)
|
|
106
|
-
return;
|
|
107
|
-
try {
|
|
108
|
-
this.onLine({ level, taskId, timestamp: ts, text });
|
|
109
|
-
}
|
|
110
|
-
catch {
|
|
111
|
-
// Never let a listener error derail the pipeline.
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
get path() {
|
|
115
|
-
return this.filePath;
|
|
116
|
-
}
|
|
117
|
-
/** Directory that holds all artifacts for this run (pipeline.log, *.stderr, etc.). */
|
|
118
|
-
get dir() {
|
|
119
|
-
return this.runDir;
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
function timestamp() {
|
|
123
|
-
const d = new Date();
|
|
124
|
-
const hh = String(d.getHours()).padStart(2, '0');
|
|
125
|
-
const mm = String(d.getMinutes()).padStart(2, '0');
|
|
126
|
-
const ss = String(d.getSeconds()).padStart(2, '0');
|
|
127
|
-
const ms = String(d.getMilliseconds()).padStart(3, '0');
|
|
128
|
-
return `${hh}:${mm}:${ss}.${ms}`;
|
|
129
|
-
}
|
|
130
|
-
/** Return the last `n` non-empty lines of `text`, joined with newlines. */
|
|
131
|
-
export function tailLines(text, n) {
|
|
132
|
-
if (!text)
|
|
133
|
-
return '';
|
|
134
|
-
const lines = text.split(/\r?\n/).filter((l) => l.length > 0);
|
|
135
|
-
return lines.slice(-n).join('\n');
|
|
136
|
-
}
|
|
137
|
-
/**
|
|
138
|
-
* Truncate a blob to at most `maxBytes` UTF-8 bytes for log embedding,
|
|
139
|
-
* appending a marker when truncation occurred.
|
|
140
|
-
* Uses TextEncoder so CJK and emoji (multi-byte) characters are counted correctly.
|
|
141
|
-
*/
|
|
142
|
-
export function clip(text, maxBytes = 16 * 1024) {
|
|
143
|
-
if (!text)
|
|
144
|
-
return '';
|
|
145
|
-
const encoder = new TextEncoder();
|
|
146
|
-
const bytes = encoder.encode(text);
|
|
147
|
-
if (bytes.length <= maxBytes)
|
|
148
|
-
return text;
|
|
149
|
-
const omittedBytes = bytes.length - maxBytes;
|
|
150
|
-
// TextDecoder handles partial code-point boundaries safely (replacement char insertion)
|
|
151
|
-
const truncated = new TextDecoder().decode(bytes.slice(0, maxBytes));
|
|
152
|
-
return truncated + `\n…[truncated ${omittedBytes} bytes]`;
|
|
153
|
-
}
|
|
1
|
+
export { clip, Logger, tailLines } from '@tagma/core';
|
|
154
2
|
//# sourceMappingURL=logger.js.map
|
package/dist/logger.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"static-context.d.ts","sourceRoot":"","sources":["../../src/middlewares/static-context.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,gBAAgB,EAAqC,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"static-context.d.ts","sourceRoot":"","sources":["../../src/middlewares/static-context.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,gBAAgB,EAAqC,MAAM,UAAU,CAAC;AAGpF,eAAO,MAAM,uBAAuB,EAAE,gBA2CrC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"static-context.js","sourceRoot":"","sources":["../../src/middlewares/static-context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAEhC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"static-context.js","sourceRoot":"","sources":["../../src/middlewares/static-context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAEhC,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE1D,MAAM,CAAC,MAAM,uBAAuB,GAAqB;IACvD,IAAI,EAAE,gBAAgB;IACtB,MAAM,EAAE;QACN,WAAW,EAAE,2DAA2D;QACxE,MAAM,EAAE;YACN,IAAI,EAAE;gBACJ,IAAI,EAAE,MAAM;gBACZ,QAAQ,EAAE,IAAI;gBACd,WAAW,EAAE,+DAA+D;gBAC5E,WAAW,EAAE,cAAc;aAC5B;YACD,KAAK,EAAE;gBACL,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,uEAAuE;gBACpF,WAAW,EAAE,oBAAoB;aAClC;SACF;KACF;IAED,KAAK,CAAC,UAAU,CACd,GAAmB,EACnB,MAA+B,EAC/B,GAAsB;QAEtB,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAc,CAAC;QACvC,IAAI,CAAC,QAAQ;YAAE,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;QAEhF,MAAM,QAAQ,GAAG,YAAY,CAAC,QAAQ,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC;QACrD,MAAM,IAAI,GAAG,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAEhC,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC;YAC3B,OAAO,CAAC,IAAI,CAAC,wBAAwB,QAAQ,sBAAsB,CAAC,CAAC;YACrE,OAAO,GAAG,CAAC;QACb,CAAC;QAED,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;QAClC,MAAM,KAAK,GAAI,MAAM,CAAC,KAAgB,IAAI,cAAc,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;QAE7E,uEAAuE;QACvE,qEAAqE;QACrE,wEAAwE;QACxE,OAAO,aAAa,CAAC,GAAG,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;IAChD,CAAC;CACF,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline-runner.d.ts","sourceRoot":"","sources":["../src/pipeline-runner.ts"],"names":[],"mappings":"AAwBA,OAAO,KAAK,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AACjE,OAAO,
|
|
1
|
+
{"version":3,"file":"pipeline-runner.d.ts","sourceRoot":"","sources":["../src/pipeline-runner.ts"],"names":[],"mappings":"AAwBA,OAAO,KAAK,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AACjE,OAAO,EAEL,KAAK,cAAc,EACnB,KAAK,eAAe,EACpB,KAAK,YAAY,EAClB,MAAM,SAAS,CAAC;AAGjB,YAAY,EAAE,YAAY,EAAE,CAAC;AAE7B,MAAM,MAAM,oBAAoB,GAAG,MAAM,GAAG,SAAS,GAAG,MAAM,GAAG,SAAS,CAAC;AAC3E,MAAM,MAAM,qBAAqB,GAAG,IAAI,CAAC,kBAAkB,EAAE,QAAQ,GAAG,SAAS,CAAC,CAAC;AAEnF,qBAAa,cAAc;IAyBvB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,IAAI;IA1BvB;;;OAGG;IACH,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAE5B;;;OAGG;IACH,OAAO,CAAC,MAAM,CAAuB;IACrC,OAAO,CAAC,OAAO,CAAgC;IAC/C,OAAO,CAAC,OAAO,CAAsC;IACrD,OAAO,CAAC,gBAAgB,CAAyB;IACjD,OAAO,CAAC,SAAS,CAA+C;IAChE;;;;;OAKG;IACH,OAAO,CAAC,MAAM,CAAmC;gBAG9B,MAAM,EAAE,cAAc,EACtB,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,qBAAqB;IAK9C,IAAI,KAAK,IAAI,MAAM,GAAG,IAAI,CAEzB;IACD,IAAI,MAAM,IAAI,oBAAoB,CAEjC;IAED;;OAEG;IACH,KAAK,IAAI,OAAO,CAAC,YAAY,CAAC;IAiC9B,OAAO,CAAC,WAAW;IA0DnB;;OAEG;IACH,KAAK,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI;IAK5B;;;OAGG;IACH,QAAQ,IAAI,WAAW,CAAC,MAAM,EAAE,YAAY,CAAC;IAM7C;;;;OAIG;IACH,SAAS,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,eAAe,KAAK,IAAI,GAAG,MAAM,IAAI;CAIjE"}
|
package/dist/pipeline-runner.js
CHANGED
|
@@ -21,8 +21,8 @@
|
|
|
21
21
|
// // Later, from IPC:
|
|
22
22
|
// runners.get(id)?.abort();
|
|
23
23
|
import { runPipeline } from './engine';
|
|
24
|
-
import { TASK_LOG_CAP } from './types';
|
|
25
|
-
import { generateRunId } from '
|
|
24
|
+
import { TASK_LOG_CAP, } from './types';
|
|
25
|
+
import { generateRunId } from '@tagma/core';
|
|
26
26
|
export class PipelineRunner {
|
|
27
27
|
config;
|
|
28
28
|
workDir;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline-runner.js","sourceRoot":"","sources":["../src/pipeline-runner.ts"],"names":[],"mappings":"AAAA,yBAAyB;AACzB,EAAE;AACF,oEAAoE;AACpE,sEAAsE;AACtE,oBAAoB;AACpB,EAAE;AACF,iEAAiE;AACjE,0EAA0E;AAC1E,kEAAkE;AAClE,sBAAsB;AACtB,EAAE;AACF,yBAAyB;AACzB,EAAE;AACF,uDAAuD;AACvD,EAAE;AACF,sEAAsE;AACtE,4DAA4D;AAC5D,oBAAoB;AACpB,4CAA4C;AAC5C,EAAE;AACF,wBAAwB;AACxB,8BAA8B;AAE9B,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAEvC,OAAO,
|
|
1
|
+
{"version":3,"file":"pipeline-runner.js","sourceRoot":"","sources":["../src/pipeline-runner.ts"],"names":[],"mappings":"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"}
|
package/dist/plugins.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export { bootstrapBuiltins } from './bootstrap';
|
|
2
|
-
export { PluginRegistry, isValidPluginName, PLUGIN_NAME_RE, readPluginManifest, } from '
|
|
3
|
-
export type { RegisteredCapability, RegisterResult } from '
|
|
2
|
+
export { PluginRegistry, isValidPluginName, PLUGIN_NAME_RE, readPluginManifest, } from '@tagma/core';
|
|
3
|
+
export type { RegisteredCapability, RegisterResult } from '@tagma/core';
|
|
4
4
|
export type { CapabilityHandler, PluginCategory, PluginCapabilities, PluginModule, PluginManifest, PluginSetupContext, TagmaPlugin, DriverPlugin, TriggerPlugin, CompletionPlugin, MiddlewarePlugin, } from './types';
|
|
5
5
|
//# sourceMappingURL=plugins.d.ts.map
|
package/dist/plugins.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugins.d.ts","sourceRoot":"","sources":["../src/plugins.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EACL,cAAc,EACd,iBAAiB,EACjB,cAAc,EACd,kBAAkB,GACnB,MAAM,
|
|
1
|
+
{"version":3,"file":"plugins.d.ts","sourceRoot":"","sources":["../src/plugins.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EACL,cAAc,EACd,iBAAiB,EACjB,cAAc,EACd,kBAAkB,GACnB,MAAM,aAAa,CAAC;AACrB,YAAY,EAAE,oBAAoB,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AACxE,YAAY,EACV,iBAAiB,EACjB,cAAc,EACd,kBAAkB,EAClB,YAAY,EACZ,cAAc,EACd,kBAAkB,EAClB,WAAW,EACX,YAAY,EACZ,aAAa,EACb,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,SAAS,CAAC"}
|
package/dist/plugins.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
export { bootstrapBuiltins } from './bootstrap';
|
|
2
|
-
export { PluginRegistry, isValidPluginName, PLUGIN_NAME_RE, readPluginManifest, } from '
|
|
2
|
+
export { PluginRegistry, isValidPluginName, PLUGIN_NAME_RE, readPluginManifest, } from '@tagma/core';
|
|
3
3
|
//# sourceMappingURL=plugins.js.map
|
package/dist/plugins.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugins.js","sourceRoot":"","sources":["../src/plugins.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EACL,cAAc,EACd,iBAAiB,EACjB,cAAc,EACd,kBAAkB,GACnB,MAAM,
|
|
1
|
+
{"version":3,"file":"plugins.js","sourceRoot":"","sources":["../src/plugins.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EACL,cAAc,EACd,iBAAiB,EACjB,cAAc,EACd,kBAAkB,GACnB,MAAM,aAAa,CAAC"}
|
package/dist/runner.d.ts
CHANGED
|
@@ -1,36 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
export interface RunOptions {
|
|
3
|
-
readonly timeoutMs?: number;
|
|
4
|
-
readonly signal?: AbortSignal;
|
|
5
|
-
/**
|
|
6
|
-
* If set, stream the child's stdout to this file path as it arrives. The
|
|
7
|
-
* returned `TaskResult.stdout` is still a bounded in-memory tail
|
|
8
|
-
* (`maxStdoutTailBytes`) — callers that need the full output should read
|
|
9
|
-
* from the returned `stdoutPath`. Parent directories are created as needed.
|
|
10
|
-
*/
|
|
11
|
-
readonly stdoutPath?: string;
|
|
12
|
-
/** Symmetric to `stdoutPath` for stderr. */
|
|
13
|
-
readonly stderrPath?: string;
|
|
14
|
-
/**
|
|
15
|
-
* Cap on bytes retained in memory for the returned `TaskResult.stdout`
|
|
16
|
-
* string. Defaults to `DEFAULT_STDOUT_TAIL_BYTES`. Bytes beyond this cap
|
|
17
|
-
* from the HEAD of the stream are dropped from the in-memory string; the
|
|
18
|
-
* on-disk file (if `stdoutPath` is set) is still the full output.
|
|
19
|
-
*/
|
|
20
|
-
readonly maxStdoutTailBytes?: number;
|
|
21
|
-
readonly maxStderrTailBytes?: number;
|
|
22
|
-
}
|
|
23
|
-
/**
|
|
24
|
-
* R2: Validate a SpawnSpec returned by a third-party driver. Returns null on
|
|
25
|
-
* success or a human-readable error message describing the first violation.
|
|
26
|
-
*
|
|
27
|
-
* Catching this here is critical: an undetected bad spec ends up calling
|
|
28
|
-
* Bun.spawn with garbage and the resulting TypeError leaks into engine
|
|
29
|
-
* processTask's catch block as "Cannot read properties of undefined". By
|
|
30
|
-
* validating here we surface a clear "Driver X returned invalid args" message
|
|
31
|
-
* instead, and short-circuit before holding any process resources.
|
|
32
|
-
*/
|
|
33
|
-
export declare function validateSpawnSpec(spec: unknown, driverName: string): string | null;
|
|
34
|
-
export declare function runSpawn(spec: SpawnSpec, driver: DriverPlugin | null, opts?: RunOptions): Promise<TaskResult>;
|
|
35
|
-
export declare function runCommand(command: string, cwd: string, opts?: RunOptions): Promise<TaskResult>;
|
|
1
|
+
export { runCommand, runSpawn } from '@tagma/runtime-bun';
|
|
36
2
|
//# sourceMappingURL=runner.d.ts.map
|
package/dist/runner.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"runner.d.ts","sourceRoot":"","sources":["../src/runner.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"runner.d.ts","sourceRoot":"","sources":["../src/runner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC"}
|