CVE-2026-39807

MEDIUM

Client-supplied URI scheme trusted without transport verification in bandit

Title source: cna
STIX 2.1

Description

Reliance on Untrusted Inputs in a Security Decision vulnerability in mtrudel bandit allows unauthenticated transport-state spoofing on plaintext HTTP connections. 'Elixir.Bandit.Pipeline':determine_scheme/2 in lib/bandit/pipeline.ex returns the client-supplied URI scheme verbatim, ignoring the transport's secure? flag. HTTP/1.1 absolute-form request targets (e.g. GET https://victim/path HTTP/1.1) and the HTTP/2 :scheme pseudo-header are both attacker-controlled strings that flow through this function. Over a plaintext TCP connection, a client can declare https and Bandit will set conn.scheme = :https even though no TLS was negotiated. Downstream Plug consumers that branch on conn.scheme are silently misled: Plug.SSL's already-secure branch skips its HTTP→HTTPS redirect, cookies emitted with secure: true are sent over plaintext, audit logs record requests as having arrived over HTTPS, and CSRF/SameSite gating may make incorrect decisions. This issue affects bandit: from 1.0.0 before 1.11.0.

Scores

CVSS v4 6.3
EPSS 0.0045
EPSS Percentile 35.8%
CVSS:4.0/AV:N/AC:L/AT:P/PR:N/UI:N/VC:L/VI:L/VA:N/SC:N/SI:N/SA:N/E:X/CR:X/IR:X/AR:X/MAV:X/MAC:X/MAT:X/MPR:X/MUI:X/MVC:X/MVI:X/MVA:X/MSC:X/MSI:X/MSA:X/S:X/AU:X/R:X/V:X/RE:X/U:X

CISA SSVC

Vulnrichment
Exploitation poc
Automatable yes
Technical Impact partial

Details

CWE
CWE-807
Status published
Products (4)
Hex/bandit 1.0.0 - 1.11.0Hex
mtrudel/bandit 1.0.0 - 1.11.0
mtrudel/bandit ff2f829326cd5dcf7335939aef9775269d881e28 - 1.11.0
mtrudel/bandit ff2f829326cd5dcf7335939aef9775269d881e28 - 45feea20dea8af7ffd7245271107b695c040e667
Published May 01, 2026
Tracked Since May 02, 2026