CVE-2019-9859

Source
https://cve.org/CVERecord?id=CVE-2019-9859
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2019-9859.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2019-9859
Published
2020-03-10T13:15:12.657Z
Modified
2025-11-14T10:05:27.373412Z
Severity
  • 8.8 (High) CVSS_V3 - CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H CVSS Calculator
Summary
[none]
Details

Vesta Control Panel (VestaCP) 0.9.7 through 0.9.8-23 is vulnerable to an authenticated command execution that can result in remote root access on the server. The platform works with PHP as the frontend language and uses shell scripts to execute system actions. PHP executes shell script through the dangerous command exec. This function can be dangerous if arguments passed to it are not filtered. Every user input in VestaCP that is used as an argument is filtered with the escapeshellarg function. This function comes from the PHP library directly and its description is as follows: "escapeshellarg() adds single quotes around a string and quotes/escapes any existing single quotes allowing you to pass a string directly to a shell function and having it be treated as a single safe argument." It means that if you give Username, it will have 'Username' as a replacement. This works well and protects users from exploiting this potentially dangerous exec function. Unfortunately, VestaCP uses this escapeshellarg function incorrectly in several places.

References

Affected packages

Git / github.com/serghey-rodin/vesta

Affected ranges

Type
GIT
Repo
https://github.com/serghey-rodin/vesta
Events
Introduced
0 Unknown introduced commit / All previous commits are affected
Last affected

Affected versions

0.*
0.9.8-10
0.9.8-11
0.9.8-12
0.9.8-13
0.9.8-15
0.9.8-16
0.9.8-17
0.9.8-18
0.9.8-19
0.9.8-20
0.9.8-23

Database specific

source
"https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2019-9859.json"