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 {
async fn external_callback(&self) -> Result<(), Error>;
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>;
async fn login<'a>(&self, return_url: Option<&'a str>) -> Result<(), Error>;
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", ¶m_value.to_string())]);
}
if let Some(ref param_value) = return_url {
local_var_req_builder =
local_var_req_builder.query(&[("returnUrl", ¶m_value.to_string())]);
}
if let Some(ref param_value) = user_identifier {
local_var_req_builder =
local_var_req_builder.query(&[("userIdentifier", ¶m_value.to_string())]);
}
if let Some(ref param_value) = sso_token {
local_var_req_builder =
local_var_req_builder.query(&[("ssoToken", ¶m_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", ¶m_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", ¶m_value.to_string())]);
}
bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
}
}