An open-source multi-agent research assistant for your Zotero library
Project description
An open-source multi-agent research assistant that connects to your Zotero library. Search, summarize, and explore your research papers through a conversational interface.
Features
- Hybrid search — combines semantic (vector) and keyword (BM25) search across titles, abstracts, tags, and full text
- Summarization — generates structured summaries and saves them as notes directly in Zotero
- Web UI — clean chat interface built on FastAPI; no browser issues, works on any platform
- Conversational context — references like "the first one" or "that paper" are resolved across turns
- Flexible LLM support — OpenAI, Anthropic, or Ollama (free, runs locally)
Web UI
zori ui
Open http://localhost:7860 in your browser. The web UI is the recommended interface on Windows, where terminal hyperlinks may not render correctly.
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
Web UI (recommended):
zori ui
Or use the terminal REPL:
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").
In the terminal REPL: 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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file zori-0.3.1.tar.gz.
File metadata
- Download URL: zori-0.3.1.tar.gz
- Upload date:
- Size: 804.0 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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ab569d29bd8a6d20bdd12207626871262296831008f5fd8220920c63d2d5e653
|
|
| MD5 |
b8873bb6fe0c933923ae288747ef4145
|
|
| BLAKE2b-256 |
8f0577dd079bf09e9f7c2c876b809814eda6ebdd1bc1c1a4b904573736399478
|
File details
Details for the file zori-0.3.1-py3-none-any.whl.
File metadata
- Download URL: zori-0.3.1-py3-none-any.whl
- Upload date:
- Size: 40.5 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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7be679983d042f39343fb9b6df13a9abcd793c1c3bb99f3971569d1dbd6d8737
|
|
| MD5 |
9c40fd609f624ed81c0ba344510c6896
|
|
| BLAKE2b-256 |
892d2d0490a2f2755d160e7dfd25c815dd0db68158a69763f0eaf37481065688
|