astrolab-smart-coffee-types 0.9.99999903

Types lib
Documentation
use actix_web::{HttpResponse, ResponseError};
use derive_more::Display;
use serde::{Deserialize, Serialize};
use validator::Validate;

#[derive(Serialize, Deserialize, Debug, Clone, Validate)]
pub struct UpdateFilterCollectionBody {
    pub id: String,
    pub names: Option<Vec<UpdateFilterCollectionNameBody>>,
    pub descriptions: Option<Vec<UpdateFilterCollectionDescriptionBody>>,
    pub categories: Option<Vec<CategoryIdBody>>,
    pub products: Option<Vec<ProductIdBody>>,
    pub max_items: Option<i32>,
    pub sorting: Option<String>,
    pub price_range: Option<FilterCollectionPriceRangeBody>,
    pub variants: Option<Vec<FilterCollectionVariantBody>>,
    pub options: Option<Vec<FilterCollectionOptionBody>>,
}

#[derive(Serialize, Deserialize, Debug, Clone)]
pub struct UpdateFilterCollectionNameBody {
    pub id: Option<String>,
    pub language_code: Option<String>,
    pub value: Option<String>,
}

#[derive(Serialize, Deserialize, Debug, Clone)]
pub struct UpdateFilterCollectionDescriptionBody {
    pub id: Option<String>,
    pub language_code: Option<String>,
    pub value: Option<String>,
}

#[derive(Serialize, Deserialize, Debug, Clone)]
pub struct CategoryIdBody {
    pub category: Option<String>,
}

#[derive(Serialize, Deserialize, Debug, Clone)]
pub struct ProductIdBody {
    pub product: Option<String>,
}

#[derive(Serialize, Deserialize, Debug, Clone)]
pub struct FilterCollectionPriceRangeBody {
    pub min: Option<f64>,
    pub max: Option<f64>,
}

#[derive(Serialize, Deserialize, Debug, Clone)]
pub struct FilterCollectionVariantBody {
    pub kind: Option<String>,
    pub value: Option<String>,
}

#[derive(Serialize, Deserialize, Debug, Clone)]
pub struct FilterCollectionOptionBody {
    pub option: Option<String>,
}

#[derive(Serialize, Deserialize, Debug, Clone)]
pub struct UpdateFilterCollectionResult {
    pub success: bool,
}

#[derive(Debug, Display)]
pub enum UpdateFilterCollectionError {
    #[display(fmt = "invalid_object_id")]
    InvalidObjectId,
    #[display(fmt = "filter_collection_not_found")]
    FilterCollectionNotFound,
    Default(String),
}

impl ResponseError for UpdateFilterCollectionError {
    fn error_response(&self) -> HttpResponse {
        match self {
            UpdateFilterCollectionError::InvalidObjectId => {
                HttpResponse::NotAcceptable().body("invalid_object_id")
            }
            UpdateFilterCollectionError::FilterCollectionNotFound => {
                HttpResponse::Conflict().body("filter_collection_not_found")
            }
            UpdateFilterCollectionError::Default(error) => HttpResponse::BadRequest().body(error),
        }
    }
}