A notification library for gophers and their furry friends.
Heavily inspired by caronc/apprise.
Visit the project's GitHub Page for full documentation.
go install github.com/nicholas-fedor/shoutrrr/shoutrrr@latestInstall the latest release binary to $HOME/go/bin (ensure it's in your PATH).
- 
Windows (amd64): New-Item -ItemType Directory -Path $HOME\go\bin -Force | Out-Null; iwr (iwr https://api.github.com/repos/nicholas-fedor/shoutrrr/releases/latest | ConvertFrom-Json).assets.where({$_.name -like "*windows_amd64*.zip"}).browser_download_url -OutFile shoutrrr.zip; Add-Type -AssemblyName System.IO.Compression.FileSystem; ($z=[System.IO.Compression.ZipFile]::OpenRead("$PWD\shoutrrr.zip")).Entries | ? {$_.Name -eq 'shoutrrr.exe'} | % {[System.IO.Compression.ZipFileExtensions]::ExtractToFile($_, "$HOME\go\bin\$($_.Name)", $true)}; $z.Dispose(); rm shoutrrr.zip; if (Test-Path "$HOME\go\bin\shoutrrr.exe") { Write-Host "Successfully installed shoutrrr.exe to $HOME\go\bin" } else { Write-Host "Failed to install shoutrrr.exe" } 
- 
Linux (amd64): mkdir -p $HOME/go/bin && curl -L $(curl -s https://api.github.com/repos/nicholas-fedor/shoutrrr/releases/latest | grep -o 'https://[^"]*linux_amd64[^"]*\.tar\.gz') | tar -xz --strip-components=1 -C $HOME/go/bin shoutrrr 
- 
macOS (amd64): mkdir -p $HOME/go/bin && curl -L $(curl -s https://api.github.com/repos/nicholas-fedor/shoutrrr/releases/latest | grep -o 'https://[^"]*darwin_amd64[^"]*\.tar\.gz') | tar -xz --strip-components=1 -C $HOME/go/bin shoutrrr 
Note
Visit the releases page for other architectures (e.g., arm, arm64, i386, riscv64).
- 
docker pull nickfedor/shoutrrr:latest 
- 
GHCR: docker pull ghcr.io/nicholas-fedor/shoutrrr:latest 
Note
Tags: latest (stable), vX.Y.Z (specific version), latest-dev (development), platform-specific (e.g., amd64-latest).
go get github.com/nicholas-fedor/shoutrrr@latest- name: Shoutrrr
  uses: nicholas-fedor/shoutrrr-action@v1
  with:
    url: ${{ secrets.SHOUTRRR_URL }}
    title: Deployed ${{ github.sha }}
    message: See changes at ${{ github.event.compare }}.shoutrrr send --url "slack://hook:T00000000-B00000000-XXXXXXXXXXXXXXXXXXXXXXXX@webhook" --message "Hello, Slack!"import "github.com/nicholas-fedor/shoutrrr"
errs := shoutrrr.Send("slack://hook:T00000000-B00000000-XXXXXXXXXXXXXXXXXXXXXXXX@webhook", "Hello, Slack!")
if len(errs) > 0 {
    // Handle errors
}docker run --rm nickfedor/shoutrrr:latest send --url "slack://hook:T00000000-B00000000-XXXXXXXXXXXXXXXXXXXXXXXX@webhook" --message "Hello, Slack!"See installation example above.
url := "slack://token-a/token-b/token-c"
err := shoutrrr.Send(url, "Hello world (or slack channel) !")url := "slack://token-a/token-b/token-c"
sender, err := shoutrrr.CreateSender(url)
sender.Send("Hello world (or slack channel) !", map[string]string { /* ... */ })urls := []string {
  "slack://token-a/token-b/token-c"
  "discord://token@channel"
}
sender, err := shoutrrr.CreateSender(urls...)
sender.Send("Hello world (or slack channel) !", map[string]string { /* ... */ })shoutrrr send [OPTIONS] <URL> <Message [...]>You can also use Shoutrrr in a GitHub Actions workflow.
name: Deploy
on:
  push:
    branches:
      - main
jobs:
  build:
    runs-on: ubuntu-latest
    steps:
      - [Your other workflow steps]
      - name: Shoutrrr
        uses: nicholas-fedor/[email protected]
        with:
          url: ${{ secrets.SHOUTRRR_URL }}
          title: Deployed ${{ github.sha }}
          message: See changes at ${{ github.event.compare }}.| Service | Description | 
|---|---|
| Bark | iOS push notifications | 
| Discord | Discord webhooks | 
| Generic | Custom HTTP webhooks | 
| Google Chat | Google Chat webhooks | 
| Gotify | Gotify push notifications | 
| IFTTT | IFTTT webhooks | 
| Join | Join push notifications | 
| Lark | Lark (Feishu) webhooks | 
| Logger | Local logging (for testing) | 
| Matrix | Matrix rooms | 
| Mattermost | Mattermost webhooks | 
| Notifiarr | Notifiarr message forwarding | 
| Ntfy | Ntfy push notifications | 
| Opsgenie | Opsgenie alerts | 
| Pushbullet | Pushbullet push notifications | 
| Pushover | Pushover push notifications | 
| Rocket.Chat | Rocket.Chat webhooks | 
| Slack | Slack webhooks or Bot API | 
| SMTP | Email notifications | 
| Teams | Microsoft Teams webhooks | 
| Telegram | Telegram bots | 
| Zulip | Zulip chat | 
| XMPP | XMPP messages (if enabled) | 
Thanks goes to these wonderful people (emoji key):
This project follows the all-contributors specification. Contributions of any kind welcome!
- Watchtower - Automate Docker container image updates
- Shoutrrr GitHub Action - Notifications using Shoutrrr in GitHub Actions