4.2 KiB
summary, read_when, title, sidebarTitle
| summary | read_when | title | sidebarTitle | |||
|---|---|---|---|---|---|---|
| Raft External Agent support through the Raft CLI wake bridge |
|
Raft | 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/raft
openclaw gateway restart
Details: 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=openclaw
Use 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 raft
How 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 check
raft --profile openclaw message send
Verify
Check that OpenClaw can find the CLI and has a configured profile:
openclaw channels status --probe
openclaw plugins inspect raft --runtime --json
Then 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.