use mogh_resolver::Resolve;
use serde::{Deserialize, Serialize};
use typeshare::typeshare;
use crate::entities::{
MongoDocument,
update::{Update, UpdateListItem},
};
use super::KomodoReadRequest;
#[cfg(feature = "utoipa")]
#[utoipa::path(
post,
path = "/GetUpdate",
description = "Get all data for the target update.",
request_body(content = GetUpdate),
responses(
(status = 200, description = "The update", body = GetUpdateResponse),
),
)]
pub fn get_update() {}
#[typeshare]
#[derive(Serialize, Deserialize, Debug, Clone, Resolve)]
#[cfg_attr(feature = "utoipa", derive(utoipa::ToSchema))]
#[empty_traits(KomodoReadRequest)]
#[response(GetUpdateResponse)]
#[error(mogh_error::Error)]
pub struct GetUpdate {
pub id: String,
}
#[typeshare]
pub type GetUpdateResponse = Update;
#[cfg(feature = "utoipa")]
#[utoipa::path(
post,
path = "/ListUpdates",
description = "Paginated endpoint for updates matching optional query.",
request_body(content = ListUpdates),
responses(
(status = 200, description = "The paginated list of updates", body = ListUpdatesResponse),
),
)]
pub fn list_updates() {}
#[typeshare]
#[derive(Serialize, Deserialize, Debug, Clone, Resolve)]
#[cfg_attr(feature = "utoipa", derive(utoipa::ToSchema))]
#[empty_traits(KomodoReadRequest)]
#[response(ListUpdatesResponse)]
#[error(mogh_error::Error)]
pub struct ListUpdates {
#[cfg_attr(feature = "utoipa", schema(value_type = Option<serde_json::Value>))]
pub query: Option<MongoDocument>,
#[serde(default)]
pub page: u32,
}
#[typeshare]
#[derive(Serialize, Deserialize, Debug, Clone)]
#[cfg_attr(feature = "utoipa", derive(utoipa::ToSchema))]
pub struct ListUpdatesResponse {
pub updates: Vec<UpdateListItem>,
pub next_page: Option<u32>,
}