Gives Claude direct access to Pusher Channels for realtime messaging. You get seven tools covering the main operations: trigger single or batch events, list active channels with prefix filtering, query subscription and user counts, fetch presence channel users, generate auth tokens for private channels, and terminate user connections. Authentication requires your Pusher app credentials from the dashboard. Useful when you want Claude to send notifications to connected clients, monitor channel activity, or manage websocket connections without writing custom API wrappers. The batch trigger endpoint lets you send up to 10 events in one call for efficiency.
An MCP (Model Context Protocol) server that gives AI agents the ability to send realtime messages, query channels, and manage users through Pusher Channels.
| Tool | Description |
|---|---|
trigger_event | Send an event to one or more channels |
trigger_batch_events | Send up to 10 events in a single API call |
list_channels | List active channels with optional prefix filter |
get_channel_info | Get subscription/user count for a channel |
get_presence_users | List users connected to a presence channel |
authorize_channel | Generate auth tokens for private/presence channels |
terminate_user_connections | Disconnect all connections for a user |
npm install -g @crashbytes/pusher-mcp-server
Or clone and build from source:
git clone https://github.com/CrashBytes/pusher-mcp-server.git
cd pusher-mcp-server
npm install
npm run build
You need four environment variables from your Pusher dashboard:
| Variable | Description |
|---|---|
PUSHER_APP_ID | Your Pusher app ID |
PUSHER_KEY | Your Pusher app key |
PUSHER_SECRET | Your Pusher app secret |
PUSHER_CLUSTER | Your Pusher cluster (e.g. us2, eu, ap1) |
Add the following to your Claude Desktop config file:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"pusher": {
"command": "node",
"args": ["/path/to/pusher-mcp-server/build/index.js"],
"env": {
"PUSHER_APP_ID": "your_app_id",
"PUSHER_KEY": "your_app_key",
"PUSHER_SECRET": "your_app_secret",
"PUSHER_CLUSTER": "us2"
}
}
}
}
If installed globally via npm:
{
"mcpServers": {
"pusher": {
"command": "pusher-mcp-server",
"env": {
"PUSHER_APP_ID": "your_app_id",
"PUSHER_KEY": "your_app_key",
"PUSHER_SECRET": "your_app_secret",
"PUSHER_CLUSTER": "us2"
}
}
}
}
claude mcp add pusher -- node /path/to/pusher-mcp-server/build/index.js
Set the environment variables in your shell before running, or configure them in your Claude Code MCP settings.
Once configured, you can ask Claude things like:
npm install
npm run dev # Run with tsx (hot reload)
npm run build # Compile TypeScript
npm run type-check # Check types without emitting
For a step-by-step guide on building this server from scratch, see the full tutorial on CrashBytes.
MIT
PUSHER_APP_ID*Your Pusher application ID
PUSHER_KEY*Your Pusher application key
PUSHER_SECRET*secretYour Pusher application secret
PUSHER_CLUSTER*Pusher cluster region (e.g. us2, eu, ap1)
io.github.mindstone/mcp-server-microsoft-teams
com.mintmcp/outlook-email
helbertparanhos/resend-email-mcp
marlinjai/email-mcp
io.github.mindstone/mcp-server-email-imap
io.github.osamahassouna/email-playbook-mcp