bitwarden_api_api/apis/
stripe_api.rs

1/*
2 * Bitwarden Internal API
3 *
4 * No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
5 *
6 * The version of the OpenAPI document: latest
7 *
8 * Generated by: https://openapi-generator.tech
9 */
10
11use 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    /// POST /setup-intent/bank-account
30    async fn create_setup_intent_for_bank_account(
31        &self,
32    ) -> Result<(), Error<CreateSetupIntentForBankAccountError>>;
33
34    /// POST /setup-intent/card
35    async fn create_setup_intent_for_card(
36        &self,
37    ) -> Result<(), Error<CreateSetupIntentForCardError>>;
38
39    /// GET /tax/is-country-supported
40    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", &param_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/// struct for typed errors of method [`StripeApi::create_setup_intent_for_bank_account`]
180#[derive(Debug, Clone, Serialize, Deserialize)]
181#[serde(untagged)]
182pub enum CreateSetupIntentForBankAccountError {
183    UnknownValue(serde_json::Value),
184}
185/// struct for typed errors of method [`StripeApi::create_setup_intent_for_card`]
186#[derive(Debug, Clone, Serialize, Deserialize)]
187#[serde(untagged)]
188pub enum CreateSetupIntentForCardError {
189    UnknownValue(serde_json::Value),
190}
191/// struct for typed errors of method [`StripeApi::is_country_supported`]
192#[derive(Debug, Clone, Serialize, Deserialize)]
193#[serde(untagged)]
194pub enum IsCountrySupportedError {
195    UnknownValue(serde_json::Value),
196}