use crate::mcp::support::{is_empty_object, serialize_bool_as_empty_object};
use serde::de::{MapAccess, Visitor};
use serde::ser::SerializeMap;
use serde::{Deserialize, Deserializer, Serialize, Serializer};
use serde_json::Value;
use serde_with::skip_serializing_none; use std::fmt;
#[derive(Debug, Clone, Default, PartialEq)]
pub struct ServerCapabilities {
pub experimental: Option<Value>,
pub logging: bool,
pub completions: bool,
pub prompts: Option<ServerPromptsCapabilities>,
pub resources: Option<ServerResourcesCapabilities>,
pub tools: Option<ServerToolsCapabilities>,
}
#[skip_serializing_none]
#[derive(Debug, Clone, Default, PartialEq, Eq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct ServerPromptsCapabilities {
pub list_changed: Option<bool>,
}
#[skip_serializing_none]
#[derive(Debug, Clone, Default, PartialEq, Eq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct ServerResourcesCapabilities {
pub subscribe: Option<bool>,
pub list_changed: Option<bool>,
}
#[skip_serializing_none]
#[derive(Debug, Clone, Default, PartialEq, Eq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct ServerToolsCapabilities {
pub list_changed: Option<bool>,
}
impl Serialize for ServerCapabilities {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: Serializer,
{
let mut map = serializer.serialize_map(None)?;
if let Some(experimental) = &self.experimental {
map.serialize_entry("experimental", experimental)?;
}
serialize_bool_as_empty_object::<S>(&mut map, "logging", self.logging)?;
serialize_bool_as_empty_object::<S>(&mut map, "completions", self.completions)?;
if let Some(prompts) = &self.prompts {
map.serialize_entry("prompts", prompts)?;
}
if let Some(resources) = &self.resources {
map.serialize_entry("resources", resources)?;
}
if let Some(tools) = &self.tools {
map.serialize_entry("tools", tools)?;
}
map.end()
}
}
impl<'de> Deserialize<'de> for ServerCapabilities {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where
D: Deserializer<'de>,
{
struct ServerCapabilitiesVisitor;
impl<'de> Visitor<'de> for ServerCapabilitiesVisitor {
type Value = ServerCapabilities;
fn expecting(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
formatter.write_str("a map representing ServerCapabilities")
}
fn visit_map<M>(self, mut map: M) -> Result<Self::Value, M::Error>
where
M: MapAccess<'de>,
{
let mut experimental: Option<Value> = None;
let mut logging: bool = false; let mut completions: bool = false; let mut prompts: Option<ServerPromptsCapabilities> = None;
let mut resources: Option<ServerResourcesCapabilities> = None;
let mut tools: Option<ServerToolsCapabilities> = None;
while let Some(key) = map.next_key::<String>()? {
match key.as_str() {
"experimental" => {
experimental = Some(map.next_value()?);
}
"logging" => {
let logging_value: Value = map.next_value()?;
if is_empty_object(&logging_value) {
logging = true;
}
}
"completions" => {
let completions_value: Value = map.next_value()?;
if is_empty_object(&completions_value) {
completions = true;
}
}
"prompts" => {
prompts = Some(map.next_value()?);
}
"resources" => {
resources = Some(map.next_value()?);
}
"tools" => {
tools = Some(map.next_value()?);
}
_ => {
let _ = map.next_value::<Value>()?;
}
}
}
Ok(ServerCapabilities {
experimental,
logging,
completions,
prompts,
resources,
tools,
})
}
}
deserializer.deserialize_map(ServerCapabilitiesVisitor)
}
}