54 lines
1.6 KiB
YAML
54 lines
1.6 KiB
YAML
version: '3.8'
|
|
|
|
services:
|
|
slack-to-ntfy:
|
|
build: .
|
|
container_name: slack-to-ntfy
|
|
ports:
|
|
- "8080:8080"
|
|
environment:
|
|
# Replace with your ntfy server URL (without topic path)
|
|
- NTFY_BASE_URL=https://your-ntfy-server.com
|
|
|
|
# For token-based authentication, uncomment and replace with your ntfy Bearer token (e.g., tk_xxxx)
|
|
# - NTFY_TOKEN=tk_your_bearer_token_here
|
|
|
|
# For username/password authentication, uncomment and replace with your ntfy credentials
|
|
# - NTFY_USERNAME=your_username
|
|
# - NTFY_PASSWORD=your_password
|
|
|
|
# Bind configuration
|
|
- BIND_ADDRESS=0.0.0.0
|
|
- BIND_PORT=8080
|
|
# TLS Configuration
|
|
# Uncomment and replace with your certificate and key file paths (relative to the container)
|
|
# - TLS_CERT_FILE=/app/certs/server.crt
|
|
# - TLS_KEY_FILE=/app/certs/server.key
|
|
restart: unless-stopped
|
|
volumes:
|
|
# Mount the local 'certs' directory into the container to provide TLS certificates
|
|
# Ensure you have server.crt and server.key in a 'certs' directory next to docker-compose.yml
|
|
- ./certs:/app/certs
|
|
|
|
# Optional: Resource limits
|
|
deploy:
|
|
resources:
|
|
limits:
|
|
memory: 32M
|
|
cpus: '0.1'
|
|
reservations:
|
|
memory: 16M
|
|
cpus: '0.05'
|
|
|
|
# Health check using the built-in endpoint
|
|
healthcheck:
|
|
test: ["CMD", "wget", "--no-verbose", "--tries=1", "--spider", "https://localhost:8080/health"]
|
|
interval: 30s
|
|
timeout: 10s
|
|
retries: 3
|
|
start_period: 10s
|
|
|
|
# Optional: Create a custom network
|
|
networks:
|
|
default:
|
|
name: slack-ntfy-middleware |