summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJesse Morgan <jesse@jesterpm.net>2020-09-18 21:41:36 -0700
committerJesse Morgan <jesse@jesterpm.net>2020-09-18 21:41:36 -0700
commit1cdfdeddbce256f26a7a7d4eae0ed2aacbcf8661 (patch)
tree710595ddfc99e261d51e4be237221e7b122e8ffb
parent89734a74faed3c330bed569ac36b6480da8ed8d9 (diff)
Replace reqwest with actix_web::client
-rw-r--r--Cargo.lock107
-rw-r--r--Cargo.toml2
-rw-r--r--src/oauth.rs42
3 files changed, 40 insertions, 111 deletions
diff --git a/Cargo.lock b/Cargo.lock
index fc6326f..2e52ff9 100644
--- a/Cargo.lock
+++ b/Cargo.lock
@@ -1203,16 +1203,10 @@ dependencies = [
"socket2",
"widestring",
"winapi 0.3.9",
- "winreg 0.6.2",
+ "winreg",
]
[[package]]
-name = "ipnet"
-version = "2.3.0"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "47be2f14c678be2fdcab04ab1171db51b2762ce6f0a8ee87c8dd4a04ed216135"
-
-[[package]]
name = "itoa"
version = "0.4.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -1229,15 +1223,6 @@ dependencies = [
]
[[package]]
-name = "js-sys"
-version = "0.3.45"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "ca059e81d9486668f12d455a4ea6daa600bd408134cd17e3d3fb5a32d1f016f8"
-dependencies = [
- "wasm-bindgen",
-]
-
-[[package]]
name = "kernel32-sys"
version = "0.2.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -1350,16 +1335,6 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "2a60c7ce501c71e03a9c9c0d35b861413ae925bd979cc7a4e30d060069aaac8d"
[[package]]
-name = "mime_guess"
-version = "2.0.3"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "2684d4c2e97d99848d30b324b00c8fcc7e5c897b7cbb5819b09e7c90e8baf212"
-dependencies = [
- "mime",
- "unicase",
-]
-
-[[package]]
name = "miniz_oxide"
version = "0.3.7"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -1807,42 +1782,6 @@ dependencies = [
]
[[package]]
-name = "reqwest"
-version = "0.10.8"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "e9eaa17ac5d7b838b7503d118fa16ad88f440498bf9ffe5424e621f93190d61e"
-dependencies = [
- "base64 0.12.3",
- "bytes",
- "encoding_rs",
- "futures-core",
- "futures-util",
- "http",
- "http-body",
- "hyper",
- "hyper-tls",
- "ipnet",
- "js-sys",
- "lazy_static",
- "log",
- "mime",
- "mime_guess",
- "native-tls",
- "percent-encoding",
- "pin-project-lite",
- "serde",
- "serde_json",
- "serde_urlencoded",
- "tokio",
- "tokio-tls",
- "url",
- "wasm-bindgen",
- "wasm-bindgen-futures",
- "web-sys",
- "winreg 0.7.0",
-]
-
-[[package]]
name = "resolv-conf"
version = "0.6.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -1981,13 +1920,13 @@ dependencies = [
"base32",
"bytes",
"chrono",
+ "derive_more",
"env_logger",
"futures",
"image",
"log",
"mime",
"rand",
- "reqwest",
"rusoto_core",
"rusoto_s3",
"serde",
@@ -2526,15 +2465,6 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "eeba86d422ce181a719445e51872fa30f1f7413b62becb52e95ec91aa262d85c"
[[package]]
-name = "unicase"
-version = "2.6.0"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "50f37be617794602aabbeee0be4f259dc1778fabe05e2d67ee8f79326d5cb4f6"
-dependencies = [
- "version_check",
-]
-
-[[package]]
name = "unicode-bidi"
version = "0.3.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -2616,8 +2546,6 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "1ac64ead5ea5f05873d7c12b545865ca2b8d28adfc50a49b84770a3a97265d42"
dependencies = [
"cfg-if",
- "serde",
- "serde_json",
"wasm-bindgen-macro",
]
@@ -2637,18 +2565,6 @@ dependencies = [
]
[[package]]
-name = "wasm-bindgen-futures"
-version = "0.4.18"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "b7866cab0aa01de1edf8b5d7936938a7e397ee50ce24119aef3e1eaa3b6171da"
-dependencies = [
- "cfg-if",
- "js-sys",
- "wasm-bindgen",
- "web-sys",
-]
-
-[[package]]
name = "wasm-bindgen-macro"
version = "0.2.68"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -2678,16 +2594,6 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "1d649a3145108d7d3fbcde896a468d1bd636791823c9921135218ad89be08307"
[[package]]
-name = "web-sys"
-version = "0.3.45"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "4bf6ef87ad7ae8008e15a355ce696bed26012b7caa21605188cfd8214ab51e2d"
-dependencies = [
- "js-sys",
- "wasm-bindgen",
-]
-
-[[package]]
name = "widestring"
version = "0.4.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -2746,15 +2652,6 @@ dependencies = [
]
[[package]]
-name = "winreg"
-version = "0.7.0"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "0120db82e8a1e0b9fb3345a539c478767c0048d842860994d96113d5b667bd69"
-dependencies = [
- "winapi 0.3.9",
-]
-
-[[package]]
name = "ws2_32-sys"
version = "0.2.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
diff --git a/Cargo.toml b/Cargo.toml
index e076570..25add68 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -17,13 +17,13 @@ bytes = "0.5"
futures = "0.3"
chrono = { version = "0.4", features = ["serde"] }
+derive_more = "0.99.9"
serde = { version = "1.0", features = ["derive"] }
serde_json = "1.0"
base32 = "0.4"
mime = "0.3"
rand = "0.7"
-reqwest = { version = "0.10", features = ["json"] }
rusoto_core = "0.45.0"
rusoto_s3 = "0.45.0"
diff --git a/src/oauth.rs b/src/oauth.rs
index 8707b1a..4d9bd1e 100644
--- a/src/oauth.rs
+++ b/src/oauth.rs
@@ -1,5 +1,9 @@
+use actix_web::client::Client;
+use actix_web::error::Error;
+use actix_web::http::{header, StatusCode};
+use actix_web::ResponseError;
+use derive_more::Display;
use futures::{FutureExt, TryFutureExt};
-use reqwest::header;
use serde::{Deserialize, Serialize};
/// Representation of an OAuth Access Token
@@ -27,7 +31,7 @@ impl AccessToken {
/// Verification Service takes an Authorization header and checks if it's valid.
pub struct VerificationService {
token_endpoint: String,
- client: reqwest::Client,
+ client: Client,
}
impl VerificationService {
@@ -37,7 +41,7 @@ impl VerificationService {
{
VerificationService {
token_endpoint: token_endpoint.into(),
- client: reqwest::Client::new(),
+ client: Client::new(),
}
}
@@ -46,8 +50,36 @@ impl VerificationService {
.get(&self.token_endpoint)
.header(header::AUTHORIZATION, auth_token)
.send()
- .map(|res| res.and_then(|r| r.error_for_status()))
- .and_then(|resp| resp.json())
+ .map_err(Error::from)
+ .map(|res| {
+ res.and_then(|r| {
+ if r.status().is_success() {
+ Ok(r)
+ } else if r.status() == StatusCode::UNAUTHORIZED {
+ Err(VerificationError::Unauthenticated.into())
+ } else {
+ Err(VerificationError::InternalError(
+ r.status()
+ .canonical_reason()
+ .unwrap_or("Unknown Error")
+ .to_string(),
+ )
+ .into())
+ }
+ })
+ })
+ .map_err(Error::from)
+ .and_then(|mut resp| resp.json().map_err(Error::from))
.await
}
}
+
+#[derive(Display, Debug)]
+pub enum VerificationError {
+ #[display(fmt = "Unauthenticated")]
+ Unauthenticated,
+ #[display(fmt = "AuthServer Error")]
+ InternalError(String),
+}
+
+impl ResponseError for VerificationError {}