CVE-2026-48859

MEDIUM

SSH server timing side-channel in ssh_auth:check_password/3 allows unauthenticated username enumeration

Title source: cna
STIX 2.1

Description

Observable Timing Discrepancy vulnerability in Erlang/OTP ssh (ssh_auth, ssh_options modules) allows unauthenticated remote username enumeration via timing side-channel in password authentication. When the SSH daemon is configured with the user_passwords or password option, ssh_auth:check_password/3 performs a PBKDF2-SHA256 computation with 600,000 iterations (~300ms) for valid usernames, but returns immediately (~0ms) for invalid usernames via the ssh_options:get_password_option/2 path. This timing difference is detectable in a single authentication attempt and allows an unauthenticated attacker to distinguish valid from invalid usernames. The user_passwords and password options are documented as intended for test purposes; the recommended alternative is pwdfun, which is not affected by this vulnerability. This vulnerability is associated with program files lib/ssh/src/ssh_auth.erl and lib/ssh/src/ssh_options.erl. This issue affects OTP from OTP 29.0 before 29.0.2 corresponding to ssh from 6.0 before 6.0.1.

Scores

CVSS v3 5.3
EPSS 0.0047
EPSS Percentile 36.5%
Attack Vector NETWORK
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:N/A:N

CISA SSVC

Vulnrichment
Exploitation none
Automatable yes
Technical Impact partial

Details

CWE
CWE-208
Status published
Products (5)
erlang/erlang\/otp 29.0 - 29.0.2
erlang/erlang\/ssh 6.0 - 6.0.1
Erlang/OTP 032d1bc9491a3975c68faf9bc7776115d6ae3005 - c342092ef4b369bb409d5b71ac8fd83bab74aedf
Erlang/OTP 29.0 - 29.0.2
Erlang/OTP 6.0 - 6.0.1
Published Jun 10, 2026
Tracked Since Jun 10, 2026