bitwarden_api_api/apis/
request_sm_access_api.rs1use reqwest;
12use serde::{de::Error as _, Deserialize, Serialize};
13
14use super::{configuration, ContentType, Error};
15use crate::{apis::ResponseContent, models};
16
17#[derive(Debug, Clone, Serialize, Deserialize)]
19#[serde(untagged)]
20pub enum RequestAccessRequestSmAccessPostError {
21 UnknownValue(serde_json::Value),
22}
23
24pub async fn request_access_request_sm_access_post(
25 configuration: &configuration::Configuration,
26 request_sm_access_request_model: Option<models::RequestSmAccessRequestModel>,
27) -> Result<(), Error<RequestAccessRequestSmAccessPostError>> {
28 let p_request_sm_access_request_model = request_sm_access_request_model;
30
31 let uri_str = format!(
32 "{}/request-access/request-sm-access",
33 configuration.base_path
34 );
35 let mut req_builder = configuration
36 .client
37 .request(reqwest::Method::POST, &uri_str);
38
39 if let Some(ref user_agent) = configuration.user_agent {
40 req_builder = req_builder.header(reqwest::header::USER_AGENT, user_agent.clone());
41 }
42 if let Some(ref token) = configuration.oauth_access_token {
43 req_builder = req_builder.bearer_auth(token.to_owned());
44 };
45 req_builder = req_builder.json(&p_request_sm_access_request_model);
46
47 let req = req_builder.build()?;
48 let resp = configuration.client.execute(req).await?;
49
50 let status = resp.status();
51
52 if !status.is_client_error() && !status.is_server_error() {
53 Ok(())
54 } else {
55 let content = resp.text().await?;
56 let entity: Option<RequestAccessRequestSmAccessPostError> =
57 serde_json::from_str(&content).ok();
58 Err(Error::ResponseError(ResponseContent {
59 status,
60 content,
61 entity,
62 }))
63 }
64}