7.4

CVE-2023-48220

Decidim's devise_invitable gem vulnerable to circumvention of invitation token expiry period

Decidim is a participatory democracy framework. Starting in version 0.4.rc3 and prior to version 2.0.9 of the `devise_invitable` gem, the invites feature allows users to accept the invitation for an unlimited amount of time through the password reset functionality. This issue creates vulnerable dependencies starting in version 0.0.1.alpha3 and prior to versions 0.26.9, 0.27.5, and 0.28.0 of the `decidim,` `decidim-admin`, and `decidim-system` gems. When using the password reset functionality, the `devise_invitable` gem always accepts the pending invitation if the user has been invited. The only check done is if the user has been invited but the code does not ensure that the pending invitation is still valid as defined by the `invite_for` expiry period. Decidim sets this configuration to `2.weeks` so this configuration should be respected. The bug is in the `devise_invitable` gem and should be fixed there and the dependency should be upgraded in Decidim once the fix becomes available. `devise_invitable` to version `2.0.9` and above fix this issue. Versions 0.26.9, 0.27.5, and 0.28.0 of the `decidim,` `decidim-admin`, and `decidim-system` gems contain this fix. As a workaround, invitations can be cancelled directly from the database.
Daten sind bereitgestellt durch National Vulnerability Database (NVD)
DecidimDecidim SwPlatformruby Version >= 0.0.2 < 0.26.9
DecidimDecidim SwPlatformruby Version >= 0.27.0 < 0.27.5
DecidimDecidim Version0.0.1 Update- SwPlatformruby
DecidimDecidim Version0.0.1 Updatealpha3 SwPlatformruby
DecidimDecidim Version0.0.1 Updatealpha4 SwPlatformruby
DecidimDecidim Version0.0.1 Updatealpha5 SwPlatformruby
DecidimDecidim Version0.0.1 Updatealpha6 SwPlatformruby
DecidimDecidim Version0.0.1 Updatealpha7 SwPlatformruby
DecidimDecidim Version0.0.1 Updatealpha8 SwPlatformruby
DecidimDecidim Version0.0.1 Updatealpha9 SwPlatformruby
ScambraDevise Invitable SwPlatformruby Version >= 0.4.1 < 2.0.9
ScambraDevise Invitable Version0.4.0 Update- SwPlatformruby
ScambraDevise Invitable Version0.4.0 Updaterc3 SwPlatformruby
ScambraDevise Invitable Version0.4.0 Updaterc4 SwPlatformruby
ScambraDevise Invitable Version0.4.0 Updaterc5 SwPlatformruby
Zu dieser CVE wurde keine Warnung gefunden.
EPSS Metriken
Typ Quelle Score Percentile
EPSS FIRST.org 0.79% 0.515
CVSS Metriken
Quelle Base Score Exploit Score Impact Score Vector String
nvd@nist.gov 7.4 2.2 5.2
CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:N
security-advisories@github.com 5.7 0.5 5.2
CVSS:3.1/AV:N/AC:H/PR:H/UI:R/S:U/C:H/I:H/A:N
CWE-672 Operation on a Resource after Expiration or Release

The product uses, accesses, or otherwise operates on a resource after that resource has been expired, released, or revoked.

https://github.com/decidim/decidim/releases/tag/v0.27.5
Release Notes
https://github.com/decidim/decidim/releases/tag/v0.28.0
Release Notes
https://github.com/decidim/decidim/blob/d2d390578050772d1bdb6d731395f1afc39dcbfc/decidim-core/config/initializers/devise.rb#L134
Product
https://github.com/decidim/decidim/commit/073e60e2e4224dd81815a784002ebba30f2ebb34
Patch
https://github.com/decidim/decidim/commit/b12800717a689c295a9ea680a38ca9f823d2c454
Patch
https://github.com/decidim/decidim/releases/tag/v0.26.9
Release Notes
https://github.com/decidim/decidim/security/advisories/GHSA-w3q8-m492-4pwp
Patch
Vendor Advisory
Mitigation
https://github.com/scambra/devise_invitable/blob/41f58970ff76fb64382a9b9ea1bd530f7c3adab2/lib/devise_invitable/models.rb#L198
Product
https://github.com/scambra/devise_invitable/commit/94d859c7de0829bf63f679ae5dd3cab2b866a098
Patch