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

exploitDog

github логотип

GHSA-26xx-m4q2-xhq8

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

Описание

Spree Auth Devise vulnerability allows for authentication bypass through CSRF weakness

Impact

CSRF vulnerability that allows user account takeover.

All applications using any version of the frontend component of spree_auth_devise are affected if protect_from_forgery method is both:

  • Executed whether as:
    • A before_action callback (the default)
    • A prepend_before_action (option prepend: true given) before the :load_object hook in Spree::UserController (most likely order to find).
  • Configured to use :null_session or :reset_session strategies (:null_session is the default in case the no strategy is given, but rails --new generated skeleton use :exception).

That means that applications that haven't been configured differently from what it's generated with Rails aren't affected.

Thanks @waiting-for-dev for reporting and providing a patch 👏

Patches

Spree 4.3 users should update to spree_auth_devise 4.4.1 Spree 4.2 users should update to spree_auth_devise 4.2.1 Spree 4.1 users should update to spree_auth_devise 4.1.1 Older Spree version users should update to spree_auth_devise 4.0.1

Workarounds

If possible, change your strategy to :exception:

class ApplicationController < ActionController::Base protect_from_forgery with: :exception end

Add the following toconfig/application.rb to at least run the :exception strategy on the affected controller:

config.after_initialize do Spree::UsersController.protect_from_forgery with: :exception end

References

https://github.com/solidusio/solidus_auth_devise/security/advisories/GHSA-xm34-v85h-9pg2

Пакеты

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

spree_auth_devise

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

>= 4.3.0, < 4.4.1

4.4.1

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

spree_auth_devise

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

>= 4.2.0, < 4.2.1

4.2.1

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

spree_auth_devise

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

>= 4.1.0, < 4.1.1

4.1.1

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

spree_auth_devise

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

< 4.0.1

4.0.1

EPSS

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

9.3 Critical

CVSS3

Дефекты

CWE-352

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

CVSS3: 9.3
nvd
больше 3 лет назад

spree_auth_devise is an open source library which provides authentication and authorization services for use with the Spree storefront framework by using an underlying Devise authentication framework. In affected versions spree_auth_devise is subject to a CSRF vulnerability that allows user account takeover. All applications using any version of the frontend component of spree_auth_devise are affected if protect_from_forgery method is both: Executed whether as: A before_action callback (the default). A prepend_before_action (option prepend: true given) before the :load_object hook in Spree::UserController (most likely order to find). Configured to use :null_session or :reset_session strategies (:null_session is the default in case the no strategy is given, but rails --new generated skeleton use :exception). Users are advised to update their spree_auth_devise gem. For users unable to update it may be possible to change your strategy to :exception. Please see the linked GHSA for more wor

EPSS

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

9.3 Critical

CVSS3

Дефекты

CWE-352