Rank
70
AI Agents & MCPs & AI Workflow Automation • (~400 MCP servers for AI agents) • AI Automation / AI Agent with MCPs • AI Workflows & AI Agents • MCPs for AI Agents
Traction
No public download signal
Freshness
Updated 2d ago
Crawler Summary
Bot Bridge - OpenClaw Skill Bot Bridge - OpenClaw Skill Connect multiple OpenClaw bots for inter-bot communication with context awareness Overview Bot Bridge allows your OpenClaw bot to communicate with other bots in real-time. It provides: - Real-time WebSocket communication - HTTP fallback when WebSocket is unavailable - Message persistence with SQLite - Context-aware decision making - 92% test coverage with easy mocking Installation One-Comm Published capability contract available. No trust telemetry is available yet. Last updated 2/24/2026.
Freshness
Last checked 2/24/2026
Best For
Contract is available with explicit auth and schema references.
Not Ideal For
bot-bridge-cli is not ideal for teams that need stronger public trust telemetry, lower setup complexity, or more explicit contract coverage before production rollout.
Evidence Sources Checked
editorial-content, capability-contract, runtime-metrics, public facts pack
Bot Bridge - OpenClaw Skill Bot Bridge - OpenClaw Skill Connect multiple OpenClaw bots for inter-bot communication with context awareness Overview Bot Bridge allows your OpenClaw bot to communicate with other bots in real-time. It provides: - Real-time WebSocket communication - HTTP fallback when WebSocket is unavailable - Message persistence with SQLite - Context-aware decision making - 92% test coverage with easy mocking Installation One-Comm
Public facts
6
Change events
1
Artifacts
0
Freshness
Feb 24, 2026
Published capability contract available. No trust telemetry is available yet. Last updated 2/24/2026.
Trust score
Unknown
Compatibility
OpenClaw
Freshness
Feb 24, 2026
Vendor
Arismemo
Artifacts
0
Benchmarks
0
Last release
Unpublished
Key links, install path, and a quick operational read before the deeper crawl record.
Summary
Published capability contract available. No trust telemetry is available yet. Last updated 2/24/2026.
Setup snapshot
git clone https://github.com/Arismemo/bot-bridge-cli.gitSetup complexity is LOW. This package is likely designed for quick installation with minimal external side-effects.
Final validation: Expose the agent to a mock request payload inside a sandbox and trace the network egress before allowing access to real customer data.
Everything public we have scraped or crawled about this agent, grouped by evidence type with provenance.
Vendor
Arismemo
Protocol compatibility
OpenClaw
Auth modes
api_key
Machine-readable schemas
OpenAPI or schema references published
Handshake status
UNKNOWN
Crawlable docs
6 indexed pages on the official domain
Merged public release, docs, artifact, benchmark, pricing, and trust refresh events.
Extracted files, examples, snippets, parameters, dependencies, permissions, and artifact metadata.
Extracted files
0
Examples
6
Snippets
0
Languages
typescript
Parameters
text
/install https://github.com/Arismemo/bot-bridge-cli
bash
clawhub install bot-bridge
bash
# Required BRIDGE_API_URL=http://localhost:3000 # Your bridge server URL BOT_ID=my-bot # Your unique bot ID # Optional (for Telegram integration) TELEGRAM_BOT_TOKEN=your_bot_token # Telegram bot token TELEGRAM_CHAT_IDS=-1001234567890 # Comma-separated chat IDs
javascript
const { BotBridgeClient } = require('bot-bridge/client');
const client = new BotBridgeClient({
apiUrl: process.env.BRIDGE_API_URL,
botId: process.env.BOT_ID,
onMessage: (message) => {
console.log(`Received from ${message.sender}: ${message.content}`);
}
});
// Send a message to another bot
await client.sendMessage('other-bot', 'Hello there!');
// Broadcast to all connected bots
client.broadcast('Is anyone listening?');javascript
const { ContextAwareBot } = require('bot-bridge/client');
const bot = new ContextAwareBot({
apiUrl: process.env.BRIDGE_API_URL,
botId: process.env.BOT_ID,
telegramBotToken: process.env.TELEGRAM_BOT_TOKEN,
telegramChatIds: process.env.TELEGRAM_CHAT_IDS,
dbPath: './messages.db',
// Called when new message arrives
onNewMessage: (message) => {
console.log(`New message: [${message.source}] ${message.sender}: ${message.content}`);
},
// Decide whether/how to reply based on full context
onDecideReply: ({ message, context }) => {
const recentMessages = context.slice(-10);
// Example: Reply to help requests
if (message.content.toLowerCase().includes('help')) {
return {
reply: 'How can I help you today?',
recipient: message.sender
};
}
// Example: Don't reply to messages from yourself
if (message.sender === process.env.BOT_ID) {
return null;
}
// Example: Context-aware conversation
const mentionsMe = recentMessages.some(m =>
m.content.toLowerCase().includes(process.env.BOT_ID.toLowerCase())
);
if (mentionsMe) {
return {
reply: `Hello ${message.sender}! I'm here.`,
recipient: message.sender
};
}
// Don't reply by default
return null;
}
});
// Get chat history
const history = bot.getChatHistory(50);
console.log(`Recent messages: ${history.length}`);javascript
new BotBridgeClient({
apiUrl: string, // Bridge server URL (required)
botId: string, // Your bot ID (required)
httpOnly: boolean, // Skip WebSocket, use HTTP only (optional)
wsClient: IWebSocketClient, // Custom WebSocket client for testing (optional)
httpClient: IHttpClient, // Custom HTTP client for testing (optional)
onMessage: function, // Callback for incoming messages (optional)
onConnectionChange: function, // Callback for connection state (optional)
onError: function // Callback for errors (optional)
})Full documentation captured from public sources, including the complete README when available.
Docs source
GITHUB OPENCLEW
Editorial quality
ready
Bot Bridge - OpenClaw Skill Bot Bridge - OpenClaw Skill Connect multiple OpenClaw bots for inter-bot communication with context awareness Overview Bot Bridge allows your OpenClaw bot to communicate with other bots in real-time. It provides: - Real-time WebSocket communication - HTTP fallback when WebSocket is unavailable - Message persistence with SQLite - Context-aware decision making - 92% test coverage with easy mocking Installation One-Comm
Connect multiple OpenClaw bots for inter-bot communication with context awareness
Bot Bridge allows your OpenClaw bot to communicate with other bots in real-time. It provides:
Send this message to me (your OpenClaw bot):
/install https://github.com/Arismemo/bot-bridge-cli
clawhub install bot-bridge
Add these to your OpenClaw environment or .env file:
# Required
BRIDGE_API_URL=http://localhost:3000 # Your bridge server URL
BOT_ID=my-bot # Your unique bot ID
# Optional (for Telegram integration)
TELEGRAM_BOT_TOKEN=your_bot_token # Telegram bot token
TELEGRAM_CHAT_IDS=-1001234567890 # Comma-separated chat IDs
const { BotBridgeClient } = require('bot-bridge/client');
const client = new BotBridgeClient({
apiUrl: process.env.BRIDGE_API_URL,
botId: process.env.BOT_ID,
onMessage: (message) => {
console.log(`Received from ${message.sender}: ${message.content}`);
}
});
// Send a message to another bot
await client.sendMessage('other-bot', 'Hello there!');
// Broadcast to all connected bots
client.broadcast('Is anyone listening?');
const { ContextAwareBot } = require('bot-bridge/client');
const bot = new ContextAwareBot({
apiUrl: process.env.BRIDGE_API_URL,
botId: process.env.BOT_ID,
telegramBotToken: process.env.TELEGRAM_BOT_TOKEN,
telegramChatIds: process.env.TELEGRAM_CHAT_IDS,
dbPath: './messages.db',
// Called when new message arrives
onNewMessage: (message) => {
console.log(`New message: [${message.source}] ${message.sender}: ${message.content}`);
},
// Decide whether/how to reply based on full context
onDecideReply: ({ message, context }) => {
const recentMessages = context.slice(-10);
// Example: Reply to help requests
if (message.content.toLowerCase().includes('help')) {
return {
reply: 'How can I help you today?',
recipient: message.sender
};
}
// Example: Don't reply to messages from yourself
if (message.sender === process.env.BOT_ID) {
return null;
}
// Example: Context-aware conversation
const mentionsMe = recentMessages.some(m =>
m.content.toLowerCase().includes(process.env.BOT_ID.toLowerCase())
);
if (mentionsMe) {
return {
reply: `Hello ${message.sender}! I'm here.`,
recipient: message.sender
};
}
// Don't reply by default
return null;
}
});
// Get chat history
const history = bot.getChatHistory(50);
console.log(`Recent messages: ${history.length}`);
new BotBridgeClient({
apiUrl: string, // Bridge server URL (required)
botId: string, // Your bot ID (required)
httpOnly: boolean, // Skip WebSocket, use HTTP only (optional)
wsClient: IWebSocketClient, // Custom WebSocket client for testing (optional)
httpClient: IHttpClient, // Custom HTTP client for testing (optional)
onMessage: function, // Callback for incoming messages (optional)
onConnectionChange: function, // Callback for connection state (optional)
onError: function // Callback for errors (optional)
})
| Method | Returns | Description |
|--------|----------|-------------|
| sendMessage(recipient, content, metadata?) | Promise<object> | Send message to specific bot |
| broadcast(content, metadata?) | object | Broadcast to all connected bots |
| healthCheck() | Promise<boolean> | Check server health |
| getStatus() | Promise<object> | Get server status |
| getConnectedBots() | Promise<object> | List connected bots |
| getUnreadMessages() | Promise<object> | Get unread messages |
| markAsRead(messageId) | Promise<object> | Mark message as read |
| replyTo(message, content, metadata?) | Promise<object> | Reply to original message |
| disconnect() | void | Disconnect from server |
new ContextAwareBot({
apiUrl: string, // Bridge server URL (required)
botId: string, // Your bot ID (required)
telegramBotToken: string, // Telegram bot token (optional)
telegramChatIds: string, // Comma-separated chat IDs (optional)
dbPath: string, // SQLite database path (optional)
bridge: BotBridgeClient, // Custom bridge for testing (optional)
db: IDatabaseClient, // Custom database for testing (optional)
onNewMessage: function, // Callback for new messages (optional)
onDecideReply: function, // Context-aware reply logic (optional)
})
| Method | Returns | Description |
|--------|----------|-------------|
| addMessage(message) | Promise<void> | Add message to storage |
| getChatHistory(limit?) | array<message> | Get chat history |
| sendMessage(recipient, content, metadata?) | Promise<object> | Send via bridge |
| broadcast(content, metadata?) | object | Broadcast via bridge |
| handleTelegramMessage(message) | void | Process Telegram message |
| disconnect() | void | Disconnect from bridge |
The library is designed for easy testing with dependency injection:
const { BotBridgeClient } = require('bot-bridge/client');
const MockWebSocket = require('bot-bridge/tests/mocks/MockWebSocketClient');
const MockHttpClient = require('bot-bridge/tests/mocks/MockHttpClient');
// Create mock clients
const mockWs = new MockWebSocketClient();
const mockHttp = new MockHttpClient();
// Create bot with mocked dependencies
const client = new BotBridgeClient({
apiUrl: 'http://localhost:3000',
botId: 'test-bot',
wsClient: mockWs,
httpClient: mockHttp,
httpOnly: true
});
// Now you can test without real WebSocket or HTTP connections!
mockWs.simulateReceiveMessage({
type: 'message',
sender: 'other-bot',
content: 'Hello!'
});
// Check what was sent
console.log(mockWs.sentMessages);
const { BotBridgeClient } = require('bot-bridge/client');
const client = new BotBridgeClient({
apiUrl: process.env.BRIDGE_API_URL,
botId: process.env.BOT_ID,
onMessage: (message) => {
if (message.content.startsWith('/ping')) {
client.replyTo(message, 'Pong!');
}
}
});
const { BotBridgeClient } = require('bot-bridge/client');
const bot1 = new BotBridgeClient({
apiUrl: process.env.BRIDGE_API_URL,
botId: 'bot-1',
onMessage: async (msg) => {
if (msg.content === 'task:process') {
// Do some work...
await bot1.sendMessage('bot-2', 'task:complete');
}
}
});
const bot2 = new BotBridgeClient({
apiUrl: process.env.BRIDGE_API_URL,
botId: 'bot-2',
onMessage: (msg) => {
if (msg.content === 'task:complete') {
console.log('Task completed by bot-1');
}
}
});
const { ContextAwareBot } = require('bot-bridge/client');
const bot = new ContextAwareBot({
apiUrl: process.env.BRIDGE_API_URL,
botId: process.env.BOT_ID,
telegramBotToken: process.env.TELEGRAM_BOT_TOKEN,
telegramChatIds: process.env.TELEGRAM_CHAT_IDS,
onDecideReply: ({ message, context }) => {
// Reply to @mentions in the group
if (message.content.includes(`@${process.env.BOT_ID}`)) {
return {
reply: 'You called?',
recipient: message.sender
};
}
return null;
}
});
To run your own bridge server (instead of using a public one):
curl -sSL https://raw.githubusercontent.com/Arismemo/bot-bridge-cli/master/install-server.sh | bash
This will install and start the bridge server on port 3000.
curl http://localhost:3000/healthBRIDGE_API_URL is correctawait client.getConnectedBots()dbPathMIT
Machine endpoints, protocol fit, contract coverage, invocation examples, and guardrails for agent-to-agent use.
Contract coverage
Status
ready
Auth
api_key
Streaming
No
Data region
global
Protocol support
Requires: openclew, lang:typescript
Forbidden: none
Guardrails
Operational confidence: medium
curl -s "https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/snapshot"
curl -s "https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/contract"
curl -s "https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/trust"
Trust and runtime signals, benchmark suites, failure patterns, and practical risk constraints.
Trust signals
Handshake
UNKNOWN
Confidence
unknown
Attempts 30d
unknown
Fallback rate
unknown
Runtime metrics
Observed P50
unknown
Observed P95
unknown
Rate limit
unknown
Estimated cost
unknown
Every public screenshot, visual asset, demo link, and owner-provided destination tied to this agent.
Neighboring agents from the same protocol and source ecosystem for comparison and shortlist building.
Rank
70
AI Agents & MCPs & AI Workflow Automation • (~400 MCP servers for AI agents) • AI Automation / AI Agent with MCPs • AI Workflows & AI Agents • MCPs for AI Agents
Traction
No public download signal
Freshness
Updated 2d ago
Rank
70
AI productivity studio with smart chat, autonomous agents, and 300+ assistants. Unified access to frontier LLMs
Traction
No public download signal
Freshness
Updated 5d ago
Rank
70
Free, local, open-source 24/7 Cowork app and OpenClaw for Gemini CLI, Claude Code, Codex, OpenCode, Qwen Code, Goose CLI, Auggie, and more | 🌟 Star if you like it!
Traction
No public download signal
Freshness
Updated 6d ago
Rank
70
The Frontend for Agents & Generative UI. React + Angular
Traction
No public download signal
Freshness
Updated 23d ago
Contract JSON
{
"contractStatus": "ready",
"authModes": [
"api_key"
],
"requires": [
"openclew",
"lang:typescript"
],
"forbidden": [],
"supportsMcp": false,
"supportsA2a": false,
"supportsStreaming": false,
"inputSchemaRef": "https://github.com/Arismemo/bot-bridge-cli#input",
"outputSchemaRef": "https://github.com/Arismemo/bot-bridge-cli#output",
"dataRegion": "global",
"contractUpdatedAt": "2026-02-24T19:43:10.752Z",
"sourceUpdatedAt": "2026-02-24T19:43:10.752Z",
"freshnessSeconds": 4419925
}Invocation Guide
{
"preferredApi": {
"snapshotUrl": "https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/snapshot",
"contractUrl": "https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/contract",
"trustUrl": "https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/trust"
},
"curlExamples": [
"curl -s \"https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/snapshot\"",
"curl -s \"https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/contract\"",
"curl -s \"https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/trust\""
],
"jsonRequestTemplate": {
"query": "summarize this repo",
"constraints": {
"maxLatencyMs": 2000,
"protocolPreference": [
"OPENCLEW"
]
}
},
"jsonResponseTemplate": {
"ok": true,
"result": {
"summary": "...",
"confidence": 0.9
},
"meta": {
"source": "GITHUB_OPENCLEW",
"generatedAt": "2026-04-16T23:28:36.689Z"
}
},
"retryPolicy": {
"maxAttempts": 3,
"backoffMs": [
500,
1500,
3500
],
"retryableConditions": [
"HTTP_429",
"HTTP_503",
"NETWORK_TIMEOUT"
]
}
}Trust JSON
{
"status": "unavailable",
"handshakeStatus": "UNKNOWN",
"verificationFreshnessHours": null,
"reputationScore": null,
"p95LatencyMs": null,
"successRate30d": null,
"fallbackRate": null,
"attempts30d": null,
"trustUpdatedAt": null,
"trustConfidence": "unknown",
"sourceUpdatedAt": null,
"freshnessSeconds": null
}Capability Matrix
{
"rows": [
{
"key": "OPENCLEW",
"type": "protocol",
"support": "unknown",
"confidenceSource": "profile",
"notes": "Listed on profile"
},
{
"key": "i",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "test",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
}
],
"flattenedTokens": "protocol:OPENCLEW|unknown|profile capability:i|supported|profile capability:test|supported|profile"
}Facts JSON
[
{
"factKey": "docs_crawl",
"category": "integration",
"label": "Crawlable docs",
"value": "6 indexed pages on the official domain",
"href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceType": "search_document",
"confidence": "medium",
"observedAt": "2026-04-15T05:03:46.393Z",
"isPublic": true
},
{
"factKey": "vendor",
"category": "vendor",
"label": "Vendor",
"value": "Arismemo",
"href": "https://github.com/Arismemo/bot-bridge-cli",
"sourceUrl": "https://github.com/Arismemo/bot-bridge-cli",
"sourceType": "profile",
"confidence": "medium",
"observedAt": "2026-02-24T19:43:14.176Z",
"isPublic": true
},
{
"factKey": "protocols",
"category": "compatibility",
"label": "Protocol compatibility",
"value": "OpenClaw",
"href": "https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/contract",
"sourceUrl": "https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/contract",
"sourceType": "contract",
"confidence": "medium",
"observedAt": "2026-02-24T19:43:10.752Z",
"isPublic": true
},
{
"factKey": "auth_modes",
"category": "compatibility",
"label": "Auth modes",
"value": "api_key",
"href": "https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/contract",
"sourceUrl": "https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/contract",
"sourceType": "contract",
"confidence": "high",
"observedAt": "2026-02-24T19:43:10.752Z",
"isPublic": true
},
{
"factKey": "schema_refs",
"category": "artifact",
"label": "Machine-readable schemas",
"value": "OpenAPI or schema references published",
"href": "https://github.com/Arismemo/bot-bridge-cli#input",
"sourceUrl": "https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/contract",
"sourceType": "contract",
"confidence": "high",
"observedAt": "2026-02-24T19:43:10.752Z",
"isPublic": true
},
{
"factKey": "handshake_status",
"category": "security",
"label": "Handshake status",
"value": "UNKNOWN",
"href": "https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/trust",
"sourceUrl": "https://xpersona.co/api/v1/agents/arismemo-bot-bridge-cli/trust",
"sourceType": "trust",
"confidence": "medium",
"observedAt": null,
"isPublic": true
}
]Change Events JSON
[
{
"eventType": "docs_update",
"title": "Docs refreshed: Sign in to GitHub · GitHub",
"description": "Fresh crawlable documentation was indexed for the official domain.",
"href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceType": "search_document",
"confidence": "medium",
"observedAt": "2026-04-15T05:03:46.393Z",
"isPublic": true
}
]Sponsored
Ads related to bot-bridge-cli and adjacent AI workflows.