use std::error::Error; use axum::headers::HeaderValue; use axum::http::StatusCode; use tracing::{debug, error, trace}; use crate::auth::AuthError::{MissingSecret, ServerError, WrongSecret}; use crate::config::SETTINGS; pub fn auth(secret: Option<&HeaderValue>) -> Result { debug!("auth request with secret {:?}", secret); if let Some(value) = secret { trace!("value exists"); let key = SETTINGS .get_string("apikey") .map_err(|err| ServerError(Box::new(err)))?; if value.to_str().map_err(|err| ServerError(Box::new(err)))? == key.as_str() { debug!("successful auth"); Ok(true) } else { debug!("unsuccessful auth (wrong secret)"); Err(WrongSecret) } } else { debug!("unsuccessful auth (no secret)"); Err(MissingSecret) } } #[derive(Debug)] pub enum AuthError { WrongSecret, MissingSecret, ServerError(Box), } impl AuthError { pub fn get(self) -> (StatusCode, &'static str) { match self { AuthError::WrongSecret => (StatusCode::UNAUTHORIZED, "Wrong credentials"), AuthError::MissingSecret => (StatusCode::BAD_REQUEST, "Missing credentials"), AuthError::ServerError(err) => { error!("server error: {}", err.to_string()); (StatusCode::INTERNAL_SERVER_ERROR, "Server Error") }, } } }