Error Analyzer MCP Server
Analyzes log files to identify root causes of project errors and generates detailed fix plans with risk assessments. It implements a multi-phase workflow that ensures no code modifications are applied without explicit user approval.
README
Error Analyzer MCP Server š§
A specialized Model Context Protocol (MCP) server that analyzes errors in your projects, identifies root causes, and generates detailed fix plans with a built-in approval workflow before applying any changes.
š Overview
When your project encounters errors, this MCP server helps you:
- Read and analyze log files to understand what went wrong
- Identify the affected files and their dependencies
- Diagnose the root cause of errors
- Create detailed fix plans with step-by-step solutions
- Request your approval before making ANY file modifications
- Apply approved fixes safely to your project
This server emphasizes safety and transparency: it never modifies your files without your explicit approval and clear understanding of what will change.
šļø Architecture
- Reads log files from a configurable
loggerdirectory - Analyzes error messages and stack traces
- Identifies related files and dependencies
- Generates fix plans with risk assessment
- Implements a two-phase workflow:
- Analysis & Planning Phase: Creates fix plans
- Approval Phase: Waits for your explicit approval
- Application Phase: Applies approved changes
š ļø Available Tools
1. list_available_logs
List all log files in your logger directory.
- Returns all
.logfiles available for analysis
2. analyze_error
Analyze errors in a specific log file.
- Input: project directory path, log file name
- Returns: error location, root cause, affected files, severity level
- Creates an analysis ID for further processing
3. create_fix_plan
Create a detailed work plan to fix identified errors.
- Input: analysis ID from previous step
- Returns: fix plan with proposed fixes, impact assessment, risk level
- Status: Awaiting your approval
- Creates a plan ID for tracking
4. approve_fix_plan
Approve a fix plan after reviewing the proposed changes.
- Input: plan ID
- Effect: Marks the plan as approved
- Next step: Call
apply_fix_planto make the changes
5. reject_fix_plan
Reject a fix plan if you disagree with proposed solutions.
- Input: plan ID, optional feedback
- Effect: Cancels the plan
- Next step: Can request new analysis with different parameters
6. apply_fix_plan
Apply the approved fixes to your project files.
- Input: plan ID (must be approved first)
- Effect: MODIFIES YOUR PROJECT FILES
- Returns: List of changes applied
- Safety: Only works if plan was explicitly approved
7. get_fix_plan_details
Retrieve detailed information about a specific fix plan.
- Useful for reviewing plans before approval
8. list_pending_plans
See all fix plans created in this session with their statuses.
- Helps track pending approvals and applied fixes
š Workflow Example
1. Error occurs in your project
ā
2. Error is written to logger/error.log
ā
3. Call analyze_error(project_dir="/path/to/project", log_file_name="error.log")
ā Returns: analysis_id = "abc123"
ā
4. Call create_fix_plan(analysis_id="abc123")
ā Returns: plan_id = "xyz789"
ā Status: "AWAITING USER APPROVAL"
ā
5. Review the proposed fixes in the plan
ā
6. Either:
a) Call approve_fix_plan(plan_id="xyz789") ā then apply_fix_plan(plan_id="xyz789")
b) Call reject_fix_plan(plan_id="xyz789", feedback="...")
š Setup
Installation
- Clone or extract the project to your workspace:
cd m:\mcp\mcp-read-log
- Install dependencies:
pip install -r requirements.txt
- Configure environment (optional):
# Copy the example file
cp .env.example .env
# Edit .env to customize:
# - LOG_DIR: Path to your logger directory (default: ./logger)
# - PROJECT_DIR: Default project to analyze
# - BACKUP_BEFORE_APPLY: Create backups before applying fixes
- Create logger directory if it doesn't exist:
mkdir logger
š Usage with Claude or Other AI Agents
In Claude or Cline:
You have access to the error-analyzer-mcp MCP server. When a user's project has errors:
1. First call: list_available_logs() to see what log files are available
2. Then call: analyze_error() with the project path and log file name
3. Review the analysis results
4. Call: create_fix_plan() with the analysis ID
5. Show the user the proposed fixes and ask for approval
6. Only after explicit approval, call: apply_fix_plan()
Example Session:
User: "My Python project is broken with errors"
AI: Calling list_available_logs()... Found: error.log, debug.log
AI: Which log should I analyze? Let me check error.log.
AI: Calling analyze_error(project_dir=".", log_file_name="error.log")
AI: Analysis complete! Found SyntaxError on line 42, affects 3 files.
AI: Calling create_fix_plan()...
AI: Created fix plan. Here are the proposed changes:
- Fix syntax error in main.py line 42
- Update import in handler.py line 15
AI: This has LOW risk. Do you approve these changes?
User: "Yes, apply them"
AI: Calling approve_fix_plan()... then apply_fix_plan()
AI: Done! Applied 2 fixes to your project.
š Safety Features
ā No file modifications without approval
- Every fix plan requires explicit user approval before changes
ā Clear risk assessment
- Each plan shows risk level, severity, and dependencies
ā Transparent change tracking
- See exactly which files and lines will be modified
ā Reversible operations
- Backup support (configurable in .env)
- Can review changes before committing
š Log File Format
Place log files in the logger directory. Supported formats:
- Standard error logs with file:line:column notation
- Stack traces with file paths
- IDE error output
- Custom formatted logs with error messages
Example:
Error in /path/to/file.py on line 42:
SyntaxError: invalid syntax
x = y +
^
File "helper.py", line 15, in process()
undefined_variable = 5
š§ Configuration Files
pyproject.toml
Project metadata and Python dependencies. Uses PyPI packages for MCP, Pydantic, and python-dotenv.
requirements.txt
Direct pip requirements for easy installation.
settings.py
Configuration dataclass for runtime settings.
.env
Environment variables:
LOG_DIR: Custom logger directory pathPROJECT_DIR: Default project to analyzeBACKUP_BEFORE_APPLY: Whether to create backups (true/false)
š Project Structure
mcp-read-log/
āāā main.py # MCP server with all tools
āāā settings.py # Configuration management
āāā pyproject.toml # Project metadata
āāā requirements.txt # Python dependencies
āāā .env.example # Example configuration
āāā README.md # This file
ā
āāā models/
ā āāā result.py # ToolResult, ErrorInfo, ErrorAnalysis models
ā āāā error_analysis_models.py # Input models for MCP tools
ā
āāā services/
ā āāā log_reader.py # Log file reading utilities
ā āāā error_analysis_service.py # Core error analysis logic
ā
āāā utils/
ā āāā (utilities for path, validation, errors)
ā
āāā tests/
ā āāā (unit tests for services)
ā
āāā logger/ # Log files (created on first use)
āāā error.log
āāā debug.log
š Debugging
If the MCP server doesn't start:
- Check Python version: Requires Python 3.12+
python --version
- Verify dependencies:
pip list | grep mcp
pip list | grep pydantic
- Test log reading:
python -c "from services.log_reader import list_log_files; print(list_log_files())"
- Check environment:
echo %LOG_DIR% # Windows
echo $LOG_DIR # Linux/Mac
š License
Based on the git-mcp-server framework by the course instructor.
š¤ Contributing
To extend this MCP server:
- Add new error detection patterns in
error_analysis_service.py - Add new analysis types by extending
ErrorAnalysismodel - Add new tool methods in
main.pyfollowing the@mcp.tool()pattern
Remember: This server helps you understand and fix errors safely. Always review proposed changes before approval!
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
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.