thostetler/scix-mcp
If you are the rightful owner of scix-mcp and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to dayong@mcphub.com.
The NASA SciX MCP Server is a Model Context Protocol server designed for the NASA Astrophysics Data System (SciX) API, enabling advanced search and analysis of astronomical literature.
NASA SciX MCP Server
A Model Context Protocol (MCP) server for the NASA Astrophysics Data System (SciX) API. This server enables LLMs to search astronomical literature, retrieve paper metadata, analyze citation metrics, and export bibliographic data.
Quick Start (MCP clients)
Get an API Key
- Create an account at SciX
- Generate an API token at https://scixplorer.org/user/settings/token
- Set the environment variable:
export SCIX_API_TOKEN=your_api_key_here
Or create a .env file:
cp .env.example .env
# Edit .env and add your key
Configure your MCP client (Claude, Codex, etc.)
Add to your MCP client configuration:
{
"mcpServers": {
"ads": {
"command": "npx",
"args": ["scix-mcp"],
"env": {
"SCIX_API_TOKEN": "your_api_key_here"
}
}
}
}
Common locations: Claude Desktop (~/Library/Application Support/Claude/claude_desktop_config.json on macOS or %AppData%\\Claude\\claude_desktop_config.json on Windows) and Codex CLI (~/.config/codex/config.json). Restart your client after editing.
Local MCP clients that read .mcp/server.json can also pick up the packaged config in .mcp/server.json; just drop in your SCIX_API_TOKEN.
Example Prompts
- Find refereed JWST exoplanet papers from 2022-2024 sorted by citation_count, return the top 5 in markdown with bibcodes, titles, first author, and citation counts.
- Build a query for gravitational wave kilonova follow-ups since 2017 (fielded abstract search), add the first 50 results to library <library_id>, and then give me metrics (h-index, total cites) for those bibcodes in JSON.
- Fetch paper 2020ApJ...905....3A, list its first 10 references with titles, and also list the first 10 forward citations with publication years.
- Create a public library named “Cosmic Web Reviews”, seeded with bibcodes [...], then share the public URL and export the contents in BibTeX.
- For bibcodes [...], return citation metrics plus a ranked list of which papers cite the most recent one (rows=25) in markdown.
- Get all my libraries, pick the one with the most documents, and return its metadata plus the first 5 document titles in JSON.
Features
- Literature Search: Full-text search with advanced Solr query syntax
- Paper Details: Retrieve comprehensive metadata for any publication
- Citation Metrics: Calculate h-index, citation counts, and usage statistics
- Citation Network: Explore forward and backward citations
- Export: Generate citations in BibTeX, AASTeX, EndNote, and MEDLARS formats
- Documentation Search: Query SciX help/docs content via the
search_docstool - Dual Format: Support for both human-readable Markdown and machine-readable JSON
Available Tools
Search & Metadata
search: Solr-powered search across SciX. Params:query(required),rows(1-100, default 10),start(offset, default 0),sort(score desc|citation_count desc|date desc|date asc|read_count desc, defaultscore desc),response_format(markdown|json, defaultmarkdown).- Example queries:
author:"Einstein, A." title:relativity,black holes year:2020-2023,author:^Smith,dark energy AND galaxy clusters.
- Example queries:
get_paper: Fetch a paper bybibcodewith optionalresponse_format.get_metrics: Metrics forbibcodes(1-2000) with optionalresponse_format; returns h-index, g-index, citation counts, usage stats.
Citation Network
get_citations: Forward citations forbibcode; optionalrows(1-100, default 20) andresponse_format.get_references: Backward references forbibcode; optionalrows(1-100, default 20) andresponse_format.
Export
export: Exportbibcodes(1-2000) informat(bibtex|aastex|endnote|medlars). Returns plain text in the chosen format.
Documentation
search_docs: Search SciX help documentation. Params:query(required, natural language),limit(1-20, default 5). Returns a ranked list with title, section/subsection, source URL, relevance score, and a focused snippet.
Libraries
get_libraries: List libraries; optionaltype(all|owner|collaborator, defaultall) andresponse_format.get_library: Metadata + documents forlibrary_id; optionalresponse_format.create_library: Create withname(required), optionaldescription,public(defaultfalse),bibcodes, andresponse_format.delete_library: Permanently delete bylibrary_id; optionalresponse_format.edit_library: Updatename,description, orpublicforlibrary_id; optionalresponse_format.manage_documents: Add/remove documents withlibrary_id,bibcodes(1-2000),action(add|remove), and optionalresponse_format.add_documents_by_query: Add search results to a library withlibrary_id,query, optionalrows(1-2000, default 25), andresponse_format.library_operation: Run set ops on a library withlibrary_id,operation(union|intersection|difference|copy|empty), optionalsource_library_ids,name/description(for copy), andresponse_format.
Permissions & Sharing
get_permissions: View owners/collaborators forlibrary_id; optionalresponse_format.update_permissions: Grant/change a user's access withlibrary_id,email,permission(owner|admin|write|read), and optionalresponse_format.transfer_library: Transfer ownership withlibrary_id,email, and optionalresponse_format.
Annotations
get_annotation: Fetch note content forlibrary_id+bibcode; optionalresponse_format.manage_annotation: Add/update note withlibrary_id,bibcode,content, and optionalresponse_format.delete_annotation: Remove note forlibrary_id+bibcode; optionalresponse_format.
Rate Limits
- 5000 requests per day per API key
- Rate limit info is returned in response headers
- Contact adshelp@cfa.harvard.edu for higher limits
SciX Search Syntax
The SciX search supports powerful query syntax:
| Syntax | Description | Example |
|---|---|---|
author:"Last, F." | Exact author | author:"Huchra, John" |
author:^Last | First author | author:^Smith |
title:keyword | Title search | title:exoplanet |
abstract:keyword | Abstract search | abstract:"dark matter" |
year:YYYY-YYYY | Year range | year:2020-2023 |
property:refereed | Refereed only | property:refereed |
citations(bibcode:X) | Papers citing X | citations(bibcode:2019ApJ...) |
references(bibcode:X) | Papers cited by X | references(bibcode:2019ApJ...) |
AND, OR, NOT | Boolean operators | black holes AND galaxy |
Development
Install & Build
npm install
npm run build
Local commands
# Watch mode
npm run dev
# Test with MCP Inspector
npx @modelcontextprotocol/inspector node build/index.js
Testing
The project includes a comprehensive test suite using Vitest.
Running Tests
# Run all tests
pnpm test
# Run tests in watch mode
pnpm test:watch
# Run tests with coverage
pnpm test:coverage
Test Structure
Tests are organized in the test/ directory:
test/
├── helpers/
│ └── mockFetch.ts # Fetch mocking utilities
├── client.test.ts # HTTP client tests
├── search-docs.test.ts # Documentation search tests
└── tools/
├── search.test.ts # Search tool tests
├── paper.test.ts # Paper details tests
├── metrics.test.ts # Metrics tests
├── citations.test.ts # Citations/references tests
├── export.test.ts # Export tests
└── library.test.ts # Library management tests
Test Coverage
The test suite covers:
- HTTP Client: GET/POST/PUT/DELETE methods, error handling (401/404/429), timeouts, request formatting
- Search Tools: Query parameter encoding, pagination, result limiting, response formatting
- Paper Tools: Bibcode validation, field selection, error handling for missing papers
- Metrics Tools: Batch bibcode processing, MAX_BIBCODES limits, metric type selection
- Citation Tools: Forward/backward citations, sorting, row limits
- Export Tools: Multiple export formats (BibTeX, AASTeX, EndNote, etc.), batch processing
- Library Tools: All CRUD operations, permissions, annotations, library operations
API Token for Tests
Tests use mock fetch and don't require a real API token. The test suite sets ADS_DEV_KEY=test-api-key automatically.
Live Integration Tests (Optional)
To run tests against the real ADS API (skipped by default):
-
Set your real API key:
export SCIX_API_TOKEN=your_real_api_key -
Run integration tests (not implemented yet):
pnpm test:integration
Note: Integration tests count against your daily rate limit (5000 requests/day).
Project Structure
src/
├── index.ts # Main server entry point
├── client.ts # SciX API client wrapper
├── types.ts # TypeScript/Zod type definitions
├── formatters.ts # Response formatting utilities
├── config.ts # Configuration constants
└── tools/
├── search.ts # Search tool
├── paper.ts # Paper details tool
├── metrics.ts # Metrics tool
├── citations.ts # Citation network tools
└── export.ts # Export tool
Library tools
get_libraries/get_library: List and inspect librariescreate_library/delete_library/edit_library: Manage library metadatamanage_documents: Add/remove bibcodes to a libraryadd_documents_by_query: Add results from a search query to a librarylibrary_operation: Union/intersection/difference/copy/empty on librariesget_permissions/update_permissions/transfer_library: Manage sharingget_annotation/manage_annotation/delete_annotation: Handle notes on documents
Example Usage
Search for papers
Use search with query "supernova 2023" to find recent supernova papers
Get paper details
Use get_paper with bibcode "2023ApJ...950..123S"
Calculate metrics
Use get_metrics with bibcodes ["2023ApJ...950..123S", "2022MNRAS.517.1234T"]
Export citations
Use export with bibcodes ["2023ApJ...950..123S"] and format "bibtex"
Error Handling
The server provides clear error messages:
- 401: Invalid API key - check
SCIX_API_TOKEN - 404: Resource not found - check bibcode format
- 429: Rate limit exceeded - wait until reset
- Timeout: Request took > 30 seconds
Resources
License
MIT
Support
For API issues: adshelp@cfa.harvard.edu For server issues: Open an issue on GitHub