EulerOS 2.0 SP10 golang vulnerabilities CVE-2023-39323, CVE-2023-39325, CVE-2023-4448
Reporter | Title | Published | Views | Family All 199 |
---|---|---|---|---|
![]() | Amazon Linux 2023 : golang, golang-bin, golang-misc (ALAS2023-2023-394) | 19 Oct 202300:00 | – | nessus |
![]() | Fedora 39 : golang (2023-822aab0a5a) | 7 Nov 202300:00 | – | nessus |
![]() | EulerOS 2.0 SP10 : golang (EulerOS-SA-2024-1058) | 16 Jan 202400:00 | – | nessus |
![]() | Amazon Linux AMI : golang (ALAS-2023-1871) | 19 Oct 202300:00 | – | nessus |
![]() | Fedora 37 : golang (2023-4bf641255e) | 29 Oct 202300:00 | – | nessus |
![]() | Fedora 38 : golang (2023-fe53e13b5b) | 29 Oct 202300:00 | – | nessus |
![]() | Amazon Linux 2 : golang (ALAS-2023-2313) | 17 Oct 202300:00 | – | nessus |
![]() | EulerOS 2.0 SP11 : golang (EulerOS-SA-2023-3270) | 16 Jan 202400:00 | – | nessus |
![]() | EulerOS 2.0 SP11 : golang (EulerOS-SA-2023-3242) | 16 Jan 202400:00 | – | nessus |
![]() | SUSE SLED15 / SLES15 / openSUSE 15 Security Update : go1.20-openssl (SUSE-SU-2023:4472-1) | 17 Nov 202300:00 | – | nessus |
#%NASL_MIN_LEVEL 80900
##
# (C) Tenable, Inc.
##
include('compat.inc');
if (description)
{
script_id(188765);
script_version("1.1");
script_set_attribute(attribute:"plugin_modification_date", value:"2024/02/09");
script_cve_id("CVE-2023-39323", "CVE-2023-39325", "CVE-2023-44487");
script_xref(name:"CISA-KNOWN-EXPLOITED", value:"2023/10/31");
script_xref(name:"CEA-ID", value:"CEA-2024-0004");
script_name(english:"EulerOS 2.0 SP10 : golang (EulerOS-SA-2024-1082)");
script_set_attribute(attribute:"synopsis", value:
"The remote EulerOS host is missing multiple security updates.");
script_set_attribute(attribute:"description", value:
"According to the versions of the golang packages installed, the EulerOS installation on the remote host is affected by
the following vulnerabilities :
- Line directives ('//line') can be used to bypass the restrictions on '//go:cgo_' directives, allowing
blocked linker and compiler flags to be passed during compilation. This can result in unexpected execution
of arbitrary code when running 'go build'. The line directive requires the absolute path of the file in
which the directive lives, which makes exploiting this issue significantly more complex. (CVE-2023-39323)
- A malicious HTTP/2 client which rapidly creates requests and immediately resets them can cause excessive
server resource consumption. While the total number of requests is bounded by the
http2.Server.MaxConcurrentStreams setting, resetting an in-progress request allows the attacker to create
a new request while the existing one is still executing. With the fix applied, HTTP/2 servers now bound
the number of simultaneously executing handler goroutines to the stream concurrency limit
(MaxConcurrentStreams). New requests arriving when at the limit (which can only happen after the client
has reset an existing, in-flight request) will be queued until a handler exits. If the request queue grows
too large, the server will terminate the connection. This issue is also fixed in golang.org/x/net/http2
for users manually configuring HTTP/2. The default stream concurrency limit is 250 streams (requests) per
HTTP/2 connection. This value may be adjusted using the golang.org/x/net/http2 package; see the
Server.MaxConcurrentStreams setting and the ConfigureServer function. (CVE-2023-39325)
- The HTTP/2 protocol allows a denial of service (server resource consumption) because request cancellation
can reset many streams quickly, as exploited in the wild in August through October 2023. (CVE-2023-44487)
Note that Tenable Network Security has extracted the preceding description block directly from the EulerOS security
advisory. Tenable has attempted to automatically clean and format it as much as possible without introducing additional
issues.");
# https://developer.huaweicloud.com/ict/en/site-euleros/euleros/security-advisories/EulerOS-SA-2024-1082
script_set_attribute(attribute:"see_also", value:"http://www.nessus.org/u?c8981ed5");
script_set_attribute(attribute:"solution", value:
"Update the affected golang packages.");
script_set_cvss_base_vector("CVSS2#AV:N/AC:H/Au:N/C:C/I:C/A:C");
script_set_cvss_temporal_vector("CVSS2#E:F/RL:OF/RC:C");
script_set_cvss3_base_vector("CVSS:3.0/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H");
script_set_cvss3_temporal_vector("CVSS:3.0/E:F/RL:O/RC:C");
script_set_attribute(attribute:"cvss_score_source", value:"CVE-2023-39323");
script_set_attribute(attribute:"exploitability_ease", value:"Exploits are available");
script_set_attribute(attribute:"exploit_available", value:"true");
script_set_attribute(attribute:"vuln_publication_date", value:"2023/10/05");
script_set_attribute(attribute:"patch_publication_date", value:"2024/01/08");
script_set_attribute(attribute:"plugin_publication_date", value:"2024/01/16");
script_set_attribute(attribute:"plugin_type", value:"local");
script_set_attribute(attribute:"cpe", value:"p-cpe:/a:huawei:euleros:golang");
script_set_attribute(attribute:"cpe", value:"p-cpe:/a:huawei:euleros:golang-devel");
script_set_attribute(attribute:"cpe", value:"p-cpe:/a:huawei:euleros:golang-help");
script_set_attribute(attribute:"cpe", value:"cpe:/o:huawei:euleros:2.0");
script_set_attribute(attribute:"generated_plugin", value:"current");
script_end_attributes();
script_category(ACT_GATHER_INFO);
script_family(english:"Huawei Local Security Checks");
script_copyright(english:"This script is Copyright (C) 2024 and is owned by Tenable, Inc. or an Affiliate thereof.");
script_dependencies("ssh_get_info.nasl");
script_require_keys("Host/local_checks_enabled", "Host/cpu", "Host/EulerOS/release", "Host/EulerOS/rpm-list", "Host/EulerOS/sp");
script_exclude_keys("Host/EulerOS/uvp_version");
exit(0);
}
include("rpm.inc");
if (!get_kb_item("Host/local_checks_enabled")) audit(AUDIT_LOCAL_CHECKS_NOT_ENABLED);
var _release = get_kb_item("Host/EulerOS/release");
if (isnull(_release) || _release !~ "^EulerOS") audit(AUDIT_OS_NOT, "EulerOS");
var uvp = get_kb_item("Host/EulerOS/uvp_version");
if (_release !~ "^EulerOS release 2\.0(\D|$)") audit(AUDIT_OS_NOT, "EulerOS 2.0 SP10");
var sp = get_kb_item("Host/EulerOS/sp");
if (isnull(sp) || sp !~ "^(10)$") audit(AUDIT_OS_NOT, "EulerOS 2.0 SP10");
if (!empty_or_null(uvp)) audit(AUDIT_OS_NOT, "EulerOS 2.0 SP10", "EulerOS UVP " + uvp);
if (!get_kb_item("Host/EulerOS/rpm-list")) audit(AUDIT_PACKAGE_LIST_MISSING);
var cpu = get_kb_item("Host/cpu");
if (isnull(cpu)) audit(AUDIT_UNKNOWN_ARCH);
if ("x86_64" >!< cpu && cpu !~ "^i[3-6]86$" && "aarch64" >!< cpu && "x86" >!< cpu) audit(AUDIT_LOCAL_CHECKS_NOT_IMPLEMENTED, "EulerOS", cpu);
if ("aarch64" >!< cpu) audit(AUDIT_ARCH_NOT, "aarch64", cpu);
var flag = 0;
var pkgs = [
"golang-1.15.7-15.h25.eulerosv2r10",
"golang-devel-1.15.7-15.h25.eulerosv2r10",
"golang-help-1.15.7-15.h25.eulerosv2r10"
];
foreach (var pkg in pkgs)
if (rpm_check(release:"EulerOS-2.0", sp:"10", reference:pkg)) flag++;
if (flag)
{
security_report_v4(
port : 0,
severity : SECURITY_HOLE,
extra : rpm_report_get()
);
exit(0);
}
else
{
var tested = pkg_tests_get();
if (tested) audit(AUDIT_PACKAGE_NOT_AFFECTED, tested);
else audit(AUDIT_PACKAGE_NOT_INSTALLED, "golang");
}
Transform Your Security Services
Elevate your offerings with Vulners' advanced Vulnerability Intelligence. Contact us for a demo and discover the difference comprehensive, actionable intelligence can make in your security strategy.
Book a live demo