A Model Context Protocol (MCP) server that provides access to OpenReview data for research and analysis. This server allows you to search for users, fetch papers, and export research data from major ML conferences (ICML, ICLR, NeurIPS).
- User search: Find OpenReview profiles by email address
- Paper retrieval: Fetch all papers by a specific author
- Conference papers: Get papers from specific venues (ICLR, NeurIPS, ICML) and years
- Keyword search: Search papers by keywords across multiple conferences
- JSON&PDF export: Export search results to PDF and JSON files for convenient reading or further analysis and coding assistant usage
git clone https://github.com/yourusername/openreview-mcp-server.git
cd openreview-mcp-serverpython3 -m venv venv
source venv/bin/activate # On Windows: venv\Scripts\activatepip install -e .You'll need your OpenReview account email and password.
Either run cmd+shift+P to open the Command Palette and find MCP settings that will lead you to the mcp.json, or look for:
Cursor: ~/.cursor/mcp.json
Open the MCP configuration file and add the openreview server to the mcpServers section:
{
"mcpServers": {
"openreview": {
"command": "/ABSOLUTE/PATH/TO/openreview-mcp-server/venv/bin/python",
"args": ["-m", "openreview_mcp_server"],
"cwd": "/ABSOLUTE/PATH/TO/openreview-mcp-server",
"env": {
"OPENREVIEW_USERNAME": "[email protected]",
"OPENREVIEW_PASSWORD": "your_password",
"OPENREVIEW_BASE_URL": "https://api2.openreview.net",
"OPENREVIEW_DEFAULT_EXPORT_DIR": "./openreview_exports"
}
}
}
}Important:
- Replace
/ABSOLUTE/PATH/TO/openreview-mcp-serverwith the actual path (e.g.,/Users/yourname/workspace/openreview-mcp-server) - Replace
[email protected]andyour_passwordwith your OpenReview credentials - Use the full path to the venv Python interpreter (ending in
/venv/bin/python)
Example configuration:
{
"mcpServers": {
"openreview": {
"command": "/Users/john/workspace/openreview-mcp-server/venv/bin/python",
"args": ["-m", "openreview_mcp_server"],
"cwd": "/Users/john/workspace/openreview-mcp-server",
"env": {
"OPENREVIEW_USERNAME": "[email protected]",
"OPENREVIEW_PASSWORD": "mySecurePassword123",
"OPENREVIEW_BASE_URL": "https://api2.openreview.net",
"OPENREVIEW_DEFAULT_EXPORT_DIR": "./openreview_exports"
}
}
}
}Completely quit and reopen Cursor for the MCP server to load.
Once configured and Cursor is restarted, you can use natural language to interact with the OpenReview MCP server:
Search for papers:
Search OpenReview for papers about "multimodal tokenization" from ICML 2025, ICLR 2025 and NeurIPS 2025
Get your own papers:
Get my papers from OpenReview using email [email protected]
Export papers with PDFs:
Export papers about "multimodal tokenization" from ICLR 2024, download PDFs and extract text
Get conference papers:
Show me all papers from NeurIPS 2024
The server will automatically:
- Fetch papers from OpenReview
- Search across titles, abstracts, and authors
- Download and extract text from PDFs
- Export results to JSON for further analysis
Exported files are saved to ./openreview_exports/ by default (or your custom directory).
Find a user profile by email address.
search_user(email="[email protected]", include_publications=true)Fetch all papers published by a specific user.
Input schema:
| Field | Type | Description | Required | Default | Allowed Values |
|---|---|---|---|---|---|
email |
string | Email address of the user whose papers to fetch | Yes | — | — |
format |
string | Format of the response: summary or detailed | No | summary | summary, detailed |
get_user_papers(email="[email protected]", format="detailed")Get papers from a specific conference and year.
Input schema:
| Field | Type | Description | Required | Default | Allowed Values |
|---|---|---|---|---|---|
venue |
string | Conference venue (e.g., "ICLR.cc", "NeurIPS.cc", "ICML.cc") |
Yes | — | ICLR.cc, NeurIPS.cc, ICML.cc |
year |
string | Conference year (e.g., "2024", "2025") |
Yes | — | Four-digit year (e.g., 2024) |
limit |
integer | Maximum number of papers to return | No | 50 |
1–1000 |
format |
string | Format of the response: summary or detailed | No | summary |
summary, detailed |
get_conference_papers(venue="ICLR.cc", year="2024", limit=50)Search for papers by keywords across multiple conferences.
Search modes:
- any: returns papers that match at least one of the keywords in the specified fields. If any keyword is found, the paper is included.
- all: returns papers that match all of the keywords in the specified fields. Only papers containing every keyword are included.
- exact: returns papers that contain the exact phrase (all keywords together, in order) in the specified fields.
Input schema:
| Field | Type | Description | Required | Default | Allowed Values |
|---|---|---|---|---|---|
query |
string | Keywords or phrase to search for (e.g., "time series token merging", "neural networks") |
Yes | — | — |
venues |
array | List of conference venues and years to search in. Each item: • venue: string• year: string |
Yes | — | — |
search_fields |
array | Fields to search in. Options: "title", "abstract", "authors" |
No | ["title", "abstract"] |
"title", "abstract", "authors" |
match_mode |
string | How keywords are matched: • "any": match any keyword• "all": match all keywords• "exact": match exact phrase |
No | "all" |
"any", "all", "exact" |
limit |
integer | Maximum number of results to return | No | 20 |
1–100 |
min_score |
number | Minimum match score (between 0.0 and 1.0) | No | 0.1 |
0.0–1.0 |
search_papers(
query="time series token merging",
match_mode="all",
search_fields=["title", "abstract"],
venues=[
{"venue": "ICLR.cc", "year": "2024"},
{"venue": "NeurIPS.cc", "year": "2024"}
],
limit=20
)Export search results to JSON files for analysis.
Input schema:
| Field | Type | Description | Required | Default | Allowed Values |
|---|---|---|---|---|---|
query |
string | Keywords to search for before export | Yes | — | — |
venues |
array | List of conference venues and years to export from. Each item: • venue: string• year: string |
Yes | — | — |
export_dir |
string | Directory to export JSON files to | No | ./openreview_exports |
— |
filename |
string | Base filename for the export (without extension) | No | auto-generated | — |
include_abstracts |
boolean | Whether to include full abstracts in export | No | True |
True, False |
min_score |
number | Minimum match score for search results (0.0 to 1.0) | No | 0.2 |
0.0–1.0 |
max_papers |
integer | Maximum number of papers to export and download | No | 3 |
1–10 |
download_pdfs |
boolean | Whether to download PDFs and extract full text content | No | True |
True, False |
export_papers(
query="neural networks",
venues=[
{"venue": "ICLR.cc", "year": "2024"},
{"venue": "ICML.cc", "year": "2024"}
],
max_papers=1,
download_pdfs=true,
include_abstracts=true,
export_dir="./research_exports"
)- Search for papers on a topic of interest:
search_papers(query="time series forecasting", match_mode="all", venues=[{"venue": "ICLR.cc", "year": "2024"}])- Export relevant papers to JSON:
export_papers(query="time series token merging", venues=[{"venue":"ICML.cc","year":"2025"}], max_papers=1, download_pdfs=true, include_abstracts=true)- Use the exported JSON files with Claude Code to implement methods inspired by the research.
- ICLR (International Conference on Learning Representations)
- NeurIPS (Conference on Neural Information Processing Systems)
- ICML (International Conference on Machine Learning)
MIT License
