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

exploitDog

github логотип

GHSA-cgjx-mwpx-47jv

Опубликовано: 23 окт. 2018
Источник: github
Github: Прошло ревью

Описание

Private Data Disclosure in express-restify-mongoose

Affected versions of express-restify-mongoose are susceptible to an information leakage vulnerability which may allow an attacker to access fields on a model even if those fields are marked as private.

Proof of Concept

If you have a user model that you want to protect, such as the following User model:

const User = mongoose.model('User', new mongoose.Schema({ name: String, password: String, }));

You would normally do something such as:

restify.serve(router, User, { private: ['password'], // Set the password part of User as private, so outside people can't read it })

This would hide the password field from people that send your application a GET /User and GET /User/some-user-id request.

A malicious user can go to your application and send a request for GET /User?distinct=password and get all the passwords for all the users in the database, despite the field being set to private. This could be used for other private data, if the malicious user knew what was set as private for specific routes.

Recommendation

Version 2.x: Update to version 2.5.0 or later. Version 3.x: Update to version 3.1.0 or later.

Пакеты

Наименование

express-restify-mongoose

npm
Затронутые версииВерсия исправления

>= 3.0.0, <= 3.0.1

3.1.0

Наименование

express-restify-mongoose

npm
Затронутые версииВерсия исправления

<= 2.4.2

2.5.0

EPSS

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

Дефекты

CWE-200

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

CVSS3: 8.8
nvd
больше 7 лет назад

express-restify-mongoose is a module to easily create a flexible REST interface for mongoose models. express-restify-mongoose 2.4.2 and earlier and 3.0.X through 3.0.1 allows a malicious user to send a request for `GET /User?distinct=password` and get all the passwords for all the users in the database, despite the field being set to private. This can be used for other private data if the malicious user knew what was set as private for specific routes.

EPSS

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

Дефекты

CWE-200