mcp-notifications
Enables sending real-time and webhook notifications when AI agents complete tasks, with support for Discord, Slack, Teams, Feishu, Ntfy, and custom webhooks.
README
MCP Notifications
This project is a spiritual successor to the original
mcp-server-notifierby tuberrabbit@gmail.com, and has been significantly rewritten and is now maintained by zudsniper.
A modern, scalable notification service that integrates with MCP (Model Context Protocol) to send real-time notifications and webhooks when AI agents complete tasks. Now featuring a monorepo architecture with SSE (Server-Sent Events) support, Next.js web interface, and PocketBase integration.

🚀 What's New in v3.0
- Monorepo Architecture: Organized as a workspace with separate apps and packages
- SSE Server: Real-time notifications via Server-Sent Events (Cloudflare Worker with Durable Objects)
- Web Dashboard: Next.js-based interface for monitoring and managing notifications
- PocketBase Integration: Persistent storage for webhooks, connections, and notification history
- Enhanced Provider Support: Improved webhook formatting for all major platforms
- Rate Limiting: Built-in rate limiting with KV storage
- Connection Management: Automatic cleanup and heartbeat for SSE connections
- TypeScript Throughout: Full TypeScript support with shared types package
Features
- Real-time Notifications: SSE-based push notifications for instant updates
- Webhook Notifications: Receive alerts when your AI agents complete tasks
- Multiple Webhook Providers: Support for Discord, Slack, Microsoft Teams, Feishu, Ntfy, and custom webhooks
- Image Support: Include images in notifications via Imgur
- Multi-Project Support: Efficiently manage notifications across different projects
- Easy Integration: Simple setup with AI tools like Cursor
- Customizable Messages: Send personalized notifications with title, body, and links
- Discord Embed Support: Send rich, customizable Discord embed notifications
- NTFY Template Support: Use pre-defined templates for status, questions, progress, and problems
- Notification History: Track all notifications with PocketBase storage
- Fallback Support: Configure backup webhooks for critical notifications
- Queue Processing: Reliable webhook delivery with queue-based processing
Architecture
The v3.0 architecture consists of multiple components working together:
- SSE Server (Cloudflare Worker): Manages real-time connections using Durable Objects
- Web Dashboard (Next.js): User interface for monitoring and configuration
- PocketBase: Persistent storage for webhooks, templates, and history
- Queue System: Reliable webhook delivery with retry logic
- Legacy MCP Server: Backward compatibility for existing integrations
Data Flow
User/AI Agent → SSE Server → Queue → Webhook Provider
↓ ↓
PocketBase Rate Limiter
↓
Web Dashboard
Project Structure
This is a monorepo organized with npm workspaces:
mcp-notifications/
├── apps/
│ ├── sse-server/ # Cloudflare Worker for SSE connections
│ └── web/ # Next.js dashboard
├── packages/
│ └── shared/ # Shared types and utilities
├── legacy/ # Legacy MCP server implementation
└── pocketbase/ # PocketBase schema and migrations
Installation
For Development
# Clone the repository
git clone https://github.com/zudsniper/mcp-notifications.git
cd mcp-notifications
# Install dependencies for all workspaces
npm install
# Build all packages
npm run build
Deploy SSE Server (Cloudflare Worker)
cd apps/sse-server
npm run deploy
Run Web Dashboard
cd apps/web
npm run dev
Legacy MCP Server
The original MCP server is still available in the legacy/ directory:
cd legacy
npm install
npm run build
Integration
SSE Client Integration
Connect to the SSE server from your application:
import { SSEClient } from '@mcp-notifications/shared';
const client = new SSEClient({
userId: 'user-123',
sseServerUrl: 'https://your-worker.workers.dev',
onNotification: (notification) => {
console.log('Received notification:', notification);
},
onConnectionStatus: (status) => {
console.log('Connection status:', status);
}
});
client.connect();
API Endpoints
Send notifications via the REST API:
curl -X POST https://your-worker.workers.dev/api/notify \
-H "Content-Type: application/json" \
-d '{
"userId": "user-123",
"message": {
"title": "Task Complete",
"body": "Your AI agent finished processing"
},
"webhookConfig": {
"type": "discord",
"url": "https://discord.com/api/webhooks/..."
}
}'
Legacy Cursor Integration
For the legacy MCP server:
{
"mcpServers": {
"notifier": {
"command": "node",
"args": [
"/path/to/legacy/build/index.js"
],
"env": {
"WEBHOOK_URL": "https://ntfy.sh/webhook-url-example",
"WEBHOOK_TYPE": "ntfy"
}
}
}
}
## Configuration
### SSE Server Configuration (Cloudflare Worker)
Configure in `apps/sse-server/wrangler.toml`:
```toml
name = "mcp-notifications-sse"
main = "src/index.ts"
compatibility_date = "2024-01-01"
[durable_objects]
bindings = [{ name = "SSE_CONNECTION_MANAGER", class_name = "SSEConnectionManager" }]
[[kv_namespaces]]
binding = "RATE_LIMIT_KV"
id = "your-kv-namespace-id"
[[queues.producers]]
binding = "WEBHOOK_QUEUE"
queue = "webhook-notifications"
[vars]
POCKETBASE_URL = "https://your-pocketbase-instance.com"
Web Dashboard Configuration
Configure in apps/web/.env.local:
NEXT_PUBLIC_SSE_SERVER_URL=https://your-worker.workers.dev
NEXT_PUBLIC_POCKETBASE_URL=https://your-pocketbase-instance.com
PocketBase Setup
- Deploy PocketBase instance
- Import schema:
pocketbase/pb_schema.json - Run migrations for initial templates
Supported Webhook Types
- Discord: Rich embeds with colors and fields
- Slack: Blocks and attachments
- Microsoft Teams: Adaptive cards
- Feishu: Interactive cards
- Ntfy: Priority levels and actions
- Generic JSON: Custom webhook format
Legacy Configuration
For the legacy MCP server, create legacy/webhook-config.json:
{
"webhook": {
"type": "discord",
"url": "https://discord.com/api/webhooks/your-webhook-url",
"name": "My Notifier"
},
"imgur": {
"clientId": "your-imgur-client-id"
}
}
See the Configuration Guide for full details and examples.
Usage
For detailed usage instructions, see the Usage Guide.
Available Tools
This package provides two tools for sending notifications:
notify- for simple notifications.full_notify- for more advanced notifications with all features.
notify
Send a simple notification with body, optional title, and optional template.
Input:
body: The main content of the notification message.title(optional): The title for the notification.template(optional): A predefined template to use (e.g., 'status', 'question', 'progress', 'problem').
Example:
// AI agent call
await run("notify", {
title: "Task Completed",
body: "I have finished the task."
});
full_notify
Send a detailed notification with advanced options like a link, image, priority, attachments, actions, and template data.
Input:
body: The main content of the notification message.title(optional): The title for the notification.link(optional): A URL to include in the notification.imageUrl(optional): The URL of an image to include.image(optional): The local file path for an image to upload to Imgur.priority(optional, ntfy only): Notification priority level from 1-5 (5 is the highest).attachments(optional, ntfy only): A list of URLs to attach to the notification.template(optional): A predefined template to use.templateData(optional): Data to be used with the selected template.actions(optional, ntfy only): Interactive action buttons for the notification.
Example:
// AI agent call
await run("full_notify", {
title: "Server Alert",
body: "Disk usage is high!",
priority: 5,
actions: [
{
action: "view",
label: "Open Grafana",
url: "https://grafana.example.com/d/abcdefg"
}
]
});
NTFY Templates
When using ntfy.sh as your webhook provider, you can use the following predefined templates with the template and templateData parameters:
status: For sending status updates.question: For asking questions.progress: For tracking the progress of long-running tasks.problem: For reporting errors or issues.
See docs/NOTIFICATIONS.md for more details on templates.
Development
Setting Up Development Environment
- Clone the repository:
git clone https://github.com/zudsniper/mcp-notifications.git
cd mcp-notifications
- Install dependencies for all workspaces:
npm install
- Build all packages:
npm run build
Development Commands
# Run SSE server locally
cd apps/sse-server
npm run dev
# Run web dashboard
cd apps/web
npm run dev
# Build shared package
cd packages/shared
npm run build
# Test legacy server
cd legacy
npm run test
Testing Webhooks
Test scripts are available in legacy/src/:
test-discord.js- Test Discord webhookstest-ntfy.js- Test ntfy notificationstest-slack.js- Test Slack webhooks
Deployment
Deploy SSE Server to Cloudflare
cd apps/sse-server
npm run deploy
Deploy Web Dashboard to Vercel
cd apps/web
vercel
Migration Guide
Migrating from v2.x to v3.0
- Legacy Support: The original MCP server is still available in
legacy/directory - New Features: Consider adopting SSE for real-time notifications
- Database: Set up PocketBase for persistent storage
- API Changes: Update API calls to use new endpoints
See MIGRATION.md for detailed migration instructions.
Performance
- SSE Connections: Support for thousands of concurrent connections via Durable Objects
- Rate Limiting: Built-in protection against abuse (10 requests/minute default)
- Queue Processing: Reliable webhook delivery with automatic retries
- Edge Computing: Global distribution via Cloudflare Workers
Security
- Authentication: Token-based auth for ntfy webhooks
- Rate Limiting: KV-based rate limiting per user
- CORS: Configurable CORS headers for web clients
- Input Validation: Zod schemas for all API inputs
License
MIT License - see LICENSE file for details.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Acknowledgments
- Original
mcp-server-notifierby tuberrabbit@gmail.com - Maintained and enhanced by zudsniper
- Built with Cloudflare Workers, Next.js, and PocketBase
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.