btcpay_client/apis/
store_payment_methods_api.rs

1/*
2 * BTCPay Greenfield API
3 *
4 * A full API to use your BTCPay Server
5 *
6 * The version of the OpenAPI document: v1
7 * 
8 * Generated by: https://openapi-generator.tech
9 */
10
11
12use reqwest;
13
14use crate::apis::ResponseContent;
15use super::{Error, configuration};
16
17
18/// struct for typed errors of method [`store_payment_methods_get_store_payment_methods`]
19#[derive(Debug, Clone, Serialize, Deserialize)]
20#[serde(untagged)]
21pub enum StorePaymentMethodsGetStorePaymentMethodsError {
22    UnknownValue(serde_json::Value),
23}
24
25
26/// View information about the stores' configured payment methods
27pub async fn store_payment_methods_get_store_payment_methods(configuration: &configuration::Configuration, store_id: &str, enabled: Option<bool>) -> Result<Vec<crate::models::GenericPaymentMethodData>, Error<StorePaymentMethodsGetStorePaymentMethodsError>> {
28    let local_var_configuration = configuration;
29
30    let local_var_client = &local_var_configuration.client;
31
32    let local_var_uri_str = format!("{}/api/v1/stores/{storeId}/payment-methods", local_var_configuration.base_path, storeId=crate::apis::urlencode(store_id));
33    let mut local_var_req_builder = local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());
34
35    if let Some(ref local_var_str) = enabled {
36        local_var_req_builder = local_var_req_builder.query(&[("enabled", &local_var_str.to_string())]);
37    }
38    if let Some(ref local_var_user_agent) = local_var_configuration.user_agent {
39        local_var_req_builder = local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
40    }
41    if let Some(ref local_var_apikey) = local_var_configuration.api_key {
42        let local_var_key = local_var_apikey.key.clone();
43        let local_var_value = match local_var_apikey.prefix {
44            Some(ref local_var_prefix) => format!("{} {}", local_var_prefix, local_var_key),
45            None => local_var_key,
46        };
47        local_var_req_builder = local_var_req_builder.header("Authorization", local_var_value);
48    };
49    if let Some(ref local_var_auth_conf) = local_var_configuration.basic_auth {
50        local_var_req_builder = local_var_req_builder.basic_auth(local_var_auth_conf.0.to_owned(), local_var_auth_conf.1.to_owned());
51    };
52
53    let local_var_req = local_var_req_builder.build()?;
54    let local_var_resp = local_var_client.execute(local_var_req).await?;
55
56    let local_var_status = local_var_resp.status();
57    let local_var_content = local_var_resp.text().await?;
58
59    if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
60        serde_json::from_str(&local_var_content).map_err(Error::from)
61    } else {
62        let local_var_entity: Option<StorePaymentMethodsGetStorePaymentMethodsError> = serde_json::from_str(&local_var_content).ok();
63        let local_var_error = ResponseContent { status: local_var_status, content: local_var_content, entity: local_var_entity };
64        Err(Error::ResponseError(local_var_error))
65    }
66}
67