Go to file
2019-05-02 13:03:16 +10:00
bin Added websock upgrade option for base proxy host locations 2018-09-29 16:02:05 +10:00
config Access Lists 2018-08-18 17:16:23 +10:00
doc Version bump 2019-03-15 07:49:08 +10:00
rootfs Enable TLS 1.3 by default 2019-05-02 13:03:16 +10:00
src Update copyright year (#121) 2019-04-20 21:28:06 +10:00
.babelrc Initial build environment stuff 2018-06-20 08:45:27 +10:00
.gitignore Access polish, import v1 stsarted 2018-08-21 08:33:51 +10:00
docker-compose.yml Support for upstream ssl proxy hosts 2018-12-12 09:47:12 +10:00
Dockerfile Expose ports for host network mode support 2018-09-05 10:03:43 +10:00
Dockerfile.arm64 Fix base docker images for arm packages 2019-02-18 21:12:46 +10:00
Dockerfile.armv6l Forgot to change dockerfiles to match CI names 2019-03-19 07:01:12 +10:00
Dockerfile.armv7l Forgot to change dockerfiles to match CI names 2019-03-19 07:01:12 +10:00
Jenkinsfile CI Docker manifest improvements 2019-03-15 07:49:08 +10:00
knexfile.js Initial build environment stuff 2018-06-20 08:45:27 +10:00
LICENSE Initial commit 2017-12-21 09:01:17 +10:00
nodemon.json Path changes 2018-08-01 11:17:31 +10:00
package.json Version bump 2019-03-15 07:49:08 +10:00
README.md Version bump 2019-03-15 07:49:08 +10:00
webpack.config.js Better webpack chunking 2018-11-07 09:31:42 +10:00

Nginx Proxy Manager

Nginx Proxy Manager

Version Stars Pulls

This project comes as a pre-built docker image that enables you to easily forward to your websites running at home or otherwise, including free SSL, without having to know too much about Nginx or Letsencrypt.

Project Goal

I created this project to fill a personal need to provide users with a easy way to accomplish reverse proxying hosts with SSL termination and it had to be so easy that a monkey could do it. This goal hasn't changed. While there might be advanced options they are optional and the project should be as simple as possible so that the barrier for entry here is low.

Features

  • Beautiful and Secure Admin Interface based on Tabler
  • Easily create forwarding domains, redirections, streams and 404 hosts without knowing anything about Nginx
  • Free SSL using Let's Encrypt or provide your own custom SSL certificates
  • Access Lists and basic HTTP Authentication for your hosts
  • Advanced Nginx configuration available for super users
  • User management, permissions and audit log

Screenshots

Login Dashboard Proxy Hosts Proxy Host Settings Proxy Host SSL Redirection Hosts Redirection Host Settings Streams Stream Settings 404 Hosts 404 Host Settings Certificates Lets Encrypt Certificates Custom Certificates Access Lists Access List Users Users User Permissions Audit Log

Getting started

Please consult the installation instructions for a complete guide or if you just want to get up and running in the quickest time possible, grab all the files in the doc/example/ folder and run docker-compose up -d

Administration

When your docker container is running, connect to it on port 81 for the admin interface.

http://localhost:81

Note: Requesting SSL Certificates won't work until this project is accessible from the outside world, as explained below.

Default Administrator User

Email:    admin@example.com
Password: changeme

Immediately after logging in with this default user you will be asked to modify your details and change your password.

Hosting your home network

I won't go in to too much detail here but here are the basics for someone new to this self-hosted world.

  1. Your home router will have a Port Forwarding section somewhere. Log in and find it
  2. Add port forwarding for port 80 and 443 to the server hosting this project
  3. Configure your domain name details to point to your home, either with a static ip or a service like DuckDNS
  4. Use the Nginx Proxy Manager here as your gateway to forward to your other web based services