summaryrefslogtreecommitdiff
path: root/src/error.rs
diff options
context:
space:
mode:
authorJesse Morgan <jesse@jesterpm.net>2024-01-27 21:45:33 -0800
committerJesse Morgan <jesse@jesterpm.net>2024-01-27 21:45:33 -0800
commit8df0ef0368dd3f6fdd2fccb5da458a1fe99f25e0 (patch)
tree55c873f7742411eb099f874b84d01327471bda62 /src/error.rs
Initial version of chkoauth2v0.1.0
Diffstat (limited to 'src/error.rs')
-rw-r--r--src/error.rs68
1 files changed, 68 insertions, 0 deletions
diff --git a/src/error.rs b/src/error.rs
new file mode 100644
index 0000000..4ecd1a3
--- /dev/null
+++ b/src/error.rs
@@ -0,0 +1,68 @@
+use oauth2::http::{header, Response, StatusCode};
+use std::fmt::{Display, Formatter};
+use std::io;
+
+#[derive(Debug)]
+#[allow(clippy::enum_variant_names)]
+pub enum Error {
+ IoError(io::Error),
+ MissingToken,
+ InvalidToken,
+ ConfigurationError,
+ IntrospectionServerError,
+ AccessDenied,
+}
+
+impl Display for Error {
+ fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
+ f.write_str(match self {
+ Error::IoError(e) => return write!(f, "IO Error: {}", e),
+ Error::AccessDenied => "Access denied",
+ Error::MissingToken => "Missing authorization token",
+ Error::InvalidToken => "Invalid access token",
+ Error::ConfigurationError => "OAuth2 client configuration error",
+ Error::IntrospectionServerError => {
+ "Introspection endpoint returned an error"
+ }
+ })
+ }
+}
+
+impl From<&Error> for StatusCode {
+ fn from(e: &Error) -> StatusCode {
+ match e {
+ Error::IoError(_) => StatusCode::INTERNAL_SERVER_ERROR,
+ Error::AccessDenied => StatusCode::FORBIDDEN,
+ Error::MissingToken => StatusCode::UNAUTHORIZED,
+ Error::InvalidToken => StatusCode::UNAUTHORIZED,
+ Error::ConfigurationError => StatusCode::INTERNAL_SERVER_ERROR,
+ Error::IntrospectionServerError => StatusCode::SERVICE_UNAVAILABLE,
+ }
+ }
+}
+
+impl From<Error> for Response<Option<String>> {
+ fn from(e: Error) -> Response<Option<String>> {
+ let resp = Response::builder().status(StatusCode::from(&e));
+ match e {
+ Error::IoError(_) => resp.body(None).unwrap(),
+ Error::AccessDenied => resp
+ .header(header::WWW_AUTHENTICATE, "Bearer")
+ .body(Some("{\"error\": \"insufficient_scope\"}".to_string()))
+ .unwrap(),
+ Error::MissingToken => resp.body(None).unwrap(),
+ Error::InvalidToken => resp
+ .header(header::WWW_AUTHENTICATE, "Bearer")
+ .body(Some("{\"error\": \"invalid_token\"}".to_string()))
+ .unwrap(),
+ Error::ConfigurationError => resp.body(None).unwrap(),
+ Error::IntrospectionServerError => resp.body(None).unwrap(),
+ }
+ }
+}
+
+impl From<io::Error> for Error {
+ fn from(e: io::Error) -> Self {
+ Error::IoError(e)
+ }
+}