Skip to main content

An open-source multi-agent research assistant for your Zotero library

Project description

Zori

An open-source multi-agent research assistant that connects to your Zotero library. Search, summarize, and explore your research papers through a conversational interface.

Python LangGraph ChromaDB License PyPI

Requirements

  • A Zotero account with API access
  • An LLM provider: OpenAI, Anthropic, or Ollama (free, runs locally)

Setup

1. Install

pip install zori
Install from source
git clone https://github.com/nazbn/zori.git
cd zori
uv sync

When installed from source, prefix all commands with uv run (e.g. uv run zori init, uv run zori ingest, uv run zori).

2. Initialize

mkdir my-zori && cd my-zori
zori init

zori init creates config.yaml and .env in the current directory. Always run zori from this directory.

3. Configure

Edit .env with your Zotero API key and library ID, and config.yaml to choose your LLM and embeddings provider (see LLM options and Embeddings options).

4. Ingest your library

zori ingest

Downloads your Zotero PDFs, extracts text, and builds the search index in .zori/. Run time depends on library size and embedding provider. You only need to do a full ingest once. To index new or modified items added to Zotero since the last ingest, run zori ingest --sync.

5. Start the assistant

zori

Usage

Zori supports natural language queries for searching and summarizing papers:

> papers on diffusion models
> papers by Vaswani
> papers from 2023 on neural radiance fields
> summarize the first one
> find attention is all you need
> summarize it

Queries use hybrid search (keyword + semantic). References to previous results are resolved in context (e.g. "the first one", "that paper").

Type exit to quit, --new-session to reset conversation history.

LLM options

Provider config.yaml Requires
OpenAI provider: openai OPENAI_API_KEY in .env
Anthropic provider: anthropic ANTHROPIC_API_KEY in .env
Ollama (free, local) provider: ollama Ollama running locally

Embeddings options

LLM and embeddings are configured independently — any combination works.

Provider config.yaml Setup
OpenAI provider: openai, model: text-embedding-3-small OPENAI_API_KEY in .env
Ollama (free, local) provider: ollama, model: nomic-embed-text Ollama running + ollama pull nomic-embed-text
HuggingFace (free, local) provider: huggingface, model: <model> (e.g. all-MiniLM-L6-v2) pip install "zori[huggingface]"

License

MIT — see LICENSE.

Contact

For questions, bug reports, or feature requests, open an issue on the GitHub issue tracker or reach out at nazanin.bagherinejad@rwth-aachen.de.


This repository was developed with the assistance of Claude (Anthropic).

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

zori-0.1.0.tar.gz (425.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

zori-0.1.0-py3-none-any.whl (31.0 kB view details)

Uploaded Python 3

File details

Details for the file zori-0.1.0.tar.gz.

File metadata

  • Download URL: zori-0.1.0.tar.gz
  • Upload date:
  • Size: 425.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.3 {"installer":{"name":"uv","version":"0.11.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for zori-0.1.0.tar.gz
Algorithm Hash digest
SHA256 8815f694f572fdccae0dec5141a2f81ee3b081545bc2fc11fd3e8ae8d28e54f7
MD5 75b4a9f0d9d8cb7e945cbecd82203571
BLAKE2b-256 d79452a6db345e91309a562d327ddfc8ddb6ec5b637f51db38e467065708368d

See more details on using hashes here.

File details

Details for the file zori-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: zori-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 31.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.3 {"installer":{"name":"uv","version":"0.11.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for zori-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1d483cd5e719c3d48d70341fdf1c3118955b10428e0b827b19faf2a730603490
MD5 a4cefc95fb8d17eb28b4f8cfe5266b82
BLAKE2b-256 70337d68271029075e346956f45df444ff226977b20f74614ca33e78519f832b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page