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 LangChain 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.2.0.tar.gz (425.3 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.2.0-py3-none-any.whl (30.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: zori-0.2.0.tar.gz
  • Upload date:
  • Size: 425.3 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.2.0.tar.gz
Algorithm Hash digest
SHA256 8c8487d1d16f24b9f8dc00a289f575c0857d7211ed738b3589e21cc67c319cf9
MD5 b569871c528cfa9f84a9f024585d8831
BLAKE2b-256 1fd6391a9e84e827f973d78ce4d841172d8c38d12d5221a2c835b8349537c8cf

See more details on using hashes here.

File details

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

File metadata

  • Download URL: zori-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 30.8 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.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 96cf08a357f4dc155a0f7e34f6678d69a311b929817b7e3302d93356f250c6b5
MD5 23be77e86b1ec5ffecfe1d57461a3018
BLAKE2b-256 7d9d96b6fc3098400478ea3a807fcba69c1379cfdc2b2ab6c33871cd0b2f72e6

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