use std::convert::TryFrom;
use url::Url;
use crate::{
rest_api::resources::{error::ErrorResponse, paging::v1::Paging},
schema::store::{SchemaStore, SchemaStoreError},
};
use super::payloads::{SchemaListSlice, SchemaSlice};
pub fn list_schemas<'a>(
url: Url,
store: Box<dyn SchemaStore + 'a>,
service_id: Option<&str>,
offset: u64,
limit: u16,
) -> Result<SchemaListSlice, ErrorResponse> {
let offset = i64::try_from(offset).unwrap_or(i64::MAX);
let limit = i64::try_from(limit).unwrap_or(10);
let schema_list = store
.list_schemas(service_id, offset, limit)
.map_err(|err| match err {
SchemaStoreError::InternalError(err) => ErrorResponse::internal_error(Box::new(err)),
SchemaStoreError::ConstraintViolationError(err) => {
ErrorResponse::new(400, &format!("{}", err))
}
SchemaStoreError::ResourceTemporarilyUnavailableError(_) => {
ErrorResponse::new(503, "Service Unavailable")
}
SchemaStoreError::NotFoundError(_) => ErrorResponse::new(404, "Resource not found"),
})?;
let data = schema_list
.data
.into_iter()
.map(SchemaSlice::from)
.collect();
let paging = Paging::new(url, schema_list.paging, service_id);
Ok(SchemaListSlice { data, paging })
}
pub fn get_schema<'a>(
store: Box<dyn SchemaStore + 'a>,
name: String,
service_id: Option<&str>,
) -> Result<SchemaSlice, ErrorResponse> {
let schema = store
.get_schema(&name, service_id)
.map_err(|err| match err {
SchemaStoreError::InternalError(err) => ErrorResponse::internal_error(Box::new(err)),
SchemaStoreError::ConstraintViolationError(err) => {
ErrorResponse::new(400, &format!("{}", err))
}
SchemaStoreError::ResourceTemporarilyUnavailableError(_) => {
ErrorResponse::new(503, "Service Unavailable")
}
SchemaStoreError::NotFoundError(_) => {
ErrorResponse::new(404, &format!("Schema {} not found", name))
}
})?;
Ok(SchemaSlice::from(schema.ok_or_else(|| {
ErrorResponse::new(404, &format!("Schema {} not found", name))
})?))
}