|
|
@ -5,16 +5,18 @@ use std::error::Error as StdError;
|
|
|
|
|
|
|
|
|
|
|
|
macro_rules! make_error {
|
|
|
|
macro_rules! make_error {
|
|
|
|
( $( $name:ident ( $ty:ty ): $src_fn:expr, $usr_msg_fun:expr ),+ $(,)? ) => {
|
|
|
|
( $( $name:ident ( $ty:ty ): $src_fn:expr, $usr_msg_fun:expr ),+ $(,)? ) => {
|
|
|
|
|
|
|
|
const BAD_REQUEST: u16 = 400;
|
|
|
|
|
|
|
|
|
|
|
|
#[derive(Display)]
|
|
|
|
#[derive(Display)]
|
|
|
|
pub enum ErrorKind { $($name( $ty )),+ }
|
|
|
|
pub enum ErrorKind { $($name( $ty )),+ }
|
|
|
|
pub struct Error { message: String, error: ErrorKind }
|
|
|
|
pub struct Error { message: String, error: ErrorKind, error_code: u16 }
|
|
|
|
|
|
|
|
|
|
|
|
$(impl From<$ty> for Error {
|
|
|
|
$(impl From<$ty> for Error {
|
|
|
|
fn from(err: $ty) -> Self { Error::from((stringify!($name), err)) }
|
|
|
|
fn from(err: $ty) -> Self { Error::from((stringify!($name), err)) }
|
|
|
|
})+
|
|
|
|
})+
|
|
|
|
$(impl<S: Into<String>> From<(S, $ty)> for Error {
|
|
|
|
$(impl<S: Into<String>> From<(S, $ty)> for Error {
|
|
|
|
fn from(val: (S, $ty)) -> Self {
|
|
|
|
fn from(val: (S, $ty)) -> Self {
|
|
|
|
Error { message: val.0.into(), error: ErrorKind::$name(val.1) }
|
|
|
|
Error { message: val.0.into(), error: ErrorKind::$name(val.1), error_code: BAD_REQUEST }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})+
|
|
|
|
})+
|
|
|
|
impl StdError for Error {
|
|
|
|
impl StdError for Error {
|
|
|
@ -43,12 +45,17 @@ use std::time::SystemTimeError as TimeErr;
|
|
|
|
use u2f::u2ferror::U2fError as U2fErr;
|
|
|
|
use u2f::u2ferror::U2fError as U2fErr;
|
|
|
|
use yubico::yubicoerror::YubicoError as YubiErr;
|
|
|
|
use yubico::yubicoerror::YubicoError as YubiErr;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#[derive(Display, Serialize)]
|
|
|
|
|
|
|
|
pub struct Empty {}
|
|
|
|
|
|
|
|
|
|
|
|
// Error struct
|
|
|
|
// Error struct
|
|
|
|
// Contains a String error message, meant for the user and an enum variant, with an error of different types.
|
|
|
|
// Contains a String error message, meant for the user and an enum variant, with an error of different types.
|
|
|
|
//
|
|
|
|
//
|
|
|
|
// After the variant itself, there are two expressions. The first one indicates whether the error contains a source error (that we pretty print).
|
|
|
|
// After the variant itself, there are two expressions. The first one indicates whether the error contains a source error (that we pretty print).
|
|
|
|
// The second one contains the function used to obtain the response sent to the client
|
|
|
|
// The second one contains the function used to obtain the response sent to the client
|
|
|
|
make_error! {
|
|
|
|
make_error! {
|
|
|
|
|
|
|
|
// Just an empty error
|
|
|
|
|
|
|
|
EmptyError(Empty): _no_source, _serialize,
|
|
|
|
// Used to represent err! calls
|
|
|
|
// Used to represent err! calls
|
|
|
|
SimpleError(String): _no_source, _api_error,
|
|
|
|
SimpleError(String): _no_source, _api_error,
|
|
|
|
// Used for special return values, like 2FA errors
|
|
|
|
// Used for special return values, like 2FA errors
|
|
|
@ -80,10 +87,19 @@ impl Error {
|
|
|
|
(usr_msg, log_msg.into()).into()
|
|
|
|
(usr_msg, log_msg.into()).into()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
pub fn empty() -> Self {
|
|
|
|
|
|
|
|
Empty {}.into()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
pub fn with_msg<M: Into<String>>(mut self, msg: M) -> Self {
|
|
|
|
pub fn with_msg<M: Into<String>>(mut self, msg: M) -> Self {
|
|
|
|
self.message = msg.into();
|
|
|
|
self.message = msg.into();
|
|
|
|
self
|
|
|
|
self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
pub fn with_code(mut self, code: u16) -> Self {
|
|
|
|
|
|
|
|
self.error_code = code;
|
|
|
|
|
|
|
|
self
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
pub trait MapResult<S> {
|
|
|
|
pub trait MapResult<S> {
|
|
|
@ -142,8 +158,10 @@ impl<'r> Responder<'r> for Error {
|
|
|
|
let usr_msg = format!("{}", self);
|
|
|
|
let usr_msg = format!("{}", self);
|
|
|
|
error!("{:#?}", self);
|
|
|
|
error!("{:#?}", self);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let code = Status::from_code(self.error_code).unwrap_or(Status::BadRequest);
|
|
|
|
|
|
|
|
|
|
|
|
Response::build()
|
|
|
|
Response::build()
|
|
|
|
.status(Status::BadRequest)
|
|
|
|
.status(code)
|
|
|
|
.header(ContentType::JSON)
|
|
|
|
.header(ContentType::JSON)
|
|
|
|
.sized_body(Cursor::new(usr_msg))
|
|
|
|
.sized_body(Cursor::new(usr_msg))
|
|
|
|
.ok()
|
|
|
|
.ok()
|
|
|
|