Coordination layer for multi-agent AI systems. Bring your own S3 / HuggingFace bucket; shared memory, mailbox, atomic task claims, handoffs, artifacts — no server, no database.
Project description
tracecraft
Tracecraft is a CLI coordination layer for multi-agent AI systems — shared memory, a mailbox, atomic task claims, handoffs, and artifacts, plus mirrored session transcripts, all stored as plain JSON in any S3 or HuggingFace bucket. No server. No database. No SDK lock-in.
Two agents, one bucket — they can't grab the same work, enforced by an S3 conditional write. No server, no lock service. All state is plain JSON you own; open it in the MinIO console or HuggingFace Hub and watch it live.
Quick start
pip install tracecraft-ai
The only infra is a bucket. For local dev, run MinIO (in production, point at AWS / R2 / HF instead):
docker run -d -p 9000:9000 \
-e MINIO_ROOT_USER=admin -e MINIO_ROOT_PASSWORD=admin123456 \
minio/minio server /data
Register two agents against the same project:
# Terminal 1
tracecraft init --project demo --agent designer \
--endpoint http://localhost:9000 --bucket tracecraft \
--access-key admin --secret-key admin123456
# Terminal 2 — same flags, --agent developer
tracecraft init --project demo --agent developer \
--endpoint http://localhost:9000 --bucket tracecraft \
--access-key admin --secret-key admin123456
Now the core move — two agents cannot grab the same work, with no lock service and no server to run:
# Terminal 1 — designer claims the task
$ tracecraft claim design
Claimed step design as designer
# Terminal 2 — developer tries the SAME task, atomically rejected (S3 If-None-Match)
$ tracecraft claim design
Error: Step design already claimed by designer
# designer finishes and leaves a handoff note for whoever picks up next
$ tracecraft complete design --note "API in api.py, see memory key design.contract"
Completed step design
# developer was blocked on it — now it unblocks
$ tracecraft wait-for design
All steps complete: design
Every call is stateless. Everything you just did is JSON files in the bucket — no server stayed running, nothing to tear down.
Agents talk to each other
Beyond claiming work, agents coordinate by messaging through the bucket — direct messages and broadcasts, each one a JSON file in a per-agent mailbox.
tracecraft send developer "contract is in memory key design.contract"
tracecraft inbox # read your direct + broadcast messages
tracecraft send _broadcast "v1 cut at 3pm, wrap your tasks"
Why tracecraft
- Atomic task claims — two agents never grab the same work, enforced by S3
If-None-Matchconditional puts, with no central coordinator. - Coordinate across hosts — the bucket is the coordinator, so agents on different machines or clouds work together by default — not just processes sharing one laptop.
- No server, no database — every CLI call is stateless; all state is JSON in a bucket you already own.
- Any backend, zero lock-in — AWS, Cloudflare R2, MinIO, Backblaze B2, Wasabi, SeaweedFS, and HuggingFace Buckets all work today.
- Harness-agnostic — Claude Code, Codex, OpenClaw, Hermes, bash, Python, or anything that can run a shell command.
- Coordination + reasoning together — the events and each agent's full session transcript live in one bucket, not two systems.
Frameworks like CrewAI and LangGraph own the agent loop; memory layers like Mem0 store one agent's recall; in-process coordination tools assume every agent shares one machine. Tracecraft owns neither the loop nor the model — just the shared bucket the agents coordinate through — so it works across hosts, across clouds, and with any harness, via a plain CLI.
Coordination + reasoning in one bucket
Most coordination tools store the events — who claimed what, who messaged whom. Tracecraft stores those and each agent's full reasoning, by mirroring coding-agent session transcripts into the same bucket. When a run goes sideways, one tracecraft session show gives you the handoffs and the chain of thought behind them — same place, same JSON, no second system to wire up.
tracecraft session mirror --harness claude-code # tail this session into the bucket
tracecraft session show <id> --tail 50 # read coordination + reasoning together
Works with Claude Code, Codex, OpenClaw, and Hermes. Source transcripts are never modified; secret-shape redaction (AWS / Anthropic / OpenAI / HF / GitHub / Slack token patterns) is on by default and counted in metadata.
Harness matrix, storage formats, and redaction details → docs/session-mirror.md
How it works
Every agent action is a JSON file under <bucket>/<project>/:
s3://bucket/demo/
agents/designer.json ← who's alive, what they're doing
memory/design/contract.json ← shared key-value state
messages/developer/1738f3_designer.json ← per-agent mailbox
steps/design/claim.json ← who claimed what (atomic)
steps/design/status.json ← pending → in_progress → complete
steps/design/handoff.json ← note for the next agent
artifacts/design/mockup.html ← shared files
sessions/claude-code/<id>/part-00000-….jsonl ← mirrored agent transcript
sessions/claude-code/<id>/meta.json ← cumulative session metadata
Any process that can call tracecraft participates. Any S3 browser (MinIO console, AWS console, HuggingFace Hub) lets you watch agents coordinate in real time. Atomicity details and the HuggingFace fallback are in docs/s3-architecture.md.
Backends
Bring your own bucket — no vendor lock-in:
| Backend | init flag |
Notes |
|---|---|---|
| MinIO | --endpoint http://localhost:9000 |
recommended for local dev |
| SeaweedFS | --endpoint http://localhost:8333 |
self-hosted |
| AWS S3 | --endpoint https://s3.amazonaws.com |
|
| Cloudflare R2 | --endpoint https://<acct>.r2.cloudflarestorage.com |
zero egress fees |
| Backblaze B2 / Wasabi | S3-compatible endpoint | |
| HuggingFace Buckets | --backend hf --bucket user/name |
browsable on the Hub; pip install tracecraft-ai[huggingface] |
Use cases
- Multi-agent coding — run several Claude Code / Codex agents in parallel; they claim modules, share artifacts, wait at barriers, and hand off context instead of stepping on each other.
- Autonomous research — agents claim experiments, share results via memory, and avoid duplicating work across a fleet.
- Pipelines — lint → test → build → deploy as claimed steps; each stage waits for its dependencies.
Full CLI reference
tracecraft init # Configure backend + project + agent
tracecraft agents # Who's online?
tracecraft memory set <key> <value> # Write (dots become path separators)
tracecraft memory get <key> # Read
tracecraft memory list [prefix] # List keys
tracecraft send <agent-id> <message> # Direct message
tracecraft send _broadcast <message> # Broadcast to all
tracecraft inbox # Read messages
tracecraft inbox --delete # Read and clear
tracecraft claim <step-id> # Claim a step (atomic)
tracecraft complete <step-id> [--note X] # Mark done + handoff note
tracecraft step-status <step-id> # Check status
tracecraft wait-for <step-ids...> # Block until complete (default 300s timeout)
tracecraft artifact upload <path> [--step id] # Share a file
tracecraft artifact download <name> [--step id] # Get a file
tracecraft artifact list [--step id] # List files
tracecraft session mirror --harness <name> # Mirror a session into the bucket
tracecraft session list # Browse mirrored sessions
tracecraft session show <id> [--tail N] # Inspect meta + transcript tail
tracecraft session stop <id> # Clear local state, mark ended
Run multiple agents from one directory by overriding identity per call:
TRACECRAFT_AGENT=designer tracecraft inbox
TRACECRAFT_AGENT=developer tracecraft inbox
More
- docs/session-mirror.md — session mirroring: harnesses, formats, redaction
- docs/s3-architecture.md — atomicity, key layout, HuggingFace fallback
- plans/ — roadmap, research, and known gaps
License
MIT
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 tracecraft_ai-0.2.0.tar.gz.
File metadata
- Download URL: tracecraft_ai-0.2.0.tar.gz
- Upload date:
- Size: 37.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
11977912eb5542e3df0f4e1f4a13298578724e6cfe1f5fc4b9092d30076fb7ad
|
|
| MD5 |
7f2ee6a69eb293d36b86085715d76903
|
|
| BLAKE2b-256 |
6b7e6d2e07372cb87ffba93bb650e6e30c49f7f3e60557fa912ba6daf98fbc71
|
Provenance
The following attestation bundles were made for tracecraft_ai-0.2.0.tar.gz:
Publisher:
release.yml on Arrmlet/tracecraft
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tracecraft_ai-0.2.0.tar.gz -
Subject digest:
11977912eb5542e3df0f4e1f4a13298578724e6cfe1f5fc4b9092d30076fb7ad - Sigstore transparency entry: 1670047532
- Sigstore integration time:
-
Permalink:
Arrmlet/tracecraft@7d77daaaf17d3f18b7718e3ddfc8ee2576446adc -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/Arrmlet
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@7d77daaaf17d3f18b7718e3ddfc8ee2576446adc -
Trigger Event:
release
-
Statement type:
File details
Details for the file tracecraft_ai-0.2.0-py3-none-any.whl.
File metadata
- Download URL: tracecraft_ai-0.2.0-py3-none-any.whl
- Upload date:
- Size: 30.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
42b27c6550f5781b394851783562e68b259d132b8035051d0e293a94a3110d42
|
|
| MD5 |
8815dd64eba1b201186cd66e22751cb9
|
|
| BLAKE2b-256 |
dd93c4dcfda3accfb8272982ce12dd3cddd1d804da913aa917d1ac4b53fd558c
|
Provenance
The following attestation bundles were made for tracecraft_ai-0.2.0-py3-none-any.whl:
Publisher:
release.yml on Arrmlet/tracecraft
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tracecraft_ai-0.2.0-py3-none-any.whl -
Subject digest:
42b27c6550f5781b394851783562e68b259d132b8035051d0e293a94a3110d42 - Sigstore transparency entry: 1670047662
- Sigstore integration time:
-
Permalink:
Arrmlet/tracecraft@7d77daaaf17d3f18b7718e3ddfc8ee2576446adc -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/Arrmlet
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@7d77daaaf17d3f18b7718e3ddfc8ee2576446adc -
Trigger Event:
release
-
Statement type: