osdm-sys 0.1.0-alpha.2

Specifications for the OSDM API standard. The OSDM specification supports two modes of operation: Retailer Mode and Distributor Mode. The API works identically in both modes, except that in distributor mode the API also returns fare information. The following resources are key to get started: - [Processes](https://osdm.io/spec/processes/) - [Models](https://osdm.io/spec/models/) - [Getting started](https://osdm.io/spec/getting-started/)
Documentation
/*
 * UIC 90918-10 - OSDM
 *
 * Specifications for the OSDM API standard. The OSDM specification supports two modes of operation: Retailer Mode and Distributor Mode. The API works identically in both modes, except that in distributor mode the API also returns fare information.  The following resources are key to get started:    -  [Processes](https://osdm.io/spec/processes/)   -  [Models](https://osdm.io/spec/models/)   -  [Getting started](https://osdm.io/spec/getting-started/) 
 *
 * The version of the OpenAPI document: 3.7.0
 * Contact: osdm@uic.org
 * Generated by: https://openapi-generator.tech
 */


use reqwest;
use serde::{Deserialize, Serialize, de::Error as _};
use crate::{apis::ResponseContent, models};
use super::{Error, configuration, ContentType};


/// struct for typed errors of method [`get_availabilities_continuous_services`]
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum GetAvailabilitiesContinuousServicesError {
    Status400(models::Problem),
    Status401(models::Problem),
    Status403(models::Problem),
    Status404(models::Problem),
    Status415(models::Problem),
    Status500(models::Problem),
    Status501(models::Problem),
    Status503(models::Problem),
    DefaultResponse(models::Problem),
    UnknownValue(serde_json::Value),
}

/// struct for typed errors of method [`get_continuous_service_usage_id`]
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum GetContinuousServiceUsageIdError {
    Status400(models::Problem),
    Status401(models::Problem),
    Status403(models::Problem),
    Status404(models::Problem),
    Status415(models::Problem),
    Status500(models::Problem),
    Status501(models::Problem),
    Status503(models::Problem),
    DefaultResponse(models::Problem),
    UnknownValue(serde_json::Value),
}

/// struct for typed errors of method [`patch_continuous_service_usage_id`]
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(untagged)]
pub enum PatchContinuousServiceUsageIdError {
    Status400(models::Problem),
    Status401(models::Problem),
    Status403(models::Problem),
    Status404(models::Problem),
    Status409(models::Problem),
    Status415(models::Problem),
    Status500(models::Problem),
    Status501(models::Problem),
    Status503(models::Problem),
    DefaultResponse(models::Problem),
    UnknownValue(serde_json::Value),
}


/// Get availabilities of an on-demand services. 
pub async fn get_availabilities_continuous_services(configuration: &configuration::Configuration, context_id: &str, context_type: models::ContextType, resource_id: &str, resource_type: models::ResourceType, continuous_service_availability_scope: models::ContinuousServiceAvailabilityScope, requestor: Option<&str>, accept_language: Option<&str>, traceparent: Option<&str>, tracestate: Option<&str>) -> Result<models::ContinuousServicesAvailabilityResponse, Error<GetAvailabilitiesContinuousServicesError>> {
    // add a prefix to parameters to efficiently prevent name collisions
    let p_query_context_id = context_id;
    let p_query_context_type = context_type;
    let p_query_resource_id = resource_id;
    let p_query_resource_type = resource_type;
    let p_body_continuous_service_availability_scope = continuous_service_availability_scope;
    let p_header_requestor = requestor;
    let p_header_accept_language = accept_language;
    let p_header_traceparent = traceparent;
    let p_header_tracestate = tracestate;

    let uri_str = format!("{}/availabilities/on-demand-services", configuration.base_path);
    let mut req_builder = configuration.client.request(reqwest::Method::POST, &uri_str);

    req_builder = req_builder.query(&[("contextId", &p_query_context_id.to_string())]);
    req_builder = req_builder.query(&[("contextType", &p_query_context_type.to_string())]);
    req_builder = req_builder.query(&[("resourceId", &p_query_resource_id.to_string())]);
    req_builder = req_builder.query(&[("resourceType", &p_query_resource_type.to_string())]);
    if let Some(ref user_agent) = configuration.user_agent {
        req_builder = req_builder.header(reqwest::header::USER_AGENT, user_agent.clone());
    }
    if let Some(param_value) = p_header_requestor {
        req_builder = req_builder.header("Requestor", param_value.to_string());
    }
    if let Some(param_value) = p_header_accept_language {
        req_builder = req_builder.header("Accept-Language", param_value.to_string());
    }
    if let Some(param_value) = p_header_traceparent {
        req_builder = req_builder.header("traceparent", param_value.to_string());
    }
    if let Some(param_value) = p_header_tracestate {
        req_builder = req_builder.header("tracestate", param_value.to_string());
    }
    if let Some(ref token) = configuration.oauth_access_token {
        req_builder = req_builder.bearer_auth(token.to_owned());
    };
    req_builder = req_builder.json(&p_body_continuous_service_availability_scope);

    let req = req_builder.build()?;
    let resp = configuration.client.execute(req).await?;

    let status = resp.status();
    let content_type = resp
        .headers()
        .get("content-type")
        .and_then(|v| v.to_str().ok())
        .unwrap_or("application/octet-stream");
    let content_type = super::ContentType::from(content_type);

    if !status.is_client_error() && !status.is_server_error() {
        let content = resp.text().await?;
        match content_type {
            ContentType::Json => serde_json::from_str(&content).map_err(Error::from),
            ContentType::Text => return Err(Error::from(serde_json::Error::custom("Received `text/plain` content type response that cannot be converted to `models::ContinuousServicesAvailabilityResponse`"))),
            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::ContinuousServicesAvailabilityResponse`")))),
        }
    } else {
        let content = resp.text().await?;
        let entity: Option<GetAvailabilitiesContinuousServicesError> = serde_json::from_str(&content).ok();
        Err(Error::ResponseError(ResponseContent { status, content, entity }))
    }
}

pub async fn get_continuous_service_usage_id(configuration: &configuration::Configuration, fulfillment_id: &str, continuous_service_usage_id: &str, requestor: Option<&str>, accept_language: Option<&str>, traceparent: Option<&str>, tracestate: Option<&str>, x_accept_namespace: Option<&str>) -> Result<models::ContinuousServiceUsage, Error<GetContinuousServiceUsageIdError>> {
    // add a prefix to parameters to efficiently prevent name collisions
    let p_path_fulfillment_id = fulfillment_id;
    let p_path_continuous_service_usage_id = continuous_service_usage_id;
    let p_header_requestor = requestor;
    let p_header_accept_language = accept_language;
    let p_header_traceparent = traceparent;
    let p_header_tracestate = tracestate;
    let p_header_x_accept_namespace = x_accept_namespace;

    let uri_str = format!("{}/fulfillments/{fulfillmentId}/continuous-service-usage/{continuousServiceUsageId}", configuration.base_path, fulfillmentId=crate::apis::urlencode(p_path_fulfillment_id), continuousServiceUsageId=crate::apis::urlencode(p_path_continuous_service_usage_id));
    let mut req_builder = configuration.client.request(reqwest::Method::GET, &uri_str);

    if let Some(ref user_agent) = configuration.user_agent {
        req_builder = req_builder.header(reqwest::header::USER_AGENT, user_agent.clone());
    }
    if let Some(param_value) = p_header_requestor {
        req_builder = req_builder.header("Requestor", param_value.to_string());
    }
    if let Some(param_value) = p_header_accept_language {
        req_builder = req_builder.header("Accept-Language", param_value.to_string());
    }
    if let Some(param_value) = p_header_traceparent {
        req_builder = req_builder.header("traceparent", param_value.to_string());
    }
    if let Some(param_value) = p_header_tracestate {
        req_builder = req_builder.header("tracestate", param_value.to_string());
    }
    if let Some(param_value) = p_header_x_accept_namespace {
        req_builder = req_builder.header("x-accept-namespace", param_value.to_string());
    }
    if let Some(ref token) = configuration.oauth_access_token {
        req_builder = req_builder.bearer_auth(token.to_owned());
    };

    let req = req_builder.build()?;
    let resp = configuration.client.execute(req).await?;

    let status = resp.status();
    let content_type = resp
        .headers()
        .get("content-type")
        .and_then(|v| v.to_str().ok())
        .unwrap_or("application/octet-stream");
    let content_type = super::ContentType::from(content_type);

    if !status.is_client_error() && !status.is_server_error() {
        let content = resp.text().await?;
        match content_type {
            ContentType::Json => serde_json::from_str(&content).map_err(Error::from),
            ContentType::Text => return Err(Error::from(serde_json::Error::custom("Received `text/plain` content type response that cannot be converted to `models::ContinuousServiceUsage`"))),
            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::ContinuousServiceUsage`")))),
        }
    } else {
        let content = resp.text().await?;
        let entity: Option<GetContinuousServiceUsageIdError> = serde_json::from_str(&content).ok();
        Err(Error::ResponseError(ResponseContent { status, content, entity }))
    }
}

/// start or end the usage of a continuous service of an demand vehicle 
pub async fn patch_continuous_service_usage_id(configuration: &configuration::Configuration, fulfillment_id: &str, continuous_service_usage_id: &str, continuous_service_usage_patch_request: models::ContinuousServiceUsagePatchRequest, requestor: Option<&str>, accept_language: Option<&str>, traceparent: Option<&str>, tracestate: Option<&str>, idempotency_key: Option<&str>, x_accept_namespace: Option<&str>) -> Result<models::ContinuousServiceUsage, Error<PatchContinuousServiceUsageIdError>> {
    // add a prefix to parameters to efficiently prevent name collisions
    let p_path_fulfillment_id = fulfillment_id;
    let p_path_continuous_service_usage_id = continuous_service_usage_id;
    let p_body_continuous_service_usage_patch_request = continuous_service_usage_patch_request;
    let p_header_requestor = requestor;
    let p_header_accept_language = accept_language;
    let p_header_traceparent = traceparent;
    let p_header_tracestate = tracestate;
    let p_header_idempotency_key = idempotency_key;
    let p_header_x_accept_namespace = x_accept_namespace;

    let uri_str = format!("{}/fulfillments/{fulfillmentId}/continuous-service-usage/{continuousServiceUsageId}", configuration.base_path, fulfillmentId=crate::apis::urlencode(p_path_fulfillment_id), continuousServiceUsageId=crate::apis::urlencode(p_path_continuous_service_usage_id));
    let mut req_builder = configuration.client.request(reqwest::Method::PATCH, &uri_str);

    if let Some(ref user_agent) = configuration.user_agent {
        req_builder = req_builder.header(reqwest::header::USER_AGENT, user_agent.clone());
    }
    if let Some(param_value) = p_header_requestor {
        req_builder = req_builder.header("Requestor", param_value.to_string());
    }
    if let Some(param_value) = p_header_accept_language {
        req_builder = req_builder.header("Accept-Language", param_value.to_string());
    }
    if let Some(param_value) = p_header_traceparent {
        req_builder = req_builder.header("traceparent", param_value.to_string());
    }
    if let Some(param_value) = p_header_tracestate {
        req_builder = req_builder.header("tracestate", param_value.to_string());
    }
    if let Some(param_value) = p_header_idempotency_key {
        req_builder = req_builder.header("Idempotency-Key", param_value.to_string());
    }
    if let Some(param_value) = p_header_x_accept_namespace {
        req_builder = req_builder.header("x-accept-namespace", param_value.to_string());
    }
    if let Some(ref token) = configuration.oauth_access_token {
        req_builder = req_builder.bearer_auth(token.to_owned());
    };
    req_builder = req_builder.json(&p_body_continuous_service_usage_patch_request);

    let req = req_builder.build()?;
    let resp = configuration.client.execute(req).await?;

    let status = resp.status();
    let content_type = resp
        .headers()
        .get("content-type")
        .and_then(|v| v.to_str().ok())
        .unwrap_or("application/octet-stream");
    let content_type = super::ContentType::from(content_type);

    if !status.is_client_error() && !status.is_server_error() {
        let content = resp.text().await?;
        match content_type {
            ContentType::Json => serde_json::from_str(&content).map_err(Error::from),
            ContentType::Text => return Err(Error::from(serde_json::Error::custom("Received `text/plain` content type response that cannot be converted to `models::ContinuousServiceUsage`"))),
            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::ContinuousServiceUsage`")))),
        }
    } else {
        let content = resp.text().await?;
        let entity: Option<PatchContinuousServiceUsageIdError> = serde_json::from_str(&content).ok();
        Err(Error::ResponseError(ResponseContent { status, content, entity }))
    }
}