use std::collections::HashMap;
use serde::{Deserialize, Serialize};
use serde_json::Value;
#[derive(Debug, Clone, Serialize)]
pub struct ParameterProperty {
#[serde(rename = "type")]
pub property_type: String,
pub description: String,
#[serde(skip_serializing_if = "Option::is_none")]
pub items: Option<Box<ParameterProperty>>,
#[serde(skip_serializing_if = "Option::is_none", rename = "enum")]
pub enum_list: Option<Vec<String>>,
}
#[derive(Debug, Clone, Serialize)]
pub struct ParametersSchema {
#[serde(rename = "type")]
pub schema_type: String,
pub properties: HashMap<String, ParameterProperty>,
pub required: Vec<String>,
}
#[derive(Debug, Clone, Serialize)]
pub struct FunctionTool {
pub name: String,
pub description: String,
pub parameters: Value,
}
#[derive(Debug, Clone, Deserialize, Serialize, PartialEq)]
pub struct StructuredOutputFormat {
pub name: String,
pub description: Option<String>,
pub schema: Option<Value>,
pub strict: Option<bool>,
}
#[derive(Debug, Clone, Serialize)]
pub struct Tool {
#[serde(rename = "type")]
pub tool_type: String,
pub function: FunctionTool,
#[serde(skip_serializing_if = "Option::is_none")]
pub cache_control: Option<Value>,
}
#[derive(Debug, Clone, Default)]
pub enum ToolChoice {
Any,
#[default]
Auto,
Tool(String),
None,
}
impl Serialize for ToolChoice {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: serde::Serializer,
{
match self {
ToolChoice::Any => serializer.serialize_str("required"),
ToolChoice::Auto => serializer.serialize_str("auto"),
ToolChoice::None => serializer.serialize_str("none"),
ToolChoice::Tool(name) => serialize_tool_choice(name, serializer),
}
}
}
fn serialize_tool_choice<S>(name: &str, serializer: S) -> Result<S::Ok, S::Error>
where
S: serde::Serializer,
{
use serde::ser::SerializeMap;
let mut map = serializer.serialize_map(Some(2))?;
map.serialize_entry("type", "function")?;
let mut function_obj = HashMap::new();
function_obj.insert("name", name);
map.serialize_entry("function", &function_obj)?;
map.end()
}