Skip to main content
Glama
yipihey

SciX Client

by yipihey

scix-client

scix-client gives your AI assistant direct access to the SciX / NASA ADS database. Search the literature, build bibliographies, analyze citation networks, manage personal libraries, resolve object names via SIMBAD/NED, and export references in BibTeX, AASTeX, or 15 other formats — all from natural language.

It also works standalone: as a CLI tool, a Python library, or a Rust crate.

Research workflows: literature reviews, bibliography management, citation analysis, reference export, object resolution, paper details, library collaboration, annotation/notes

Mode

What it does

Guide

MCP server (scix serve)

Expose SciX tools to Claude, Cursor, Zed, etc.

docs/mcp-server.md

CLI (scix)

Command-line tool for your terminal

docs/cli.md

Python library (scix_client)

Native Python module — pip install scix-client

docs/python.md

Rust library (scix_client)

Async Rust crate — cargo add scix-client

docs/rust.md

One binary (scix) does everything. Python bindings are auto-generated from the Rust types — zero extra maintenance.

Prerequisites

You need a SciX / ADS API token. Get one (free) at: https://ui.adsabs.harvard.edu/user/settings/token

export SCIX_API_TOKEN="your-token-here"
# or, for backwards compatibility:
export ADS_API_TOKEN="your-token-here"

Quick Start: MCP

Give your AI assistant access to the entire SciX database.

Install

cargo install scix-client --features cli
# or: cargo binstall scix-client
scix setup

This detects your installed editors (Claude Code, Claude Desktop, Cursor, Zed), prompts for your API token, validates it, and writes the correct config for each one. Run it once and you're done.

Options:

  • scix setup claude-code — configure only Claude Code

  • scix setup --yes — non-interactive (uses env token, configures all detected editors)

  • scix setup --skip-validation — skip token validation

Manual setup

claude mcp add scix -- /path/to/scix serve

Add to ~/Library/Application Support/Claude/claude_desktop_config.json:

{
  "mcpServers": {
    "scix": {
      "command": "/path/to/scix",
      "args": ["serve"],
      "env": { "SCIX_API_TOKEN": "your-token-here" }
    }
  }
}

See docs/mcp-server.md for Cursor, Zed, full tool reference, and example workflows.


Quick Start: CLI

cargo install scix-client --features cli

scix search 'first_author:"Perlmutter" supernova' --sort "citation_count desc"
scix export 1999ApJ...517..565P --format bibtex
scix cites 1999ApJ...517..565P --rows 50
scix libraries create "Thesis Papers" --description "Key references"

See docs/cli.md for all commands including library permissions, notes, and set operations.


Quick Start: Python

pip install scix-client
import scix_client

client = scix_client.SciXClient()
results = client.search('author:"Einstein" year:1905', rows=5)
for paper in results.papers:
    print(f"{paper.title} ({paper.year}) — {paper.citation_count} citations")

See docs/python.md for the full API reference including v0.2.0 library management methods.


Quick Start: Rust

[dependencies]
scix-client = "0.3"
use scix_client::SciXClient;

#[tokio::main]
async fn main() -> scix_client::error::Result<()> {
    let client = SciXClient::from_env()?;
    let results = client.search("author:\"Einstein\" year:1905", 5).await?;
    for paper in &results.papers {
        println!("{} — {} citations", paper.title, paper.citation_count.unwrap_or(0));
    }
    Ok(())
}

See docs/rust.md for the full API, error handling, and architecture.


Query Syntax Quick Reference

Pattern

Meaning

author:"Einstein"

Author search

first_author:"Einstein"

First author only

title:"dark matter"

Title words

abs:"gravitational waves"

Abstract words

year:2023 or year:[2020 TO 2023]

Year / year range

bibcode:2023ApJ...

Bibcode

doi:"10.1234/..."

DOI

object:"M31"

Astronomical object

property:refereed

Refereed papers

property:openaccess

Open access

Boolean: AND, OR, NOT, parentheses Functional: citations(bibcode:X), references(bibcode:X), similar(bibcode:X) Sort: date desc (default), citation_count desc, score desc, read_count desc

See docs/query-syntax.md for the full reference including all 17 export formats.


Rate Limiting

The SciX API allows 5,000 requests/day and 5 requests/second. scix-client handles rate limiting automatically — a token-bucket rate limiter enforces 5 req/s locally, and API rate-limit headers are respected.

License

MIT

-
security - not tested
A
license - permissive license
-
quality - not tested

Resources

Looking for Admin?

Admins can modify the Dockerfile, update the server description, and track usage metrics. If you are the server author, to access the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/yipihey/scix-client'

If you have feedback or need assistance with the MCP directory API, please join our Discord server