Connect GoClaw to Alibaba's Qwen models via the DashScope OpenAI-compatible API.
DashScope is Alibaba's model serving platform, offering the Qwen family of models. GoClaw uses a dedicated DashScopeProvider that wraps the standard OpenAI-compatible layer and adds one critical workaround: DashScope does not support tool calls and streaming simultaneously. When your agent uses tools, GoClaw automatically falls back to a non-streaming request and then synthesizes streaming callbacks for the caller — so your agent works correctly without any code changes.
DashScope also supports extended thinking via thinking_level, which GoClaw maps to DashScope-specific enable_thinking and thinking_budget parameters.
Add your DashScope API key to config.json:
{
"providers": {
"dashscope": {
"api_key": "$DASHSCOPE_API_KEY"
}
},
"agents": {
"defaults": {
"provider": "dashscope",
"model": "qwen3-max"
}
}
}Store your key in .env.local:
DASHSCOPE_API_KEY=sk-xxxxxxxxxxxxxxxxxxxxxxxxThe default API base is https://dashscope-intl.aliyuncs.com/compatible-mode/v1 (international endpoint). For China-region access, set api_base to https://dashscope.aliyuncs.com/compatible-mode/v1.
| Model | Notes |
|---|---|
qwen3-max |
Best accuracy (default) |
qwen3-plus |
Balanced performance and cost |
qwen3-turbo |
Fastest Qwen3 model |
qwen3-235b-a22b |
Open-weight, MoE architecture |
qwq-32b |
Extended thinking / reasoning model |
qwen3.5-max |
Qwen 3.5 series, highest capability |
qwen3.5-plus |
Qwen 3.5 series, balanced |
qwen3.5-turbo |
Qwen 3.5 series, fastest |
GoClaw uses a simplified per-model guard to decide whether to send enable_thinking and thinking_budget parameters. Only models that actually support extended thinking receive these parameters — other models silently ignore the thinking_level setting. In v3, this logic was simplified (previously had redundant checks that could cause incorrect behavior for some model names).
Models that support thinking: qwq-32b, and Qwen 3.5 series models with thinking capability.
For models that support extended thinking (like qwq-32b), set thinking_level in your agent options:
{
"agents": {
"defaults": {
"provider": "dashscope",
"model": "qwq-32b",
"thinking_level": "medium"
}
}
}GoClaw maps thinking_level to DashScope's thinking_budget:
| Level | Budget (tokens) |
|---|---|
low |
4,096 |
medium |
16,384 (default) |
high |
32,768 |
Minimal config with international endpoint:
{
"providers": {
"dashscope": {
"api_key": "$DASHSCOPE_API_KEY"
}
},
"agents": {
"defaults": {
"provider": "dashscope",
"model": "qwen3-max",
"max_tokens": 8192
}
}
}China-region endpoint:
{
"providers": {
"dashscope": {
"api_key": "$DASHSCOPE_API_KEY",
"api_base": "https://dashscope.aliyuncs.com/compatible-mode/v1"
}
}
}| Problem | Cause | Fix |
|---|---|---|
401 Unauthorized |
Invalid API key | Verify DASHSCOPE_API_KEY in .env.local |
| Slow tool call responses | Tools disable streaming; GoClaw uses non-streaming fallback | Expected — DashScope limitation; response is still delivered |
| Thinking content missing | Model doesn't support thinking | Use qwq-32b or another thinking-capable model |
404 on requests |
Wrong region endpoint | Set api_base to China or international endpoint as appropriate |
- Claude CLI — unique provider that shells out to the Claude Code CLI binary
- Custom Provider — connect any OpenAI-compatible API