Launch Week Day 1: Announcing Security Design Review
MEDIUM 5.3 RubyGems

Rack vulnerable to ReDoS in content type parsing (2nd degree polynomial)

GHSA-22f2-v57c-j9cx · CVE-2024-25126

Published · Modified

Description

Summary

module Rack
  class MediaType
    SPLIT_PATTERN = %r{\s*[;,]\s*}

The above regexp is subject to ReDos. 50K blank characters as a prefix to the header will take over 10s to split.

PoC

A simple HTTP request with lots of blank characters in the content-type header:

request["Content-Type"] = (" " * 50_000) + "a,"

Impact

It's a very easy to craft ReDoS. Like all ReDoS the impact is debatable.

Ready to move

Start Securing

Free, no credit card | First findings in minutes