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 TwoFactorApi: Send + Sync {
async fn delete_web_authn<'a>(
&self,
two_factor_web_authn_delete_request_model: Option<
models::TwoFactorWebAuthnDeleteRequestModel,
>,
) -> Result<models::TwoFactorWebAuthnResponseModel, Error>;
async fn disable_authenticator<'a>(
&self,
two_factor_authenticator_disable_request_model: Option<
models::TwoFactorAuthenticatorDisableRequestModel,
>,
) -> Result<models::TwoFactorProviderResponseModel, Error>;
async fn get(&self) -> Result<models::TwoFactorProviderResponseModelListResponseModel, Error>;
async fn get_authenticator<'a>(
&self,
secret_verification_request_model: Option<models::SecretVerificationRequestModel>,
) -> Result<models::TwoFactorAuthenticatorResponseModel, Error>;
async fn get_duo<'a>(
&self,
secret_verification_request_model: Option<models::SecretVerificationRequestModel>,
) -> Result<models::TwoFactorDuoResponseModel, Error>;
async fn get_email<'a>(
&self,
secret_verification_request_model: Option<models::SecretVerificationRequestModel>,
) -> Result<models::TwoFactorEmailResponseModel, Error>;
async fn get_organization<'a>(
&self,
id: &'a str,
) -> Result<models::TwoFactorProviderResponseModelListResponseModel, Error>;
async fn get_organization_duo<'a>(
&self,
id: &'a str,
secret_verification_request_model: Option<models::SecretVerificationRequestModel>,
) -> Result<models::TwoFactorDuoResponseModel, Error>;
async fn get_recover<'a>(
&self,
secret_verification_request_model: Option<models::SecretVerificationRequestModel>,
) -> Result<models::TwoFactorRecoverResponseModel, Error>;
async fn get_web_authn<'a>(
&self,
secret_verification_request_model: Option<models::SecretVerificationRequestModel>,
) -> Result<models::TwoFactorWebAuthnResponseModel, Error>;
async fn get_yubi_key<'a>(
&self,
secret_verification_request_model: Option<models::SecretVerificationRequestModel>,
) -> Result<models::TwoFactorYubiKeyResponseModel, Error>;
async fn put_authenticator<'a>(
&self,
update_two_factor_authenticator_request_model: Option<
models::UpdateTwoFactorAuthenticatorRequestModel,
>,
) -> Result<models::TwoFactorAuthenticatorResponseModel, Error>;
async fn put_disable<'a>(
&self,
two_factor_provider_request_model: Option<models::TwoFactorProviderRequestModel>,
) -> Result<models::TwoFactorProviderResponseModel, Error>;
async fn put_duo<'a>(
&self,
update_two_factor_duo_request_model: Option<models::UpdateTwoFactorDuoRequestModel>,
) -> Result<models::TwoFactorDuoResponseModel, Error>;
async fn put_email<'a>(
&self,
update_two_factor_email_request_model: Option<models::UpdateTwoFactorEmailRequestModel>,
) -> Result<models::TwoFactorEmailResponseModel, Error>;
async fn put_organization_disable<'a>(
&self,
id: &'a str,
two_factor_provider_request_model: Option<models::TwoFactorProviderRequestModel>,
) -> Result<models::TwoFactorProviderResponseModel, Error>;
async fn put_organization_duo<'a>(
&self,
id: &'a str,
update_two_factor_duo_request_model: Option<models::UpdateTwoFactorDuoRequestModel>,
) -> Result<models::TwoFactorDuoResponseModel, Error>;
async fn put_web_authn<'a>(
&self,
two_factor_web_authn_request_model: Option<models::TwoFactorWebAuthnRequestModel>,
) -> Result<models::TwoFactorWebAuthnResponseModel, Error>;
async fn put_yubi_key<'a>(
&self,
update_two_factor_yubico_otp_request_model: Option<
models::UpdateTwoFactorYubicoOtpRequestModel,
>,
) -> Result<models::TwoFactorYubiKeyResponseModel, Error>;
async fn send_email<'a>(
&self,
two_factor_email_request_model: Option<models::TwoFactorEmailRequestModel>,
) -> Result<(), Error>;
async fn send_email_login<'a>(
&self,
two_factor_email_request_model: Option<models::TwoFactorEmailRequestModel>,
) -> Result<(), Error>;
}
pub struct TwoFactorApiClient {
configuration: Arc<configuration::Configuration>,
}
impl TwoFactorApiClient {
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 TwoFactorApi for TwoFactorApiClient {
async fn delete_web_authn<'a>(
&self,
two_factor_web_authn_delete_request_model: Option<
models::TwoFactorWebAuthnDeleteRequestModel,
>,
) -> Result<models::TwoFactorWebAuthnResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str =
format!("{}/two-factor/webauthn", local_var_configuration.base_path);
let mut local_var_req_builder =
local_var_client.request(reqwest::Method::DELETE, 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(&two_factor_web_authn_delete_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn disable_authenticator<'a>(
&self,
two_factor_authenticator_disable_request_model: Option<
models::TwoFactorAuthenticatorDisableRequestModel,
>,
) -> Result<models::TwoFactorProviderResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/two-factor/authenticator",
local_var_configuration.base_path
);
let mut local_var_req_builder =
local_var_client.request(reqwest::Method::DELETE, 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(&two_factor_authenticator_disable_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn get(&self) -> Result<models::TwoFactorProviderResponseModelListResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/two-factor", local_var_configuration.base_path);
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_authenticator<'a>(
&self,
secret_verification_request_model: Option<models::SecretVerificationRequestModel>,
) -> Result<models::TwoFactorAuthenticatorResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/two-factor/get-authenticator",
local_var_configuration.base_path
);
let mut local_var_req_builder =
local_var_client.request(reqwest::Method::POST, 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(&secret_verification_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn get_duo<'a>(
&self,
secret_verification_request_model: Option<models::SecretVerificationRequestModel>,
) -> Result<models::TwoFactorDuoResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/two-factor/get-duo", local_var_configuration.base_path);
let mut local_var_req_builder =
local_var_client.request(reqwest::Method::POST, 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(&secret_verification_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn get_email<'a>(
&self,
secret_verification_request_model: Option<models::SecretVerificationRequestModel>,
) -> Result<models::TwoFactorEmailResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str =
format!("{}/two-factor/get-email", local_var_configuration.base_path);
let mut local_var_req_builder =
local_var_client.request(reqwest::Method::POST, 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(&secret_verification_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn get_organization<'a>(
&self,
id: &'a str,
) -> Result<models::TwoFactorProviderResponseModelListResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/organizations/{id}/two-factor",
local_var_configuration.base_path,
id = crate::apis::urlencode(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_organization_duo<'a>(
&self,
id: &'a str,
secret_verification_request_model: Option<models::SecretVerificationRequestModel>,
) -> Result<models::TwoFactorDuoResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/organizations/{id}/two-factor/get-duo",
local_var_configuration.base_path,
id = crate::apis::urlencode(id)
);
let mut local_var_req_builder =
local_var_client.request(reqwest::Method::POST, 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(&secret_verification_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn get_recover<'a>(
&self,
secret_verification_request_model: Option<models::SecretVerificationRequestModel>,
) -> Result<models::TwoFactorRecoverResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/two-factor/get-recover",
local_var_configuration.base_path
);
let mut local_var_req_builder =
local_var_client.request(reqwest::Method::POST, 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(&secret_verification_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn get_web_authn<'a>(
&self,
secret_verification_request_model: Option<models::SecretVerificationRequestModel>,
) -> Result<models::TwoFactorWebAuthnResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/two-factor/get-webauthn",
local_var_configuration.base_path
);
let mut local_var_req_builder =
local_var_client.request(reqwest::Method::POST, 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(&secret_verification_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn get_yubi_key<'a>(
&self,
secret_verification_request_model: Option<models::SecretVerificationRequestModel>,
) -> Result<models::TwoFactorYubiKeyResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/two-factor/get-yubikey",
local_var_configuration.base_path
);
let mut local_var_req_builder =
local_var_client.request(reqwest::Method::POST, 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(&secret_verification_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn put_authenticator<'a>(
&self,
update_two_factor_authenticator_request_model: Option<
models::UpdateTwoFactorAuthenticatorRequestModel,
>,
) -> Result<models::TwoFactorAuthenticatorResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/two-factor/authenticator",
local_var_configuration.base_path
);
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(&update_two_factor_authenticator_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn put_disable<'a>(
&self,
two_factor_provider_request_model: Option<models::TwoFactorProviderRequestModel>,
) -> Result<models::TwoFactorProviderResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/two-factor/disable", local_var_configuration.base_path);
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(&two_factor_provider_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn put_duo<'a>(
&self,
update_two_factor_duo_request_model: Option<models::UpdateTwoFactorDuoRequestModel>,
) -> Result<models::TwoFactorDuoResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/two-factor/duo", local_var_configuration.base_path);
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(&update_two_factor_duo_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn put_email<'a>(
&self,
update_two_factor_email_request_model: Option<models::UpdateTwoFactorEmailRequestModel>,
) -> Result<models::TwoFactorEmailResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/two-factor/email", local_var_configuration.base_path);
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(&update_two_factor_email_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn put_organization_disable<'a>(
&self,
id: &'a str,
two_factor_provider_request_model: Option<models::TwoFactorProviderRequestModel>,
) -> Result<models::TwoFactorProviderResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/organizations/{id}/two-factor/disable",
local_var_configuration.base_path,
id = crate::apis::urlencode(id)
);
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(&two_factor_provider_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn put_organization_duo<'a>(
&self,
id: &'a str,
update_two_factor_duo_request_model: Option<models::UpdateTwoFactorDuoRequestModel>,
) -> Result<models::TwoFactorDuoResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/organizations/{id}/two-factor/duo",
local_var_configuration.base_path,
id = crate::apis::urlencode(id)
);
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(&update_two_factor_duo_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn put_web_authn<'a>(
&self,
two_factor_web_authn_request_model: Option<models::TwoFactorWebAuthnRequestModel>,
) -> Result<models::TwoFactorWebAuthnResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str =
format!("{}/two-factor/webauthn", local_var_configuration.base_path);
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(&two_factor_web_authn_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn put_yubi_key<'a>(
&self,
update_two_factor_yubico_otp_request_model: Option<
models::UpdateTwoFactorYubicoOtpRequestModel,
>,
) -> Result<models::TwoFactorYubiKeyResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!("{}/two-factor/yubikey", local_var_configuration.base_path);
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(&update_two_factor_yubico_otp_request_model);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn send_email<'a>(
&self,
two_factor_email_request_model: Option<models::TwoFactorEmailRequestModel>,
) -> Result<(), Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/two-factor/send-email",
local_var_configuration.base_path
);
let mut local_var_req_builder =
local_var_client.request(reqwest::Method::POST, 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(&two_factor_email_request_model);
bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
}
async fn send_email_login<'a>(
&self,
two_factor_email_request_model: Option<models::TwoFactorEmailRequestModel>,
) -> Result<(), Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/two-factor/send-email-login",
local_var_configuration.base_path
);
let mut local_var_req_builder =
local_var_client.request(reqwest::Method::POST, 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(&two_factor_email_request_model);
bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
}
}