PT-2023-22093 · Unknown · @Fastify/Passport+1

Pedromigueladao

·

Published

2023-04-21

·

Updated

2023-05-03

·

CVE-2023-29020

CVSS v3.1

6.5

Medium

VectorAV:N/AC:L/PR:N/UI:R/S:U/C:N/I:H/A:N
Name of the Vulnerable Software and Affected Versions @fastify/passport versions prior to the version that includes the configuration options clearSessionOnLogin and clearSessionIgnoreFields
Description The CSRF protection enforced by the @fastify/csrf-protection library, when combined with @fastify/passport, can be bypassed by network and same-site attackers. The @fastify/csrf-protection library implements the synchronizer token pattern by storing a random value used for CSRF token generation in the csrf attribute of a user's session. The @fastify/passport library does not clear the session object upon authentication, preserving the csrf attribute between pre-login and authenticated sessions. Consequently, CSRF tokens generated before authentication are still valid. Network and same-site attackers can thus obtain a CSRF token for their pre-session, fixate that pre-session in the victim's browser via cookie tossing, and then perform a CSRF attack after the victim authenticates.
Recommendations As a solution, update @fastify/passport to a version that includes the configuration options clearSessionOnLogin and clearSessionIgnoreFields, and set clearSessionOnLogin to true to clear all the session attributes by default, preserving those explicitly defined in clearSessionIgnoreFields. Consider temporarily disabling the @fastify/csrf-protection library until a patch is available, or restrict access to the vulnerable module to minimize the risk of exploitation.

Exploit

Fix

CSRF

Session Fixation

Weakness Enumeration

Related Identifiers

CVE-2023-29020
GHSA-2CCF-FFRJ-M4QW

Affected Products

@Fastify/Csrf-Protection
@Fastify/Passport