Skip to content

Commit

Permalink
Use async verify for Yubikey (dani-garcia#4448)
Browse files Browse the repository at this point in the history
  • Loading branch information
dani-garcia authored Mar 23, 2024
1 parent 93636eb commit 2d98aa3
Showing 1 changed file with 5 additions and 12 deletions.
17 changes: 5 additions & 12 deletions src/api/core/two_factor/yubikey.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
use rocket::serde::json::Json;
use rocket::Route;
use serde_json::Value;
use yubico::{config::Config, verify};
use yubico::{config::Config, verify_async};

use crate::{
api::{
Expand Down Expand Up @@ -74,13 +74,10 @@ async fn verify_yubikey_otp(otp: String) -> EmptyResult {
let config = Config::default().set_client_id(yubico_id).set_key(yubico_secret);

match CONFIG.yubico_server() {
Some(server) => {
tokio::task::spawn_blocking(move || verify(otp, config.set_api_hosts(vec![server]))).await.unwrap()
}
None => tokio::task::spawn_blocking(move || verify(otp, config)).await.unwrap(),
Some(server) => verify_async(otp, config.set_api_hosts(vec![server])).await,
None => verify_async(otp, config).await,
}
.map_res("Failed to verify OTP")
.and(Ok(()))
}

#[post("/two-factor/get-yubikey", data = "<data>")]
Expand Down Expand Up @@ -194,10 +191,6 @@ pub async fn validate_yubikey_login(response: &str, twofactor_data: &str) -> Emp
err!("Given Yubikey is not registered");
}

let result = verify_yubikey_otp(response.to_owned()).await;

match result {
Ok(_answer) => Ok(()),
Err(_e) => err!("Failed to verify Yubikey against OTP server"),
}
verify_yubikey_otp(response.to_owned()).await.map_res("Failed to verify Yubikey against OTP server")?;
Ok(())
}

0 comments on commit 2d98aa3

Please sign in to comment.