mirror of
https://github.com/ultraworkers/claw-code.git
synced 2026-06-07 02:12:29 +08:00
151 lines
6.2 KiB
Markdown
151 lines
6.2 KiB
Markdown
|
|
# Local OpenAI-compatible providers and skills setup
|
|||
|
|
|
|||
|
|
This guide covers two common offline/local workflows:
|
|||
|
|
|
|||
|
|
1. running Claw against an OpenAI-compatible local model server such as Ollama, llama.cpp, or vLLM; and
|
|||
|
|
2. installing local skills from disk so Claw can discover them without network access.
|
|||
|
|
|
|||
|
|
## Claw is not Claude-only
|
|||
|
|
|
|||
|
|
Claw Code is a Claude-Code-shaped workflow/runtime, not a Claude-only product. It supports Anthropic directly and can target OpenAI-compatible, provider-routed, and local models depending on configuration. Non-Claude providers are supported honestly: they may require stricter tool-call and response-shape compatibility, and some slash/tool workflows can be rougher than first-party Anthropic/OpenAI paths. Provider-specific identity leaks are bugs, not intended product positioning.
|
|||
|
|
|
|||
|
|
If you need the most polished daily-driver experience for a specific non-Claude model today, compare that provider’s native tools. If you need runtime/provider hackability, Claw’s OpenAI-compatible route is the intended extension path.
|
|||
|
|
|
|||
|
|
## OpenAI-compatible routing basics
|
|||
|
|
|
|||
|
|
Set `OPENAI_BASE_URL` to the server’s `/v1` endpoint and set `OPENAI_API_KEY` to either the required token or a harmless placeholder for local servers that expect an Authorization header. The model name must match what the server exposes.
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
export OPENAI_BASE_URL="http://127.0.0.1:11434/v1"
|
|||
|
|
export OPENAI_API_KEY="local-dev-token"
|
|||
|
|
claw --model "qwen3:latest" prompt "Reply exactly HELLO_WORLD_123"
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
Routing notes:
|
|||
|
|
|
|||
|
|
- Use the `openai/` prefix for OpenAI-compatible gateways when you need prefix routing to win over ambient Anthropic credentials, for example `--model "openai/gpt-4.1-mini"` with OpenRouter.
|
|||
|
|
- For local servers, prefer the exact model ID reported by the server (`qwen3:latest`, `llama3.2`, `Qwen/Qwen2.5-Coder-7B-Instruct`, etc.). If your local gateway exposes slash-containing IDs, use that exact slug.
|
|||
|
|
- If you have multiple provider keys in your environment, remove unrelated keys while smoke-testing a local route or choose a model prefix that unambiguously selects the intended provider.
|
|||
|
|
- Tool workflows need model/server support for OpenAI-compatible tool calls. Plain prompt smoke tests can pass even when slash/tool workflows still fail because the server returns an incompatible tool-call shape.
|
|||
|
|
|
|||
|
|
## Raw `/v1/chat/completions` smoke test
|
|||
|
|
|
|||
|
|
Before debugging Claw, verify the local server speaks the expected wire format:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
curl -sS "$OPENAI_BASE_URL/chat/completions" \
|
|||
|
|
-H "Authorization: Bearer ${OPENAI_API_KEY:-local-dev-token}" \
|
|||
|
|
-H "Content-Type: application/json" \
|
|||
|
|
-d '{
|
|||
|
|
"model": "qwen3:latest",
|
|||
|
|
"messages": [{"role": "user", "content": "Reply exactly HELLO_WORLD_123"}],
|
|||
|
|
"stream": false
|
|||
|
|
}'
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
Expected result: a JSON response with one assistant message containing `HELLO_WORLD_123`. If this fails, fix the local server, model name, or auth token before changing Claw settings.
|
|||
|
|
|
|||
|
|
## Ollama
|
|||
|
|
|
|||
|
|
Start Ollama and pull a model:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
ollama pull qwen3:latest
|
|||
|
|
ollama serve
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
In another shell:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
export OPENAI_BASE_URL="http://127.0.0.1:11434/v1"
|
|||
|
|
export OPENAI_API_KEY="local-dev-token"
|
|||
|
|
claw --model "qwen3:latest" prompt "Reply exactly HELLO_WORLD_123"
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
If Ollama is running without auth and your build accepts authless local OpenAI-compatible servers, `unset OPENAI_API_KEY` is also acceptable. Use a placeholder token rather than a real cloud API key for local testing.
|
|||
|
|
|
|||
|
|
## llama.cpp server
|
|||
|
|
|
|||
|
|
Start a llama.cpp OpenAI-compatible server with the model name you want Claw to send:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
llama-server -m ./models/qwen2.5-coder.gguf --host 127.0.0.1 --port 8080 --alias qwen2.5-coder
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
Then smoke-test through Claw:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
export OPENAI_BASE_URL="http://127.0.0.1:8080/v1"
|
|||
|
|
export OPENAI_API_KEY="local-dev-token"
|
|||
|
|
claw --model "qwen2.5-coder" prompt "Reply exactly HELLO_WORLD_123"
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## vLLM or another OpenAI-compatible server
|
|||
|
|
|
|||
|
|
Start vLLM with an OpenAI-compatible API server:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
vllm serve Qwen/Qwen2.5-Coder-7B-Instruct --host 127.0.0.1 --port 8000
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
Then route Claw to it:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
export OPENAI_BASE_URL="http://127.0.0.1:8000/v1"
|
|||
|
|
export OPENAI_API_KEY="local-dev-token"
|
|||
|
|
claw --model "Qwen/Qwen2.5-Coder-7B-Instruct" prompt "Reply exactly HELLO_WORLD_123"
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## Local skills install from disk
|
|||
|
|
|
|||
|
|
Skills are discovered from Claw skill roots such as `.claw/skills/` in a workspace and `~/.claw/skills/` for user-level installs. Legacy `.codex/skills/` roots may also be scanned for compatibility, but new local Claw projects should prefer `.claw/skills/`.
|
|||
|
|
|
|||
|
|
A skill directory should contain a `SKILL.md` file with frontmatter:
|
|||
|
|
|
|||
|
|
```text
|
|||
|
|
my-skill/
|
|||
|
|
└── SKILL.md
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
```markdown
|
|||
|
|
---
|
|||
|
|
name: my-skill
|
|||
|
|
description: Explain when this skill should be used.
|
|||
|
|
---
|
|||
|
|
|
|||
|
|
# My Skill
|
|||
|
|
|
|||
|
|
Instructions for the agent go here.
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
Install a skill from a local path in the interactive REPL:
|
|||
|
|
|
|||
|
|
```text
|
|||
|
|
/skills install /absolute/path/to/my-skill
|
|||
|
|
/skills list
|
|||
|
|
/skills my-skill
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
Or inspect skills from the direct CLI surface:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
claw skills --output-format json
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
Offline install checklist:
|
|||
|
|
|
|||
|
|
- Install the specific skill directory, not only the repository root, unless that repository root itself contains `SKILL.md`.
|
|||
|
|
- Keep the frontmatter `name` aligned with the directory name users will type.
|
|||
|
|
- After installing, run `/skills list` or `claw skills --output-format json` to confirm the discovered name and source path.
|
|||
|
|
- If a skill invocation fails with an HTTP/provider error, the skill may have installed correctly but the current model/provider call failed. Run `claw doctor`, verify provider credentials, and try a simple prompt smoke test before reinstalling the skill.
|
|||
|
|
|
|||
|
|
## Troubleshooting
|
|||
|
|
|
|||
|
|
| Symptom | Check |
|
|||
|
|
|---|---|
|
|||
|
|
| Claw still asks for Anthropic credentials | Use an explicit OpenAI-compatible model route or remove unrelated Anthropic env vars during local smoke tests. |
|
|||
|
|
| `model not found` from local server | Use the exact model ID exposed by Ollama/llama.cpp/vLLM. |
|
|||
|
|
| Plain prompt works but tools fail | Confirm the model/server supports OpenAI-compatible tool calls and response shapes. |
|
|||
|
|
| Skill says installed but `/skills <name>` fails | Check `/skills list` for the discovered name and source; verify provider credentials separately with `claw doctor`. |
|
|||
|
|
| A local docs/log file contains secrets | Redact it before using `@path` file context or attaching it to an issue. |
|