mirror of
https://github.com/flant/ovpn-admin.git
synced 2025-12-13 04:16:14 -08:00
184 lines
7.7 KiB
Markdown
184 lines
7.7 KiB
Markdown
# ovpn-admin
|
|
|
|
Simple web UI to manage OpenVPN users, their certificates & routes in Linux. While backend is written in Go, frontend is based on Vue.js.
|
|
|
|
***DISCLAIMER!** This project was created for experienced users (system administrators) and private (e.g., protected by network policies) environments only. Thus, it is not implemented with security in mind (e.g., it doesn't strictly check all parameters passed by users, etc.). It also relies heavily on files and fails if required files aren't available.*
|
|
|
|
## Features
|
|
|
|
* Adding, deleting OpenVPN users (generating certificates for them);
|
|
* Revoking/restoring/rotating users certificates;
|
|
* Generating ready-to-user config files;
|
|
* Providing metrics for Prometheus, including certificates expiration date, number of (connected/total) users, information about connected users;
|
|
* (optionally) Specifying CCD (`client-config-dir`) for each user;
|
|
* (optionally) Operating in a master/slave mode (syncing certs & CCD with other server);
|
|
* (optionally) Specifying/changing password for additional authorization in OpenVPN;
|
|
* (optionally) Specifying the Kubernetes LoadBalancer if it's used in front of the OpenVPN server (to get an automatically defined `remote` in the `client.conf.tpl` template).
|
|
* (optionally) Storing certificates and other files in Kubernetes Secrets (**Attention, this feature is experimental!**).
|
|
|
|
### Screenshots
|
|
|
|
Managing users in ovpn-admin:
|
|

|
|
|
|
An example of dashboard made using ovpn-admin metrics:
|
|

|
|
|
|
## Installation
|
|
|
|
### 1. Docker
|
|
|
|
There is a ready-to-use [docker-compose.yaml](https://github.com/palark/ovpn-admin/blob/master/docker-compose.yaml), so you can just change/add values you need and start it with [start.sh](https://github.com/palark/ovpn-admin/blob/master/start.sh).
|
|
|
|
Requirements:
|
|
You need [Docker](https://docs.docker.com/get-docker/) and [docker-compose](https://docs.docker.com/compose/install/) installed.
|
|
|
|
Commands to execute:
|
|
|
|
```bash
|
|
git clone https://github.com/palark/ovpn-admin.git
|
|
cd ovpn-admin
|
|
./start.sh
|
|
```
|
|
#### 1.1
|
|
Ready docker images available on [Docker Hub](https://hub.docker.com/r/flant/ovpn-admin/tags)
|
|
. Tags are simple: `$VERSION` or `latest` for ovpn-admin and `openvpn-$VERSION` or `openvpn-latest` for openvpn-server
|
|
|
|
### 2. Building from source
|
|
|
|
Requirements. You need Linux with the following components installed:
|
|
- [golang](https://golang.org/doc/install)
|
|
- [packr2](https://github.com/gobuffalo/packr#installation)
|
|
- [nodejs/npm](https://nodejs.org/en/download/package-manager/)
|
|
|
|
Commands to execute:
|
|
|
|
```bash
|
|
git clone https://github.com/palark/ovpn-admin.git
|
|
cd ovpn-admin
|
|
./bootstrap.sh
|
|
./build.sh
|
|
./ovpn-admin
|
|
```
|
|
|
|
(Please don't forget to configure all needed params in advance.)
|
|
|
|
### 3. Prebuilt binary
|
|
|
|
You can also download and use prebuilt binaries from the [releases](https://github.com/palark/ovpn-admin/releases/latest) page — just choose a relevant tar.gz file.
|
|
|
|
|
|
## Notes
|
|
* This tool uses external calls for `bash`, `coreutils` and `easy-rsa`, thus **Linux systems only are supported** at the moment.
|
|
* To enable additional password authentication, provide `--auth` and `--auth.db="/etc/easyrsa/pki/users.db`" flags and install [openvpn-user](https://github.com/pashcovich/openvpn-user/releases/latest). This tool should be available in your `$PATH` and its binary should be executable (`+x`).
|
|
* If you use `--ccd` and `--ccd.path="/etc/openvpn/ccd"` and plan to use static address setup for users, do not forget to provide `--ovpn.network="172.16.100.0/24"` with valid openvpn-server network.
|
|
* If you want to pass all the traffic generated by the user, you need to edit `ovpn-admin/templates/client.conf.tpl` and uncomment `redirect-gateway def1`.
|
|
* Tested with openvpn-server versions 2.4 and 2.5 and with tls-auth mode only.
|
|
* Not tested with Easy-RSA version > 3.0.8.
|
|
* Status of user connections update every 28 seconds.
|
|
* Master-replica synchronization and additional password authentication do not work with `--storage.backend=kubernetes.secrets` - **WIP**
|
|
|
|
## Usage
|
|
|
|
```
|
|
usage: ovpn-admin [<flags>]
|
|
|
|
Flags:
|
|
--help show context-sensitive help (try also --help-long and --help-man)
|
|
|
|
--listen.host="0.0.0.0" host for ovpn-admin
|
|
(or OVPN_LISTEN_HOST)
|
|
|
|
--listen.port="8080" port for ovpn-admin
|
|
(or OVPN_LISTEN_PORT)
|
|
|
|
--listen.base-url="/" base URL for ovpn-admin web files
|
|
(or $OVPN_LISTEN_BASE_URL)
|
|
|
|
--role="master" server role, master or slave
|
|
(or OVPN_ROLE)
|
|
|
|
--master.host="http://127.0.0.1"
|
|
(or OVPN_MASTER_HOST) URL for the master server
|
|
|
|
--master.basic-auth.user="" user for master server's Basic Auth
|
|
(or OVPN_MASTER_USER)
|
|
|
|
--master.basic-auth.password=""
|
|
(or OVPN_MASTER_PASSWORD) password for master server's Basic Auth
|
|
|
|
--master.sync-frequency=600 master host data sync frequency in seconds
|
|
(or OVPN_MASTER_SYNC_FREQUENCY)
|
|
|
|
--master.sync-token=TOKEN master host data sync security token
|
|
(or OVPN_MASTER_TOKEN)
|
|
|
|
--ovpn.network="172.16.100.0/24"
|
|
(or OVPN_NETWORK) NETWORK/MASK_PREFIX for OpenVPN server
|
|
|
|
--ovpn.server=HOST:PORT:PROTOCOL ...
|
|
(or OVPN_SERVER) HOST:PORT:PROTOCOL for OpenVPN server
|
|
can have multiple values
|
|
|
|
--ovpn.server.behindLB enable if your OpenVPN server is behind Kubernetes
|
|
(or OVPN_LB) Service having the LoadBalancer type
|
|
|
|
--ovpn.service="openvpn-external"
|
|
(or OVPN_LB_SERVICE) the name of Kubernetes Service having the LoadBalancer
|
|
type if your OpenVPN server is behind it
|
|
|
|
--mgmt=main=127.0.0.1:8989 ...
|
|
(or OVPN_MGMT) ALIAS=HOST:PORT for OpenVPN server mgmt interface;
|
|
can have multiple values
|
|
|
|
--metrics.path="/metrics" URL path for exposing collected metrics
|
|
(or OVPN_METRICS_PATH)
|
|
|
|
--easyrsa.path="./easyrsa/" path to easyrsa dir
|
|
(or EASYRSA_PATH)
|
|
|
|
--easyrsa.index-path="./easyrsa/pki/index.txt"
|
|
(or OVPN_INDEX_PATH) path to easyrsa index file
|
|
|
|
--ccd enable client-config-dir
|
|
(or OVPN_CCD)
|
|
|
|
--ccd.path="./ccd" path to client-config-dir
|
|
(or OVPN_CCD_PATH)
|
|
|
|
--templates.clientconfig-path=""
|
|
(or OVPN_TEMPLATES_CC_PATH) path to custom client.conf.tpl
|
|
|
|
--templates.ccd-path="" path to custom ccd.tpl
|
|
(or OVPN_TEMPLATES_CCD_PATH)
|
|
|
|
--auth.password enable additional password authorization
|
|
(or OVPN_AUTH)
|
|
|
|
--auth.db="./easyrsa/pki/users.db"
|
|
(or OVPN_AUTH_DB_PATH) database path for password authorization
|
|
|
|
--auth.db-init
|
|
(or OVPN_AUTH_DB_INIT) enable database init if user db not exists or size is 0
|
|
|
|
--log.level set log level: trace, debug, info, warn, error (default info)
|
|
(or LOG_LEVEL)
|
|
|
|
--log.format set log format: text, json (default text)
|
|
(or LOG_FORMAT)
|
|
|
|
--storage.backend storage backend: filesystem, kubernetes.secrets (default filesystem)
|
|
(or STORAGE_BACKEND)
|
|
|
|
--version show application version
|
|
```
|
|
|
|
## Authors
|
|
|
|
ovpn-admin was originally created in [Flant](https://github.com/flant/) and used internally for years.
|
|
|
|
In March 2021, it [went public](https://medium.com/flant-com/introducing-ovpn-admin-a-web-interface-to-manage-openvpn-users-d81705ad8f23) and was still developed in Flant.
|
|
Namely, [@vitaliy-sn](https://github.com/vitaliy-sn) created its first version in Python, and [@pashcovich](https://github.com/pashcovich) rewrote it in Go.
|
|
|
|
In November 2024, this project was moved to [Palark](https://github.com/palark/), which is currently responsible for its maintenance and development.
|