# MCP Proxy - CTF Problem Management System

A GUI-based problem management system that operates as a proxy between MCP (Model Context Protocol) servers and CTF (Capture The Flag) challenges.

## Overview

This project serves as a proxy layer that interfaces with MCP servers to retrieve CTF challenges and provides a user-friendly web interface for problem management and solving.

## Features

- **MCP Server Integration**: Connects to MCP servers to fetch CTF challenges
- **SQLite Database**: Stores problem information locally for fast loading
- **Problem Loading**: Fetches new problem lists from MCP servers and stores them in the database
- **ID-based Sorting**: Displays problems sorted by ID for organized viewing
- **Three Options per Problem**:
  1. **Start Solving** - Begin a new problem-solving session
  2. **View Solution** - Check answers for already solved problems
  3. **Problem Information** - View detailed information about the problem
- **Visual Problem Status**: Distinguishes between solved and unsolved problems
- **Responsive Design**: Works on both desktop and mobile devices
- **Docker Container Cleanup**: Automatic cleanup of old Docker containers (65+ minutes) with target images
- **Real-time Process Monitoring**: Monitor running and completed processes
- **Attempt Count Management**: Edit and manage attempt counts for different models

## Project Structure

```
MCP-proxy/
├── app.py                    # Flask main application
├── requirements.txt          # Python dependencies
├── problems.db               # SQLite database (auto-generated)
├── templates/                # HTML templates
│   ├── index.html           # Main page
│   ├── status.html          # Process monitoring page
│   ├── edit_attempts.html   # Attempt count management page
│   └── docker_cleanup.html  # Docker cleanup management page
└── README.md                # Project documentation
```

## Docker Container Cleanup

The application includes an automatic Docker container cleanup system that runs in the background to manage resource usage.

### Features
- **Automatic Cleanup**: Runs every 5 minutes in the background
- **Target Images**: Monitors specific Docker images (`sweagent/enigma:latest`, `ctfenv:multiagent`)
- **Time Threshold**: Removes containers running for more than 65 minutes
- **Web Interface**: Manage cleanup settings via `/docker-cleanup` page
- **API Control**: Start/stop cleanup and run manual cleanup via API

### Configuration
```python
DELETE_THRESHOLD = timedelta(minutes=65)  # Container age threshold
TARGET_IMAGES = {
    "sweagent/enigma:latest",
    "ctfenv:multiagent"
}
CHECK_INTERVAL = 5 * 60  # Check every 5 minutes
```

### Web Interface
Access the Docker cleanup management page at `/docker-cleanup` to:
- View current cleanup status
- Start/stop automatic cleanup
- Run manual cleanup immediately
- Monitor cleanup results

### API Endpoints

#### Docker Cleanup APIs
- **POST /api/docker/cleanup/start**: Start automatic cleanup
- **POST /api/docker/cleanup/stop**: Stop automatic cleanup
- **GET /api/docker/cleanup/status**: Get cleanup status and configuration
- **POST /api/docker/cleanup/run-now**: Run cleanup immediately

## API Endpoints

### GET /api/problems
Returns the list of problems from the database (sorted by ID).

### POST /api/problems/load
Fetches new problem list from MCP server and stores it in the database.

**Response Example:**
```json
{
  "success": true,
  "problems": [
    {
      "id": 1,
      "name": "Sum of Two Numbers",
      "solved_by_name": "user1"
    },
    {
      "id": 2,
      "name": "Find Maximum in Array",
      "solved_by_name": null
    }
  ]
}
```

### GET /api/problem/{problem_id}/options
Returns available options for a specific problem.

**Response Example:**
```json
{
  "success": true,
  "problem_id": 1,
  "options": [
    {
      "id": 1,
      "name": "Start Solving",
      "description": "Begin solving this problem",
      "action": "solve"
    },
    {
      "id": 2,
      "name": "View Solution",
      "description": "Check the solution for this solved problem",
      "action": "view_solution"
    },
    {
      "id": 3,
      "name": "Problem Information",
      "description": "View detailed information about this problem",
      "action": "info"
    }
  ]
}
```

### POST /api/problem/{problem_id}/action
Handles problem-related actions.

**Request Example:**
```json
{
  "action": "solve"
}
```

**Response Example:**
```json
{
  "success": true,
  "message": "Starting to solve problem 1.",
  "action": "solve"
}
```

## MCP Server Integration

The application fetches problem lists from MCP servers at `http://127.0.0.1:8000/challenges` endpoint.

### MCP API Endpoints

- **GET /challenges**: Retrieve problem list
- **GET /challenges/{id}**: Get specific problem details
- **POST /challenges/{id}/solve**: Start problem solving
- **GET /challenges/{id}/solution**: Get problem solution

### Data Structure

The application supports the following fields from MCP server data:
- `id`, `problem_id`, `challenge_id`: Problem ID
- `name`, `title`, `problem_name`: Problem name
- `solved_by_name`, `solved_by`, `solvedBy`: User who solved the problem

### Fallback Data

When MCP server connection fails, the application automatically uses sample data to ensure normal operation.

## Customization

### Problem Data Structure Changes
Modify the `MCPProblem` class and related API endpoints to support different data structures.

### Option Addition/Modification
Modify the option list in the `get_problem_options` function to add different actions.

### UI Style Changes
Modify CSS styles in `templates/index.html` to change the design.

## Development Environment

- Python 3.7+
- Flask 2.3.3
- requests 2.31.0
- python-dotenv 1.0.0
- psutil 5.9.5
- docker 6.1.3

## Installation

1. Clone the repository
2. Install dependencies:
   ```bash
   pip install -r requirements.txt
   ```
3. Run the application:
   ```bash
   python app.py
   ```
4. Access the web interface at `http://localhost:5000`

## License

This project is distributed under the MIT License. 