// rocie - An enterprise grocery management system // // Copyright (C) 2026 Benedikt Peetz // SPDX-License-Identifier: GPL-3.0-or-later // // This file is part of Rocie. // // You should have received a copy of the License along with this program. // If not, see . /* * rocie-server * * An enterprise grocery management system - server * * The version of the OpenAPI document: 0.1.0 * Contact: benedikt.peetz@b-peetz.de * Generated by: https://openapi-generator.tech */ use super::{ContentType, Error, configuration}; use crate::{apis::ResponseContent, models}; use reqwest; use serde::{Deserialize, Serialize, de::Error as _}; /// struct for typed errors of method [`recipe_by_id`] #[derive(Debug, Clone, Serialize, Deserialize)] #[serde(untagged)] pub enum RecipeByIdError { Status404(), Status500(String), UnknownValue(serde_json::Value), } /// struct for typed errors of method [`recipes`] #[derive(Debug, Clone, Serialize, Deserialize)] #[serde(untagged)] pub enum RecipesError { Status500(String), UnknownValue(serde_json::Value), } pub async fn recipe_by_id( configuration: &configuration::Configuration, id: models::RecipeId, ) -> Result> { // add a prefix to parameters to efficiently prevent name collisions let p_id = id; let uri_str = format!( "{}/recipe/by-id/{id}", configuration.base_path, id = p_id.to_string() ); 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()); } 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::Recipe`", ))); } 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::Recipe`" )))); } } } else { let content = resp.text().await?; let entity: Option = serde_json::from_str(&content).ok(); Err(Error::ResponseError(ResponseContent { status, content, entity, })) } } pub async fn recipes( configuration: &configuration::Configuration, ) -> Result> { let uri_str = format!("{}/recipe/all", configuration.base_path); 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()); } 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::Recipe`", ))); } 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::Recipe`" )))); } } } else { let content = resp.text().await?; let entity: Option = serde_json::from_str(&content).ok(); Err(Error::ResponseError(ResponseContent { status, content, entity, })) } }