From 4bdf4c40c292b681452c9499b9072b759073bf32 Mon Sep 17 00:00:00 2001 From: Conrad Ludgate Date: Wed, 8 Dec 2021 13:37:49 +0000 Subject: feat: login/register no longer blocking (#216) --- atuin-client/src/api_client.rs | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) (limited to 'atuin-client/src/api_client.rs') diff --git a/atuin-client/src/api_client.rs b/atuin-client/src/api_client.rs index 24922836..3a4c859b 100644 --- a/atuin-client/src/api_client.rs +++ b/atuin-client/src/api_client.rs @@ -26,7 +26,7 @@ pub struct Client<'a> { client: reqwest::Client, } -pub fn register( +pub async fn register( address: &str, username: &str, email: &str, @@ -45,36 +45,38 @@ pub fn register( } let url = format!("{}/register", address); - let client = reqwest::blocking::Client::new(); + let client = reqwest::Client::new(); let resp = client .post(url) .header(USER_AGENT, APP_USER_AGENT) .json(&map) - .send()?; + .send() + .await?; if !resp.status().is_success() { return Err(eyre!("failed to register user")); } - let session = resp.json::()?; + let session = resp.json::().await?; Ok(session) } -pub fn login(address: &str, req: LoginRequest) -> Result> { +pub async fn login(address: &str, req: LoginRequest<'_>) -> Result> { let url = format!("{}/login", address); - let client = reqwest::blocking::Client::new(); + let client = reqwest::Client::new(); let resp = client .post(url) .header(USER_AGENT, APP_USER_AGENT) .json(&req) - .send()?; + .send() + .await?; if resp.status() != reqwest::StatusCode::OK { return Err(eyre!("invalid login details")); } - let session = resp.json::()?; + let session = resp.json::().await?; Ok(session) } -- cgit v1.3.1