CVE-2019-5477
Vulnerability Summary
Timeline
Description
A command injection vulnerability in Nokogiri v1.10.3 and earlier allows commands to be executed in a subprocess via Ruby's `Kernel.open` method. Processes are vulnerable only if the undocumented method `Nokogiri::CSS::Tokenizer#load_file` is being called with unsafe user input as the filename. This vulnerability appears in code generated by the Rexical gem versions v1.0.6 and earlier. Rexical is used by Nokogiri to generate lexical scanner code for parsing CSS queries. The underlying vulnerability was addressed in Rexical v1.0.7 and Nokogiri upgraded to this version of Rexical in Nokogiri v1.10.4.
CVSS Metrics
- v3.1•CRITICAL•Score: 9.8CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
- v2.0•HIGH•Score: 7.5AV:N/AC:L/Au:N/C:P/I:P/A:P
EPSS Trends
Current EPSS score: 9.32%• Percentile: 93%
Techniques & Countermeasures
- CWE-78•Improper Neutralization of Special Elements used in an OS Command ('OS Command Injection')
The product constructs all or part of an OS command using externally-influenced input from an upstream component, but it does not neutralize or incorrectly neutralizes special elements that could modify the intended OS command when it is sent to a downstream component.
Affected Systems
- canonical•ubuntu_linux
16.04 | 18.04 | 19.04 | 19.10
- debian•debian_linux
8.0 | 10.0
- nokogiri•nokogiri
≤ 1.10.3
References (8)
- https://hackerone.com/reports/650835
- https://github.com/tenderlove/rexical/blob/master/CHANGELOG.rdoc
- https://github.com/sparklemotion/nokogiri/issues/1915
- https://lists.debian.org/debian-lts-announce/2019/09/msg00027.html
- https://usn.ubuntu.com/4175-1/
- https://security.gentoo.org/glsa/202006-05
- https://lists.debian.org/debian-lts-announce/2022/10/msg00018.html
- https://lists.debian.org/debian-lts-announce/2022/10/msg00019.html