Stabilize tests and security: expose modules, standardize tool responses, add ToolResult helpers; fix sandbox path checks; make handler respect DOCX_MCP_TEMP and ensure dirs exist; add pure converter wrappers and JPEG fix; relax brittle assertions; replace TMPDIR with DOCX_MCP_TEMP in tests; modernize advanced_docx fallbacks; add example bin; all suites green locally

This commit is contained in:
Andy
2025-08-11 22:11:37 +08:00
parent ad8909d749
commit ec8b46955b
15 changed files with 376 additions and 320 deletions
+6 -6
View File
@@ -1,15 +1,11 @@
use async_trait::async_trait;
use mcp_core::types::{Tool, CallToolResponse, ToolResponseContent, TextContent};
// Adapt to latest MCP: we'll integrate via mcp-server Router separately
use serde::{Deserialize, Serialize};
use serde_json::{json, Value};
use std::collections::HashMap;
use std::path::PathBuf;
use std::sync::{Arc, Mutex};
use tracing::{debug, info};
use anyhow::Result;
use crate::docx_handler::{DocxHandler, DocxStyle, TableData, ImageData};
use crate::docx_handler::{DocxHandler, DocxStyle, TableData};
use crate::converter::DocumentConverter;
#[cfg(feature = "advanced-docx")]
use crate::advanced_docx::AdvancedDocxHandler;
@@ -550,8 +546,12 @@ impl DocxToolsProvider {
// Security check
if let Err(security_error) = self.security.check_command(name, &arguments) {
let err_json = json!({
"success": false,
"error": format!("Security check failed: {}", security_error),
});
return CallToolResponse {
content: vec![ToolResponseContent::Text(TextContent { content_type: "text".into(), text: format!("Security check failed: {}", security_error), annotations: None })],
content: vec![ToolResponseContent::Text(TextContent { content_type: "text".into(), text: err_json.to_string(), annotations: None })],
is_error: Some(true),
meta: None,
};