CVE-2026-39983

HIGH

FTP Command Injection via CRLF in basic-ftp

Title source: cna

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.

Exploits (1)

nomisec WRITEUP
by zebbernCVE · poc
https://github.com/zebbernCVE/CVE-2026-39983

Scores

CVSS v3 8.6
EPSS 0.0184
EPSS Percentile 83.0%
Attack Vector NETWORK
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:H/A:L

Details

CWE
CWE-93
Status published
Products (2)
npm/basic-ftp 5.2.0 - 5.2.1npm
patrickjuchli/basic-ftp < 5.2.1 (2 CPE variants)
Published Apr 09, 2026
Tracked Since Apr 09, 2026