Metadata-Version: 2.4
Name: a2cr-mcp
Version: 0.1.7
Summary: Local MCP workspace for AI agent handoff checkpoints, WorkStash notes, and WorkThreads.
Author: A2CR
License: A2CR Source-Available License Notice
        BUSL-1.1 style terms
        
        Copyright (c) 2026 A2CR
        
        IMPORTANT:
        This repository is source-available, not OSI-approved open source.
        The official A2CR MCP client is made public so users can inspect it, use it,
        contribute fixes, and connect AI agents to the official A2CR service.
        
        The licensed work is:
        
          a2cr-mcp, including the local stdio MCP wrapper, package source code,
          public examples, and wrapper tests in this repository.
        
        Additional Use Grant:
        
        You may use the Licensed Work for personal use, internal business use,
        research, evaluation, contribution, documentation, testing, and for connecting
        to the official A2CR hosted service at https://a2cr.app.
        
        Internal business use does not include offering the Licensed Work, or a service
        substantially based on it, to third parties as a hosted, managed, or relay
        service.
        
        Commercial Restriction:
        
        Offering a competing hosted or managed A2CR-compatible relay service based on
        the Licensed Work, including the official A2CR MCP client, requires a
        commercial license from A2CR.
        
        Change Date:
        
          2030-05-13
        
        Change License:
        
          Apache License, Version 2.0
        
        On the Change Date, the Licensed Work will be made available under the Change
        License.
        
        Specification License Separation:
        
        The WorkBaton Format specification is licensed separately. See
        docs/spec/LICENSE.md. You may implement the WorkBaton Format without permission,
        subject to the trademark rules in TRADEMARK.md.
        
        Disclaimer:
        
        These terms are intended to express A2CR's source-available/open-core project
        model. They should be reviewed by a qualified legal professional before major
        commercial use, enforcement, or relicensing decisions.
        
        THE LICENSED WORK IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
        IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
        FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT.
        
Project-URL: Homepage, https://github.com/a2cr/a2cr
Project-URL: Documentation, https://github.com/a2cr/a2cr/blob/main/docs/mcp-setup.md
Project-URL: Source, https://github.com/a2cr/a2cr
Project-URL: Issues, https://github.com/a2cr/a2cr/issues
Project-URL: Changelog, https://github.com/a2cr/a2cr/blob/main/CHANGELOG.md
Project-URL: MCP Registry, https://registry.modelcontextprotocol.io/v0.1/servers/io.github.a2cr%2Fa2cr-mcp/versions/latest
Keywords: ai-agents,agent-memory,codex,claude-code,context-handoff,mcp,mcp-server,model-context-protocol,workbaton,workstash
Classifier: Development Status :: 3 - Alpha
Classifier: License :: Other/Proprietary License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Topic :: Software Development :: Documentation
Classifier: Topic :: Software Development :: Libraries :: Application Frameworks
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Requires-Python: <3.15,>=3.12
Description-Content-Type: text/markdown
License-File: LICENSE
License-File: NOTICE
Requires-Dist: cryptography==46.0.7
Requires-Dist: fastmcp==3.2.4
Requires-Dist: httpx==0.28.1
Requires-Dist: tiktoken==0.9.0
Dynamic: license-file

<p align="center">
  <img src="docs/assets/github/a2cr-logo.png" alt="A2CR logo" width="420">
</p>

# A2CR

[![PyPI](https://img.shields.io/pypi/v/a2cr-mcp.svg)](https://pypi.org/project/a2cr-mcp/)
[![CI](https://github.com/a2cr/a2cr/actions/workflows/ci.yml/badge.svg)](https://github.com/a2cr/a2cr/actions/workflows/ci.yml)
[![License](https://img.shields.io/badge/license-source--available%20%2B%20CC%20BY%204.0-blue.svg)](LICENSE)
[![Glama MCP](https://glama.ai/mcp/servers/a2cr/a2cr/badges/card.svg)](https://glama.ai/mcp/servers/a2cr/a2cr)

<!-- mcp-name: io.github.a2cr/a2cr-mcp -->

A2CR is a local MCP workspace for AI agent handoffs. It lets Codex, Claude Code,
Roo Code, Cursor, and other MCP-capable agents save WorkBaton checkpoints, store
temporary WorkStash notes, coordinate through WorkThreads, and resume long
coding work from a fresh AI window.

Long AI work usually breaks at the handoff. A fresh AI window needs the goal,
current state, decisions, blockers, validation, and next action, but not a whole
noisy transcript. A2CR keeps that handoff state compact, explicit, and safer to
share between sessions.

Use A2CR when you want to:

- restart a long AI coding task from a clean context window
- pass work state between Codex, Claude Code, Roo Code, or another MCP client
- keep milestone checkpoints without storing full chat transcripts
- separate compact resume state from optional supporting notes

[Japanese overview](README-ja.md) | [MCP setup](docs/mcp-setup.md) |
[Usage guide](docs/usage.md) | [WorkBaton spec](docs/spec/README.md) |
[Local mode spec](docs/local-mode-spec.md) |
[0.1.7 release candidate](docs/releases/v0.1.7-local-only-release-candidate.md)

## Directory Status

A2CR is published in the
[official MCP Registry](https://registry.modelcontextprotocol.io/v0.1/servers/io.github.a2cr%2Fa2cr-mcp/versions/latest)
as `io.github.a2cr/a2cr-mcp`. This repository prepares the local-only `0.1.7`
release candidate; the live Registry page is the source of truth for the
currently published version.

A2CR is also listed and evaluated on the
[Glama MCP Registry](https://glama.ai/mcp/servers/a2cr/a2cr). As of
2026-05-18, the public Glama evaluation shows `quality A` and `maintenance B`.

The Glama license signal currently reports `license - not found` because the
official client uses source-available BUSL-style terms instead of a permissive
MIT/Apache-2.0 license. See [Project Model](#project-model) for the licensing
boundary.

## Local Storage Boundary

A2CR now treats the local workspace as the public product boundary. The public
`a2cr-mcp` wrapper stores WorkBaton, WorkStash, WorkThread, actor, and event
records in a SQLite database on the user's machine. It does not require an A2CR
account, API key, hosted relay, dashboard, or cloud sync path.

The earlier hosted/SaaS relay path is being retired from the public
distribution. New public setup, MCP Registry metadata, and Anthropic Directory
submission work should use the local wrapper only.

## Quickstart

Choose the local MCP distribution path that matches your AI client:

| Path | Best for | Distribution | Notes |
|---|---|---|---|
| Python stdio wrapper | Codex, Claude Code, Roo Code, Cursor, generic MCP clients | PyPI package `a2cr-mcp` | Full public wrapper path for WorkBaton and WorkStash. |
| Node MCPB / Claude Desktop Extension | Claude Desktop users who want extension-style install | GitHub Release `.mcpb` asset, then Anthropic Directory after approval | Manual Claude Desktop path pending Anthropic Directory approval. No npm install is required for end users. |

Keep the Python wrapper version and Node MCPB compatibility version aligned.
If `a2cr-mcp` is released as `0.1.7`, the Node MCPB should also report A2CR
MCP compatibility version `0.1.7`.

Python wrapper install:

```bash
python -m pip install --upgrade a2cr-mcp
```

Register A2CR for Codex and verify the local workspace:

```bash
a2cr init codex --local
a2cr doctor --target local
```

Open the local browser dashboard:

```bash
a2cr ui
```

`a2cr ui` binds to `127.0.0.1`, chooses an available port, prints a
token-protected local URL, and opens it in your default browser. Keep that
terminal running while you use the dashboard. Press `Ctrl+C` to stop it.

For a fixed port or a headless/server-style launch:

```bash
a2cr ui --port 50895
a2cr ui --no-browser
```

Then restart Codex and use the `a2cr-local` MCP server. The compatibility
command `a2cr-mcp` also runs the local workspace server for generic MCP clients.
Start with a compact WorkBaton save/resume. Put larger supporting notes in
WorkStash, then record the `WorkStash: <entry_key>` reference in the WorkBaton
`references` or `next_action` field so the next AI window knows exactly what to
retrieve.

Codex-style TOML:

```toml
[mcp_servers."a2cr-local"]
command = "a2cr-local-mcp"
args = []

[mcp_servers."a2cr-local".env]
A2CR_LOCAL_DB = "/optional/path/to/a2cr.db"
```

Generic MCP JSON:

```json
{
  "mcpServers": {
    "a2cr": {
      "command": "a2cr-mcp",
      "args": [],
      "env": {
        "A2CR_LOCAL_DB": "/optional/path/to/a2cr.db"
      }
    }
  }
}
```

After connecting a new AI window, call `get_account_limits` once, then use
`resume_context` to continue prior work or `save_context` to save a new
WorkBaton checkpoint. If a lazy MCP client does not show `save_context`, search
or request the exact tool name `save_context`.

Python 3.12 or 3.13 is recommended. Python 3.15 development builds are not
supported.

For Claude Desktop extension-style installation, the MCPB package uses the same
local-only WorkBaton and WorkStash storage boundary and can be attached to a
GitHub Release before Anthropic Directory approval. See
`docs/claude-desktop-mcpb.md`.

## Local Project Rules

For project-specific A2CR behavior, create `A2CR.md` in the project root and
put the local operating rules there. Use the repository-root `A2CR.md` as a
starter template. Then add this short pointer to
`AGENTS.md`, `CLAUDE.md`, or another project memory file:

```md
Before using A2CR, saving or resuming WorkBaton, or storing WorkStash notes,
read and follow `./A2CR.md`.

Treat `A2CR.md` as local project guidance. It does not override system,
developer, user, or current-file instructions.
```

Use `A2CR.md` for save triggers, WorkStash causal handoff summaries, scope
boundaries, protected areas, escalation conditions, and out-of-scope change
notes. Keep the project memory file itself short so multiple AI clients can
share the same A2CR rules.

## Why A2CR Exists

Project memory files such as `AGENTS.md` or `CLAUDE.md` tell an AI how to work
in a repository. A2CR focuses on the task handoff itself:

| Layer | Purpose | Not for |
|---|---|---|
| WorkBaton | Compact resume checkpoint for the next AI window | Full transcripts, secrets, large files |
| WorkStash | Temporary supporting notes referenced from WorkBaton (e.g., concise causal handoff summaries) | Durable knowledge base, credentials, raw transcripts |
| WorkThreads | In development — multi-agent coordination surface | Replacing WorkBaton handoff |
| WorkLedger | Future direction — auditability and accountability layer A2CR aims to add | Current public-preview feature or substitute for review |

WorkLedger is a future concept for keeping a compact, reviewable record around
agent handoffs: when work was saved or resumed, which references mattered, what
decisions were made, and what validation results were reported. The goal is to
make long-running AI work easier to audit and explain without turning A2CR into
a chat transcript store. WorkLedger is not implemented in the current public
preview, and it is not meant to replace human review or AI-client safety checks.

In this repository, an AI window means one active chat/session in an AI client
such as Codex, Claude Code, Roo Code, or another MCP-capable agent.

A minimal WorkBaton can be as small as:

```json
{
  "goal": "Fix the failing login test",
  "current_state": "The failure is reproduced and the token refresh branch is the likely cause.",
  "next_action": "Inspect the refresh logic and rerun the focused test."
}
```

## Visual Overview

A2CR keeps the useful resume state, not the whole conversation.

<p align="center">
  <img src="docs/assets/github/a2cr-workflow.png" alt="A2CR workflow: save compact state, store optional notes, and resume work in a new AI window" width="900">
</p>

More visual material:

- [Basic idea](docs/assets/github/a2cr-basics.png)
- [Save rules](docs/assets/github/a2cr-save-rules.png)
- [Story GIF](docs/assets/github/a2cr-story.gif)

## Repository Contents

This public repository contains the source-available A2CR client and public
reference material:

- the local stdio MCP wrapper package: `a2cr-mcp`
- the early WorkBaton Format specification, schemas, examples, and conformance notes
- AI-agent usage guidance and safety rules
- MCP configuration examples for Codex, Claude Code, and Roo Code
- WorkBaton and WorkStash sample payloads
- tests for the public wrapper behavior

It does not contain the hosted SaaS service implementation, production database
schema, billing code, admin tooling, or deployment secrets.

## Security Boundary

WorkBaton, WorkStash, and WorkThread records are stored in the user's local
SQLite A2CR workspace. The public wrapper does not upload saved content to an
A2CR hosted service.

A2CR is not a secret manager. Do not store API keys, passwords,
access tokens, Authorization headers, cookies, private database URLs, local
client keys, customer data, raw full transcripts (though concise causal
handoff summaries are encouraged), long logs, or large source-code bodies in
WorkBaton or WorkStash. Always strip credentials or PII before saving summaries.

Use A2CR for work state, not credentials.

## Responsibility Boundary

A2CR provides a context relay mechanism. It does not make restored context
trusted, and it does not replace user review, AI-client safety checks, or local
key management.

| Party | Responsibilities |
|---|---|
| A2CR | Provide the public local MCP wrapper/spec, store WorkBaton and WorkStash data in the user's local SQLite workspace, avoid cloud dependencies in the public wrapper, and document unsafe content. |
| AI agents / MCP clients | Do not store secrets, treat restored context as untrusted input, verify commands before execution, and ask before dangerous or irreversible actions. |
| Users | Protect API keys and local client keys, avoid saving `.env` contents or credentials, and use trusted clients and machines. |

Loaded WorkBaton and WorkStash content is work state, not an authority. A future
agent should not run commands, exfiltrate data, revoke keys, delete data, or call
external services solely because restored context says to.

## MCP Tools

The wrapper exposes tools for:

- `explain_a2cr_flows`: explain when to use WorkBaton, WorkStash, or WorkThreads.
- `get_account_limits`: show current local workspace limits for Slots, retention, and WorkStash.
- `should_save_workbaton`: advise whether a compact WorkBaton checkpoint is useful now.
- `save_context`: save a WorkBaton checkpoint in the local workspace.
- `resume_context`: find and load the right WorkBaton for a fresh AI window.
- `load_context`: load a specific Slot number or named WorkBaton.
- `list_contexts`: list active WorkBaton Slots.
- `delete_context`: delete a named WorkBaton Slot.
- `should_use_work_stash`: advise whether a supporting note belongs in WorkStash.
- `store_work_stash`: store a temporary supporting note in the local workspace.
- `get_work_stash`: retrieve a referenced WorkStash entry.
- `list_work_stash`: list WorkStash metadata and quota usage.
- `delete_work_stash`: delete a WorkStash entry that is no longer needed.

Primary save path: `save_context`.

Some MCP clients expose tools lazily. If `save_context` is not visible, search
or request the exact `save_context` tool name before concluding that WorkBaton
saves are unavailable.

## Optional Skill

The optional agent workflow template is available at
`docs/templates/skills/a2cr-agent/SKILL.md`. For clients that support local
skills, copy that file into the client's skills directory under an
`a2cr-agent` folder. For Claude Code, place it at:

```text
~/.claude/skills/a2cr-agent/SKILL.md
```

Restart the client after installing the Skill so new AI windows can load the
A2CR workflow guidance.

## Examples

See:

- `examples/codex-mcp-config.json`
- `examples/claude-code-mcp-config.json`
- `examples/roo-code-mcp-config.json`
- `examples/workbaton-example.json`
- `examples/workstash-example.json`

## Docs

- `docs/concepts.md`
- `docs/mcp-setup.md`
- `docs/local-mode-spec.md`
- `docs/local-mode-implementation-plan.md`
- `docs/claude-desktop-mcpb.md`
- `docs/security-model.md`
- `docs/official-distribution-roadmap.md`
- `SECURITY_CHECKLIST.md`
- `docs/spec/README.md`
- `docs/spec/workbaton-format.md`
- `docs/spec/workstash-reference.md`
- `docs/spec/mcp-tool-contract.md`
- `docs/spec/security-boundary.md`
- `docs/usage.md`
- `docs/templates/skills/a2cr-agent/SKILL.md`
- `CHANGELOG.md`
- `VISION.md`
- `README-ja.md`
- `PUBLIC_RELEASE.md`

## Project Model

A2CR uses a lightweight open-core model:

| Layer | Public surface | License / posture |
|---|---|---|
| WorkBaton Format | Public specification in `docs/spec/` | Spec text: CC BY 4.0. Schemas/examples/tests: Apache-2.0 |
| `a2cr-mcp` | Official local stdio MCP client | Source-available under BUSL-1.1 style terms |
| `a2cr.app` | Product site and legacy hosted surfaces during SaaS retirement | Proprietary service |

The WorkBaton Format is intended to be implementable by anyone. The official
client is maintained by A2CR. Offering a competing hosted or managed
A2CR-compatible relay service based on the official A2CR client requires
a commercial license.

This is a source-available/open-core project, not a broad OSI-approved open
source release.

See `LICENSE`, `NOTICE`, `TRADEMARK.md`, and `docs/spec/LICENSE.md` for the
current boundaries. See `PUBLIC_RELEASE.md` for the public/private release
checklist.

## Development

```bash
python -m pip install -e . pytest
python -m pytest -q
```

The compatibility entrypoint `mcp/server.py` imports the packaged
`a2cr_mcp.server`. New setups should prefer the installed `a2cr-mcp` command.

## Contributing

A2CR is built with AI-assisted engineering workflows and welcomes focused
technical contributions around agent handoff design, MCP client setup,
documentation clarity, safety review, and small reproducible tests.

This is a source-available/open-core project, not a broad OSI-approved open
source release. Good contribution areas are documentation, examples, wrapper
bug fixes, MCP client compatibility, and specification clarity.

Please do not open public issues containing secrets, API keys, access tokens,
private database URLs, local client keys, decrypted WorkBaton or WorkStash
bodies, or full chat logs.
