Alertmanager to ntfy-sh webhook container for Kubernetes deployments
Find a file
2024-11-17 07:30:40 +00:00
.forgejo/workflows
.taskfiles
docker chore(deps): update nixos/nix docker tag to v2.25.1 2024-11-14 01:00:14 +00:00
examples
src Merge pull request 'chore(deps): update dependency go to v1.23.3' (#23) from renovate/go-1.x into main 2024-11-09 00:46:57 +00:00
.gitignore
default.nix
flake.lock
flake.nix
LICENSE
mock.json
module.nix
README.md
renovate.json
Taskfile.yaml

alertmanager-ntfy

Listen for webhooks from Alertmanager and send them to ntfy push notifications

Configuration is done with environment variables.

Variable Description Example
HTTP_ADDRESS Adress to listen on localhost
HTTP_PORT Port to listen on 8080
NTFY_SERVER_URL ntfy server to send to https://ntfy.sh
NTFY_USER ntfy user for basic auth myuser
NTFY_PASS ntfy password for basic auth supersecret

Nix

For Nix/Nixos users a flake.nix is provided to simplify the build. It also privides app to test the hooks with mocked data from mock.json

Build

nix build .#container

Push to registry

nix run .#push-container

Run directly

nix run

Test alerts

nix run '.#mock-hook'

Module

The flake also includes a NixOS module for ease of use. A minimal configuration will look like this:


# Add to flake inputs
inputs.alertmanager-ntfy.url = "github:pinpox/alertmanager-ntfy";

# Import the module in your configuration.nix
imports = [
	self.inputs.alertmanager-ntfy.nixosModules.default
];

# Enable and set options
services.alertmanager-ntfy = {
	enable = true;
	httpAddress = "localhost";
	httpPort = "9999";
	ntfyTopic = "https://ntfy.sh/test";
	ntfyPriority = "high";
	envFile = "/var/src/secrets/alertmanager-ntfy/envfile";
};

🤩 Gratitude

This repo is based on the work by pinpox/alertmanager-ntfy. Adaptions has been made for Kubernetes deployment.