CEDARScript MCP Server
Exposes CEDARScript Editor through Model Context Protocol, enabling AI agents to perform semantic-aware code transformations with security features like path validation and dry-run mode.
README
CEDARScript MCP Server
AI-Assisted Code Transformations via Model Context Protocol
Overview
CEDARScript MCP Server exposes the powerful CEDARScript Editor through the Model Context Protocol (MCP), enabling AI agents like Claude to perform intelligent, semantic-aware code transformations.
Key Features
- š Secure by Default: Path validation, sandboxing, read-only mode
- šÆ Dry-Run Mode: Preview changes before applying
- š² Tree-Sitter Powered: Language-aware code analysis
- š” STDIO Transport: Simple subprocess integration (no HTTP overhead)
- š ļø Production-Ready: Comprehensive logging, error handling, testing
Quick Start
Installation
pip install cedarscript-mcp-server
Usage with Claude Desktop
-
Open Claude Desktop configuration (usually
~/.config/Claude/claude_desktop_config.json) -
Add CEDARScript MCP server:
{
"mcpServers": {
"cedarscript": {
"command": "python",
"args": [
"-m",
"cedarscript_mcp.server",
"--root",
"/path/to/your/project"
]
}
}
}
-
Restart Claude Desktop
-
Ask Claude to use CEDARScript:
- "Parse this CEDARScript command:
UPDATE myfile.py SET imports.append('import os')" - "Apply this transformation (preview first):
UPDATE calculator.py SET function:calculate REPLACE 'x + 1' WITH 'x + 2'"
- "Parse this CEDARScript command:
Command-Line Usage
# Start server (STDIO mode)
python -m cedarscript_mcp.server --root /path/to/project
# With custom options
python -m cedarscript_mcp.server \
--root /path/to/project \
--read-only \
--log-level DEBUG \
--max-file-size 10485760
Architecture
CEDARScript MCP Server is a thin adapter layer that:
- Accepts JSON-RPC requests over STDIO
- Validates paths and security constraints
- Delegates to CEDARScript Editor for execution
- Returns structured results or error messages
āāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāā
ā Claude Desktop / VS Code ā
ā (MCP Client) ā
āāāāāāāāāāāāāā¬āāāāāāāāāāāāāāāāāāāāā
ā JSON-RPC over STDIO
āāāāāāāāāāāāāā¼āāāāāāāāāāāāāāāāāāāāā
ā CEDARScript MCP Server ā
ā ⢠Security (path validation) ā
ā ⢠Tools (parse, apply, list) ā
ā ⢠Adapters (protocol mapping) ā
āāāāāāāāāāāāāā¬āāāāāāāāāāāāāāāāāāāāā
ā
āāāāāāāāāāāāāā¼āāāāāāāāāāāāāāāāāāāāā
ā CEDARScript Editor (core) ā
ā ⢠AST parsing ā
ā ⢠Tree-sitter analysis ā
ā ⢠File transformations ā
āāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāā
Available Tools
parse_cedarscript
Parse and validate CEDARScript commands without execution.
Parameters:
content(string): CEDARScript commands
Returns: Parsed AST commands
Example:
{
"content": "UPDATE myfile.py SET imports.append('import os')"
}
apply_cedarscript
Apply CEDARScript transformations to code files.
Parameters:
commands(string): CEDARScript commandsroot(string): Project root directory pathdry_run(boolean, default: true): Preview changes without writing
Returns: Results, diffs (if dry_run), affected files
Example:
{
"commands": "UPDATE calculator.py SET function:add REPLACE 'x + y' WITH 'x + y + 1'",
"root": "/path/to/project",
"dry_run": true
}
list_capabilities
List server capabilities and supported features.
Returns: Server version, features, security settings
Configuration
Environment Variables
CEDARSCRIPT_ROOT: Default project root (default: current directory)CEDARSCRIPT_LOG_LEVEL: Logging level (DEBUG, INFO, WARNING, ERROR)CEDARSCRIPT_LOG_FORMAT: Log format (text, json)CEDARSCRIPT_READ_ONLY: Force read-only mode (true/false)CEDARSCRIPT_MAX_FILE_SIZE: Max file size in bytes (default: 10485760)
CLI Arguments
python -m cedarscript_mcp.server \
--root /path/to/project \ # Project root directory
--read-only \ # Enable read-only mode
--log-level DEBUG \ # Logging level
--max-file-size 10485760 # Max file size (bytes)
Security
Path Validation
- All file paths are validated against the specified root directory
- Path traversal attacks (
../../../etc/passwd) are blocked - Symlinks are resolved and validated
Denylist Patterns
Files matching these patterns are automatically rejected:
.git/**,node_modules/**,__pycache__/**.env,*.env,.env.*credentials.json,*.key,*.pem
Read-Only Mode
When enabled, all write operations are rejected (parsing/analysis only).
File Size Limits
Configurable maximum file size (default: 10MB) to prevent resource exhaustion.
Development
Setup
# Clone repository
git clone https://github.com/CEDARScript/cedarscript-mcp-server.git
cd cedarscript-mcp-server
# Install development dependencies
make install
# Run tests
make test
# Run with coverage
make test-cov
# Format and lint
make check
Makefile Targets
make help # Show all available targets
make install # Install with dev dependencies
make test # Run full test suite
make test-fast # Run tests (skip integration)
make check # Format, lint, security checks
make run # Launch server (demo mode)
make build # Build distribution packages
See planning/MAKEFILE_DESIGN.md for complete target documentation.
Testing
# Run all tests
make test
# With coverage report
make test-cov
# Watch mode (auto-rerun on changes)
make test-watch
# Test against multiple cedarscript-editor versions
make test-matrix
Documentation
- ARCHITECTURE.md: System design, protocol mapping, security model
- IMPLEMENTATION.md: Step-by-step implementation guide
- MAKEFILE_DESIGN.md: Makefile targets and automation
- Examples: Claude Desktop, VS Code, quickstart guides
Examples
Claude Desktop Configuration
See examples/claude_desktop.json for drop-in configuration.
VS Code MCP Client
See examples/vscode_mcp.json for VS Code setup.
Programmatic Usage
from cedarscript_mcp import PathValidator, apply_cedarscript_tool
# Create validator
validator = PathValidator(Path("/path/to/project"))
# Apply transformation (dry-run)
result = apply_cedarscript_tool(
commands="UPDATE myfile.py SET imports.append('import os')",
root="/path/to/project",
dry_run=True,
validator=validator
)
print(result)
Troubleshooting
Server Not Starting
Issue: ModuleNotFoundError: No module named 'mcp'
Solution: Install MCP SDK: pip install mcp>=1.0.0
Path Validation Errors
Issue: SecurityError: Path escape attempt
Solution: Ensure file paths are within the specified root directory.
Read-Only Mode Blocking Writes
Issue: SecurityError: Write operation rejected
Solution: Remove --read-only flag or set CEDARSCRIPT_READ_ONLY=false.
Contributing
Contributions welcome! Please:
- Fork the repository
- Create a feature branch
- Run
make check testbefore committing - Submit a pull request
License
Apache License 2.0 - see LICENSE for details.
Related Projects
- CEDARScript Editor - Core transformation library
- CEDARScript AST Parser - Language parser
- Model Context Protocol - MCP specification
Support
- Issues: GitHub Issues
- Documentation: GitHub README
- Email: cedarscript@orgecc.com
Made with ā¤ļø by the CEDARScript Team
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.