bitwarden_api_api/apis/
stripe_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 StripeApi: Send + Sync {
29 async fn create_setup_intent_for_bank_account(
31 &self,
32 ) -> Result<(), Error<CreateSetupIntentForBankAccountError>>;
33
34 async fn create_setup_intent_for_card(
36 &self,
37 ) -> Result<(), Error<CreateSetupIntentForCardError>>;
38
39 async fn is_country_supported<'a>(
41 &self,
42 country: Option<&'a str>,
43 ) -> Result<(), Error<IsCountrySupportedError>>;
44}
45
46pub struct StripeApiClient {
47 configuration: Arc<configuration::Configuration>,
48}
49
50impl StripeApiClient {
51 pub fn new(configuration: Arc<configuration::Configuration>) -> Self {
52 Self { configuration }
53 }
54}
55
56#[cfg_attr(target_arch = "wasm32", async_trait(?Send))]
57#[cfg_attr(not(target_arch = "wasm32"), async_trait)]
58impl StripeApi for StripeApiClient {
59 async fn create_setup_intent_for_bank_account(
60 &self,
61 ) -> Result<(), Error<CreateSetupIntentForBankAccountError>> {
62 let local_var_configuration = &self.configuration;
63
64 let local_var_client = &local_var_configuration.client;
65
66 let local_var_uri_str = format!(
67 "{}/setup-intent/bank-account",
68 local_var_configuration.base_path
69 );
70 let mut local_var_req_builder =
71 local_var_client.request(reqwest::Method::POST, local_var_uri_str.as_str());
72
73 if let Some(ref local_var_token) = local_var_configuration.oauth_access_token {
74 local_var_req_builder = local_var_req_builder.bearer_auth(local_var_token.to_owned());
75 };
76 local_var_req_builder = local_var_req_builder.with_extension(AuthRequired::Bearer);
77
78 let local_var_req = local_var_req_builder.build()?;
79 let local_var_resp = local_var_client.execute(local_var_req).await?;
80
81 let local_var_status = local_var_resp.status();
82 let local_var_content = local_var_resp.text().await?;
83
84 if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
85 Ok(())
86 } else {
87 let local_var_entity: Option<CreateSetupIntentForBankAccountError> =
88 serde_json::from_str(&local_var_content).ok();
89 let local_var_error = ResponseContent {
90 status: local_var_status,
91 content: local_var_content,
92 entity: local_var_entity,
93 };
94 Err(Error::ResponseError(local_var_error))
95 }
96 }
97
98 async fn create_setup_intent_for_card(
99 &self,
100 ) -> Result<(), Error<CreateSetupIntentForCardError>> {
101 let local_var_configuration = &self.configuration;
102
103 let local_var_client = &local_var_configuration.client;
104
105 let local_var_uri_str = format!("{}/setup-intent/card", local_var_configuration.base_path);
106 let mut local_var_req_builder =
107 local_var_client.request(reqwest::Method::POST, local_var_uri_str.as_str());
108
109 if let Some(ref local_var_token) = local_var_configuration.oauth_access_token {
110 local_var_req_builder = local_var_req_builder.bearer_auth(local_var_token.to_owned());
111 };
112 local_var_req_builder = local_var_req_builder.with_extension(AuthRequired::Bearer);
113
114 let local_var_req = local_var_req_builder.build()?;
115 let local_var_resp = local_var_client.execute(local_var_req).await?;
116
117 let local_var_status = local_var_resp.status();
118 let local_var_content = local_var_resp.text().await?;
119
120 if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
121 Ok(())
122 } else {
123 let local_var_entity: Option<CreateSetupIntentForCardError> =
124 serde_json::from_str(&local_var_content).ok();
125 let local_var_error = ResponseContent {
126 status: local_var_status,
127 content: local_var_content,
128 entity: local_var_entity,
129 };
130 Err(Error::ResponseError(local_var_error))
131 }
132 }
133
134 async fn is_country_supported<'a>(
135 &self,
136 country: Option<&'a str>,
137 ) -> Result<(), Error<IsCountrySupportedError>> {
138 let local_var_configuration = &self.configuration;
139
140 let local_var_client = &local_var_configuration.client;
141
142 let local_var_uri_str = format!(
143 "{}/tax/is-country-supported",
144 local_var_configuration.base_path
145 );
146 let mut local_var_req_builder =
147 local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());
148
149 if let Some(ref param_value) = country {
150 local_var_req_builder =
151 local_var_req_builder.query(&[("country", ¶m_value.to_string())]);
152 }
153 if let Some(ref local_var_token) = local_var_configuration.oauth_access_token {
154 local_var_req_builder = local_var_req_builder.bearer_auth(local_var_token.to_owned());
155 };
156 local_var_req_builder = local_var_req_builder.with_extension(AuthRequired::Bearer);
157
158 let local_var_req = local_var_req_builder.build()?;
159 let local_var_resp = local_var_client.execute(local_var_req).await?;
160
161 let local_var_status = local_var_resp.status();
162 let local_var_content = local_var_resp.text().await?;
163
164 if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
165 Ok(())
166 } else {
167 let local_var_entity: Option<IsCountrySupportedError> =
168 serde_json::from_str(&local_var_content).ok();
169 let local_var_error = ResponseContent {
170 status: local_var_status,
171 content: local_var_content,
172 entity: local_var_entity,
173 };
174 Err(Error::ResponseError(local_var_error))
175 }
176 }
177}
178
179#[derive(Debug, Clone, Serialize, Deserialize)]
181#[serde(untagged)]
182pub enum CreateSetupIntentForBankAccountError {
183 UnknownValue(serde_json::Value),
184}
185#[derive(Debug, Clone, Serialize, Deserialize)]
187#[serde(untagged)]
188pub enum CreateSetupIntentForCardError {
189 UnknownValue(serde_json::Value),
190}
191#[derive(Debug, Clone, Serialize, Deserialize)]
193#[serde(untagged)]
194pub enum IsCountrySupportedError {
195 UnknownValue(serde_json::Value),
196}