Skip to main content

MCP server for Claude Desktop sound and visual notifications on macOS

Project description

Notifications MCP Server

Tests

MCP server that plays sounds and shows notifications when Claude Desktop completes tasks.

Why This Exists

You kick off a long Claude task and tab away to check email, review PRs, or write docs. Ten minutes later you realize Claude finished five minutes ago. This server fixes that. Sound plays, notification appears, you're back in action.

What It Does

Integrates with Claude Desktop to provide real-time completion feedback:

  • System Notifications - Native macOS notifications when tasks complete
  • Sound Alerts - Customizable audio feedback (success, error, warning tones)
  • Task Status - Clear indication of completion state
  • Non-Intrusive - Works in background, no polling required

Tech Stack

  • Python 3.8+
  • FastMCP for Model Context Protocol integration
  • macOS Notification Center
  • PyObjC for native system integration

Features

Notification Types

  • Success - Task completed successfully
  • Error - Task failed with error details
  • Warning - Task completed with warnings
  • Info - General task updates

Sound Options

  • Built-in system sounds
  • Custom sound file support
  • Volume control
  • Sound enable/disable toggle

Configuration

{
  "notifications": {
    "enabled": true,
    "sound": true,
    "sound_file": "Glass",
    "volume": 0.7
  }
}

Quick Start

Installation

pip install notifications-mcp-server

Configuration

Add to Claude Desktop config (~/Library/Application Support/Claude/claude_desktop_config.json):

{
  "mcpServers": {
    "notifications": {
      "command": "python",
      "args": ["-m", "notifications_mcp_server"]
    }
  }
}

Restart Claude Desktop. Notifications are now active.

Architecture

notifications-mcp-server/
├── core/
│   ├── notification_manager.py    # Notification logic
│   └── sound_manager.py           # Audio playback
├── platform/
│   ├── macos.py                   # macOS integration
│   └── base.py                    # Platform interface
├── utils/
│   ├── config.py                  # Configuration management
│   └── logger.py                  # Logging utilities
└── server.py                      # MCP server entry point

Design Principles

  1. Modular Platform Support - Clean abstraction for future Linux/Windows support
  2. Zero Configuration - Works out of box with sensible defaults
  3. Non-Blocking - Never delays Claude's operations
  4. Fail Safe - Notification failures don't break Claude tasks

Platform Support

  • macOS - Full support (notifications + sound)
  • Linux - Planned (via notify-send)
  • Windows - Planned (via Windows Toast)

Usage Examples

Claude Desktop automatically triggers notifications. No manual invocation needed.

Custom Sounds

Place custom audio files in ~/.config/notifications-mcp/sounds/:

mkdir -p ~/.config/notifications-mcp/sounds
cp my-notification.wav ~/.config/notifications-mcp/sounds/

Update config to use custom sound:

{
  "notifications": {
    "sound_file": "my-notification.wav"
  }
}

Future Ideas

  • Linux Support - Native notification support via libnotify
  • Windows Support - Windows 10/11 Toast notifications
  • Custom Sound Uploads - Web interface for managing notification sounds
  • Slack Integration - Post completion updates to Slack channels
  • Discord Integration - Send notifications to Discord webhooks
  • Notification History - Track and review past task completions
  • Smart Notifications - Only notify for tasks exceeding time threshold
  • Team Notifications - Share task completion across team members

Development

# Clone repository
git clone https://github.com/charles-adedotun/notifications-mcp-server.git
cd notifications-mcp-server

# Install dependencies
pip install -e ".[dev]"

# Run tests
pytest

# Type checking
mypy src/

Troubleshooting

Notifications Not Appearing

  1. Check macOS Notification Center permissions
  2. Verify Claude Desktop config syntax
  3. Check server logs: tail -f ~/.config/notifications-mcp/logs/server.log

Sound Not Playing

  1. Verify sound file exists
  2. Check volume settings
  3. Test sound file: afplay /path/to/sound.wav

Contributing

Found a bug? Open an issue with reproduction steps. Built Windows/Linux support? Submit a PR. Keep platform modules isolated and tested.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file iflow_mcp_charles_adedotun_notifications_mcp_server-1.2.0.tar.gz.

File metadata

  • Download URL: iflow_mcp_charles_adedotun_notifications_mcp_server-1.2.0.tar.gz
  • Upload date:
  • Size: 16.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_charles_adedotun_notifications_mcp_server-1.2.0.tar.gz
Algorithm Hash digest
SHA256 b1bb8765d2f344472cf82b57afd56cba6fb2dd0c4f6ee8120d0c524bed4aaa43
MD5 c53714ffc8f4ae89b35166eb88df1b65
BLAKE2b-256 57bcc87a05b2f3068ab961453c8a189975364e547986467ec11054d5fb42001d

See more details on using hashes here.

File details

Details for the file iflow_mcp_charles_adedotun_notifications_mcp_server-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: iflow_mcp_charles_adedotun_notifications_mcp_server-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 18.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_charles_adedotun_notifications_mcp_server-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 99b89c6b9702fe7d2c0d816fbe5263fad9f10ab878acb7f13967cdbd19f40c68
MD5 83ff1eb195308dfc64579c579d26d339
BLAKE2b-256 7ff21258f55403cce338dcf09ff63b51fb29c4df383dbc0b1db5d4f82c384e0b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page