btcpay_client/apis/
apps_api.rs1use reqwest;
13
14use crate::apis::ResponseContent;
15use super::{Error, configuration};
16
17
18#[derive(Debug, Clone, Serialize, Deserialize)]
20#[serde(untagged)]
21pub enum AppsCreatePointOfSaleAppError {
22 Status422(Vec<crate::models::ValidationProblemDetailsInner>),
23 UnknownValue(serde_json::Value),
24}
25
26#[derive(Debug, Clone, Serialize, Deserialize)]
28#[serde(untagged)]
29pub enum AppsDeletePointOfSaleAppError {
30 Status404(),
31 UnknownValue(serde_json::Value),
32}
33
34#[derive(Debug, Clone, Serialize, Deserialize)]
36#[serde(untagged)]
37pub enum AppsGetPointOfSaleAppError {
38 Status404(),
39 UnknownValue(serde_json::Value),
40}
41
42
43pub async fn apps_create_point_of_sale_app(configuration: &configuration::Configuration, store_id: &str, apps_create_point_of_sale_app_request: Option<crate::models::AppsCreatePointOfSaleAppRequest>) -> Result<crate::models::PointOfSaleAppData, Error<AppsCreatePointOfSaleAppError>> {
45 let local_var_configuration = configuration;
46
47 let local_var_client = &local_var_configuration.client;
48
49 let local_var_uri_str = format!("{}/api/v1/stores/{storeId}/apps/pos", local_var_configuration.base_path, storeId=crate::apis::urlencode(store_id));
50 let mut local_var_req_builder = local_var_client.request(reqwest::Method::POST, local_var_uri_str.as_str());
51
52 if let Some(ref local_var_user_agent) = local_var_configuration.user_agent {
53 local_var_req_builder = local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
54 }
55 if let Some(ref local_var_apikey) = local_var_configuration.api_key {
56 let local_var_key = local_var_apikey.key.clone();
57 let local_var_value = match local_var_apikey.prefix {
58 Some(ref local_var_prefix) => format!("{} {}", local_var_prefix, local_var_key),
59 None => local_var_key,
60 };
61 local_var_req_builder = local_var_req_builder.header("Authorization", local_var_value);
62 };
63 if let Some(ref local_var_auth_conf) = local_var_configuration.basic_auth {
64 local_var_req_builder = local_var_req_builder.basic_auth(local_var_auth_conf.0.to_owned(), local_var_auth_conf.1.to_owned());
65 };
66 local_var_req_builder = local_var_req_builder.json(&apps_create_point_of_sale_app_request);
67
68 let local_var_req = local_var_req_builder.build()?;
69 let local_var_resp = local_var_client.execute(local_var_req).await?;
70
71 let local_var_status = local_var_resp.status();
72 let local_var_content = local_var_resp.text().await?;
73
74 if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
75 serde_json::from_str(&local_var_content).map_err(Error::from)
76 } else {
77 let local_var_entity: Option<AppsCreatePointOfSaleAppError> = serde_json::from_str(&local_var_content).ok();
78 let local_var_error = ResponseContent { status: local_var_status, content: local_var_content, entity: local_var_entity };
79 Err(Error::ResponseError(local_var_error))
80 }
81}
82
83pub async fn apps_delete_point_of_sale_app(configuration: &configuration::Configuration, app_id: &str) -> Result<(), Error<AppsDeletePointOfSaleAppError>> {
85 let local_var_configuration = configuration;
86
87 let local_var_client = &local_var_configuration.client;
88
89 let local_var_uri_str = format!("{}/api/v1/apps/{appId}", local_var_configuration.base_path, appId=crate::apis::urlencode(app_id));
90 let mut local_var_req_builder = local_var_client.request(reqwest::Method::DELETE, local_var_uri_str.as_str());
91
92 if let Some(ref local_var_user_agent) = local_var_configuration.user_agent {
93 local_var_req_builder = local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
94 }
95 if let Some(ref local_var_apikey) = local_var_configuration.api_key {
96 let local_var_key = local_var_apikey.key.clone();
97 let local_var_value = match local_var_apikey.prefix {
98 Some(ref local_var_prefix) => format!("{} {}", local_var_prefix, local_var_key),
99 None => local_var_key,
100 };
101 local_var_req_builder = local_var_req_builder.header("Authorization", local_var_value);
102 };
103 if let Some(ref local_var_auth_conf) = local_var_configuration.basic_auth {
104 local_var_req_builder = local_var_req_builder.basic_auth(local_var_auth_conf.0.to_owned(), local_var_auth_conf.1.to_owned());
105 };
106
107 let local_var_req = local_var_req_builder.build()?;
108 let local_var_resp = local_var_client.execute(local_var_req).await?;
109
110 let local_var_status = local_var_resp.status();
111 let local_var_content = local_var_resp.text().await?;
112
113 if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
114 Ok(())
115 } else {
116 let local_var_entity: Option<AppsDeletePointOfSaleAppError> = serde_json::from_str(&local_var_content).ok();
117 let local_var_error = ResponseContent { status: local_var_status, content: local_var_content, entity: local_var_entity };
118 Err(Error::ResponseError(local_var_error))
119 }
120}
121
122pub async fn apps_get_point_of_sale_app(configuration: &configuration::Configuration, app_id: &str) -> Result<crate::models::BasicAppData, Error<AppsGetPointOfSaleAppError>> {
124 let local_var_configuration = configuration;
125
126 let local_var_client = &local_var_configuration.client;
127
128 let local_var_uri_str = format!("{}/api/v1/apps/{appId}", local_var_configuration.base_path, appId=crate::apis::urlencode(app_id));
129 let mut local_var_req_builder = local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());
130
131 if let Some(ref local_var_user_agent) = local_var_configuration.user_agent {
132 local_var_req_builder = local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
133 }
134 if let Some(ref local_var_apikey) = local_var_configuration.api_key {
135 let local_var_key = local_var_apikey.key.clone();
136 let local_var_value = match local_var_apikey.prefix {
137 Some(ref local_var_prefix) => format!("{} {}", local_var_prefix, local_var_key),
138 None => local_var_key,
139 };
140 local_var_req_builder = local_var_req_builder.header("Authorization", local_var_value);
141 };
142 if let Some(ref local_var_auth_conf) = local_var_configuration.basic_auth {
143 local_var_req_builder = local_var_req_builder.basic_auth(local_var_auth_conf.0.to_owned(), local_var_auth_conf.1.to_owned());
144 };
145
146 let local_var_req = local_var_req_builder.build()?;
147 let local_var_resp = local_var_client.execute(local_var_req).await?;
148
149 let local_var_status = local_var_resp.status();
150 let local_var_content = local_var_resp.text().await?;
151
152 if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
153 serde_json::from_str(&local_var_content).map_err(Error::from)
154 } else {
155 let local_var_entity: Option<AppsGetPointOfSaleAppError> = serde_json::from_str(&local_var_content).ok();
156 let local_var_error = ResponseContent { status: local_var_status, content: local_var_content, entity: local_var_entity };
157 Err(Error::ResponseError(local_var_error))
158 }
159}
160