Skip to content

A private wireguard network stack (pwn) with Unbound DNS, PiHold ad blocking, and a Web UI for managing Wireguard peer connections.

License

Notifications You must be signed in to change notification settings

rmayobre/easy-pwn

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Easy Private Wireguard Network (easy pwn)

A private wireguard network stack (PWN) with Unbound DNS, PiHold ad blocking, and a Web UI for managing Wireguard peer connections. With easy-pwn you can hide all self hosted services behind a Wireguard VPN and use PiHole for local DNS resolving. Clients connected to the Wireguard VPN will also gain the benefit of ad blocking.

Addresses

References

Wireguard VPN

Unbound DNS

PiHole

Requirements

You must run Linux with a kernel that has support for Wireguard. Most Linux distros now come with Wireguard by default, however, some do not. CentOS 8 distros, for example, do not come with Wireguard installed. If you are running a CentOS 8 distro (Rocky Linux 8, AlmaLinux, CentOS 8, etc.), try running this script to install the Wireguard Kernel modules.

You will also need to install the Docker Engine and docker-compose.

Before Installing

Change the password to the wireguard service:

services:
    wireguard:
    ...
    environment:
        ...
        - PASSWORD=admin # Update this - comment out for no password requirements.
        ...
    ...
...

Change the password to the pihole service:

services:
    wireguard:
    ...
    environment:
        ...
        WEBPASSWORD: "" # Create a password, otherwise, no password required to access.
        ...
    ...
...

Installation

Navigate to this repo's directory and run docker compose:

docker-compose up -d

Access LocalHost

For the initial installation and connection to the PWN network, you will need access the docker host's localhost. If you are using a remote server or VPS, I recommend SSH port fowarding to access the Wireguard UI (wg-easy).

SSH port forward port number 51821 to your localhost to gain access to the Wireguard UI (wg-easy).

SSH Config file template (~/.ssh/config):

Host myserver # Change to a reasonable host alias
   HostName 256.256.256.256 # Change to remote server's IP Address.
   User myuser # Change to your username
   LocalForward 51821 localhost:51821 # Forwards port 51821 to your localhost.

Now ssh into your server:

ssh myserver

Once you're connected, go to your browser and go to localhost:51821 and log into Wireguard. Use the password declared in the docker-compose.yml.

Create a client profile for your computer to use and connect to the Wireguard server.

Once you are connected to the wireguard server, you can access the Wireguard UI (wg-easy) as well as portainer and Pi hole via Wireguard connection. See Addresses at the top for the links.

Portainer Configuration (Using docker-compose-portainer)

If you used the docker-compose-portainer.yml stack, the following instructions will help with accessing the portainer webpage. Follow these instructions after you have configured the your wireguard client connection to the pwn network.

Go to Portainer (http://10.2.0.3:9000) and create a profile. After creating a profile, connect to the Protainer Agent. Connect to the the following endpoint: 10.2.0.5:9001. Once connected, Portainer is ready to use.

Additional Configurations

You can add an Nginx reverse proxy to your private network by adding this stack to your pwn-network. Update your PiHole local DNS records to point to the 10.2.0.0/24 ip address of your Nginx container. Then add the proxy to the nginx database (optionally you can add an SSL cert).

About

A private wireguard network stack (pwn) with Unbound DNS, PiHold ad blocking, and a Web UI for managing Wireguard peer connections.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published