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

exploitDog

github логотип

GHSA-pmf4-v838-29hg

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

Описание

Directus allows privilege escalation using Share feature

Summary

When sharing an item, user can specify an arbitrary role. It allows user to use a higher-privileged role to see fields that otherwise the user should not be able to see.

Details

Specifying role on share should be available only for admins. The current flow has a security flaw.

Each other role should allow to share only in the context of the same role. As there is no role hierarchy in Directus, it is impossible to tell which role is higher or lower, so only admins should be able to specify the role for share.

Optionally, instead of specifying a role, shareer* should be able to specify which fields (limited to fields shareer sees) are available on shared item. Similarily to import.

*shareer - a person that creates a share link to item

PoC

  1. Create a collection with a secret field.
  2. Create role A that sees the secret field
  3. Create role B that does not see the secret field, but can use share feature.
  4. Create item with secret field filled.
  5. Use account with role B to share the object as role A and gain unauthorized access to secret value.

Here's video example: https://www.youtube.com/watch?v=DbV4IxbWzN4 I had to upload it to YouTube, because GitHub allows only 10MB videos.

Impact

Impacted are instances that use the share feature and have specific roles hierarchy and fields that are not visible for certain roles.

Пакеты

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

directus

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

< 11.2.0

11.2.0

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

@directus/app

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

< 13.3.1

13.3.1

EPSS

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

5 Medium

CVSS3

Дефекты

CWE-269

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

CVSS3: 5
nvd
около 1 года назад

Directus is a real-time API and App dashboard for managing SQL database content. Prior to version 11.2.0, when sharing an item, a typical user can specify an arbitrary role. It allows the user to use a higher-privileged role to see fields that otherwise the user should not be able to see. Instances that are impacted are those that use the share feature and have specific roles hierarchy and fields that are not visible for certain roles. Version 11.2.0 contains a patch the issue.

CVSS3: 5
fstec
около 1 года назад

Уязвимость прикладного программного интерфейса управления содержимым базы данных SQL Directus, позволяющая нарушителю повысить свои привилегии

EPSS

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

5 Medium

CVSS3

Дефекты

CWE-269