Some HTTP/2 implementations are vulnerable to window size manipulation and stream prioritization manipulation, potentially leading to a denial of service. The attacker requests a large amount of data from a specified resource over multiple streams. They manipulate window size and stream priority to force the server to queue the data in 1-byte chunks. Depending on how efficiently this data is queued, this can consume excess CPU, memory, or both. (CVE-2019-9511)
Some HTTP/2 implementations are vulnerable to resource loops, potentially leading to a denial of service. The attacker creates multiple request streams and continually shuffles the priority of the streams in a way that causes substantial churn to the priority tree.
This can consume excess CPU. (CVE-2019-9513)
Some HTTP/2 implementations are vulnerable to a header leak, potentially leading to a denial of service. The attacker sends a stream of headers with a 0-length header name and 0-length header value, optionally Huffman encoded into 1-byte or greater headers. Some implementations allocate memory for these headers and keep the allocation alive until the session dies. This can consume excess memory. (CVE-2019-9516)
#
# (C) Tenable Network Security, Inc.
#
# The descriptive text and package checks in this plugin were
# extracted from Amazon Linux AMI Security Advisory ALAS-2019-1299.
#
include("compat.inc");
if (description)
{
script_id(129569);
script_version("1.4");
script_set_attribute(attribute:"plugin_modification_date", value:"2022/12/06");
script_cve_id("CVE-2019-9511", "CVE-2019-9513", "CVE-2019-9516");
script_xref(name:"ALAS", value:"2019-1299");
script_xref(name:"CEA-ID", value:"CEA-2019-0643");
script_name(english:"Amazon Linux AMI : nginx (ALAS-2019-1299) (0-Length Headers Leak) (Data Dribble) (Resource Loop)");
script_summary(english:"Checks rpm output for the updated packages");
script_set_attribute(
attribute:"synopsis",
value:"The remote Amazon Linux AMI host is missing a security update."
);
script_set_attribute(
attribute:"description",
value:
"Some HTTP/2 implementations are vulnerable to window size manipulation
and stream prioritization manipulation, potentially leading to a
denial of service. The attacker requests a large amount of data from a
specified resource over multiple streams. They manipulate window size
and stream priority to force the server to queue the data in 1-byte
chunks. Depending on how efficiently this data is queued, this can
consume excess CPU, memory, or both. (CVE-2019-9511)
Some HTTP/2 implementations are vulnerable to resource loops,
potentially leading to a denial of service. The attacker creates
multiple request streams and continually shuffles the priority of the
streams in a way that causes substantial churn to the priority tree.
This can consume excess CPU. (CVE-2019-9513)
Some HTTP/2 implementations are vulnerable to a header leak,
potentially leading to a denial of service. The attacker sends a
stream of headers with a 0-length header name and 0-length header
value, optionally Huffman encoded into 1-byte or greater headers. Some
implementations allocate memory for these headers and keep the
allocation alive until the session dies. This can consume excess
memory. (CVE-2019-9516)"
);
script_set_attribute(
attribute:"see_also",
value:"https://alas.aws.amazon.com/ALAS-2019-1299.html"
);
script_set_attribute(
attribute:"solution",
value:"Run 'yum update nginx' to update your system."
);
script_set_cvss_base_vector("CVSS2#AV:N/AC:L/Au:N/C:N/I:N/A:C");
script_set_cvss_temporal_vector("CVSS2#E:U/RL:OF/RC:C");
script_set_cvss3_base_vector("CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H");
script_set_cvss3_temporal_vector("CVSS:3.0/E:U/RL:O/RC:C");
script_set_attribute(attribute:"exploitability_ease", value:"No known exploits are available");
script_set_attribute(attribute:"plugin_type", value:"local");
script_set_attribute(attribute:"cpe", value:"p-cpe:/a:amazon:linux:nginx");
script_set_attribute(attribute:"cpe", value:"p-cpe:/a:amazon:linux:nginx-all-modules");
script_set_attribute(attribute:"cpe", value:"p-cpe:/a:amazon:linux:nginx-debuginfo");
script_set_attribute(attribute:"cpe", value:"p-cpe:/a:amazon:linux:nginx-mod-http-geoip");
script_set_attribute(attribute:"cpe", value:"p-cpe:/a:amazon:linux:nginx-mod-http-image-filter");
script_set_attribute(attribute:"cpe", value:"p-cpe:/a:amazon:linux:nginx-mod-http-perl");
script_set_attribute(attribute:"cpe", value:"p-cpe:/a:amazon:linux:nginx-mod-http-xslt-filter");
script_set_attribute(attribute:"cpe", value:"p-cpe:/a:amazon:linux:nginx-mod-mail");
script_set_attribute(attribute:"cpe", value:"p-cpe:/a:amazon:linux:nginx-mod-stream");
script_set_attribute(attribute:"cpe", value:"cpe:/o:amazon:linux");
script_set_attribute(attribute:"vuln_publication_date", value:"2019/08/13");
script_set_attribute(attribute:"patch_publication_date", value:"2019/09/30");
script_set_attribute(attribute:"plugin_publication_date", value:"2019/10/04");
script_set_attribute(attribute:"in_the_news", value:"true");
script_set_attribute(attribute:"generated_plugin", value:"current");
script_end_attributes();
script_category(ACT_GATHER_INFO);
script_copyright(english:"This script is Copyright (C) 2019-2022 and is owned by Tenable, Inc. or an Affiliate thereof.");
script_family(english:"Amazon Linux Local Security Checks");
script_dependencies("ssh_get_info.nasl");
script_require_keys("Host/local_checks_enabled", "Host/AmazonLinux/release", "Host/AmazonLinux/rpm-list");
exit(0);
}
include("audit.inc");
include("global_settings.inc");
include("rpm.inc");
if (!get_kb_item("Host/local_checks_enabled")) audit(AUDIT_LOCAL_CHECKS_NOT_ENABLED);
release = get_kb_item("Host/AmazonLinux/release");
if (isnull(release) || !strlen(release)) audit(AUDIT_OS_NOT, "Amazon Linux");
os_ver = pregmatch(pattern: "^AL(A|\d)", string:release);
if (isnull(os_ver)) audit(AUDIT_UNKNOWN_APP_VER, "Amazon Linux");
os_ver = os_ver[1];
if (os_ver != "A")
{
if (os_ver == 'A') os_ver = 'AMI';
audit(AUDIT_OS_NOT, "Amazon Linux AMI", "Amazon Linux " + os_ver);
}
if (!get_kb_item("Host/AmazonLinux/rpm-list")) audit(AUDIT_PACKAGE_LIST_MISSING);
flag = 0;
if (rpm_check(release:"ALA", reference:"nginx-1.16.1-1.37.amzn1")) flag++;
if (rpm_check(release:"ALA", reference:"nginx-all-modules-1.16.1-1.37.amzn1")) flag++;
if (rpm_check(release:"ALA", reference:"nginx-debuginfo-1.16.1-1.37.amzn1")) flag++;
if (rpm_check(release:"ALA", reference:"nginx-mod-http-geoip-1.16.1-1.37.amzn1")) flag++;
if (rpm_check(release:"ALA", reference:"nginx-mod-http-image-filter-1.16.1-1.37.amzn1")) flag++;
if (rpm_check(release:"ALA", reference:"nginx-mod-http-perl-1.16.1-1.37.amzn1")) flag++;
if (rpm_check(release:"ALA", reference:"nginx-mod-http-xslt-filter-1.16.1-1.37.amzn1")) flag++;
if (rpm_check(release:"ALA", reference:"nginx-mod-mail-1.16.1-1.37.amzn1")) flag++;
if (rpm_check(release:"ALA", reference:"nginx-mod-stream-1.16.1-1.37.amzn1")) flag++;
if (flag)
{
if (report_verbosity > 0) security_hole(port:0, extra:rpm_report_get());
else security_hole(0);
exit(0);
}
else
{
tested = pkg_tests_get();
if (tested) audit(AUDIT_PACKAGE_NOT_AFFECTED, tested);
else audit(AUDIT_PACKAGE_NOT_INSTALLED, "nginx / nginx-all-modules / nginx-debuginfo / nginx-mod-http-geoip / etc");
}
Vendor | Product | Version | CPE |
---|---|---|---|
amazon | linux | nginx | p-cpe:/a:amazon:linux:nginx |
amazon | linux | nginx-all-modules | p-cpe:/a:amazon:linux:nginx-all-modules |
amazon | linux | nginx-debuginfo | p-cpe:/a:amazon:linux:nginx-debuginfo |
amazon | linux | nginx-mod-http-geoip | p-cpe:/a:amazon:linux:nginx-mod-http-geoip |
amazon | linux | nginx-mod-http-image-filter | p-cpe:/a:amazon:linux:nginx-mod-http-image-filter |
amazon | linux | nginx-mod-http-perl | p-cpe:/a:amazon:linux:nginx-mod-http-perl |
amazon | linux | nginx-mod-http-xslt-filter | p-cpe:/a:amazon:linux:nginx-mod-http-xslt-filter |
amazon | linux | nginx-mod-mail | p-cpe:/a:amazon:linux:nginx-mod-mail |
amazon | linux | nginx-mod-stream | p-cpe:/a:amazon:linux:nginx-mod-stream |
amazon | linux | cpe:/o:amazon:linux |