docs/channels/mqtt/README.md
PicoClaw supports any MQTT client as a chat channel. Devices or services publish requests to a broker; PicoClaw subscribes, processes them, and publishes responses back.
1. Add the channel to ~/.picoclaw/config.json:
{
"channel_list": {
"mqtt": {
"enabled": true,
"type": "mqtt",
"settings": {
"broker": "tcp://localhost:1883",
"agent_id": "assistant"
}
}
}
}
2. Start the gateway:
picoclaw gateway
3. Send a message from any MQTT client:
mosquitto_pub -t "/picoclaw/assistant/device1/request" \
-m '{"text": "What is the CPU usage?"}'
4. Subscribe to receive the response:
mosquitto_sub -t "/picoclaw/assistant/device1/response"
{prefix}/{agent_id}/{client_id}/request # Client → PicoClaw
{prefix}/{agent_id}/{client_id}/response # PicoClaw → Client
| Segment | Description |
|---|---|
prefix | Topic prefix, configured server-side. Default: /picoclaw |
agent_id | PicoClaw instance identifier, set in agent_id config field |
client_id | Client-defined session identifier — use a stable ID per device to maintain conversation context |
{ "text": "your message here" }
{
"channel_list": {
"mqtt": {
"enabled": true,
"type": "mqtt",
"settings": {
"broker": "ssl://your-broker:8883",
"agent_id": "assistant",
"topic_prefix": "/picoclaw",
"client_id": "",
"keep_alive": 60,
"qos": 0
}
}
}
}
Username and password are stored in ~/.picoclaw/.security.yml, not in config.json:
channel_list:
mqtt:
settings:
username: your_username
password: your_password
| Field | Location | Required | Default | Description |
|---|---|---|---|---|
broker | settings | Yes | — | MQTT broker URL, e.g. tcp://host:1883, ssl://host:8883 |
agent_id | settings | Yes | — | Agent identifier, used as part of the topic path |
topic_prefix | settings | No | /picoclaw | Topic namespace prefix |
username | .security.yml | No | — | Broker authentication username |
password | .security.yml | No | — | Broker authentication password |
client_id | settings | No | auto-generated | Paho client ID sent to the broker. Auto-generated as picoclaw-mqtt-{agent_id}-{8-char hex} if not set; stays fixed for the process lifetime so reconnects reuse the same ID |
keep_alive | settings | No | 60 | MQTT keepalive interval in seconds |
qos | settings | No | 0 | QoS level for publish and subscribe: 0, 1, or 2 |
All fields can be set via environment variables:
| Variable | Field |
|---|---|
PICOCLAW_CHANNELS_MQTT_BROKER | broker |
PICOCLAW_CHANNELS_MQTT_AGENT_ID | agent_id |
PICOCLAW_CHANNELS_MQTT_TOPIC_PREFIX | topic_prefix |
PICOCLAW_CHANNELS_MQTT_USERNAME | username |
PICOCLAW_CHANNELS_MQTT_PASSWORD | password |
PICOCLAW_CHANNELS_MQTT_CLIENT_ID | client_id |
PICOCLAW_CHANNELS_MQTT_KEEP_ALIVE | keep_alive |
PICOCLAW_CHANNELS_MQTT_QOS | qos |
PicoClaw automatically reconnects to the broker if the connection is lost, with a 5-second retry interval. On reconnect, the subscription is re-established automatically. The broker-side client ID stays the same across reconnects so the broker correctly identifies it as the same session.
ssl:// broker URL). Certificate verification is skipped by default.client_id in the topic path is set by your client application and identifies the conversation session. It is separate from the broker-level client ID used by PicoClaw's paho connection.agent_id, set distinct client_id values to avoid broker-level conflicts.