Thanks to visit codestin.com
Credit goes to github.com

Skip to content

zmef/pangolin

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

pangolin

Documentation Docker Stars Discord Youtube

Tunneled Mesh Reverse Proxy Server with Access Control

Your own self-hosted zero trust tunnel.

Pangolin is a self-hosted tunneled reverse proxy server with identity and access control, designed to securely expose private resources on distributed networks. Acting as a central hub, it connects isolated networks — even those behind restrictive firewalls — through encrypted tunnels, enabling easy access to remote services without opening ports.

Preview

Sites page of Pangolin dashboard (dark mode) showing multiple tunnels connected to the central server.

Key Features

Reverse Proxy Through WireGuard Tunnel

  • Expose private resources on your network without opening ports (firewall punching).
  • Secure and easy to configure site-to-site connectivity via a custom user space WireGuard client, Newt.
  • Built-in support for any WireGuard client.
  • Automated SSL certificates (https) via LetsEncrypt.
  • Support for HTTP/HTTPS and raw TCP/UDP services.
  • Load balancing.

Identity & Access Management

  • Centralized authentication system using platform SSO. Users will only have to manage one login.
  • Define access control rules for IPs, IP ranges, and URL paths per resource.
  • TOTP with backup codes for two-factor authentication.
  • Create organizations, each with multiple sites, users, and roles.
  • Role-based access control to manage resource access permissions.
  • Additional authentication options include:
    • Email whitelisting with one-time passcodes.
    • Temporary, self-destructing share links.
    • Resource specific pin codes.
    • Resource specific passwords.

Simple Dashboard UI

  • Manage sites, users, and roles with a clean and intuitive UI.
  • Monitor site usage and connectivity.
  • Light and dark mode options.
  • Mobile friendly.

Easy Deployment

  • Run on any cloud provider or on-premises.
  • Docker Compose based setup for simplified deployment.
  • Future-proof installation script for streamlined setup and feature additions.
  • Use any WireGuard client to connect, or use Newt, our custom user space client for the best experience.

Modular Design

  • Extend functionality with existing Traefik plugins, such as CrowdSec and Geoblock.
    • Automatically install and configure Crowdsec via Pangolin's installer script.
  • Attach as many sites to the central server as you wish.

Collage

Deployment and Usage Example

  1. Deploy the Central Server:

    • Deploy the Docker Compose stack onto a VPS hosted on a cloud platform like RackNerd, Amazon EC2, DigitalOcean Droplet, or similar. There are many cheap VPS hosting options available to suit your needs.

Tip

Many of our users have had a great experience with RackNerd. Depending on promotions, you can likely get a VPS with 1 vCPU, 1GB RAM, and ~20GB SSD for just around $12/year. That's a great deal! We are part of the RackNerd affiliate program, so if you purchase through our link, we receive a small commission which helps us maintain the project and keep it free for everyone.

  1. Domain Configuration:

    • Point your domain name to the VPS and configure Pangolin with your preferred settings.
  2. Connect Private Sites:

    • Install Newt or use another WireGuard client on private sites.
    • Automatically establish a connection from these sites to the central server.
  3. Expose Resources:

    • Add resources to the central server and configure access control rules.
    • Access these resources securely from anywhere.

Use Case Example - Bypassing Port Restrictions in Home Lab: Imagine private sites where the ISP restricts port forwarding. By connecting these sites to Pangolin via WireGuard, you can securely expose HTTP and HTTPS resources on the private network without any networking complexity.

Use Case Example - IoT Networks: IoT networks are often fragmented and difficult to manage. By deploying Pangolin on a central server, you can connect all your IoT sites via Newt or another WireGuard client. This creates a simple, secure, and centralized way to access IoT resources without the need for intricate networking setups.

Resources

Resources page of Pangolin dashboard (dark mode) showing HTTPS and TCP resources with access control rules.

Similar Projects and Inspirations

Cloudflare Tunnels: A similar approach to proxying private resources securely, but Pangolin is a self-hosted alternative, giving you full control over your infrastructure.

Authentik and Authelia: These projects inspired Pangolin’s centralized authentication system for proxies, enabling robust user and role management.

Project Development / Roadmap

Note

Pangolin is under heavy development. The roadmap is subject to change as we fix bugs, add new features, and make improvements.

View the project board for more detailed info.

Licensing

Pangolin is dual licensed under the AGPL-3 and the Fossorial Commercial license. To see our commercial offerings, please see our website for details. For inquiries about commercial licensing, please contact us at [email protected].

Contributions

Please see CONTRIBUTING in the repository for guidelines and best practices.

Please post bug reports and other functional issues in the Issues section of the repository. For all feature requests, or other ideas, please use the Discussions section.

About

Tunneled Mesh Reverse Proxy Server with Identity and Access Control and Dashboard UI

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 97.4%
  • Go 2.2%
  • Other 0.4%