amazon_spapi/apis/
sellingpartners_api.rs

1/*
2 * Selling Partner API for Replenishment
3 *
4 * The Selling Partner API for Replenishment (Replenishment API) provides programmatic access to replenishment program metrics and offers. These programs provide recurring delivery of any replenishable item at a frequency chosen by the customer.  The Replenishment API is available worldwide wherever Amazon Subscribe & Save is available or is supported. The API is available to vendors and FBA selling partners.
5 *
6 * The version of the OpenAPI document: 2022-11-07
7 * 
8 * Generated by: https://openapi-generator.tech
9 */
10
11
12use reqwest;
13use serde::{Deserialize, Serialize, de::Error as _};
14use crate::{apis::ResponseContent, models};
15use super::{Error, configuration, ContentType};
16
17
18/// struct for typed errors of method [`get_selling_partner_metrics`]
19#[derive(Debug, Clone, Serialize, Deserialize)]
20#[serde(untagged)]
21pub enum GetSellingPartnerMetricsError {
22    Status400(models::replenishment_2022_11_07::ErrorList),
23    Status401(models::replenishment_2022_11_07::ErrorList),
24    Status403(models::replenishment_2022_11_07::ErrorList),
25    Status404(models::replenishment_2022_11_07::ErrorList),
26    Status413(models::replenishment_2022_11_07::ErrorList),
27    Status415(models::replenishment_2022_11_07::ErrorList),
28    Status429(models::replenishment_2022_11_07::ErrorList),
29    Status500(models::replenishment_2022_11_07::ErrorList),
30    Status503(models::replenishment_2022_11_07::ErrorList),
31    UnknownValue(serde_json::Value),
32}
33
34
35/// Returns aggregated replenishment program metrics for a selling partner.   **Usage Plan:**  | Rate (requests per second) | Burst | | ---- | ---- | | 1 | 1 |  The `x-amzn-RateLimit-Limit` response header returns the usage plan rate limits that were applied to the requested operation, when available. The table above indicates the default rate and burst values for this operation. Selling partners whose business demands require higher throughput may see higher rate and burst values than those shown here. For more information, see [Usage Plans and Rate Limits in the Selling Partner API](https://developer-docs.amazon.com/sp-api/docs/usage-plans-and-rate-limits-in-the-sp-api).
36pub async fn get_selling_partner_metrics(configuration: &configuration::Configuration, body: Option<models::replenishment_2022_11_07::GetSellingPartnerMetricsRequest>) -> Result<models::replenishment_2022_11_07::GetSellingPartnerMetricsResponse, Error<GetSellingPartnerMetricsError>> {
37    // add a prefix to parameters to efficiently prevent name collisions
38    let p_body = body;
39
40    let uri_str = format!("{}/replenishment/2022-11-07/sellingPartners/metrics/search", configuration.base_path);
41    let mut req_builder = configuration.client.request(reqwest::Method::POST, &uri_str);
42
43    if let Some(ref user_agent) = configuration.user_agent {
44        req_builder = req_builder.header(reqwest::header::USER_AGENT, user_agent.clone());
45    }
46    req_builder = req_builder.json(&p_body);
47
48    let req = req_builder.build()?;
49    let resp = configuration.client.execute(req).await?;
50
51    let status = resp.status();
52    let content_type = resp
53        .headers()
54        .get("content-type")
55        .and_then(|v| v.to_str().ok())
56        .unwrap_or("application/octet-stream");
57    let content_type = super::ContentType::from(content_type);
58
59    if !status.is_client_error() && !status.is_server_error() {
60        let content = resp.text().await?;
61        match content_type {
62            ContentType::Json => serde_json::from_str(&content).map_err(Error::from),
63            ContentType::Text => return Err(Error::from(serde_json::Error::custom("Received `text/plain` content type response that cannot be converted to `models::replenishment_2022_11_07::GetSellingPartnerMetricsResponse`"))),
64            ContentType::Unsupported(unknown_type) => return Err(Error::from(serde_json::Error::custom(format!("Received `{unknown_type}` content type response that cannot be converted to `models::replenishment_2022_11_07::GetSellingPartnerMetricsResponse`")))),
65        }
66    } else {
67        let content = resp.text().await?;
68        let entity: Option<GetSellingPartnerMetricsError> = serde_json::from_str(&content).ok();
69        Err(Error::ResponseError(ResponseContent { status, content, entity }))
70    }
71}
72