From 93805a5d7bb32c1f3c2168cfa73b60593dfeb53e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daniel=20Garc=C3=ADa?= Date: Sat, 16 Feb 2019 21:30:55 +0100 Subject: [PATCH] Fix Yubikeys deleted on error --- src/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 index 7c35c7ae..e797c506 100644 --- a/src/api/core/two_factor.rs +++ b/src/api/core/two_factor.rs @@ -573,11 +573,10 @@ fn activate_yubikey(data: JsonUpcase, 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, 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);