Skip to content

πŸ”” Cross-platform smart notifications plugin for Claude Code. 6 types. Click-to-focus. 1 line installation. Instant. Analyze context. Zero dependencies. webhooks. Linux, MacOS, Windows.

License

Notifications You must be signed in to change notification settings

777genius/claude-notifications-go

Repository files navigation

Claude Notifications (plugin)

Ubuntu CI macOS CI Windows CI Go Report Card codecov

image image image

Smart notifications for Claude Code with click-to-focus, git branch display, and webhook integrations.

Table of Contents

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, zellij β€” 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 below.

Manual Install

Step-by-step installation (if bootstrap doesn't work)
# 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.

Manual update (if bootstrap didn't work)

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:

  1. Run /plugin, select Marketplaces, choose claude-notifications-go, then select Update marketplace
  2. 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 / AppleScript with bundle ID detection:

Terminal Focus method
Ghostty AXDocument (OSC 7 CWD)
VS Code / Insiders AXTitle (focus-window subcommand)
iTerm2, Warp, kitty, WezTerm, Alacritty, Hyper, Apple Terminal AppleScript (window title)
Any other (custom terminalBundleId) AppleScript (window title)

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, zellij β€” 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": 12,
    "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 12 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.

Troubleshooting

See Troubleshooting Guide for common issues:

  • Ubuntu 24.04: EXDEV: cross-device link not permitted during /plugin install (TMPDIR workaround)
  • Windows: install issues related to %TEMP% / %TMP% location

Documentation

License

GPL-3.0 - See LICENSE file for details.

About

πŸ”” Cross-platform smart notifications plugin for Claude Code. 6 types. Click-to-focus. 1 line installation. Instant. Analyze context. Zero dependencies. webhooks. Linux, MacOS, Windows.

Topics

Resources

License

Contributing

Stars

Watchers

Forks

Packages

 
 
 

Contributors