AIE8-MCP Session Server
Provides web search, dice rolling, text processing, and dad jokes tools, integrated with LangGraph for intelligent workflow orchestration.
README
<p align = "center" draggable="false" ><img src="https://github.com/AI-Maker-Space/LLM-Dev-101/assets/37101144/d1343317-fa2f-41e1-8af1-1dbb18399719" width="200px" height="auto"/> </p>
<h1 align="center" id="heading">AI Makerspace: MCP Session Repo for Session 13</h1>
This project demonstrates an MCP (Model Context Protocol) server with LangGraph integration, utilizing the Tavily API for web search capabilities and other useful tools.
Project Overview
The MCP server provides multiple tools and is integrated with a LangGraph application for intelligent workflow orchestration.
Prerequisites
- Python 3.13 or higher
- A valid Tavily API key
- A valid OpenAI API key
β οΈNOTE FOR WINDOWS:β οΈ
You'll need to install this on the Windows side of your OS.
This will require getting two CLI tool for Powershell, which you can do as follows:
winget install astral-sh.uvwinget install --id Git.Git -e --source winget
After you have those CLI tools, please open Cursor into Windows.
Then, you can clone the repository using the following command in your Cursor terminal:
git clone https://AI-Maker-Space/AIE8-MCP-Session.git
After that, you can follow from Step 2. below!
Installation
-
Clone the repository:
git clone <repository-url> cd <repository-directory> -
Configure environment variables: Copy the
.env.sampleto.envand add your API keys:TAVILY_API_KEY=your_tavily_api_key_here OPENAI_API_KEY=your_openai_api_key_here -
Set up the environment:
uv run python setup_env.py
Running the MCP Server
To start the MCP server, you will need to add the following to your MCP Profile in Cursor:
NOTE: To get to your MCP config. you can use the Command Pallete (CMD/CTRL+SHIFT+P) and select "View: Open MCP Settings" and replace the contents with the JSON blob below.
{
"mcpServers": {
"mcp-server": {
"command" : "uv",
"args" : ["--directory", "/PATH/TO/REPOSITORY", "run", "server.py"]
}
}
}
The server will start and listen for commands via standard input/output.
Activities:
ποΈ Activity #1: β COMPLETED
Choose an API that you enjoy using - and build an MCP server for it!
MCP Server Features:
- Web search using Tavily API
- Dice rolling with custom notation
- Text processing utilities
- Random dad jokes
ποΈ Activity #2: β COMPLETED
Build a simple LangGraph application that interacts with your MCP Server.
Simple Solution:
langgraph_simple_final.py- The complete LangGraph applicationsetup_env.py- Helper script for environment setupSIMPLE_SOLUTION.md- Complete documentation
Quick Start:
# 1. Set up environment
uv run python setup_env.py
# 2. Add your OpenAI API key to .env file
# 3. Run the application
uv run python langgraph_simple_final.py
# Or run interactive mode
uv run python langgraph_simple_final.py --interactive
Features:
- β Single file solution - Everything in one Python file
- β LLM-powered - Uses OpenAI GPT-4o-mini with API key
- β All MCP tools integrated - Web search, dice rolling, text processing, jokes
- β Automatic tool selection - LLM chooses appropriate tools based on input
- β Interactive mode - Real-time conversation with the system
- β Type-safe state management - Uses TypedDict for reliability
Architecture:
- Single LangGraph node that processes user input
- Direct MCP function imports (no subprocess complexity)
- LangChain tool binding for seamless integration
- OpenAI API integration for intelligent responses
Usage
The LangGraph application provides an intelligent interface to all MCP server tools. Simply run the application and ask it to:
- Search the web for information
- Roll dice with custom notation
- Process text (uppercase, lowercase, reverse, etc.)
- Tell you a joke
The LLM will automatically choose the appropriate tools and provide intelligent responses based on your requests.
Additional Files
Testing
test_server.py- Comprehensive test script for the MCP server- Tests all MCP functions directly
- Tests MCP server via subprocess communication
- Run with:
uv run python test_server.py
Advanced Features
dice_roller_numpy.py- Advanced dice rolling utility using NumPy- Better performance for large numbers of dice
- Statistical analysis of rolls
- Supports complex notation (e.g., "3d8+2", "1d20-1")
- Run with:
uv run python dice_roller_numpy.py
Project Structure
AIE8-MCP-Session/
βββ langgraph_simple_final.py # Main LangGraph application
βββ setup_env.py # Environment setup helper
βββ server.py # MCP server (Activity #1)
βββ dice_roller.py # Basic dice rolling utility
βββ dice_roller_numpy.py # Advanced NumPy dice roller
βββ test_server.py # Test script for MCP server
βββ pyproject.toml # Dependencies
βββ README.md # Main documentation
βββ SIMPLE_SOLUTION.md # Simple solution guide
βββ uv.lock # Lock file
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.