OpenVPN server web administration interface.
Goal: create quick to deploy and easy to use solution that makes work with small OpenVPN environments a breeze.
If you have docker and docker-compose installed, you can jump directly to installation.
Please note this project is in alpha stage. It still needs some work to make it secure and feature complete.
- status page that shows server statistics and list of connected clients
- easy creation of client certificates
- ability to download client certificates as a zip package with client configuration inside
- log preview
- modification of OpenVPN configuration file through web interface
After startup web service is visible on port 8080. To login use the following default credentials:
- username: admin
- password: b3secure (this will be soon replaced with random password)
Please change password to your own immediately!
Requirements:
- docker and docker-compose
- on firewall open ports: 1194/udp and 8080/tcp
Execute commands
curl -O https://raw.githubusercontent.com/adamwalach/openvpn-web-ui/master/docs/docker-compose.yml docker-compose up -d It starts two docker containers. One with OpenVPN server and second with OpenVPNAdmin web application. Through a docker volume it creates following directory structure:
. ├── docker-compose.yml └── openvpn-data ├── conf │ ├── dh2048.pem │ ├── ipp.txt │ ├── keys │ │ ├── 01.pem │ │ ├── ca.crt │ │ ├── ca.key │ │ ├── index.txt │ │ ├── index.txt.attr │ │ ├── index.txt.old │ │ ├── serial │ │ ├── serial.old │ │ ├── server.crt │ │ ├── server.csr │ │ ├── server.key │ │ └── vars │ ├── openvpn.log │ └── server.conf └── db └── data.db Requirements:
- golang environments
- beego
Execute commands:
go get github.com/adamwalach/openvpn-web-ui cd $GOPATH/src/github.com/adamwalach/openvpn-web-ui bee run -gendoc=true - add unit tests
- add option to modify certificate properties
- generate random admin password at initialization phase
- add versioning
- add automatic ssl/tls (check how ponzu did it)
This project uses MIT license
https://github.com/kardianos/govendor is used for vendoring.
To update dependencies from GOPATH:
govendor update +v
AdminLTE - dashboard & control panel theme. Built on top of Bootstrap 3.
Preview: https://almsaeedstudio.com/themes/AdminLTE/index2.html
