@jsonstudio/rcc 0.89.1205 → 0.89.1348
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 +17 -0
- package/configsamples/config.json +426 -0
- package/configsamples/config.reference.json +58 -0
- package/configsamples/provider/crs/config.v1.json +46 -0
- package/configsamples/provider/glm/config.v1.json +81 -0
- package/configsamples/provider/glm-anthropic/config.v1.json +45 -0
- package/configsamples/provider/iflow/config.v1.json +74 -0
- package/configsamples/provider/kimi/config.v1.json +41 -0
- package/configsamples/provider/lmstudio/config.v1.json +101 -0
- package/configsamples/provider/mimo/config.v1.json +35 -0
- package/configsamples/provider/modelscope/config.v1.json +96 -0
- package/configsamples/provider/qwen/config.v1.json +38 -0
- package/configsamples/provider/tab/config.v1.json +50 -0
- package/configsamples/provider/tabglm/config.v1.json +49 -0
- package/dist/build-info.js +2 -2
- package/dist/cli/commands/code.js +12 -6
- package/dist/cli/commands/code.js.map +1 -1
- package/dist/cli/commands/config.d.ts +2 -1
- package/dist/cli/commands/config.js +74 -103
- package/dist/cli/commands/config.js.map +1 -1
- package/dist/cli/commands/examples.js +6 -6
- package/dist/cli/commands/examples.js.map +1 -1
- package/dist/cli/commands/init.d.ts +28 -0
- package/dist/cli/commands/init.js +91 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/port.js +10 -2
- package/dist/cli/commands/port.js.map +1 -1
- package/dist/cli/commands/restart.js +5 -2
- package/dist/cli/commands/restart.js.map +1 -1
- package/dist/cli/commands/start.js +25 -22
- package/dist/cli/commands/start.js.map +1 -1
- package/dist/cli/commands/status.js +1 -0
- package/dist/cli/commands/status.js.map +1 -1
- package/dist/cli/commands/stop.js +1 -0
- package/dist/cli/commands/stop.js.map +1 -1
- package/dist/cli/config/bundled-docs.d.ts +20 -0
- package/dist/cli/config/bundled-docs.js +91 -0
- package/dist/cli/config/bundled-docs.js.map +1 -0
- package/dist/cli/config/init-config.d.ts +36 -0
- package/dist/cli/config/init-config.js +180 -0
- package/dist/cli/config/init-config.js.map +1 -0
- package/dist/cli/config/init-provider-catalog.d.ts +8 -0
- package/dist/cli/config/init-provider-catalog.js +187 -0
- package/dist/cli/config/init-provider-catalog.js.map +1 -0
- package/dist/cli/register/init-command.d.ts +3 -0
- package/dist/cli/register/init-command.js +5 -0
- package/dist/cli/register/init-command.js.map +1 -0
- package/dist/cli.js +28 -3
- package/dist/cli.js.map +1 -1
- package/dist/client/gemini-cli/gemini-cli-protocol-client.js +1 -1
- package/dist/client/gemini-cli/gemini-cli-protocol-client.js.map +1 -1
- package/dist/config/risk-control-config.d.ts +94 -0
- package/dist/config/risk-control-config.js +196 -0
- package/dist/config/risk-control-config.js.map +1 -0
- package/dist/constants/index.d.ts +6 -0
- package/dist/constants/index.js +13 -0
- package/dist/constants/index.js.map +1 -1
- package/dist/docs/daemon-admin-ui.html +2113 -190
- package/dist/index.js +0 -1
- package/dist/index.js.map +1 -1
- package/dist/manager/modules/health/index.d.ts +1 -1
- package/dist/manager/modules/quota/antigravity-quota-manager.d.ts +70 -0
- package/dist/manager/modules/quota/antigravity-quota-manager.js +442 -0
- package/dist/manager/modules/quota/antigravity-quota-manager.js.map +1 -0
- package/dist/manager/modules/quota/index.d.ts +3 -127
- package/dist/manager/modules/quota/index.js +2 -1093
- package/dist/manager/modules/quota/index.js.map +1 -1
- package/dist/manager/modules/quota/provider-key-normalization.d.ts +3 -0
- package/dist/manager/modules/quota/provider-key-normalization.js +155 -0
- package/dist/manager/modules/quota/provider-key-normalization.js.map +1 -0
- package/dist/manager/modules/quota/provider-quota-daemon.cooldown.d.ts +9 -0
- package/dist/manager/modules/quota/provider-quota-daemon.cooldown.js +115 -0
- package/dist/manager/modules/quota/provider-quota-daemon.cooldown.js.map +1 -0
- package/dist/manager/modules/quota/provider-quota-daemon.d.ts +77 -0
- package/dist/manager/modules/quota/provider-quota-daemon.events.d.ts +12 -0
- package/dist/manager/modules/quota/provider-quota-daemon.events.js +237 -0
- package/dist/manager/modules/quota/provider-quota-daemon.events.js.map +1 -0
- package/dist/manager/modules/quota/provider-quota-daemon.js +404 -0
- package/dist/manager/modules/quota/provider-quota-daemon.js.map +1 -0
- package/dist/manager/modules/quota/provider-quota-daemon.model-backoff.d.ts +11 -0
- package/dist/manager/modules/quota/provider-quota-daemon.model-backoff.js +189 -0
- package/dist/manager/modules/quota/provider-quota-daemon.model-backoff.js.map +1 -0
- package/dist/manager/modules/quota/provider-quota-daemon.snapshot.d.ts +8 -0
- package/dist/manager/modules/quota/provider-quota-daemon.snapshot.js +96 -0
- package/dist/manager/modules/quota/provider-quota-daemon.snapshot.js.map +1 -0
- package/dist/manager/modules/quota/provider-quota-daemon.view.d.ts +19 -0
- package/dist/manager/modules/quota/provider-quota-daemon.view.js +37 -0
- package/dist/manager/modules/quota/provider-quota-daemon.view.js.map +1 -0
- package/dist/manager/modules/routing/index.d.ts +1 -0
- package/dist/manager/modules/routing/index.js +11 -25
- package/dist/manager/modules/routing/index.js.map +1 -1
- package/dist/manager/quota/provider-quota-center.d.ts +2 -0
- package/dist/manager/quota/provider-quota-center.js +80 -82
- package/dist/manager/quota/provider-quota-center.js.map +1 -1
- package/dist/modules/llmswitch/bridge.d.ts +16 -18
- package/dist/modules/llmswitch/bridge.js +293 -94
- package/dist/modules/llmswitch/bridge.js.map +1 -1
- package/dist/modules/llmswitch/core-loader.d.ts +4 -2
- package/dist/modules/llmswitch/core-loader.js +32 -20
- package/dist/modules/llmswitch/core-loader.js.map +1 -1
- package/dist/modules/pipeline/utils/colored-logger.js +3 -2
- package/dist/modules/pipeline/utils/colored-logger.js.map +1 -1
- package/dist/modules/pipeline/utils/debug-logger.js +1 -1
- package/dist/modules/pipeline/utils/debug-logger.js.map +1 -1
- package/dist/providers/auth/iflow-cookie-auth.js +0 -2
- package/dist/providers/auth/iflow-cookie-auth.js.map +1 -1
- package/dist/providers/auth/oauth-lifecycle.js +2 -23
- package/dist/providers/auth/oauth-lifecycle.js.map +1 -1
- package/dist/providers/core/config/camoufox-launcher.js +35 -4
- package/dist/providers/core/config/camoufox-launcher.js.map +1 -1
- package/dist/providers/core/runtime/antigravity-quota-client.js +6 -3
- package/dist/providers/core/runtime/antigravity-quota-client.js.map +1 -1
- package/dist/providers/core/runtime/base-provider.d.ts +2 -2
- package/dist/providers/core/runtime/base-provider.js +74 -69
- package/dist/providers/core/runtime/base-provider.js.map +1 -1
- package/dist/providers/core/runtime/gemini-cli-http-provider.js +6 -4
- package/dist/providers/core/runtime/gemini-cli-http-provider.js.map +1 -1
- package/dist/providers/core/runtime/http-request-executor.js +2 -2
- package/dist/providers/core/runtime/http-request-executor.js.map +1 -1
- package/dist/providers/core/runtime/http-transport-provider.d.ts +14 -0
- package/dist/providers/core/runtime/http-transport-provider.js +111 -5
- package/dist/providers/core/runtime/http-transport-provider.js.map +1 -1
- package/dist/providers/core/runtime/provider-error-classifier.js +10 -0
- package/dist/providers/core/runtime/provider-error-classifier.js.map +1 -1
- package/dist/providers/core/runtime/provider-factory.js +7 -5
- package/dist/providers/core/runtime/provider-factory.js.map +1 -1
- package/dist/providers/core/runtime/provider-runtime-metadata.d.ts +6 -0
- package/dist/providers/core/runtime/provider-runtime-metadata.js.map +1 -1
- package/dist/providers/core/runtime/responses-provider.d.ts +1 -7
- package/dist/providers/core/runtime/responses-provider.js +12 -93
- package/dist/providers/core/runtime/responses-provider.js.map +1 -1
- package/dist/providers/core/strategies/oauth-auth-code-flow.js +12 -8
- package/dist/providers/core/strategies/oauth-auth-code-flow.js.map +1 -1
- package/dist/providers/core/utils/http-client.js +16 -3
- package/dist/providers/core/utils/http-client.js.map +1 -1
- package/dist/providers/core/utils/provider-error-logger.d.ts +1 -1
- package/dist/providers/core/utils/provider-error-reporter.d.ts +3 -1
- package/dist/providers/core/utils/provider-error-reporter.js +3 -0
- package/dist/providers/core/utils/provider-error-reporter.js.map +1 -1
- package/dist/providers/core/utils/snapshot-writer.js +1 -4
- package/dist/providers/core/utils/snapshot-writer.js.map +1 -1
- package/dist/providers/mock/mock-provider-runtime.js +57 -27
- package/dist/providers/mock/mock-provider-runtime.js.map +1 -1
- package/dist/scripts/camoufox/launch-auth.mjs +193 -58
- package/dist/server/handlers/handler-utils.js +3 -2
- package/dist/server/handlers/handler-utils.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/auth-handler.d.ts +2 -0
- package/dist/server/runtime/http-server/daemon-admin/auth-handler.js +103 -0
- package/dist/server/runtime/http-server/daemon-admin/auth-handler.js.map +1 -0
- package/dist/server/runtime/http-server/daemon-admin/auth-session.d.ts +5 -0
- package/dist/server/runtime/http-server/daemon-admin/auth-session.js +77 -0
- package/dist/server/runtime/http-server/daemon-admin/auth-session.js.map +1 -0
- package/dist/server/runtime/http-server/daemon-admin/auth-store.d.ts +18 -0
- package/dist/server/runtime/http-server/daemon-admin/auth-store.js +89 -0
- package/dist/server/runtime/http-server/daemon-admin/auth-store.js.map +1 -0
- package/dist/server/runtime/http-server/daemon-admin/credentials-handler.js +1 -2
- package/dist/server/runtime/http-server/daemon-admin/credentials-handler.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/providers-handler.js +226 -24
- package/dist/server/runtime/http-server/daemon-admin/providers-handler.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/quota-handler.js +47 -8
- package/dist/server/runtime/http-server/daemon-admin/quota-handler.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/restart-handler.js +1 -1
- package/dist/server/runtime/http-server/daemon-admin/restart-handler.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/stats-handler.js +1 -1
- package/dist/server/runtime/http-server/daemon-admin/stats-handler.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/status-handler.js +68 -4
- package/dist/server/runtime/http-server/daemon-admin/status-handler.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin-routes.d.ts +3 -4
- package/dist/server/runtime/http-server/daemon-admin-routes.js +9 -14
- package/dist/server/runtime/http-server/daemon-admin-routes.js.map +1 -1
- package/dist/server/runtime/http-server/executor-metadata.js +1 -1
- package/dist/server/runtime/http-server/executor-metadata.js.map +1 -1
- package/dist/server/runtime/http-server/executor-response.js +0 -16
- package/dist/server/runtime/http-server/executor-response.js.map +1 -1
- package/dist/server/runtime/http-server/hub-shadow-compare.js +110 -34
- package/dist/server/runtime/http-server/hub-shadow-compare.js.map +1 -1
- package/dist/server/runtime/http-server/index.d.ts +5 -3
- package/dist/server/runtime/http-server/index.js +215 -109
- package/dist/server/runtime/http-server/index.js.map +1 -1
- package/dist/server/runtime/http-server/middleware.js +19 -1
- package/dist/server/runtime/http-server/middleware.js.map +1 -1
- package/dist/server/runtime/http-server/request-executor.js +10 -19
- package/dist/server/runtime/http-server/request-executor.js.map +1 -1
- package/dist/server/runtime/http-server/routes.js +8 -2
- package/dist/server/runtime/http-server/routes.js.map +1 -1
- package/dist/server/runtime/http-server/session-dir.d.ts +2 -0
- package/dist/server/runtime/http-server/session-dir.js +59 -0
- package/dist/server/runtime/http-server/session-dir.js.map +1 -0
- package/dist/server/runtime/http-server/types.d.ts +0 -4
- package/dist/server/utils/utf8-chunk-buffer.js +6 -3
- package/dist/server/utils/utf8-chunk-buffer.js.map +1 -1
- package/dist/server/utils/warmup-storm-tracker.js +1 -1
- package/dist/server/utils/warmup-storm-tracker.js.map +1 -1
- package/dist/server-factory.d.ts +6 -28
- package/dist/server-factory.js +8 -93
- package/dist/server-factory.js.map +1 -1
- package/dist/token-daemon/index.js +2 -2
- package/dist/token-daemon/index.js.map +1 -1
- package/dist/token-daemon/provider-registry.js +0 -1
- package/dist/token-daemon/provider-registry.js.map +1 -1
- package/dist/token-daemon/server-utils.js +8 -9
- package/dist/token-daemon/server-utils.js.map +1 -1
- package/dist/token-daemon/token-utils.js +1 -1
- package/dist/token-daemon/token-utils.js.map +1 -1
- package/dist/tools/semantic-replay.js +2 -2
- package/dist/tools/semantic-replay.js.map +1 -1
- package/dist/tools/stats-request-events.d.ts +1 -1
- package/dist/tools/stats-usage.js +6 -3
- package/dist/tools/stats-usage.js.map +1 -1
- package/dist/utils/llms-engine-shadow.d.ts +19 -0
- package/dist/utils/llms-engine-shadow.js +209 -0
- package/dist/utils/llms-engine-shadow.js.map +1 -0
- package/dist/utils/runtime-versions.js +2 -1
- package/dist/utils/runtime-versions.js.map +1 -1
- package/docs/ARCHITECTURE.md +402 -0
- package/docs/CODEX_AND_CLAUDE_CODE.md +69 -0
- package/docs/CONFIG_ARCHITECTURE.md +517 -0
- package/docs/ERROR_HANDLING_AUDIT.md +0 -0
- package/docs/GCLI2API_PARITY_GAPS.md +98 -0
- package/docs/INSTALLATION_AND_QUICKSTART.md +74 -0
- package/docs/INSTRUCTION_MARKUP.md +89 -0
- package/docs/MODULE_ENHANCEMENT_SYSTEM.md +666 -0
- package/docs/PORTS.md +36 -0
- package/docs/PROVIDERS_BUILTIN.md +111 -0
- package/docs/PROVIDER_TYPES.md +55 -0
- package/docs/SERVERTOOL_CLOCK_DESIGN.md +233 -0
- package/docs/USAGE_HANDLING_ANALYSIS.md +335 -0
- package/docs/USER_CONFIG_PARSER_CHANGES.md +175 -0
- package/docs/V3_INBOUND_OUTBOUND_DESIGN.md +86 -0
- package/docs/VIRTUAL_ROUTER_PRIORITY_AND_HEALTH.md +125 -0
- package/docs/anthropic-request-golden-samples.md +50 -0
- package/docs/ccr-alignment-enhancetool.md +105 -0
- package/docs/chat-glm-500-analysis.md +79 -0
- package/docs/chat-request-golden-samples.md +42 -0
- package/docs/chat-semantic-expansion-plan.md +82 -0
- package/docs/cli-command-inventory.md +76 -0
- package/docs/codex-samples-replay.md +50 -0
- package/docs/daemon-admin-api-design.md +350 -0
- package/docs/daemon-admin-module-structure.md +169 -0
- package/docs/daemon-admin-ui.html +3394 -0
- package/docs/debug-system-design.md +734 -0
- package/docs/debugging/gemini-sse-root-cause.md +52 -0
- package/docs/debugging/sse_encoding_failure_analysis.md +53 -0
- package/docs/dry-run/README.md +721 -0
- package/docs/error-handling-v2.md +92 -0
- package/docs/exec-command-guard-policy.example.v1.json +42 -0
- package/docs/fixes/gemini-protocol-mapping.md +57 -0
- package/docs/fixes/oauth-portal-timing-fix.md +202 -0
- package/docs/fixes/web-search-hop3-fix.md +265 -0
- package/docs/glm-api-reference.md +390 -0
- package/docs/glm-chat-completions.md +1779 -0
- package/docs/glm-history-inline-images.md +44 -0
- package/docs/golden-ci-library.md +66 -0
- package/docs/lmstudio-dry-run-summary.md +203 -0
- package/docs/lmstudio-tool-calling.md +214 -0
- package/docs/mapping-tables/anthropic-to-openai.json +290 -0
- package/docs/mapping-tables/iflow-to-openai.json +215 -0
- package/docs/mapping-tables/openai-passthrough.json +190 -0
- package/docs/mapping-tables/openai-to-iflow.json +227 -0
- package/docs/monitoring/Design.md +61 -0
- package/docs/multi-token-auth-guide.md +66 -0
- package/docs/oauth-authentication-guide.md +168 -0
- package/docs/oauth-iflow-implementation.md +153 -0
- package/docs/pipeline-routing-report.md +209 -0
- package/docs/plans/manager-daemon/PLAN.md +86 -0
- package/docs/plans/provider-config-v2-plan.md +176 -0
- package/docs/plans/provider-runtime-manager-plan.md +209 -0
- package/docs/plans/transparent-429-failover.md +89 -0
- package/docs/plans/unified-hub-framework-v1.md +245 -0
- package/docs/provider-config-v2-ui-design.md +181 -0
- package/docs/provider-quota-design.md +129 -0
- package/docs/providers/gemini-provider.md +62 -0
- package/docs/providers/lmstudio-v2-migration-report.md +102 -0
- package/docs/providers/provider-composite-design.md +142 -0
- package/docs/providers/provider-composite-testing.md +98 -0
- package/docs/providers/provider-type-only-migration.md +111 -0
- package/docs/rccx-wasm-migration.md +74 -0
- package/docs/refactoring/architecture-comparison-diagram.md +140 -0
- package/docs/refactoring/compatibility-v2-architecture-design.md +738 -0
- package/docs/refactoring/workflow-compatibility-refactoring-design.md +361 -0
- package/docs/reports/routing-classification-report.json +24 -0
- package/docs/reports/routing-classification-report.md +18 -0
- package/docs/reports/thinking-keywords-report.json +19 -0
- package/docs/responses/README.md +156 -0
- package/docs/responses-generic-provider.md +86 -0
- package/docs/responses-passthrough-provider-design.md +202 -0
- package/docs/routing-awrr-health-weighted-round-robin.md +179 -0
- package/docs/routing-instructions.md +393 -0
- package/docs/stop-message-auto.md +225 -0
- package/docs/streaming-flow.html +30 -0
- package/docs/streaming-flow.md +182 -0
- package/docs/token-daemon-preview.html +490 -0
- package/docs/token-refresh-daemon-plan.md +269 -0
- package/docs/transformation-tables/Gemini-FinishReason/345/256/214/346/225/264/350/275/254/346/215/242/350/241/250.json +233 -0
- package/docs/transformation-tables/README.md +225 -0
- package/docs/transformation-tables/claude-code-router-anthropic-to-gemini.json +283 -0
- package/docs/transformation-tables/claude-code-router-anthropic-to-openai.json +208 -0
- package/docs/transformation-tables/claude-code-router-openai-to-anthropic.json +261 -0
- package/docs/transformation-tables/claude-code-router-openai-to-gemini.json +208 -0
- package/docs/transformation-tables/claude-code-router-openai-to-lmstudio.json +182 -0
- package/docs/transformation-tables/claude-code-router-openai-to-ollama.json +250 -0
- package/docs/transformation-tables/claude-code-router-openai-to-textgenwebui.json +295 -0
- package/docs/transformation-tables/claude-code-router-provider-conversions.json +193 -0
- package/docs/transformation-tables//345/256/214/346/225/264/347/232/204/345/267/245/345/205/267/346/211/247/350/241/214/346/265/201/347/250/213/350/275/254/346/215/242/350/241/250.json +299 -0
- package/docs/transformation-tables//345/257/271/350/257/235/345/216/206/345/217/262/347/273/264/346/212/244/345/210/206/346/236/220.md +134 -0
- package/docs/transformation-tables//345/267/245/345/205/267/350/260/203/347/224/250/346/250/241/345/274/217/345/210/206/346/236/220.md +158 -0
- package/docs/transformation-tables//347/212/266/346/200/201/347/256/241/347/220/206/351/234/200/346/261/202/345/210/206/346/236/220.md +175 -0
- package/docs/transformation-tables//351/235/231/346/200/201/350/241/250vs/345/212/250/346/200/201/345/210/206/346/236/220.md +189 -0
- package/docs/transformation-tables//351/235/231/346/200/201/350/241/250/345/207/206/347/241/256/346/200/247/350/257/204/344/274/260.md +179 -0
- package/docs/transformation-tables//351/235/236/346/265/201/345/274/217/345/234/272/346/231/257/345/210/206/346/236/220.md +189 -0
- package/docs/v2-architecture/IMPLEMENTATION-ROADMAP.md +367 -0
- package/docs/v2-architecture/OPTIMIZED-DESIGN.md +827 -0
- package/docs/v2-architecture/PRERUN-CONNECTION-DESIGN.md +716 -0
- package/docs/v2-architecture/README.md +551 -0
- package/docs/verification/modelscope-verify.md +59 -0
- package/docs/web-search-service-design.md +322 -0
- package/package.json +12 -7
- package/scripts/camoufox/launch-auth.mjs +193 -58
- package/scripts/monitor-diff.mjs +126 -0
- package/scripts/pack-mode.mjs +19 -1
- package/scripts/pack-rcc.mjs +63 -0
- package/scripts/unified-hub-shadow-compare.mjs +33 -13
- package/scripts/verify-e2e-toolcall.mjs +115 -26
- package/dist/modules/llmswitch/pipeline-registry.d.ts +0 -57
- package/dist/modules/llmswitch/pipeline-registry.js +0 -229
- package/dist/modules/llmswitch/pipeline-registry.js.map +0 -1
- package/dist/server/RouteCodexServer.d.ts +0 -13
- package/dist/server/RouteCodexServer.js +0 -25
- package/dist/server/RouteCodexServer.js.map +0 -1
- package/dist/v2/conversion/hub/snapshot-recorder.d.ts +0 -12
- package/dist/v2/conversion/hub/snapshot-recorder.js +0 -22
- package/dist/v2/conversion/hub/snapshot-recorder.js.map +0 -1
|
@@ -0,0 +1,299 @@
|
|
|
1
|
+
{
|
|
2
|
+
"sourceProvider": "Anthropic",
|
|
3
|
+
"targetProvider": "OpenAI",
|
|
4
|
+
"description": "完整的工具执行流程转换表",
|
|
5
|
+
"version": "1.0",
|
|
6
|
+
"focus": "工具执行生命周期和结果处理",
|
|
7
|
+
|
|
8
|
+
"toolExecutionLifecycle": {
|
|
9
|
+
"detection": {
|
|
10
|
+
"source": {
|
|
11
|
+
"condition": "LLM decides to use tool",
|
|
12
|
+
"response": {
|
|
13
|
+
"type": "tool_use",
|
|
14
|
+
"id": "string",
|
|
15
|
+
"name": "string",
|
|
16
|
+
"input": "object"
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
"target": {
|
|
20
|
+
"condition": "LLM decides to use tool",
|
|
21
|
+
"response": {
|
|
22
|
+
"tool_calls": [
|
|
23
|
+
{
|
|
24
|
+
"id": "string",
|
|
25
|
+
"type": "function",
|
|
26
|
+
"function": {
|
|
27
|
+
"name": "string",
|
|
28
|
+
"arguments": "string"
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
]
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
},
|
|
35
|
+
|
|
36
|
+
"execution": {
|
|
37
|
+
"clientAction": "客户端执行工具",
|
|
38
|
+
"resultFormat": {
|
|
39
|
+
"anthropic": {
|
|
40
|
+
"role": "user",
|
|
41
|
+
"content": [
|
|
42
|
+
{
|
|
43
|
+
"type": "tool_result",
|
|
44
|
+
"tool_use_id": "string",
|
|
45
|
+
"content": "工具执行结果"
|
|
46
|
+
}
|
|
47
|
+
]
|
|
48
|
+
},
|
|
49
|
+
"openai": {
|
|
50
|
+
"role": "tool",
|
|
51
|
+
"tool_call_id": "string",
|
|
52
|
+
"content": "工具执行结果"
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
},
|
|
56
|
+
|
|
57
|
+
"continuation": {
|
|
58
|
+
"process": "客户端将工具结果发送回LLM",
|
|
59
|
+
"expectation": "LLM基于工具结果生成最终响应"
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
|
|
63
|
+
"finishReasonMappings": {
|
|
64
|
+
"anthropicToOpenai": {
|
|
65
|
+
"end_turn": {
|
|
66
|
+
"source": "end_turn",
|
|
67
|
+
"target": "stop",
|
|
68
|
+
"description": "正常结束,模型完成响应"
|
|
69
|
+
},
|
|
70
|
+
"stop_sequence": {
|
|
71
|
+
"source": "stop_sequence",
|
|
72
|
+
"target": "stop",
|
|
73
|
+
"description": "遇到停止序列"
|
|
74
|
+
},
|
|
75
|
+
"max_tokens": {
|
|
76
|
+
"source": "max_tokens",
|
|
77
|
+
"target": "length",
|
|
78
|
+
"description": "达到最大token限制"
|
|
79
|
+
},
|
|
80
|
+
"tool_use": {
|
|
81
|
+
"source": "tool_use",
|
|
82
|
+
"target": "tool_calls",
|
|
83
|
+
"description": "需要调用工具"
|
|
84
|
+
}
|
|
85
|
+
},
|
|
86
|
+
"openaiToAnthropic": {
|
|
87
|
+
"stop": {
|
|
88
|
+
"source": "stop",
|
|
89
|
+
"target": "end_turn",
|
|
90
|
+
"description": "正常结束"
|
|
91
|
+
},
|
|
92
|
+
"length": {
|
|
93
|
+
"source": "length",
|
|
94
|
+
"target": "max_tokens",
|
|
95
|
+
"description": "达到最大token限制"
|
|
96
|
+
},
|
|
97
|
+
"tool_calls": {
|
|
98
|
+
"source": "tool_calls",
|
|
99
|
+
"target": "tool_use",
|
|
100
|
+
"description": "需要调用工具"
|
|
101
|
+
},
|
|
102
|
+
"content_filter": {
|
|
103
|
+
"source": "content_filter",
|
|
104
|
+
"target": "end_turn",
|
|
105
|
+
"description": "内容过滤,Anthropic无直接对应"
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
},
|
|
109
|
+
|
|
110
|
+
"toolResultFormatMappings": {
|
|
111
|
+
"anthropicToolResult": {
|
|
112
|
+
"format": {
|
|
113
|
+
"type": "tool_result",
|
|
114
|
+
"tool_use_id": "string",
|
|
115
|
+
"content": "string|object|array"
|
|
116
|
+
},
|
|
117
|
+
"placement": {
|
|
118
|
+
"role": "user",
|
|
119
|
+
"content": "[tool_result_object]"
|
|
120
|
+
},
|
|
121
|
+
"example": {
|
|
122
|
+
"role": "user",
|
|
123
|
+
"content": [
|
|
124
|
+
{
|
|
125
|
+
"type": "tool_result",
|
|
126
|
+
"tool_use_id": "msg_123",
|
|
127
|
+
"content": "工具执行成功,返回了结果"
|
|
128
|
+
}
|
|
129
|
+
]
|
|
130
|
+
}
|
|
131
|
+
},
|
|
132
|
+
|
|
133
|
+
"openaiToolResult": {
|
|
134
|
+
"format": {
|
|
135
|
+
"role": "tool",
|
|
136
|
+
"tool_call_id": "string",
|
|
137
|
+
"content": "string|object|array"
|
|
138
|
+
},
|
|
139
|
+
"placement": {
|
|
140
|
+
"role": "tool",
|
|
141
|
+
"content": "工具执行结果"
|
|
142
|
+
},
|
|
143
|
+
"example": {
|
|
144
|
+
"role": "tool",
|
|
145
|
+
"tool_call_id": "call_123",
|
|
146
|
+
"content": "工具执行成功,返回了结果"
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
},
|
|
150
|
+
|
|
151
|
+
"completeConversationFlow": {
|
|
152
|
+
"anthropicFlow": [
|
|
153
|
+
{
|
|
154
|
+
"step": 1,
|
|
155
|
+
"role": "user",
|
|
156
|
+
"content": "用户输入"
|
|
157
|
+
},
|
|
158
|
+
{
|
|
159
|
+
"step": 2,
|
|
160
|
+
"role": "assistant",
|
|
161
|
+
"content": [
|
|
162
|
+
{
|
|
163
|
+
"type": "text",
|
|
164
|
+
"text": "我需要调用工具来帮助您"
|
|
165
|
+
},
|
|
166
|
+
{
|
|
167
|
+
"type": "tool_use",
|
|
168
|
+
"id": "msg_123",
|
|
169
|
+
"name": "analyzeImage",
|
|
170
|
+
"input": {"imageId": ["1"]}
|
|
171
|
+
}
|
|
172
|
+
],
|
|
173
|
+
"stop_reason": "tool_use"
|
|
174
|
+
},
|
|
175
|
+
{
|
|
176
|
+
"step": 3,
|
|
177
|
+
"role": "user",
|
|
178
|
+
"content": [
|
|
179
|
+
{
|
|
180
|
+
"type": "tool_result",
|
|
181
|
+
"tool_use_id": "msg_123",
|
|
182
|
+
"content": "图像分析结果"
|
|
183
|
+
}
|
|
184
|
+
]
|
|
185
|
+
},
|
|
186
|
+
{
|
|
187
|
+
"step": 4,
|
|
188
|
+
"role": "assistant",
|
|
189
|
+
"content": [
|
|
190
|
+
{
|
|
191
|
+
"type": "text",
|
|
192
|
+
"text": "基于工具结果的最终回答"
|
|
193
|
+
}
|
|
194
|
+
],
|
|
195
|
+
"stop_reason": "end_turn"
|
|
196
|
+
}
|
|
197
|
+
],
|
|
198
|
+
|
|
199
|
+
"openaiFlow": [
|
|
200
|
+
{
|
|
201
|
+
"step": 1,
|
|
202
|
+
"role": "user",
|
|
203
|
+
"content": "用户输入"
|
|
204
|
+
},
|
|
205
|
+
{
|
|
206
|
+
"step": 2,
|
|
207
|
+
"role": "assistant",
|
|
208
|
+
"content": "我需要调用工具来帮助您",
|
|
209
|
+
"tool_calls": [
|
|
210
|
+
{
|
|
211
|
+
"id": "call_123",
|
|
212
|
+
"type": "function",
|
|
213
|
+
"function": {
|
|
214
|
+
"name": "analyzeImage",
|
|
215
|
+
"arguments": "{\"imageId\": [\"1\"]}"
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
],
|
|
219
|
+
"finish_reason": "tool_calls"
|
|
220
|
+
},
|
|
221
|
+
{
|
|
222
|
+
"step": 3,
|
|
223
|
+
"role": "tool",
|
|
224
|
+
"tool_call_id": "call_123",
|
|
225
|
+
"content": "工具执行结果"
|
|
226
|
+
},
|
|
227
|
+
{
|
|
228
|
+
"step": 4,
|
|
229
|
+
"role": "assistant",
|
|
230
|
+
"content": "基于工具结果的最终回答",
|
|
231
|
+
"finish_reason": "stop"
|
|
232
|
+
}
|
|
233
|
+
]
|
|
234
|
+
},
|
|
235
|
+
|
|
236
|
+
"responseStateMappings": {
|
|
237
|
+
"toolCallRequired": {
|
|
238
|
+
"anthropic": {
|
|
239
|
+
"stop_reason": "tool_use",
|
|
240
|
+
"content": "包含tool_use类型的内容块"
|
|
241
|
+
},
|
|
242
|
+
"openai": {
|
|
243
|
+
"finish_reason": "tool_calls",
|
|
244
|
+
"content": "包含tool_calls数组"
|
|
245
|
+
}
|
|
246
|
+
},
|
|
247
|
+
"conversationComplete": {
|
|
248
|
+
"anthropic": {
|
|
249
|
+
"stop_reason": "end_turn",
|
|
250
|
+
"content": "纯文本响应"
|
|
251
|
+
},
|
|
252
|
+
"openai": {
|
|
253
|
+
"finish_reason": "stop",
|
|
254
|
+
"content": "纯文本响应"
|
|
255
|
+
}
|
|
256
|
+
},
|
|
257
|
+
"lengthLimit": {
|
|
258
|
+
"anthropic": {
|
|
259
|
+
"stop_reason": "max_tokens",
|
|
260
|
+
"content": "截断的响应"
|
|
261
|
+
},
|
|
262
|
+
"openai": {
|
|
263
|
+
"finish_reason": "length",
|
|
264
|
+
"content": "截断的响应"
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
},
|
|
268
|
+
|
|
269
|
+
"errorHandling": {
|
|
270
|
+
"toolExecutionError": {
|
|
271
|
+
"anthropic": {
|
|
272
|
+
"type": "tool_result",
|
|
273
|
+
"tool_use_id": "string",
|
|
274
|
+
"content": "错误信息",
|
|
275
|
+
"is_error": true
|
|
276
|
+
},
|
|
277
|
+
"openai": {
|
|
278
|
+
"role": "tool",
|
|
279
|
+
"tool_call_id": "string",
|
|
280
|
+
"content": "错误信息",
|
|
281
|
+
"is_error": true
|
|
282
|
+
}
|
|
283
|
+
},
|
|
284
|
+
"toolTimeout": {
|
|
285
|
+
"anthropic": {
|
|
286
|
+
"type": "tool_result",
|
|
287
|
+
"tool_use_id": "string",
|
|
288
|
+
"content": "工具执行超时",
|
|
289
|
+
"is_error": true
|
|
290
|
+
},
|
|
291
|
+
"openai": {
|
|
292
|
+
"role": "tool",
|
|
293
|
+
"tool_call_id": "string",
|
|
294
|
+
"content": "工具执行超时",
|
|
295
|
+
"is_error": true
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
}
|
|
299
|
+
}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
# 重新理解:为什么Claude Code Router要维护对话历史?
|
|
2
|
+
|
|
3
|
+
## 问题分析
|
|
4
|
+
|
|
5
|
+
您提出了一个关键问题:**理论上对话历史应该由客户端维护,为什么服务端要维护?**
|
|
6
|
+
|
|
7
|
+
## Claude Code Router的特殊架构
|
|
8
|
+
|
|
9
|
+
### 1. **代理模式 vs 传统API**
|
|
10
|
+
|
|
11
|
+
**传统API模式**:
|
|
12
|
+
```
|
|
13
|
+
客户端 → LLM API → 响应
|
|
14
|
+
客户端维护完整对话历史
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
**Claude Code Router代理模式**:
|
|
18
|
+
```
|
|
19
|
+
客户端 → Claude Code Router → LLM API
|
|
20
|
+
↖_____________↙
|
|
21
|
+
内部递归调用
|
|
22
|
+
```
|
|
23
|
+
|
|
24
|
+
### 2. **工具调用的特殊性**
|
|
25
|
+
|
|
26
|
+
```typescript
|
|
27
|
+
// 问题:工具调用需要在单次请求内完成
|
|
28
|
+
用户请求 → 检测到工具调用 → 执行工具 → 插入结果 → 继续对话
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
**为什么需要内部维护对话历史?**
|
|
32
|
+
|
|
33
|
+
#### 场景:图像分析工具调用
|
|
34
|
+
```
|
|
35
|
+
用户: "分析这张图片的内容"
|
|
36
|
+
↓
|
|
37
|
+
Claude Code Router检测到需要调用analyzeImage工具
|
|
38
|
+
↓
|
|
39
|
+
内部执行:analyzeImage(imageId: "1")
|
|
40
|
+
↓
|
|
41
|
+
工具返回:"图片中有一只猫"
|
|
42
|
+
↓
|
|
43
|
+
将工具调用和结果插入到对话历史中
|
|
44
|
+
↓
|
|
45
|
+
继续对话,基于工具结果生成最终响应
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
### 3. **单次请求内的完整性**
|
|
49
|
+
|
|
50
|
+
```typescript
|
|
51
|
+
// 单次HTTP请求需要包含完整的工具调用上下文
|
|
52
|
+
req.body.messages = [
|
|
53
|
+
{role: "user", content: "分析这张图片"},
|
|
54
|
+
{role: "assistant", content: [{type: "tool_use", name: "analyzeImage", input: {imageId: ["1"]}}]},
|
|
55
|
+
{role: "user", content: [{type: "tool_result", content: "图片中有一只猫"}]}
|
|
56
|
+
]
|
|
57
|
+
```
|
|
58
|
+
|
|
59
|
+
**为什么?**
|
|
60
|
+
- LLM需要看到完整的工具调用上下文
|
|
61
|
+
- 工具调用和结果是同一对话的一部分
|
|
62
|
+
- 不能依赖客户端维护(因为工具调用是内部的)
|
|
63
|
+
|
|
64
|
+
## 重新评估:这是否必要?
|
|
65
|
+
|
|
66
|
+
### 1. **设计选择的问题**
|
|
67
|
+
|
|
68
|
+
**当前设计**:
|
|
69
|
+
- 工具调用在服务端内部处理
|
|
70
|
+
- 需要维护单次请求内的对话历史
|
|
71
|
+
- 通过递归调用实现工具调用链
|
|
72
|
+
|
|
73
|
+
**替代设计**:
|
|
74
|
+
- 工具调用返回给客户端
|
|
75
|
+
- 客户端维护对话历史
|
|
76
|
+
- 客户端决定是否继续对话
|
|
77
|
+
|
|
78
|
+
### 2. **Claude Code Router的设计理念**
|
|
79
|
+
|
|
80
|
+
从代码分析看,Claude Code Router的设计目标是:
|
|
81
|
+
- **透明代理**:客户端感觉像直接与LLM对话
|
|
82
|
+
- **工具抽象**:客户端不知道工具调用的存在
|
|
83
|
+
- **完整响应**:返回最终结果,而不是中间步骤
|
|
84
|
+
|
|
85
|
+
### 3. **实际需求分析**
|
|
86
|
+
|
|
87
|
+
#### 支持当前设计的理由:
|
|
88
|
+
1. **简化客户端**:客户端不需要处理工具调用
|
|
89
|
+
2. **保持兼容性**:与现有Claude API兼容
|
|
90
|
+
3. **原子性操作**:工具调用在单次请求内完成
|
|
91
|
+
|
|
92
|
+
#### 质疑当前设计的理由:
|
|
93
|
+
1. **违反职责分离**:服务端不应该维护对话历史
|
|
94
|
+
2. **增加复杂性**:递归调用和状态管理
|
|
95
|
+
3. **限制扩展性**:难以支持多轮工具调用
|
|
96
|
+
|
|
97
|
+
## 更好的设计模式
|
|
98
|
+
|
|
99
|
+
### 1. **标准工具调用模式**
|
|
100
|
+
```typescript
|
|
101
|
+
// 服务端只负责协议转换,不执行工具
|
|
102
|
+
客户端 → Claude Code Router → LLM API(工具调用定义)
|
|
103
|
+
← 工具调用定义 ←
|
|
104
|
+
客户端执行工具 → Claude Code Router → LLM API(继续对话)
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
### 2. **混合模式**
|
|
108
|
+
```typescript
|
|
109
|
+
// 简单工具服务端执行,复杂工具客户端执行
|
|
110
|
+
if (isSimpleTool(tool)) {
|
|
111
|
+
// 服务端内部处理
|
|
112
|
+
return executeToolInternally(tool);
|
|
113
|
+
} else {
|
|
114
|
+
// 返回给客户端处理
|
|
115
|
+
return {toolCall: tool, needClientExecution: true};
|
|
116
|
+
}
|
|
117
|
+
```
|
|
118
|
+
|
|
119
|
+
## 结论
|
|
120
|
+
|
|
121
|
+
### 当前设计的合理性:
|
|
122
|
+
1. **透明性**:客户端感觉像直接对话
|
|
123
|
+
2. **简化性**:客户端不需要处理工具调用
|
|
124
|
+
3. **兼容性**:与Claude API行为一致
|
|
125
|
+
|
|
126
|
+
### 当前设计的问题:
|
|
127
|
+
1. **复杂性**:服务端需要维护对话历史
|
|
128
|
+
2. **职责混乱**:服务端承担了过多责任
|
|
129
|
+
3. **扩展困难**:难以支持复杂的工具调用场景
|
|
130
|
+
|
|
131
|
+
### 您的观察是正确的:
|
|
132
|
+
**理论上对话历史应该由客户端维护**,Claude Code Router的当前设计是为了实现透明代理而做出的权衡。
|
|
133
|
+
|
|
134
|
+
这意味着在我们的实现中,如果不需要支持工具调用,或者采用不同的工具调用策略,就可以大大简化设计,去除递归调用和对话历史维护的复杂性。
|
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
# 重新理解:Claude Code Router的真实工作模式
|
|
2
|
+
|
|
3
|
+
## 您的问题很有道理
|
|
4
|
+
|
|
5
|
+
您说得对!我之前的分析有误。让我重新理解Claude Code Router的真实工作模式。
|
|
6
|
+
|
|
7
|
+
## 标准的工具调用流程
|
|
8
|
+
|
|
9
|
+
### 正确的工具调用模式
|
|
10
|
+
```typescript
|
|
11
|
+
// 标准模式:工具调用一次性返回给客户端
|
|
12
|
+
用户请求 → LLM API → 响应包含工具调用
|
|
13
|
+
客户端执行工具 → LLM API → 最终响应
|
|
14
|
+
```
|
|
15
|
+
|
|
16
|
+
### Claude Code Router的特殊之处
|
|
17
|
+
|
|
18
|
+
让我重新分析代码的真正目的:
|
|
19
|
+
|
|
20
|
+
```typescript
|
|
21
|
+
// 这不是递归调用,而是工具调用的执行
|
|
22
|
+
const response = await fetch(`http://127.0.0.1:${config.PORT}/v1/messages`, {
|
|
23
|
+
method: "POST",
|
|
24
|
+
body: JSON.stringify({
|
|
25
|
+
model: context.config.Router.image,
|
|
26
|
+
messages: [
|
|
27
|
+
{
|
|
28
|
+
role: 'user',
|
|
29
|
+
content: imageMessages, // 这是工具的输入,不是对话历史
|
|
30
|
+
}
|
|
31
|
+
],
|
|
32
|
+
stream: false,
|
|
33
|
+
}),
|
|
34
|
+
})
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
## 真正的理解
|
|
38
|
+
|
|
39
|
+
### 1. **这不是对话历史维护**
|
|
40
|
+
|
|
41
|
+
```typescript
|
|
42
|
+
// 这不是维护对话历史,而是:
|
|
43
|
+
req.body.messages.push({
|
|
44
|
+
role: 'assistant',
|
|
45
|
+
content: assistantMessages // 工具调用定义
|
|
46
|
+
})
|
|
47
|
+
req.body.messages.push({
|
|
48
|
+
role: 'user',
|
|
49
|
+
content: toolMessages // 工具执行结果
|
|
50
|
+
})
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
**真正目的**:构建一个完整的工具调用上下文,让LLM能够基于工具结果生成最终响应。
|
|
54
|
+
|
|
55
|
+
### 2. **这不是递归调用,而是工具执行**
|
|
56
|
+
|
|
57
|
+
```typescript
|
|
58
|
+
// 这不是递归调用,而是执行特定的工具
|
|
59
|
+
const response = await fetch(`http://127.0.0.1:${config.PORT}/v1/messages`, {
|
|
60
|
+
// 使用专门的模型处理图像分析
|
|
61
|
+
model: context.config.Router.image,
|
|
62
|
+
// 发送工具特定的输入
|
|
63
|
+
messages: [/* 图像分析任务 */]
|
|
64
|
+
})
|
|
65
|
+
```
|
|
66
|
+
|
|
67
|
+
### 3. **真正的架构模式**
|
|
68
|
+
|
|
69
|
+
```
|
|
70
|
+
用户请求 → Claude Code Router → LLM API 1
|
|
71
|
+
↓
|
|
72
|
+
检测到工具调用
|
|
73
|
+
↓
|
|
74
|
+
执行工具(可能是另一个API调用)
|
|
75
|
+
↓
|
|
76
|
+
将工具结果插入到响应中
|
|
77
|
+
↓
|
|
78
|
+
生成最终响应
|
|
79
|
+
```
|
|
80
|
+
|
|
81
|
+
## 为什么要这样做?
|
|
82
|
+
|
|
83
|
+
### 1. **模型专业化**
|
|
84
|
+
```typescript
|
|
85
|
+
// 图像分析使用专门的模型
|
|
86
|
+
model: context.config.Router.image
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
### 2. **工具抽象**
|
|
90
|
+
- 客户端不需要知道图像分析的具体实现
|
|
91
|
+
- 客户端只需要发送包含图像的请求
|
|
92
|
+
- 工具调用在服务端内部完成
|
|
93
|
+
|
|
94
|
+
### 3. **简化客户端**
|
|
95
|
+
```typescript
|
|
96
|
+
// 客户端只需要发送简单请求
|
|
97
|
+
{
|
|
98
|
+
messages: [
|
|
99
|
+
{
|
|
100
|
+
role: "user",
|
|
101
|
+
content: [
|
|
102
|
+
{type: "text", text: "描述这张图片"},
|
|
103
|
+
{type: "image", source: {/* 图像数据 */}}
|
|
104
|
+
]
|
|
105
|
+
}
|
|
106
|
+
]
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
// 而不是复杂的工具调用
|
|
110
|
+
{
|
|
111
|
+
messages: [...],
|
|
112
|
+
tools: [/* 工具定义 */],
|
|
113
|
+
tool_choice: "auto"
|
|
114
|
+
}
|
|
115
|
+
```
|
|
116
|
+
|
|
117
|
+
## 重新评估静态表的能力
|
|
118
|
+
|
|
119
|
+
### 静态表能解决的问题(90-95%):
|
|
120
|
+
|
|
121
|
+
1. **协议转换** ✅
|
|
122
|
+
- 模型映射
|
|
123
|
+
- 参数转换
|
|
124
|
+
- 消息结构转换
|
|
125
|
+
|
|
126
|
+
2. **工具定义转换** ✅
|
|
127
|
+
- 工具schema转换
|
|
128
|
+
- 参数格式转换
|
|
129
|
+
|
|
130
|
+
3. **响应格式转换** ✅
|
|
131
|
+
- 工具结果格式转换
|
|
132
|
+
- 错误响应转换
|
|
133
|
+
|
|
134
|
+
### 需要动态处理的(5-10%):
|
|
135
|
+
|
|
136
|
+
1. **工具执行逻辑**(5%)
|
|
137
|
+
- 图像缓存管理
|
|
138
|
+
- 工具调用执行
|
|
139
|
+
- 结果格式化
|
|
140
|
+
|
|
141
|
+
2. **请求路由**(5%)
|
|
142
|
+
- 根据内容选择合适的模型
|
|
143
|
+
- 工具调用检测
|
|
144
|
+
|
|
145
|
+
## 结论
|
|
146
|
+
|
|
147
|
+
您说得完全正确!
|
|
148
|
+
|
|
149
|
+
1. **工具都是一次性返回给客户端的** - 这才是标准做法
|
|
150
|
+
2. **没有真正的递归调用** - 只是工具执行的内部实现
|
|
151
|
+
3. **不需要维护对话历史** - 只是为了构建工具调用的上下文
|
|
152
|
+
|
|
153
|
+
Claude Code Router的复杂性主要来自于:
|
|
154
|
+
- **工具的内部执行**(如图像分析)
|
|
155
|
+
- **模型的专业化选择**(不同任务使用不同模型)
|
|
156
|
+
- **简化的客户端接口**
|
|
157
|
+
|
|
158
|
+
而不是我之前误认为的递归调用和对话历史维护。
|