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:
remote-capable server
The server can be hosted and run remotely because it primarily relies on remote services or has no dependency on the local environment.
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 that enables web search, scraping, crawling, and content extraction through multiple engines including SearXNG, Firecrawl, and Tavily.Last updated -41,15248TypeScriptMIT License
- -securityAlicense-qualityA Model Context Protocol server that enables AI agents to search, retrieve, and analyze academic papers from arXiv, supporting features like keyword search, paper details retrieval, content extraction, and paper analysis.Last updated -PythonMIT License
- AsecurityAlicenseAqualityA Model Context Protocol server that enables natural language interaction with arXiv.org, allowing users to search, retrieve metadata, download PDFs, and load scholarly articles into LLM context.Last updated -519PythonMIT License
- -securityFlicense-qualityA Python implementation of the Model Context Protocol (MCP) server that enables searching and extracting information from arXiv papers, designed to be extensible with additional MCP tools.Last updated -Python