# CTFusion

CTFusion is a project that integrates various CTF (Capture The Flag) tools.

## 🚀 Installation and Setup

### 1. Clone Repository

```bash
git clone <repository-url>
cd CTFusion
```

### 2. Environment Variables Setup

Create a `.env` file in the project root directory and set the necessary environment variables:

```bash
# Create .env file
touch .env
```

Add the following content to the `.env` file:

```env
# CTFd related settings
CTFD_API_TOKEN='your_ctfd_api_token_here'
CTFD_BASE_URL='https://your-ctfd-instance.com/'
FLAG_FORMAT=FLAG{example_flag}

# AI API key settings
OPENAI_API_KEY=your_openai_api_key_here
ANTHROPIC_API_KEY=your_anthropic_api_key_here
GEMINI_API_KEY=your_gemini_api_key_here

# SWE Agent timeout settings (optional)
SWE_AGENT_ACTION_TIMEOUT=300
SWE_AGENT_ACTION_NO_OUTPUT_TIMEOUT=60
SWE_AGENT_ENV_LONG_TIMEOUT=600
```

### 3. Create and Activate Virtual Environment

```bash
python3 -m venv venv
source venv/bin/activate
```

### 4. Install Dependencies

```bash
bash setup.sh
```

## 🚀 Server Execution

### 5. Run CTFd-MCP Server

```bash
python3 CTFd-MCP/server/server.py
```

### 6. Run MCP-Proxy Server

In a new terminal window, run the following command:

```bash
cd CTFusion
source venv/bin/activate
python3 MCP-proxy/app.py
```

## 📁 Project Structure

```
CTFusion/
├── .env                    # Environment variables file
├── setup.sh               # Dependency installation script
├── CTFd-MCP/             # CTFd MCP server
├── MCP-proxy/            # MCP proxy server
├── EVAL-D-CIPHER/        # D-CIPHER evaluation tool
```

## ⚠️ Important Notes

- The `.env` file contains sensitive information. Do not commit it to Git.
- Regularly update API keys and delete unused keys.
- To stop each server, press `Ctrl+C` in the respective terminal.

## 📞 Support

If you encounter any issues or have questions, please create an issue. 
