VDB
KO
HIGH

GHSA-48r7-hpm6-gfxm

@angular/common: Denial of Service (DoS) via OOM in Date Formatting (formatDate)

Details

A Denial of Service (DoS) vulnerability exists in the `@angular/common` package of the Angular framework. The `formatDate` function, which is also utilized by the standard Angular `DatePipe`, does not properly limit or validate the length of the `format` parameter.

When parsing a maliciously crafted, excessively long date format string (e.g., a repeating pattern or very large string), the internal parser splits the string iteratively using a regular expression loop. This results in uncontrolled resource consumption (high CPU utilization and excessive memory allocations), leading to a Denial of Service (DoS).

### Impact

#### 1. Server-Side Rendering (SSR) In Angular applications that leverage Server-Side Rendering, an attacker can supply a malicious payload with an excessively long date format string. Processing this on the server causes high CPU usage and triggers a `JavaScript heap out of memory` crash, rendering the application unavailable to all users.

#### 2. Client-Side Rendering (CSR) In standard client-side applications, executing the vulnerable function with an excessively long format string blocks the browser's main thread, causing the browser tab to freeze and become completely unresponsive.

### Patched Versions * 22.0.1 * 21.2.17 * 20.3.25

### Attack Preconditions For this vulnerability to be exploitable, both of the following conditions must be met: 1. **Vulnerable Component Usage:** The application must format dates using the `formatDate` utility or the `DatePipe`. 2. **Attacker-Controlled Parameter:** The date format string passed to these utilities must be customizable or directly controlled by untrusted user input (e.g., parsed from query parameters, user preferences, or API responses).

*If the date format is hardcoded (e.g., `'mediumDate'`, `'shortTime'`, or static strings) or properly validated to be within a reasonable length limit, the application is not vulnerable.*

Are you affected?

Enter the version of the package you're using.

Affected packages

npm / @angular/common
Introduced in: 22.0.0-next.0 Fixed in: 22.0.1
Fix npm install @angular/common@22.0.1
npm / @angular/common
Introduced in: 21.0.0-next.0 Fixed in: 21.2.17
Fix npm install @angular/common@21.2.17
npm / @angular/common
Introduced in: 20.0.0-next.0 Fixed in: 20.3.25
Fix npm install @angular/common@20.3.25
npm / @angular/common
Introduced in: 0

No fixed version published yet for @angular/common (npm). Pin to a known-safe version or switch to an alternative.

References