use async_trait::async_trait;
use crate::context::Context;
use crate::error::Error;
use crate::model::batch_update_resource_limits::BatchUpdateResourceLimits;
use crate::model::error_body::ErrorBody;
use crate::model::errors_body::ErrorsBody;
use crate::model::resource_limits::ResourceLimits;
use crate::model::update_resource_limits_response::UpdateResourceLimitsResponse;
pub enum LimitsError {
Error400(ErrorsBody),
Error401(ErrorBody),
Error403(ErrorBody),
Error500(ErrorBody),
}
#[async_trait]
pub trait LimitsClient {
async fn get(&self, account_id: &str) -> Result<ResourceLimits, Error<LimitsError>>;
async fn post(&self, value: &BatchUpdateResourceLimits) -> Result<UpdateResourceLimitsResponse, Error<LimitsError>>;
}
pub struct LimitsClientLive {
pub context: Context,
}
#[async_trait]
impl LimitsClient for LimitsClientLive {
async fn get(&self, account_id: &str) -> Result<ResourceLimits, Error<LimitsError>> {
let mut url = self.context.base_url.clone();
url.path_segments_mut().unwrap()
.push("v2")
.push("resource-limits");
url.query_pairs_mut().append_pair("account_id", &account_id);
let mut request = self
.context
.client
.get(url.clone());
{
tracing::info!(method="get", endpoint="/v2/resource-limits", url=url.to_string(), "get");
}
if let Some(token) = self.context.bearer_token() {
request = request.bearer_auth(token);
}
let response = request.send().await?;
let status = response.status().as_u16();
match status {
200 => {
Ok(response.json::<ResourceLimits>().await?)
}
400 => {
let body = response.json::<ErrorsBody>().await?;
Err(Error::Item(LimitsError::Error400(body)))
}
401 => {
let body = response.json::<ErrorBody>().await?;
Err(Error::Item(LimitsError::Error401(body)))
}
403 => {
let body = response.json::<ErrorBody>().await?;
Err(Error::Item(LimitsError::Error403(body)))
}
500 => {
let body = response.json::<ErrorBody>().await?;
Err(Error::Item(LimitsError::Error500(body)))
}
_ => Err(Error::unexpected(status, response.bytes().await?)),
}
}
async fn post(&self, value: &BatchUpdateResourceLimits) -> Result<UpdateResourceLimitsResponse, Error<LimitsError>> {
let mut url = self.context.base_url.clone();
url.path_segments_mut().unwrap()
.push("v2")
.push("resource-limits");
let mut request = self
.context
.client
.post(url.clone());
{
tracing::info!(method="post", endpoint="/v2/resource-limits", url=url.to_string(), body=serde_json::to_string(value)?, "post");
}
if let Some(token) = self.context.bearer_token() {
request = request.bearer_auth(token);
}
request = request.json(value);
let response = request.send().await?;
let status = response.status().as_u16();
match status {
200 => {
Ok(response.json::<UpdateResourceLimitsResponse>().await?)
}
400 => {
let body = response.json::<ErrorsBody>().await?;
Err(Error::Item(LimitsError::Error400(body)))
}
401 => {
let body = response.json::<ErrorBody>().await?;
Err(Error::Item(LimitsError::Error401(body)))
}
403 => {
let body = response.json::<ErrorBody>().await?;
Err(Error::Item(LimitsError::Error403(body)))
}
500 => {
let body = response.json::<ErrorBody>().await?;
Err(Error::Item(LimitsError::Error500(body)))
}
_ => Err(Error::unexpected(status, response.bytes().await?)),
}
}
}