use http::{HeaderMap, HeaderValue};
use log::error;
use thiserror::Error;
use crate::api::job::Job;
use crate::api::users::CurrentUser;
use crate::api::{self, AsyncQuery, Query};
#[derive(Debug, Error)]
#[non_exhaustive]
pub enum AuthError {
#[error("header value error: {}", source)]
HeaderValue {
#[from]
source: http::header::InvalidHeaderValue,
},
}
type AuthResult<T> = Result<T, AuthError>;
#[derive(Clone)]
#[non_exhaustive]
pub enum Auth {
Token(String),
JobToken(String),
OAuth2(String),
None,
}
impl Auth {
pub fn set_header<'a>(
&self,
headers: &'a mut HeaderMap<HeaderValue>,
) -> AuthResult<&'a mut HeaderMap<HeaderValue>> {
match self {
Auth::Token(token) => {
let mut token_header_value = HeaderValue::from_str(token)?;
token_header_value.set_sensitive(true);
headers.insert("PRIVATE-TOKEN", token_header_value);
},
Auth::JobToken(token) => {
let mut token_header_value = HeaderValue::from_str(token)?;
token_header_value.set_sensitive(true);
headers.insert("JOB-TOKEN", token_header_value);
},
Auth::OAuth2(token) => {
let value = format!("Bearer {}", token);
let mut token_header_value = HeaderValue::from_str(&value)?;
token_header_value.set_sensitive(true);
headers.insert(http::header::AUTHORIZATION, token_header_value);
},
Auth::None => {},
}
Ok(headers)
}
pub fn check_connection<C>(&self, api: &C) -> Result<(), api::ApiError<C::Error>>
where
C: api::Client,
{
match self {
Self::None => {
},
Self::JobToken(_) => {
api::ignore(Job::builder().build().unwrap()).query(api)?;
},
Self::Token(_) | Self::OAuth2(_) => {
api::ignore(CurrentUser::builder().build().unwrap()).query(api)?;
},
}
Ok(())
}
pub async fn check_connection_async<C>(&self, api: &C) -> Result<(), api::ApiError<C::Error>>
where
C: api::AsyncClient + Sync,
{
match self {
Self::None => {
},
Self::JobToken(_) => {
api::ignore(Job::builder().build().unwrap())
.query_async(api)
.await?;
},
Self::Token(_) | Self::OAuth2(_) => {
api::ignore(CurrentUser::builder().build().unwrap())
.query_async(api)
.await?;
},
}
Ok(())
}
}