Skip to main content

FastAPI server for Z3rno: REST API, authentication, rate limiting, and Celery workers.

Project description

z3rno-server

PyPI License: Apache 2.0 CI

FastAPI REST API server for Z3rno -- wraps z3rno-core engine functions as HTTP endpoints.

Quickstart

Run with Docker Compose

cp .env.example .env   # configure DATABASE_URL, API keys, etc.
docker compose -f docker-compose.dev.yml up

This starts PostgreSQL 17 (with pgvector, Apache AGE), Valkey, the API server on localhost:8000, and a Celery worker.

Store a memory

curl -X POST http://localhost:8000/v1/memories \
  -H "Authorization: Bearer z3rno_sk_test_localdev" \
  -H "Content-Type: application/json" \
  -d '{"agent_id": "agent-1", "content": "User prefers dark mode", "memory_type": "semantic"}'

Recall memories

curl -X POST http://localhost:8000/v1/memories/recall \
  -H "Authorization: Bearer z3rno_sk_test_localdev" \
  -H "Content-Type: application/json" \
  -d '{"agent_id": "agent-1", "query": "What does the user prefer?", "top_k": 5}'

Forget a memory

curl -X POST http://localhost:8000/v1/memories/forget \
  -H "Authorization: Bearer z3rno_sk_test_localdev" \
  -H "Content-Type: application/json" \
  -d '{"memory_id": "<memory-uuid>"}'

API Endpoints

Method Path Description
POST /v1/memories Store a new memory
POST /v1/memories/recall Recall memories by semantic query
POST /v1/memories/forget Soft-delete a memory
GET /v1/audit Query the audit log
POST /v1/sessions Start a new session
POST /v1/sessions/{id}/end End a session
GET /v1/sessions/{id} Get session state
GET /v1/health Health check
GET /v1/ready Readiness check

Configuration

All configuration is via environment variables:

Variable Description Default
DATABASE_URL PostgreSQL connection string (asyncpg) required
REDIS_URL Valkey/Redis URL redis://localhost:6379/0
Z3RNO_API_KEY API key for authentication required
EMBEDDING_MODEL LiteLLM embedding model name text-embedding-3-small
OPENAI_API_KEY OpenAI API key (for embeddings) --
LOG_LEVEL Logging level INFO
CORS_ORIGINS Allowed CORS origins (comma-separated) --

OpenAPI Documentation

When running locally, interactive API docs are available at:

  • Swagger UI: http://localhost:8000/docs
  • ReDoc: http://localhost:8000/redoc

Development

uv sync --dev
uv run ruff check .
uv run mypy .
uv run pytest

See CONTRIBUTING.md for the full workflow.

License

Apache 2.0 -- see LICENSE.

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

z3rno_server-0.1.0.tar.gz (315.8 kB view details)

Uploaded Source

Built Distribution

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

z3rno_server-0.1.0-py3-none-any.whl (37.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: z3rno_server-0.1.0.tar.gz
  • Upload date:
  • Size: 315.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for z3rno_server-0.1.0.tar.gz
Algorithm Hash digest
SHA256 ec199f447e82a824860179688d3cadb301c459779077cd7f7215409999afa8dd
MD5 a76198b0610a806a53658b220f302c82
BLAKE2b-256 53ecda3d18c39694e56bc24a2cd82bb49d2043252ed417da87bd1f889281a2a7

See more details on using hashes here.

File details

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

File metadata

  • Download URL: z3rno_server-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 37.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for z3rno_server-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3f2832760e44253570f196e7c8eb2e8c6baf82f1ba2dcf3b13855811ae3b1173
MD5 9a82e2c90178256d3e6037caf4d478ac
BLAKE2b-256 0d437f0fb6305c68eb20fea373ac895c88d80f232eb0e80fe13615fe1b1fd3e7

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