1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
/*
* Copyright (c) 2018 Kalev Anri Kalda <github.com/koala-kalda>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or (at your
* option) any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
* details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*
* This file incorporates work covered by the following copyright and
* permission notice:
*
* Copyright (c) 2015-2018 Alex Maslakov, <gildedhonour.com>,
* <alexmaslakov.me>
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy
* of the License at <http://www.apache.org/licenses/LICENSE-2.0>
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*/
use std::io::Error as IoError;
use serde_json::Error as SJError;
use openssl::error::ErrorStack;
use base64::DecodeError as B64Error;
use std::error;
use std::fmt;
macro_rules! impl_error {
($from:ty, $to:path) => {
impl From<$from> for Error {
fn from(e: $from) -> Self {
$to(format!("{:?}", e))
}
}
}
}
#[derive(Clone, Debug, PartialEq, Eq)]
pub enum Error {
SignatureExpired,
SignatureInvalid,
JWTInvalid,
IssuerInvalid,
ExpirationInvalid,
AudienceInvalid,
FormatInvalid(String),
IoError(String),
OpenSslError(String),
ProtocolError(String),
}
impl fmt::Display for Error {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
match self {
Error::SignatureExpired => write!(f, "Signature expired."),
Error::SignatureInvalid => write!(f, "Signature invalid."),
Error::JWTInvalid => write!(f, "JWT invalid."),
Error::IssuerInvalid => write!(f, "Issuer invalid."),
Error::ExpirationInvalid => write!(f, "Expiration invalid."),
Error::AudienceInvalid => write!(f, "Audience invalid."),
Error::FormatInvalid(msg) => write!(f, "Format invalid: {}.", msg),
Error::IoError(msg) => write!(f, "IO error: {}.", msg),
Error::OpenSslError(msg) => write!(f, "Open SSL error: {}.", msg),
Error::ProtocolError(msg) => write!(f, "Protocol error: {}.", msg),
}
}
}
impl error::Error for Error {}
impl_error!{IoError, Error::IoError}
impl_error!{SJError, Error::FormatInvalid}
impl_error!{ErrorStack, Error::OpenSslError}
impl_error!{B64Error, Error::ProtocolError}