mirror of
https://github.com/dani-garcia/vaultwarden.git
synced 2026-04-09 19:16:15 -06:00
Fix: update OAuth2 state storage initialization and state token encoding
This commit is contained in:
parent
96fe363ee5
commit
7e3acf26b4
@ -106,7 +106,7 @@ static CAN_BACKUP: LazyLock<bool> =
|
||||
static CAN_BACKUP: LazyLock<bool> = LazyLock::new(|| false);
|
||||
|
||||
// OAuth2 state storage for CSRF protection (state -> expiration timestamp)
|
||||
static OAUTH2_STATES: LazyLock<RwLock<HashMap<String, u64>>> =
|
||||
static OAUTH2_STATES: LazyLock<RwLock<HashMap<String, u64>>> =
|
||||
LazyLock::new(|| RwLock::new(HashMap::new()));
|
||||
|
||||
#[get("/")]
|
||||
@ -370,7 +370,7 @@ fn oauth2_authorize(_token: AdminToken) -> Result<Redirect, Error> {
|
||||
let scopes = CONFIG.smtp_oauth2_scopes();
|
||||
|
||||
// Generate a random state token for CSRF protection
|
||||
let state = crate::crypto::encode_random_bytes::<32>(BASE64URL_NOPAD);
|
||||
let state = crate::crypto::encode_random_bytes::<32>(&BASE64URL_NOPAD);
|
||||
|
||||
// Store state with expiration (10 minutes from now)
|
||||
let expiration = SystemTime::now().duration_since(UNIX_EPOCH).unwrap().as_secs() + 600;
|
||||
|
||||
Loading…
Reference in New Issue
Block a user