Description
Micronaut Framework is a JVM-based full stack Java framework designed for building modular, easily testable JVM applications. From 4.3.0 to before 4.10.22, TimeConverterRegistrar caches DateTimeFormatter instances in an unbounded ConcurrentHashMap<String, DateTimeFormatter> whose key is derived from the @Format annotation pattern concatenated with the locale from the HTTP Accept-Language header. Because Locale.forLanguageTag() accepts arbitrary BCP 47 private-use extensions (en-x-a001, en-x-a002, …), an unauthenticated attacker can generate an unlimited number of unique cache keys by sending requests with novel locale tags, growing the cache until heap memory is exhausted and the JVM crashes. This vulnerability is fixed in 4.10.22.
Problem types
CWE-400: Uncontrolled Resource Consumption
Product status
References
github.com/...t-core/security/advisories/GHSA-8hjv-92q9-g4xj
github.com/...t-core/security/advisories/GHSA-8hjv-92q9-g4xj
github.com/...-projects/micronaut-core/releases/tag/v4.10.22