Content
# DeepSeek MCP-like Server for Terminal
[](https://archestra.ai/mcp-catalog/othmaneblial__term_mcp_deepseek)
This project is an MCP‑like server using the DeepSeek API. It aims to demonstrate the core concepts behind the Model Context Protocol (MCP) by exposing endpoints that allow AI assistants to:
- List available tools.
- Invoke commands on an active shell session.
- Integrate with an AI chat (DeepSeek) that can include special instructions (e.g., `CMD:` lines) to trigger command execution.
> **Note:** While this implementation captures many of the MCP ideas and includes features like real-time streaming, session management, and basic security, it is not yet a fully compliant MCP server as defined by Anthropic. It is designed as a proof-of-concept, and further enhancements (e.g., complete JSON‑RPC protocol support, advanced authentication, and comprehensive error handling) would be needed for production use.
## Features
- **Chat Interface:**
A modern web-based chat client (using Flask and Tailwind CSS) where users can interact with the server, now with real-time updates and improved error handling.
- **AI Integration:**
Uses the DeepSeek API to generate responses. The AI can instruct the server to execute terminal commands by including lines beginning with `CMD:`.
- **Terminal Command Execution:**
Executes shell commands via a persistent Bash session using the `pexpect` library and returns output to the client, with added real-time streaming capabilities.
- **MCP Endpoints:**
Provides `/mcp/list_tools` and `/mcp/call_tool` endpoints that mimic MCP tool discovery and invocation, with expanded protocol support including prompts, resources, and roots.
- **Real-time Streaming:**
Server-Sent Events (SSE) for live command execution updates and terminal output.
- **Security Enhancements:**
Basic authentication, rate limiting, input validation, and security headers for safer operation.
- **Multiple Transport Options:**
Supports both HTTP REST API and STDIO command-line interface for flexibility.
- **Session Management:**
Improved session handling and conversation storage.
- **Docker Support:**
Containerization for easier deployment and testing.
## Getting Started
### Prerequisites
- Python 3.8+
- [pip](https://pip.pypa.io/)
- A valid DeepSeek API key
### Installation
1. **Clone the repository:**
```bash
git clone https://github.com/OthmaneBlial/term_mcp_deepseek.git
cd term_mcp_deepseek
```
2. **Create and activate a virtual environment:**
```bash
python3 -m venv venv
source venv/bin/activate # On Windows, use `venv\Scripts\activate`
```
3. **Install the required dependencies:**
```bash
pip install -r requirements.txt
```
4. **Configure your API key:**
Update the `DEEPSEEK_API_KEY` in `.env` with your DeepSeek API key.
### Running the Server
#### Quick Start
Use the provided startup script for convenience:
```bash
chmod +x startup.sh
./startup.sh
```
#### Manual Start
Run the Flask server with:
```bash
python server.py
```
Visit [http://127.0.0.1:8000](http://127.0.0.1:8000) to access the chat interface.
#### Docker
For containerized deployment:
```bash
docker-compose up -d
```
## Endpoints
### Chat Endpoint
- **URL:** `/chat`
- **Method:** `POST`
- **Payload:** `{ "message": "your message here" }`
- **Description:**
Adds the user message to the conversation, sends it to the DeepSeek API, looks for any command instructions (`CMD:`), executes them, and returns the final response.
### MCP Endpoints
#### List Tools
- **URL:** `/mcp/list_tools`
- **Method:** `POST`
- **Response:**
JSON listing available tools (e.g., `write_to_terminal`, `read_terminal_output`, `send_control_character`).
#### Call Tool
- **URL:** `/mcp/call_tool`
- **Method:** `POST`
- **Payload:**
```json
{
"name": "tool_name",
"arguments": { ... }
}
```
- **Description:**
Directly invoke a tool command on the server.
### Real-time Streaming
- **URL:** `/stream?session_id=session_id`
- **Method:** `GET`
- **Description:** Server-Sent Events endpoint for real-time command output updates.
## Future Improvements
- **Protocol Standardization:**
Implement JSON‑RPC for a more robust and standardized communication protocol.
- **Real-time Communication:**
Add Server‑Sent Events (SSE) or WebSockets for live command output streaming.
- **Session & Security Enhancements:**
Introduce per‑user sessions, proper authentication, input sanitization, and comprehensive error handling.
- **Modular Code Architecture:**
Further separate API logic from business logic for better maintainability and scalability.
## License
This project is open-source and available under the [MIT License](LICENSE).
Connection Info
You Might Also Like
Git
Model Context Protocol Servers
repomix
📦 Repomix is a powerful tool that packs your entire repository into a...
Mastra
The TypeScript AI agent framework. ⚡ Assistants, RAG, observability....
Blender
BlenderMCP integrates Blender with Claude AI for enhanced 3D modeling.
cua
Open-source infrastructure for Computer-Use Agents. Sandboxes, SDKs, and...
fastapi_mcp
Expose your FastAPI endpoints as Model Context Protocol (MCP) tools, with Auth!