prompty 2.0.0-alpha.11

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

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

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

#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
pub enum mcpApprovalModeKind {
    Always,
    Never,
    Specify,
}

impl Default for mcpApprovalModeKind {
    fn default() -> Self {
        Self::Always
    }
}

impl std::fmt::Display for mcpApprovalModeKind {
    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
        match self {
            Self::Always => write!(f, "always"),
            Self::Never => write!(f, "never"),
            Self::Specify => write!(f, "specify"),
        }
    }
}

impl mcpApprovalModeKind {
    pub fn from_str_opt(s: &str) -> Option<Self> {
        match s {
            "always" => Some(Self::Always),
            "never" => Some(Self::Never),
            "specify" => Some(Self::Specify),
            _ => None,
        }
    }

    pub fn as_str(&self) -> &str {
        match self {
            Self::Always => "always",
            Self::Never => "never",
            Self::Specify => "specify",
        }
    }
}

/// The approval mode for MCP server tools. When kind is "specify", use alwaysRequireApprovalTools and neverRequireApprovalTools to control per-tool approval. For "always" and "never", those fields are ignored.
#[derive(Debug, Clone, Default)]
pub struct McpApprovalMode {
    /// The approval mode: 'always', 'never', or 'specify'
    pub kind: mcpApprovalModeKind,
    /// List of tools that always require approval (only used when kind is 'specify')
    pub always_require_approval_tools: Option<Vec<String>>,
    /// List of tools that never require approval (only used when kind is 'specify')
    pub never_require_approval_tools: Option<Vec<String>>,
}

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

    /// Load McpApprovalMode 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 McpApprovalMode 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 McpApprovalMode 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());
        if let Some(s) = value.as_str() {
            let value = s.to_string();
            return McpApprovalMode {
                kind: mcpApprovalModeKind::from_str_opt(&value)
                    .unwrap_or(mcpApprovalModeKind::Always),
                ..Default::default()
            };
        }
        Self {
            kind: value
                .get("kind")
                .and_then(|v| v.as_str())
                .and_then(|s| mcpApprovalModeKind::from_str_opt(s))
                .unwrap_or(mcpApprovalModeKind::Always),
            always_require_approval_tools: value
                .get("alwaysRequireApprovalTools")
                .and_then(|v| v.as_array())
                .map(|arr| {
                    arr.iter()
                        .filter_map(|v| v.as_str().map(|s| s.to_string()))
                        .collect()
                }),
            never_require_approval_tools: value
                .get("neverRequireApprovalTools")
                .and_then(|v| v.as_array())
                .map(|arr| {
                    arr.iter()
                        .filter_map(|v| v.as_str().map(|s| s.to_string()))
                        .collect()
                }),
        }
    }

    /// Serialize McpApprovalMode 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
        result.insert(
            "kind".to_string(),
            serde_json::Value::String(self.kind.to_string()),
        );
        if let Some(ref items) = self.always_require_approval_tools {
            result.insert(
                "alwaysRequireApprovalTools".to_string(),
                serde_json::to_value(items).unwrap_or(serde_json::Value::Null),
            );
        }
        if let Some(ref items) = self.never_require_approval_tools {
            result.insert(
                "neverRequireApprovalTools".to_string(),
                serde_json::to_value(items).unwrap_or(serde_json::Value::Null),
            );
        }
        ctx.process_dict(serde_json::Value::Object(result))
    }

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