Логотип exploitDog
Консоль
Логотип exploitDog

exploitDog

nvd логотип

CVE-2023-26158

Опубликовано: 08 дек. 2023
Источник: nvd
CVSS3: 8.2
EPSS Низкий

Описание

All versions of the package mockjs are vulnerable to Prototype Pollution via the Util.extend function due to missing check if the attribute resolves to the object prototype. By adding or modifying attributes of an object prototype, it is possible to create attributes that exist on every object, or replace critical attributes with malicious ones. This can be problematic if the software depends on existence or non-existence of certain attributes, or uses pre-defined attributes of object prototype (such as hasOwnProperty, toString or valueOf).

User controlled inputs inside the extend() method of the Mock.Handler, Mock.Random, Mock.RE.Handler or Mock.Util, will allow an attacker to exploit this vulnerability.

Workaround

By using a denylist of dangerous attributes, this weakness can be eliminated.

Add the following line in the Util.extend function:

js js if (["proto", "constructor", "prototype"].includes(name)) continue

js // src/mock/handler.js Util.extend = function extend() {

Уязвимые конфигурации

Конфигурация 1
cpe:2.3:a:mockjs:mock.js:*:*:*:*:*:node.js:*:*
Версия до 1.1.0 (включая)

EPSS

Процентиль: 25%
0.00086
Низкий

8.2 High

CVSS3

Дефекты

CWE-1321
CWE-1321

Связанные уязвимости

CVSS3: 8.2
github
около 2 лет назад

mockjs vulnerable to Prototype Pollution via the Util.extend function

EPSS

Процентиль: 25%
0.00086
Низкий

8.2 High

CVSS3

Дефекты

CWE-1321
CWE-1321