The Ultimate Server— caddyserver.com
Caddy 2 is a powerful, enterprise-ready, open source web server with automatic HTTPS written in Go
Caddy advertises itself as a simple and reliable web server that's Secure by Default.
About the Vulnerability
The bug bounty hunter Mayank Mukhi (@Hunt2behunter) reported an Open Redirect vulnerability on our website to us. After further analysis for the reason of this vulnerability, it was stated that the Caddy web server in version v2.4.6 is affected by this kind of vulnerability.
Steps to reproduce
- Download Caddy v2.4.6 from the GitHub Releases page
- Ensure that the file-server's root directory at least contains an index.html file
- Start caddy file-server
- Navigate to the web server with the following path and get a redirect (HTTP Status Code 308):
All versions v2.x up to v2.5.0-rc.1 were tested and it was confirmed that only version v2.4.6 is affected by the listed attack vector.
The bug / security issue was fixed in commit 78b5356f2b1945a90de1ef7f2c7669d82098edbd and will be available in the next stable release.
Server administrators should upgrade caddy to the latest version v2.5.0.
Responsible Disclosure Timeline
Mayank Mukhi (@Hunt2behunter) reported an Open Redirect Vulnerability on our site;
Vulnerability was confirmed by us;
Research started and verified vulnerability in Caddy;
Requested CVE-ID from MITRE
A tool for automated testing all v2.x caddy versions was developed and used;
Confirmed only vulnerable version v2.4.6;
Sent a vulnerability report to Matt Holt, Creator, Maintainer and Security Contact for Caddy
Matt Holt confirmed that the vulnerability was discovered, reported and fixed months ago;
Although no new stable version was released yet
|2022-04-21||Performed additional automated tests to determine commit that fixed the issue|
|2022-04-22||Publication of this vulnerability writeup|
|2022-04-27||Updated Section Fix with latest caddy release v2.5.0 from 2022-04-25.|
The vulnerability was discovered and reported by:
Sascha Brendel | CEO, IT-Security Consultant & Penetrationtester