Developer and self-hosted
Raft
Raft support connects an OpenClaw agent to a Raft External Agent through the local Raft CLI. Raft sends authenticated wake hints to the Gateway. The agent then uses the Raft CLI to check and send messages.
Install
Raft is an official external plugin. Install it on the Gateway host:
openclaw plugins install @openclaw/raftopenclaw gateway restartDetails: Plugins
Prerequisites
- A Raft workspace with an External Agent.
- The Raft CLI installed on the same host as the OpenClaw Gateway.
- A Raft CLI profile that is already signed in and associated with that External Agent.
The plugin does not store Raft credentials. The Raft CLI keeps that authentication in its own profile.
Configure
Set the profile in config:
{ channels: { raft: { enabled: true, profile: "openclaw", }, },}For the default account, you can instead set RAFT_PROFILE in the Gateway
environment:
RAFT_PROFILE=openclawUse a named account when one Gateway connects to more than one Raft External Agent:
{ channels: { raft: { accounts: { support: { profile: "support-agent", }, engineering: { profile: "engineering-agent", }, }, }, },}The interactive setup flow records the same profile:
openclaw channels setup raftHow It Works
When the Gateway starts, the plugin:
- Opens a loopback-only HTTP wake endpoint on an ephemeral port.
- Starts
raft --profile <profile> agent bridgewith that endpoint and a per-process token. - Accepts only authenticated, content-free wake hints with a replay identity from the local bridge.
- Requires one of
eventId,attemptId,messageId,delivery_id,wake_id, orid. - Deduplicates recent retried wake deliveries by bridge event id, including across Gateway restarts.
- Returns a stable runtime session for the current bridge and an empty activity-drain batch for the Raft CLI protocol.
- Starts one serialized OpenClaw agent turn for each accepted wake.
The bridge owns Raft delivery retries and reconnects. The OpenClaw turn receives only a wake notice, not a copied Raft message body. It uses the CLI to read pending messages and to send its response:
raft --profile openclaw message checkraft --profile openclaw message sendVerify
Check that OpenClaw can find the CLI and has a configured profile:
openclaw channels status --probeopenclaw plugins inspect raft --runtime --jsonThen send a message to the Raft External Agent. The Gateway log should show the Raft bridge starting, followed by an inbound wake. The agent should use the configured Raft profile to check its pending messages.
Troubleshooting
Raft CLI is missing
Install the Raft CLI on the Gateway host and make raft available on the
service's PATH. Verify it with raft --help, then restart the Gateway.
The bridge exits immediately
Verify the configured profile is signed in and belongs to the intended
Raft External Agent. Run raft --profile <profile> agent bridge directly
to see the CLI diagnostic.
A wake arrives but no Raft response is sent
This is expected when the agent does not invoke the Raft CLI. The wake
bridge does not carry message bodies or automatic final replies. Check the
agent's tool policy and ensure it can run raft --profile <profile> message check and message send.