2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
# 🚨 alertmanager-ntfy 🚨
2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
This project is a lightweight bridge between [Prometheus Alertmanager ](https://prometheus.io/docs/alerting/latest/alertmanager/ ) and [ntfy ](https://ntfy.sh/ ). It sends push notifications to your devices.
2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
## 📦 Features
2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
- Configure via environment variables.
- Exports Prometheus metrics to monitor webhook activity.
- Built for Kubernetes, but works anywhere
- Has a `flake.nix`
2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
## 🚀 Getting Started
2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
To send your Alertmanager alerts to ntfy, configure the following environment variables:
2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
| Variable | Description | Example |
|-------------------|----------------------------------------------|-------------------|
| `HTTP_ADDRESS` | Address to listen on | `localhost` |
| `HTTP_PORT` | Port to listen on | `8080` |
| `NTFY_SERVER_URL` | ntfy server to send alerts to | `https://ntfy.sh` |
| `NTFY_USER` | Username for basic auth (optional) | `myuser` |
| `NTFY_PASS` | Password for basic auth (optional) | `supersecret` |
| `LOG_LEVEL` | Log level (`debug`, `info` , `warn` , `error` ) | `info` |
2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
### Example
2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
To expose the service on `localhost:8080` and send alerts to an ntfy topic `https://ntfy.sh/mytopic` :
```bash
export HTTP_ADDRESS="localhost"
export HTTP_PORT="8080"
export NTFY_SERVER_URL="https://ntfy.sh/mytopic"
export NTFY_USER="myuser"
export NTFY_PASS="supersecret"
export LOG_LEVEL="info"
2022-11-02 13:16:19 +00:00
```
2024-12-21 12:12:56 +00:00
## 🛠️ Nix Support
2024-09-09 19:25:18 +00:00
2024-12-21 12:12:56 +00:00
For Nix/NixOS users, a `flake.nix` is provided for build, run and test.
2024-09-09 19:25:18 +00:00
2024-12-21 12:12:56 +00:00
### Building with Nix
2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
To build the container image: `nix build .#container`
2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
If you are not on amd64 use `nix build .#packages.x86_64-linux.container` .
2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
Push the built container to your preferred registry: `nix run .#push-container`
2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
You can run the application directly from Nix with: `nix run`
2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
To simulate alerts with test data: `nix run '.#mock-hook'`
2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
## 🖥️ Nix Module
A Nix module is provided for easy setup and integration. A minimal configuration would look like this:
2022-11-02 13:16:19 +00:00
2024-12-21 12:12:56 +00:00
```nix
2022-11-02 13:16:19 +00:00
# Add to flake inputs
2024-12-21 12:12:56 +00:00
inputs.alertmanager-ntfy.url = "git+https://code.252.no/tommy/alertmanager-ntfy";
2022-11-02 13:16:19 +00:00
# Import the module in your configuration.nix
imports = [
2024-12-21 12:12:56 +00:00
self.inputs.alertmanager-ntfy.nixosModules.default
2022-11-02 13:16:19 +00:00
];
2024-12-21 12:12:56 +00:00
# Enable the service and configure options
2022-11-02 13:16:19 +00:00
services.alertmanager-ntfy = {
2024-12-21 12:12:56 +00:00
enable = true;
httpAddress = "localhost";
httpPort = "9999";
ntfyTopic = "https://ntfy.sh/test";
ntfyPriority = "high";
envFile = "/var/src/secrets/alertmanager-ntfy/envfile";
2022-11-02 13:16:19 +00:00
};
```
2024-08-11 19:02:39 +00:00
2024-12-21 12:12:56 +00:00
## 🔍 Prometheus Metrics
The service exports Prometheus metrics for tracking webhook requests and errors. By default, these metrics are exposed at `/metrics` :
- **`http_requests_total`**: Total number of HTTP requests received.
- **`http_request_errors_total`**: Total number of errors encountered during request processing.
2024-08-11 19:02:39 +00:00
## 🤩 Gratitude
2024-12-21 12:12:56 +00:00
This project is based on the fantastic work by [pinpox/alertmanager-ntfy ](https://github.com/pinpox/alertmanager-ntfy ), with adaptations for Kubernetes deployments and enhanced logging/metrics support.