| Reporter | Title | Published | Views | Family All 544 |
|---|---|---|---|---|
| freerdp -- multiple vulnerabilities | 24 Dec 202200:00 | – | freebsd | |
| Security fix for the ALT Linux 9 package freerdp version 2.9.0-alt1 | 6 Dec 202200:00 | – | altlinux | |
| Amazon Linux 2 : freerdp, freerdp-devel, freerdp-libs (ALAS-2023-1930) | 6 Feb 202300:00 | – | nessus | |
| Amazon Linux 2 : freerdp (ALAS-2023-2269) | 5 Oct 202300:00 | – | nessus | |
| Alibaba Cloud Linux 3 : 0064: freerdp (ALINUX3-SA-2023:0064) | 14 May 202500:00 | – | nessus | |
| AlmaLinux 9 : freerdp (ALSA-2023:2326) | 14 May 202300:00 | – | nessus | |
| AlmaLinux 8 : freerdp (ALSA-2023:2851) | 20 May 202300:00 | – | nessus | |
| CentOS 8 : freerdp (CESA-2023:2851) | 17 May 202300:00 | – | nessus | |
| CentOS 9 : freerdp-2.4.1-5.el9 | 26 Apr 202400:00 | – | nessus | |
| Debian dla-3606 : freerdp2-dev - security update | 8 Oct 202300:00 | – | nessus |
#%NASL_MIN_LEVEL 80900
##
# (C) Tenable, Inc.
#
# The descriptive text and package checks in this plugin were
# extracted from Tencent Linux Security Advisory TSSA-2024:0135.
##
include('compat.inc');
if (description)
{
script_id(276130);
script_version("1.2");
script_set_attribute(attribute:"plugin_modification_date", value:"2026/02/24");
script_cve_id(
"CVE-2022-39316",
"CVE-2022-39317",
"CVE-2022-39318",
"CVE-2022-39319",
"CVE-2022-39320",
"CVE-2022-39347",
"CVE-2022-41877",
"CVE-2023-39350",
"CVE-2023-39351",
"CVE-2023-39352",
"CVE-2023-39353",
"CVE-2023-39354",
"CVE-2023-39356",
"CVE-2023-40181",
"CVE-2023-40186",
"CVE-2023-40188",
"CVE-2023-40567",
"CVE-2023-40569",
"CVE-2023-40589"
);
script_xref(name:"IAVA", value:"2024-A-0259-S");
script_name(english:"TencentOS Server 4: freerdp (TSSA-2024:0135)");
script_set_attribute(attribute:"synopsis", value:
"The remote TencentOS Server 4 host is missing one or more security updates.");
script_set_attribute(attribute:"description", value:
"The version of Tencent Linux installed on the remote TencentOS Server 4 host is prior to tested version. It is,
therefore, affected by multiple vulnerabilities as referenced in the TSSA-2024:0135 advisory.
Package updates are available for TencentOS Server 4 that fix the following vulnerabilities:
CVE-2022-39316:
FreeRDP is a free remote desktop protocol library and clients. In affected versions there is an out of
bound read in ZGFX decoder component of FreeRDP. A malicious server can trick a FreeRDP based client to
read out of bound data and try to decode it likely resulting in a crash. This issue has been addressed in
the 2.9.0 release. Users are advised to upgrade.
CVE-2022-39317:
FreeRDP is a free remote desktop protocol library and clients. Affected versions of FreeRDP are missing a
range check for input offset index in ZGFX decoder. A malicious server can trick a FreeRDP based client to
read out of bound data and try to decode it. This issue has been addressed in version 2.9.0. There are no
known workarounds for this issue.
CVE-2022-39318:
FreeRDP is a free remote desktop protocol library and clients. Affected versions of FreeRDP are missing
input validation in `urbdrc` channel. A malicious server can trick a FreeRDP based client to crash with
division by zero. This issue has been addressed in version 2.9.0. All users are advised to upgrade. Users
unable to upgrade should not use the `/usb` redirection switch.
CVE-2022-39319:
FreeRDP is a free remote desktop protocol library and clients. Affected versions of FreeRDP are missing
input length validation in the `urbdrc` channel. A malicious server can trick a FreeRDP based client to
read out of bound data and send it back to the server. This issue has been addressed in version 2.9.0 and
all users are advised to upgrade. Users unable to upgrade should not use the `/usb` redirection switch.
CVE-2022-39320:
FreeRDP is a free remote desktop protocol library and clients. Affected versions of FreeRDP may attempt
integer addition on too narrow types leads to allocation of a buffer too small holding the data written. A
malicious server can trick a FreeRDP based client to read out of bound data and send it back to the
server. This issue has been addressed in version 2.9.0 and all users are advised to upgrade. Users unable
to upgrade should not use the `/usb` redirection switch.
CVE-2022-39347:
FreeRDP is a free remote desktop protocol library and clients. Affected versions of FreeRDP are missing
path canonicalization and base path check for `drive` channel. A malicious server can trick a FreeRDP
based client to read files outside the shared directory. This issue has been addressed in version 2.9.0
and all users are advised to upgrade. Users unable to upgrade should not use the `/drive`, `/drives` or
`+home-drive` redirection switch.
CVE-2022-41877:
FreeRDP is a free remote desktop protocol library and clients. Affected versions of FreeRDP are missing
input length validation in `drive` channel. A malicious server can trick a FreeRDP based client to read
out of bound data and send it back to the server. This issue has been addressed in version 2.9.0 and all
users are advised to upgrade. Users unable to upgrade should not use the drive redirection channel -
command line options `/drive`, `+drives` or `+home-drive`.
CVE-2023-39350:
FreeRDP is a free implementation of the Remote Desktop Protocol (RDP), released under the Apache license.
This issue affects Clients only. Integer underflow leading to DOS (e.g. abort due to `WINPR_ASSERT` with
default compilation flags). When an insufficient blockLen is provided, and proper length validation is not
performed, an Integer Underflow occurs, leading to a Denial of Service (DOS) vulnerability. This issue has
been addressed in versions 2.11.0 and 3.0.0-beta3. Users are advised to upgrade. There are no known
workarounds for this vulnerability.
CVE-2023-39351:
FreeRDP is a free implementation of the Remote Desktop Protocol (RDP), released under the Apache license.
Affected versions of FreeRDP are subject to a Null Pointer Dereference leading a crash in the RemoteFX
(rfx) handling. Inside the `rfx_process_message_tileset` function, the program allocates tiles using
`rfx_allocate_tiles` for the number of numTiles. If the initialization process of tiles is not completed
for various reasons, tiles will have a NULL pointer. Which may be accessed in further processing and would
cause a program crash. This issue has been addressed in versions 2.11.0 and 3.0.0-beta3. Users are advised
to upgrade. There are no known workarounds for this vulnerability.
CVE-2023-39352:
FreeRDP is a free implementation of the Remote Desktop Protocol (RDP), released under the Apache license.
Affected versions are subject to an invalid offset validation leading to Out Of Bound Write. This can be
triggered when the values `rect->left` and `rect->top` are exactly equal to `surface->width` and
`surface->height`. eg. `rect->left` == `surface->width` && `rect->top` == `surface->height`. In practice
this should cause a crash. This issue has been addressed in versions 2.11.0 and 3.0.0-beta3. Users are
advised to upgrade. There are no known workarounds for this vulnerability.
CVE-2023-39353:
FreeRDP is a free implementation of the Remote Desktop Protocol (RDP), released under the Apache license.
Affected versions are subject to a missing offset validation leading to Out Of Bound Read. In the
`libfreerdp/codec/rfx.c` file there is no offset validation in `tile->quantIdxY`, `tile->quantIdxCb`, and
`tile->quantIdxCr`. As a result crafted input can lead to an out of bounds read access which in turn will
cause a crash. This issue has been addressed in versions 2.11.0 and 3.0.0-beta3. Users are advised to
upgrade. There are no known workarounds for this vulnerability.
CVE-2023-39354:
FreeRDP is a free implementation of the Remote Desktop Protocol (RDP), released under the Apache license.
Affected versions are subject to an Out-Of-Bounds Read in the `nsc_rle_decompress_data` function. The Out-
Of-Bounds Read occurs because it processes `context->Planes` without checking if it contains data of
sufficient length. Should an attacker be able to leverage this vulnerability they may be able to cause a
crash. This issue has been addressed in versions 2.11.0 and 3.0.0-beta3. Users are advised to upgrade.
There are no known workarounds for this vulnerability.
CVE-2023-39356:
FreeRDP is a free implementation of the Remote Desktop Protocol (RDP), released under the Apache license.
In affected versions a missing offset validation may lead to an Out Of Bound Read in the function
`gdi_multi_opaque_rect`. In particular there is no code to validate if the value
`multi_opaque_rect->numRectangles` is less than 45. Looping through `multi_opaque_rect->`numRectangles
without proper boundary checks can lead to Out-of-Bounds Read errors which will likely lead to a crash.
This issue has been addressed in versions 2.11.0 and 3.0.0-beta3. Users are advised to upgrade. There are
no known workarounds for this vulnerability.
CVE-2023-40181:
FreeRDP is a free implementation of the Remote Desktop Protocol (RDP), released under the Apache license.
Affected versions are subject to an Integer-Underflow leading to Out-Of-Bound Read in the
`zgfx_decompress_segment` function. In the context of `CopyMemory`, it's possible to read data beyond the
transmitted packet range and likely cause a crash. This issue has been addressed in versions 2.11.0 and
3.0.0-beta3. Users are advised to upgrade. There are no known workarounds for this issue.
CVE-2023-40186:
FreeRDP is a free implementation of the Remote Desktop Protocol (RDP), released under the Apache license.
Affected versions are subject to an IntegerOverflow leading to Out-Of-Bound Write Vulnerability in the
`gdi_CreateSurface` function. This issue affects FreeRDP based clients only. FreeRDP proxies are not
affected as image decoding is not done by a proxy. This issue has been addressed in versions 2.11.0 and
3.0.0-beta3. Users are advised to upgrade. There are no known workarounds for this issue.
CVE-2023-40188:
FreeRDP is a free implementation of the Remote Desktop Protocol (RDP), released under the Apache license.
Affected versions are subject to an Out-Of-Bounds Read in the `general_LumaToYUV444` function. This Out-
Of-Bounds Read occurs because processing is done on the `in` variable without checking if it contains data
of sufficient length. Insufficient data for the `in` variable may cause errors or crashes. This issue has
been addressed in versions 2.11.0 and 3.0.0-beta3. Users are advised to upgrade. There are no known
workarounds for this issue.
CVE-2023-40567:
FreeRDP is a free implementation of the Remote Desktop Protocol (RDP), released under the Apache license.
Affected versions are subject to an Out-Of-Bounds Write in the `clear_decompress_bands_data` function in
which there is no offset validation. Abuse of this vulnerability may lead to an out of bounds write. This
issue has been addressed in versions 2.11.0 and 3.0.0-beta3. Users are advised to upgrade. there are no
known workarounds for this vulnerability.
CVE-2023-40569:
FreeRDP is a free implementation of the Remote Desktop Protocol (RDP), released under the Apache license.
Affected versions are subject to an Out-Of-Bounds Write in the `progressive_decompress` function. This
issue is likely down to incorrect calculations of the `nXSrc` and `nYSrc` variables. This issue has been
addressed in versions 2.11.0 and 3.0.0-beta3. Users are advised to upgrade. there are no known workarounds
for this vulnerability.
CVE-2023-40589:
FreeRDP is a free implementation of the Remote Desktop Protocol (RDP), released under the Apache license.
In affected versions there is a Global-Buffer-Overflow in the ncrush_decompress function. Feeding crafted
input into this function can trigger the overflow which has only been shown to cause a crash. This issue
has been addressed in versions 2.11.0 and 3.0.0-beta3. Users are advised to upgrade. There are no known
workarounds for this issue.
Tenable has extracted the preceding description block directly from the Tencent Linux security advisory.
Note that Nessus has not tested for these issues but has instead relied only on the application's self-reported version
number.");
script_set_attribute(attribute:"see_also", value:"https://mirrors.tencent.com/tlinux/errata/tssa-20240135.xml");
script_set_attribute(attribute:"solution", value:
"Update the affected packages.");
script_set_cvss_base_vector("CVSS2#AV:N/AC:L/Au:N/C:C/I:C/A:C");
script_set_cvss_temporal_vector("CVSS2#E:POC/RL:OF/RC:C");
script_set_cvss3_base_vector("CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H");
script_set_cvss3_temporal_vector("CVSS:3.0/E:P/RL:O/RC:C");
script_set_attribute(attribute:"cvss_score_source", value:"CVE-2023-40569");
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:"2022/11/16");
script_set_attribute(attribute:"patch_publication_date", value:"2024/05/08");
script_set_attribute(attribute:"plugin_publication_date", value:"2025/11/20");
script_set_attribute(attribute:"plugin_type", value:"local");
script_set_attribute(attribute:"cpe", value:"cpe:/o:tencent:tencentos_server:4");
script_set_attribute(attribute:"cpe", value:"p-cpe:/a:tencent:tencentos_server:freerdp");
script_set_attribute(attribute:"generated_plugin", value:"current");
script_set_attribute(attribute:"stig_severity", value:"I");
script_end_attributes();
script_category(ACT_GATHER_INFO);
script_family(english:"Tencent Local Security Checks");
script_copyright(english:"This script is Copyright (C) 2025-2026 and is owned by Tenable, Inc. or an Affiliate thereof.");
script_dependencies("ssh_get_info2.nasl");
script_require_keys("Host/local_checks_enabled", "Host/etc/os-release", "Host/TencentOS/rpm-list", "Host/cpu");
exit(0);
}
include('rpm2.inc');
if (!get_kb_item('Host/local_checks_enabled')) audit(AUDIT_LOCAL_CHECKS_NOT_ENABLED);
var os_product = get_kb_item('installed_os/local/SSH/0/product');
if (isnull(os_product) || 'TencentOS' >!< os_product) audit(AUDIT_OS_NOT, 'TencentOS');
var os_version = get_kb_item('installed_os/local/SSH/0/version');
if (isnull(os_version)) audit(AUDIT_UNKNOWN_APP_VER, 'TencentOS');
if (! preg(pattern:"^4([^0-9]|$)", string:os_version)) audit(AUDIT_OS_NOT, 'TencentOS 4.x', 'TencentOS ' + os_version);
if (!get_kb_item('Host/TencentOS/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$" && 's390' >!< cpu && 'aarch64' >!< cpu) audit(AUDIT_LOCAL_CHECKS_NOT_IMPLEMENTED, 'TencentOS', cpu);
var constraints = [
{
'release': '4',
'pkgs': [
{'reference':'freerdp-2.11.2-1.tl4', 'cpu':'aarch64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'freerdp-2.11.2-1.tl4', 'cpu':'x86_64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'freerdp-debuginfo-2.11.2-1.tl4', 'cpu':'aarch64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'freerdp-debuginfo-2.11.2-1.tl4', 'cpu':'x86_64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'freerdp-debugsource-2.11.2-1.tl4', 'cpu':'aarch64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'freerdp-debugsource-2.11.2-1.tl4', 'cpu':'x86_64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'freerdp-devel-2.11.2-1.tl4', 'cpu':'aarch64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'freerdp-devel-2.11.2-1.tl4', 'cpu':'x86_64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'freerdp-libs-2.11.2-1.tl4', 'cpu':'aarch64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'freerdp-libs-2.11.2-1.tl4', 'cpu':'x86_64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'freerdp-libs-debuginfo-2.11.2-1.tl4', 'cpu':'aarch64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'freerdp-libs-debuginfo-2.11.2-1.tl4', 'cpu':'x86_64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'freerdp-server-2.11.2-1.tl4', 'cpu':'aarch64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'freerdp-server-2.11.2-1.tl4', 'cpu':'x86_64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'freerdp-server-debuginfo-2.11.2-1.tl4', 'cpu':'aarch64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'freerdp-server-debuginfo-2.11.2-1.tl4', 'cpu':'x86_64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'libwinpr-2.11.2-1.tl4', 'cpu':'aarch64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'libwinpr-2.11.2-1.tl4', 'cpu':'x86_64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'libwinpr-debuginfo-2.11.2-1.tl4', 'cpu':'aarch64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'libwinpr-debuginfo-2.11.2-1.tl4', 'cpu':'x86_64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'libwinpr-devel-2.11.2-1.tl4', 'cpu':'aarch64', 'rpm_spec_vers_cmp':TRUE},
{'reference':'libwinpr-devel-2.11.2-1.tl4', 'cpu':'x86_64', 'rpm_spec_vers_cmp':TRUE}
]
}
];
var os_release = get_one_kb_item('installed_os/local/SSH/0/release');
var os_sp = get_one_kb_item('Host/*/minor_release');
var flag = 0;
var reference;
var sp;
var _cpu;
var el_string;
var rpm_spec_vers_cmp;
var epoch;
var allowmaj;
var exists_check;
var cves;
foreach var constraint ( constraints ) {
# Check that the target release is equal to the affected release
if (!empty_or_null(constraint['release'])){
if (constraint['release'] != os_release) continue;
}
if (!empty_or_null(constraint['sp'])){
if (constraint['sp'] != os_sp) continue;
}
foreach var pkg ( constraint['pkgs'] ) {
reference = NULL;
sp = NULL;
_cpu = NULL;
el_string = NULL;
rpm_spec_vers_cmp = NULL;
epoch = NULL;
allowmaj = NULL;
exists_check = NULL;
cves = NULL;
if (!empty_or_null(pkg['reference'])) reference = pkg['reference'];
if (!empty_or_null(pkg['sp'])) sp = pkg['sp'];
if (!empty_or_null(pkg['cpu'])) _cpu = pkg['cpu'];
if (!empty_or_null(pkg['el_string'])) el_string = pkg['el_string'];
if (!empty_or_null(pkg['rpm_spec_vers_cmp'])) rpm_spec_vers_cmp = pkg['rpm_spec_vers_cmp'];
if (!empty_or_null(pkg['epoch'])) epoch = pkg['epoch'];
if (!empty_or_null(pkg['allowmaj'])) allowmaj = pkg['allowmaj'];
if (!empty_or_null(pkg['exists_check'])) exists_check = pkg['exists_check'];
if (!empty_or_null(pkg['cves'])) cves = pkg['cves'];
if (reference &&
## (no known rpm to check OR known rpm_exists)
(!exists_check || rpm_exists(rpm:exists_check)) &&
rpm_check(sp:sp, cpu:_cpu, reference:reference, epoch:epoch, el_string:el_string, rpm_spec_vers_cmp:rpm_spec_vers_cmp, allowmaj:allowmaj, cves:cves)) 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, 'freerdp / freerdp-debuginfo / freerdp-debugsource / etc');
}
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