#![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",
}
}
}
#[derive(Debug, Clone, Default)]
pub struct McpApprovalMode {
pub kind: mcpApprovalModeKind,
pub always_require_approval_tools: Option<Vec<String>>,
pub never_require_approval_tools: Option<Vec<String>>,
}
impl McpApprovalMode {
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());
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()
}),
}
}
pub fn to_value(&self, ctx: &SaveContext) -> serde_json::Value {
let mut result = serde_json::Map::new();
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))
}
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))
}
}