CVE-2026-48598
LOWCRLF injection in Tesla.Multipart disposition parameters allows multipart part header injection
Title source: cnaExploitation Summary
EIP tracks 1 public exploit for CVE-2026-48598. PoCs published by workshops-de.
AI-analyzed exploit summary This repository provides a patched fork of the `google_gax` library to address compatibility issues with Tesla >= 1.18.3, which introduced strict validation for multipart field names as part of CVE-2026-48598. The changes involve converting atom field names to strings and adjusting header formats to comply with Tesla's security fixes.
Description
Improper Encoding or Escaping of Output vulnerability in elixir-tesla tesla allows multipart part header injection via unescaped Content-Disposition parameter values. Tesla.Multipart.part_headers_for_disposition/1 interpolates each disposition parameter as #{k}="#{v}" with no validation of CR (\r), LF (\n), or double-quote characters. The values come verbatim from the caller via Tesla.Multipart.add_field/4 (the name parameter), Tesla.Multipart.add_file/3, and Tesla.Multipart.add_file_content/4 (both the filename parameter and other disposition opts). A " in the value closes the quoted parameter early; a \r\n ends the Content-Disposition header line and starts a new part header (such as a forged Content-Type), or, after a second \r\n, ends the entire part header block and prepends bytes to the part body. The default-filename path in add_file/3 derives the filename via Path.basename/1, which does not strip CR or LF, so any application forwarding a partially-attacker-controlled file path inherits the same issue. This issue affects tesla: from 0.8.0 before 1.18.3.
Exploits (1)
This repository provides a patched fork of the `google_gax` library to address compatibility issues with Tesla >= 1.18.3, which introduced strict validation for multipart field names as part of CVE-2026-48598. The changes involve converting atom field names to strings and adjusting header formats to comply with Tesla's security fixes.
References (4)
Scores
CVSS:4.0/AV:L/AC:L/AT:P/PR:N/UI:N/VC:N/VI:N/VA:N/SC:N/SI:L/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