An MCP server that connects Claude Code to a persistent OpenClaw daemon for 24/7 automation. Includes a Claude CLI proxy that lets OpenClaw use your Claude Code subscription as its AI brain — no separate API key needed.
OpenClaw runs as a background daemon on your machine. This MCP server gives Claude Code tools to manage that daemon — create cron jobs, set up webhooks, send messages across 23+ platforms, and automate your browser.
The key difference from other approaches: automations keep running when Claude Code isn't open. When you come back, Claude catches up on everything that happened through an event queue.
┌─────────────────────────────────────────────┐
│ OpenClaw Daemon (24/7) │
│ ┌─────────┐ ┌──────┐ ┌────────┐ ┌───────┐ │
│ │ Discord │ │ Cron │ │Browser │ │ Gmail │ │
│ └────┬────┘ └──┬───┘ └───┬────┘ └───┬───┘ │
│ └─────────┴─────────┴──────────┘ │
│ │ │
│ Gateway (:18789) │
└──────────┬─────────────────┬───────────────┘
│ │
MCP stdio │ OpenAI API │
Claude Code ◄──────────► MCP Server│ (:18790) │
│ │ │
SQLite DB └── Claude Proxy ◄┘
│
claude --print
(your CLI sub)
- OpenClaw Daemon runs in the background (systemd/launchd). Handles cron, messaging channels, browser automation.
- MCP Server connects to the daemon and exposes tools for Claude Code.
- Claude Proxy translates OpenAI API calls to
claude --printcalls. OpenClaw thinks it's talking to an API, but it's using your Claude Code subscription. - Event Queue stores results from automations. When Claude Code reconnects, it polls for missed events.
- Claude Code CLI installed and authenticated
- OpenClaw installed locally
- Node.js 22+
git clone https://github.com/mordiaky/clawdaemon-mcp.git
cd clawdaemon-mcp
npm install
npm run buildIf you haven't installed OpenClaw yet:
git clone https://github.com/openclaw/openclaw.git
cd openclaw
npx pnpm install
npx pnpm buildStart the gateway:
node openclaw.mjs gateway runThe gateway starts on http://127.0.0.1:18789 by default.
claude mcp add clawdaemon -- node /absolute/path/to/clawdaemon-mcp/build/server.jsOptionally add OpenClaw's built-in messaging tools:
claude mcp add openclaw -- node /absolute/path/to/openclaw/openclaw.mjs mcp serveRestart Claude Code for the tools to load.
The Claude Proxy lets OpenClaw use your Claude Code CLI subscription as its AI model. This means OpenClaw can respond to Discord messages, run heartbeat tasks, and process automations — all powered by Claude, with no separate API key.
cd clawdaemon-mcp
npm run proxyThe proxy listens on http://127.0.0.1:18790/v1 and translates OpenAI-compatible API calls into claude --print calls.
Add to your ~/.openclaw/openclaw.json:
{
"models": {
"providers": {
"claude-proxy": {
"baseUrl": "http://127.0.0.1:18790/v1",
"api": "openai-completions",
"models": [
{
"id": "claude-cli",
"name": "Claude via CLI Proxy",
"input": ["text", "image"],
"contextWindow": 200000,
"maxTokens": 8192
}
]
}
}
},
"agents": {
"defaults": {
"model": {
"primary": "claude-proxy/claude-cli"
}
}
}
}Restart the gateway to apply:
openclaw gateway restartEdit openclaw-mcp-config.json to add any MCP servers you want the proxy-spawned Claude to have access to:
{
"mcpServers": {
"clawdaemon": {
"type": "stdio",
"command": "node",
"args": ["/absolute/path/to/clawdaemon-mcp/build/server.js"],
"env": {}
},
"your-other-server": {
"type": "stdio",
"command": "node",
"args": ["/absolute/path/to/your-server/build/index.js"],
"env": {}
}
}
}The proxy passes this config to claude --print --mcp-config so the Claude instance that responds to messages has full tool access.
| Tool | What it does |
|---|---|
daemon_status |
Check if OpenClaw gateway is running and healthy |
| Tool | What it does |
|---|---|
create_cron |
Schedule a recurring automation |
list_automations |
List all active automations |
delete_automation |
Remove an automation |
| Tool | What it does |
|---|---|
poll_events |
Get events that happened since last check |
acknowledge_event |
Mark an event as processed |
get_event_history |
Browse past events |
prune_events |
Remove expired events from the queue |
| Tool | What it does |
|---|---|
send_message |
Send a message via any connected channel |
list_channels |
List connected messaging channels |
| Tool | What it does |
|---|---|
browser_navigate |
Open a URL in the browser |
browser_extract |
Get a DOM snapshot of the current page |
browser_screenshot |
Take a screenshot |
| Variable | Default | Description |
|---|---|---|
OPENCLAW_GATEWAY_URL |
ws://127.0.0.1:18789 |
Gateway WebSocket URL |
OPENCLAW_GATEWAY_TOKEN |
(from ~/.openclaw/openclaw.json) | Auth token for gateway |
CLAWDAEMON_DB |
~/.clawdaemon/events.db |
Event queue database path |
CLAUDE_PROXY_PORT |
18790 |
Port for the Claude CLI proxy |
The proxy is a lightweight HTTP server that makes Claude Code CLI look like an OpenAI-compatible API:
- OpenClaw sends a standard
/v1/chat/completionsrequest - The proxy converts the messages to a prompt string
- It spawns
claude --print --output-format json --mcp-config openclaw-mcp-config.json - Claude processes the prompt with full MCP tool access
- The proxy wraps the response in OpenAI format and returns it
- OpenClaw delivers the response to Discord/Telegram/etc.
Supports both streaming (SSE) and non-streaming responses.
Once the proxy is running and OpenClaw is configured to use it, add a messaging channel:
- Create a Discord bot at https://discord.com/developers/applications
- Get the bot token, enable Message Content Intent
- Add to
~/.openclaw/openclaw.json:
{
"channels": {
"discord": {
"enabled": true,
"groupPolicy": "open",
"accounts": {
"default": {
"token": "YOUR_DISCORD_BOT_TOKEN"
}
}
}
}
}- Restart the gateway and invite the bot to your server
- DM the bot to trigger pairing, then approve:
openclaw pairing approve discord <CODE>
Claude will now respond to Discord messages through the proxy.
- Restart Claude Code — MCP tools only load at session start.
- Check the gateway is running — Visit
http://127.0.0.1:18789. - Check MCP server status — Run
/mcpin Claude Code.
- Check the proxy is running —
curl http://127.0.0.1:18790/v1/models - Check Claude CLI is authenticated —
claude --version - Check proxy logs — Logs go to stderr. Run
npm run proxyin a terminal to see them.
- Enable all three Privileged Gateway Intents in the Discord Developer Portal (Message Content, Server Members, Presence)
- Set
groupPolicy: "open"in the Discord channel config - DM the bot and complete the pairing flow
Discord's WebSocket sometimes doesn't reconnect cleanly. Stop the gateway, wait 15 seconds, then restart:
systemctl --user stop openclaw-gateway.service
sleep 15
openclaw gateway restartOpenClaw is a powerful automation daemon but its built-in AI requires separate API keys. Claude Code users already have a Claude subscription. This MCP server + proxy lets you use OpenClaw's full automation stack (messaging, cron, browser, webhooks) powered entirely by your existing Claude Code subscription — no additional API costs, no ToS violations.
MIT