From dc3917b05018cb32e2451d9eaed242036c5e7512 Mon Sep 17 00:00:00 2001 From: bigfoot547 Date: Tue, 28 Jan 2025 21:23:07 -0600 Subject: wip: auth --- src/auth.rs | 54 +++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 53 insertions(+), 1 deletion(-) (limited to 'src/auth.rs') diff --git a/src/auth.rs b/src/auth.rs index a11c0de..f4522ed 100644 --- a/src/auth.rs +++ b/src/auth.rs @@ -1,3 +1,55 @@ -struct AuthenticationDatabase { +mod types; +pub mod device_code; +use std::error::Error; +use std::fmt::{Display, Formatter}; +use chrono::{DateTime, Utc}; +pub use types::*; + +#[derive(Debug)] +pub enum AuthError { + Request { what: &'static str, error: reqwest::Error }, +} + +impl Display for AuthError { + fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result { + match self { + AuthError::Request { what, error } => write!(f, "auth request error ({}): {}", what, error) + } + } +} + +impl Error for AuthError { + fn source(&self) -> Option<&(dyn Error + 'static)> { + match self { + AuthError::Request { error, .. } => Some(error) + } + } +} + +impl Token { + fn is_expired(&self, now: DateTime) -> bool { + self.expire.is_some_and(|exp| now < exp) + } +} + +impl MsaUser { + async fn log_in(&mut self) -> Result<(), AuthError> { + todo!() + } +} + +#[cfg(test)] +mod test { + use reqwest::Client; + use super::*; + + #[tokio::test] + async fn abc() { + device_code::DeviceCodeAuthBuilder::new() + .client_id("00000000402b5328") + .scope("service::user.auth.xboxlive.com::MBI_SSL") + .url("https://login.live.com/oauth20_connect.srf") + .begin(Client::new()).await.unwrap(); + } } -- cgit v1.2.3-70-g09d2