Files
server-scripts/haven-notify
Jose Henrique 45567b2242
All checks were successful
Check scripts syntax / check-scripts-syntax (push) Successful in 2s
Haven Notify Build and Deploy / Build Haven Notify Image (push) Successful in 10m0s
Haven Notify Build and Deploy / Deploy Haven Notify (internal) (push) Successful in 11s
updating templates
2025-08-23 22:01:01 -03:00
..
2025-08-22 21:08:28 -03:00
2025-08-23 20:27:49 -03:00
2025-08-23 22:01:01 -03:00
2025-08-23 21:36:32 -03:00
2025-08-21 21:11:22 -03:00
2025-08-23 20:44:32 -03:00

Haven Notify Logo

Overview

Haven Notify is an internal service designed to send notifications to a specified Discord channel.

It's built in Go and can be deployed as a container or managed service.

Prerequisites

  • Go 1.18 or newer
  • Docker
  • A Discord Webhook URL

API Specification

Send Notification

  • Endpoint: /notify
  • Method: POST
  • Request Body:
{
  "title": "Notification Title",
  "message": "Notification Message"
}

Send Backup Notification

  • Endpoint: /template/notify/backup
  • Method: POST
  • Request Body:
{
  "title": "Notification Title",
  "message": "Notification Message",
  "backupSizeInMB": 500,
  "extra": [
    {
      "name": "Additional Info",
      "value": "Some extra information"
    }
  ]
}

Send Update Notification

  • Endpoint: /template/notify/update
  • Method: POST
  • Request Body:
{
  "host": "Notification Title",
  "asset": "Notification Message",
  "time": 500 // in seconds
}

Send Error Notification

  • Endpoint: /template/notify/error
  • Method: POST
  • Request Body:
{
  "caller": "Who triggered the error",
  "message": "Error while moving file",
  "critical": true,
  "extra": [
    {
      "name": "Additional Info",
      "value": "Some extra information"
    }
  ]
}

Setup & Usage

Docker

  1. Build the Docker image:
    docker build -t haven-notify .
    
  2. Run the container:
    docker run -e WEBHOOK_URL=your_webhook_url haven-notify
    

Kubernetes

Deployment manifest is available at deploy/haven-notify.yaml.

  1. Edit the manifest to set your environment variables.
  2. Create a generic secret named WEBHOOK_URL with discord-webhook=your_webhook_url
  3. Apply deployment:
    kubectl apply -f deploy/haven-notify.yaml