qlogicagent 0.2.1 → 0.4.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.
- package/README.md +45 -45
- package/package.json +56 -42
- package/dist/agent/agent.d.ts +0 -43
- package/dist/agent/agent.js +0 -113
- package/dist/agent/tool-loop.d.ts +0 -64
- package/dist/agent/tool-loop.js +0 -575
- package/dist/agent/types.d.ts +0 -175
- package/dist/agent/types.js +0 -14
- package/dist/cli/main.d.ts +0 -11
- package/dist/cli/main.js +0 -23
- package/dist/cli/stdio-server.d.ts +0 -45
- package/dist/cli/stdio-server.js +0 -463
- package/dist/config/config.d.ts +0 -17
- package/dist/config/config.js +0 -21
- package/dist/contracts/hooks.d.ts +0 -120
- package/dist/contracts/hooks.js +0 -7
- package/dist/contracts/index.d.ts +0 -10
- package/dist/contracts/index.js +0 -10
- package/dist/contracts/planner.d.ts +0 -35
- package/dist/contracts/planner.js +0 -2
- package/dist/contracts/skill-candidate.d.ts +0 -63
- package/dist/contracts/skill-candidate.js +0 -195
- package/dist/contracts/todo.d.ts +0 -14
- package/dist/contracts/todo.js +0 -9
- package/dist/index.d.ts +0 -13
- package/dist/index.js +0 -15
- package/dist/llm/builtin-providers.d.ts +0 -10
- package/dist/llm/builtin-providers.js +0 -531
- package/dist/llm/index.d.ts +0 -15
- package/dist/llm/index.js +0 -14
- package/dist/llm/llm-client.d.ts +0 -43
- package/dist/llm/llm-client.js +0 -67
- package/dist/llm/model-catalog.d.ts +0 -53
- package/dist/llm/model-catalog.js +0 -191
- package/dist/llm/provider-def.d.ts +0 -59
- package/dist/llm/provider-def.js +0 -12
- package/dist/llm/provider-registry.d.ts +0 -54
- package/dist/llm/provider-registry.js +0 -147
- package/dist/llm/transport.d.ts +0 -62
- package/dist/llm/transport.js +0 -27
- package/dist/llm/transports/anthropic-messages.d.ts +0 -31
- package/dist/llm/transports/anthropic-messages.js +0 -293
- package/dist/llm/transports/openai-chat.d.ts +0 -36
- package/dist/llm/transports/openai-chat.js +0 -165
- package/dist/orchestration/agent-registry.d.ts +0 -41
- package/dist/orchestration/agent-registry.js +0 -116
- package/dist/orchestration/approval-aware-tool-plan.d.ts +0 -32
- package/dist/orchestration/approval-aware-tool-plan.js +0 -87
- package/dist/orchestration/context-compression.d.ts +0 -220
- package/dist/orchestration/context-compression.js +0 -583
- package/dist/orchestration/conversation-repair.d.ts +0 -61
- package/dist/orchestration/conversation-repair.js +0 -429
- package/dist/orchestration/curator-scheduler.d.ts +0 -119
- package/dist/orchestration/curator-scheduler.js +0 -135
- package/dist/orchestration/embedded-failover-policy.d.ts +0 -110
- package/dist/orchestration/embedded-failover-policy.js +0 -168
- package/dist/orchestration/error-classification.d.ts +0 -12
- package/dist/orchestration/error-classification.js +0 -77
- package/dist/orchestration/failover-classification.d.ts +0 -8
- package/dist/orchestration/failover-classification.js +0 -381
- package/dist/orchestration/failover-error.d.ts +0 -33
- package/dist/orchestration/failover-error.js +0 -198
- package/dist/orchestration/fork-subagent.d.ts +0 -100
- package/dist/orchestration/fork-subagent.js +0 -98
- package/dist/orchestration/index.d.ts +0 -120
- package/dist/orchestration/index.js +0 -267
- package/dist/orchestration/memory-flush-policy.d.ts +0 -57
- package/dist/orchestration/memory-flush-policy.js +0 -85
- package/dist/orchestration/memory-provider.d.ts +0 -14
- package/dist/orchestration/memory-provider.js +0 -2
- package/dist/orchestration/parallel-tool-calls.d.ts +0 -41
- package/dist/orchestration/parallel-tool-calls.js +0 -59
- package/dist/orchestration/prompt-cache-strategy.d.ts +0 -126
- package/dist/orchestration/prompt-cache-strategy.js +0 -228
- package/dist/orchestration/reactive-compact.d.ts +0 -73
- package/dist/orchestration/reactive-compact.js +0 -78
- package/dist/orchestration/retry-loop.d.ts +0 -22
- package/dist/orchestration/retry-loop.js +0 -24
- package/dist/orchestration/skill-candidate.d.ts +0 -52
- package/dist/orchestration/skill-candidate.js +0 -141
- package/dist/orchestration/skill-consolidation.d.ts +0 -123
- package/dist/orchestration/skill-consolidation.js +0 -220
- package/dist/orchestration/skill-improvement.d.ts +0 -59
- package/dist/orchestration/skill-improvement.js +0 -66
- package/dist/orchestration/skill-similarity.d.ts +0 -98
- package/dist/orchestration/skill-similarity.js +0 -131
- package/dist/orchestration/streaming-tool-executor.d.ts +0 -73
- package/dist/orchestration/streaming-tool-executor.js +0 -96
- package/dist/orchestration/team-orchestration.d.ts +0 -195
- package/dist/orchestration/team-orchestration.js +0 -369
- package/dist/orchestration/team-tool-loop-wiring.d.ts +0 -92
- package/dist/orchestration/team-tool-loop-wiring.js +0 -147
- package/dist/orchestration/tool-choice-policy.d.ts +0 -54
- package/dist/orchestration/tool-choice-policy.js +0 -164
- package/dist/orchestration/tool-loop-state.d.ts +0 -50
- package/dist/orchestration/tool-loop-state.js +0 -133
- package/dist/orchestration/tool-schema.d.ts +0 -39
- package/dist/orchestration/tool-schema.js +0 -297
- package/dist/orchestration/transcript-repair.d.ts +0 -42
- package/dist/orchestration/transcript-repair.js +0 -426
- package/dist/orchestration/turn-loop-guard.d.ts +0 -86
- package/dist/orchestration/turn-loop-guard.js +0 -92
- package/dist/orchestration/web-browser-policy.d.ts +0 -17
- package/dist/orchestration/web-browser-policy.js +0 -39
- package/dist/runtime/context-compression.d.ts +0 -61
- package/dist/runtime/context-compression.js +0 -274
- package/dist/runtime/hook-registry.d.ts +0 -12
- package/dist/runtime/hook-registry.js +0 -53
- package/dist/runtime/memory-hooks.d.ts +0 -23
- package/dist/runtime/memory-hooks.js +0 -65
- package/dist/runtime/tool-eligibility.d.ts +0 -59
- package/dist/runtime/tool-eligibility.js +0 -111
- package/dist/skills/index.d.ts +0 -108
- package/dist/skills/index.js +0 -82
- package/dist/skills/memory-extractor.d.ts +0 -64
- package/dist/skills/memory-extractor.js +0 -173
- package/dist/skills/memory-query-tool.d.ts +0 -43
- package/dist/skills/memory-query-tool.js +0 -127
- package/dist/skills/memory-store.d.ts +0 -66
- package/dist/skills/memory-store.js +0 -228
- package/dist/skills/memory-tool.d.ts +0 -67
- package/dist/skills/memory-tool.js +0 -192
- package/dist/skills/portable-tool.d.ts +0 -71
- package/dist/skills/portable-tool.js +0 -14
- package/dist/skills/qmemory-adapter.d.ts +0 -52
- package/dist/skills/qmemory-adapter.js +0 -165
- package/dist/skills/skill-frontmatter.d.ts +0 -19
- package/dist/skills/skill-frontmatter.js +0 -344
- package/dist/skills/skill-guard.d.ts +0 -23
- package/dist/skills/skill-guard.js +0 -229
- package/dist/skills/skill-loader.d.ts +0 -16
- package/dist/skills/skill-loader.js +0 -303
- package/dist/skills/skill-source.d.ts +0 -119
- package/dist/skills/skill-source.js +0 -126
- package/dist/skills/skill-types.d.ts +0 -199
- package/dist/skills/skill-types.js +0 -6
- package/dist/skills/think-tool.d.ts +0 -16
- package/dist/skills/think-tool.js +0 -59
- package/dist/skills/todo-tool.d.ts +0 -63
- package/dist/skills/todo-tool.js +0 -114
- package/dist/skills/tools/agent-tool.d.ts +0 -91
- package/dist/skills/tools/agent-tool.js +0 -142
- package/dist/skills/tools/apply-patch-tool.d.ts +0 -29
- package/dist/skills/tools/apply-patch-tool.js +0 -184
- package/dist/skills/tools/ask-user-tool.d.ts +0 -80
- package/dist/skills/tools/ask-user-tool.js +0 -121
- package/dist/skills/tools/brief-tool.d.ts +0 -74
- package/dist/skills/tools/brief-tool.js +0 -95
- package/dist/skills/tools/browser-tool.d.ts +0 -114
- package/dist/skills/tools/browser-tool.js +0 -155
- package/dist/skills/tools/checkpoint-tool.d.ts +0 -66
- package/dist/skills/tools/checkpoint-tool.js +0 -102
- package/dist/skills/tools/config-tool.d.ts +0 -63
- package/dist/skills/tools/config-tool.js +0 -143
- package/dist/skills/tools/cron-tool.d.ts +0 -116
- package/dist/skills/tools/cron-tool.js +0 -175
- package/dist/skills/tools/edit-tool.d.ts +0 -43
- package/dist/skills/tools/edit-tool.js +0 -70
- package/dist/skills/tools/exec-tool.d.ts +0 -102
- package/dist/skills/tools/exec-tool.js +0 -133
- package/dist/skills/tools/image-generate-tool.d.ts +0 -62
- package/dist/skills/tools/image-generate-tool.js +0 -67
- package/dist/skills/tools/instructions-tool.d.ts +0 -103
- package/dist/skills/tools/instructions-tool.js +0 -187
- package/dist/skills/tools/lsp-tool.d.ts +0 -153
- package/dist/skills/tools/lsp-tool.js +0 -227
- package/dist/skills/tools/mcp-client-types.d.ts +0 -269
- package/dist/skills/tools/mcp-client-types.js +0 -53
- package/dist/skills/tools/mcp-tool.d.ts +0 -249
- package/dist/skills/tools/mcp-tool.js +0 -503
- package/dist/skills/tools/memory-tool.d.ts +0 -74
- package/dist/skills/tools/memory-tool.js +0 -88
- package/dist/skills/tools/monitor-tool.d.ts +0 -113
- package/dist/skills/tools/monitor-tool.js +0 -131
- package/dist/skills/tools/music-generate-tool.d.ts +0 -55
- package/dist/skills/tools/music-generate-tool.js +0 -62
- package/dist/skills/tools/notify-tool.d.ts +0 -53
- package/dist/skills/tools/notify-tool.js +0 -62
- package/dist/skills/tools/patch-tool.d.ts +0 -45
- package/dist/skills/tools/patch-tool.js +0 -505
- package/dist/skills/tools/pdf-tool.d.ts +0 -66
- package/dist/skills/tools/pdf-tool.js +0 -88
- package/dist/skills/tools/plan-mode-tool.d.ts +0 -59
- package/dist/skills/tools/plan-mode-tool.js +0 -122
- package/dist/skills/tools/read-tool.d.ts +0 -51
- package/dist/skills/tools/read-tool.js +0 -84
- package/dist/skills/tools/repl-tool.d.ts +0 -70
- package/dist/skills/tools/repl-tool.js +0 -69
- package/dist/skills/tools/search-tool.d.ts +0 -112
- package/dist/skills/tools/search-tool.js +0 -225
- package/dist/skills/tools/send-message-tool.d.ts +0 -51
- package/dist/skills/tools/send-message-tool.js +0 -76
- package/dist/skills/tools/skill-list-tool.d.ts +0 -33
- package/dist/skills/tools/skill-list-tool.js +0 -54
- package/dist/skills/tools/skill-manage-tool.d.ts +0 -73
- package/dist/skills/tools/skill-manage-tool.js +0 -153
- package/dist/skills/tools/skill-view-tool.d.ts +0 -37
- package/dist/skills/tools/skill-view-tool.js +0 -72
- package/dist/skills/tools/sleep-tool.d.ts +0 -49
- package/dist/skills/tools/sleep-tool.js +0 -81
- package/dist/skills/tools/structured-output-tool.d.ts +0 -116
- package/dist/skills/tools/structured-output-tool.js +0 -176
- package/dist/skills/tools/task-tool.d.ts +0 -104
- package/dist/skills/tools/task-tool.js +0 -161
- package/dist/skills/tools/team-tool.d.ts +0 -89
- package/dist/skills/tools/team-tool.js +0 -105
- package/dist/skills/tools/tool-search-tool.d.ts +0 -51
- package/dist/skills/tools/tool-search-tool.js +0 -110
- package/dist/skills/tools/tts-tool.d.ts +0 -38
- package/dist/skills/tools/tts-tool.js +0 -45
- package/dist/skills/tools/video-edit-tool.d.ts +0 -69
- package/dist/skills/tools/video-edit-tool.js +0 -74
- package/dist/skills/tools/video-generate-tool.d.ts +0 -62
- package/dist/skills/tools/video-generate-tool.js +0 -66
- package/dist/skills/tools/video-merge-tool.d.ts +0 -105
- package/dist/skills/tools/video-merge-tool.js +0 -92
- package/dist/skills/tools/video-upscale-tool.d.ts +0 -45
- package/dist/skills/tools/video-upscale-tool.js +0 -52
- package/dist/skills/tools/web-fetch-tool.d.ts +0 -78
- package/dist/skills/tools/web-fetch-tool.js +0 -92
- package/dist/skills/tools/web-search-tool.d.ts +0 -57
- package/dist/skills/tools/web-search-tool.js +0 -86
- package/dist/skills/tools/worktree-tool.d.ts +0 -69
- package/dist/skills/tools/worktree-tool.js +0 -147
- package/dist/skills/tools/write-tool.d.ts +0 -45
- package/dist/skills/tools/write-tool.js +0 -81
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ModelCatalog — remote model directory with disk cache + fallback.
|
|
3
|
-
*
|
|
4
|
-
* Fetches model metadata from models.dev (open community catalog, 4000+ models).
|
|
5
|
-
* Aligned with Hermes agent/models_dev.py caching strategy.
|
|
6
|
-
*
|
|
7
|
-
* Three-layer fallback:
|
|
8
|
-
* 1. In-memory cache (process-level, TTL check against disk mtime)
|
|
9
|
-
* 2. Disk cache (~/.openclaw/cache/model_catalog.json)
|
|
10
|
-
* 3. Remote fetch (https://models.dev/api.json)
|
|
11
|
-
* 4. Stale disk cache (if remote fails)
|
|
12
|
-
* 5. Empty (caller falls back to builtin-providers.ts hardcoded)
|
|
13
|
-
*
|
|
14
|
-
* Non-blocking: first startup without cache returns empty immediately,
|
|
15
|
-
* triggers background async fetch. Agent uses builtin providers until
|
|
16
|
-
* catalog arrives.
|
|
17
|
-
*/
|
|
18
|
-
import type { ModelInfo } from "./provider-def.js";
|
|
19
|
-
export declare class ModelCatalog {
|
|
20
|
-
private cache;
|
|
21
|
-
private cacheDir;
|
|
22
|
-
private cacheFile;
|
|
23
|
-
private ttlMs;
|
|
24
|
-
private fetching;
|
|
25
|
-
private lastFetchAttempt;
|
|
26
|
-
constructor(opts?: {
|
|
27
|
-
cacheDir?: string;
|
|
28
|
-
ttlMs?: number;
|
|
29
|
-
});
|
|
30
|
-
/**
|
|
31
|
-
* Get models for a provider. Non-blocking: returns whatever is cached.
|
|
32
|
-
* Triggers background refresh if stale.
|
|
33
|
-
*/
|
|
34
|
-
getModels(providerId: string): ModelInfo[];
|
|
35
|
-
/**
|
|
36
|
-
* Get a single model by provider + model id.
|
|
37
|
-
*/
|
|
38
|
-
getModel(providerId: string, modelId: string): ModelInfo | undefined;
|
|
39
|
-
/**
|
|
40
|
-
* List all known provider ids from the catalog.
|
|
41
|
-
*/
|
|
42
|
-
listProviderIds(): string[];
|
|
43
|
-
/**
|
|
44
|
-
* Force refresh from remote. Returns true if successful.
|
|
45
|
-
*/
|
|
46
|
-
refreshCatalog(): Promise<boolean>;
|
|
47
|
-
private ensureLoaded;
|
|
48
|
-
private isStale;
|
|
49
|
-
private loadFromDisk;
|
|
50
|
-
private saveToDisk;
|
|
51
|
-
private backgroundFetch;
|
|
52
|
-
private fetchRemote;
|
|
53
|
-
}
|
|
@@ -1,191 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ModelCatalog — remote model directory with disk cache + fallback.
|
|
3
|
-
*
|
|
4
|
-
* Fetches model metadata from models.dev (open community catalog, 4000+ models).
|
|
5
|
-
* Aligned with Hermes agent/models_dev.py caching strategy.
|
|
6
|
-
*
|
|
7
|
-
* Three-layer fallback:
|
|
8
|
-
* 1. In-memory cache (process-level, TTL check against disk mtime)
|
|
9
|
-
* 2. Disk cache (~/.openclaw/cache/model_catalog.json)
|
|
10
|
-
* 3. Remote fetch (https://models.dev/api.json)
|
|
11
|
-
* 4. Stale disk cache (if remote fails)
|
|
12
|
-
* 5. Empty (caller falls back to builtin-providers.ts hardcoded)
|
|
13
|
-
*
|
|
14
|
-
* Non-blocking: first startup without cache returns empty immediately,
|
|
15
|
-
* triggers background async fetch. Agent uses builtin providers until
|
|
16
|
-
* catalog arrives.
|
|
17
|
-
*/
|
|
18
|
-
import { existsSync, mkdirSync, readFileSync, writeFileSync } from "node:fs";
|
|
19
|
-
import { join } from "node:path";
|
|
20
|
-
import { homedir } from "node:os";
|
|
21
|
-
// ── Constants ────────────────────────────────────────────────────────────────
|
|
22
|
-
const MODELS_DEV_URL = "https://models.dev/api.json";
|
|
23
|
-
const FETCH_TIMEOUT_MS = 15_000;
|
|
24
|
-
const DEFAULT_TTL_MS = 24 * 60 * 60 * 1000; // 24 hours
|
|
25
|
-
const RETRY_TTL_MS = 5 * 60 * 1000; // 5 min after failure
|
|
26
|
-
// ── ModelCatalog class ───────────────────────────────────────────────────────
|
|
27
|
-
export class ModelCatalog {
|
|
28
|
-
cache = null;
|
|
29
|
-
cacheDir;
|
|
30
|
-
cacheFile;
|
|
31
|
-
ttlMs;
|
|
32
|
-
fetching = false;
|
|
33
|
-
lastFetchAttempt = 0;
|
|
34
|
-
constructor(opts) {
|
|
35
|
-
this.cacheDir = opts?.cacheDir ?? join(homedir(), ".openclaw", "cache");
|
|
36
|
-
this.cacheFile = join(this.cacheDir, "model_catalog.json");
|
|
37
|
-
this.ttlMs = opts?.ttlMs ?? DEFAULT_TTL_MS;
|
|
38
|
-
}
|
|
39
|
-
/**
|
|
40
|
-
* Get models for a provider. Non-blocking: returns whatever is cached.
|
|
41
|
-
* Triggers background refresh if stale.
|
|
42
|
-
*/
|
|
43
|
-
getModels(providerId) {
|
|
44
|
-
this.ensureLoaded();
|
|
45
|
-
const provider = this.cache?.providers.get(providerId);
|
|
46
|
-
if (!provider)
|
|
47
|
-
return [];
|
|
48
|
-
return [...provider.models.values()];
|
|
49
|
-
}
|
|
50
|
-
/**
|
|
51
|
-
* Get a single model by provider + model id.
|
|
52
|
-
*/
|
|
53
|
-
getModel(providerId, modelId) {
|
|
54
|
-
this.ensureLoaded();
|
|
55
|
-
return this.cache?.providers.get(providerId)?.models.get(modelId);
|
|
56
|
-
}
|
|
57
|
-
/**
|
|
58
|
-
* List all known provider ids from the catalog.
|
|
59
|
-
*/
|
|
60
|
-
listProviderIds() {
|
|
61
|
-
this.ensureLoaded();
|
|
62
|
-
return this.cache ? [...this.cache.providers.keys()] : [];
|
|
63
|
-
}
|
|
64
|
-
/**
|
|
65
|
-
* Force refresh from remote. Returns true if successful.
|
|
66
|
-
*/
|
|
67
|
-
async refreshCatalog() {
|
|
68
|
-
return this.fetchRemote();
|
|
69
|
-
}
|
|
70
|
-
// ── Internal ──────────────────────────────────────────────────
|
|
71
|
-
ensureLoaded() {
|
|
72
|
-
if (this.cache && !this.isStale())
|
|
73
|
-
return;
|
|
74
|
-
// Try disk cache
|
|
75
|
-
if (!this.cache) {
|
|
76
|
-
this.loadFromDisk();
|
|
77
|
-
}
|
|
78
|
-
// Trigger background fetch if stale or missing
|
|
79
|
-
if (!this.cache || this.isStale()) {
|
|
80
|
-
this.backgroundFetch();
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
isStale() {
|
|
84
|
-
if (!this.cache)
|
|
85
|
-
return true;
|
|
86
|
-
return Date.now() - this.cache.fetchedAt > this.ttlMs;
|
|
87
|
-
}
|
|
88
|
-
loadFromDisk() {
|
|
89
|
-
try {
|
|
90
|
-
if (!existsSync(this.cacheFile))
|
|
91
|
-
return;
|
|
92
|
-
const raw = readFileSync(this.cacheFile, "utf8");
|
|
93
|
-
const parsed = JSON.parse(raw);
|
|
94
|
-
if (!parsed.fetchedAt || !parsed.data)
|
|
95
|
-
return;
|
|
96
|
-
this.cache = {
|
|
97
|
-
fetchedAt: parsed.fetchedAt,
|
|
98
|
-
providers: parseModelsDevResponse(parsed.data),
|
|
99
|
-
};
|
|
100
|
-
}
|
|
101
|
-
catch {
|
|
102
|
-
// Corrupted cache file — ignore
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
saveToDisk(data) {
|
|
106
|
-
try {
|
|
107
|
-
mkdirSync(this.cacheDir, { recursive: true });
|
|
108
|
-
const payload = JSON.stringify({ fetchedAt: Date.now(), data }, null, 0);
|
|
109
|
-
writeFileSync(this.cacheFile, payload, "utf8");
|
|
110
|
-
}
|
|
111
|
-
catch {
|
|
112
|
-
// Disk write failure — non-fatal
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
backgroundFetch() {
|
|
116
|
-
if (this.fetching)
|
|
117
|
-
return;
|
|
118
|
-
// Don't retry too soon after a failure
|
|
119
|
-
if (Date.now() - this.lastFetchAttempt < RETRY_TTL_MS)
|
|
120
|
-
return;
|
|
121
|
-
this.fetching = true;
|
|
122
|
-
this.fetchRemote().finally(() => {
|
|
123
|
-
this.fetching = false;
|
|
124
|
-
});
|
|
125
|
-
}
|
|
126
|
-
async fetchRemote() {
|
|
127
|
-
this.lastFetchAttempt = Date.now();
|
|
128
|
-
try {
|
|
129
|
-
const response = await fetch(MODELS_DEV_URL, {
|
|
130
|
-
signal: AbortSignal.timeout(FETCH_TIMEOUT_MS),
|
|
131
|
-
headers: { Accept: "application/json" },
|
|
132
|
-
});
|
|
133
|
-
if (!response.ok) {
|
|
134
|
-
return false;
|
|
135
|
-
}
|
|
136
|
-
const data = await response.json();
|
|
137
|
-
const providers = parseModelsDevResponse(data);
|
|
138
|
-
if (providers.size === 0) {
|
|
139
|
-
return false;
|
|
140
|
-
}
|
|
141
|
-
this.cache = { fetchedAt: Date.now(), providers };
|
|
142
|
-
this.saveToDisk(data);
|
|
143
|
-
return true;
|
|
144
|
-
}
|
|
145
|
-
catch {
|
|
146
|
-
// Network failure — keep stale cache if any
|
|
147
|
-
return false;
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
}
|
|
151
|
-
// ── Parser: models.dev JSON → CatalogProvider map ────────────────────────────
|
|
152
|
-
/**
|
|
153
|
-
* Parse models.dev api.json response.
|
|
154
|
-
* Format: { provider_id: { models: { model_name: { ... } } } }
|
|
155
|
-
*/
|
|
156
|
-
function parseModelsDevResponse(data) {
|
|
157
|
-
const providers = new Map();
|
|
158
|
-
if (!data || typeof data !== "object")
|
|
159
|
-
return providers;
|
|
160
|
-
for (const [providerId, providerData] of Object.entries(data)) {
|
|
161
|
-
if (!providerData || typeof providerData !== "object")
|
|
162
|
-
continue;
|
|
163
|
-
const modelsObj = providerData.models;
|
|
164
|
-
if (!modelsObj || typeof modelsObj !== "object")
|
|
165
|
-
continue;
|
|
166
|
-
const models = new Map();
|
|
167
|
-
for (const [modelId, modelData] of Object.entries(modelsObj)) {
|
|
168
|
-
if (!modelData || typeof modelData !== "object")
|
|
169
|
-
continue;
|
|
170
|
-
const m = modelData;
|
|
171
|
-
const limit = m.limit ?? {};
|
|
172
|
-
const modalities = m.modalities ?? {};
|
|
173
|
-
const inputMods = Array.isArray(modalities.input) ? modalities.input : [];
|
|
174
|
-
models.set(modelId, {
|
|
175
|
-
id: modelId,
|
|
176
|
-
name: typeof m.name === "string" ? m.name : modelId,
|
|
177
|
-
contextWindow: typeof limit.context === "number" ? limit.context : 200_000,
|
|
178
|
-
maxOutput: typeof limit.output === "number" ? limit.output : 8_192,
|
|
179
|
-
toolCall: m.tool_call === true,
|
|
180
|
-
reasoning: m.reasoning === true,
|
|
181
|
-
vision: m.attachment === true || inputMods.includes("image"),
|
|
182
|
-
costInput: typeof m.cost_input === "number" ? m.cost_input : undefined,
|
|
183
|
-
costOutput: typeof m.cost_output === "number" ? m.cost_output : undefined,
|
|
184
|
-
});
|
|
185
|
-
}
|
|
186
|
-
if (models.size > 0) {
|
|
187
|
-
providers.set(providerId, { models });
|
|
188
|
-
}
|
|
189
|
-
}
|
|
190
|
-
return providers;
|
|
191
|
-
}
|
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ProviderDef — defines how to connect to an LLM provider.
|
|
3
|
-
*
|
|
4
|
-
* Aligned with Hermes `ProviderDef` dataclass pattern:
|
|
5
|
-
* id + name + transport type + baseUrl + auth config + model list
|
|
6
|
-
*
|
|
7
|
-
* Three-layer merge strategy (Layer 3 > Layer 2 > Layer 1):
|
|
8
|
-
* Layer 1: builtin-providers.ts hardcoded (fallback)
|
|
9
|
-
* Layer 2: model-catalog.ts remote (models.dev)
|
|
10
|
-
* Layer 3: user config (from agent.turn.config)
|
|
11
|
-
*/
|
|
12
|
-
export type TransportType = "openai-chat" | "anthropic-messages";
|
|
13
|
-
export type AuthType = "bearer" | "x-api-key" | "none";
|
|
14
|
-
export interface ProviderDef {
|
|
15
|
-
/** Unique provider id, e.g. "deepseek", "openai", "anthropic" */
|
|
16
|
-
id: string;
|
|
17
|
-
/** Display name, e.g. "DeepSeek" */
|
|
18
|
-
name: string;
|
|
19
|
-
/** Which transport to use for LLM calls */
|
|
20
|
-
transport: TransportType;
|
|
21
|
-
/** API base URL, e.g. "https://api.deepseek.com" */
|
|
22
|
-
baseUrl: string;
|
|
23
|
-
/** Env var names for API key (priority order) */
|
|
24
|
-
apiKeyEnvVars: string[];
|
|
25
|
-
/** Auth header style */
|
|
26
|
-
authType: AuthType;
|
|
27
|
-
/** Is an aggregator (OpenRouter, 硅基) — model ids may have prefix */
|
|
28
|
-
isAggregator: boolean;
|
|
29
|
-
/** Recommended default model */
|
|
30
|
-
defaultModel?: string;
|
|
31
|
-
/** Known models for this provider */
|
|
32
|
-
models?: ModelInfo[];
|
|
33
|
-
/** Extra headers to send with every request (e.g. aggregator-specific) */
|
|
34
|
-
extraHeaders?: Record<string, string>;
|
|
35
|
-
/** Whether this provider supports stream_options (default true for openai-chat) */
|
|
36
|
-
supportsStreamOptions?: boolean;
|
|
37
|
-
/** Whether to omit temperature when it equals 0 (some providers reject 0) */
|
|
38
|
-
omitZeroTemperature?: boolean;
|
|
39
|
-
}
|
|
40
|
-
export interface ModelInfo {
|
|
41
|
-
/** Model id, e.g. "deepseek-chat" */
|
|
42
|
-
id: string;
|
|
43
|
-
/** Display name, e.g. "DeepSeek Chat V3" */
|
|
44
|
-
name: string;
|
|
45
|
-
/** Context window in tokens */
|
|
46
|
-
contextWindow: number;
|
|
47
|
-
/** Max output tokens */
|
|
48
|
-
maxOutput: number;
|
|
49
|
-
/** Supports function/tool calling */
|
|
50
|
-
toolCall: boolean;
|
|
51
|
-
/** Has reasoning/thinking mode */
|
|
52
|
-
reasoning: boolean;
|
|
53
|
-
/** Supports vision (image input) */
|
|
54
|
-
vision: boolean;
|
|
55
|
-
/** Cost per 1M input tokens (USD) */
|
|
56
|
-
costInput?: number;
|
|
57
|
-
/** Cost per 1M output tokens (USD) */
|
|
58
|
-
costOutput?: number;
|
|
59
|
-
}
|
package/dist/llm/provider-def.js
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ProviderDef — defines how to connect to an LLM provider.
|
|
3
|
-
*
|
|
4
|
-
* Aligned with Hermes `ProviderDef` dataclass pattern:
|
|
5
|
-
* id + name + transport type + baseUrl + auth config + model list
|
|
6
|
-
*
|
|
7
|
-
* Three-layer merge strategy (Layer 3 > Layer 2 > Layer 1):
|
|
8
|
-
* Layer 1: builtin-providers.ts hardcoded (fallback)
|
|
9
|
-
* Layer 2: model-catalog.ts remote (models.dev)
|
|
10
|
-
* Layer 3: user config (from agent.turn.config)
|
|
11
|
-
*/
|
|
12
|
-
export {};
|
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ProviderRegistry — three-layer merge registry for LLM providers.
|
|
3
|
-
*
|
|
4
|
-
* Layer 1: builtin-providers.ts hardcoded (lowest priority, ~20 providers)
|
|
5
|
-
* Layer 2: model-catalog.ts remote (models.dev — enriches model metadata)
|
|
6
|
-
* Layer 3: user config override (from agent.turn.config — highest priority)
|
|
7
|
-
*
|
|
8
|
-
* Merge strategy: Layer 3 > Layer 2 > Layer 1 (later layers override same-id fields)
|
|
9
|
-
*
|
|
10
|
-
* Aligned with Hermes provider_registry.py.
|
|
11
|
-
*/
|
|
12
|
-
import type { ModelInfo, ProviderDef } from "./provider-def.js";
|
|
13
|
-
import { ModelCatalog } from "./model-catalog.js";
|
|
14
|
-
export declare class ProviderRegistry {
|
|
15
|
-
/** Layer 1: builtin hardcoded providers */
|
|
16
|
-
private builtins;
|
|
17
|
-
/** Layer 2: remote model catalog (models.dev) */
|
|
18
|
-
private catalog;
|
|
19
|
-
/** Layer 3: user overrides (from agent.turn.config) */
|
|
20
|
-
private overrides;
|
|
21
|
-
constructor(opts?: {
|
|
22
|
-
catalog?: ModelCatalog;
|
|
23
|
-
});
|
|
24
|
-
/**
|
|
25
|
-
* Apply user config override for a provider.
|
|
26
|
-
* Typically called when agent.turn.config has baseUrl/apiKey overrides.
|
|
27
|
-
*/
|
|
28
|
-
applyOverride(providerId: string, override: Partial<ProviderDef>): void;
|
|
29
|
-
/**
|
|
30
|
-
* Get merged ProviderDef by id (Layer 3 > Layer 1).
|
|
31
|
-
* Returns undefined if provider not found.
|
|
32
|
-
* Supports common aliases (e.g., "claude" → "anthropic").
|
|
33
|
-
*/
|
|
34
|
-
getProvider(id: string): ProviderDef | undefined;
|
|
35
|
-
/**
|
|
36
|
-
* List all known provider ids.
|
|
37
|
-
*/
|
|
38
|
-
listProviders(): ProviderDef[];
|
|
39
|
-
/**
|
|
40
|
-
* List models for a specific provider.
|
|
41
|
-
* Merges: Layer 3 override > Layer 1 builtin > Layer 2 catalog enrichment.
|
|
42
|
-
*/
|
|
43
|
-
listModels(providerId: string): ModelInfo[];
|
|
44
|
-
/**
|
|
45
|
-
* Trigger background refresh of the remote model catalog.
|
|
46
|
-
*/
|
|
47
|
-
refreshCatalog(): Promise<boolean>;
|
|
48
|
-
/**
|
|
49
|
-
* Resolve API key for a provider:
|
|
50
|
-
* 1. Explicit key (from agent.turn.config)
|
|
51
|
-
* 2. Environment variables (ProviderDef.apiKeyEnvVars)
|
|
52
|
-
*/
|
|
53
|
-
resolveApiKey(providerId: string, explicitKey?: string): string | undefined;
|
|
54
|
-
}
|
|
@@ -1,147 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ProviderRegistry — three-layer merge registry for LLM providers.
|
|
3
|
-
*
|
|
4
|
-
* Layer 1: builtin-providers.ts hardcoded (lowest priority, ~20 providers)
|
|
5
|
-
* Layer 2: model-catalog.ts remote (models.dev — enriches model metadata)
|
|
6
|
-
* Layer 3: user config override (from agent.turn.config — highest priority)
|
|
7
|
-
*
|
|
8
|
-
* Merge strategy: Layer 3 > Layer 2 > Layer 1 (later layers override same-id fields)
|
|
9
|
-
*
|
|
10
|
-
* Aligned with Hermes provider_registry.py.
|
|
11
|
-
*/
|
|
12
|
-
import { BUILTIN_PROVIDERS } from "./builtin-providers.js";
|
|
13
|
-
import { ModelCatalog } from "./model-catalog.js";
|
|
14
|
-
// Provider alias map (Hermes-aligned): common user names → canonical ids
|
|
15
|
-
const PROVIDER_ALIASES = {
|
|
16
|
-
claude: "anthropic",
|
|
17
|
-
gemini: "google",
|
|
18
|
-
"x-ai": "xai",
|
|
19
|
-
"z-ai": "xai",
|
|
20
|
-
silicon: "siliconflow",
|
|
21
|
-
"silicon-flow": "siliconflow",
|
|
22
|
-
};
|
|
23
|
-
export class ProviderRegistry {
|
|
24
|
-
/** Layer 1: builtin hardcoded providers */
|
|
25
|
-
builtins = new Map();
|
|
26
|
-
/** Layer 2: remote model catalog (models.dev) */
|
|
27
|
-
catalog;
|
|
28
|
-
/** Layer 3: user overrides (from agent.turn.config) */
|
|
29
|
-
overrides = new Map();
|
|
30
|
-
constructor(opts) {
|
|
31
|
-
for (const p of BUILTIN_PROVIDERS) {
|
|
32
|
-
this.builtins.set(p.id, p);
|
|
33
|
-
}
|
|
34
|
-
this.catalog = opts?.catalog ?? new ModelCatalog();
|
|
35
|
-
}
|
|
36
|
-
/**
|
|
37
|
-
* Apply user config override for a provider.
|
|
38
|
-
* Typically called when agent.turn.config has baseUrl/apiKey overrides.
|
|
39
|
-
*/
|
|
40
|
-
applyOverride(providerId, override) {
|
|
41
|
-
this.overrides.set(providerId, {
|
|
42
|
-
...this.overrides.get(providerId),
|
|
43
|
-
...override,
|
|
44
|
-
});
|
|
45
|
-
}
|
|
46
|
-
/**
|
|
47
|
-
* Get merged ProviderDef by id (Layer 3 > Layer 1).
|
|
48
|
-
* Returns undefined if provider not found.
|
|
49
|
-
* Supports common aliases (e.g., "claude" → "anthropic").
|
|
50
|
-
*/
|
|
51
|
-
getProvider(id) {
|
|
52
|
-
const resolvedId = PROVIDER_ALIASES[id] ?? id;
|
|
53
|
-
const builtin = this.builtins.get(resolvedId);
|
|
54
|
-
const override = this.overrides.get(resolvedId);
|
|
55
|
-
if (!builtin && !override)
|
|
56
|
-
return undefined;
|
|
57
|
-
if (!builtin && override) {
|
|
58
|
-
// User defined a custom provider entirely
|
|
59
|
-
if (!override.id || !override.transport || !override.baseUrl) {
|
|
60
|
-
return undefined;
|
|
61
|
-
}
|
|
62
|
-
return {
|
|
63
|
-
id: override.id,
|
|
64
|
-
name: override.name ?? override.id,
|
|
65
|
-
transport: override.transport,
|
|
66
|
-
baseUrl: override.baseUrl,
|
|
67
|
-
apiKeyEnvVars: override.apiKeyEnvVars ?? [],
|
|
68
|
-
authType: override.authType ?? "bearer",
|
|
69
|
-
isAggregator: override.isAggregator ?? false,
|
|
70
|
-
defaultModel: override.defaultModel,
|
|
71
|
-
models: override.models,
|
|
72
|
-
};
|
|
73
|
-
}
|
|
74
|
-
if (builtin && !override)
|
|
75
|
-
return builtin;
|
|
76
|
-
// Merge: override fields take precedence
|
|
77
|
-
return {
|
|
78
|
-
...builtin,
|
|
79
|
-
...override,
|
|
80
|
-
// Merge models: override models replace if provided
|
|
81
|
-
models: override.models ?? builtin.models,
|
|
82
|
-
};
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* List all known provider ids.
|
|
86
|
-
*/
|
|
87
|
-
listProviders() {
|
|
88
|
-
const all = new Map();
|
|
89
|
-
for (const [id, p] of this.builtins) {
|
|
90
|
-
all.set(id, p);
|
|
91
|
-
}
|
|
92
|
-
// Override/custom providers
|
|
93
|
-
for (const [id] of this.overrides) {
|
|
94
|
-
const merged = this.getProvider(id);
|
|
95
|
-
if (merged)
|
|
96
|
-
all.set(id, merged);
|
|
97
|
-
}
|
|
98
|
-
return [...all.values()];
|
|
99
|
-
}
|
|
100
|
-
/**
|
|
101
|
-
* List models for a specific provider.
|
|
102
|
-
* Merges: Layer 3 override > Layer 1 builtin > Layer 2 catalog enrichment.
|
|
103
|
-
*/
|
|
104
|
-
listModels(providerId) {
|
|
105
|
-
const provider = this.getProvider(providerId);
|
|
106
|
-
const builtinModels = provider?.models ?? [];
|
|
107
|
-
// Enrich with catalog data (Layer 2): catalog provides updated context windows,
|
|
108
|
-
// costs, and capability flags; builtin models take precedence for known fields.
|
|
109
|
-
const catalogModels = this.catalog.getModels(providerId);
|
|
110
|
-
if (catalogModels.length === 0)
|
|
111
|
-
return builtinModels;
|
|
112
|
-
// Build merged model list: builtin first, then catalog models not in builtin
|
|
113
|
-
const byId = new Map();
|
|
114
|
-
for (const cm of catalogModels) {
|
|
115
|
-
byId.set(cm.id, cm);
|
|
116
|
-
}
|
|
117
|
-
for (const bm of builtinModels) {
|
|
118
|
-
// Builtin overrides catalog for same id (builtin has curated values)
|
|
119
|
-
byId.set(bm.id, bm);
|
|
120
|
-
}
|
|
121
|
-
return [...byId.values()];
|
|
122
|
-
}
|
|
123
|
-
/**
|
|
124
|
-
* Trigger background refresh of the remote model catalog.
|
|
125
|
-
*/
|
|
126
|
-
async refreshCatalog() {
|
|
127
|
-
return this.catalog.refreshCatalog();
|
|
128
|
-
}
|
|
129
|
-
/**
|
|
130
|
-
* Resolve API key for a provider:
|
|
131
|
-
* 1. Explicit key (from agent.turn.config)
|
|
132
|
-
* 2. Environment variables (ProviderDef.apiKeyEnvVars)
|
|
133
|
-
*/
|
|
134
|
-
resolveApiKey(providerId, explicitKey) {
|
|
135
|
-
if (explicitKey)
|
|
136
|
-
return explicitKey;
|
|
137
|
-
const provider = this.getProvider(providerId);
|
|
138
|
-
if (!provider)
|
|
139
|
-
return undefined;
|
|
140
|
-
for (const envVar of provider.apiKeyEnvVars) {
|
|
141
|
-
const value = process.env[envVar];
|
|
142
|
-
if (value?.trim())
|
|
143
|
-
return value.trim();
|
|
144
|
-
}
|
|
145
|
-
return undefined;
|
|
146
|
-
}
|
|
147
|
-
}
|
package/dist/llm/transport.d.ts
DELETED
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* LLMTransport — abstract interface for LLM inference calls.
|
|
3
|
-
*
|
|
4
|
-
* Aligned with Hermes `ProviderTransport` ABC:
|
|
5
|
-
* stream(request, apiKey, signal) → AsyncGenerator<LLMChunk>
|
|
6
|
-
*
|
|
7
|
-
* Two concrete implementations:
|
|
8
|
-
* - OpenAI Chat Completions (covers 95% of providers)
|
|
9
|
-
* - Anthropic Messages API
|
|
10
|
-
*/
|
|
11
|
-
import type { ChatMessage, ToolDefinition } from "../agent/types.js";
|
|
12
|
-
export interface LLMRequest {
|
|
13
|
-
model: string;
|
|
14
|
-
messages: ChatMessage[];
|
|
15
|
-
tools?: ToolDefinition[];
|
|
16
|
-
toolChoice?: "auto" | "none" | "required";
|
|
17
|
-
temperature?: number;
|
|
18
|
-
maxTokens?: number;
|
|
19
|
-
reasoning?: {
|
|
20
|
-
effort: "low" | "medium" | "high";
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
|
-
export type LLMChunk = {
|
|
24
|
-
type: "delta";
|
|
25
|
-
text: string;
|
|
26
|
-
} | {
|
|
27
|
-
type: "tool_call_delta";
|
|
28
|
-
index: number;
|
|
29
|
-
id?: string;
|
|
30
|
-
name?: string;
|
|
31
|
-
arguments: string;
|
|
32
|
-
} | {
|
|
33
|
-
type: "reasoning_delta";
|
|
34
|
-
text: string;
|
|
35
|
-
} | {
|
|
36
|
-
type: "usage";
|
|
37
|
-
promptTokens: number;
|
|
38
|
-
completionTokens: number;
|
|
39
|
-
reasoningTokens?: number;
|
|
40
|
-
} | {
|
|
41
|
-
type: "done";
|
|
42
|
-
finishReason: string;
|
|
43
|
-
};
|
|
44
|
-
export interface AccumulatedToolCall {
|
|
45
|
-
id: string;
|
|
46
|
-
name: string;
|
|
47
|
-
arguments: string;
|
|
48
|
-
}
|
|
49
|
-
export interface LLMTransport {
|
|
50
|
-
/**
|
|
51
|
-
* Stream an LLM inference request.
|
|
52
|
-
* apiKey is passed explicitly (from agent.turn.config, not env).
|
|
53
|
-
*/
|
|
54
|
-
stream(request: LLMRequest, apiKey: string, signal?: AbortSignal): AsyncGenerator<LLMChunk>;
|
|
55
|
-
}
|
|
56
|
-
/**
|
|
57
|
-
* Accumulate tool_call_delta chunks into complete ToolCall objects.
|
|
58
|
-
* Modeled after admin-infer-proxy-client's Map<index, toolCall> accumulator.
|
|
59
|
-
*/
|
|
60
|
-
export declare function accumulateToolCalls(accumulator: Map<number, AccumulatedToolCall>, chunk: LLMChunk & {
|
|
61
|
-
type: "tool_call_delta";
|
|
62
|
-
}): void;
|
package/dist/llm/transport.js
DELETED
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* LLMTransport — abstract interface for LLM inference calls.
|
|
3
|
-
*
|
|
4
|
-
* Aligned with Hermes `ProviderTransport` ABC:
|
|
5
|
-
* stream(request, apiKey, signal) → AsyncGenerator<LLMChunk>
|
|
6
|
-
*
|
|
7
|
-
* Two concrete implementations:
|
|
8
|
-
* - OpenAI Chat Completions (covers 95% of providers)
|
|
9
|
-
* - Anthropic Messages API
|
|
10
|
-
*/
|
|
11
|
-
// ── Convenience: aggregate chunks to tool calls ──────────────────────────────
|
|
12
|
-
/**
|
|
13
|
-
* Accumulate tool_call_delta chunks into complete ToolCall objects.
|
|
14
|
-
* Modeled after admin-infer-proxy-client's Map<index, toolCall> accumulator.
|
|
15
|
-
*/
|
|
16
|
-
export function accumulateToolCalls(accumulator, chunk) {
|
|
17
|
-
let tc = accumulator.get(chunk.index);
|
|
18
|
-
if (!tc) {
|
|
19
|
-
tc = { id: "", name: "", arguments: "" };
|
|
20
|
-
accumulator.set(chunk.index, tc);
|
|
21
|
-
}
|
|
22
|
-
if (chunk.id)
|
|
23
|
-
tc.id = chunk.id;
|
|
24
|
-
if (chunk.name)
|
|
25
|
-
tc.name += chunk.name;
|
|
26
|
-
tc.arguments += chunk.arguments;
|
|
27
|
-
}
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Anthropic Messages Transport — SSE streaming for Claude API.
|
|
3
|
-
*
|
|
4
|
-
* POST {baseUrl}/v1/messages with stream: true
|
|
5
|
-
* Auth: x-api-key: {apiKey} + anthropic-version header
|
|
6
|
-
*
|
|
7
|
-
* SSE event types:
|
|
8
|
-
* message_start, content_block_start, content_block_delta,
|
|
9
|
-
* content_block_stop, message_delta, message_stop
|
|
10
|
-
*
|
|
11
|
-
* Tool use is via content blocks with type "tool_use" + "input_json_delta".
|
|
12
|
-
*
|
|
13
|
-
* Aligned with Hermes anthropic_messages.py transport.
|
|
14
|
-
*/
|
|
15
|
-
import type { LLMChunk, LLMRequest, LLMTransport } from "../transport.js";
|
|
16
|
-
export interface AnthropicTransportConfig {
|
|
17
|
-
baseUrl: string;
|
|
18
|
-
/** anthropic-version header (default "2023-06-01") */
|
|
19
|
-
apiVersion?: string;
|
|
20
|
-
/** Timeout in ms (default 180_000) */
|
|
21
|
-
timeoutMs?: number;
|
|
22
|
-
}
|
|
23
|
-
export declare class AnthropicMessagesTransport implements LLMTransport {
|
|
24
|
-
private baseUrl;
|
|
25
|
-
private apiVersion;
|
|
26
|
-
private timeoutMs;
|
|
27
|
-
constructor(config: AnthropicTransportConfig);
|
|
28
|
-
stream(request: LLMRequest, apiKey: string, signal?: AbortSignal): AsyncGenerator<LLMChunk>;
|
|
29
|
-
private parseSSEStream;
|
|
30
|
-
private mapEvent;
|
|
31
|
-
}
|