use async_trait::async_trait;
use crate::context::Context;
use crate::error::Error;
use crate::model::error_body::ErrorBody;
use crate::model::errors_body::ErrorsBody;
use crate::model::project_policy::ProjectPolicy;
use crate::model::project_policy_data::ProjectPolicyData;
use uuid::Uuid;
pub enum ProjectPolicyError {
Error400(ErrorsBody),
Error401(ErrorBody),
Error403(ErrorBody),
Error404(ErrorBody),
Error500(ErrorBody),
}
#[async_trait]
pub trait ProjectPolicyClient {
async fn project_policy_id_get(&self, project_policy_id: &Uuid) -> Result<ProjectPolicy, Error<ProjectPolicyError>>;
async fn post(&self, value: &ProjectPolicyData) -> Result<ProjectPolicy, Error<ProjectPolicyError>>;
}
pub struct ProjectPolicyClientLive {
pub context: Context,
}
#[async_trait]
impl ProjectPolicyClient for ProjectPolicyClientLive {
async fn project_policy_id_get(&self, project_policy_id: &Uuid) -> Result<ProjectPolicy, Error<ProjectPolicyError>> {
let mut url = self.context.base_url.clone();
url.path_segments_mut().unwrap()
.push("v2")
.push("project-policies")
.push(&project_policy_id.to_string());
let mut request = self
.context
.client
.get(url.clone());
{
tracing::info!(method="get", endpoint="/v2/project-policies/{project_policy_id}", url=url.to_string(), "project_policy_id_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::<ProjectPolicy>().await?)
}
400 => {
let body = response.json::<ErrorsBody>().await?;
Err(Error::Item(ProjectPolicyError::Error400(body)))
}
401 => {
let body = response.json::<ErrorBody>().await?;
Err(Error::Item(ProjectPolicyError::Error401(body)))
}
403 => {
let body = response.json::<ErrorBody>().await?;
Err(Error::Item(ProjectPolicyError::Error403(body)))
}
404 => {
let body = response.json::<ErrorBody>().await?;
Err(Error::Item(ProjectPolicyError::Error404(body)))
}
500 => {
let body = response.json::<ErrorBody>().await?;
Err(Error::Item(ProjectPolicyError::Error500(body)))
}
_ => Err(Error::unexpected(status, response.bytes().await?)),
}
}
async fn post(&self, value: &ProjectPolicyData) -> Result<ProjectPolicy, Error<ProjectPolicyError>> {
let mut url = self.context.base_url.clone();
url.path_segments_mut().unwrap()
.push("v2")
.push("project-policies");
let mut request = self
.context
.client
.post(url.clone());
{
tracing::info!(method="post", endpoint="/v2/project-policies", 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::<ProjectPolicy>().await?)
}
400 => {
let body = response.json::<ErrorsBody>().await?;
Err(Error::Item(ProjectPolicyError::Error400(body)))
}
401 => {
let body = response.json::<ErrorBody>().await?;
Err(Error::Item(ProjectPolicyError::Error401(body)))
}
403 => {
let body = response.json::<ErrorBody>().await?;
Err(Error::Item(ProjectPolicyError::Error403(body)))
}
404 => {
let body = response.json::<ErrorBody>().await?;
Err(Error::Item(ProjectPolicyError::Error404(body)))
}
500 => {
let body = response.json::<ErrorBody>().await?;
Err(Error::Item(ProjectPolicyError::Error500(body)))
}
_ => Err(Error::unexpected(status, response.bytes().await?)),
}
}
}