Charon

Charon

The Gateway to Effortless Connectivity. Charon bridges the gap between the complex internet and your private services. Enjoy a simplified, visual management experience built specifically for the home server enthusiast. No code requiredβ€”just safe passage.

Cerberus

The Guardian at the Gate. Ensure nothing passes without permission. Cerberus is a robust security suite featuring the Coraza WAF, deep CrowdSec integration, and granular rate-limiting. Always watching, always protecting.



License: MIT Release Build Status

--- ## ✨ Top Features | Feature | Description | |---------|-------------| | πŸ” **Automatic HTTPS** | Free SSL certificates from Let's Encrypt, auto-renewed | | πŸ›‘οΈ **Built-in Security** | CrowdSec integration, geo-blocking, IP access lists (optional, powered by Cerberus) | | ⚑ **Zero Downtime** | Hot-reload configuration without restarts | | 🐳 **Docker Discovery** | Auto-detect containers on local and remote Docker hosts | | πŸ“Š **Uptime Monitoring** | Know when your services go down with smart notifications | | πŸ” **Health Checks** | Test connections before saving | | πŸ“₯ **Easy Import** | Bring your existing Caddy configs with one click | | πŸ’Ύ **Backup & Restore** | Never lose your settings, export anytime | | 🌐 **WebSocket Support** | Perfect for real-time apps and chat services | | 🎨 **Beautiful Dark UI** | Modern interface that's easy on the eyes, works on any device | **[See all features β†’](https://wikid82.github.io/charon/features)** --- ## πŸš€ Quick Start ```bash services: charon: image: ghcr.io/wikid82/charon:latest container_name: charon restart: unless-stopped ports: - "80:80" # HTTP (Caddy proxy) - "443:443" # HTTPS (Caddy proxy) - "443:443/udp" # HTTP/3 (Caddy proxy) - "8080:8080" # Management UI (Charon) environment: - CHARON_ENV=production # New env var prefix (CHARON_). CPM_ values still supported. - TZ=UTC # Set timezone (e.g., America/New_York) - CHARON_HTTP_PORT=8080 - CHARON_DB_PATH=/app/data/charon.db - CHARON_FRONTEND_DIR=/app/frontend/dist - CHARON_CADDY_ADMIN_API=http://localhost:2019 - CHARON_CADDY_CONFIG_DIR=/app/data/caddy - CHARON_CADDY_BINARY=caddy - CHARON_IMPORT_CADDYFILE=/import/Caddyfile - CHARON_IMPORT_DIR=/app/data/imports # Security Services (Optional) #- CERBERUS_SECURITY_CROWDSEC_MODE=disabled # disabled, local, external #- CERBERUS_SECURITY_CROWDSEC_API_URL= # Required if mode is external #- CERBERUS_SECURITY_CROWDSEC_API_KEY= # Required if mode is external #- CERBERUS_SECURITY_WAF_MODE=disabled # disabled, enabled #- CERBERUS_SECURITY_RATELIMIT_ENABLED=false #- CERBERUS_SECURITY_ACL_ENABLED=false extra_hosts: - "host.docker.internal:host-gateway" volumes: - :/app/data - :/data - :/config - /var/run/docker.sock:/var/run/docker.sock:ro # For local container discovery # Mount your existing Caddyfile for automatic import (optional) # - ./my-existing-Caddyfile:/import/Caddyfile:ro # - ./sites:/import/sites:ro # If your Caddyfile imports other files healthcheck: test: ["CMD", "wget", "--no-verbose", "--tries=1", "--spider", "http://localhost:8080/api/v1/health"] interval: 30s timeout: 10s retries: 3 start_period: 40s ``` Open **http://localhost:8080** β€” that's it! πŸŽ‰ **[Full documentation β†’](https://wikid82.github.io/charon/)** --- ## πŸ’¬ Community - πŸ› **Found a bug?** [Open an issue](https://github.com/Wikid82/charon/issues) - πŸ’‘ **Have an idea?** [Start a discussion](https://github.com/Wikid82/charon/discussions) - πŸ“‹ **Roadmap** [View the project board](https://github.com/users/Wikid82/projects/7) ## 🀝 Contributing We welcome contributions! See our [Contributing Guide](CONTRIBUTING.md) to get started. ---

MIT License Β· Documentation Β· Releases

Built with ❀️ by @Wikid82
Powered by Caddy Server Β· Inspired by Nginx Proxy Manager & Pangolin