Логотип exploitDog
Консоль
Логотип exploitDog

exploitDog

debian логотип

CVE-2026-30852

Опубликовано: 07 мар. 2026
Источник: debian
EPSS Низкий

Описание

Caddy is an extensible server platform that uses TLS by default. From version 2.7.5 to before version 2.11.2, the vars_regexp matcher in vars.go:337 double-expands user-controlled input through the Caddy replacer. When vars_regexp matches against a placeholder like {http.request.header.X-Input}, the header value gets resolved once (expected), then passed through repl.ReplaceAll() again (the bug). This means an attacker can put {env.DATABASE_URL} or {file./etc/passwd} in a request header and the server will evaluate it, leaking environment variables, file contents, and system info. This issue has been patched in version 2.11.2.

Пакеты

ПакетСтатусВерсия исправленияРелизТип
caddynot-affectedpackage

Примечания

  • https://github.com/caddyserver/caddy/security/advisories/GHSA-m2w3-8f23-hxxf

  • Introduced with: https://github.com/caddyserver/caddy/commit/85375861f6a903da9af8aa665552a6546d075c9f (v2.7.0-beta.1)

EPSS

Процентиль: 12%
0.00039
Низкий

Связанные уязвимости

CVSS3: 7.5
ubuntu
22 дня назад

Caddy is an extensible server platform that uses TLS by default. From version 2.7.5 to before version 2.11.2, the vars_regexp matcher in vars.go:337 double-expands user-controlled input through the Caddy replacer. When vars_regexp matches against a placeholder like {http.request.header.X-Input}, the header value gets resolved once (expected), then passed through repl.ReplaceAll() again (the bug). This means an attacker can put {env.DATABASE_URL} or {file./etc/passwd} in a request header and the server will evaluate it, leaking environment variables, file contents, and system info. This issue has been patched in version 2.11.2.

CVSS3: 7.5
nvd
22 дня назад

Caddy is an extensible server platform that uses TLS by default. From version 2.7.5 to before version 2.11.2, the vars_regexp matcher in vars.go:337 double-expands user-controlled input through the Caddy replacer. When vars_regexp matches against a placeholder like {http.request.header.X-Input}, the header value gets resolved once (expected), then passed through repl.ReplaceAll() again (the bug). This means an attacker can put {env.DATABASE_URL} or {file./etc/passwd} in a request header and the server will evaluate it, leaking environment variables, file contents, and system info. This issue has been patched in version 2.11.2.

github
23 дня назад

Caddy's vars_regexp double-expands user input, leaking env vars and files

EPSS

Процентиль: 12%
0.00039
Низкий