#![allow(unused_imports, dead_code, non_camel_case_types, unused_variables, clippy::all)]
use super::super::context::{LoadContext, SaveContext};
use super::anthropic_usage::AnthropicUsage;
#[derive(Debug, Clone, Default)]
pub struct AnthropicMessagesResponse {
pub id: String,
pub type: String,
pub role: String,
pub content: Vec<serde_json::Value>,
pub model: String,
pub stop_reason: String,
pub usage: AnthropicUsage,
}
impl AnthropicMessagesResponse {
pub fn new() -> Self {
Self::default()
}
pub fn from_json(json: &str, ctx: &LoadContext) -> Result<Self, serde_json::Error> {
let value: serde_json::Value = serde_json::from_str(json)?;
Ok(Self::load_from_value(&value, ctx))
}
pub fn from_yaml(yaml: &str, ctx: &LoadContext) -> Result<Self, serde_yaml::Error> {
let value: serde_json::Value = serde_yaml::from_str(yaml)?;
Ok(Self::load_from_value(&value, ctx))
}
pub fn load_from_value(value: &serde_json::Value, ctx: &LoadContext) -> Self {
let value = ctx.process_input(value.clone());
Self {
id: value.get("id").and_then(|v| v.as_str()).unwrap_or_default().to_string(),
type: value.get("type").and_then(|v| v.as_str()).unwrap_or_default().to_string(),
role: value.get("role").and_then(|v| v.as_str()).unwrap_or_default().to_string(),
content: value.get("content").and_then(|v| v.as_array()).map(|arr| arr.to_vec()).unwrap_or_default(),
model: value.get("model").and_then(|v| v.as_str()).unwrap_or_default().to_string(),
stop_reason: value.get("stop_reason").and_then(|v| v.as_str()).unwrap_or_default().to_string(),
usage: value.get("usage").filter(|v| v.is_object() || v.is_array() || v.is_string()).map(|v| AnthropicUsage::load_from_value(v, ctx)).unwrap_or_default(),
}
}
pub fn to_value(&self, ctx: &SaveContext) -> serde_json::Value {
let mut result = serde_json::Map::new();
if !self.id.is_empty() {
result.insert("id".to_string(), serde_json::Value::String(self.id.clone()));
}
if !self.type.is_empty() {
result.insert("type".to_string(), serde_json::Value::String(self.type.clone()));
}
if !self.role.is_empty() {
result.insert("role".to_string(), serde_json::Value::String(self.role.clone()));
}
if !self.content.is_empty() {
result.insert("content".to_string(), serde_json::to_value(&self.content).unwrap_or(serde_json::Value::Null));
}
if !self.model.is_empty() {
result.insert("model".to_string(), serde_json::Value::String(self.model.clone()));
}
if !self.stop_reason.is_empty() {
result.insert("stop_reason".to_string(), serde_json::Value::String(self.stop_reason.clone()));
}
{
let nested = self.usage.to_value(ctx);
if !nested.is_null() {
result.insert("usage".to_string(), nested);
}
}
ctx.process_dict(serde_json::Value::Object(result))
}
pub fn to_json(&self, ctx: &SaveContext) -> Result<String, serde_json::Error> {
serde_json::to_string_pretty(&self.to_value(ctx))
}
pub fn to_yaml(&self, ctx: &SaveContext) -> Result<String, serde_yaml::Error> {
serde_yaml::to_string(&self.to_value(ctx))
}
}