# Notification System Charon's notification system keeps you informed about important events in your infrastructure. With flexible JSON templates and support for multiple providers, you can customize how and where you receive alerts. ## Overview Notifications can be triggered by various events: - **SSL Certificate Events**: Issued, renewed, or failed - **Uptime Monitoring**: Host status changes (up/down) - **Security Events**: WAF blocks, CrowdSec alerts, ACL violations - **System Events**: Configuration changes, backup completions ## Supported Services | Service | JSON Templates | Native API | Rich Formatting | |---------|----------------|------------|-----------------| | **Discord** | ✅ Yes | ✅ Webhooks | ✅ Embeds | | **Slack** | ✅ Yes | ✅ Webhooks | ✅ Native Formatting | | **Gotify** | ✅ Yes | ✅ HTTP API | ✅ Priority + Extras | | **Pushover** | ✅ Yes | ✅ HTTP API | ✅ Priority + Sound | | **Ntfy** | ✅ Yes | ✅ HTTP API | ✅ Priority + Tags | | **Custom Webhook** | ✅ Yes | ✅ HTTP API | ✅ Template-Controlled | | **Email** | ❌ No | ✅ SMTP | ✅ HTML Branded Templates | Additional providers are planned for later staged releases. ### Email Notifications Email notifications send HTML-branded alerts directly to one or more email addresses using your SMTP server. **Setup:** 1. Navigate to **Settings** → **SMTP** and configure your mail server connection 2. Go to **Settings** → **Notifications** and click **"Add Provider"** 3. Select **Email** as the service type 4. Enter one or more recipient email addresses 5. Configure notification triggers and save Email notifications use built-in HTML templates with Charon branding — no JSON template editing is required. ### Why JSON Templates? JSON templates give you complete control over notification formatting, allowing you to: - **Customize appearance**: Use rich embeds, colors, and formatting - **Add metadata**: Include custom fields, timestamps, and links - **Optimize visibility**: Structure messages for better readability - **Integrate seamlessly**: Match your team's existing notification styles ## Configuration ### Basic Setup 1. Navigate to **Settings** → **Notifications** 2. Click **"Add Provider"** 3. Select your service type 4. Enter the webhook URL 5. Configure notification triggers 6. Save your provider ### JSON Template Support For JSON-based services (Discord, Slack, Gotify, and Custom Webhook), you can choose from three template options. Email uses its own built-in HTML templates and does not use JSON templates. #### 1. Minimal Template (Default) Simple, clean notifications with essential information: ```json { "content": "{{.Title}}: {{.Message}}" } ``` **Use when:** - You want low-noise notifications - Space is limited (mobile notifications) - Only essential info is needed #### 2. Detailed Template Comprehensive notifications with all available context: ```json { "embeds": [{ "title": "{{.Title}}", "description": "{{.Message}}", "color": {{.Color}}, "timestamp": "{{.Timestamp}}", "fields": [ {"name": "Event Type", "value": "{{.EventType}}", "inline": true}, {"name": "Host", "value": "{{.HostName}}", "inline": true} ] }] } ``` **Use when:** - You need full event context - Multiple team members review notifications - Historical tracking is important #### 3. Custom Template Create your own template with complete control over structure and formatting. **Use when:** - Standard templates don't meet your needs - You have specific formatting requirements - Integrating with custom systems ## Service-Specific Examples ### Discord Webhooks Discord supports rich embeds with colors, fields, and timestamps. #### Basic Embed ```json { "embeds": [{ "title": "{{.Title}}", "description": "{{.Message}}", "color": {{.Color}}, "timestamp": "{{.Timestamp}}" }] } ``` #### Advanced Embed with Fields ```json { "username": "Charon Alerts", "avatar_url": "https://example.com/charon-icon.png", "embeds": [{ "title": "🚨 {{.Title}}", "description": "{{.Message}}", "color": {{.Color}}, "timestamp": "{{.Timestamp}}", "fields": [ { "name": "Event Type", "value": "{{.EventType}}", "inline": true }, { "name": "Severity", "value": "{{.Severity}}", "inline": true }, { "name": "Host", "value": "{{.HostName}}", "inline": false } ], "footer": { "text": "Charon Notification System" } }] } ``` **Available Discord Colors:** - `2326507` - Blue (info) - `15158332` - Red (error) - `16776960` - Yellow (warning) - `3066993` - Green (success) ### Slack Webhooks Slack notifications send messages to a channel using an Incoming Webhook URL. **Setup:** 1. In Slack, go to **[Your Apps](https://api.slack.com/apps)** → **Create New App** → **From scratch** 2. Under **Features**, select **Incoming Webhooks** and toggle it **on** 3. Click **"Add New Webhook to Workspace"** and choose the channel to post to 4. Copy the Webhook URL (it looks like `https://hooks.slack.com/services/T.../B.../...`) 5. In Charon, go to **Settings** → **Notifications** and click **"Add Provider"** 6. Select **Slack** as the service type 7. Paste your Webhook URL into the **Webhook URL** field 8. Optionally enter a channel display name (e.g., `#alerts`) for easy identification 9. Configure notification triggers and save > **Security:** Your Webhook URL is stored securely and is never exposed in API responses. The settings page only shows a `has_token: true` indicator, so your URL stays private even if someone gains read-only access to the API. #### Basic Message ```json { "text": "{{.Title}}: {{.Message}}" } ``` #### Formatted Message with Context ```json { "text": "*{{.Title}}*\n{{.Message}}\n\n• *Event:* {{.EventType}}\n• *Host:* {{.HostName}}\n• *Severity:* {{.Severity}}\n• *Time:* {{.Timestamp}}" } ``` **Slack formatting tips:** - Use `*bold*` for emphasis - Use `\n` for line breaks - Use `•` for bullet points - Slack automatically linkifies URLs ### Pushover Pushover delivers push notifications directly to your iOS, Android, or desktop devices. **Setup:** 1. Create an account at [pushover.net](https://pushover.net) and install the Pushover app on your device 2. From your Pushover dashboard, copy your **User Key** 3. Create a new **Application/API Token** for Charon 4. In Charon, go to **Settings** → **Notifications** and click **"Add Provider"** 5. Select **Pushover** as the service type 6. Enter your **Application API Token** in the token field 7. Enter your **User Key** in the User Key field 8. Configure notification triggers and save > **Security:** Your Application API Token is stored securely and is never exposed in API responses. #### Basic Message ```json { "title": "{{.Title}}", "message": "{{.Message}}" } ``` #### Message with Priority ```json { "title": "{{.Title}}", "message": "{{.Message}}", "priority": 1 } ``` **Pushover priority levels:** - `-2` - Lowest (no sound or vibration) - `-1` - Low (quiet) - `0` - Normal (default) - `1` - High (bypass quiet hours) > **Note:** Emergency priority (`2`) is not supported and will be rejected with a clear error. ### Ntfy Ntfy delivers push notifications to your phone or desktop using a simple HTTP-based publish/subscribe model. Works with the free hosted service at [ntfy.sh](https://ntfy.sh) or your own self-hosted instance. **Setup:** 1. Pick a topic name (or use an existing one) on [ntfy.sh](https://ntfy.sh) or your self-hosted server 2. In Charon, go to **Settings** → **Notifications** and click **"Add Provider"** 3. Select **Ntfy** as the service type 4. Enter your Topic URL (e.g., `https://ntfy.sh/charon-alerts` or `https://ntfy.example.com/charon-alerts`) 5. (Optional) Add an access token if your topic requires authentication 6. Configure notification triggers and save > **Security:** Your access token is stored securely and is never exposed in API responses. #### Basic Message ```json { "topic": "charon-alerts", "title": "{{.Title}}", "message": "{{.Message}}" } ``` #### Message with Priority and Tags ```json { "topic": "charon-alerts", "title": "{{.Title}}", "message": "{{.Message}}", "priority": 4, "tags": ["rotating_light"] } ``` **Ntfy priority levels:** - `1` - Min - `2` - Low - `3` - Default - `4` - High - `5` - Max (urgent) ## Planned Provider Expansion Additional providers (for example Telegram) are planned for later staged releases. This page will be expanded as each provider is validated and released. ## Template Variables All services support these variables in JSON templates: | Variable | Description | Example | |----------|-------------|---------| | `{{.Title}}` | Event title | "SSL Certificate Renewed" | | `{{.Message}}` | Event message/details | "Certificate for example.com renewed" | | `{{.EventType}}` | Type of event | "ssl_renewal", "uptime_down" | | `{{.Severity}}` | Event severity level | "info", "warning", "error" | | `{{.HostName}}` | Affected proxy host | "example.com" | | `{{.Timestamp}}` | ISO 8601 timestamp | "2025-12-24T10:30:00Z" | | `{{.Color}}` | Color code (integer) | 2326507 (blue) | | `{{.Priority}}` | Numeric priority (1-10) | 5 | ### Event-Specific Variables Some events include additional variables: **SSL Certificate Events:** - `{{.Domain}}` - Certificate domain - `{{.ExpiryDate}}` - Expiration date - `{{.DaysRemaining}}` - Days until expiry **Uptime Events:** - `{{.StatusChange}}` - "up_to_down" or "down_to_up" - `{{.ResponseTime}}` - Last response time in ms - `{{.Downtime}}` - Duration of downtime **Security Events:** - `{{.AttackerIP}}` - Source IP address - `{{.RuleID}}` - Triggered rule identifier - `{{.Action}}` - Action taken (block/log) ## Migration Guide ### Upgrading from Basic Webhooks If you've been using webhook providers without JSON templates: **Before (Basic webhook):** ``` Type: webhook URL: https://discord.com/api/webhooks/... Template: (not available) ``` **After (JSON template):** ``` Type: discord URL: https://discord.com/api/webhooks/... Template: detailed (or custom) ``` **Steps:** 1. Edit your existing provider 2. Change type from `webhook` to the specific service (e.g., `discord`) 3. Select a template (minimal, detailed, or custom) 4. Test the notification 5. Save changes Gotify and Custom Webhook providers are active runtime paths in the current rollout and can be used in production. ## Validation Coverage The current rollout includes payload-focused notification tests to catch formatting and delivery regressions across provider types before release. ### Testing Your Template Before saving, always test your template: 1. Click **"Send Test Notification"** in the provider form 2. Check your Discord channel 3. Verify formatting, colors, and all fields appear correctly 4. Adjust template if needed 5. Test again until satisfied ## Troubleshooting ### Template Validation Errors **Error:** `Invalid JSON template` **Solution:** Validate your JSON using a tool like [jsonlint.com](https://jsonlint.com). Common issues: - Missing closing braces `}` - Trailing commas - Unescaped quotes in strings **Error:** `Template variable not found: {{.CustomVar}}` **Solution:** Only use supported template variables listed above. ### Notification Not Received **Checklist:** 1. ✅ Provider is enabled 2. ✅ Event type is configured for notifications 3. ✅ Webhook URL is correct 4. ✅ Discord is online 5. ✅ Test notification succeeds 6. ✅ Check Charon logs for errors: `docker logs charon | grep notification` ### Discord Embed Not Showing **Cause:** Embeds require specific structure. **Solution:** Ensure your template includes the `embeds` array: ```json { "embeds": [ { "title": "{{.Title}}", "description": "{{.Message}}" } ] } ``` ## Best Practices ### 1. Start Simple Begin with the **minimal** template and only customize if you need more information. ### 2. Test Thoroughly Always test notifications before relying on them for critical alerts. ### 3. Use Color Coding Consistent colors help quickly identify severity: - 🔴 Red: Errors, outages - 🟡 Yellow: Warnings - 🟢 Green: Success, recovery - 🔵 Blue: Informational ### 4. Group Related Events Use separate Discord providers for different event types: - Critical alerts → Discord (with mentions) - Info notifications → Discord (general channel) - Security events → Discord (security channel) ### 5. Rate Limit Awareness Be mindful of service limits: - **Discord**: 5 requests per 2 seconds per webhook - **Slack**: 1 request per second per webhook - **Email**: Subject to your SMTP server's sending limits ### 6. Keep Templates Maintainable - Document custom templates - Version control your templates - Test after service updates ## Advanced Use Cases ### Routing by Severity Create separate providers for different severity levels: ``` Provider: Discord Critical Events: uptime_down, ssl_failure Template: Custom with @everyone mention Provider: Discord Info Events: ssl_renewal, backup_success Template: Minimal Provider: Discord All Events: * (all) Template: Detailed ``` ### Conditional Formatting Use template logic (if supported by your service): ```json { "embeds": [{ "title": "{{.Title}}", "description": "{{.Message}}", "color": {{if eq .Severity "error"}}15158332{{else}}2326507{{end}} }] } ``` ### Integration with Automation Forward notifications to automation tools: ```json { "webhook_type": "charon_notification", "trigger_workflow": true, "data": { "event": "{{.EventType}}", "host": "{{.HostName}}", "action_required": {{if eq .Severity "error"}}true{{else}}false{{end}} } } ``` ## Additional Resources - [Discord Webhook Documentation](https://discord.com/developers/docs/resources/webhook) - [Charon Security Guide](../security.md) ## Need Help? - 💬 [Ask in Discussions](https://github.com/Wikid82/charon/discussions) - 🐛 [Report Issues](https://github.com/Wikid82/charon/issues) - 📖 [View Full Documentation](https://wikid82.github.io/charon/)