@zhijiewang/openharness 0.1.0

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.
Files changed (135) hide show
  1. package/CHANGELOG.md +18 -0
  2. package/CONTRIBUTING.md +55 -0
  3. package/LICENSE +21 -0
  4. package/README.md +154 -0
  5. package/data/models.json +74 -0
  6. package/data/prompts/system.md +25 -0
  7. package/data/skills/code-review.md +19 -0
  8. package/data/skills/commit.md +17 -0
  9. package/data/skills/debug.md +24 -0
  10. package/data/skills/tdd.md +22 -0
  11. package/dist/Tool.d.ts +45 -0
  12. package/dist/Tool.d.ts.map +1 -0
  13. package/dist/Tool.js +62 -0
  14. package/dist/Tool.js.map +1 -0
  15. package/dist/components/App.d.ts +16 -0
  16. package/dist/components/App.d.ts.map +1 -0
  17. package/dist/components/App.js +25 -0
  18. package/dist/components/App.js.map +1 -0
  19. package/dist/components/Messages.d.ts +9 -0
  20. package/dist/components/Messages.d.ts.map +1 -0
  21. package/dist/components/Messages.js +23 -0
  22. package/dist/components/Messages.js.map +1 -0
  23. package/dist/components/PermissionPrompt.d.ts +9 -0
  24. package/dist/components/PermissionPrompt.d.ts.map +1 -0
  25. package/dist/components/PermissionPrompt.js +18 -0
  26. package/dist/components/PermissionPrompt.js.map +1 -0
  27. package/dist/components/REPL.d.ts +15 -0
  28. package/dist/components/REPL.d.ts.map +1 -0
  29. package/dist/components/REPL.js +114 -0
  30. package/dist/components/REPL.js.map +1 -0
  31. package/dist/components/Spinner.d.ts +7 -0
  32. package/dist/components/Spinner.d.ts.map +1 -0
  33. package/dist/components/Spinner.js +7 -0
  34. package/dist/components/Spinner.js.map +1 -0
  35. package/dist/components/TextInput.d.ts +7 -0
  36. package/dist/components/TextInput.d.ts.map +1 -0
  37. package/dist/components/TextInput.js +37 -0
  38. package/dist/components/TextInput.js.map +1 -0
  39. package/dist/components/ToolCallDisplay.d.ts +12 -0
  40. package/dist/components/ToolCallDisplay.d.ts.map +1 -0
  41. package/dist/components/ToolCallDisplay.js +16 -0
  42. package/dist/components/ToolCallDisplay.js.map +1 -0
  43. package/dist/harness/cost.d.ts +33 -0
  44. package/dist/harness/cost.d.ts.map +1 -0
  45. package/dist/harness/cost.js +68 -0
  46. package/dist/harness/cost.js.map +1 -0
  47. package/dist/harness/onboarding.d.ts +17 -0
  48. package/dist/harness/onboarding.d.ts.map +1 -0
  49. package/dist/harness/onboarding.js +99 -0
  50. package/dist/harness/onboarding.js.map +1 -0
  51. package/dist/harness/rules.d.ts +8 -0
  52. package/dist/harness/rules.d.ts.map +1 -0
  53. package/dist/harness/rules.js +66 -0
  54. package/dist/harness/rules.js.map +1 -0
  55. package/dist/harness/session.d.ts +24 -0
  56. package/dist/harness/session.d.ts.map +1 -0
  57. package/dist/harness/session.js +56 -0
  58. package/dist/harness/session.js.map +1 -0
  59. package/dist/main.d.ts +12 -0
  60. package/dist/main.d.ts.map +1 -0
  61. package/dist/main.js +177 -0
  62. package/dist/main.js.map +1 -0
  63. package/dist/providers/anthropic.d.ts +27 -0
  64. package/dist/providers/anthropic.d.ts.map +1 -0
  65. package/dist/providers/anthropic.js +291 -0
  66. package/dist/providers/anthropic.js.map +1 -0
  67. package/dist/providers/base.d.ts +41 -0
  68. package/dist/providers/base.d.ts.map +1 -0
  69. package/dist/providers/base.js +5 -0
  70. package/dist/providers/base.js.map +1 -0
  71. package/dist/providers/index.d.ts +12 -0
  72. package/dist/providers/index.d.ts.map +1 -0
  73. package/dist/providers/index.js +57 -0
  74. package/dist/providers/index.js.map +1 -0
  75. package/dist/providers/ollama.d.ts +19 -0
  76. package/dist/providers/ollama.d.ts.map +1 -0
  77. package/dist/providers/ollama.js +233 -0
  78. package/dist/providers/ollama.js.map +1 -0
  79. package/dist/providers/openai.d.ts +21 -0
  80. package/dist/providers/openai.d.ts.map +1 -0
  81. package/dist/providers/openai.js +242 -0
  82. package/dist/providers/openai.js.map +1 -0
  83. package/dist/providers/openrouter.d.ts +25 -0
  84. package/dist/providers/openrouter.d.ts.map +1 -0
  85. package/dist/providers/openrouter.js +278 -0
  86. package/dist/providers/openrouter.js.map +1 -0
  87. package/dist/query.d.ts +35 -0
  88. package/dist/query.d.ts.map +1 -0
  89. package/dist/query.js +185 -0
  90. package/dist/query.js.map +1 -0
  91. package/dist/tools/BashTool/index.d.ts +15 -0
  92. package/dist/tools/BashTool/index.d.ts.map +1 -0
  93. package/dist/tools/BashTool/index.js +78 -0
  94. package/dist/tools/BashTool/index.js.map +1 -0
  95. package/dist/tools/FileEditTool/index.d.ts +21 -0
  96. package/dist/tools/FileEditTool/index.d.ts.map +1 -0
  97. package/dist/tools/FileEditTool/index.js +70 -0
  98. package/dist/tools/FileEditTool/index.js.map +1 -0
  99. package/dist/tools/FileReadTool/index.d.ts +18 -0
  100. package/dist/tools/FileReadTool/index.d.ts.map +1 -0
  101. package/dist/tools/FileReadTool/index.js +63 -0
  102. package/dist/tools/FileReadTool/index.js.map +1 -0
  103. package/dist/tools/FileWriteTool/index.d.ts +15 -0
  104. package/dist/tools/FileWriteTool/index.d.ts.map +1 -0
  105. package/dist/tools/FileWriteTool/index.js +42 -0
  106. package/dist/tools/FileWriteTool/index.js.map +1 -0
  107. package/dist/tools/GlobTool/index.d.ts +15 -0
  108. package/dist/tools/GlobTool/index.d.ts.map +1 -0
  109. package/dist/tools/GlobTool/index.js +126 -0
  110. package/dist/tools/GlobTool/index.js.map +1 -0
  111. package/dist/tools/GrepTool/index.d.ts +21 -0
  112. package/dist/tools/GrepTool/index.d.ts.map +1 -0
  113. package/dist/tools/GrepTool/index.js +125 -0
  114. package/dist/tools/GrepTool/index.js.map +1 -0
  115. package/dist/tools/WebFetchTool/index.d.ts +12 -0
  116. package/dist/tools/WebFetchTool/index.d.ts.map +1 -0
  117. package/dist/tools/WebFetchTool/index.js +98 -0
  118. package/dist/tools/WebFetchTool/index.js.map +1 -0
  119. package/dist/tools.d.ts +9 -0
  120. package/dist/tools.d.ts.map +1 -0
  121. package/dist/tools.js +25 -0
  122. package/dist/tools.js.map +1 -0
  123. package/dist/types/events.d.ts +49 -0
  124. package/dist/types/events.d.ts.map +1 -0
  125. package/dist/types/events.js +5 -0
  126. package/dist/types/events.js.map +1 -0
  127. package/dist/types/message.d.ts +27 -0
  128. package/dist/types/message.d.ts.map +1 -0
  129. package/dist/types/message.js +22 -0
  130. package/dist/types/message.js.map +1 -0
  131. package/dist/types/permissions.d.ts +22 -0
  132. package/dist/types/permissions.d.ts.map +1 -0
  133. package/dist/types/permissions.js +27 -0
  134. package/dist/types/permissions.js.map +1 -0
  135. package/package.json +55 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rules.js","sourceRoot":"","sources":["../../src/harness/rules.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ /**
2
+ * Session persistence — save and resume conversations.
3
+ */
4
+ import type { Message } from "../types/message.js";
5
+ export type Session = {
6
+ id: string;
7
+ messages: Message[];
8
+ createdAt: number;
9
+ updatedAt: number;
10
+ provider: string;
11
+ model: string;
12
+ totalCost: number;
13
+ };
14
+ export declare function createSession(provider: string, model: string): Session;
15
+ export declare function saveSession(session: Session, dir?: string): string;
16
+ export declare function loadSession(id: string, dir?: string): Session;
17
+ export declare function listSessions(dir?: string): Array<{
18
+ id: string;
19
+ model: string;
20
+ messages: number;
21
+ cost: number;
22
+ updatedAt: number;
23
+ }>;
24
+ //# sourceMappingURL=session.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session.d.ts","sourceRoot":"","sources":["../../src/harness/session.ts"],"names":[],"mappings":"AAAA;;GAEG;AAKH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAInD,MAAM,MAAM,OAAO,GAAG;IACpB,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,wBAAgB,aAAa,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAUtE;AAED,wBAAgB,WAAW,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,CAOlE;AAED,wBAAgB,WAAW,CAAC,EAAE,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,CAI7D;AAED,wBAAgB,YAAY,CAAC,GAAG,CAAC,EAAE,MAAM,GAAG,KAAK,CAAC;IAChD,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC,CAsBD"}
@@ -0,0 +1,56 @@
1
+ /**
2
+ * Session persistence — save and resume conversations.
3
+ */
4
+ import { readFileSync, writeFileSync, mkdirSync, readdirSync, existsSync } from "node:fs";
5
+ import { join } from "node:path";
6
+ import { homedir } from "node:os";
7
+ const DEFAULT_SESSION_DIR = join(homedir(), ".oh", "sessions");
8
+ export function createSession(provider, model) {
9
+ return {
10
+ id: crypto.randomUUID().slice(0, 12),
11
+ messages: [],
12
+ createdAt: Date.now(),
13
+ updatedAt: Date.now(),
14
+ provider,
15
+ model,
16
+ totalCost: 0,
17
+ };
18
+ }
19
+ export function saveSession(session, dir) {
20
+ const sessionDir = dir ?? DEFAULT_SESSION_DIR;
21
+ mkdirSync(sessionDir, { recursive: true });
22
+ const path = join(sessionDir, `${session.id}.json`);
23
+ session.updatedAt = Date.now();
24
+ writeFileSync(path, JSON.stringify(session, null, 2));
25
+ return path;
26
+ }
27
+ export function loadSession(id, dir) {
28
+ const sessionDir = dir ?? DEFAULT_SESSION_DIR;
29
+ const path = join(sessionDir, `${id}.json`);
30
+ return JSON.parse(readFileSync(path, "utf-8"));
31
+ }
32
+ export function listSessions(dir) {
33
+ const sessionDir = dir ?? DEFAULT_SESSION_DIR;
34
+ if (!existsSync(sessionDir))
35
+ return [];
36
+ return readdirSync(sessionDir)
37
+ .filter((f) => f.endsWith(".json"))
38
+ .map((f) => {
39
+ try {
40
+ const data = JSON.parse(readFileSync(join(sessionDir, f), "utf-8"));
41
+ return {
42
+ id: data.id,
43
+ model: data.model ?? "",
44
+ messages: data.messages?.length ?? 0,
45
+ cost: data.totalCost ?? 0,
46
+ updatedAt: data.updatedAt ?? 0,
47
+ };
48
+ }
49
+ catch {
50
+ return null;
51
+ }
52
+ })
53
+ .filter((s) => s !== null)
54
+ .sort((a, b) => b.updatedAt - a.updatedAt);
55
+ }
56
+ //# sourceMappingURL=session.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session.js","sourceRoot":"","sources":["../../src/harness/session.ts"],"names":[],"mappings":"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"}
package/dist/main.d.ts ADDED
@@ -0,0 +1,12 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * OpenHarness CLI entry point.
4
+ *
5
+ * Usage:
6
+ * npx openharness # auto-detect provider, start chatting
7
+ * npx openharness --model ollama/llama3 # use specific model
8
+ * npx openharness models # list models
9
+ * npx openharness tools # list tools
10
+ */
11
+ export {};
12
+ //# sourceMappingURL=main.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"main.d.ts","sourceRoot":"","sources":["../src/main.tsx"],"names":[],"mappings":";AACA;;;;;;;;GAQG"}
package/dist/main.js ADDED
@@ -0,0 +1,177 @@
1
+ #!/usr/bin/env node
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { render } from "ink";
4
+ import { Command, Option } from "commander";
5
+ import App from "./components/App.js";
6
+ import { getAllTools } from "./tools.js";
7
+ import { createRulesFile, loadRules } from "./harness/rules.js";
8
+ import { detectProject } from "./harness/onboarding.js";
9
+ import { MODEL_PRICING } from "./harness/cost.js";
10
+ import { listSessions } from "./harness/session.js";
11
+ const VERSION = "0.1.0";
12
+ const program = new Command();
13
+ program
14
+ .name("openharness")
15
+ .description("Open-source terminal coding agent. Build your own Claude Code with any LLM.")
16
+ .version(VERSION);
17
+ // ── Default command: just run `openharness` to start chatting ──
18
+ program
19
+ .command("chat", { isDefault: true })
20
+ .description("Start an interactive chat session")
21
+ .option("-m, --model <model>", "Model to use (e.g., ollama/llama3, gpt-4o)")
22
+ .addOption(new Option("--permission-mode <mode>", "Permission mode")
23
+ .choices(["ask", "trust", "deny"])
24
+ .default("ask"))
25
+ .option("--trust", "Auto-approve all tool calls")
26
+ .option("--deny", "Block all non-read tool calls")
27
+ .option("--resume <id>", "Resume a saved session")
28
+ .action(async (opts) => {
29
+ const permissionMode = opts.trust
30
+ ? "trust"
31
+ : opts.deny
32
+ ? "deny"
33
+ : opts.permissionMode;
34
+ // Auto-detect provider or prompt for setup
35
+ let provider;
36
+ let resolvedModel;
37
+ try {
38
+ const { createProvider } = await import("./providers/index.js");
39
+ const result = await createProvider(opts.model);
40
+ provider = result.provider;
41
+ resolvedModel = result.model;
42
+ }
43
+ catch (err) {
44
+ // First-run experience: guide the user
45
+ console.log();
46
+ console.log(" Welcome to OpenHarness!");
47
+ console.log();
48
+ console.log(" To get started, choose a provider:");
49
+ console.log();
50
+ console.log(" Local (free, no API key):");
51
+ console.log(" npx openharness --model ollama/llama3");
52
+ console.log(" npx openharness --model ollama/qwen2.5:7b-instruct");
53
+ console.log();
54
+ console.log(" Cloud (needs API key in env var):");
55
+ console.log(" OPENAI_API_KEY=sk-... npx openharness --model gpt-4o");
56
+ console.log(" ANTHROPIC_API_KEY=sk-ant-... npx openharness --model claude-sonnet-4-6");
57
+ console.log();
58
+ console.log(" Make sure Ollama is running: ollama serve");
59
+ console.log();
60
+ process.exit(0);
61
+ }
62
+ const tools = getAllTools();
63
+ render(_jsx(App, { provider: provider, tools: tools, permissionMode: permissionMode, model: resolvedModel }));
64
+ });
65
+ // ── models ──
66
+ program
67
+ .command("models")
68
+ .description("List available models and pricing")
69
+ .action(async () => {
70
+ console.log();
71
+ console.log(" Model Provider Input/1M Output/1M");
72
+ console.log(" " + "─".repeat(65));
73
+ // Try listing Ollama local models
74
+ try {
75
+ const { createProvider } = await import("./providers/index.js");
76
+ const { provider } = await createProvider("ollama/llama3");
77
+ for (const m of provider.listModels()) {
78
+ console.log(` ${m.id.padEnd(30)} ${"ollama".padEnd(12)} free`);
79
+ }
80
+ }
81
+ catch { /* Ollama not running */ }
82
+ // Cloud models from pricing registry
83
+ for (const [model, [inp, out]] of Object.entries(MODEL_PRICING).sort()) {
84
+ if (inp === 0)
85
+ continue;
86
+ console.log(` ${model.padEnd(30)} ${guessProvider(model).padEnd(12)} $${inp.toFixed(2).padStart(6)} $${out.toFixed(2).padStart(6)}`);
87
+ }
88
+ console.log();
89
+ });
90
+ // ── tools ──
91
+ program
92
+ .command("tools")
93
+ .description("List available tools and risk levels")
94
+ .action(() => {
95
+ const tools = getAllTools();
96
+ console.log();
97
+ console.log(" Tool Risk Description");
98
+ console.log(" " + "─".repeat(55));
99
+ for (const t of tools) {
100
+ console.log(` ${t.name.padEnd(10)} ${t.riskLevel.padEnd(8)} ${t.description.slice(0, 45)}`);
101
+ }
102
+ console.log();
103
+ });
104
+ // ── init ──
105
+ program
106
+ .command("init")
107
+ .description("Initialize OpenHarness for the current project")
108
+ .action(() => {
109
+ const rulesPath = createRulesFile();
110
+ const ctx = detectProject();
111
+ console.log();
112
+ console.log(" OpenHarness initialized!");
113
+ console.log(` Created: ${rulesPath}`);
114
+ if (ctx.language !== "unknown") {
115
+ console.log(` Detected: ${ctx.language}${ctx.framework ? ` (${ctx.framework})` : ""}`);
116
+ }
117
+ if (ctx.hasGit) {
118
+ console.log(` Git branch: ${ctx.gitBranch}`);
119
+ }
120
+ console.log();
121
+ console.log(" Next: npx openharness --model ollama/llama3");
122
+ console.log();
123
+ });
124
+ // ── sessions ──
125
+ program
126
+ .command("sessions")
127
+ .description("List saved sessions")
128
+ .action(() => {
129
+ const sessions = listSessions();
130
+ if (sessions.length === 0) {
131
+ console.log(" No saved sessions.");
132
+ return;
133
+ }
134
+ console.log();
135
+ console.log(" ID Model Messages Updated");
136
+ console.log(" " + "─".repeat(55));
137
+ for (const s of sessions.slice(0, 20)) {
138
+ const date = new Date(s.updatedAt).toISOString().slice(0, 16);
139
+ console.log(` ${s.id.padEnd(13)} ${s.model.padEnd(18)} ${String(s.messages).padEnd(10)} ${date}`);
140
+ }
141
+ console.log();
142
+ console.log(" Resume: npx openharness --resume <ID>");
143
+ console.log();
144
+ });
145
+ // ── rules ──
146
+ program
147
+ .command("rules")
148
+ .description("Show project rules")
149
+ .option("--init", "Create .oh/RULES.md")
150
+ .action((opts) => {
151
+ if (opts.init) {
152
+ console.log(` Created: ${createRulesFile()}`);
153
+ return;
154
+ }
155
+ const rules = loadRules();
156
+ if (rules.length === 0) {
157
+ console.log(" No rules. Run: npx openharness init");
158
+ return;
159
+ }
160
+ console.log(` ${rules.length} rule(s) loaded.`);
161
+ });
162
+ program.parseAsync(process.argv).catch((err) => {
163
+ console.error(err instanceof Error ? err.message : String(err));
164
+ process.exitCode = 1;
165
+ });
166
+ function guessProvider(model) {
167
+ if (model.includes("gpt") || model.startsWith("o3"))
168
+ return "openai";
169
+ if (model.includes("claude"))
170
+ return "anthropic";
171
+ if (model.includes("deepseek"))
172
+ return "deepseek";
173
+ if (model.includes("qwen"))
174
+ return "qwen";
175
+ return "unknown";
176
+ }
177
+ //# sourceMappingURL=main.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,27 @@
1
+ /**
2
+ * Anthropic provider — Claude models via the Anthropic Messages API.
3
+ */
4
+ import type { Message } from "../types/message.js";
5
+ import type { StreamEvent } from "../types/events.js";
6
+ import type { Provider, APIToolDef, ModelInfo, ProviderConfig } from "./base.js";
7
+ export declare class AnthropicProvider implements Provider {
8
+ readonly name = "anthropic";
9
+ private apiKey;
10
+ private baseUrl;
11
+ private defaultModel;
12
+ constructor(config: ProviderConfig);
13
+ private headers;
14
+ /**
15
+ * Convert internal messages to Anthropic format.
16
+ * System prompt goes in a separate field; tool results become user messages
17
+ * with tool_result content blocks.
18
+ */
19
+ private convertMessages;
20
+ private convertTools;
21
+ stream(messages: Message[], systemPrompt: string, tools?: APIToolDef[], model?: string): AsyncGenerator<StreamEvent, void>;
22
+ complete(messages: Message[], systemPrompt: string, tools?: APIToolDef[], model?: string): Promise<Message>;
23
+ private getModelInfo;
24
+ listModels(): ModelInfo[];
25
+ healthCheck(): Promise<boolean>;
26
+ }
27
+ //# sourceMappingURL=anthropic.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"anthropic.d.ts","sourceRoot":"","sources":["../../src/providers/anthropic.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAY,MAAM,qBAAqB,CAAC;AAC7D,OAAO,KAAK,EAAE,WAAW,EAAoB,MAAM,oBAAoB,CAAC;AAExE,OAAO,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAEjF,qBAAa,iBAAkB,YAAW,QAAQ;IAChD,QAAQ,CAAC,IAAI,eAAe;IAC5B,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,YAAY,CAAS;gBAEjB,MAAM,EAAE,cAAc;IAMlC,OAAO,CAAC,OAAO;IAQf;;;;OAIG;IACH,OAAO,CAAC,eAAe;IAqCvB,OAAO,CAAC,YAAY;IASb,MAAM,CACX,QAAQ,EAAE,OAAO,EAAE,EACnB,YAAY,EAAE,MAAM,EACpB,KAAK,CAAC,EAAE,UAAU,EAAE,EACpB,KAAK,CAAC,EAAE,MAAM,GACb,cAAc,CAAC,WAAW,EAAE,IAAI,CAAC;IAoJ9B,QAAQ,CACZ,QAAQ,EAAE,OAAO,EAAE,EACnB,YAAY,EAAE,MAAM,EACpB,KAAK,CAAC,EAAE,UAAU,EAAE,EACpB,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,OAAO,CAAC;IAwCnB,OAAO,CAAC,YAAY;IAIpB,UAAU,IAAI,SAAS,EAAE;IAmCnB,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;CAGtC"}
@@ -0,0 +1,291 @@
1
+ /**
2
+ * Anthropic provider — Claude models via the Anthropic Messages API.
3
+ */
4
+ import { createAssistantMessage } from "../types/message.js";
5
+ export class AnthropicProvider {
6
+ name = "anthropic";
7
+ apiKey;
8
+ baseUrl;
9
+ defaultModel;
10
+ constructor(config) {
11
+ this.apiKey = config.apiKey ?? "";
12
+ this.baseUrl = (config.baseUrl ?? "https://api.anthropic.com").replace(/\/$/, "");
13
+ this.defaultModel = config.defaultModel ?? "claude-sonnet-4-6";
14
+ }
15
+ headers() {
16
+ return {
17
+ "Content-Type": "application/json",
18
+ "x-api-key": this.apiKey,
19
+ "anthropic-version": "2023-06-01",
20
+ };
21
+ }
22
+ /**
23
+ * Convert internal messages to Anthropic format.
24
+ * System prompt goes in a separate field; tool results become user messages
25
+ * with tool_result content blocks.
26
+ */
27
+ convertMessages(messages) {
28
+ const out = [];
29
+ for (const msg of messages) {
30
+ if (msg.role === "system")
31
+ continue;
32
+ if (msg.role === "assistant" && msg.toolCalls?.length) {
33
+ const content = [];
34
+ if (msg.content) {
35
+ content.push({ type: "text", text: msg.content });
36
+ }
37
+ for (const tc of msg.toolCalls) {
38
+ content.push({
39
+ type: "tool_use",
40
+ id: tc.id,
41
+ name: tc.toolName,
42
+ input: tc.arguments,
43
+ });
44
+ }
45
+ out.push({ role: "assistant", content });
46
+ }
47
+ else if (msg.role === "tool" && msg.toolResults?.length) {
48
+ const content = msg.toolResults.map((tr) => ({
49
+ type: "tool_result",
50
+ tool_use_id: tr.callId,
51
+ content: tr.output,
52
+ is_error: tr.isError,
53
+ }));
54
+ out.push({ role: "user", content });
55
+ }
56
+ else if (msg.role === "assistant") {
57
+ out.push({ role: "assistant", content: msg.content });
58
+ }
59
+ else {
60
+ out.push({ role: "user", content: msg.content });
61
+ }
62
+ }
63
+ return out;
64
+ }
65
+ convertTools(tools) {
66
+ if (!tools?.length)
67
+ return undefined;
68
+ return tools.map((t) => ({
69
+ name: t.function.name,
70
+ description: t.function.description,
71
+ input_schema: t.function.parameters,
72
+ }));
73
+ }
74
+ async *stream(messages, systemPrompt, tools, model) {
75
+ const m = model ?? this.defaultModel;
76
+ const body = {
77
+ model: m,
78
+ max_tokens: 8192,
79
+ system: systemPrompt,
80
+ messages: this.convertMessages(messages),
81
+ stream: true,
82
+ };
83
+ const anthropicTools = this.convertTools(tools);
84
+ if (anthropicTools)
85
+ body.tools = anthropicTools;
86
+ let res;
87
+ try {
88
+ res = await fetch(`${this.baseUrl}/v1/messages`, {
89
+ method: "POST",
90
+ headers: this.headers(),
91
+ body: JSON.stringify(body),
92
+ });
93
+ }
94
+ catch (err) {
95
+ yield { type: "error", message: `Anthropic request failed: ${err}` };
96
+ return;
97
+ }
98
+ if (!res.ok) {
99
+ yield { type: "error", message: `Anthropic HTTP ${res.status}: ${await res.text()}` };
100
+ return;
101
+ }
102
+ const reader = res.body?.getReader();
103
+ if (!reader)
104
+ return;
105
+ const decoder = new TextDecoder();
106
+ let buffer = "";
107
+ // Track current tool_use block for input_json_delta accumulation
108
+ let currentToolId = "";
109
+ let currentToolName = "";
110
+ let currentToolArgs = "";
111
+ while (true) {
112
+ const { done, value } = await reader.read();
113
+ if (done)
114
+ break;
115
+ buffer += decoder.decode(value, { stream: true });
116
+ const lines = buffer.split("\n");
117
+ buffer = lines.pop() ?? "";
118
+ let currentEvent = "";
119
+ for (const line of lines) {
120
+ const trimmed = line.trim();
121
+ if (trimmed.startsWith("event:")) {
122
+ currentEvent = trimmed.slice(6).trim();
123
+ continue;
124
+ }
125
+ if (!trimmed.startsWith("data:"))
126
+ continue;
127
+ const payload = trimmed.slice(5).trim();
128
+ let data;
129
+ try {
130
+ data = JSON.parse(payload);
131
+ }
132
+ catch {
133
+ continue;
134
+ }
135
+ switch (currentEvent) {
136
+ case "content_block_start": {
137
+ const block = data.content_block;
138
+ if (block?.type === "tool_use") {
139
+ currentToolId = block.id;
140
+ currentToolName = block.name;
141
+ currentToolArgs = "";
142
+ yield {
143
+ type: "tool_call_start",
144
+ toolName: block.name,
145
+ callId: block.id,
146
+ };
147
+ }
148
+ break;
149
+ }
150
+ case "content_block_delta": {
151
+ const delta = data.delta;
152
+ if (delta?.type === "text_delta" && delta.text) {
153
+ yield { type: "text_delta", content: delta.text };
154
+ }
155
+ if (delta?.type === "input_json_delta" && delta.partial_json) {
156
+ currentToolArgs += delta.partial_json;
157
+ }
158
+ break;
159
+ }
160
+ case "content_block_stop": {
161
+ if (currentToolId) {
162
+ yield {
163
+ type: "tool_call_complete",
164
+ callId: currentToolId,
165
+ toolName: currentToolName,
166
+ arguments: currentToolArgs ? JSON.parse(currentToolArgs) : {},
167
+ };
168
+ currentToolId = "";
169
+ currentToolName = "";
170
+ currentToolArgs = "";
171
+ }
172
+ break;
173
+ }
174
+ case "message_delta": {
175
+ // Contains stop_reason and usage
176
+ const usage = data.usage;
177
+ if (usage) {
178
+ const outputTokens = usage.output_tokens ?? 0;
179
+ // Input tokens come from message_start; output delta comes here
180
+ // We'll emit partial cost; full cost from message_start + message_delta
181
+ const info = this.getModelInfo(m);
182
+ const cost = (outputTokens * (info?.outputCostPerMtok ?? 0)) / 1_000_000;
183
+ yield {
184
+ type: "cost_update",
185
+ inputTokens: 0,
186
+ outputTokens,
187
+ cost,
188
+ model: m,
189
+ };
190
+ }
191
+ break;
192
+ }
193
+ case "message_start": {
194
+ const usage = data.message?.usage;
195
+ if (usage) {
196
+ const inputTokens = usage.input_tokens ?? 0;
197
+ const info = this.getModelInfo(m);
198
+ const cost = (inputTokens * (info?.inputCostPerMtok ?? 0)) / 1_000_000;
199
+ yield {
200
+ type: "cost_update",
201
+ inputTokens,
202
+ outputTokens: 0,
203
+ cost,
204
+ model: m,
205
+ };
206
+ }
207
+ break;
208
+ }
209
+ }
210
+ currentEvent = "";
211
+ }
212
+ }
213
+ }
214
+ async complete(messages, systemPrompt, tools, model) {
215
+ const m = model ?? this.defaultModel;
216
+ const body = {
217
+ model: m,
218
+ max_tokens: 8192,
219
+ system: systemPrompt,
220
+ messages: this.convertMessages(messages),
221
+ };
222
+ const anthropicTools = this.convertTools(tools);
223
+ if (anthropicTools)
224
+ body.tools = anthropicTools;
225
+ const res = await fetch(`${this.baseUrl}/v1/messages`, {
226
+ method: "POST",
227
+ headers: this.headers(),
228
+ body: JSON.stringify(body),
229
+ });
230
+ if (!res.ok) {
231
+ throw new Error(`Anthropic HTTP ${res.status}: ${await res.text()}`);
232
+ }
233
+ const data = await res.json();
234
+ let content = "";
235
+ const toolCalls = [];
236
+ for (const block of data.content ?? []) {
237
+ if (block.type === "text") {
238
+ content += block.text;
239
+ }
240
+ else if (block.type === "tool_use") {
241
+ toolCalls.push({
242
+ id: block.id,
243
+ toolName: block.name,
244
+ arguments: block.input ?? {},
245
+ });
246
+ }
247
+ }
248
+ return createAssistantMessage(content, toolCalls.length ? toolCalls : undefined);
249
+ }
250
+ getModelInfo(id) {
251
+ return this.listModels().find((m) => m.id === id);
252
+ }
253
+ listModels() {
254
+ return [
255
+ {
256
+ id: "claude-sonnet-4-6",
257
+ provider: "anthropic",
258
+ contextWindow: 200_000,
259
+ supportsTools: true,
260
+ supportsStreaming: true,
261
+ supportsVision: true,
262
+ inputCostPerMtok: 3,
263
+ outputCostPerMtok: 15,
264
+ },
265
+ {
266
+ id: "claude-haiku-4-5",
267
+ provider: "anthropic",
268
+ contextWindow: 200_000,
269
+ supportsTools: true,
270
+ supportsStreaming: true,
271
+ supportsVision: true,
272
+ inputCostPerMtok: 0.8,
273
+ outputCostPerMtok: 4,
274
+ },
275
+ {
276
+ id: "claude-opus-4-6",
277
+ provider: "anthropic",
278
+ contextWindow: 200_000,
279
+ supportsTools: true,
280
+ supportsStreaming: true,
281
+ supportsVision: true,
282
+ inputCostPerMtok: 15,
283
+ outputCostPerMtok: 75,
284
+ },
285
+ ];
286
+ }
287
+ async healthCheck() {
288
+ return !!this.apiKey;
289
+ }
290
+ }
291
+ //# sourceMappingURL=anthropic.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"anthropic.js","sourceRoot":"","sources":["../../src/providers/anthropic.ts"],"names":[],"mappings":"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"}