CVE-2016-0787

NameCVE-2016-0787
DescriptionThe diffie_hellman_sha256 function in kex.c in libssh2 before 1.7.0 improperly truncates secrets to 128 or 256 bits, which makes it easier for man-in-the-middle attackers to decrypt or intercept SSH sessions via unspecified vectors, aka a "bits/bytes confusion bug."
SourceCVE (at NVD; CERT, LWN, oss-sec, fulldisc, Red Hat, Ubuntu, Gentoo, SUSE bugzilla/CVE, GitHub advisories/code/issues, web search, more)
ReferencesDLA-426-1, DSA-3487-1
Debian Bugs815662

Vulnerable and fixed packages

The table below lists information on source packages.

Source PackageReleaseVersionStatus
libssh2 (PTS)jessie, jessie (lts)1.4.3-4.1+deb8u7fixed
stretch (security)1.7.0-1+deb9u2fixed
stretch (lts), stretch1.7.0-1+deb9u3fixed
buster (security), buster, buster (lts)1.8.0-2.1+deb10u1fixed
bullseye1.9.0-2+deb11u1fixed
bookworm1.10.0-3fixed
sid, trixie1.11.1-1fixed

The information below is based on the following data on fixed versions.

PackageTypeReleaseFixed VersionUrgencyOriginDebian Bugs
libssh2sourcesqueeze1.2.6-1+deb6u2DLA-426-1
libssh2sourcewheezy1.4.2-1.1+deb7u2DSA-3487-1
libssh2sourcejessie1.4.3-4.1+deb8u1DSA-3487-1
libssh2source(unstable)1.5.0-2.1815662

Notes

Upstream fix: https://github.com/libssh2/libssh2/commit/ca5222ea819cc5ed797860070b4c6c1aeeb28420
Upstream patch only fixes DH SHA-256 key exchange type, not DH SHA-1

Search for package or bug name: Reporting problems