use super::manager::PromptManager;
use super::template::parse_template;
use kodegen_mcp_schema::{McpError, Tool, ToolExecutionContext, ToolArgs, ToolResponse};
use kodegen_mcp_schema::prompt::{EditPromptArgs, PromptEditOutput, PromptEditPrompts, PROMPT_EDIT};
#[derive(Clone)]
pub struct EditPromptTool {
manager: PromptManager,
}
impl EditPromptTool {
pub fn with_manager(manager: PromptManager) -> Self {
Self { manager }
}
pub async fn new() -> Result<Self, McpError> {
let manager = PromptManager::new();
manager.init().await?;
Ok(Self { manager })
}
}
impl Tool for EditPromptTool {
type Args = EditPromptArgs;
type Prompts = PromptEditPrompts;
fn name() -> &'static str {
PROMPT_EDIT
}
fn description() -> &'static str {
"Edit an existing prompt template. Provide the prompt name and complete new content \
(including YAML frontmatter). The content is validated before saving. Use get_prompt \
to retrieve current content before editing."
}
fn read_only() -> bool {
false
}
fn destructive() -> bool {
true }
fn idempotent() -> bool {
true }
async fn execute(&self, args: Self::Args, _ctx: ToolExecutionContext) -> Result<ToolResponse<<Self::Args as ToolArgs>::Output>, McpError> {
self.manager
.edit_prompt(&args.name, &args.content)
.await
.map_err(McpError::Other)?;
let filename = format!("{}.j2.md", args.name);
let template = parse_template(&filename, &args.content)
.map_err(McpError::Other)?;
let template_length = args.content.len();
let parameter_count = template.metadata.parameters.len();
let summary = format!(
"\x1b[33m Prompt Updated: {}\x1b[0m\n\
Template length: {} · Parameters: {}",
args.name,
template_length,
parameter_count
);
let output = PromptEditOutput {
success: true,
name: args.name.clone(),
message: format!("Prompt '{}' updated successfully ({} bytes, {} parameters)", args.name, template_length, parameter_count),
path: None,
};
Ok(ToolResponse::new(summary, output))
}
}