@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,19 @@
|
|
|
1
|
+
import { ClaudeProvider } from "./provider.js";
|
|
2
|
+
export const providerModule = {
|
|
3
|
+
id: "claude",
|
|
4
|
+
create: () => new ClaudeProvider(),
|
|
5
|
+
onboarding: {
|
|
6
|
+
env: [
|
|
7
|
+
{
|
|
8
|
+
key: "CLAUDE_CMD",
|
|
9
|
+
description: "Optional claude binary path override"
|
|
10
|
+
}
|
|
11
|
+
],
|
|
12
|
+
auth: {
|
|
13
|
+
supported: true,
|
|
14
|
+
description: "Runs `claude setup-token`."
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
export { ClaudeProvider };
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/core/providers/providers/claude/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAE/C,MAAM,CAAC,MAAM,cAAc,GAAmB;IAC5C,EAAE,EAAE,QAAQ;IACZ,MAAM,EAAE,GAAG,EAAE,CAAC,IAAI,cAAc,EAAE;IAClC,UAAU,EAAE;QACV,GAAG,EAAE;YACH;gBACE,GAAG,EAAE,YAAY;gBACjB,WAAW,EAAE,sCAAsC;aACpD;SACF;QACD,IAAI,EAAE;YACJ,SAAS,EAAE,IAAI;YACf,WAAW,EAAE,4BAA4B;SAC1C;KACF;CACF,CAAC;AAEF,OAAO,EAAE,cAAc,EAAE,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { ProviderAuthOptions, ProviderCreateAgentOptions, ProviderExecutionResult, ProviderInvokeOptions } from "../../types.js";
|
|
2
|
+
import { BaseCliProvider } from "../../cli-provider.js";
|
|
3
|
+
export declare class ClaudeProvider extends BaseCliProvider {
|
|
4
|
+
constructor();
|
|
5
|
+
protected buildInvocationArgs(options: ProviderInvokeOptions): string[];
|
|
6
|
+
protected buildAuthInvocationArgs(options: ProviderAuthOptions): string[];
|
|
7
|
+
createAgent(options: ProviderCreateAgentOptions): Promise<ProviderExecutionResult>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { mkdir, writeFile } from "node:fs/promises";
|
|
2
|
+
import os from "node:os";
|
|
3
|
+
import path from "node:path";
|
|
4
|
+
import { BaseCliProvider } from "../../cli-provider.js";
|
|
5
|
+
export class ClaudeProvider extends BaseCliProvider {
|
|
6
|
+
constructor() {
|
|
7
|
+
super({
|
|
8
|
+
id: "claude",
|
|
9
|
+
displayName: "Claude Code",
|
|
10
|
+
kind: "cli",
|
|
11
|
+
command: "claude",
|
|
12
|
+
commandEnvVar: "CLAUDE_CMD",
|
|
13
|
+
capabilities: {
|
|
14
|
+
agent: true,
|
|
15
|
+
model: true,
|
|
16
|
+
auth: true,
|
|
17
|
+
passthrough: true,
|
|
18
|
+
agentCreate: true
|
|
19
|
+
}
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
buildInvocationArgs(options) {
|
|
23
|
+
const args = ["--print"];
|
|
24
|
+
if (options.agent) {
|
|
25
|
+
args.push("--agent", options.agent);
|
|
26
|
+
}
|
|
27
|
+
if (options.model) {
|
|
28
|
+
args.push("--model", options.model);
|
|
29
|
+
}
|
|
30
|
+
args.push(...(options.passthroughArgs ?? []));
|
|
31
|
+
args.push(options.message);
|
|
32
|
+
return args;
|
|
33
|
+
}
|
|
34
|
+
buildAuthInvocationArgs(options) {
|
|
35
|
+
return ["setup-token", ...(options.passthroughArgs ?? [])];
|
|
36
|
+
}
|
|
37
|
+
async createAgent(options) {
|
|
38
|
+
const env = options.env ?? process.env;
|
|
39
|
+
const agentFilePath = resolveClaudeAgentFilePath(options.agentId, env);
|
|
40
|
+
try {
|
|
41
|
+
await mkdir(path.dirname(agentFilePath), { recursive: true });
|
|
42
|
+
const definition = renderClaudeAgentDefinition(options.agentId, options.displayName);
|
|
43
|
+
await writeFile(agentFilePath, definition, { encoding: "utf-8", flag: "wx" });
|
|
44
|
+
return {
|
|
45
|
+
code: 0,
|
|
46
|
+
stdout: `Created Claude agent '${options.agentId}' at ${agentFilePath}\n`,
|
|
47
|
+
stderr: ""
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
catch (error) {
|
|
51
|
+
if (isAlreadyExistsError(error)) {
|
|
52
|
+
return {
|
|
53
|
+
code: 0,
|
|
54
|
+
stdout: `Claude agent '${options.agentId}' already exists at ${agentFilePath}\n`,
|
|
55
|
+
stderr: ""
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
return {
|
|
59
|
+
code: 1,
|
|
60
|
+
stdout: "",
|
|
61
|
+
stderr: `Failed to create Claude agent '${options.agentId}': ${formatErrorMessage(error)}\n`
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
function resolveClaudeAgentFilePath(agentId, env) {
|
|
67
|
+
const explicitAgentsDir = env.CLAUDE_AGENTS_DIR?.trim();
|
|
68
|
+
if (explicitAgentsDir) {
|
|
69
|
+
return path.join(explicitAgentsDir, `${agentId}.md`);
|
|
70
|
+
}
|
|
71
|
+
const explicitConfigDir = env.CLAUDE_CONFIG_DIR?.trim();
|
|
72
|
+
if (explicitConfigDir) {
|
|
73
|
+
return path.join(explicitConfigDir, "agents", `${agentId}.md`);
|
|
74
|
+
}
|
|
75
|
+
const homeDir = resolveHomeDir(env);
|
|
76
|
+
return path.join(homeDir, ".claude", "agents", `${agentId}.md`);
|
|
77
|
+
}
|
|
78
|
+
function resolveHomeDir(env) {
|
|
79
|
+
return env.HOME?.trim() || env.USERPROFILE?.trim() || os.homedir();
|
|
80
|
+
}
|
|
81
|
+
function renderClaudeAgentDefinition(agentId, displayName) {
|
|
82
|
+
const safeId = JSON.stringify(agentId);
|
|
83
|
+
const safeDescription = JSON.stringify(`${displayName} agent managed by OpenGoat`);
|
|
84
|
+
return [
|
|
85
|
+
"---",
|
|
86
|
+
`name: ${safeId}`,
|
|
87
|
+
`description: ${safeDescription}`,
|
|
88
|
+
"---",
|
|
89
|
+
"",
|
|
90
|
+
`You are ${displayName}, an agent managed by OpenGoat.`,
|
|
91
|
+
"Follow instructions from OpenGoat and the user."
|
|
92
|
+
].join("\n");
|
|
93
|
+
}
|
|
94
|
+
function isAlreadyExistsError(error) {
|
|
95
|
+
return Boolean(error &&
|
|
96
|
+
typeof error === "object" &&
|
|
97
|
+
"code" in error &&
|
|
98
|
+
error.code === "EEXIST");
|
|
99
|
+
}
|
|
100
|
+
function formatErrorMessage(error) {
|
|
101
|
+
if (error instanceof Error && error.message.trim()) {
|
|
102
|
+
return error.message.trim();
|
|
103
|
+
}
|
|
104
|
+
return "unknown error";
|
|
105
|
+
}
|
|
106
|
+
//# sourceMappingURL=provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider.js","sourceRoot":"","sources":["../../../../../src/core/providers/providers/claude/provider.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { CodexProvider } from "./provider.js";
|
|
2
|
+
export const providerModule = {
|
|
3
|
+
id: "codex",
|
|
4
|
+
create: () => new CodexProvider(),
|
|
5
|
+
onboarding: {
|
|
6
|
+
env: [
|
|
7
|
+
{
|
|
8
|
+
key: "CODEX_CMD",
|
|
9
|
+
description: "Optional codex binary path override"
|
|
10
|
+
}
|
|
11
|
+
],
|
|
12
|
+
auth: {
|
|
13
|
+
supported: true,
|
|
14
|
+
description: "Runs `codex login`."
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
export { CodexProvider };
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/core/providers/providers/codex/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAE9C,MAAM,CAAC,MAAM,cAAc,GAAmB;IAC5C,EAAE,EAAE,OAAO;IACX,MAAM,EAAE,GAAG,EAAE,CAAC,IAAI,aAAa,EAAE;IACjC,UAAU,EAAE;QACV,GAAG,EAAE;YACH;gBACE,GAAG,EAAE,WAAW;gBAChB,WAAW,EAAE,qCAAqC;aACnD;SACF;QACD,IAAI,EAAE;YACJ,SAAS,EAAE,IAAI;YACf,WAAW,EAAE,qBAAqB;SACnC;KACF;CACF,CAAC;AAEF,OAAO,EAAE,aAAa,EAAE,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { ProviderAuthOptions, ProviderInvokeOptions } from "../../types.js";
|
|
2
|
+
import { BaseCliProvider } from "../../cli-provider.js";
|
|
3
|
+
export declare class CodexProvider extends BaseCliProvider {
|
|
4
|
+
constructor();
|
|
5
|
+
protected buildInvocationArgs(options: ProviderInvokeOptions): string[];
|
|
6
|
+
protected buildAuthInvocationArgs(options: ProviderAuthOptions): string[];
|
|
7
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { BaseCliProvider } from "../../cli-provider.js";
|
|
2
|
+
export class CodexProvider extends BaseCliProvider {
|
|
3
|
+
constructor() {
|
|
4
|
+
super({
|
|
5
|
+
id: "codex",
|
|
6
|
+
displayName: "Codex CLI",
|
|
7
|
+
kind: "cli",
|
|
8
|
+
command: "codex",
|
|
9
|
+
commandEnvVar: "CODEX_CMD",
|
|
10
|
+
capabilities: {
|
|
11
|
+
agent: false,
|
|
12
|
+
model: true,
|
|
13
|
+
auth: true,
|
|
14
|
+
passthrough: true
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
buildInvocationArgs(options) {
|
|
19
|
+
const args = ["exec", "--skip-git-repo-check"];
|
|
20
|
+
if (options.model) {
|
|
21
|
+
args.push("--model", options.model);
|
|
22
|
+
}
|
|
23
|
+
args.push(...(options.passthroughArgs ?? []));
|
|
24
|
+
args.push(options.message);
|
|
25
|
+
return args;
|
|
26
|
+
}
|
|
27
|
+
buildAuthInvocationArgs(options) {
|
|
28
|
+
return ["login", ...(options.passthroughArgs ?? [])];
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider.js","sourceRoot":"","sources":["../../../../../src/core/providers/providers/codex/provider.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,MAAM,OAAO,aAAc,SAAQ,eAAe;IAChD;QACE,KAAK,CAAC;YACJ,EAAE,EAAE,OAAO;YACX,WAAW,EAAE,WAAW;YACxB,IAAI,EAAE,KAAK;YACX,OAAO,EAAE,OAAO;YAChB,aAAa,EAAE,WAAW;YAC1B,YAAY,EAAE;gBACZ,KAAK,EAAE,KAAK;gBACZ,KAAK,EAAE,IAAI;gBACX,IAAI,EAAE,IAAI;gBACV,WAAW,EAAE,IAAI;aAClB;SACF,CAAC,CAAC;IACL,CAAC;IAES,mBAAmB,CAAC,OAA8B;QAC1D,MAAM,IAAI,GAAG,CAAC,MAAM,EAAE,uBAAuB,CAAC,CAAC;QAE/C,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;YAClB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;QACtC,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC,CAAC;QAC9C,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAE3B,OAAO,IAAI,CAAC;IACd,CAAC;IAEkB,uBAAuB,CAAC,OAA4B;QACrE,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC,OAAO,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC,CAAC;IACvD,CAAC;CACF"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { CursorProvider } from "./provider.js";
|
|
2
|
+
export const providerModule = {
|
|
3
|
+
id: "cursor",
|
|
4
|
+
create: () => new CursorProvider(),
|
|
5
|
+
onboarding: {
|
|
6
|
+
env: [
|
|
7
|
+
{
|
|
8
|
+
key: "CURSOR_CMD",
|
|
9
|
+
description: "Optional cursor binary path override"
|
|
10
|
+
}
|
|
11
|
+
],
|
|
12
|
+
auth: {
|
|
13
|
+
supported: true,
|
|
14
|
+
description: "Runs `cursor agent login` (or `cursor-agent login`)."
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
export { CursorProvider };
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/core/providers/providers/cursor/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAE/C,MAAM,CAAC,MAAM,cAAc,GAAmB;IAC5C,EAAE,EAAE,QAAQ;IACZ,MAAM,EAAE,GAAG,EAAE,CAAC,IAAI,cAAc,EAAE;IAClC,UAAU,EAAE;QACV,GAAG,EAAE;YACH;gBACE,GAAG,EAAE,YAAY;gBACjB,WAAW,EAAE,sCAAsC;aACpD;SACF;QACD,IAAI,EAAE;YACJ,SAAS,EAAE,IAAI;YACf,WAAW,EAAE,sDAAsD;SACpE;KACF;CACF,CAAC;AAEF,OAAO,EAAE,cAAc,EAAE,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { BaseCliProvider } from "../../cli-provider.js";
|
|
2
|
+
import type { ProviderAuthOptions, ProviderExecutionResult, ProviderInvocation, ProviderInvokeOptions } from "../../types.js";
|
|
3
|
+
export declare class CursorProvider extends BaseCliProvider {
|
|
4
|
+
constructor();
|
|
5
|
+
protected buildInvocationArgs(options: ProviderInvokeOptions, command: string): string[];
|
|
6
|
+
protected buildAuthInvocationArgs(options: ProviderAuthOptions, command: string): string[];
|
|
7
|
+
buildInvocation(options: ProviderInvokeOptions, env?: NodeJS.ProcessEnv): ProviderInvocation;
|
|
8
|
+
buildAuthInvocation(options?: ProviderAuthOptions, env?: NodeJS.ProcessEnv): ProviderInvocation;
|
|
9
|
+
invoke(options: ProviderInvokeOptions): Promise<ProviderExecutionResult>;
|
|
10
|
+
private createChatSessionId;
|
|
11
|
+
}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import path from "node:path";
|
|
2
|
+
import { executeCommand } from "../../command-executor.js";
|
|
3
|
+
import { BaseCliProvider } from "../../cli-provider.js";
|
|
4
|
+
import { attachProviderSessionId } from "../../provider-session.js";
|
|
5
|
+
export class CursorProvider extends BaseCliProvider {
|
|
6
|
+
constructor() {
|
|
7
|
+
super({
|
|
8
|
+
id: "cursor",
|
|
9
|
+
displayName: "Cursor",
|
|
10
|
+
kind: "cli",
|
|
11
|
+
command: "cursor",
|
|
12
|
+
commandEnvVar: "CURSOR_CMD",
|
|
13
|
+
capabilities: {
|
|
14
|
+
agent: false,
|
|
15
|
+
model: false,
|
|
16
|
+
auth: true,
|
|
17
|
+
passthrough: true
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
buildInvocationArgs(options, command) {
|
|
22
|
+
const payload = [];
|
|
23
|
+
if (options.providerSessionId?.trim()) {
|
|
24
|
+
payload.push("--resume", options.providerSessionId.trim());
|
|
25
|
+
}
|
|
26
|
+
payload.push(...(options.passthroughArgs ?? []), options.message);
|
|
27
|
+
if (isCursorAgentCommand(command)) {
|
|
28
|
+
return payload;
|
|
29
|
+
}
|
|
30
|
+
return ["agent", ...payload];
|
|
31
|
+
}
|
|
32
|
+
buildAuthInvocationArgs(options, command) {
|
|
33
|
+
const payload = ["login", ...(options.passthroughArgs ?? [])];
|
|
34
|
+
if (isCursorAgentCommand(command)) {
|
|
35
|
+
return payload;
|
|
36
|
+
}
|
|
37
|
+
return ["agent", ...payload];
|
|
38
|
+
}
|
|
39
|
+
buildInvocation(options, env = process.env) {
|
|
40
|
+
return super.buildInvocation(options, env);
|
|
41
|
+
}
|
|
42
|
+
buildAuthInvocation(options = {}, env = process.env) {
|
|
43
|
+
return super.buildAuthInvocation(options, env);
|
|
44
|
+
}
|
|
45
|
+
async invoke(options) {
|
|
46
|
+
const env = options.env ?? process.env;
|
|
47
|
+
const requestedSessionId = options.providerSessionId?.trim();
|
|
48
|
+
let effectiveSessionId = requestedSessionId;
|
|
49
|
+
if (!effectiveSessionId && options.forceNewProviderSession) {
|
|
50
|
+
effectiveSessionId = await this.createChatSessionId(env, options.cwd, options.abortSignal);
|
|
51
|
+
}
|
|
52
|
+
const result = await super.invoke({
|
|
53
|
+
...options,
|
|
54
|
+
providerSessionId: effectiveSessionId
|
|
55
|
+
});
|
|
56
|
+
return attachProviderSessionId(result, effectiveSessionId);
|
|
57
|
+
}
|
|
58
|
+
async createChatSessionId(env, cwd, abortSignal) {
|
|
59
|
+
const command = this.resolveCommand(env);
|
|
60
|
+
const args = isCursorAgentCommand(command) ? ["create-chat"] : ["agent", "create-chat"];
|
|
61
|
+
try {
|
|
62
|
+
const result = await executeCommand({
|
|
63
|
+
command,
|
|
64
|
+
args,
|
|
65
|
+
cwd,
|
|
66
|
+
env,
|
|
67
|
+
abortSignal
|
|
68
|
+
});
|
|
69
|
+
if (result.code !== 0) {
|
|
70
|
+
return undefined;
|
|
71
|
+
}
|
|
72
|
+
const firstLine = result.stdout
|
|
73
|
+
.split(/\r?\n/)
|
|
74
|
+
.map((line) => line.trim())
|
|
75
|
+
.find((line) => Boolean(line));
|
|
76
|
+
return firstLine || undefined;
|
|
77
|
+
}
|
|
78
|
+
catch (error) {
|
|
79
|
+
if (error instanceof Error && error.name === "AbortError") {
|
|
80
|
+
throw error;
|
|
81
|
+
}
|
|
82
|
+
return undefined;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
function isCursorAgentCommand(command) {
|
|
87
|
+
const executable = path.basename(command).toLowerCase();
|
|
88
|
+
return executable === "cursor-agent" || executable === "cursor-agent.exe";
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider.js","sourceRoot":"","sources":["../../../../../src/core/providers/providers/cursor/provider.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import type { ProviderOnboardingEnvField, ProviderOnboardingSpec } from "../../provider-module.js";
|
|
2
|
+
export type ExtendedHttpProviderProtocol = "openai-chat" | "anthropic-messages" | "bedrock-converse";
|
|
3
|
+
export type ExtendedHttpAuthHeader = "bearer" | "x-api-key" | "api-key";
|
|
4
|
+
interface ExtendedHttpProviderEndpoint {
|
|
5
|
+
baseUrl?: string;
|
|
6
|
+
baseUrlEnvVar?: string;
|
|
7
|
+
endpointPath?: string;
|
|
8
|
+
endpointPathEnvVar?: string;
|
|
9
|
+
endpointEnvVar?: string;
|
|
10
|
+
resolveBaseUrl?: (env: NodeJS.ProcessEnv) => string | undefined;
|
|
11
|
+
}
|
|
12
|
+
interface ExtendedHttpProviderAuth {
|
|
13
|
+
envVars?: string[];
|
|
14
|
+
header?: ExtendedHttpAuthHeader;
|
|
15
|
+
optional?: boolean;
|
|
16
|
+
oauthTokenHeader?: ExtendedHttpAuthHeader;
|
|
17
|
+
}
|
|
18
|
+
interface ExtendedHttpHeaderFromEnv {
|
|
19
|
+
name: string;
|
|
20
|
+
envVar: string;
|
|
21
|
+
}
|
|
22
|
+
export interface ExtendedHttpProviderSpec {
|
|
23
|
+
id: string;
|
|
24
|
+
displayName: string;
|
|
25
|
+
protocol: ExtendedHttpProviderProtocol;
|
|
26
|
+
endpoint: ExtendedHttpProviderEndpoint;
|
|
27
|
+
auth?: ExtendedHttpProviderAuth;
|
|
28
|
+
requiredEnv: ProviderOnboardingEnvField[];
|
|
29
|
+
modelEnvVar: string;
|
|
30
|
+
defaultModel?: string;
|
|
31
|
+
stripProviderPrefix?: boolean;
|
|
32
|
+
fixedHeaders?: Record<string, string>;
|
|
33
|
+
headersFromEnv?: ExtendedHttpHeaderFromEnv[];
|
|
34
|
+
maxTokensEnvVar?: string;
|
|
35
|
+
defaultMaxTokens?: number;
|
|
36
|
+
}
|
|
37
|
+
export declare const extendedHttpProviderCatalog: ExtendedHttpProviderSpec[];
|
|
38
|
+
export declare function resolveExtendedHttpProviderModelEnvVar(providerId: string): string | undefined;
|
|
39
|
+
export declare function resolveExtendedHttpProviderOnboarding(spec: ExtendedHttpProviderSpec): ProviderOnboardingSpec;
|
|
40
|
+
export {};
|