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