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 EmergencyAccessApi: Send + Sync {
async fn accept<'a>(
&self,
id: uuid::Uuid,
organization_user_accept_request_model: Option<models::OrganizationUserAcceptRequestModel>,
) -> Result<(), Error>;
async fn approve<'a>(&self, id: uuid::Uuid) -> Result<(), Error>;
async fn confirm<'a>(
&self,
id: uuid::Uuid,
organization_user_confirm_request_model: Option<
models::OrganizationUserConfirmRequestModel,
>,
) -> Result<(), Error>;
async fn delete<'a>(&self, id: uuid::Uuid) -> Result<(), Error>;
async fn get<'a>(
&self,
id: uuid::Uuid,
) -> Result<models::EmergencyAccessGranteeDetailsResponseModel, Error>;
async fn get_attachment_data<'a>(
&self,
id: uuid::Uuid,
cipher_id: uuid::Uuid,
attachment_id: &'a str,
) -> Result<models::AttachmentResponseModel, Error>;
async fn get_contacts(
&self,
) -> Result<models::EmergencyAccessGranteeDetailsResponseModelListResponseModel, Error>;
async fn get_grantees(
&self,
) -> Result<models::EmergencyAccessGrantorDetailsResponseModelListResponseModel, Error>;
async fn initiate<'a>(&self, id: uuid::Uuid) -> Result<(), Error>;
async fn invite<'a>(
&self,
emergency_access_invite_request_model: Option<models::EmergencyAccessInviteRequestModel>,
) -> Result<(), Error>;
async fn password<'a>(
&self,
id: uuid::Uuid,
emergency_access_password_request_model: Option<
models::EmergencyAccessPasswordRequestModel,
>,
) -> Result<(), Error>;
async fn policies<'a>(
&self,
id: uuid::Uuid,
) -> Result<models::PolicyResponseModelListResponseModel, Error>;
async fn put<'a>(
&self,
id: uuid::Uuid,
emergency_access_update_request_model: Option<models::EmergencyAccessUpdateRequestModel>,
) -> Result<(), Error>;
async fn reinvite<'a>(&self, id: uuid::Uuid) -> Result<(), Error>;
async fn reject<'a>(&self, id: uuid::Uuid) -> Result<(), Error>;
async fn takeover<'a>(
&self,
id: uuid::Uuid,
) -> Result<models::EmergencyAccessTakeoverResponseModel, Error>;
async fn view_ciphers<'a>(
&self,
id: uuid::Uuid,
) -> Result<models::EmergencyAccessViewResponseModel, Error>;
}
pub struct EmergencyAccessApiClient {
configuration: Arc<configuration::Configuration>,
}
impl EmergencyAccessApiClient {
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 EmergencyAccessApi for EmergencyAccessApiClient {
async fn accept<'a>(
&self,
id: uuid::Uuid,
organization_user_accept_request_model: Option<models::OrganizationUserAcceptRequestModel>,
) -> Result<(), Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/{id}/accept",
local_var_configuration.base_path,
id = 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(&organization_user_accept_request_model);
bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
}
async fn approve<'a>(&self, id: uuid::Uuid) -> Result<(), Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/{id}/approve",
local_var_configuration.base_path,
id = 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);
bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
}
async fn confirm<'a>(
&self,
id: uuid::Uuid,
organization_user_confirm_request_model: Option<
models::OrganizationUserConfirmRequestModel,
>,
) -> Result<(), Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/{id}/confirm",
local_var_configuration.base_path,
id = 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(&organization_user_confirm_request_model);
bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
}
async fn delete<'a>(&self, id: uuid::Uuid) -> Result<(), Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/{id}",
local_var_configuration.base_path,
id = id
);
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);
bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
}
async fn get<'a>(
&self,
id: uuid::Uuid,
) -> Result<models::EmergencyAccessGranteeDetailsResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/{id}",
local_var_configuration.base_path,
id = 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_attachment_data<'a>(
&self,
id: uuid::Uuid,
cipher_id: uuid::Uuid,
attachment_id: &'a str,
) -> Result<models::AttachmentResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/{id}/{cipherId}/attachment/{attachmentId}",
local_var_configuration.base_path,
id = id,
cipherId = cipher_id,
attachmentId = crate::apis::urlencode(attachment_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_contacts(
&self,
) -> Result<models::EmergencyAccessGranteeDetailsResponseModelListResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/trusted",
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_grantees(
&self,
) -> Result<models::EmergencyAccessGrantorDetailsResponseModelListResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/granted",
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 initiate<'a>(&self, id: uuid::Uuid) -> Result<(), Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/{id}/initiate",
local_var_configuration.base_path,
id = 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);
bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
}
async fn invite<'a>(
&self,
emergency_access_invite_request_model: Option<models::EmergencyAccessInviteRequestModel>,
) -> Result<(), Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/invite",
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(&emergency_access_invite_request_model);
bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
}
async fn password<'a>(
&self,
id: uuid::Uuid,
emergency_access_password_request_model: Option<
models::EmergencyAccessPasswordRequestModel,
>,
) -> Result<(), Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/{id}/password",
local_var_configuration.base_path,
id = 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(&emergency_access_password_request_model);
bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
}
async fn policies<'a>(
&self,
id: 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!(
"{}/emergency-access/{id}/policies",
local_var_configuration.base_path,
id = 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,
id: uuid::Uuid,
emergency_access_update_request_model: Option<models::EmergencyAccessUpdateRequestModel>,
) -> Result<(), Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/{id}",
local_var_configuration.base_path,
id = 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(&emergency_access_update_request_model);
bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
}
async fn reinvite<'a>(&self, id: uuid::Uuid) -> Result<(), Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/{id}/reinvite",
local_var_configuration.base_path,
id = 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);
bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
}
async fn reject<'a>(&self, id: uuid::Uuid) -> Result<(), Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/{id}/reject",
local_var_configuration.base_path,
id = 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);
bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
}
async fn takeover<'a>(
&self,
id: uuid::Uuid,
) -> Result<models::EmergencyAccessTakeoverResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/{id}/takeover",
local_var_configuration.base_path,
id = 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);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
async fn view_ciphers<'a>(
&self,
id: uuid::Uuid,
) -> Result<models::EmergencyAccessViewResponseModel, Error> {
let local_var_configuration = &self.configuration;
let local_var_client = &local_var_configuration.client;
let local_var_uri_str = format!(
"{}/emergency-access/{id}/view",
local_var_configuration.base_path,
id = 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);
bitwarden_api_base::process_with_json_response(local_var_req_builder).await
}
}