Added perform request without client
This commit is contained in:
parent
e271f0e344
commit
a058023e05
@ -1,4 +1,5 @@
|
|||||||
use actix_web_utils::{enums::error::Error, dtos::message::MessageResource};
|
use actix_web_utils::{enums::error::Error, dtos::message::MessageResource};
|
||||||
|
use reqwest::Client;
|
||||||
use serde::{Serialize, de::DeserializeOwned};
|
use serde::{Serialize, de::DeserializeOwned};
|
||||||
|
|
||||||
pub async fn perform_request<B: Serialize, R: DeserializeOwned>(
|
pub async fn perform_request<B: Serialize, R: DeserializeOwned>(
|
||||||
@ -17,6 +18,59 @@ pub async fn perform_request<B: Serialize, R: DeserializeOwned>(
|
|||||||
req_incomplete = req_incomplete.header(&header.0, &header.1);
|
req_incomplete = req_incomplete.header(&header.0, &header.1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let req_complete = match body {
|
||||||
|
Some(b) => req_incomplete.json(&b),
|
||||||
|
None => req_incomplete.header("content-length", 0),
|
||||||
|
};
|
||||||
|
println!("{:?}", req_complete);
|
||||||
|
match req_complete.send().await {
|
||||||
|
// Error handling here
|
||||||
|
Ok(res) => {
|
||||||
|
// Request sent correctly
|
||||||
|
match res.status().as_u16() == expected_status_code {
|
||||||
|
true => {
|
||||||
|
match res.json::<R>().await {
|
||||||
|
Ok(resp_dto) => Ok(resp_dto), // Return correctly deserialized obj
|
||||||
|
Err(err) => Err(Error::ClientError(MessageResource::new_from_err(err))),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
false => {
|
||||||
|
//If status code is any other than expected
|
||||||
|
Err(Error::UnexpectedStatusCode(
|
||||||
|
expected_status_code,
|
||||||
|
res.status().as_u16(),
|
||||||
|
match res.json::<Vec<MessageResource>>().await {
|
||||||
|
Ok(messages) => messages,
|
||||||
|
Err(e) => vec![MessageResource::new_from_err(e.to_string())],
|
||||||
|
},
|
||||||
|
))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Err(e) => {
|
||||||
|
// Request couldn't be sent
|
||||||
|
Err(Error::ClientError(MessageResource::new_from_err(e)))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/// This function is mainly for when you don't have a client in your application and just want to get it over with.
|
||||||
|
/// This shouldn't be used as it takes more resource consumption than the above method.
|
||||||
|
pub async fn perform_request_without_client<B: Serialize, R: DeserializeOwned>(
|
||||||
|
base_url: String,
|
||||||
|
method: reqwest::Method,
|
||||||
|
path: String,
|
||||||
|
body: Option<B>,
|
||||||
|
expected_status_code: u16,
|
||||||
|
headers: Vec<(String, String)>,
|
||||||
|
) -> Result<R, Error> {
|
||||||
|
let client = Client::new();
|
||||||
|
let mut req_incomplete =
|
||||||
|
client.request(method, format!("{url}{path}", url = base_url, path = path));
|
||||||
|
|
||||||
|
for header in headers {
|
||||||
|
req_incomplete = req_incomplete.header(&header.0, &header.1);
|
||||||
|
}
|
||||||
|
|
||||||
let req_complete = match body {
|
let req_complete = match body {
|
||||||
Some(b) => req_incomplete.json(&b),
|
Some(b) => req_incomplete.json(&b),
|
||||||
None => req_incomplete.header("content-length", 0),
|
None => req_incomplete.header("content-length", 0),
|
||||||
|
Loading…
Reference in New Issue
Block a user