Skip to main content

A local-first memory sidecar for agent applications

Project description

HotMem

A local-first memory sidecar for agent applications. One SQLite DB. One port: 8711.

HotMem provides fast, queryable working memory with hybrid vector + keyword search. Store facts, retrieve them ranked, and get back LLM-ready message objects you can stitch directly into prompts.

Install

pip install hotmem@git+https://github.com/KnowGuard-AI/HotMem.git
# or
uv add hotmem@git+https://github.com/KnowGuard-AI/HotMem.git

Or add to requirements.txt:

hotmem @ git+https://github.com/KnowGuard-AI/HotMem.git

Quick Start

# Start with a mount directory (portable memory)
hotmem serve --mount ./hotmem

# Or just start (uses temp DB)
hotmem serve

CLI

hotmem serve --port 8711 --mount ./data/hotmem
hotmem serve --db ./my.sqlite
hotmem hydrate --file swap.jsonl --db ./my.sqlite
hotmem snapshot --file swap.jsonl --db ./my.sqlite
hotmem status

API

All endpoints under /v1. Default: http://127.0.0.1:8711

GET /v1/health

{"status": "ok", "memory_count": 42, "db_path": "...", "uptime_s": 120.5}

POST /v1/add

{"identifier": "vendor_x", "fact": "Invoice total was $5000", "importance": 0.8}

POST /v1/search

{"query": "duplicate invoice risk", "top_k": 5, "max_chars": 1500}

Returns ranked message objects ready for LLM stitching:

{
  "memories": [
    {"role": "system", "content": "...", "memory_id": "...", "identifier": "...", "score": 0.87}
  ],
  "count": 5,
  "trace_ms": 2.1
}

POST /v1/hydrate

{"file": "swap.jsonl"}

POST /v1/snapshot

{"file": "swap.jsonl"}

Python Client

from hotmem.client import HotMemClient

with HotMemClient("http://127.0.0.1:8711") as client:
    client.add("vendor_x", "Invoice total $5000", importance=0.8)

    memories = client.search("duplicate invoice risk", top_k=5, max_chars=1500)

    # memories are LLM-ready message objects
    messages = memories + [{"role": "user", "content": "Analyze this vendor."}]

Mounting

Any directory can be a HotMem mount. The mount contains:

  • hotmem.sqlite — the database
  • swap.jsonl — portable JSONL backup
  • manifest.json — mount metadata
hotmem serve --mount /mnt/usb/hotmem     # portable memory on USB
hotmem serve --mount ./data/hotmem        # local project memory

Development

uv sync                          # install deps
uv run pytest                    # run tests
uv run ruff check src/ tests/    # lint
uv run ruff format src/ tests/   # format
uv build                         # build wheel

Architecture (for agents)

Each source module is independently extensible with self-documenting headers:

Module Purpose Extension Point
trace.py Structured JSON logging Add sinks, formatters
embed.py Hash-based embedder (dim=64) Swap for real model
db.py SQLite + cosine UDF Add FTS5, indexes
search.py Hybrid ranking Add reranking, MMR
swap.py JSONL hydrate/snapshot Add compression
mount.py Directory bootstrap Add remote sync
server.py FastAPI endpoints Add CORS, new routes
cli.py Click CLI Add subcommands
client.py httpx SDK Add async client

Every operation emits structured JSON traces to stderr with component tags:

hotmem serve --mount ./data 2>&1 | grep '"component": "search"'

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

hotmem-0.1.4.tar.gz (18.2 kB view details)

Uploaded Source

Built Distribution

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

hotmem-0.1.4-py3-none-any.whl (17.3 kB view details)

Uploaded Python 3

File details

Details for the file hotmem-0.1.4.tar.gz.

File metadata

  • Download URL: hotmem-0.1.4.tar.gz
  • Upload date:
  • Size: 18.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for hotmem-0.1.4.tar.gz
Algorithm Hash digest
SHA256 b6cd2deeeebd312ecf6b1a44808e155e42bf0bc5edc7c88f4f112ece4d97eea7
MD5 8854001dec9a0d03661eed3f07540fa1
BLAKE2b-256 2ecfe8fdabef7b65697c0ab805759e1e3283d4a4ae44186432d0e4bddec5bd5f

See more details on using hashes here.

Provenance

The following attestation bundles were made for hotmem-0.1.4.tar.gz:

Publisher: release.yml on KnowGuard-AI/HotMem

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file hotmem-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: hotmem-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 17.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for hotmem-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 0b36a9e228af3261a68754bf5c7d005b4a84d2da66c56be335d7a5e3c3a724e3
MD5 c5cfbe8904214ee2eb807fc8e3f535bb
BLAKE2b-256 a2992957ee06823d64b2dfd0d5de030bf752d4dc4658be97921ac48a213a7c7f

See more details on using hashes here.

Provenance

The following attestation bundles were made for hotmem-0.1.4-py3-none-any.whl:

Publisher: release.yml on KnowGuard-AI/HotMem

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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