claude-notifications-go
Health Pass
- License รขโฌโ License: NOASSERTION
- Description รขโฌโ Repository has a description
- Active repo รขโฌโ Last push 0 days ago
- Community trust รขโฌโ 458 GitHub stars
Code Pass
- Code scan รขโฌโ Scanned 12 files during light audit, no dangerous patterns found
Permissions Pass
- Permissions รขโฌโ No dangerous permissions requested
This plugin provides smart, cross-platform desktop notifications for Claude Code sessions. It supports six different notification types, click-to-focus functionality across various terminal emulators, and webhook integrations for services like Slack and Telegram.
Security Assessment
Overall Risk: Low. The automated code scan of 12 files found no dangerous patterns, hardcoded secrets, or requests for excessive permissions. However, developers should be aware of a few inherent behaviors. Because the plugin features click-to-focus capabilities across terminal emulators and multiplexers like tmux, it necessarily interacts with local system windows and processes. Additionally, the webhook integration feature means the tool does make outbound network requests to external APIs based on user configuration. No sensitive data harvesting was detected.
Quality Assessment
The project appears to be highly active and reliable. It received pushes as recently as today, demonstrating active maintenance. It boasts 458 GitHub stars, indicating a healthy level of community trust and adoption. The repository features a comprehensive README with clear installation instructions, and Continuous Integration (CI) pipelines are set up across Ubuntu, macOS, and Windows. The only downside is that the license is marked as NOASSERTION, meaning the exact terms of use are technically unclear, though this is common for many open-source utilities.
Verdict
Safe to use, though you should verify compatibility with your specific terminal setup and be mindful of the outbound network requests if you configure external webhooks.
๐ Cross-platform smart notifications plugin for Claude Code. 6 types. Click-to-focus. 1 line installation. Instant. Analyze context. Zero dependencies. webhooks (ntfy, slack, telegram...). Linux, MacOS, Windows.
Claude Notifications (plugin)
Smart notifications for Claude Code with click-to-focus, git branch display, and webhook integrations.
Boost your productivity โ check out the advanced task manager for Claude with a convenient UI, from the creator of this plugin.
Table of Contents
- Features
- Installation
- Supported Notification Types
- Platform Support
- Configuration
- Manual Testing
- Contributing
- Troubleshooting
- Documentation
- License
Features
- Cross-platform: macOS (Intel & Apple Silicon), Linux (x64 & ARM64), Windows 10+ (x64)
- 6 notification types: Task Complete, Review Complete, Question, Plan Ready, Session Limit, API Error
- Click-to-focus (macOS, Linux): click notification to focus the exact project window and tab โ Ghostty, VS Code, iTerm2, Warp, kitty, WezTerm, Alacritty, Hyper, Apple Terminal, GNOME Terminal, Konsole, Tilix, Terminator, XFCE4 Terminal, MATE Terminal
- Multiplexers: tmux (including iTerm2 -CC integration mode), zellij, WezTerm, kitty โ click switches to the correct session/pane/tab
- Git branch in title:
โ Completed main [cat] - Sounds: MP3/WAV/FLAC/OGG/AIFF, volume control, audio device selection
- Webhooks: Slack, Discord, Telegram, Lark/Feishu, Microsoft Teams, ntfy.sh, PagerDuty, Zapier, n8n, Make, custom โ with retry, circuit breaker, rate limiting (docs)
- Plugin compatibility: works with double-shot-latte and other plugins that spawn background Claude instances
Installation
Prerequisites
- Claude Code
- Windows users: Git Bash (included with Git for Windows) or WSL
- macOS/Linux users: No additional software required
Quick Install (Recommended)
One command to install everything:
curl -fsSL https://raw.githubusercontent.com/777genius/claude-notifications-go/main/bin/bootstrap.sh | bash
Then restart Claude Code and optionally run /claude-notifications-go:settings to configure sounds.
The binary is downloaded once and cached locally. You can re-run /claude-notifications-go:settings anytime to reconfigure.
If the bootstrap script doesn't work for your environment, use the Manual Install steps below inside Claude Code.
Manual Install
Step-by-step installation inside Claude Code (if bootstrap doesn't work)Run these slash commands in the Claude Code chat, not in your system terminal:
# 1) Add marketplace
/plugin marketplace add 777genius/claude-notifications-go
# 2) Install plugin
/plugin install claude-notifications-go@claude-notifications-go
# 3) Restart Claude Code
# 4) Download binary
/claude-notifications-go:init
# 5) (Optional) Configure sounds and settings
/claude-notifications-go:settings
Having issues with installation? See Troubleshooting.
Updating
Run the same command as for installation โ it will update both the plugin and the binary:
curl -fsSL https://raw.githubusercontent.com/777genius/claude-notifications-go/main/bin/bootstrap.sh | bash
Then restart Claude Code to apply the new version. Your settings in ~/.claude/claude-notifications-go/config.json are preserved across updates.
Claude Code also periodically checks for plugin updates automatically. Binaries are updated on the next hook invocation when a version mismatch is detected.
To update manually via Claude Code UI:
- Run
/plugin, select Marketplaces, chooseclaude-notifications-go, then select Update marketplace - Select Installed, choose
claude-notifications-go, then select Update now
If the binary auto-update didn't work (e.g. no internet at the time), run /claude-notifications-go:init to download it manually. If hook definitions changed in the new version, restart Claude Code to apply them.
Supported Notification Types
| Status | Icon | Description | Trigger |
|---|---|---|---|
| Task Complete | โ | Main task completed | Stop/SubagentStop hooks (state machine detects active tools like Write/Edit/Bash, or ExitPlanMode followed by tool usage) |
| Review Complete | ๐ | Code review finished | Stop/SubagentStop hooks (state machine detects only read-like tools: Read/Grep/Glob with no active tools, plus long text response >200 chars) |
| Question | โ | Claude has a question | PreToolUse hook (AskUserQuestion) OR Notification hook |
| Plan Ready | ๐ | Plan ready for approval | PreToolUse hook (ExitPlanMode) |
| Session Limit Reached | โฑ๏ธ | Session limit reached | Stop/SubagentStop hooks (state machine detects "Session limit reached" text in last 3 assistant messages) |
| API Error | ๐ด | Authentication expired, rate limit, server error, connection error | Stop/SubagentStop hooks (state machine detects via isApiErrorMessage flag + error field from JSONL) |
Platform Support
Supported platforms:
- macOS (Intel & Apple Silicon)
- Linux (x64 & ARM64)
- Windows 10+ (x64)
No additional dependencies:
- โ Binaries auto-download from GitHub Releases
- โ Pure Go - no C compiler needed
- โ All libraries bundled
- โ Works offline after first setup
Windows-specific features:
- Native Toast notifications (Windows 10+)
- Works in PowerShell, CMD, Git Bash, or WSL
- MP3/WAV/OGG/FLAC audio playback via native Windows APIs
- System sounds not accessible - use built-in MP3s or custom files
Click-to-Focus (macOS & Linux)
Clicking a notification activates your terminal window. Auto-detects terminal and platform.
macOS โ via AX API with bundle ID detection:
| Terminal | Focus method |
|---|---|
| Ghostty | AXDocument (OSC 7 CWD) |
| VS Code / Insiders / Cursor | AXTitle (focus-window subcommand) |
| iTerm2, Warp, kitty, WezTerm, Alacritty, Hyper, Apple Terminal | AXTitle (focus-window subcommand) |
Any other (custom terminalBundleId) |
AXTitle (focus-window subcommand) |
Linux โ via D-Bus daemon with automatic compositor detection:
| Terminal | Supported compositors |
|---|---|
| VS Code | GNOME, KDE, Sway, X11 |
| GNOME Terminal, Konsole, Alacritty, kitty, WezTerm, Tilix, Terminator, XFCE4 Terminal, MATE Terminal | GNOME, KDE, Sway, X11 |
| Any other | Fallback by name |
Linux focus methods (tried in order): GNOME extension, GNOME Shell Eval, GNOME FocusApp, wlrctl (Sway/wlroots), kdotool (KDE), xdotool (X11).
Multiplexers (both platforms): tmux (including iTerm2 -CC integration mode), zellij, WezTerm, kitty โ click switches to the correct pane/tab.
Windows โ notifications only, no click-to-focus.
See Click-to-Focus Guide for configuration details.
Configuration
Run /claude-notifications-go:settings to configure sounds, volume, webhooks, and other options via an interactive wizard. You can re-run it anytime to reconfigure.
Manual Configuration
Config file location:
| Platform | Path |
|---|---|
| macOS / Linux | ~/.claude/claude-notifications-go/config.json |
| Windows (Git Bash) | ~/.claude/claude-notifications-go/config.json |
| Windows (PowerShell) | $env:USERPROFILE\.claude\claude-notifications-go\config.json |
Edit the config file directly:
{
"notifications": {
"desktop": {
"enabled": true,
"sound": true,
"volume": 1.0,
"audioDevice": "",
"clickToFocus": true,
"terminalBundleId": "",
"appIcon": "${CLAUDE_PLUGIN_ROOT}/claude_icon.png"
},
"webhook": {
"enabled": false,
"preset": "slack",
"url": "",
"chat_id": "",
"format": "json",
"headers": {}
},
"suppressQuestionAfterTaskCompleteSeconds": 12,
"suppressQuestionAfterAnyNotificationSeconds": 7,
"notifyOnSubagentStop": false,
"notifyOnTextResponse": true,
"respectJudgeMode": true,
"suppressFilters": [
{
"name": "Suppress ClaudeProbe completions (remote-control)",
"status": "task_complete",
"gitBranch": "",
"folder": "ClaudeProbe"
}
]
},
"statuses": {
"task_complete": {
"title": "โ
Completed",
"sound": "${CLAUDE_PLUGIN_ROOT}/sounds/task-complete.mp3"
},
"review_complete": {
"title": "๐ Review",
"sound": "${CLAUDE_PLUGIN_ROOT}/sounds/review-complete.mp3"
},
"question": {
"title": "โ Question",
"sound": "${CLAUDE_PLUGIN_ROOT}/sounds/question.mp3"
},
"plan_ready": {
"title": "๐ Plan",
"sound": "${CLAUDE_PLUGIN_ROOT}/sounds/plan-ready.mp3"
},
"session_limit_reached": {
"title": "โฑ๏ธ Session Limit Reached",
"sound": "${CLAUDE_PLUGIN_ROOT}/sounds/error.mp3"
},
"api_error": {
"title": "๐ด API Error: 401",
"sound": "${CLAUDE_PLUGIN_ROOT}/sounds/error.mp3"
},
"api_error_overloaded": {
"title": "๐ด API Error",
"sound": "${CLAUDE_PLUGIN_ROOT}/sounds/error.mp3"
}
}
}
| Option | Default | Description |
|---|---|---|
notifyOnSubagentStop |
false |
Send notifications when subagents (Task tool) complete |
notifyOnTextResponse |
true |
Send notifications for text-only responses (no tool usage) |
respectJudgeMode |
true |
Honor CLAUDE_HOOK_JUDGE_MODE=true env var to suppress notifications |
suppressQuestionAfterTaskCompleteSeconds |
12 |
Suppress question notifications for N seconds after task complete |
suppressQuestionAfterAnyNotificationSeconds |
7 |
Suppress question notifications for N seconds after any notification |
suppressFilters |
[] |
Array of rules to suppress notifications by status, git branch, and/or folder. Each rule is an AND of its fields; omitted fields match any value. Set gitBranch to "" to match sessions outside git repos. |
Each status can be individually disabled by adding "enabled": false.
Sound Options
Built-in sounds (included):
${CLAUDE_PLUGIN_ROOT}/sounds/task-complete.mp3${CLAUDE_PLUGIN_ROOT}/sounds/review-complete.mp3${CLAUDE_PLUGIN_ROOT}/sounds/question.mp3${CLAUDE_PLUGIN_ROOT}/sounds/plan-ready.mp3${CLAUDE_PLUGIN_ROOT}/sounds/error.mp3
System sounds:
- macOS:
/System/Library/Sounds/Glass.aiff,/System/Library/Sounds/Hero.aiff, etc. - Linux:
/usr/share/sounds/**/*.ogg(varies by distribution) - Windows: Use built-in MP3s (system sounds not easily accessible)
Supported formats: MP3, WAV, FLAC, OGG/Vorbis, AIFF
List Available Sounds
See all available notification sounds on your system:
# List all sounds (built-in + system)
bin/list-sounds
# Output as JSON
bin/list-sounds --json
# Preview a sound
bin/list-sounds --play task-complete
# Preview at specific volume
bin/list-sounds --play Glass --volume 0.5
Or use the skill command: /claude-notifications-go:sounds
Audio Device Selection
Route notification sounds to a specific audio output device instead of the system default:
# List available audio devices
bin/list-devices
# Output:
# 0: MacBook Pro-Lautsprecher
# 1: Babyface (23314790) (default)
# 2: Immersed
Then add the device name to your ~/.claude/claude-notifications-go/config.json:
{
"notifications": {
"desktop": {
"audioDevice": "MacBook Pro-Lautsprecher"
}
}
}
Leave audioDevice empty or omit it to use the system default device.
Test Sound Playback
Preview any sound file with optional volume control:
# Test built-in sound (full volume)
bin/sound-preview sounds/task-complete.mp3
# Test with reduced volume (30% - recommended for testing)
bin/sound-preview --volume 0.3 sounds/task-complete.mp3
# Test macOS system sound at 30% volume
bin/sound-preview --volume 0.3 /System/Library/Sounds/Glass.aiff
# Test custom sound at 50% volume
bin/sound-preview --volume 0.5 /path/to/your/sound.wav
# Show all options
bin/sound-preview --help
Volume flag: Use --volume to control playback volume (0.0 to 1.0). Default is 1.0 (full volume).
Manual Testing
The plugin is invoked automatically by Claude Code hooks. To test manually:
# Test PreToolUse hook
echo '{"session_id":"test","transcript_path":"/path/to/transcript.jsonl","tool_name":"ExitPlanMode"}' | \
claude-notifications handle-hook PreToolUse
# Test Stop hook
echo '{"session_id":"test","transcript_path":"/path/to/transcript.jsonl"}' | \
claude-notifications handle-hook Stop
Contributing
See CONTRIBUTING.md for development setup, testing, building, and submitting changes.
For local plugin workflows and real-claude smoke/manual E2E testing, see docs/LOCAL_DEVELOPMENT.md.
Troubleshooting
See Troubleshooting Guide for common issues:
- Ubuntu 24.04:
EXDEV: cross-device link not permittedduring/plugin install(TMPDIR workaround) - Windows: install issues related to
%TEMP%/%TMP%location - Windows / Git Bash: GitHub Releases download fails because of proxy / TLS inspection / certificate revocation
Documentation
Architecture - Plugin architecture, directory structure, data flow
Local Development And E2E - Local marketplace testing, real Claude smoke tests, manual click-to-focus validation
Click-to-Focus - Configuration, supported terminals, platform details
Volume Control Guide - Customize notification volume
- Configure volume from 0% to 100%
- Logarithmic scaling for natural sound
- Per-environment recommendations
Interactive Sound Preview - Preview sounds during setup
- Interactive sound selection
- Preview before choosing
Plugin Compatibility - Integration with other Claude Code plugins
Troubleshooting - Common install/runtime issues
- Ubuntu 24.04
EXDEVduring/plugin install(TMPDIR workaround)
- Ubuntu 24.04
Webhook Integration Guide - Complete guide for webhook setup
- Slack - Slack integration with color-coded attachments
- Discord - Discord integration with rich embeds
- Telegram - Telegram bot integration
- Lark/Feishu - Lark/Feishu integration with interactive cards
- Custom Webhooks - Any webhook-compatible service
- Configuration - Retry, circuit breaker, rate limiting
- Monitoring - Metrics and debugging
- Troubleshooting - Common issues and solutions
License
GPL-3.0 - See LICENSE file for details.
Reviews (0)
Sign in to leave a review.
Leave a reviewNo results found