prompty 2.0.0-beta.1

Prompty is an asset class and format for LLM prompts
Documentation
// Code generated by Prompty emitter; DO NOT EDIT.

#![allow(
    unused_imports,
    dead_code,
    non_camel_case_types,
    unused_variables,
    clippy::all
)]

use super::super::context::{LoadContext, SaveContext};

use super::anthropic_usage::AnthropicUsage;

/// The response body from the Anthropic Messages API.
#[derive(Debug, Clone, Default)]
pub struct AnthropicMessagesResponse {
    /// Unique response identifier
    pub id: String,
    /// Object type (always 'message')
    pub r#type: String,
    /// The role of the response (always 'assistant')
    pub role: String,
    /// Array of content blocks in the response (AnthropicTextBlock | AnthropicToolUseBlock)
    pub content: Vec<serde_json::Value>,
    /// The model that generated the response
    pub model: String,
    /// The reason generation stopped ('end_turn', 'max_tokens', 'stop_sequence', 'tool_use')
    pub stop_reason: String,
    /// Token usage statistics
    pub usage: AnthropicUsage,
}

impl AnthropicMessagesResponse {
    /// Create a new AnthropicMessagesResponse with default values.
    pub fn new() -> Self {
        Self::default()
    }

    /// Load AnthropicMessagesResponse from a JSON string.
    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))
    }

    /// Load AnthropicMessagesResponse from a YAML string.
    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))
    }

    /// Load AnthropicMessagesResponse from a `serde_json::Value`.
    ///
    /// Calls `ctx.process_input` before field extraction.
    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(),
            r#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(),
        }
    }

    /// Serialize AnthropicMessagesResponse to a `serde_json::Value`.
    ///
    /// Calls `ctx.process_dict` after serialization.
    pub fn to_value(&self, ctx: &SaveContext) -> serde_json::Value {
        let mut result = serde_json::Map::new();
        // Write base fields
        if !self.id.is_empty() {
            result.insert("id".to_string(), serde_json::Value::String(self.id.clone()));
        }
        if !self.r#type.is_empty() {
            result.insert(
                "type".to_string(),
                serde_json::Value::String(self.r#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))
    }

    /// Serialize AnthropicMessagesResponse to a JSON string.
    pub fn to_json(&self, ctx: &SaveContext) -> Result<String, serde_json::Error> {
        serde_json::to_string_pretty(&self.to_value(ctx))
    }

    /// Serialize AnthropicMessagesResponse to a YAML string.
    pub fn to_yaml(&self, ctx: &SaveContext) -> Result<String, serde_yaml::Error> {
        serde_yaml::to_string(&self.to_value(ctx))
    }
}