bitwarden_api_api/apis/
sync_api.rs1use std::sync::Arc;
12
13use async_trait::async_trait;
14#[cfg(feature = "mockall")]
15use mockall::automock;
16use reqwest;
17use serde::{Deserialize, Serialize, de::Error as _};
18
19use super::{Error, configuration};
20use crate::{
21 apis::{AuthRequired, ContentType, ResponseContent},
22 models,
23};
24
25#[cfg_attr(feature = "mockall", automock)]
26#[cfg_attr(target_arch = "wasm32", async_trait(?Send))]
27#[cfg_attr(not(target_arch = "wasm32"), async_trait)]
28pub trait SyncApi: Send + Sync {
29 async fn get<'a>(
31 &self,
32 exclude_domains: Option<bool>,
33 ) -> Result<models::SyncResponseModel, Error<GetError>>;
34}
35
36pub struct SyncApiClient {
37 configuration: Arc<configuration::Configuration>,
38}
39
40impl SyncApiClient {
41 pub fn new(configuration: Arc<configuration::Configuration>) -> Self {
42 Self { configuration }
43 }
44}
45
46#[cfg_attr(target_arch = "wasm32", async_trait(?Send))]
47#[cfg_attr(not(target_arch = "wasm32"), async_trait)]
48impl SyncApi for SyncApiClient {
49 async fn get<'a>(
50 &self,
51 exclude_domains: Option<bool>,
52 ) -> Result<models::SyncResponseModel, Error<GetError>> {
53 let local_var_configuration = &self.configuration;
54
55 let local_var_client = &local_var_configuration.client;
56
57 let local_var_uri_str = format!("{}/sync", local_var_configuration.base_path);
58 let mut local_var_req_builder =
59 local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());
60
61 if let Some(ref param_value) = exclude_domains {
62 local_var_req_builder =
63 local_var_req_builder.query(&[("excludeDomains", ¶m_value.to_string())]);
64 }
65 if let Some(ref local_var_token) = local_var_configuration.oauth_access_token {
66 local_var_req_builder = local_var_req_builder.bearer_auth(local_var_token.to_owned());
67 };
68 local_var_req_builder = local_var_req_builder.with_extension(AuthRequired::Bearer);
69
70 let local_var_req = local_var_req_builder.build()?;
71 let local_var_resp = local_var_client.execute(local_var_req).await?;
72
73 let local_var_status = local_var_resp.status();
74 let local_var_content_type = local_var_resp
75 .headers()
76 .get("content-type")
77 .and_then(|v| v.to_str().ok())
78 .unwrap_or("application/octet-stream");
79 let local_var_content_type = super::ContentType::from(local_var_content_type);
80 let local_var_content = local_var_resp.text().await?;
81
82 if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
83 match local_var_content_type {
84 ContentType::Json => serde_json::from_str(&local_var_content).map_err(Error::from),
85 ContentType::Text => {
86 return Err(Error::from(serde_json::Error::custom(
87 "Received `text/plain` content type response that cannot be converted to `models::SyncResponseModel`",
88 )));
89 }
90 ContentType::Unsupported(local_var_unknown_type) => {
91 return Err(Error::from(serde_json::Error::custom(format!(
92 "Received `{local_var_unknown_type}` content type response that cannot be converted to `models::SyncResponseModel`"
93 ))));
94 }
95 }
96 } else {
97 let local_var_entity: Option<GetError> = serde_json::from_str(&local_var_content).ok();
98 let local_var_error = ResponseContent {
99 status: local_var_status,
100 content: local_var_content,
101 entity: local_var_entity,
102 };
103 Err(Error::ResponseError(local_var_error))
104 }
105 }
106}
107
108#[derive(Debug, Clone, Serialize, Deserialize)]
110#[serde(untagged)]
111pub enum GetError {
112 UnknownValue(serde_json::Value),
113}