Multi-agent, Multi-team, Multi-channel, 24/7 AI assistant
Run multiple teams of AI agents that collaborate with each other simultaneously with isolated workspaces.
- β Multi-agent - Run multiple isolated AI agents with specialized roles
- β Multi-team collaboration - Agents hand off work to teammates via chain execution and fan-out
- β Multi-channel - Discord, WhatsApp, and Telegram
- β
Team Observation - You can observe agent teams conversations via
tinyclaw team visualize - β Multiple AI providers - Anthropic Claude and OpenAI Codex using existing subscriptions without breaking ToS
- β Parallel processing - Agents process messages concurrently
- β Live TUI dashboard - Real-time team visualizer for monitoring agent chains
- β Persistent sessions - Conversation context maintained across restarts
- β File-based queue - No race conditions, reliable message handling
- β 24/7 operation - Runs in tmux for always-on availability
- macOS or Linux
- Node.js v14+
- tmux
- Bash 4.0+ (macOS:
brew install bash) - Claude Code CLI (for Anthropic provider)
- Codex CLI (for OpenAI provider)
Option 1: One-line Install (Recommended)
curl -fsSL https://raw.githubusercontent.com/jlia0/tinyclaw/main/scripts/remote-install.sh | bashOption 2: From Release
wget https://github.com/jlia0/tinyclaw/releases/latest/download/tinyclaw-bundle.tar.gz
tar -xzf tinyclaw-bundle.tar.gz
cd tinyclaw && ./scripts/install.shOption 3: From Source
git clone https://github.com/jlia0/tinyclaw.git
cd tinyclaw && npm install && ./scripts/install.shtinyclaw start # Runs interactive setup wizardThe setup wizard will guide you through:
- Channel selection - Choose Discord, WhatsApp, and/or Telegram
- Bot tokens - Enter tokens for enabled channels
- Workspace setup - Name your workspace directory
- Default agent - Configure your main AI assistant
- AI provider - Select Anthropic (Claude) or OpenAI
- Model selection - Choose model (e.g., Sonnet, Opus, GPT-5.3)
- Heartbeat interval - Set proactive check-in frequency
π± Channel Setup Guides
- Go to Discord Developer Portal
- Create application β Bot section β Create bot
- Copy bot token
- Enable "Message Content Intent"
- Invite bot using OAuth2 URL Generator
- Open Telegram β Search
@BotFather - Send
/newbotβ Follow prompts - Copy bot token
- Start chat with your bot
After starting TinyClaw, scan the QR code:
βββββββββββββββββββββββββββββββββββ
WhatsApp QR Code
βββββββββββββββββββββββββββββββββββ
[QR CODE HERE]
π± Settings β Linked Devices β Link a Device
Commands work with tinyclaw (if CLI installed) or ./tinyclaw.sh (direct script).
| Command | Description | Example |
|---|---|---|
start |
Start TinyClaw daemon | tinyclaw start |
stop |
Stop all processes | tinyclaw stop |
restart |
Restart TinyClaw | tinyclaw restart |
status |
Show current status and activity | tinyclaw status |
setup |
Run setup wizard (reconfigure) | tinyclaw setup |
logs [type] |
View logs (discord/telegram/whatsapp/queue/heartbeat/all) | tinyclaw logs queue |
attach |
Attach to tmux session | tinyclaw attach |
| Command | Description | Example |
|---|---|---|
agent list |
List all configured agents | tinyclaw agent list |
agent add |
Add new agent (interactive) | tinyclaw agent add |
agent show <id> |
Show agent configuration | tinyclaw agent show coder |
agent remove <id> |
Remove an agent | tinyclaw agent remove coder |
agent reset <id> |
Reset agent conversation | tinyclaw agent reset coder |
| Command | Description | Example |
|---|---|---|
team list |
List all configured teams | tinyclaw team list |
team add |
Add new team (interactive) | tinyclaw team add |
team show <id> |
Show team configuration | tinyclaw team show dev |
team remove <id> |
Remove a team | tinyclaw team remove dev |
team visualize [id] |
Live TUI dashboard for team chains | tinyclaw team visualize dev |
| Command | Description | Example |
|---|---|---|
provider [name] |
Show or switch AI provider | tinyclaw provider anthropic |
provider <name> --model <model> |
Switch provider and model | tinyclaw provider openai --model gpt-5.3-codex |
model [name] |
Show or switch AI model | tinyclaw model opus |
reset |
Reset all conversations | tinyclaw reset |
channels reset <channel> |
Reset channel authentication | tinyclaw channels reset whatsapp |
Use sender pairing to control who can message your agents.
| Command | Description | Example |
|---|---|---|
pairing pending |
Show pending sender approvals (with pairing codes) | tinyclaw pairing pending |
pairing approved |
Show approved senders | tinyclaw pairing approved |
pairing list |
Show both pending and approved senders | tinyclaw pairing list |
pairing approve <code> |
Move a sender from pending to approved by code | tinyclaw pairing approve ABCD1234 |
pairing unpair <channel> <sender_id> |
Remove an approved sender from the allowlist | tinyclaw pairing unpair telegram 1234567 |
Pairing behavior:
- First message from unknown sender: TinyClaw generates a code and sends approval instructions.
- Additional messages while still pending: TinyClaw blocks silently (no repeated pairing message).
- After approval: messages from that sender are processed normally.
| Command | Description | Example |
|---|---|---|
update |
Update TinyClaw to latest version | tinyclaw update |
Note: If you are on v0.0.1 or v0.0.2, the update script was broken. Please re-install instead:
curl -fsSL https://raw.githubusercontent.com/jlia0/tinyclaw/main/scripts/remote-install.sh | bashYour settings and user data will be preserved.
Update Details
Auto-detection: TinyClaw checks for updates on startup (once per hour).
Manual update:
tinyclaw updateThis will:
- Check for latest release
- Show changelog URL
- Download bundle
- Create backup of current installation
- Install new version
Disable update checks:
export TINYCLAW_SKIP_UPDATE_CHECK=1| Command | Description | Example |
|---|---|---|
send <message> |
Send message to AI manually | tinyclaw send "Hello!" |
send <message> |
Route to specific agent | tinyclaw send "@coder fix bug" |
These commands work in Discord, Telegram, and WhatsApp:
| Command | Description | Example |
|---|---|---|
@agent_id message |
Route message to specific agent | @coder fix the bug |
@team_id message |
Route message to team leader | @dev fix the auth bug |
/agent |
List all available agents | /agent |
/team |
List all available teams | /team |
@agent_id /reset |
Reset specific agent conversation | @coder /reset |
/reset |
Reset conversation (WhatsApp/global) | /reset or !reset |
message |
Send to default agent (no prefix) | help me with this |
Note: The @agent_id routing prefix requires a space after it (e.g., @coder fix not @coderfix).
Access control note: before routing, channel clients apply sender pairing allowlist checks.
Use @agent_id prefix to route messages to specific agents (see In-Chat Commands table above):
@coder fix the authentication bug
@writer document the API endpoints
@researcher find papers on transformers
help me with this β goes to default agent (no prefix needed)
Agents are configured in .tinyclaw/settings.json:
{
"workspace": {
"path": "/Users/me/tinyclaw-workspace",
"name": "tinyclaw-workspace"
},
"agents": {
"coder": {
"name": "Code Assistant",
"provider": "anthropic",
"model": "sonnet",
"working_directory": "/Users/me/tinyclaw-workspace/coder"
},
"writer": {
"name": "Technical Writer",
"provider": "openai",
"model": "gpt-5.3-codex",
"working_directory": "/Users/me/tinyclaw-workspace/writer"
}
}
}Each agent operates in isolation:
- Separate workspace directory -
~/tinyclaw-workspace/{agent_id}/ - Own conversation history - Maintained by CLI
- Custom configuration -
.claude/,heartbeat.md(root),AGENTS.md - Independent resets - Reset individual agent conversations
π Learn more about agents
See docs/AGENTS.md for:
- Architecture details
- Agent configuration
- Use cases and examples
- Advanced features
- Troubleshooting
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
β Message Channels β
β (Discord, Telegram, WhatsApp, Heartbeat) β
ββββββββββββββββββββββ¬βββββββββββββββββββββββββββββββββββββββββ
β Write message.json
β
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
β ~/.tinyclaw/queue/ β
β β
β incoming/ processing/ outgoing/ β
β ββ msg1.json β ββ msg1.json β ββ msg1.json β
β ββ msg2.json ββ msg2.json ββ msg2.json β
β ββ msg3.json β
β β
ββββββββββββββββββββββ¬βββββββββββββββββββββββββββββββββββββββββ
β Queue Processor
β
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
β Parallel Processing by Agent β
β β
β Agent: coder Agent: writer Agent: assistant β
β ββββββββββββ ββββββββββββ ββββββββββββ β
β β Message 1β β Message 1β β Message 1β β
β β Message 2β ... β Message 2β ... β Message 2β ... β
β β Message 3β β β β β β
β ββββββ¬ββββββ ββββββ¬ββββββ ββββββ¬ββββββ β
β β β β β
βββββββββΌβββββββββββββββββββΌββββββββββββββββββββββΌβββββββββββββ
β β β
claude CLI claude CLI claude CLI
(workspace/coder) (workspace/writer) (workspace/assistant)
Key features:
- File-based queue - Atomic operations, no race conditions
- Parallel agents - Different agents process messages concurrently
- Sequential per agent - Preserves conversation order within each agent
- Isolated workspaces - Each agent has its own directory and context
π Learn more about the queue system
See docs/QUEUE.md for:
- Detailed message flow
- Parallel processing explanation
- Performance characteristics
- Debugging tips
tinyclaw/
βββ .tinyclaw/ # TinyClaw data
β βββ settings.json # Configuration
β βββ queue/ # Message queue
β β βββ incoming/
β β βββ processing/
β β βββ outgoing/
β βββ logs/ # All logs
β βββ channels/ # Channel state
β βββ files/ # Uploaded files
β βββ pairing.json # Sender allowlist state (pending + approved)
β βββ chats/ # Team chain chat history
β β βββ {team_id}/ # Per-team chat logs
β βββ events/ # Real-time event files
β βββ .claude/ # Template for agents
β βββ heartbeat.md # Template for agents
β βββ AGENTS.md # Template for agents
βββ ~/tinyclaw-workspace/ # Agent workspaces
β βββ coder/
β β βββ .claude/
β β βββ heartbeat.md
β β βββ AGENTS.md
β βββ writer/
β βββ assistant/
βββ src/ # TypeScript sources
βββ dist/ # Compiled output
βββ lib/ # Runtime scripts
βββ scripts/ # Installation scripts
βββ tinyclaw.sh # Main script
Located at .tinyclaw/settings.json:
{
"channels": {
"enabled": ["discord", "telegram", "whatsapp"],
"discord": { "bot_token": "..." },
"telegram": { "bot_token": "..." },
"whatsapp": {}
},
"workspace": {
"path": "/Users/me/tinyclaw-workspace",
"name": "tinyclaw-workspace"
},
"agents": {
"assistant": {
"name": "Assistant",
"provider": "anthropic",
"model": "sonnet",
"working_directory": "/Users/me/tinyclaw-workspace/assistant"
}
},
"teams": {
"dev": {
"name": "Development Team",
"agents": ["coder", "reviewer"],
"leader_agent": "coder"
}
},
"monitoring": {
"heartbeat_interval": 3600
}
}Edit agent-specific heartbeat prompts:
# Edit heartbeat for specific agent
nano ~/tinyclaw-workspace/coder/heartbeat.mdDefault heartbeat prompt:
Check for:
1. Pending tasks
2. Errors
3. Unread messages
Take action if needed.You: "Remind me to call mom"
Claude: "I'll remind you!"
[1 hour later via heartbeat]
Claude: "Don't forget to call mom!"
@coder Review and fix bugs in auth.ts
@writer Document the changes
@reviewer Check the documentation quality
@dev fix the auth bug
# β Routes to team leader (@coder)
# β Coder fixes bug, mentions @reviewer in response
# β Reviewer automatically invoked, reviews changes
# β Combined response sent back to user
Teams support sequential chains (single handoff) and parallel fan-out (multiple teammate mentions). See docs/TEAMS.md for details.
- WhatsApp on phone
- Discord on desktop
- Telegram anywhere
- CLI for automation
All channels share agent conversations!
- AGENTS.md - Agent management and routing
- TEAMS.md - Team collaboration, chain execution, and visualizer
- QUEUE.md - Queue system and message flow
- TROUBLESHOOTING.md - Common issues and solutions
See docs/TROUBLESHOOTING.md for detailed solutions.
Quick fixes:
# Reset everything (preserves settings)
tinyclaw stop && rm -rf .tinyclaw/queue/* && tinyclaw start
# Reset WhatsApp
tinyclaw channels reset whatsapp
# Check status
tinyclaw status
# View logs
tinyclaw logs allCommon issues:
- Bash version error β Install bash 4.0+:
brew install bash - WhatsApp not connecting β Reset auth:
tinyclaw channels reset whatsapp - Messages stuck β Clear queue:
rm -rf .tinyclaw/queue/processing/* - Agent not found β Check:
tinyclaw agent list
Need help?
- GitHub Issues
- Check logs:
tinyclaw logs all
- Inspired by OpenClaw by Peter Steinberger
- Built on Claude Code and Codex CLI
- Uses discord.js, whatsapp-web.js, node-telegram-bot-api
MIT
TinyClaw - Tiny but mighty! π¦β¨