LLM Chat Assistant
A chat assistant that integrates an MCP client with an LLM and other external MCP servers.
LLM Chat Assistant
This project is a chat assistant application that integrates MCP client (MCP host) with an LLM (Large Language Model) and external tools (MCP Servers). It allows users to interact with the LLM, which can either provide direct answers or call external tools (MCP servers) to process user requests.
Supported modes
- stdio Mode
- http Mode
Features
- LLM Integration: Communicates with an LLM using the
pydantic-ailibrary. - Tool Execution: Supports external tools - MCP servers that can be executed based on user input.
- Structured Responses: Handles structured responses from the LLM, including tool calls and direct answers.
- Server Management: Manages multiple MCP servers for tool execution.
Requirements
- Python 3.13 or higher
- MCP server(s) configured for tool execution
- LLM used local installed Ollama with qwen3:0.6b - You can change it if needed (https://ollama.com - instruction how to.)
- .env LLM_API_KEY=your-api-key-here if exteral LLM used
Installation
To execute demo MCP servers from 'mcp-servers' folder 1.FatMCP - https://github.com/modelcontextprotocol/python-sdk?tab=readme-ov-file#adding-mcp-to-your-python-project
- More information about FastMCP -> https://gofastmcp.com/getting-started/welcome
- Clone the repository:
git clone https://github.com/Rommagcom/agentic_ai_mcp.git cd agentic_ai_mcp pip install -r requirements.txt python mcp_host_client.py - To test http Mode:
- run file from folder mcp-servers/test_http_server.py - python mcp-servers/test_http_server.py
Interaction Example
-
You: echo test (After this request LLM determine to call neccessery Tool from MCP server)
-
Assistant: The result of the echo test is a text containing the message "This is echo test test". (Direct answer from MCP server)
-
You: How is the weather in Phuket ?
-
Assistant: The weather in Phuket is currently being retrieved via the API, with the mock response indicating it's a simulated result.
Add your MCP server
1. Add to mcp-server folder new .py file like in examples echo.py or weater_server.py or test_http_server.py
2. Add section to servers_config.json like where 'echo' is tool name in .py file -> @mcp.tool(description="A simple echo tool", name="echo")
"args": ["mcp-servers/weather_server.py"] full server file path
```Example:
{
"mcpServers": {
"echo": {
"command": "python",
"args": ["mcp-servers/echo.py"]
},
"weather_server": {
"command": "python",
"args": ["mcp-servers/weather_server.py"]
}
}
}
For http use case add http(s) MCP server url to config as: "url": "http://127.0.0.1:9000/mcp" and server name like "test_http" as in :
```Example:
{
"mcpServers": {
"test_http": {
"url": "http://127.0.0.1:9000/mcp"
}
}
}
Related Servers
Instagram DMs
Send Instagram DMs via your LLM
Blogger
Interact with the Google Blogger API to manage blogs, posts, and comments.
Gmail MCP Server
Send emails with attachments through Gmail's SMTP server using AI agents.
ElevenLabs MCP Enhanced
Text-to-speech generation with conversation history features using the ElevenLabs API.
Gmail MCP
An MCP server for interacting with your Gmail account using AI assistants.
VOICEROID Daemon
A text-to-speech server for VOICEROID2 via the voiceroid_daemon.
Slack Notification
Send notifications to Slack channels using webhook URLs.
Gmail MCP
Manage your Gmail account, including sending, reading, and organizing emails.
Gmail
Query live Gmail data using LLMs via CData's read-only MCP server.
Gmail
Tools for common Gmail operations, such as sending emails.