Provides tools for searching academic papers on arXiv by topic and extracting detailed information about specific papers by their ID.
Employs .env file for environment configuration, specifically for storing the Anthropic API key.
Leverages Node.js runtime environment to execute the MCP server functionality, with v16 or higher required.
Implements the MCP server using TypeScript for type safety and modern JavaScript features.
Uses Yarn package manager for dependency management and script execution.
MCP Demo - TypeScript Implementation
This is a TypeScript implementation of the MCP: Build Rich-Context AI Apps with Anthropic course from DeepLearning.AI.
Overview
This project demonstrates the Model Context Protocol (MCP) implementation with streamable HTTP capabilities. MCP is an open protocol that standardizes how LLM applications can access context through tools and data resources using a client-server architecture.
⚠️ This project is for educational and demo purposes only.
Features
- MCP client-server architecture implementation
- Streamable HTTP communication
- arXiv paper search functionality
- Paper information extraction
- Tool selection and argument extraction
- Prompt template management
Prerequisites
- Node.js (v16 or higher)
- Yarn package manager
- Anthropic API key
Setup
- Clone the repository
- Install dependencies
- Environment ConfigurationCreate a
.env
file in the root directory:Important: Replace<your_anthropic_api_key_here>
with your actual Anthropic API key. - Build the project
Project Structure
Usage
Starting the MCP Server
Starting the MCP Client
Running Both (Development)
Available Tools
The MCP server provides the following tools:
search_papers
- Search for papers on arXiv- Arguments:
topic
(string): The topic to search formax_results
(number, optional): Maximum number of results (default: 5)
- Arguments:
extract_info
- Extract information from a specific paper- Arguments:
paper_id
(string): The ID of the paper to look for
- Arguments:
API Reference
search_papers(topic: string, max_results?: number)
Searches for papers on arXiv based on a topic and returns their information.
extract_info(paper_id: string)
Searches for information about a specific paper by ID from arXiv.
getToolSelectionPrompt(toolList: string, userQuery: string)
Generates a detailed prompt for tool selection and argument extraction.
Course Reference
This implementation is based on the MCP: Build Rich-Context AI Apps with Anthropic course by DeepLearning.AI in partnership with Anthropic. The course covers:
- Core concepts of MCP
- Client-server architecture
- Building MCP-compatible applications
- Connecting to third-party servers
- Deploying MCP servers remotely
For the complete course content, visit: https://learn.deeplearning.ai/courses/mcp-build-rich-context-ai-apps-with-anthropic
Contributing
This is a demo project for educational purposes. Feel free to experiment and modify the code to learn more about MCP implementation.
License
This project is for educational purposes only. Please refer to the original course materials for licensing information.
Support
For questions about the MCP protocol or the original course, please refer to:
A TypeScript implementation of the Model Context Protocol server that enables searching arXiv papers and extracting paper information through standardized client-server communication.
Related MCP Servers
- AsecurityAlicenseAqualityA Model Context Protocol server enabling advanced search and content extraction using the Tavily API, with rich customization and integration options.Last updated -4571JavaScriptMIT License
- -securityAlicense-qualityA Model Context Protocol server that enables web search, scraping, crawling, and content extraction through multiple engines including SearXNG, Firecrawl, and Tavily.Last updated -3511TypeScriptMIT License
- -securityFlicense-qualityA TypeScript implementation of the Model Context Protocol server that enables creation, management, and semantic search of memory streams with Mem0 integration.Last updated -TypeScript
- -securityAlicense-qualityA Model Context Protocol server that enables querying the Crossref API to search for academic publications by title, author, or DOI, returning structured metadata about scholarly works.Last updated -JavaScriptMIT License