CVE-2026-39983
Description
basic-ftp is an FTP client for Node.js. Prior to 5.2.1, basic-ftp allows FTP command injection via CRLF sequences (\r\n) in file path parameters passed to high-level path APIs such as cd(), remove(), rename(), uploadFrom(), downloadTo(), list(), and removeDir(). The library's protectWhitespace() helper only handles leading spaces and returns other paths unchanged, while FtpContext.send() writes the resulting command string directly to the control socket with \r\n appended. This lets attacker-controlled path strings split one intended FTP command into multiple commands. This vulnerability is fixed in 5.2.1.
AI Insight
LLM-synthesized narrative grounded in this CVE's description and references.
Affected packages
Versions sourced from the GitHub Security Advisory.
| Package | Affected versions | Patched versions |
|---|---|---|
basic-ftpnpm | >= 5.2.0, < 5.2.1 | 5.2.1 |
Affected products
29- osv-coords28 versionspkg:apk/chainguard/kibana-8.17pkg:apk/chainguard/kibana-8.17-bitnamipkg:apk/chainguard/kibana-8.17-iamguardedpkg:apk/chainguard/kibana-8.19pkg:apk/chainguard/kibana-8.19-bitnamipkg:apk/chainguard/kibana-8.19-iamguardedpkg:apk/chainguard/kibana-9.0pkg:apk/chainguard/kibana-9.0-bitnamipkg:apk/chainguard/kibana-9.0-iamguardedpkg:apk/chainguard/kibana-9.1pkg:apk/chainguard/kibana-9.1-iamguardedpkg:apk/chainguard/kibana-9.2pkg:apk/chainguard/kibana-9.2-iamguardedpkg:apk/chainguard/kibana-9.3pkg:apk/chainguard/kibana-9.3-iamguardedpkg:apk/chainguard/langfuse-2-workerpkg:apk/chainguard/langfuse-3-workerpkg:apk/chainguard/langfuse-fips-2-workerpkg:apk/chainguard/langfuse-fips-3-workerpkg:apk/chainguard/opensearch-dashboards-2-fips-security-dashboards-pluginpkg:apk/chainguard/opensearch-dashboards-2-security-dashboards-pluginpkg:apk/chainguard/opensearch-dashboards-3-fips-security-dashboards-pluginpkg:apk/chainguard/opensearch-dashboards-3-security-dashboards-pluginpkg:apk/chainguard/wazuh-dashboard-security-pluginpkg:apk/wolfi/langfuse-3-workerpkg:apk/wolfi/opensearch-dashboards-2-security-dashboards-pluginpkg:apk/wolfi/opensearch-dashboards-3-security-dashboards-pluginpkg:npm/basic-ftp
< 8.17.10-r17+ 27 more
- (no CPE)range: < 8.17.10-r17
- (no CPE)range: < 8.17.10-r17
- (no CPE)range: < 8.17.10-r17
- (no CPE)range: < 8.19.14-r2
- (no CPE)range: < 8.19.14-r2
- (no CPE)range: < 8.19.14-r2
- (no CPE)range: < 9.0.8-r19
- (no CPE)range: < 9.0.8-r19
- (no CPE)range: < 9.0.8-r19
- (no CPE)range: < 9.1.10-r12
- (no CPE)range: < 9.1.10-r12
- (no CPE)range: < 9.2.7-r5
- (no CPE)range: < 9.2.7-r5
- (no CPE)range: < 9.3.3-r4
- (no CPE)range: < 9.3.3-r4
- (no CPE)range: < 2.95.12-r19
- (no CPE)range: < 3.164.0-r5
- (no CPE)range: < 2.95.12-r22
- (no CPE)range: < 3.164.0-r3
- (no CPE)range: < 2.19.5-r7
- (no CPE)range: < 2.19.5-r8
- (no CPE)range: < 3.5.0-r10
- (no CPE)range: < 3.5.0-r15
- (no CPE)range: < 4.14.4-r2
- (no CPE)range: < 3.164.0-r5
- (no CPE)range: < 2.19.5-r8
- (no CPE)range: < 3.5.0-r15
- (no CPE)range: >= 5.2.0, < 5.2.1
Patches
Vulnerability mechanics
References
5- github.com/patrickjuchli/basic-ftp/commit/2ecc8e2c500c5234115f06fd1dbde1aa03d70f4bnvdPatchWEB
- github.com/patrickjuchli/basic-ftp/security/advisories/GHSA-chqc-8p9q-pq6qnvdExploitMitigationVendor AdvisoryWEB
- github.com/advisories/GHSA-chqc-8p9q-pq6qghsaADVISORY
- nvd.nist.gov/vuln/detail/CVE-2026-39983ghsaADVISORY
- github.com/patrickjuchli/basic-ftp/releases/tag/v5.2.1nvdProductRelease NotesWEB
News mentions
0No linked articles in our index yet.