You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Bigard Florian 3d5f44cf21 Merge pull request #79 from serjoscha87/master 8 years ago
.github Add github issue template 8 years ago
css Add beautiful chocobo favicon 8 years ago
include - moved the configuration interface elements (logs, users, webadmins) to tabs; this makes useability a tiny bit better 8 years ago
installation Fix deprecated option in server configuration 8 years ago
js - moved the configuration interface elements (logs, users, webadmins) to tabs; this makes useability a tiny bit better 8 years ago
sql Fix init script 8 years ago
.bowerrc Big refresh 10 years ago
.gitignore Fix database date: 0000-00-00 -> NULL 8 years ago
CHANGELOG.md Update version 0.3.2 8 years ago
LICENSE.md Update to AGPL licence 8 years ago
README.md added `curl` package for debian jessie 8 years ago
bower.json Update version 0.3.2 8 years ago
desinstall.sh Hide root password at desinstallation step 9 years ago
index.php fixed little grammar mistake 8 years ago
install.sh Fix openrsa install 8 years ago
migration.php Fix migration script 8 years ago
update.sh Fix database date: 0000-00-00 -> NULL 8 years ago

README.md

OpenVPN Admin

Summary

Administrate its OpenVPN with a web interface (logs visualisations, users managing...) and a SQL database.

Previsualisation configuration Previsualisation administration

Prerequisite

  • GNU/Linux with Bash and root access
  • Fresh install of OpenVPN
  • Web server (NGinx, Apache...)
  • MySQL
  • PHP >= 5.5 with modules:
    • zip
    • pdo_mysql
  • bower
  • unzip
  • wget
  • sed
  • curl

Debian Jessie

# apt-get install openvpn apache2 php5-mysql mysql-server php5 nodejs unzip git wget sed npm curl
# npm install -g bower
# ln -s /usr/bin/nodejs /usr/bin/node

CentOS 7

# yum install epel-release
# yum install openvpn httpd php-mysql mariadb-server php nodejs unzip git wget sed npm
# npm install -g bower
# systemctl enable mariadb
# systemctl start mariadb

Other distribution... (PR welcome)

Tests

Only tested on Debian Jessie. Feel free to open issues.

Installation

  • Setup OpenVPN and the web application:

    $ cd ~/my_coding_workspace
    $ git clone https://github.com/Chocobozzz/OpenVPN-Admin openvpn-admin
    $ cd openvpn-admin
    # ./install.sh www_base_dir web_user web_group
    
  • Setup the web server (Apache, NGinx...) to serve the web application.

  • Create the admin of the web application by visiting http://your-installation/index.php?installation

Usage

  • Start OpenVPN on the server (for example systemctl start openvpn@server)
  • Connect to the web application as an admin
  • Create an user
  • User get the configurations files via the web application (and put them in /etc/openvpn)
  • Users on GNU/Linux systems, run chmod +x /etc/openvpn/update-resolv.sh as root
  • User run OpenVPN (for example systemctl start openvpn@client)

Update

$ git pull origin master
# ./update.sh www_base_dir

Desinstall

It will remove all installed components (OpenVPN keys and configurations, the web application, iptables rules...).

# ./desinstall.sh www_base_dir

Use of