@opengoat/core 2026.2.9
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/LICENSE +21 -0
- package/README.md +20 -0
- package/dist/apps/runtime/create-opengoat-runtime.d.ts +14 -0
- package/dist/apps/runtime/create-opengoat-runtime.js +23 -0
- package/dist/apps/runtime/create-opengoat-runtime.js.map +1 -0
- package/dist/core/acp/application/acp-agent.d.ts +60 -0
- package/dist/core/acp/application/acp-agent.js +424 -0
- package/dist/core/acp/application/acp-agent.js.map +1 -0
- package/dist/core/acp/application/session-store.d.ts +13 -0
- package/dist/core/acp/application/session-store.js +40 -0
- package/dist/core/acp/application/session-store.js.map +1 -0
- package/dist/core/acp/domain/meta.d.ts +7 -0
- package/dist/core/acp/domain/meta.js +31 -0
- package/dist/core/acp/domain/meta.js.map +1 -0
- package/dist/core/acp/domain/session.d.ts +23 -0
- package/dist/core/acp/domain/session.js +2 -0
- package/dist/core/acp/domain/session.js.map +1 -0
- package/dist/core/acp/index.d.ts +5 -0
- package/dist/core/acp/index.js +4 -0
- package/dist/core/acp/index.js.map +1 -0
- package/dist/core/agents/application/agent-manifest.service.d.ts +20 -0
- package/dist/core/agents/application/agent-manifest.service.js +89 -0
- package/dist/core/agents/application/agent-manifest.service.js.map +1 -0
- package/dist/core/agents/application/agent.service.d.ts +25 -0
- package/dist/core/agents/application/agent.service.js +191 -0
- package/dist/core/agents/application/agent.service.js.map +1 -0
- package/dist/core/agents/application/workspace-context.service.d.ts +28 -0
- package/dist/core/agents/application/workspace-context.service.js +157 -0
- package/dist/core/agents/application/workspace-context.service.js.map +1 -0
- package/dist/core/agents/domain/agent-manifest.d.ts +37 -0
- package/dist/core/agents/domain/agent-manifest.js +228 -0
- package/dist/core/agents/domain/agent-manifest.js.map +1 -0
- package/dist/core/agents/domain/workspace-context.d.ts +13 -0
- package/dist/core/agents/domain/workspace-context.js +14 -0
- package/dist/core/agents/domain/workspace-context.js.map +1 -0
- package/dist/core/agents/index.d.ts +6 -0
- package/dist/core/agents/index.js +6 -0
- package/dist/core/agents/index.js.map +1 -0
- package/dist/core/bootstrap/application/bootstrap.service.d.ts +24 -0
- package/dist/core/bootstrap/application/bootstrap.service.js +108 -0
- package/dist/core/bootstrap/application/bootstrap.service.js.map +1 -0
- package/dist/core/bootstrap/index.d.ts +1 -0
- package/dist/core/bootstrap/index.js +2 -0
- package/dist/core/bootstrap/index.js.map +1 -0
- package/dist/core/domain/agent-id.d.ts +3 -0
- package/dist/core/domain/agent-id.js +12 -0
- package/dist/core/domain/agent-id.js.map +1 -0
- package/dist/core/domain/agent.d.ts +39 -0
- package/dist/core/domain/agent.js +2 -0
- package/dist/core/domain/agent.js.map +1 -0
- package/dist/core/domain/opengoat-paths.d.ts +29 -0
- package/dist/core/domain/opengoat-paths.js +2 -0
- package/dist/core/domain/opengoat-paths.js.map +1 -0
- package/dist/core/gateway/domain/protocol.d.ts +113 -0
- package/dist/core/gateway/domain/protocol.js +394 -0
- package/dist/core/gateway/domain/protocol.js.map +1 -0
- package/dist/core/gateway/index.d.ts +2 -0
- package/dist/core/gateway/index.js +2 -0
- package/dist/core/gateway/index.js.map +1 -0
- package/dist/core/llm/application/vercel-ai-text-runtime.d.ts +26 -0
- package/dist/core/llm/application/vercel-ai-text-runtime.js +223 -0
- package/dist/core/llm/application/vercel-ai-text-runtime.js.map +1 -0
- package/dist/core/llm/domain/text-runtime.d.ts +22 -0
- package/dist/core/llm/domain/text-runtime.js +2 -0
- package/dist/core/llm/domain/text-runtime.js.map +1 -0
- package/dist/core/llm/index.d.ts +2 -0
- package/dist/core/llm/index.js +2 -0
- package/dist/core/llm/index.js.map +1 -0
- package/dist/core/logging/application/structured-logger.d.ts +29 -0
- package/dist/core/logging/application/structured-logger.js +86 -0
- package/dist/core/logging/application/structured-logger.js.map +1 -0
- package/dist/core/logging/domain/logger.d.ts +16 -0
- package/dist/core/logging/domain/logger.js +18 -0
- package/dist/core/logging/domain/logger.js.map +1 -0
- package/dist/core/logging/index.d.ts +3 -0
- package/dist/core/logging/index.js +3 -0
- package/dist/core/logging/index.js.map +1 -0
- package/dist/core/opengoat/application/opengoat.service.d.ts +84 -0
- package/dist/core/opengoat/application/opengoat.service.js +308 -0
- package/dist/core/opengoat/application/opengoat.service.js.map +1 -0
- package/dist/core/opengoat/index.d.ts +1 -0
- package/dist/core/opengoat/index.js +2 -0
- package/dist/core/opengoat/index.js.map +1 -0
- package/dist/core/orchestration/application/orchestration-planner.service.d.ts +28 -0
- package/dist/core/orchestration/application/orchestration-planner.service.js +279 -0
- package/dist/core/orchestration/application/orchestration-planner.service.js.map +1 -0
- package/dist/core/orchestration/application/orchestration.service.d.ts +52 -0
- package/dist/core/orchestration/application/orchestration.service.js +1044 -0
- package/dist/core/orchestration/application/orchestration.service.js.map +1 -0
- package/dist/core/orchestration/application/routing.service.d.ts +11 -0
- package/dist/core/orchestration/application/routing.service.js +108 -0
- package/dist/core/orchestration/application/routing.service.js.map +1 -0
- package/dist/core/orchestration/domain/loop.d.ts +119 -0
- package/dist/core/orchestration/domain/loop.js +2 -0
- package/dist/core/orchestration/domain/loop.js.map +1 -0
- package/dist/core/orchestration/domain/routing.d.ts +58 -0
- package/dist/core/orchestration/domain/routing.js +2 -0
- package/dist/core/orchestration/domain/routing.js.map +1 -0
- package/dist/core/orchestration/domain/run-events.d.ts +21 -0
- package/dist/core/orchestration/domain/run-events.js +2 -0
- package/dist/core/orchestration/domain/run-events.js.map +1 -0
- package/dist/core/orchestration/index.d.ts +6 -0
- package/dist/core/orchestration/index.js +4 -0
- package/dist/core/orchestration/index.js.map +1 -0
- package/dist/core/plugins/application/plugin.service.d.ts +32 -0
- package/dist/core/plugins/application/plugin.service.js +236 -0
- package/dist/core/plugins/application/plugin.service.js.map +1 -0
- package/dist/core/plugins/domain/openclaw-compat.d.ts +60 -0
- package/dist/core/plugins/domain/openclaw-compat.js +9 -0
- package/dist/core/plugins/domain/openclaw-compat.js.map +1 -0
- package/dist/core/plugins/index.d.ts +3 -0
- package/dist/core/plugins/index.js +3 -0
- package/dist/core/plugins/index.js.map +1 -0
- package/dist/core/ports/command-runner.port.d.ts +14 -0
- package/dist/core/ports/command-runner.port.js +2 -0
- package/dist/core/ports/command-runner.port.js.map +1 -0
- package/dist/core/ports/file-system.port.d.ts +9 -0
- package/dist/core/ports/file-system.port.js +2 -0
- package/dist/core/ports/file-system.port.js.map +1 -0
- package/dist/core/ports/path.port.d.ts +3 -0
- package/dist/core/ports/path.port.js +2 -0
- package/dist/core/ports/path.port.js.map +1 -0
- package/dist/core/ports/paths-provider.port.d.ts +4 -0
- package/dist/core/ports/paths-provider.port.js +2 -0
- package/dist/core/ports/paths-provider.port.js.map +1 -0
- package/dist/core/providers/application/provider.service.d.ts +80 -0
- package/dist/core/providers/application/provider.service.js +391 -0
- package/dist/core/providers/application/provider.service.js.map +1 -0
- package/dist/core/providers/base-provider.d.ts +20 -0
- package/dist/core/providers/base-provider.js +44 -0
- package/dist/core/providers/base-provider.js.map +1 -0
- package/dist/core/providers/cli-provider.d.ts +26 -0
- package/dist/core/providers/cli-provider.js +151 -0
- package/dist/core/providers/cli-provider.js.map +1 -0
- package/dist/core/providers/command-executor.d.ts +12 -0
- package/dist/core/providers/command-executor.js +76 -0
- package/dist/core/providers/command-executor.js.map +1 -0
- package/dist/core/providers/errors.d.ts +30 -0
- package/dist/core/providers/errors.js +52 -0
- package/dist/core/providers/errors.js.map +1 -0
- package/dist/core/providers/index.d.ts +18 -0
- package/dist/core/providers/index.js +27 -0
- package/dist/core/providers/index.js.map +1 -0
- package/dist/core/providers/loader.d.ts +2 -0
- package/dist/core/providers/loader.js +99 -0
- package/dist/core/providers/loader.js.map +1 -0
- package/dist/core/providers/onboarding.d.ts +13 -0
- package/dist/core/providers/onboarding.js +149 -0
- package/dist/core/providers/onboarding.js.map +1 -0
- package/dist/core/providers/provider-module.d.ts +19 -0
- package/dist/core/providers/provider-module.js +2 -0
- package/dist/core/providers/provider-module.js.map +1 -0
- package/dist/core/providers/provider-session.d.ts +3 -0
- package/dist/core/providers/provider-session.js +44 -0
- package/dist/core/providers/provider-session.js.map +1 -0
- package/dist/core/providers/providers/claude/index.d.ts +4 -0
- package/dist/core/providers/providers/claude/index.js +19 -0
- package/dist/core/providers/providers/claude/index.js.map +1 -0
- package/dist/core/providers/providers/claude/provider.d.ts +8 -0
- package/dist/core/providers/providers/claude/provider.js +106 -0
- package/dist/core/providers/providers/claude/provider.js.map +1 -0
- package/dist/core/providers/providers/codex/index.d.ts +4 -0
- package/dist/core/providers/providers/codex/index.js +19 -0
- package/dist/core/providers/providers/codex/index.js.map +1 -0
- package/dist/core/providers/providers/codex/provider.d.ts +7 -0
- package/dist/core/providers/providers/codex/provider.js +31 -0
- package/dist/core/providers/providers/codex/provider.js.map +1 -0
- package/dist/core/providers/providers/cursor/index.d.ts +4 -0
- package/dist/core/providers/providers/cursor/index.js +19 -0
- package/dist/core/providers/providers/cursor/index.js.map +1 -0
- package/dist/core/providers/providers/cursor/provider.d.ts +11 -0
- package/dist/core/providers/providers/cursor/provider.js +90 -0
- package/dist/core/providers/providers/cursor/provider.js.map +1 -0
- package/dist/core/providers/providers/extended-http/catalog.d.ts +40 -0
- package/dist/core/providers/providers/extended-http/catalog.js +728 -0
- package/dist/core/providers/providers/extended-http/catalog.js.map +1 -0
- package/dist/core/providers/providers/extended-http/index.d.ts +5 -0
- package/dist/core/providers/providers/extended-http/index.js +13 -0
- package/dist/core/providers/providers/extended-http/index.js.map +1 -0
- package/dist/core/providers/providers/extended-http/provider.d.ts +31 -0
- package/dist/core/providers/providers/extended-http/provider.js +580 -0
- package/dist/core/providers/providers/extended-http/provider.js.map +1 -0
- package/dist/core/providers/providers/gemini/index.d.ts +4 -0
- package/dist/core/providers/providers/gemini/index.js +37 -0
- package/dist/core/providers/providers/gemini/index.js.map +1 -0
- package/dist/core/providers/providers/gemini/provider.d.ts +7 -0
- package/dist/core/providers/providers/gemini/provider.js +59 -0
- package/dist/core/providers/providers/gemini/provider.js.map +1 -0
- package/dist/core/providers/providers/grok/index.d.ts +4 -0
- package/dist/core/providers/providers/grok/index.js +41 -0
- package/dist/core/providers/providers/grok/index.js.map +1 -0
- package/dist/core/providers/providers/grok/provider.d.ts +13 -0
- package/dist/core/providers/providers/grok/provider.js +95 -0
- package/dist/core/providers/providers/grok/provider.js.map +1 -0
- package/dist/core/providers/providers/openai/index.d.ts +4 -0
- package/dist/core/providers/providers/openai/index.js +45 -0
- package/dist/core/providers/providers/openai/index.js.map +1 -0
- package/dist/core/providers/providers/openai/provider.d.ts +14 -0
- package/dist/core/providers/providers/openai/provider.js +203 -0
- package/dist/core/providers/providers/openai/provider.js.map +1 -0
- package/dist/core/providers/providers/openclaw/index.d.ts +4 -0
- package/dist/core/providers/providers/openclaw/index.js +31 -0
- package/dist/core/providers/providers/openclaw/index.js.map +1 -0
- package/dist/core/providers/providers/openclaw/provider.d.ts +11 -0
- package/dist/core/providers/providers/openclaw/provider.js +108 -0
- package/dist/core/providers/providers/openclaw/provider.js.map +1 -0
- package/dist/core/providers/providers/opencode/index.d.ts +4 -0
- package/dist/core/providers/providers/opencode/index.js +23 -0
- package/dist/core/providers/providers/opencode/index.js.map +1 -0
- package/dist/core/providers/providers/opencode/provider.d.ts +11 -0
- package/dist/core/providers/providers/opencode/provider.js +215 -0
- package/dist/core/providers/providers/opencode/provider.js.map +1 -0
- package/dist/core/providers/providers/openrouter/index.d.ts +4 -0
- package/dist/core/providers/providers/openrouter/index.js +37 -0
- package/dist/core/providers/providers/openrouter/index.js.map +1 -0
- package/dist/core/providers/providers/openrouter/provider.d.ts +13 -0
- package/dist/core/providers/providers/openrouter/provider.js +80 -0
- package/dist/core/providers/providers/openrouter/provider.js.map +1 -0
- package/dist/core/providers/registry.d.ts +13 -0
- package/dist/core/providers/registry.js +36 -0
- package/dist/core/providers/registry.js.map +1 -0
- package/dist/core/providers/types.d.ts +101 -0
- package/dist/core/providers/types.js +2 -0
- package/dist/core/providers/types.js.map +1 -0
- package/dist/core/scenarios/application/scenario-runner.service.d.ts +23 -0
- package/dist/core/scenarios/application/scenario-runner.service.js +172 -0
- package/dist/core/scenarios/application/scenario-runner.service.js.map +1 -0
- package/dist/core/scenarios/domain/scenario.d.ts +43 -0
- package/dist/core/scenarios/domain/scenario.js +2 -0
- package/dist/core/scenarios/domain/scenario.js.map +1 -0
- package/dist/core/scenarios/index.d.ts +2 -0
- package/dist/core/scenarios/index.js +2 -0
- package/dist/core/scenarios/index.js.map +1 -0
- package/dist/core/sessions/application/session.service.d.ts +74 -0
- package/dist/core/sessions/application/session.service.js +895 -0
- package/dist/core/sessions/application/session.service.js.map +1 -0
- package/dist/core/sessions/domain/session.d.ts +80 -0
- package/dist/core/sessions/domain/session.js +24 -0
- package/dist/core/sessions/domain/session.js.map +1 -0
- package/dist/core/sessions/domain/transcript.d.ts +28 -0
- package/dist/core/sessions/domain/transcript.js +10 -0
- package/dist/core/sessions/domain/transcript.js.map +1 -0
- package/dist/core/sessions/errors.d.ts +12 -0
- package/dist/core/sessions/errors.js +22 -0
- package/dist/core/sessions/errors.js.map +1 -0
- package/dist/core/sessions/index.d.ts +6 -0
- package/dist/core/sessions/index.js +4 -0
- package/dist/core/sessions/index.js.map +1 -0
- package/dist/core/skills/application/skill.service.d.ts +24 -0
- package/dist/core/skills/application/skill.service.js +375 -0
- package/dist/core/skills/application/skill.service.js.map +1 -0
- package/dist/core/skills/domain/skill.d.ts +62 -0
- package/dist/core/skills/domain/skill.js +46 -0
- package/dist/core/skills/domain/skill.js.map +1 -0
- package/dist/core/skills/index.d.ts +3 -0
- package/dist/core/skills/index.js +3 -0
- package/dist/core/skills/index.js.map +1 -0
- package/dist/core/templates/default-templates.d.ts +19 -0
- package/dist/core/templates/default-templates.js +259 -0
- package/dist/core/templates/default-templates.js.map +1 -0
- package/dist/index.d.ts +27 -0
- package/dist/index.js +28 -0
- package/dist/index.js.map +1 -0
- package/dist/platform/node/acp-server.d.ts +12 -0
- package/dist/platform/node/acp-server.js +18 -0
- package/dist/platform/node/acp-server.js.map +1 -0
- package/dist/platform/node/dotenv.d.ts +6 -0
- package/dist/platform/node/dotenv.js +67 -0
- package/dist/platform/node/dotenv.js.map +1 -0
- package/dist/platform/node/node-command-runner.d.ts +4 -0
- package/dist/platform/node/node-command-runner.js +29 -0
- package/dist/platform/node/node-command-runner.js.map +1 -0
- package/dist/platform/node/node-file-system.d.ts +10 -0
- package/dist/platform/node/node-file-system.js +47 -0
- package/dist/platform/node/node-file-system.js.map +1 -0
- package/dist/platform/node/node-logger.d.ts +9 -0
- package/dist/platform/node/node-logger.js +124 -0
- package/dist/platform/node/node-logger.js.map +1 -0
- package/dist/platform/node/node-path.port.d.ts +9 -0
- package/dist/platform/node/node-path.port.js +41 -0
- package/dist/platform/node/node-path.port.js.map +1 -0
- package/dist/platform/node/opengoat-gateway-client.d.ts +19 -0
- package/dist/platform/node/opengoat-gateway-client.js +194 -0
- package/dist/platform/node/opengoat-gateway-client.js.map +1 -0
- package/dist/platform/node/opengoat-gateway-server.d.ts +53 -0
- package/dist/platform/node/opengoat-gateway-server.js +906 -0
- package/dist/platform/node/opengoat-gateway-server.js.map +1 -0
- package/package.json +37 -0
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
export type ProviderKind = "cli" | "http";
|
|
2
|
+
export interface ProviderCapabilities {
|
|
3
|
+
agent: boolean;
|
|
4
|
+
model: boolean;
|
|
5
|
+
auth: boolean;
|
|
6
|
+
passthrough: boolean;
|
|
7
|
+
agentCreate?: boolean;
|
|
8
|
+
agentDelete?: boolean;
|
|
9
|
+
}
|
|
10
|
+
export interface ProviderInvokeOptions {
|
|
11
|
+
message: string;
|
|
12
|
+
systemPrompt?: string;
|
|
13
|
+
skillsPromptOverride?: string;
|
|
14
|
+
sessionRef?: string;
|
|
15
|
+
forceNewSession?: boolean;
|
|
16
|
+
disableSession?: boolean;
|
|
17
|
+
directAgentSession?: boolean;
|
|
18
|
+
providerSessionId?: string;
|
|
19
|
+
forceNewProviderSession?: boolean;
|
|
20
|
+
sessionContext?: string;
|
|
21
|
+
agent?: string;
|
|
22
|
+
model?: string;
|
|
23
|
+
passthroughArgs?: string[];
|
|
24
|
+
cwd?: string;
|
|
25
|
+
env?: NodeJS.ProcessEnv;
|
|
26
|
+
abortSignal?: AbortSignal;
|
|
27
|
+
onStdout?: (chunk: string) => void;
|
|
28
|
+
onStderr?: (chunk: string) => void;
|
|
29
|
+
}
|
|
30
|
+
export interface ProviderInvocationLifecycleEvent {
|
|
31
|
+
runId?: string;
|
|
32
|
+
timestamp: string;
|
|
33
|
+
step?: number;
|
|
34
|
+
agentId: string;
|
|
35
|
+
providerId: string;
|
|
36
|
+
}
|
|
37
|
+
export interface ProviderInvocationLifecycleHooks {
|
|
38
|
+
onInvocationStarted?: (event: ProviderInvocationLifecycleEvent) => void;
|
|
39
|
+
onInvocationCompleted?: (event: ProviderInvocationLifecycleEvent & {
|
|
40
|
+
code: number;
|
|
41
|
+
}) => void;
|
|
42
|
+
}
|
|
43
|
+
export interface ProviderInvokeRuntimeContext {
|
|
44
|
+
runId?: string;
|
|
45
|
+
step?: number;
|
|
46
|
+
hooks?: ProviderInvocationLifecycleHooks;
|
|
47
|
+
}
|
|
48
|
+
export interface ProviderAuthOptions {
|
|
49
|
+
passthroughArgs?: string[];
|
|
50
|
+
cwd?: string;
|
|
51
|
+
env?: NodeJS.ProcessEnv;
|
|
52
|
+
onStdout?: (chunk: string) => void;
|
|
53
|
+
onStderr?: (chunk: string) => void;
|
|
54
|
+
}
|
|
55
|
+
export interface ProviderCreateAgentOptions {
|
|
56
|
+
agentId: string;
|
|
57
|
+
displayName: string;
|
|
58
|
+
workspaceDir: string;
|
|
59
|
+
internalConfigDir: string;
|
|
60
|
+
cwd?: string;
|
|
61
|
+
env?: NodeJS.ProcessEnv;
|
|
62
|
+
onStdout?: (chunk: string) => void;
|
|
63
|
+
onStderr?: (chunk: string) => void;
|
|
64
|
+
}
|
|
65
|
+
export interface ProviderDeleteAgentOptions {
|
|
66
|
+
agentId: string;
|
|
67
|
+
cwd?: string;
|
|
68
|
+
env?: NodeJS.ProcessEnv;
|
|
69
|
+
onStdout?: (chunk: string) => void;
|
|
70
|
+
onStderr?: (chunk: string) => void;
|
|
71
|
+
}
|
|
72
|
+
export interface ProviderExecutionResult {
|
|
73
|
+
code: number;
|
|
74
|
+
stdout: string;
|
|
75
|
+
stderr: string;
|
|
76
|
+
providerSessionId?: string;
|
|
77
|
+
}
|
|
78
|
+
export interface ProviderInvocation {
|
|
79
|
+
command: string;
|
|
80
|
+
args: string[];
|
|
81
|
+
}
|
|
82
|
+
export interface Provider {
|
|
83
|
+
readonly id: string;
|
|
84
|
+
readonly displayName: string;
|
|
85
|
+
readonly kind: ProviderKind;
|
|
86
|
+
readonly capabilities: ProviderCapabilities;
|
|
87
|
+
invoke(options: ProviderInvokeOptions): Promise<ProviderExecutionResult>;
|
|
88
|
+
invokeAuth?(options?: ProviderAuthOptions): Promise<ProviderExecutionResult>;
|
|
89
|
+
createAgent?(options: ProviderCreateAgentOptions): Promise<ProviderExecutionResult>;
|
|
90
|
+
deleteAgent?(options: ProviderDeleteAgentOptions): Promise<ProviderExecutionResult>;
|
|
91
|
+
}
|
|
92
|
+
export interface ProviderSummary {
|
|
93
|
+
id: string;
|
|
94
|
+
displayName: string;
|
|
95
|
+
kind: ProviderKind;
|
|
96
|
+
capabilities: ProviderCapabilities;
|
|
97
|
+
}
|
|
98
|
+
export interface AgentProviderBinding {
|
|
99
|
+
agentId: string;
|
|
100
|
+
providerId: string;
|
|
101
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/core/providers/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { OpenGoatService } from "../../opengoat/index.js";
|
|
2
|
+
import type { FileSystemPort } from "../../ports/file-system.port.js";
|
|
3
|
+
import type { PathPort } from "../../ports/path.port.js";
|
|
4
|
+
import type { OpenGoatPathsProvider } from "../../ports/paths-provider.port.js";
|
|
5
|
+
import type { ScenarioRunResult, ScenarioSpec } from "../domain/scenario.js";
|
|
6
|
+
interface ScenarioRunnerServiceDeps {
|
|
7
|
+
fileSystem: FileSystemPort;
|
|
8
|
+
pathPort: PathPort;
|
|
9
|
+
pathsProvider: OpenGoatPathsProvider;
|
|
10
|
+
nowIso?: () => string;
|
|
11
|
+
}
|
|
12
|
+
export declare class ScenarioRunnerService {
|
|
13
|
+
private readonly fileSystem;
|
|
14
|
+
private readonly pathPort;
|
|
15
|
+
private readonly pathsProvider;
|
|
16
|
+
private readonly nowIso;
|
|
17
|
+
constructor(deps: ScenarioRunnerServiceDeps);
|
|
18
|
+
runLive(service: OpenGoatService, scenario: ScenarioSpec): Promise<ScenarioRunResult>;
|
|
19
|
+
runScripted(scenario: ScenarioSpec): Promise<ScenarioRunResult>;
|
|
20
|
+
private evaluate;
|
|
21
|
+
private writeAgentManifest;
|
|
22
|
+
}
|
|
23
|
+
export {};
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
import { BaseProvider, ProviderRegistry } from "../../providers/index.js";
|
|
2
|
+
import { OpenGoatService } from "../../opengoat/index.js";
|
|
3
|
+
export class ScenarioRunnerService {
|
|
4
|
+
fileSystem;
|
|
5
|
+
pathPort;
|
|
6
|
+
pathsProvider;
|
|
7
|
+
nowIso;
|
|
8
|
+
constructor(deps) {
|
|
9
|
+
this.fileSystem = deps.fileSystem;
|
|
10
|
+
this.pathPort = deps.pathPort;
|
|
11
|
+
this.pathsProvider = deps.pathsProvider;
|
|
12
|
+
this.nowIso = deps.nowIso ?? (() => new Date().toISOString());
|
|
13
|
+
}
|
|
14
|
+
async runLive(service, scenario) {
|
|
15
|
+
await service.initialize();
|
|
16
|
+
const result = await service.runAgent(scenario.entryAgentId ?? "orchestrator", {
|
|
17
|
+
message: scenario.message
|
|
18
|
+
});
|
|
19
|
+
return this.evaluate("live", scenario, result);
|
|
20
|
+
}
|
|
21
|
+
async runScripted(scenario) {
|
|
22
|
+
if (!scenario.scripted) {
|
|
23
|
+
throw new Error("Scripted scenario mode requires a 'scripted' section.");
|
|
24
|
+
}
|
|
25
|
+
const registry = new ProviderRegistry();
|
|
26
|
+
registry.register("scenario-scripted", () => new ScenarioScriptedProvider(scenario));
|
|
27
|
+
const service = new OpenGoatService({
|
|
28
|
+
fileSystem: this.fileSystem,
|
|
29
|
+
pathPort: this.pathPort,
|
|
30
|
+
pathsProvider: this.pathsProvider,
|
|
31
|
+
providerRegistry: registry,
|
|
32
|
+
nowIso: this.nowIso
|
|
33
|
+
});
|
|
34
|
+
await service.initialize();
|
|
35
|
+
for (const agent of scenario.agents ?? []) {
|
|
36
|
+
const created = await service.createAgent(agent.name);
|
|
37
|
+
await service.setAgentProvider(created.agent.id, "scenario-scripted");
|
|
38
|
+
await this.writeAgentManifest(created.agent.id, agent.name, agent.description);
|
|
39
|
+
}
|
|
40
|
+
await service.setAgentProvider("orchestrator", "scenario-scripted");
|
|
41
|
+
const result = await service.runAgent(scenario.entryAgentId ?? "orchestrator", {
|
|
42
|
+
message: scenario.message
|
|
43
|
+
});
|
|
44
|
+
return this.evaluate("scripted", scenario, result);
|
|
45
|
+
}
|
|
46
|
+
evaluate(mode, scenario, result) {
|
|
47
|
+
const assertions = scenario.assertions ?? {};
|
|
48
|
+
const failures = [];
|
|
49
|
+
if (assertions.mustSucceed !== false && result.code !== 0) {
|
|
50
|
+
failures.push(`Expected success code 0, received ${result.code}.`);
|
|
51
|
+
}
|
|
52
|
+
const output = result.stdout.trim();
|
|
53
|
+
for (const fragment of assertions.stdoutIncludes ?? []) {
|
|
54
|
+
if (!output.includes(fragment)) {
|
|
55
|
+
failures.push(`stdout missing required fragment: "${fragment}"`);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
const delegatedAgents = (result.orchestration?.steps ?? [])
|
|
59
|
+
.map((step) => step.agentCall?.targetAgentId)
|
|
60
|
+
.filter((value) => Boolean(value));
|
|
61
|
+
if (assertions.delegatedAgents) {
|
|
62
|
+
const expected = assertions.delegatedAgents.join(",");
|
|
63
|
+
const actual = delegatedAgents.join(",");
|
|
64
|
+
if (expected !== actual) {
|
|
65
|
+
failures.push(`delegated agents mismatch. expected=${expected} actual=${actual}`);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
const steps = result.orchestration?.steps.length ?? 0;
|
|
69
|
+
if (typeof assertions.minSteps === "number" && steps < assertions.minSteps) {
|
|
70
|
+
failures.push(`expected at least ${assertions.minSteps} steps, received ${steps}`);
|
|
71
|
+
}
|
|
72
|
+
if (typeof assertions.maxSteps === "number" && steps > assertions.maxSteps) {
|
|
73
|
+
failures.push(`expected at most ${assertions.maxSteps} steps, received ${steps}`);
|
|
74
|
+
}
|
|
75
|
+
return {
|
|
76
|
+
scenarioName: scenario.name,
|
|
77
|
+
mode,
|
|
78
|
+
success: failures.length === 0,
|
|
79
|
+
failures,
|
|
80
|
+
tracePath: result.tracePath,
|
|
81
|
+
output,
|
|
82
|
+
delegatedAgents,
|
|
83
|
+
steps
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
async writeAgentManifest(agentId, name, description) {
|
|
87
|
+
const paths = this.pathsProvider.getPaths();
|
|
88
|
+
const manifestPath = this.pathPort.join(paths.workspacesDir, agentId, "AGENTS.md");
|
|
89
|
+
const content = [
|
|
90
|
+
"---",
|
|
91
|
+
`id: ${agentId}`,
|
|
92
|
+
`name: ${name}`,
|
|
93
|
+
`description: ${description}`,
|
|
94
|
+
"provider: scenario-scripted",
|
|
95
|
+
"discoverable: true",
|
|
96
|
+
"tags: [scenario, scripted]",
|
|
97
|
+
"delegation:",
|
|
98
|
+
" canReceive: true",
|
|
99
|
+
" canDelegate: false",
|
|
100
|
+
"priority: 70",
|
|
101
|
+
"---",
|
|
102
|
+
"",
|
|
103
|
+
`# ${name}`,
|
|
104
|
+
"",
|
|
105
|
+
description
|
|
106
|
+
].join("\n") + "\n";
|
|
107
|
+
await this.fileSystem.writeFile(manifestPath, content);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
class ScenarioScriptedProvider extends BaseProvider {
|
|
111
|
+
scenario;
|
|
112
|
+
constructor(scenario) {
|
|
113
|
+
super({
|
|
114
|
+
id: "scenario-scripted",
|
|
115
|
+
displayName: "Scenario Scripted Provider",
|
|
116
|
+
kind: "http",
|
|
117
|
+
capabilities: {
|
|
118
|
+
agent: true,
|
|
119
|
+
model: true,
|
|
120
|
+
auth: false,
|
|
121
|
+
passthrough: false
|
|
122
|
+
}
|
|
123
|
+
});
|
|
124
|
+
this.scenario = scenario;
|
|
125
|
+
}
|
|
126
|
+
async invoke(options) {
|
|
127
|
+
this.validateInvokeOptions(options);
|
|
128
|
+
const agentId = options.agent ?? "unknown";
|
|
129
|
+
const output = this.resolveOutput(agentId, options.message);
|
|
130
|
+
options.onStdout?.(output);
|
|
131
|
+
return {
|
|
132
|
+
code: 0,
|
|
133
|
+
stdout: output,
|
|
134
|
+
stderr: ""
|
|
135
|
+
};
|
|
136
|
+
}
|
|
137
|
+
resolveOutput(agentId, message) {
|
|
138
|
+
if (agentId === "orchestrator") {
|
|
139
|
+
return this.resolvePlannerOutput(message);
|
|
140
|
+
}
|
|
141
|
+
const reply = this.scenario.scripted?.agentReplies[agentId] ?? `handled-by:${agentId}`;
|
|
142
|
+
return reply.endsWith("\n") ? reply : `${reply}\n`;
|
|
143
|
+
}
|
|
144
|
+
resolvePlannerOutput(message) {
|
|
145
|
+
const actions = this.scenario.scripted?.orchestratorActions ?? [];
|
|
146
|
+
const index = resolvePlannerStepIndex(message);
|
|
147
|
+
const selected = actions[Math.min(index, Math.max(0, actions.length - 1))];
|
|
148
|
+
if (!selected) {
|
|
149
|
+
return JSON.stringify({
|
|
150
|
+
rationale: "No scripted action available.",
|
|
151
|
+
action: {
|
|
152
|
+
type: "finish",
|
|
153
|
+
mode: "direct",
|
|
154
|
+
message: "Scenario finished without scripted actions."
|
|
155
|
+
}
|
|
156
|
+
}, null, 2);
|
|
157
|
+
}
|
|
158
|
+
return `${JSON.stringify(selected, null, 2)}\n`;
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
function resolvePlannerStepIndex(message) {
|
|
162
|
+
const match = message.match(/Step\s+(\d+)\//i);
|
|
163
|
+
if (!match) {
|
|
164
|
+
return 0;
|
|
165
|
+
}
|
|
166
|
+
const parsed = Number.parseInt(match[1] ?? "1", 10);
|
|
167
|
+
if (!Number.isFinite(parsed) || parsed <= 1) {
|
|
168
|
+
return 0;
|
|
169
|
+
}
|
|
170
|
+
return parsed - 1;
|
|
171
|
+
}
|
|
172
|
+
//# sourceMappingURL=scenario-runner.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scenario-runner.service.js","sourceRoot":"","sources":["../../../../src/core/scenarios/application/scenario-runner.service.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,YAAY,EACZ,gBAAgB,EAGjB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAa1D,MAAM,OAAO,qBAAqB;IACf,UAAU,CAAiB;IAC3B,QAAQ,CAAW;IACnB,aAAa,CAAwB;IACrC,MAAM,CAAe;IAEtC,YAAmB,IAA+B;QAChD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC9B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;QACxC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;IAChE,CAAC;IAEM,KAAK,CAAC,OAAO,CAAC,OAAwB,EAAE,QAAsB;QACnE,MAAM,OAAO,CAAC,UAAU,EAAE,CAAC;QAC3B,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,YAAY,IAAI,cAAc,EAAE;YAC7E,OAAO,EAAE,QAAQ,CAAC,OAAO;SAC1B,CAAC,CAAC;QACH,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;IACjD,CAAC;IAEM,KAAK,CAAC,WAAW,CAAC,QAAsB;QAC7C,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;YACvB,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;QAC3E,CAAC;QAED,MAAM,QAAQ,GAAG,IAAI,gBAAgB,EAAE,CAAC;QACxC,QAAQ,CAAC,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE,CAAC,IAAI,wBAAwB,CAAC,QAAQ,CAAC,CAAC,CAAC;QAErF,MAAM,OAAO,GAAG,IAAI,eAAe,CAAC;YAClC,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,gBAAgB,EAAE,QAAQ;YAC1B,MAAM,EAAE,IAAI,CAAC,MAAM;SACpB,CAAC,CAAC;QAEH,MAAM,OAAO,CAAC,UAAU,EAAE,CAAC;QAC3B,KAAK,MAAM,KAAK,IAAI,QAAQ,CAAC,MAAM,IAAI,EAAE,EAAE,CAAC;YAC1C,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACtD,MAAM,OAAO,CAAC,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,EAAE,mBAAmB,CAAC,CAAC;YACtE,MAAM,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC;QACjF,CAAC;QACD,MAAM,OAAO,CAAC,gBAAgB,CAAC,cAAc,EAAE,mBAAmB,CAAC,CAAC;QAEpE,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,YAAY,IAAI,cAAc,EAAE;YAC7E,OAAO,EAAE,QAAQ,CAAC,OAAO;SAC1B,CAAC,CAAC;QACH,OAAO,IAAI,CAAC,QAAQ,CAAC,UAAU,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;IACrD,CAAC;IAEO,QAAQ,CACd,IAAyB,EACzB,QAAsB,EACtB,MAAwD;QAExD,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,IAAI,EAAE,CAAC;QAC7C,MAAM,QAAQ,GAAa,EAAE,CAAC;QAE9B,IAAI,UAAU,CAAC,WAAW,KAAK,KAAK,IAAI,MAAM,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;YAC1D,QAAQ,CAAC,IAAI,CAAC,qCAAqC,MAAM,CAAC,IAAI,GAAG,CAAC,CAAC;QACrE,CAAC;QAED,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QACpC,KAAK,MAAM,QAAQ,IAAI,UAAU,CAAC,cAAc,IAAI,EAAE,EAAE,CAAC;YACvD,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC/B,QAAQ,CAAC,IAAI,CAAC,sCAAsC,QAAQ,GAAG,CAAC,CAAC;YACnE,CAAC;QACH,CAAC;QAED,MAAM,eAAe,GAAG,CAAC,MAAM,CAAC,aAAa,EAAE,KAAK,IAAI,EAAE,CAAC;aACxD,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,aAAa,CAAC;aAC5C,MAAM,CAAC,CAAC,KAAK,EAAmB,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;QACtD,IAAI,UAAU,CAAC,eAAe,EAAE,CAAC;YAC/B,MAAM,QAAQ,GAAG,UAAU,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACtD,MAAM,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACzC,IAAI,QAAQ,KAAK,MAAM,EAAE,CAAC;gBACxB,QAAQ,CAAC,IAAI,CAAC,uCAAuC,QAAQ,WAAW,MAAM,EAAE,CAAC,CAAC;YACpF,CAAC;QACH,CAAC;QAED,MAAM,KAAK,GAAG,MAAM,CAAC,aAAa,EAAE,KAAK,CAAC,MAAM,IAAI,CAAC,CAAC;QACtD,IAAI,OAAO,UAAU,CAAC,QAAQ,KAAK,QAAQ,IAAI,KAAK,GAAG,UAAU,CAAC,QAAQ,EAAE,CAAC;YAC3E,QAAQ,CAAC,IAAI,CAAC,qBAAqB,UAAU,CAAC,QAAQ,oBAAoB,KAAK,EAAE,CAAC,CAAC;QACrF,CAAC;QACD,IAAI,OAAO,UAAU,CAAC,QAAQ,KAAK,QAAQ,IAAI,KAAK,GAAG,UAAU,CAAC,QAAQ,EAAE,CAAC;YAC3E,QAAQ,CAAC,IAAI,CAAC,oBAAoB,UAAU,CAAC,QAAQ,oBAAoB,KAAK,EAAE,CAAC,CAAC;QACpF,CAAC;QAED,OAAO;YACL,YAAY,EAAE,QAAQ,CAAC,IAAI;YAC3B,IAAI;YACJ,OAAO,EAAE,QAAQ,CAAC,MAAM,KAAK,CAAC;YAC9B,QAAQ;YACR,SAAS,EAAE,MAAM,CAAC,SAAS;YAC3B,MAAM;YACN,eAAe;YACf,KAAK;SACN,CAAC;IACJ,CAAC;IAEO,KAAK,CAAC,kBAAkB,CAAC,OAAe,EAAE,IAAY,EAAE,WAAmB;QACjF,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;QAC5C,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,OAAO,EAAE,WAAW,CAAC,CAAC;QACnF,MAAM,OAAO,GACX;YACE,KAAK;YACL,OAAO,OAAO,EAAE;YAChB,SAAS,IAAI,EAAE;YACf,gBAAgB,WAAW,EAAE;YAC7B,6BAA6B;YAC7B,oBAAoB;YACpB,4BAA4B;YAC5B,aAAa;YACb,oBAAoB;YACpB,sBAAsB;YACtB,cAAc;YACd,KAAK;YACL,EAAE;YACF,KAAK,IAAI,EAAE;YACX,EAAE;YACF,WAAW;SACZ,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;QACtB,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;IACzD,CAAC;CACF;AAED,MAAM,wBAAyB,SAAQ,YAAY;IAChC,QAAQ,CAAe;IAExC,YAAmB,QAAsB;QACvC,KAAK,CAAC;YACJ,EAAE,EAAE,mBAAmB;YACvB,WAAW,EAAE,4BAA4B;YACzC,IAAI,EAAE,MAAM;YACZ,YAAY,EAAE;gBACZ,KAAK,EAAE,IAAI;gBACX,KAAK,EAAE,IAAI;gBACX,IAAI,EAAE,KAAK;gBACX,WAAW,EAAE,KAAK;aACnB;SACF,CAAC,CAAC;QACH,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAEM,KAAK,CAAC,MAAM,CAAC,OAA8B;QAChD,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;QACpC,MAAM,OAAO,GAAG,OAAO,CAAC,KAAK,IAAI,SAAS,CAAC;QAE3C,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;QAC5D,OAAO,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,CAAC;QAC3B,OAAO;YACL,IAAI,EAAE,CAAC;YACP,MAAM,EAAE,MAAM;YACd,MAAM,EAAE,EAAE;SACX,CAAC;IACJ,CAAC;IAEO,aAAa,CAAC,OAAe,EAAE,OAAe;QACpD,IAAI,OAAO,KAAK,cAAc,EAAE,CAAC;YAC/B,OAAO,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;QAC5C,CAAC;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,YAAY,CAAC,OAAO,CAAC,IAAI,cAAc,OAAO,EAAE,CAAC;QACvF,OAAO,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC;IACrD,CAAC;IAEO,oBAAoB,CAAC,OAAe;QAC1C,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,mBAAmB,IAAI,EAAE,CAAC;QAClE,MAAM,KAAK,GAAG,uBAAuB,CAAC,OAAO,CAAC,CAAC;QAC/C,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3E,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,OAAO,IAAI,CAAC,SAAS,CACnB;gBACE,SAAS,EAAE,+BAA+B;gBAC1C,MAAM,EAAE;oBACN,IAAI,EAAE,QAAQ;oBACd,IAAI,EAAE,QAAQ;oBACd,OAAO,EAAE,6CAA6C;iBACvD;aACF,EACD,IAAI,EACJ,CAAC,CACF,CAAC;QACJ,CAAC;QACD,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC;IAClD,CAAC;CACF;AAED,SAAS,uBAAuB,CAAC,OAAe;IAC9C,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;IAC/C,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,OAAO,CAAC,CAAC;IACX,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE,EAAE,CAAC,CAAC;IACpD,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,MAAM,IAAI,CAAC,EAAE,CAAC;QAC5C,OAAO,CAAC,CAAC;IACX,CAAC;IACD,OAAO,MAAM,GAAG,CAAC,CAAC;AACpB,CAAC"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
export interface ScenarioAgentSpec {
|
|
2
|
+
id: string;
|
|
3
|
+
name: string;
|
|
4
|
+
description: string;
|
|
5
|
+
}
|
|
6
|
+
export interface ScenarioScriptedSpec {
|
|
7
|
+
orchestratorActions: Array<{
|
|
8
|
+
rationale: string;
|
|
9
|
+
action: {
|
|
10
|
+
type: "delegate_to_agent" | "respond_user" | "finish";
|
|
11
|
+
mode?: "direct" | "artifacts" | "hybrid";
|
|
12
|
+
targetAgentId?: string;
|
|
13
|
+
message: string;
|
|
14
|
+
expectedOutput?: string;
|
|
15
|
+
};
|
|
16
|
+
}>;
|
|
17
|
+
agentReplies: Record<string, string>;
|
|
18
|
+
}
|
|
19
|
+
export interface ScenarioAssertions {
|
|
20
|
+
mustSucceed?: boolean;
|
|
21
|
+
stdoutIncludes?: string[];
|
|
22
|
+
delegatedAgents?: string[];
|
|
23
|
+
minSteps?: number;
|
|
24
|
+
maxSteps?: number;
|
|
25
|
+
}
|
|
26
|
+
export interface ScenarioSpec {
|
|
27
|
+
name: string;
|
|
28
|
+
message: string;
|
|
29
|
+
entryAgentId?: string;
|
|
30
|
+
agents?: ScenarioAgentSpec[];
|
|
31
|
+
scripted?: ScenarioScriptedSpec;
|
|
32
|
+
assertions?: ScenarioAssertions;
|
|
33
|
+
}
|
|
34
|
+
export interface ScenarioRunResult {
|
|
35
|
+
scenarioName: string;
|
|
36
|
+
mode: "live" | "scripted";
|
|
37
|
+
success: boolean;
|
|
38
|
+
failures: string[];
|
|
39
|
+
tracePath: string;
|
|
40
|
+
output: string;
|
|
41
|
+
delegatedAgents: string[];
|
|
42
|
+
steps: number;
|
|
43
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scenario.js","sourceRoot":"","sources":["../../../../src/core/scenarios/domain/scenario.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/scenarios/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,0CAA0C,CAAC"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import type { OpenGoatPaths } from "../../domain/opengoat-paths.js";
|
|
2
|
+
import type { CommandRunnerPort } from "../../ports/command-runner.port.js";
|
|
3
|
+
import type { FileSystemPort } from "../../ports/file-system.port.js";
|
|
4
|
+
import type { PathPort } from "../../ports/path.port.js";
|
|
5
|
+
import { type SessionHistoryItem, type SessionRemoveResult, type SessionRunInfo, type SessionSummary } from "../domain/session.js";
|
|
6
|
+
interface SessionServiceDeps {
|
|
7
|
+
fileSystem: FileSystemPort;
|
|
8
|
+
pathPort: PathPort;
|
|
9
|
+
commandRunner?: CommandRunnerPort;
|
|
10
|
+
nowIso?: () => string;
|
|
11
|
+
nowMs?: () => number;
|
|
12
|
+
}
|
|
13
|
+
export interface PrepareSessionRunRequest {
|
|
14
|
+
sessionRef?: string;
|
|
15
|
+
forceNew?: boolean;
|
|
16
|
+
disableSession?: boolean;
|
|
17
|
+
workingPath?: string;
|
|
18
|
+
userMessage: string;
|
|
19
|
+
}
|
|
20
|
+
export type PreparedSessionRun = {
|
|
21
|
+
enabled: false;
|
|
22
|
+
} | {
|
|
23
|
+
enabled: true;
|
|
24
|
+
info: SessionRunInfo;
|
|
25
|
+
contextPrompt: string;
|
|
26
|
+
compactionApplied: boolean;
|
|
27
|
+
};
|
|
28
|
+
export interface SessionHistoryResult {
|
|
29
|
+
sessionKey: string;
|
|
30
|
+
sessionId?: string;
|
|
31
|
+
transcriptPath?: string;
|
|
32
|
+
messages: SessionHistoryItem[];
|
|
33
|
+
}
|
|
34
|
+
export interface SessionCompactionResult {
|
|
35
|
+
sessionKey: string;
|
|
36
|
+
sessionId: string;
|
|
37
|
+
transcriptPath: string;
|
|
38
|
+
applied: boolean;
|
|
39
|
+
summary?: string;
|
|
40
|
+
compactedMessages: number;
|
|
41
|
+
}
|
|
42
|
+
export declare class SessionService {
|
|
43
|
+
private readonly fileSystem;
|
|
44
|
+
private readonly pathPort;
|
|
45
|
+
private readonly commandRunner?;
|
|
46
|
+
private readonly nowIso;
|
|
47
|
+
private readonly nowMs;
|
|
48
|
+
constructor(deps: SessionServiceDeps);
|
|
49
|
+
prepareRunSession(paths: OpenGoatPaths, agentId: string, request: PrepareSessionRunRequest): Promise<PreparedSessionRun>;
|
|
50
|
+
recordAssistantReply(paths: OpenGoatPaths, info: SessionRunInfo, content: string): Promise<SessionCompactionResult>;
|
|
51
|
+
listSessions(paths: OpenGoatPaths, agentId: string, options?: {
|
|
52
|
+
activeMinutes?: number;
|
|
53
|
+
}): Promise<SessionSummary[]>;
|
|
54
|
+
renameSession(paths: OpenGoatPaths, agentId: string, title: string, sessionRef?: string): Promise<SessionSummary>;
|
|
55
|
+
removeSession(paths: OpenGoatPaths, agentId: string, sessionRef?: string): Promise<SessionRemoveResult>;
|
|
56
|
+
getSessionHistory(paths: OpenGoatPaths, agentId: string, options?: {
|
|
57
|
+
sessionRef?: string;
|
|
58
|
+
limit?: number;
|
|
59
|
+
includeCompaction?: boolean;
|
|
60
|
+
}): Promise<SessionHistoryResult>;
|
|
61
|
+
resetSession(paths: OpenGoatPaths, agentId: string, sessionRef?: string): Promise<SessionRunInfo>;
|
|
62
|
+
compactSession(paths: OpenGoatPaths, agentId: string, sessionRef?: string): Promise<SessionCompactionResult>;
|
|
63
|
+
private compactSessionInternal;
|
|
64
|
+
private appendMessage;
|
|
65
|
+
private buildSessionContext;
|
|
66
|
+
private ensureTranscriptHeader;
|
|
67
|
+
private readStore;
|
|
68
|
+
private persistStore;
|
|
69
|
+
private readTranscriptRecords;
|
|
70
|
+
private writeTranscriptRecords;
|
|
71
|
+
private readSessionConfig;
|
|
72
|
+
private ensureWorkingPathGitRepository;
|
|
73
|
+
}
|
|
74
|
+
export {};
|