CVE-2024-34075
kurwov vulnerable to Denial of Service due to improper data sanitization
描述
### Summary An unsafe sanitization of dataset contents on the `MarkovData#getNext` method used in `Markov#generate` and `Markov#choose` allows a maliciously crafted string on the dataset to throw and stop the function from running properly. ### Details https://github.com/xiboon/kurwov/blob/0d58dfa42135ab40e830e92622857282f980ca89/src/MarkovData.ts#L38-L44 If a string contains a forbidden substring (i.e. `__proto__`) followed by a space character, the second line will access a special property in `MarkovData#finalData` by removing the last character of the string, bypassing the dataset sanitization (as it is supposed to be already sanitized before this function is called). `data` is then defined as the special function found in its prototype instead of an array. On the last line, `data` is then indexed by a random number, which is supposed to return a string but returns undefined as it's a function. Calling `endsWith` then throws. ### PoC https://runkit.com/embed/m6uu40r5ja9b ### Impact Any dataset can be contaminated with the substring making it unable to properly generate anything in some cases.
如何修補 CVE-2024-34075
要修補 CVE-2024-34075,請將受影響套件升級到下列已修補版本。
- —升級至 3.2.5 或更新版本
CVE-2024-34075 正在被利用嗎?
低 — EPSS 為 0.0%,目前沒有觀察到大規模利用活動。
受影響套件(1)
- >= 3.1.0, < 3.2.5
CVSS 分數
| 來源 | 版本 | 嚴重程度 | 向量 |
|---|