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.
Files changed (226) hide show
  1. package/README.md +45 -45
  2. package/package.json +56 -42
  3. package/dist/agent/agent.d.ts +0 -43
  4. package/dist/agent/agent.js +0 -113
  5. package/dist/agent/tool-loop.d.ts +0 -64
  6. package/dist/agent/tool-loop.js +0 -575
  7. package/dist/agent/types.d.ts +0 -175
  8. package/dist/agent/types.js +0 -14
  9. package/dist/cli/main.d.ts +0 -11
  10. package/dist/cli/main.js +0 -23
  11. package/dist/cli/stdio-server.d.ts +0 -45
  12. package/dist/cli/stdio-server.js +0 -463
  13. package/dist/config/config.d.ts +0 -17
  14. package/dist/config/config.js +0 -21
  15. package/dist/contracts/hooks.d.ts +0 -120
  16. package/dist/contracts/hooks.js +0 -7
  17. package/dist/contracts/index.d.ts +0 -10
  18. package/dist/contracts/index.js +0 -10
  19. package/dist/contracts/planner.d.ts +0 -35
  20. package/dist/contracts/planner.js +0 -2
  21. package/dist/contracts/skill-candidate.d.ts +0 -63
  22. package/dist/contracts/skill-candidate.js +0 -195
  23. package/dist/contracts/todo.d.ts +0 -14
  24. package/dist/contracts/todo.js +0 -9
  25. package/dist/index.d.ts +0 -13
  26. package/dist/index.js +0 -15
  27. package/dist/llm/builtin-providers.d.ts +0 -10
  28. package/dist/llm/builtin-providers.js +0 -531
  29. package/dist/llm/index.d.ts +0 -15
  30. package/dist/llm/index.js +0 -14
  31. package/dist/llm/llm-client.d.ts +0 -43
  32. package/dist/llm/llm-client.js +0 -67
  33. package/dist/llm/model-catalog.d.ts +0 -53
  34. package/dist/llm/model-catalog.js +0 -191
  35. package/dist/llm/provider-def.d.ts +0 -59
  36. package/dist/llm/provider-def.js +0 -12
  37. package/dist/llm/provider-registry.d.ts +0 -54
  38. package/dist/llm/provider-registry.js +0 -147
  39. package/dist/llm/transport.d.ts +0 -62
  40. package/dist/llm/transport.js +0 -27
  41. package/dist/llm/transports/anthropic-messages.d.ts +0 -31
  42. package/dist/llm/transports/anthropic-messages.js +0 -293
  43. package/dist/llm/transports/openai-chat.d.ts +0 -36
  44. package/dist/llm/transports/openai-chat.js +0 -165
  45. package/dist/orchestration/agent-registry.d.ts +0 -41
  46. package/dist/orchestration/agent-registry.js +0 -116
  47. package/dist/orchestration/approval-aware-tool-plan.d.ts +0 -32
  48. package/dist/orchestration/approval-aware-tool-plan.js +0 -87
  49. package/dist/orchestration/context-compression.d.ts +0 -220
  50. package/dist/orchestration/context-compression.js +0 -583
  51. package/dist/orchestration/conversation-repair.d.ts +0 -61
  52. package/dist/orchestration/conversation-repair.js +0 -429
  53. package/dist/orchestration/curator-scheduler.d.ts +0 -119
  54. package/dist/orchestration/curator-scheduler.js +0 -135
  55. package/dist/orchestration/embedded-failover-policy.d.ts +0 -110
  56. package/dist/orchestration/embedded-failover-policy.js +0 -168
  57. package/dist/orchestration/error-classification.d.ts +0 -12
  58. package/dist/orchestration/error-classification.js +0 -77
  59. package/dist/orchestration/failover-classification.d.ts +0 -8
  60. package/dist/orchestration/failover-classification.js +0 -381
  61. package/dist/orchestration/failover-error.d.ts +0 -33
  62. package/dist/orchestration/failover-error.js +0 -198
  63. package/dist/orchestration/fork-subagent.d.ts +0 -100
  64. package/dist/orchestration/fork-subagent.js +0 -98
  65. package/dist/orchestration/index.d.ts +0 -120
  66. package/dist/orchestration/index.js +0 -267
  67. package/dist/orchestration/memory-flush-policy.d.ts +0 -57
  68. package/dist/orchestration/memory-flush-policy.js +0 -85
  69. package/dist/orchestration/memory-provider.d.ts +0 -14
  70. package/dist/orchestration/memory-provider.js +0 -2
  71. package/dist/orchestration/parallel-tool-calls.d.ts +0 -41
  72. package/dist/orchestration/parallel-tool-calls.js +0 -59
  73. package/dist/orchestration/prompt-cache-strategy.d.ts +0 -126
  74. package/dist/orchestration/prompt-cache-strategy.js +0 -228
  75. package/dist/orchestration/reactive-compact.d.ts +0 -73
  76. package/dist/orchestration/reactive-compact.js +0 -78
  77. package/dist/orchestration/retry-loop.d.ts +0 -22
  78. package/dist/orchestration/retry-loop.js +0 -24
  79. package/dist/orchestration/skill-candidate.d.ts +0 -52
  80. package/dist/orchestration/skill-candidate.js +0 -141
  81. package/dist/orchestration/skill-consolidation.d.ts +0 -123
  82. package/dist/orchestration/skill-consolidation.js +0 -220
  83. package/dist/orchestration/skill-improvement.d.ts +0 -59
  84. package/dist/orchestration/skill-improvement.js +0 -66
  85. package/dist/orchestration/skill-similarity.d.ts +0 -98
  86. package/dist/orchestration/skill-similarity.js +0 -131
  87. package/dist/orchestration/streaming-tool-executor.d.ts +0 -73
  88. package/dist/orchestration/streaming-tool-executor.js +0 -96
  89. package/dist/orchestration/team-orchestration.d.ts +0 -195
  90. package/dist/orchestration/team-orchestration.js +0 -369
  91. package/dist/orchestration/team-tool-loop-wiring.d.ts +0 -92
  92. package/dist/orchestration/team-tool-loop-wiring.js +0 -147
  93. package/dist/orchestration/tool-choice-policy.d.ts +0 -54
  94. package/dist/orchestration/tool-choice-policy.js +0 -164
  95. package/dist/orchestration/tool-loop-state.d.ts +0 -50
  96. package/dist/orchestration/tool-loop-state.js +0 -133
  97. package/dist/orchestration/tool-schema.d.ts +0 -39
  98. package/dist/orchestration/tool-schema.js +0 -297
  99. package/dist/orchestration/transcript-repair.d.ts +0 -42
  100. package/dist/orchestration/transcript-repair.js +0 -426
  101. package/dist/orchestration/turn-loop-guard.d.ts +0 -86
  102. package/dist/orchestration/turn-loop-guard.js +0 -92
  103. package/dist/orchestration/web-browser-policy.d.ts +0 -17
  104. package/dist/orchestration/web-browser-policy.js +0 -39
  105. package/dist/runtime/context-compression.d.ts +0 -61
  106. package/dist/runtime/context-compression.js +0 -274
  107. package/dist/runtime/hook-registry.d.ts +0 -12
  108. package/dist/runtime/hook-registry.js +0 -53
  109. package/dist/runtime/memory-hooks.d.ts +0 -23
  110. package/dist/runtime/memory-hooks.js +0 -65
  111. package/dist/runtime/tool-eligibility.d.ts +0 -59
  112. package/dist/runtime/tool-eligibility.js +0 -111
  113. package/dist/skills/index.d.ts +0 -108
  114. package/dist/skills/index.js +0 -82
  115. package/dist/skills/memory-extractor.d.ts +0 -64
  116. package/dist/skills/memory-extractor.js +0 -173
  117. package/dist/skills/memory-query-tool.d.ts +0 -43
  118. package/dist/skills/memory-query-tool.js +0 -127
  119. package/dist/skills/memory-store.d.ts +0 -66
  120. package/dist/skills/memory-store.js +0 -228
  121. package/dist/skills/memory-tool.d.ts +0 -67
  122. package/dist/skills/memory-tool.js +0 -192
  123. package/dist/skills/portable-tool.d.ts +0 -71
  124. package/dist/skills/portable-tool.js +0 -14
  125. package/dist/skills/qmemory-adapter.d.ts +0 -52
  126. package/dist/skills/qmemory-adapter.js +0 -165
  127. package/dist/skills/skill-frontmatter.d.ts +0 -19
  128. package/dist/skills/skill-frontmatter.js +0 -344
  129. package/dist/skills/skill-guard.d.ts +0 -23
  130. package/dist/skills/skill-guard.js +0 -229
  131. package/dist/skills/skill-loader.d.ts +0 -16
  132. package/dist/skills/skill-loader.js +0 -303
  133. package/dist/skills/skill-source.d.ts +0 -119
  134. package/dist/skills/skill-source.js +0 -126
  135. package/dist/skills/skill-types.d.ts +0 -199
  136. package/dist/skills/skill-types.js +0 -6
  137. package/dist/skills/think-tool.d.ts +0 -16
  138. package/dist/skills/think-tool.js +0 -59
  139. package/dist/skills/todo-tool.d.ts +0 -63
  140. package/dist/skills/todo-tool.js +0 -114
  141. package/dist/skills/tools/agent-tool.d.ts +0 -91
  142. package/dist/skills/tools/agent-tool.js +0 -142
  143. package/dist/skills/tools/apply-patch-tool.d.ts +0 -29
  144. package/dist/skills/tools/apply-patch-tool.js +0 -184
  145. package/dist/skills/tools/ask-user-tool.d.ts +0 -80
  146. package/dist/skills/tools/ask-user-tool.js +0 -121
  147. package/dist/skills/tools/brief-tool.d.ts +0 -74
  148. package/dist/skills/tools/brief-tool.js +0 -95
  149. package/dist/skills/tools/browser-tool.d.ts +0 -114
  150. package/dist/skills/tools/browser-tool.js +0 -155
  151. package/dist/skills/tools/checkpoint-tool.d.ts +0 -66
  152. package/dist/skills/tools/checkpoint-tool.js +0 -102
  153. package/dist/skills/tools/config-tool.d.ts +0 -63
  154. package/dist/skills/tools/config-tool.js +0 -143
  155. package/dist/skills/tools/cron-tool.d.ts +0 -116
  156. package/dist/skills/tools/cron-tool.js +0 -175
  157. package/dist/skills/tools/edit-tool.d.ts +0 -43
  158. package/dist/skills/tools/edit-tool.js +0 -70
  159. package/dist/skills/tools/exec-tool.d.ts +0 -102
  160. package/dist/skills/tools/exec-tool.js +0 -133
  161. package/dist/skills/tools/image-generate-tool.d.ts +0 -62
  162. package/dist/skills/tools/image-generate-tool.js +0 -67
  163. package/dist/skills/tools/instructions-tool.d.ts +0 -103
  164. package/dist/skills/tools/instructions-tool.js +0 -187
  165. package/dist/skills/tools/lsp-tool.d.ts +0 -153
  166. package/dist/skills/tools/lsp-tool.js +0 -227
  167. package/dist/skills/tools/mcp-client-types.d.ts +0 -269
  168. package/dist/skills/tools/mcp-client-types.js +0 -53
  169. package/dist/skills/tools/mcp-tool.d.ts +0 -249
  170. package/dist/skills/tools/mcp-tool.js +0 -503
  171. package/dist/skills/tools/memory-tool.d.ts +0 -74
  172. package/dist/skills/tools/memory-tool.js +0 -88
  173. package/dist/skills/tools/monitor-tool.d.ts +0 -113
  174. package/dist/skills/tools/monitor-tool.js +0 -131
  175. package/dist/skills/tools/music-generate-tool.d.ts +0 -55
  176. package/dist/skills/tools/music-generate-tool.js +0 -62
  177. package/dist/skills/tools/notify-tool.d.ts +0 -53
  178. package/dist/skills/tools/notify-tool.js +0 -62
  179. package/dist/skills/tools/patch-tool.d.ts +0 -45
  180. package/dist/skills/tools/patch-tool.js +0 -505
  181. package/dist/skills/tools/pdf-tool.d.ts +0 -66
  182. package/dist/skills/tools/pdf-tool.js +0 -88
  183. package/dist/skills/tools/plan-mode-tool.d.ts +0 -59
  184. package/dist/skills/tools/plan-mode-tool.js +0 -122
  185. package/dist/skills/tools/read-tool.d.ts +0 -51
  186. package/dist/skills/tools/read-tool.js +0 -84
  187. package/dist/skills/tools/repl-tool.d.ts +0 -70
  188. package/dist/skills/tools/repl-tool.js +0 -69
  189. package/dist/skills/tools/search-tool.d.ts +0 -112
  190. package/dist/skills/tools/search-tool.js +0 -225
  191. package/dist/skills/tools/send-message-tool.d.ts +0 -51
  192. package/dist/skills/tools/send-message-tool.js +0 -76
  193. package/dist/skills/tools/skill-list-tool.d.ts +0 -33
  194. package/dist/skills/tools/skill-list-tool.js +0 -54
  195. package/dist/skills/tools/skill-manage-tool.d.ts +0 -73
  196. package/dist/skills/tools/skill-manage-tool.js +0 -153
  197. package/dist/skills/tools/skill-view-tool.d.ts +0 -37
  198. package/dist/skills/tools/skill-view-tool.js +0 -72
  199. package/dist/skills/tools/sleep-tool.d.ts +0 -49
  200. package/dist/skills/tools/sleep-tool.js +0 -81
  201. package/dist/skills/tools/structured-output-tool.d.ts +0 -116
  202. package/dist/skills/tools/structured-output-tool.js +0 -176
  203. package/dist/skills/tools/task-tool.d.ts +0 -104
  204. package/dist/skills/tools/task-tool.js +0 -161
  205. package/dist/skills/tools/team-tool.d.ts +0 -89
  206. package/dist/skills/tools/team-tool.js +0 -105
  207. package/dist/skills/tools/tool-search-tool.d.ts +0 -51
  208. package/dist/skills/tools/tool-search-tool.js +0 -110
  209. package/dist/skills/tools/tts-tool.d.ts +0 -38
  210. package/dist/skills/tools/tts-tool.js +0 -45
  211. package/dist/skills/tools/video-edit-tool.d.ts +0 -69
  212. package/dist/skills/tools/video-edit-tool.js +0 -74
  213. package/dist/skills/tools/video-generate-tool.d.ts +0 -62
  214. package/dist/skills/tools/video-generate-tool.js +0 -66
  215. package/dist/skills/tools/video-merge-tool.d.ts +0 -105
  216. package/dist/skills/tools/video-merge-tool.js +0 -92
  217. package/dist/skills/tools/video-upscale-tool.d.ts +0 -45
  218. package/dist/skills/tools/video-upscale-tool.js +0 -52
  219. package/dist/skills/tools/web-fetch-tool.d.ts +0 -78
  220. package/dist/skills/tools/web-fetch-tool.js +0 -92
  221. package/dist/skills/tools/web-search-tool.d.ts +0 -57
  222. package/dist/skills/tools/web-search-tool.js +0 -86
  223. package/dist/skills/tools/worktree-tool.d.ts +0 -69
  224. package/dist/skills/tools/worktree-tool.js +0 -147
  225. package/dist/skills/tools/write-tool.d.ts +0 -45
  226. 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
- }
@@ -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
- }
@@ -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;
@@ -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
- }