Description
Luxon is a library for working with dates and times in JavaScript. On the 1.x branch prior to 1.38.1, the 2.x branch prior to 2.5.2, and the 3.x branch on 3.2.1, Luxon's `DateTime.fromRFC2822() has quadratic (N^2) complexity on some specific inputs. This causes a noticeable slowdown for inputs with lengths above 10k characters. Users providing untrusted data to this method are therefore vulnerable to (Re)DoS attacks. This issue also appears in Moment as CVE-2022-31129. Versions 1.38.1, 2.5.2, and 3.2.1 contain patches for this issue. As a workaround, limit the length of the input.
Remediation
References
https://github.com/moment/moment/pull/6015#issuecomment-1152961973
https://github.com/moment/luxon/commit/5ab3bf64a10da929a437629cdb2f059bb83212bf
https://github.com/moment/moment/security/advisories/GHSA-wc69-rhjr-hc9g
https://github.com/moment/luxon/security/advisories/GHSA-3xq5-wjfh-ppjc
https://lists.fedoraproject.org/archives/list/package-announce@lists.fedoraproject.org/message/4LIVOASKBQH7FEUI5RWM3SOHR6VK7ZZR/
https://lists.fedoraproject.org/archives/list/package-announce@lists.fedoraproject.org/message/44I3WAJKYXDLOVYRGMHAUXMIV4SPFXDZ/
Related Vulnerabilities
CVE-2023-29008 Vulnerability in npm package @sveltejs/kit
CVE-2021-23444 Vulnerability in npm package jointjs
CVE-2023-48218 Vulnerability in npm package strapi-plugin-protected-populate
CVE-2022-2564 Vulnerability in maven package org.webjars.npm:mongoose
CVE-2019-17566 Vulnerability in maven package org.apache.xmlgraphics:batik-transcoder