Skip to main content

Durable context for long-running agents.

Project description

Remaind

tests python license

Durable context for long-running agents.

Remaind is a local-first context ledger, compaction pipeline, and resume substrate for AI agents. It preserves the meaningful state of an agent run across context resets: a future agent can start with a clean model context, load Remaind's local state, understand what happened before, know what must happen next, and continue safely without asking the user to reconstruct the work.

Remaind is not a wiki — it is a machine-readable and human-readable continuity layer: raw event ledger, structured state, compact handover, searchable memory, structured validation, safe rollback, and a mechanical resume gate.

Install

git clone https://github.com/magpiexyz-lab/Remaind.git
cd Remaind
python3 -m venv .venv
.venv/bin/pip install -e ".[dev]"

Requires Python ≥ 3.11.

Quick start

# Bootstrap a .context/ in the current directory.
remaind init

# Inspect what's there.
remaind validate
remaind status

# After work happens (events appended by your agent harness),
# compact when token band climbs.
remaind compact

# Build a resume packet for a fresh agent run.
remaind resume --next-tool deploy_prod

# Roll back if something went wrong.
remaind rollback --to 2026-05-14T03:54:33Z

What lives in .context/

.context/
├── README.md
├── CONTRACT.md           # the contract — read this first
├── active/
│   ├── state.json        # derived working state (atomic replace)
│   ├── handover.md       # compact continuity document (atomic replace)
│   └── (resume_packet.md, history/  — runtime, git-ignored)
├── logs/
│   └── events.jsonl      # append-only raw timeline (source of truth)
├── schemas/
│   ├── event.schema.json         # JSON Schema Draft 2020-12
│   ├── state.schema.json
│   ├── memory.schema.json
│   ├── validation.schema.json
│   ├── thresholds.yaml           # 40k/60k/70k/80k band math
│   ├── redaction.yaml            # 9 default secret patterns
│   ├── tools.yaml                # mechanical risk flags
│   └── migrations/{state,events}/
└── (db/context.sqlite, artifacts/  — runtime, git-ignored)

Authority order

When sources disagree, lower wins:

  1. Latest explicit user instruction
  2. Raw event log (logs/events.jsonl)
  3. active/state.json
  4. active/handover.md
  5. Derived memories

A stale summary or memory MUST NOT override a newer user instruction.

Commands

Command What it does
remaind init Bootstrap .context/; --force backs up existing
remaind validate Walk the v1 checklist (structure, schemas, events, SQLite)
remaind status [--json] State + thresholds + event counts + compaction recommendation
remaind compact Run the compaction pipeline, gated by structured validation
remaind resume [--next-tool TOOL] Build a resume packet; consult the resume gate
remaind rollback --to <ts> Restore derived files from history; raw log untouched

Architecture

Phase Subject
1 Frozen contract — schemas, configs, layout
2 Migration interfaces — state migrations + event adapters (Protocols)
3 init + validate + schema/config loaders + JSONL streaming
4 Redaction engine + content-addressed artifact store + append-only event writer
5 Atomic state/handover writes + history snapshots + threshold band recompute
6 status human/JSON inspector
7 SQLite memory + FTS5 (memories, memories_fts, events_index)
8 chars/4 token estimator + compaction-needed surface
9 Source-event selection + reference compactor
10 Structured compaction validator (reject-on-any-false)
11 Resume packet builder + mechanical resume gate
12 Rollback (restores derived files; raw log untouched)

V1 non-goals

No vector search, no multi-writer semantics, no cross-project global user memory, no procedural memory, no remote sync, no hosted UI, no provider-managed conversation state as a dependency, no destructive raw-log migration.

Hard rules

  • Do not rewrite events.jsonl.
  • Do not let summaries become source of truth.
  • Do not store secrets in raw logs.
  • Do not store huge outputs inline (threshold: 4096 bytes).
  • Do not allow stale memory to override latest user instruction.
  • Do not accept compaction without structured validation.
  • Do not mutate files on resume if the resume packet is contradictory or unsafe.

Tests

.venv/bin/python -m pytest -q

177 tests covering every phase. Adding a feature? Add a test.

License

MIT — 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

remaind-0.1.0.tar.gz (2.2 MB view details)

Uploaded Source

Built Distribution

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

remaind-0.1.0-py3-none-any.whl (59.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: remaind-0.1.0.tar.gz
  • Upload date:
  • Size: 2.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for remaind-0.1.0.tar.gz
Algorithm Hash digest
SHA256 bd9228a07169943b36157b3b5edc3be20c72d528573e04ab3319014d79872ec3
MD5 7109271d1255c9576df74b5a7bac84e6
BLAKE2b-256 01f2df853ee603b4f1819165db50aaccf69662cfff39b533e2e634f6201fadb7

See more details on using hashes here.

Provenance

The following attestation bundles were made for remaind-0.1.0.tar.gz:

Publisher: release.yml on magpiexyz-lab/Remaind

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

File details

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

File metadata

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

File hashes

Hashes for remaind-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8071a8daff14b7233854ea588b270b503b8be9ff9cdc020997ab642af095771d
MD5 9e441d146bbba8789c532b2b392a2ba0
BLAKE2b-256 a69681e29517534d568a07ef64f1d3cb8ec0d1d62249ef12f7d4c286738caca4

See more details on using hashes here.

Provenance

The following attestation bundles were made for remaind-0.1.0-py3-none-any.whl:

Publisher: release.yml on magpiexyz-lab/Remaind

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