bitwarden-api-api 3.0.0

Api bindings for the Bitwarden API.
Documentation
/*
 * Bitwarden Internal API
 *
 * No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
 *
 * The version of the OpenAPI document: latest
 *
 * Generated by: https://openapi-generator.tech
 */

use std::sync::Arc;

use async_trait::async_trait;
#[cfg(feature = "mockall")]
use mockall::automock;
use reqwest;
use serde::{Deserialize, Serialize, de::Error as _};

use super::{Error, configuration};
use crate::{
    apis::{AuthRequired, ContentType, ResponseContent},
    models,
};

#[cfg_attr(feature = "mockall", automock)]
#[cfg_attr(target_arch = "wasm32", async_trait(?Send))]
#[cfg_attr(not(target_arch = "wasm32"), async_trait)]
pub trait PoliciesApi: Send + Sync {
    /// GET /organizations/{orgId}/policies/{type}
    async fn get<'a>(
        &self,
        org_id: uuid::Uuid,
        r#type: models::PolicyType,
    ) -> Result<models::PolicyStatusResponseModel, Error>;

    /// GET /organizations/{orgId}/policies
    async fn get_all<'a>(
        &self,
        org_id: &'a str,
    ) -> Result<models::PolicyStatusResponseModelListResponseModel, Error>;

    /// GET /organizations/{orgId}/policies/token
    async fn get_by_token<'a>(
        &self,
        org_id: uuid::Uuid,
        email: Option<&'a str>,
        token: Option<&'a str>,
        organization_user_id: Option<uuid::Uuid>,
    ) -> Result<models::PolicyResponseModelListResponseModel, Error>;

    /// GET /organizations/{orgId}/policies/master-password
    async fn get_master_password_policy<'a>(
        &self,
        org_id: uuid::Uuid,
    ) -> Result<models::PolicyResponseModel, Error>;

    /// PUT /organizations/{orgId}/policies/{type}
    async fn put<'a>(
        &self,
        org_id: uuid::Uuid,
        r#type: models::PolicyType,
        save_policy_request: Option<models::SavePolicyRequest>,
    ) -> Result<models::PolicyResponseModel, Error>;

    /// PUT /organizations/{orgId}/policies/{type}/vnext
    async fn put_v_next<'a>(
        &self,
        org_id: uuid::Uuid,
        r#type: models::PolicyType,
        save_policy_request: Option<models::SavePolicyRequest>,
    ) -> Result<models::PolicyResponseModel, Error>;
}

pub struct PoliciesApiClient {
    configuration: Arc<configuration::Configuration>,
}

impl PoliciesApiClient {
    pub fn new(configuration: Arc<configuration::Configuration>) -> Self {
        Self { configuration }
    }
}

#[cfg_attr(target_arch = "wasm32", async_trait(?Send))]
#[cfg_attr(not(target_arch = "wasm32"), async_trait)]
impl PoliciesApi for PoliciesApiClient {
    async fn get<'a>(
        &self,
        org_id: uuid::Uuid,
        r#type: models::PolicyType,
    ) -> Result<models::PolicyStatusResponseModel, Error> {
        let local_var_configuration = &self.configuration;

        let local_var_client = &local_var_configuration.client;

        let local_var_uri_str = format!("{}/organizations/{orgId}/policies/{type}", local_var_configuration.base_path, orgId=org_id, type=r#type.to_string());
        let mut local_var_req_builder =
            local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());

        local_var_req_builder = local_var_req_builder.with_extension(AuthRequired::Bearer);

        bitwarden_api_base::process_with_json_response(local_var_req_builder).await
    }

    async fn get_all<'a>(
        &self,
        org_id: &'a str,
    ) -> Result<models::PolicyStatusResponseModelListResponseModel, Error> {
        let local_var_configuration = &self.configuration;

        let local_var_client = &local_var_configuration.client;

        let local_var_uri_str = format!(
            "{}/organizations/{orgId}/policies",
            local_var_configuration.base_path,
            orgId = crate::apis::urlencode(org_id)
        );
        let mut local_var_req_builder =
            local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());

        local_var_req_builder = local_var_req_builder.with_extension(AuthRequired::Bearer);

        bitwarden_api_base::process_with_json_response(local_var_req_builder).await
    }

    async fn get_by_token<'a>(
        &self,
        org_id: uuid::Uuid,
        email: Option<&'a str>,
        token: Option<&'a str>,
        organization_user_id: Option<uuid::Uuid>,
    ) -> Result<models::PolicyResponseModelListResponseModel, Error> {
        let local_var_configuration = &self.configuration;

        let local_var_client = &local_var_configuration.client;

        let local_var_uri_str = format!(
            "{}/organizations/{orgId}/policies/token",
            local_var_configuration.base_path,
            orgId = org_id
        );
        let mut local_var_req_builder =
            local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());

        if let Some(ref param_value) = email {
            local_var_req_builder =
                local_var_req_builder.query(&[("email", &param_value.to_string())]);
        }
        if let Some(ref param_value) = token {
            local_var_req_builder =
                local_var_req_builder.query(&[("token", &param_value.to_string())]);
        }
        if let Some(ref param_value) = organization_user_id {
            local_var_req_builder =
                local_var_req_builder.query(&[("organizationUserId", &param_value.to_string())]);
        }
        local_var_req_builder = local_var_req_builder.with_extension(AuthRequired::Bearer);

        bitwarden_api_base::process_with_json_response(local_var_req_builder).await
    }

    async fn get_master_password_policy<'a>(
        &self,
        org_id: uuid::Uuid,
    ) -> Result<models::PolicyResponseModel, Error> {
        let local_var_configuration = &self.configuration;

        let local_var_client = &local_var_configuration.client;

        let local_var_uri_str = format!(
            "{}/organizations/{orgId}/policies/master-password",
            local_var_configuration.base_path,
            orgId = org_id
        );
        let mut local_var_req_builder =
            local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());

        local_var_req_builder = local_var_req_builder.with_extension(AuthRequired::Bearer);

        bitwarden_api_base::process_with_json_response(local_var_req_builder).await
    }

    async fn put<'a>(
        &self,
        org_id: uuid::Uuid,
        r#type: models::PolicyType,
        save_policy_request: Option<models::SavePolicyRequest>,
    ) -> Result<models::PolicyResponseModel, Error> {
        let local_var_configuration = &self.configuration;

        let local_var_client = &local_var_configuration.client;

        let local_var_uri_str = format!("{}/organizations/{orgId}/policies/{type}", local_var_configuration.base_path, orgId=org_id, type=r#type.to_string());
        let mut local_var_req_builder =
            local_var_client.request(reqwest::Method::PUT, local_var_uri_str.as_str());

        local_var_req_builder = local_var_req_builder.with_extension(AuthRequired::Bearer);
        local_var_req_builder = local_var_req_builder.json(&save_policy_request);

        bitwarden_api_base::process_with_json_response(local_var_req_builder).await
    }

    async fn put_v_next<'a>(
        &self,
        org_id: uuid::Uuid,
        r#type: models::PolicyType,
        save_policy_request: Option<models::SavePolicyRequest>,
    ) -> Result<models::PolicyResponseModel, Error> {
        let local_var_configuration = &self.configuration;

        let local_var_client = &local_var_configuration.client;

        let local_var_uri_str = format!("{}/organizations/{orgId}/policies/{type}/vnext", local_var_configuration.base_path, orgId=org_id, type=r#type.to_string());
        let mut local_var_req_builder =
            local_var_client.request(reqwest::Method::PUT, local_var_uri_str.as_str());

        local_var_req_builder = local_var_req_builder.with_extension(AuthRequired::Bearer);
        local_var_req_builder = local_var_req_builder.json(&save_policy_request);

        bitwarden_api_base::process_with_json_response(local_var_req_builder).await
    }
}