Lucene search
K

OpenVPN Monitor 1.1.3 Command Injection

🗓️ 24 Sep 2021 00:00:00Reported by Sylvain HeinigerType 
packetstorm
 packetstorm
🔗 packetstormsecurity.com👁 319 Views

OpenVPN Monitor 1.1.3 Command Injection, Denial of Servic

Related
Code
ReporterTitlePublishedViews
Family
0day.today
OpenVPN Monitor 1.1.3 Cross Site Request Forgery Vulnerability
25 Sep 202100:00
zdt
0day.today
OpenVPN Monitor 1.1.3 Command Injection Vulnerability
25 Sep 202100:00
zdt
0day.today
OpenVPN Monitor 1.1.3 Authorization Bypass / Denial Of Service Vulnerabilities
25 Sep 202100:00
zdt
Circl
CVE-2021-31605
27 Sep 202112:34
circl
Circl
CVE-2021-31606
27 Sep 202112:34
circl
CNNVD
Openvpn OpenVPN 命令注入漏洞
24 Sep 202100:00
cnnvd
CNNVD
Openvpn OpenVPN 授权问题漏洞
24 Sep 202100:00
cnnvd
CVE
CVE-2021-31605
27 Sep 202105:35
cve
CVE
CVE-2021-31606
27 Sep 202100:00
cve
Cvelist
CVE-2021-31605
27 Sep 202105:35
cvelist
Rows per page
`#############################################################  
#  
# COMPASS SECURITY ADVISORY  
# https://www.compass-security.com/research/advisories/  
#  
#############################################################  
#  
# Product: openvpn-monitor  
# Vendor: https://github.com/furlongm/openvpn-monitor  
# CSNC ID: CSNC-2021-010  
# CVE ID: CVE-2021-31605  
# Subject: OpenVPN Management Socket Command Injection  
# Severity: High  
# Effect: Denial of Service  
# Author: Emanuel Duss <[email protected]>  
# Sylvain Heiniger <[email protected]>  
# Date: 2021-09-22  
#  
#############################################################  
  
Introduction  
------------  
  
openvpn-monitor is a simple Python program to generate HTML that displays the  
status of an OpenVPN server, including all current connections. It uses the  
OpenVPN management console. It typically runs on the same host as the OpenVPN  
server. [0][1]  
  
During a security assessment of one of our customers, several security  
vulnerabilities were discovered in this software.  
  
This advisory describes an injection vulnerability which allows an attacker to  
inject arbitrary commands into the OpenVPN server management interface socket.  
  
  
Affected  
--------  
  
- Vulnerable: openvpn-monitor <= 1.1.3  
- Not vulnerable: none  
  
The vulnerability is already fixed in the source code [3], but there is no new  
release which contains the fix. Therefore, all currently available releases  
contain this vulnerability.  
  
  
Technical Description  
---------------------  
  
The following route is defined which processes user input sent via HTTP POST:  
  
[CUT BY COMPASS]  
@app.route('/', method='POST')  
def post_slash():  
vpn_id = request.forms.get('vpn_id')  
ip = request.forms.get('ip')  
port = request.forms.get('port')  
client_id = request.forms.get('client_id')  
return render(vpn_id=vpn_id, ip=ip, port=port, client_id=client_id)  
[CUT BY COMPASS]  
  
Depending on the OpenVPN server version, either the `ip` and `port` parameters  
or the `client_id` parameter is used in the `self.send_command(command)`  
function call as a parameter for a command in the OpenVPN server management  
interface socket:  
  
[CUT BY COMPASS]  
class OpenvpnMgmtInterface(object):  
  
def __init__(self, cfg, **kwargs):  
self.vpns = cfg.vpns  
  
if kwargs.get('vpn_id'):  
vpn = self.vpns[kwargs['vpn_id']]  
self._socket_connect(vpn)  
if vpn['socket_connected']:  
release = self.send_command('version\n')  
version = semver(self.parse_version(release).split(' ')[1])  
if version.major == 2 and \  
version.minor >= 4 and \  
kwargs.get('client_id'):  
command = 'client-kill {0!s}\n'.format(kwargs['client_id'])  
else:  
command = 'kill {0!s}:{1!s}\n'.format(kwargs['ip'], kwargs['port'])  
self.send_command(command)  
self._socket_disconnect()  
[CUT BY COMPASS]  
  
An attacker can use a newline character (`0x0a`) to inject additional commands  
into the socket. This allows an attacker for example to stop the OpenVPN server  
by sending a SIGTERM signal via the `signal SIGTERM` management command:  
  
# curl http://openvpn-monitor.example.net -d "vpn_id=UDP&ip=10.5.23.42&port=1194&client_id=5%0asignal%20SIGTERM"  
  
It's also possible to disconnect all clients at once using the `signal SIGHUP`  
command or to reconfigure the OpenVPN server or connected clients. See the  
OpenVPN documentation [2] for more information about the OpenVPN management  
interface socket and all available commands.  
  
This attack can even be performed if the client disconnect feature is disabled,  
because of an identified authorization bypass vulnerability (CVE-2021-31606).  
  
  
Vulnerability Classification  
----------------------------  
  
CVSS v3.1 Metrics [3]:  
  
* CVSS Base Score: 9.3  
* CVSS Vector: AV:N/AC:L/PR:N/UI:N/S:C/C:N/I:L/A:H  
  
  
Workaround / Fix  
----------------  
  
# openvpn-monitor Vendor  
  
The user input should be sanitized so that it is not possible anymore to break  
out of the context and inject own commands into the management socket.  
  
# openvpn-monitor Users  
  
Users of the openvpn-monitor should either apply the patch which is available  
on GitHub [2] or use the latest version from the source code repository [1].  
  
  
Timeline  
--------  
  
2021-05-05: Vulnerability discovered  
2021-04-20: Requested CVE ID @ MITRE  
2021-04-20: Contacted vendor  
2021-04-22: Sent details via email to vendor  
2021-04-24: Vendor confirmed and already started to work on a fix  
2021-09-08: Asked vendor for updates  
2021-09-08: Vendor told it's OK to publish the advisory  
2021-09-22: Public disclosure  
  
  
References  
----------  
  
[0] http://openvpn-monitor.openbytes.ie/  
[1] https://github.com/furlongm/openvpn-monitor  
[2] https://openvpn.net/community-resources/management-interface/  
[3] https://nvd.nist.gov/vuln-metrics/cvss/v3-calculator?vector=AV:N/AC:L/PR:N/UI:N/S:C/C:N/I:L/A:H&version=3.1  
  
  
`

Data

Build on a solid foundation with Vulners data

We provide the essential building blocks for cybersecurity solutions with comprehensive, structured, and constantly updated vulnerability and exploits data

Api

Power your application with Vulners API

The Vulners REST API offers reliable, high-performance access to vulnerability intelligence, with 99.9% SLA uptime and CDN-backed data delivery for seamless global access

App

Assess and manage vulnerabilities with Vulners tools

Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation

24 Sep 2021 00:00Current
7.5High risk
Vulners AI Score7.5
EPSS0.02194
319