bitwarden-api-identity 3.0.0

Api bindings for the Bitwarden Identity API.
Documentation
/*
 * Bitwarden Identity
 *
 * No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
 *
 * The version of the OpenAPI document: v1
 *
 * 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 SsoApi: Send + Sync {
    /// GET /sso/ExternalCallback
    async fn external_callback(&self) -> Result<(), Error>;

    /// GET /sso/ExternalChallenge
    async fn external_challenge<'a>(
        &self,
        domain_hint: Option<&'a str>,
        return_url: Option<&'a str>,
        user_identifier: Option<&'a str>,
        sso_token: Option<&'a str>,
    ) -> Result<(), Error>;

    /// GET /sso/Login
    async fn login<'a>(&self, return_url: Option<&'a str>) -> Result<(), Error>;

    /// GET /sso/PreValidate
    async fn pre_validate<'a>(&self, domain_hint: Option<&'a str>) -> Result<(), Error>;
}

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

impl SsoApiClient {
    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 SsoApi for SsoApiClient {
    async fn external_callback(&self) -> Result<(), Error> {
        let local_var_configuration = &self.configuration;

        let local_var_client = &local_var_configuration.client;

        let local_var_uri_str =
            format!("{}/sso/ExternalCallback", local_var_configuration.base_path);
        let mut local_var_req_builder =
            local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());

        bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
    }

    async fn external_challenge<'a>(
        &self,
        domain_hint: Option<&'a str>,
        return_url: Option<&'a str>,
        user_identifier: Option<&'a str>,
        sso_token: Option<&'a str>,
    ) -> Result<(), Error> {
        let local_var_configuration = &self.configuration;

        let local_var_client = &local_var_configuration.client;

        let local_var_uri_str = format!(
            "{}/sso/ExternalChallenge",
            local_var_configuration.base_path
        );
        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) = domain_hint {
            local_var_req_builder =
                local_var_req_builder.query(&[("domainHint", &param_value.to_string())]);
        }
        if let Some(ref param_value) = return_url {
            local_var_req_builder =
                local_var_req_builder.query(&[("returnUrl", &param_value.to_string())]);
        }
        if let Some(ref param_value) = user_identifier {
            local_var_req_builder =
                local_var_req_builder.query(&[("userIdentifier", &param_value.to_string())]);
        }
        if let Some(ref param_value) = sso_token {
            local_var_req_builder =
                local_var_req_builder.query(&[("ssoToken", &param_value.to_string())]);
        }

        bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
    }

    async fn login<'a>(&self, return_url: Option<&'a str>) -> Result<(), Error> {
        let local_var_configuration = &self.configuration;

        let local_var_client = &local_var_configuration.client;

        let local_var_uri_str = format!("{}/sso/Login", local_var_configuration.base_path);
        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) = return_url {
            local_var_req_builder =
                local_var_req_builder.query(&[("returnUrl", &param_value.to_string())]);
        }

        bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
    }

    async fn pre_validate<'a>(&self, domain_hint: Option<&'a str>) -> Result<(), Error> {
        let local_var_configuration = &self.configuration;

        let local_var_client = &local_var_configuration.client;

        let local_var_uri_str = format!("{}/sso/PreValidate", local_var_configuration.base_path);
        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) = domain_hint {
            local_var_req_builder =
                local_var_req_builder.query(&[("domainHint", &param_value.to_string())]);
        }

        bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
    }
}