# openvpn-monitor
## Summary
openvpn-monitor is a flask app that displays the status of OpenVPN servers,
including all current connections. It uses the OpenVPN management console.
It typically runs on the same host as the OpenVPN server, but it can also
manage remote servers.
[![](https://raw.githubusercontent.com/furlongm/openvpn-monitor/gh-pages/screenshots/openvpn-monitor.png)](https://raw.githubusercontent.com/furlongm/openvpn-monitor/gh-pages/screenshots/openvpn-monitor.png)
## Supported Operating Systems
- Ubuntu 24.04 LTS (noble)
- Debian 11 (bullseye)
- CentOS / Rocky / Alma / RHEL 9
## Installation Options
- [source](#source)
- [deb/rpm](#debrpm)
- [apache](#apache)
- [docker](#docker)
- [virtualenv + pip + gunicorn](#virtualenv--pip--gunicorn)
- [nginx + uwsgi](#nginx--uwsgi)
N.B. all CentOS / Rocky / Alma / RHEL instructions assume the EPEL repository has been installed:
```shell
dnf -y install epel-release
dnf makecache
```
If selinux is enabled the following changes are required for host/port to work:
```
dnf -y install policycoreutils-python-utils
semanage port -a -t openvpn_port_t -p tcp 5555
setsebool -P httpd_can_network_connect 1
```
### Source
Checkout the code:
```shell
cd /var/www/html
git clone https://github.com/furlongm/openvpn-monitor
cd openvpn-monitor
yarnpkg --prod --modules-folder openvpn_monitor/static/dist install
python3 -m venv .venv
. venv/bin/activate
pip install -r requirements.txt
```
Run the development server in debug mode:
```shell
flask --app openvpn_monitor/app run --debug
```
### deb/rpm
### Ubuntu 24.04 (noble)
```shell
curl -sS https://repo.openbytes.ie/openbytes.gpg > /usr/share/keyrings/openbytes.gpg
echo "deb [signed-by=/usr/share/keyrings/openbytes.gpg] https://repo.openbytes.ie/openvpn-monitor/ubuntu noble main" > /etc/apt/sources.list.d/openvpn-monitor.list
apt update
apt -y install python3-openvpn-monitor
```
### Debian 12 (bookworm)
```shell
curl -sS https://repo.openbytes.ie/openbytes.gpg > /usr/share/keyrings/openbytes.gpg
echo "deb [signed-by=/usr/share/keyrings/openbytes.gpg] https://repo.openbytes.ie/openvpn-monitor/debian bookworm main" > /etc/apt/sources.list.d/openvpn-monitor.list
apt update
apt -y install python3-openvpn-monitor
```
### CentOS / Rocky / Alma / RHEL 9
```shell
curl -sS https://repo.openbytes.ie/openbytes.gpg > /etc/pki/rpm-gpg/RPM-GPG-KEY-openbytes
cat <<EOF >> /etc/yum.repos.d/openvpn-monitor.repo
[openbytes]
name=openbytes
baseurl=https://repo.openbytes.ie/openvpn-monitor/el9
enabled=1
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-openbytes
EOF
update-crypto-policies --set DEFAULT:SHA1
dnf -y install epel-release
dnf makecache
dnf -y install python3-openvpn-monitor
```
See [configuration](#configuration) for details on configuring openvpn-monitor.
### apache
#### Install dependencies and configure apache
These instructions assume a source checkout to /var/www/html/openvpn-monitor
##### Debian / Ubuntu
```shell
apt -y install git apache2 libapache2-mod-wsgi-py3 python3-geoip2 python3-humanize python3-flask python3-flaskext.wtf python3-semver yarnpkg
cp /var/www/html/openvpn-monitor/etc/openvpn-monitor/apache.conf.example /etc/apache2/conf-available/openvpn-monitor.conf
sed -i -e "s#^\(Define openvpn_monitor_pythonpath\).*#\1 /var/www/html/openvpn-monitor#" /etc/apache2/conf-available/openvpn-monitor.conf
a2enconf openvpn-monitor
systemctl restart apache2
```
##### CentOS / Rocky / Alma / RHEL
```shell
dnf -y install git httpd mod_wsgi python3-geoip2 python3-humanize python3-flask python3-flask-wtf python3-semver geolite2-city yarnpkg
cp /var/www/html/openvpn-monitor/etc/openvpn-monitor/apache.conf.example /etc/httpd/conf.d/openvpn-monitor.conf
sed -i -e "s#^\(Define openvpn_monitor_pythonpath\).*#\1 /var/www/html/openvpn-monitor#" /etc/httpd/conf.d/openvpn-monitor.conf
systemctl restart httpd
```
See [configuration](#configuration) for details on configuring openvpn-monitor.
### docker
```shell
docker run -p 80:80 ruimarinho/openvpn-monitor
```
Read the [docker installation instructions](https://github.com/ruimarinho/docker-openvpn-monitor#usage)
for details on how to generate a dynamic configuration using only environment
variables.
### virtualenv + pip + gunicorn
```shell
apt -y install python3-venv # (debian/ubuntu)
dnf -y install python3 geolite2-city # (rocky/alma/rhel)
mkdir /srv/openvpn-monitor
cd /srv/openvpn-monitor
python3 -m venv .venv
. venv/bin/activate
pip install openvpn-monitor gunicorn
gunicorn openvpn_monitor.app -b 0.0.0.0:80
```
See [configuration](#configuration) for details on configuring openvpn-monitor.
### nginx + uwsgi
#### Install openvpn-monitor
```shell
apt -y install git gcc nginx uwsgi uwsgi-plugin-python3 python3-dev python3-venv libgeoip-dev yarnpkg # (debian/ubuntu)
dnf -y install git gcc nginx uwsgi uwsgi-plugin-python3 python3-devel geolite2-city yarnpkg # (centos/rhel)
cd /srv
git clone https://github.com/furlongm/openvpn-monitor
cd openvpn-monitor
python3 -m venv .venv
. .venv/bin/activate
pip install -r requirements.txt
yarnpkg --prod --modules-folder openvpn_monitor/static/dist install
```
#### uWSGI app config
Create a uWSGI config: `/etc/uwsgi/apps-available/openvpn-monitor.ini`
```
[uwsgi]
base = /srv
project = openvpn-monitor
logto = /var/log/uwsgi/app/%(project).log
plugins = python3
chdir = %(base)/%(project)
virtualenv = %(chdir)/.venv
module = openvpn-monitor:application
manage-script-name = true
mount=/openvpn-monitor=openvpn_monitor/app.py
```
#### Nginx site config
Create an Nginx config: `/etc/nginx/sites-available/openvpn-monitor`
```
server {
listen 80;
location /openvpn-monitor/ {
uwsgi_pass unix:///run/uwsgi/app/openvpn-monitor/socket;
include uwsgi_params;
}
}
```
#### Enable uWSGI app and Nginx site, and restart services
```shell
ln -s /etc/uwsgi/apps-available/openvpn-monitor.ini /etc/uwsgi/apps-enabled/
systemctl restart uwsgi
ln -s /etc/nginx/sites-available/openvpn-monitor /etc/nginx/sites-enabled/
rm /etc/nginx/sites-enabled/default
systemctl restart nginx
```
See [configuration](#configuration) for details on configuring openvpn-monitor.
## Configuration
### Configure OpenVPN
Add the following line to your OpenVPN server configuration to run the
management console on 127.0.0.1 port 5555, with the management password
in /etc/openvpn/pw-file:
```
management 127.0.0.1 5555 pw-file
```
To run the management console on a socket, with the management password
in /etc/openvpn/pw-file:
```
management socket-name unix pw-file
```
Refer to the OpenVPN documentation for further information on how to secure
access to the management interface.
### Configure openvpn-monitor
Copy the example configuration file `openvpn-monitor.conf.example` to the same
directory as app.py or to /etc/openvpn-monitor/openvpn-monitor.conf
```shell
cp openvpn-monitor.conf.example openvpn_monitor/openvpn-monitor.conf
```
or
```shell
mkdir -p /etc/openvpn-monitor
cp openvpn-monitor.conf.example /etc/openvpn_monitor/openvpn-monitor.conf
```
In this file you can set site name, add a logo, set the default map location
(latitude and longitude). If not set, the default location is New York, USA.
Once configured, navigate to `http://myipaddress/openvpn-monitor/`
## License
openvpn-monitor is licensed under the GPLv3, a copy of which can be found in
the COPYING file.
## Acknowledgements
Flags are created by Matthias Slovig (flags@slovig.de) and are licensed under
Creative Commons License Deed Attribution-ShareAlike 3.0 Unported
(CC BY-SA 3.0). See http://flags.blogpotato.de/ for more details.
Raw data
{
"_id": null,
"home_page": "http://openvpn-monitor.openbytes.ie",
"name": "openvpn-monitor",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": "web openvpn monitor",
"author": "Marcus Furlong",
"author_email": "furlongm@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/5f/07/68327716eeb0653ae1c7b5035b8a211fb77db48a68bf8fb63aed3442e6fc/openvpn_monitor-2.0.4.tar.gz",
"platform": null,
"description": "# openvpn-monitor\n\n\n## Summary\n\nopenvpn-monitor is a flask app that displays the status of OpenVPN servers,\nincluding all current connections. It uses the OpenVPN management console.\nIt typically runs on the same host as the OpenVPN server, but it can also\nmanage remote servers.\n\n[![](https://raw.githubusercontent.com/furlongm/openvpn-monitor/gh-pages/screenshots/openvpn-monitor.png)](https://raw.githubusercontent.com/furlongm/openvpn-monitor/gh-pages/screenshots/openvpn-monitor.png)\n\n## Supported Operating Systems\n\n - Ubuntu 24.04 LTS (noble)\n - Debian 11 (bullseye)\n - CentOS / Rocky / Alma / RHEL 9\n\n\n## Installation Options\n\n - [source](#source)\n - [deb/rpm](#debrpm)\n - [apache](#apache)\n - [docker](#docker)\n - [virtualenv + pip + gunicorn](#virtualenv--pip--gunicorn)\n - [nginx + uwsgi](#nginx--uwsgi)\n\nN.B. all CentOS / Rocky / Alma / RHEL instructions assume the EPEL repository has been installed:\n\n```shell\ndnf -y install epel-release\ndnf makecache\n```\n\nIf selinux is enabled the following changes are required for host/port to work:\n\n```\ndnf -y install policycoreutils-python-utils\nsemanage port -a -t openvpn_port_t -p tcp 5555\nsetsebool -P httpd_can_network_connect 1\n```\n\n### Source\n\nCheckout the code:\n\n```shell\ncd /var/www/html\ngit clone https://github.com/furlongm/openvpn-monitor\ncd openvpn-monitor\nyarnpkg --prod --modules-folder openvpn_monitor/static/dist install\npython3 -m venv .venv\n. venv/bin/activate\npip install -r requirements.txt\n```\n\nRun the development server in debug mode:\n\n```shell\nflask --app openvpn_monitor/app run --debug\n```\n\n### deb/rpm\n\n### Ubuntu 24.04 (noble)\n\n```shell\ncurl -sS https://repo.openbytes.ie/openbytes.gpg > /usr/share/keyrings/openbytes.gpg\necho \"deb [signed-by=/usr/share/keyrings/openbytes.gpg] https://repo.openbytes.ie/openvpn-monitor/ubuntu noble main\" > /etc/apt/sources.list.d/openvpn-monitor.list\napt update\napt -y install python3-openvpn-monitor\n```\n\n### Debian 12 (bookworm)\n\n```shell\ncurl -sS https://repo.openbytes.ie/openbytes.gpg > /usr/share/keyrings/openbytes.gpg\necho \"deb [signed-by=/usr/share/keyrings/openbytes.gpg] https://repo.openbytes.ie/openvpn-monitor/debian bookworm main\" > /etc/apt/sources.list.d/openvpn-monitor.list\napt update\napt -y install python3-openvpn-monitor\n```\n\n### CentOS / Rocky / Alma / RHEL 9\n\n\n```shell\ncurl -sS https://repo.openbytes.ie/openbytes.gpg > /etc/pki/rpm-gpg/RPM-GPG-KEY-openbytes\ncat <<EOF >> /etc/yum.repos.d/openvpn-monitor.repo\n[openbytes]\nname=openbytes\nbaseurl=https://repo.openbytes.ie/openvpn-monitor/el9\nenabled=1\ngpgcheck=1\ngpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-openbytes\nEOF\nupdate-crypto-policies --set DEFAULT:SHA1\ndnf -y install epel-release\ndnf makecache\ndnf -y install python3-openvpn-monitor\n```\n\nSee [configuration](#configuration) for details on configuring openvpn-monitor.\n\n### apache\n\n#### Install dependencies and configure apache\n\nThese instructions assume a source checkout to /var/www/html/openvpn-monitor\n\n##### Debian / Ubuntu\n\n```shell\napt -y install git apache2 libapache2-mod-wsgi-py3 python3-geoip2 python3-humanize python3-flask python3-flaskext.wtf python3-semver yarnpkg\ncp /var/www/html/openvpn-monitor/etc/openvpn-monitor/apache.conf.example /etc/apache2/conf-available/openvpn-monitor.conf\nsed -i -e \"s#^\\(Define openvpn_monitor_pythonpath\\).*#\\1 /var/www/html/openvpn-monitor#\" /etc/apache2/conf-available/openvpn-monitor.conf\na2enconf openvpn-monitor\n\nsystemctl restart apache2\n```\n\n##### CentOS / Rocky / Alma / RHEL\n\n```shell\ndnf -y install git httpd mod_wsgi python3-geoip2 python3-humanize python3-flask python3-flask-wtf python3-semver geolite2-city yarnpkg\ncp /var/www/html/openvpn-monitor/etc/openvpn-monitor/apache.conf.example /etc/httpd/conf.d/openvpn-monitor.conf\nsed -i -e \"s#^\\(Define openvpn_monitor_pythonpath\\).*#\\1 /var/www/html/openvpn-monitor#\" /etc/httpd/conf.d/openvpn-monitor.conf\nsystemctl restart httpd\n```\n\nSee [configuration](#configuration) for details on configuring openvpn-monitor.\n\n\n### docker\n\n```shell\ndocker run -p 80:80 ruimarinho/openvpn-monitor\n```\n\nRead the [docker installation instructions](https://github.com/ruimarinho/docker-openvpn-monitor#usage)\nfor details on how to generate a dynamic configuration using only environment\nvariables.\n\n\n### virtualenv + pip + gunicorn\n\n```shell\napt -y install python3-venv # (debian/ubuntu)\ndnf -y install python3 geolite2-city # (rocky/alma/rhel)\nmkdir /srv/openvpn-monitor\ncd /srv/openvpn-monitor\npython3 -m venv .venv\n. venv/bin/activate\npip install openvpn-monitor gunicorn\ngunicorn openvpn_monitor.app -b 0.0.0.0:80\n```\n\nSee [configuration](#configuration) for details on configuring openvpn-monitor.\n\n\n### nginx + uwsgi\n\n#### Install openvpn-monitor\n\n```shell\napt -y install git gcc nginx uwsgi uwsgi-plugin-python3 python3-dev python3-venv libgeoip-dev yarnpkg # (debian/ubuntu)\ndnf -y install git gcc nginx uwsgi uwsgi-plugin-python3 python3-devel geolite2-city yarnpkg # (centos/rhel)\ncd /srv\ngit clone https://github.com/furlongm/openvpn-monitor\ncd openvpn-monitor\npython3 -m venv .venv\n. .venv/bin/activate\npip install -r requirements.txt\nyarnpkg --prod --modules-folder openvpn_monitor/static/dist install\n```\n\n#### uWSGI app config\n\nCreate a uWSGI config: `/etc/uwsgi/apps-available/openvpn-monitor.ini`\n\n```\n[uwsgi]\nbase = /srv\nproject = openvpn-monitor\nlogto = /var/log/uwsgi/app/%(project).log\nplugins = python3\nchdir = %(base)/%(project)\nvirtualenv = %(chdir)/.venv\nmodule = openvpn-monitor:application\nmanage-script-name = true\nmount=/openvpn-monitor=openvpn_monitor/app.py\n```\n\n#### Nginx site config\n\nCreate an Nginx config: `/etc/nginx/sites-available/openvpn-monitor`\n\n```\nserver {\n listen 80;\n location /openvpn-monitor/ {\n uwsgi_pass unix:///run/uwsgi/app/openvpn-monitor/socket;\n include uwsgi_params;\n }\n}\n```\n\n#### Enable uWSGI app and Nginx site, and restart services\n\n```shell\nln -s /etc/uwsgi/apps-available/openvpn-monitor.ini /etc/uwsgi/apps-enabled/\nsystemctl restart uwsgi\nln -s /etc/nginx/sites-available/openvpn-monitor /etc/nginx/sites-enabled/\nrm /etc/nginx/sites-enabled/default\nsystemctl restart nginx\n```\n\nSee [configuration](#configuration) for details on configuring openvpn-monitor.\n\n## Configuration\n\n### Configure OpenVPN\n\nAdd the following line to your OpenVPN server configuration to run the\nmanagement console on 127.0.0.1 port 5555, with the management password\nin /etc/openvpn/pw-file:\n\n```\nmanagement 127.0.0.1 5555 pw-file\n```\n\nTo run the management console on a socket, with the management password\nin /etc/openvpn/pw-file:\n\n```\nmanagement socket-name unix pw-file\n```\n\nRefer to the OpenVPN documentation for further information on how to secure\naccess to the management interface.\n\n\n### Configure openvpn-monitor\n\nCopy the example configuration file `openvpn-monitor.conf.example` to the same\ndirectory as app.py or to /etc/openvpn-monitor/openvpn-monitor.conf\n\n```shell\ncp openvpn-monitor.conf.example openvpn_monitor/openvpn-monitor.conf\n```\nor\n```shell\nmkdir -p /etc/openvpn-monitor\ncp openvpn-monitor.conf.example /etc/openvpn_monitor/openvpn-monitor.conf\n```\n\nIn this file you can set site name, add a logo, set the default map location\n(latitude and longitude). If not set, the default location is New York, USA.\n\nOnce configured, navigate to `http://myipaddress/openvpn-monitor/`\n\n\n## License\n\nopenvpn-monitor is licensed under the GPLv3, a copy of which can be found in\nthe COPYING file.\n\n\n## Acknowledgements\n\nFlags are created by Matthias Slovig (flags@slovig.de) and are licensed under\nCreative Commons License Deed Attribution-ShareAlike 3.0 Unported\n(CC BY-SA 3.0). See http://flags.blogpotato.de/ for more details.\n",
"bugtrack_url": null,
"license": "GPLv3",
"summary": "A simple web based openvpn monitor",
"version": "2.0.4",
"project_urls": {
"Homepage": "http://openvpn-monitor.openbytes.ie"
},
"split_keywords": [
"web",
"openvpn",
"monitor"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "93eaea6306d4b7e44d4dcf6b612437cbf290f9b3f23bb324b0651b90c7083962",
"md5": "0e9db09de23072bc5b60e3db06c2decf",
"sha256": "c76e997799b98b43b207a8e29f26bd2783e324a127fdef001c6d1a219ebfc639"
},
"downloads": -1,
"filename": "openvpn_monitor-2.0.4-py3-none-any.whl",
"has_sig": false,
"md5_digest": "0e9db09de23072bc5b60e3db06c2decf",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 2607263,
"upload_time": "2025-01-02T21:35:06",
"upload_time_iso_8601": "2025-01-02T21:35:06.566555Z",
"url": "https://files.pythonhosted.org/packages/93/ea/ea6306d4b7e44d4dcf6b612437cbf290f9b3f23bb324b0651b90c7083962/openvpn_monitor-2.0.4-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "5f0768327716eeb0653ae1c7b5035b8a211fb77db48a68bf8fb63aed3442e6fc",
"md5": "a6854fe51ad34fcbac93dd832fe3a1e0",
"sha256": "5e97c35694e37296a85af27157029a9ce886d6e3d881e14757cff62bcc0dbb4f"
},
"downloads": -1,
"filename": "openvpn_monitor-2.0.4.tar.gz",
"has_sig": false,
"md5_digest": "a6854fe51ad34fcbac93dd832fe3a1e0",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 2281222,
"upload_time": "2025-01-02T21:35:09",
"upload_time_iso_8601": "2025-01-02T21:35:09.782803Z",
"url": "https://files.pythonhosted.org/packages/5f/07/68327716eeb0653ae1c7b5035b8a211fb77db48a68bf8fb63aed3442e6fc/openvpn_monitor-2.0.4.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-02 21:35:09",
"github": false,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"lcname": "openvpn-monitor"
}