summaryrefslogtreecommitdiffstats
path: root/src/auth.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/auth.rs')
-rw-r--r--src/auth.rs23
1 files changed, 16 insertions, 7 deletions
diff --git a/src/auth.rs b/src/auth.rs
index f4522ed..e7d8061 100644
--- a/src/auth.rs
+++ b/src/auth.rs
@@ -1,5 +1,5 @@
mod types;
-pub mod device_code;
+mod oauth;
use std::error::Error;
use std::fmt::{Display, Formatter};
@@ -9,12 +9,16 @@ pub use types::*;
#[derive(Debug)]
pub enum AuthError {
Request { what: &'static str, error: reqwest::Error },
+ Internal(String),
+ Timeout
}
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)
+ AuthError::Request { what, error } => write!(f, "auth request error ({}): {}", what, error),
+ AuthError::Internal(msg) => write!(f, "internal auth error: {}", msg),
+ AuthError::Timeout => f.write_str("interactive authentication timed out")
}
}
}
@@ -22,7 +26,8 @@ impl Display for AuthError {
impl Error for AuthError {
fn source(&self) -> Option<&(dyn Error + 'static)> {
match self {
- AuthError::Request { error, .. } => Some(error)
+ AuthError::Request { error, .. } => Some(error),
+ _ => None
}
}
}
@@ -42,14 +47,18 @@ impl MsaUser {
#[cfg(test)]
mod test {
use reqwest::Client;
+ use crate::auth::oauth::device_code;
use super::*;
#[tokio::test]
async fn abc() {
- device_code::DeviceCodeAuthBuilder::new()
+ simple_logger::SimpleLogger::new().with_colors(true).with_level(log::LevelFilter::Trace).init().unwrap();
+
+ _=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();
+ .add_scope("service::user.auth.xboxlive.com::MBI_SSL", true)
+ .code_request_url("https://login.live.com/oauth20_connect.srf")
+ .check_url("https://login.live.com/oauth20_token.srf")
+ .begin(Client::new()).await.unwrap().drive().await;
}
}