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
Bridges web applications to messaging protocols (IRC, XMPP, RSS/Atom) via ActivityStreams. Use when building chat clients, connecting to IRC channels, sending XMPP messages, fetching RSS feeds, or creating protocol-agnostic messaging applications. --- name: sockethub description: Bridges web applications to messaging protocols (IRC, XMPP, RSS/Atom) via ActivityStreams. Use when building chat clients, connecting to IRC channels, sending XMPP messages, fetching RSS feeds, or creating protocol-agnostic messaging applications. --- Sockethub A polyglot messaging gateway that translates ActivityStreams messages to protocol-specific formats, enabling browser JavaScri Published capability contract available. No trust telemetry is available yet. 392 GitHub stars reported by the source. Last updated 2/24/2026.
Freshness
Last checked 2/22/2026
Best For
Contract is available with explicit auth and schema references.
Not Ideal For
sockethub 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
Bridges web applications to messaging protocols (IRC, XMPP, RSS/Atom) via ActivityStreams. Use when building chat clients, connecting to IRC channels, sending XMPP messages, fetching RSS feeds, or creating protocol-agnostic messaging applications. --- name: sockethub description: Bridges web applications to messaging protocols (IRC, XMPP, RSS/Atom) via ActivityStreams. Use when building chat clients, connecting to IRC channels, sending XMPP messages, fetching RSS feeds, or creating protocol-agnostic messaging applications. --- Sockethub A polyglot messaging gateway that translates ActivityStreams messages to protocol-specific formats, enabling browser JavaScri
Public facts
7
Change events
1
Artifacts
0
Freshness
Feb 22, 2026
Published capability contract available. No trust telemetry is available yet. 392 GitHub stars reported by the source. Last updated 2/24/2026.
Trust score
Unknown
Compatibility
OpenClaw
Freshness
Feb 22, 2026
Vendor
Sockethub
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. 392 GitHub stars reported by the source. Last updated 2/24/2026.
Setup snapshot
git clone https://github.com/sockethub/sockethub.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
Sockethub
Protocol compatibility
OpenClaw
Auth modes
api_key
Machine-readable schemas
OpenAPI or schema references published
Adoption signal
392 GitHub stars
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
bash
# Install globally bun add -g sockethub@alpha # Start server (requires Redis) sockethub --port 10550 # Or run with Docker docker run -d --name redis redis sockethub
javascript
import SockethubClient from '@sockethub/client';
import { io } from 'socket.io-client';
const socket = io('http://localhost:10550', { path: '/sockethub' });
const sc = new SockethubClient(socket);
// Listen for messages
sc.socket.on('message', (msg) => console.log(msg));
// Send ActivityStreams message
sc.socket.emit('message', {
context: 'irc',
type: 'send',
actor: 'myuser@irc.libera.chat',
target: { id: '#channel@irc.libera.chat', type: 'room' },
object: { type: 'Note', content: 'Hello!' }
});javascript
// Set credentials
sc.socket.emit('credentials', {
context: 'irc',
type: 'credentials',
actor: { id: 'mynick@irc.libera.chat' },
object: {
type: 'credentials',
nick: 'mynick',
server: 'irc.libera.chat',
port: 6697,
secure: true
}
});
// Connect
sc.socket.emit('message', {
context: 'irc',
type: 'connect',
actor: 'mynick@irc.libera.chat'
});
// Join channel
sc.socket.emit('message', {
context: 'irc',
type: 'join',
actor: 'mynick@irc.libera.chat',
target: { id: '#sockethub@irc.libera.chat', type: 'room' }
});javascript
// Set XMPP credentials
sc.socket.emit('credentials', {
context: 'xmpp',
type: 'credentials',
actor: { id: 'user@jabber.org' },
object: {
type: 'credentials',
userAddress: 'user@jabber.org',
password: 'secret',
resource: 'web'
}
});
// Connect and send
sc.socket.emit('message', {
context: 'xmpp',
type: 'connect',
actor: 'user@jabber.org'
});
sc.socket.emit('message', {
context: 'xmpp',
type: 'send',
actor: 'user@jabber.org',
target: { id: 'friend@jabber.org', type: 'person' },
object: { type: 'Note', content: 'Hello from Sockethub!' }
});javascript
sc.socket.emit('message', {
context: 'feeds',
type: 'fetch',
actor: { id: 'https://example.com/feed.rss' }
});
// Response is a Collection of Create activities with feed entries
sc.socket.on('message', (msg) => {
if (msg.context === 'feeds') {
msg.object.items.forEach(entry => {
console.log(entry.object.title, entry.object.url);
});
}
});text
sockethub [options] Options: --port <number> Server port (default: 10550, env: PORT) --host <string> Server host (default: localhost, env: HOST) --config, -c <path> Path to sockethub.config.json --examples Enable example pages at /examples --info Display runtime information --redis.url <url> Redis connection URL (env: REDIS_URL) --sentry.dsn <dsn> Sentry DSN for error reporting Environment Variables: PORT Server port HOST Server hostname REDIS_URL Redis connection string DEBUG Debug namespaces (e.g., sockethub*)
Full documentation captured from public sources, including the complete README when available.
Docs source
GITHUB OPENCLEW
Editorial quality
ready
Bridges web applications to messaging protocols (IRC, XMPP, RSS/Atom) via ActivityStreams. Use when building chat clients, connecting to IRC channels, sending XMPP messages, fetching RSS feeds, or creating protocol-agnostic messaging applications. --- name: sockethub description: Bridges web applications to messaging protocols (IRC, XMPP, RSS/Atom) via ActivityStreams. Use when building chat clients, connecting to IRC channels, sending XMPP messages, fetching RSS feeds, or creating protocol-agnostic messaging applications. --- Sockethub A polyglot messaging gateway that translates ActivityStreams messages to protocol-specific formats, enabling browser JavaScri
A polyglot messaging gateway that translates ActivityStreams messages to protocol-specific formats, enabling browser JavaScript to communicate with IRC, XMPP, and feed services.
Invoke when you need to:
# Install globally
bun add -g sockethub@alpha
# Start server (requires Redis)
sockethub --port 10550
# Or run with Docker
docker run -d --name redis redis
sockethub
import SockethubClient from '@sockethub/client';
import { io } from 'socket.io-client';
const socket = io('http://localhost:10550', { path: '/sockethub' });
const sc = new SockethubClient(socket);
// Listen for messages
sc.socket.on('message', (msg) => console.log(msg));
// Send ActivityStreams message
sc.socket.emit('message', {
context: 'irc',
type: 'send',
actor: 'myuser@irc.libera.chat',
target: { id: '#channel@irc.libera.chat', type: 'room' },
object: { type: 'Note', content: 'Hello!' }
});
// Set credentials
sc.socket.emit('credentials', {
context: 'irc',
type: 'credentials',
actor: { id: 'mynick@irc.libera.chat' },
object: {
type: 'credentials',
nick: 'mynick',
server: 'irc.libera.chat',
port: 6697,
secure: true
}
});
// Connect
sc.socket.emit('message', {
context: 'irc',
type: 'connect',
actor: 'mynick@irc.libera.chat'
});
// Join channel
sc.socket.emit('message', {
context: 'irc',
type: 'join',
actor: 'mynick@irc.libera.chat',
target: { id: '#sockethub@irc.libera.chat', type: 'room' }
});
// Set XMPP credentials
sc.socket.emit('credentials', {
context: 'xmpp',
type: 'credentials',
actor: { id: 'user@jabber.org' },
object: {
type: 'credentials',
userAddress: 'user@jabber.org',
password: 'secret',
resource: 'web'
}
});
// Connect and send
sc.socket.emit('message', {
context: 'xmpp',
type: 'connect',
actor: 'user@jabber.org'
});
sc.socket.emit('message', {
context: 'xmpp',
type: 'send',
actor: 'user@jabber.org',
target: { id: 'friend@jabber.org', type: 'person' },
object: { type: 'Note', content: 'Hello from Sockethub!' }
});
sc.socket.emit('message', {
context: 'feeds',
type: 'fetch',
actor: { id: 'https://example.com/feed.rss' }
});
// Response is a Collection of Create activities with feed entries
sc.socket.on('message', (msg) => {
if (msg.context === 'feeds') {
msg.object.items.forEach(entry => {
console.log(entry.object.title, entry.object.url);
});
}
});
sockethub [options]
Options:
--port <number> Server port (default: 10550, env: PORT)
--host <string> Server host (default: localhost, env: HOST)
--config, -c <path> Path to sockethub.config.json
--examples Enable example pages at /examples
--info Display runtime information
--redis.url <url> Redis connection URL (env: REDIS_URL)
--sentry.dsn <dsn> Sentry DSN for error reporting
Environment Variables:
PORT Server port
HOST Server hostname
REDIS_URL Redis connection string
DEBUG Debug namespaces (e.g., sockethub*)
irc): connect, join, leave, send, update, query, disconnectxmpp): connect, join, leave, send, update, request-friend, make-friend,
remove-friend, query, disconnectfeeds): fetch (RSS 2.0, Atom 1.0, RSS 1.0/RDF)metadata): fetch (Open Graph and page metadata)All messages follow ActivityStreams 2.0 structure:
{
context: 'irc' | 'xmpp' | 'feeds', // Platform identifier
type: 'send' | 'join' | 'connect', // Action type
actor: { id: 'user@server', type: 'person' }, // Who is acting
target: { id: 'room@server', type: 'room' }, // Target of action
object: { type: 'Note', content: '...' } // Payload
}
If actor is provided as a string, Sockethub expands it using any previously
saved ActivityObject with the same id (including type and any other stored
properties). If none exists, it expands to { id }.
import SockethubClient from '@sockethub/client';
const sc = new SockethubClient(socket);
// Properties
sc.socket // Underlying Socket.IO instance
sc.ActivityStreams // ActivityStreams helper library
// Methods
sc.clearCredentials() // Remove stored credentials
// Events
sc.socket.on('message', handler) // Incoming messages
sc.socket.on('completed', handler) // Job completion
sc.socket.on('failed', handler) // Job failure
sc.socket.emit('message', activity) // Send message
sc.socket.emit('credentials', creds) // Set credentials
{
type: 'credentials',
nick: 'nickname',
server: 'irc.libera.chat',
port: 6697,
secure: true,
password: 'optional',
sasl: false
}
{
type: 'credentials',
userAddress: 'user@domain',
password: 'secret',
resource: 'device-identifier'
}
@sockethub/client - Browser/Node client library@sockethub/server - Core server implementation@sockethub/activity-streams - ActivityStreams utilities@sockethub/platform-irc - IRC platform@sockethub/platform-xmpp - XMPP platform@sockethub/platform-feeds - RSS/Atom platformMachine endpoints, protocol fit, contract coverage, invocation examples, and guardrails for agent-to-agent use.
Contract coverage
Status
ready
Auth
api_key
Streaming
Yes
Data region
global
Protocol support
Requires: openclew, lang:typescript, streaming
Forbidden: none
Guardrails
Operational confidence: medium
curl -s "https://xpersona.co/api/v1/agents/sockethub-sockethub/snapshot"
curl -s "https://xpersona.co/api/v1/agents/sockethub-sockethub/contract"
curl -s "https://xpersona.co/api/v1/agents/sockethub-sockethub/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",
"streaming"
],
"forbidden": [],
"supportsMcp": false,
"supportsA2a": false,
"supportsStreaming": true,
"inputSchemaRef": "https://github.com/sockethub/sockethub#input",
"outputSchemaRef": "https://github.com/sockethub/sockethub#output",
"dataRegion": "global",
"contractUpdatedAt": "2026-02-24T19:44:02.923Z",
"sourceUpdatedAt": "2026-02-24T19:44:02.923Z",
"freshnessSeconds": 4420128
}Invocation Guide
{
"preferredApi": {
"snapshotUrl": "https://xpersona.co/api/v1/agents/sockethub-sockethub/snapshot",
"contractUrl": "https://xpersona.co/api/v1/agents/sockethub-sockethub/contract",
"trustUrl": "https://xpersona.co/api/v1/agents/sockethub-sockethub/trust"
},
"curlExamples": [
"curl -s \"https://xpersona.co/api/v1/agents/sockethub-sockethub/snapshot\"",
"curl -s \"https://xpersona.co/api/v1/agents/sockethub-sockethub/contract\"",
"curl -s \"https://xpersona.co/api/v1/agents/sockethub-sockethub/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:32:51.177Z"
}
},
"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"
}
],
"flattenedTokens": "protocol:OPENCLEW|unknown|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": "protocols",
"category": "compatibility",
"label": "Protocol compatibility",
"value": "OpenClaw",
"href": "https://xpersona.co/api/v1/agents/sockethub-sockethub/contract",
"sourceUrl": "https://xpersona.co/api/v1/agents/sockethub-sockethub/contract",
"sourceType": "contract",
"confidence": "medium",
"observedAt": "2026-02-24T19:44:02.923Z",
"isPublic": true
},
{
"factKey": "auth_modes",
"category": "compatibility",
"label": "Auth modes",
"value": "api_key",
"href": "https://xpersona.co/api/v1/agents/sockethub-sockethub/contract",
"sourceUrl": "https://xpersona.co/api/v1/agents/sockethub-sockethub/contract",
"sourceType": "contract",
"confidence": "high",
"observedAt": "2026-02-24T19:44:02.923Z",
"isPublic": true
},
{
"factKey": "schema_refs",
"category": "artifact",
"label": "Machine-readable schemas",
"value": "OpenAPI or schema references published",
"href": "https://github.com/sockethub/sockethub#input",
"sourceUrl": "https://xpersona.co/api/v1/agents/sockethub-sockethub/contract",
"sourceType": "contract",
"confidence": "high",
"observedAt": "2026-02-24T19:44:02.923Z",
"isPublic": true
},
{
"factKey": "vendor",
"category": "vendor",
"label": "Vendor",
"value": "Sockethub",
"href": "https://github.com/sockethub/sockethub",
"sourceUrl": "https://github.com/sockethub/sockethub",
"sourceType": "profile",
"confidence": "medium",
"observedAt": "2026-02-24T19:43:14.176Z",
"isPublic": true
},
{
"factKey": "traction",
"category": "adoption",
"label": "Adoption signal",
"value": "392 GitHub stars",
"href": "https://github.com/sockethub/sockethub",
"sourceUrl": "https://github.com/sockethub/sockethub",
"sourceType": "profile",
"confidence": "medium",
"observedAt": "2026-02-24T19:43:14.176Z",
"isPublic": true
},
{
"factKey": "handshake_status",
"category": "security",
"label": "Handshake status",
"value": "UNKNOWN",
"href": "https://xpersona.co/api/v1/agents/sockethub-sockethub/trust",
"sourceUrl": "https://xpersona.co/api/v1/agents/sockethub-sockethub/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 sockethub and adjacent AI workflows.