Error Analyzer MCP Server

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.

Category
Visit Server

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 logger directory
  • Analyzes error messages and stack traces
  • Identifies related files and dependencies
  • Generates fix plans with risk assessment
  • Implements a two-phase workflow:
    1. Analysis & Planning Phase: Creates fix plans
    2. Approval Phase: Waits for your explicit approval
    3. Application Phase: Applies approved changes

šŸ› ļø Available Tools

1. list_available_logs

List all log files in your logger directory.

  • Returns all .log files 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_plan to 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

  1. Clone or extract the project to your workspace:
cd m:\mcp\mcp-read-log
  1. Install dependencies:
pip install -r requirements.txt
  1. 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
  1. 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 path
  • PROJECT_DIR: Default project to analyze
  • BACKUP_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:

  1. Check Python version: Requires Python 3.12+
python --version
  1. Verify dependencies:
pip list | grep mcp
pip list | grep pydantic
  1. Test log reading:
python -c "from services.log_reader import list_log_files; print(list_log_files())"
  1. 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 ErrorAnalysis model
  • Add new tool methods in main.py following the @mcp.tool() pattern

Remember: This server helps you understand and fix errors safely. Always review proposed changes before approval!

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured