vw_small

Hardened fork of Vaultwarden (https://github.com/dani-garcia/vaultwarden) with fewer features.
git clone https://git.philomathiclife.com/repos/vw_small
Log | Files | Refs | README

commit 93805a5d7bb32c1f3c2168cfa73b60593dfeb53e
parent 71da961ecdb4ea8581227e387f986df554c57410
Author: Daniel GarcĂ­a <dani-garcia@users.noreply.github.com>
Date:   Sat, 16 Feb 2019 21:30:55 +0100

Fix Yubikeys deleted on error

Diffstat:
Msrc/api/core/two_factor.rs | 17++++++-----------
1 file changed, 6 insertions(+), 11 deletions(-)

diff --git a/src/api/core/two_factor.rs b/src/api/core/two_factor.rs @@ -573,11 +573,10 @@ fn activate_yubikey(data: JsonUpcase<EnableYubikeyData>, headers: Headers, conn: } // Check if we already have some data - let yubikey_data = TwoFactor::find_by_user_and_type(&user.uuid, TwoFactorType::YubiKey as i32, &conn); - - if let Some(yubikey_data) = yubikey_data { - yubikey_data.delete(&conn)?; - } + let mut yubikey_data = match TwoFactor::find_by_user_and_type(&user.uuid, TwoFactorType::YubiKey as i32, &conn) { + Some(data) => data, + None => TwoFactor::new(user.uuid.clone(), TwoFactorType::YubiKey, String::new()), + }; let yubikeys = parse_yubikeys(&data); @@ -605,12 +604,8 @@ fn activate_yubikey(data: JsonUpcase<EnableYubikeyData>, headers: Headers, conn: Nfc: data.Nfc, }; - let yubikey_registration = TwoFactor::new( - user.uuid.clone(), - TwoFactorType::YubiKey, - serde_json::to_string(&yubikey_metadata).unwrap(), - ); - yubikey_registration.save(&conn)?; + yubikey_data.data = serde_json::to_string(&yubikey_metadata).unwrap(); + yubikey_data.save(&conn)?; _generate_recover_code(&mut user, &conn);