#![allow(
unused_imports,
dead_code,
non_camel_case_types,
unused_variables,
clippy::all
)]
use super::super::context::{LoadContext, SaveContext};
use super::super::model::token_usage::TokenUsage;
use super::trace_time::TraceTime;
#[derive(Debug, Clone, Default)]
pub struct TraceSpan {
pub name: String,
pub __time: TraceTime,
pub signature: Option<String>,
pub inputs: serde_json::Value,
pub output: Option<serde_json::Value>,
pub error: Option<String>,
pub __usage: Option<TokenUsage>,
pub attributes: serde_json::Value,
pub __frames: Option<Vec<serde_json::Value>>,
}
impl TraceSpan {
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 {
name: value
.get("name")
.and_then(|v| v.as_str())
.unwrap_or_default()
.to_string(),
__time: value
.get("__time")
.filter(|v| v.is_object() || v.is_array() || v.is_string())
.map(|v| TraceTime::load_from_value(v, ctx))
.unwrap_or_default(),
signature: value
.get("signature")
.and_then(|v| v.as_str())
.map(|s| s.to_string()),
inputs: value
.get("inputs")
.cloned()
.unwrap_or(serde_json::Value::Null),
output: value.get("output").cloned(),
error: value
.get("error")
.and_then(|v| v.as_str())
.map(|s| s.to_string()),
__usage: value
.get("__usage")
.filter(|v| v.is_object() || v.is_array() || v.is_string())
.map(|v| TokenUsage::load_from_value(v, ctx)),
attributes: value
.get("attributes")
.cloned()
.unwrap_or(serde_json::Value::Null),
__frames: value
.get("__frames")
.and_then(|v| v.as_array())
.map(|arr| arr.to_vec()),
}
}
pub fn to_value(&self, ctx: &SaveContext) -> serde_json::Value {
let mut result = serde_json::Map::new();
if !self.name.is_empty() {
result.insert(
"name".to_string(),
serde_json::Value::String(self.name.clone()),
);
}
{
let nested = self.__time.to_value(ctx);
if !nested.is_null() {
result.insert("__time".to_string(), nested);
}
}
if let Some(ref val) = self.signature {
result.insert(
"signature".to_string(),
serde_json::Value::String(val.clone()),
);
}
if !self.inputs.is_null() {
result.insert("inputs".to_string(), self.inputs.clone());
}
if let Some(ref val) = self.output {
result.insert("output".to_string(), val.clone());
}
if let Some(ref val) = self.error {
result.insert("error".to_string(), serde_json::Value::String(val.clone()));
}
if let Some(ref val) = self.__usage {
let nested = val.to_value(ctx);
if !nested.is_null() {
result.insert("__usage".to_string(), nested);
}
}
if !self.attributes.is_null() {
result.insert("attributes".to_string(), self.attributes.clone());
}
if let Some(ref items) = self.__frames {
result.insert(
"__frames".to_string(),
serde_json::to_value(items).unwrap_or(serde_json::Value::Null),
);
}
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))
}
pub fn as_inputs_dict(&self) -> Option<&serde_json::Map<String, serde_json::Value>> {
self.inputs.as_object()
}
pub fn as_attributes_dict(&self) -> Option<&serde_json::Map<String, serde_json::Value>> {
self.attributes.as_object()
}
}