Skip to main content

bitwarden_api_identity/apis/
sso_api.rs

1/*
2 * Bitwarden Identity
3 *
4 * No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
5 *
6 * The version of the OpenAPI document: v1
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 SsoApi: Send + Sync {
29    /// GET /sso/ExternalCallback
30    async fn external_callback(&self) -> Result<(), Error>;
31
32    /// GET /sso/ExternalChallenge
33    async fn external_challenge<'a>(
34        &self,
35        domain_hint: Option<&'a str>,
36        return_url: Option<&'a str>,
37        user_identifier: Option<&'a str>,
38        sso_token: Option<&'a str>,
39    ) -> Result<(), Error>;
40
41    /// GET /sso/Login
42    async fn login<'a>(&self, return_url: Option<&'a str>) -> Result<(), Error>;
43
44    /// GET /sso/PreValidate
45    async fn pre_validate<'a>(&self, domain_hint: Option<&'a str>) -> Result<(), Error>;
46}
47
48pub struct SsoApiClient {
49    configuration: Arc<configuration::Configuration>,
50}
51
52impl SsoApiClient {
53    pub fn new(configuration: Arc<configuration::Configuration>) -> Self {
54        Self { configuration }
55    }
56}
57
58#[cfg_attr(target_arch = "wasm32", async_trait(?Send))]
59#[cfg_attr(not(target_arch = "wasm32"), async_trait)]
60impl SsoApi for SsoApiClient {
61    async fn external_callback(&self) -> Result<(), Error> {
62        let local_var_configuration = &self.configuration;
63
64        let local_var_client = &local_var_configuration.client;
65
66        let local_var_uri_str =
67            format!("{}/sso/ExternalCallback", local_var_configuration.base_path);
68        let mut local_var_req_builder =
69            local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());
70
71        bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
72    }
73
74    async fn external_challenge<'a>(
75        &self,
76        domain_hint: Option<&'a str>,
77        return_url: Option<&'a str>,
78        user_identifier: Option<&'a str>,
79        sso_token: Option<&'a str>,
80    ) -> Result<(), Error> {
81        let local_var_configuration = &self.configuration;
82
83        let local_var_client = &local_var_configuration.client;
84
85        let local_var_uri_str = format!(
86            "{}/sso/ExternalChallenge",
87            local_var_configuration.base_path
88        );
89        let mut local_var_req_builder =
90            local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());
91
92        if let Some(ref param_value) = domain_hint {
93            local_var_req_builder =
94                local_var_req_builder.query(&[("domainHint", &param_value.to_string())]);
95        }
96        if let Some(ref param_value) = return_url {
97            local_var_req_builder =
98                local_var_req_builder.query(&[("returnUrl", &param_value.to_string())]);
99        }
100        if let Some(ref param_value) = user_identifier {
101            local_var_req_builder =
102                local_var_req_builder.query(&[("userIdentifier", &param_value.to_string())]);
103        }
104        if let Some(ref param_value) = sso_token {
105            local_var_req_builder =
106                local_var_req_builder.query(&[("ssoToken", &param_value.to_string())]);
107        }
108
109        bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
110    }
111
112    async fn login<'a>(&self, return_url: Option<&'a str>) -> Result<(), Error> {
113        let local_var_configuration = &self.configuration;
114
115        let local_var_client = &local_var_configuration.client;
116
117        let local_var_uri_str = format!("{}/sso/Login", local_var_configuration.base_path);
118        let mut local_var_req_builder =
119            local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());
120
121        if let Some(ref param_value) = return_url {
122            local_var_req_builder =
123                local_var_req_builder.query(&[("returnUrl", &param_value.to_string())]);
124        }
125
126        bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
127    }
128
129    async fn pre_validate<'a>(&self, domain_hint: Option<&'a str>) -> Result<(), Error> {
130        let local_var_configuration = &self.configuration;
131
132        let local_var_client = &local_var_configuration.client;
133
134        let local_var_uri_str = format!("{}/sso/PreValidate", local_var_configuration.base_path);
135        let mut local_var_req_builder =
136            local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());
137
138        if let Some(ref param_value) = domain_hint {
139            local_var_req_builder =
140                local_var_req_builder.query(&[("domainHint", &param_value.to_string())]);
141        }
142
143        bitwarden_api_base::process_with_empty_response(local_var_req_builder).await
144    }
145}