Metadata-Version: 2.4
Name: a2cr-mcp
Version: 0.1.5
Summary: A2CR local stdio MCP wrapper for WorkBaton and WorkStash.
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://a2cr.app/
Project-URL: Documentation, https://a2cr.app/en/manual
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 :: 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)

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

Agent-to-Agent Context Relay.

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 is a lightweight context relay layer for AI agents. It lets an agent save
a compact WorkBaton checkpoint, move optional supporting notes into WorkStash,
and resume the work from a fresh AI window.

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

[Japanese overview](README-ja.md)

## 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 | Durable knowledge base, credentials |
| WorkThreads | Planned multi-agent coordination surface | Replacing WorkBaton handoff |

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."
}
```

<p align="center">
  <img src="docs/assets/github/a2cr-story.gif" alt="A2CR turns long AI conversation history into compact WorkBaton and WorkStash handoff state" width="900">
</p>

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
- 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.

## Visual Overview

### 1. The Basic Idea

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

<p align="center">
  <img src="docs/assets/github/a2cr-basics.png" alt="A2CR basics: WorkBaton stores compact handoff state and WorkStash stores optional supporting notes" width="900">
</p>

### 2. Save Rules

Use A2CR for work state. Keep secrets, credentials, raw logs, and full
transcripts out.

<p align="center">
  <img src="docs/assets/github/a2cr-save-rules.png" alt="A2CR save rules and cautions: store only safe work state and avoid secrets or full logs" width="900">
</p>

### 3. Typical Workflow

Save a WorkBaton, optionally reference WorkStash notes, then resume from a fresh
AI window.

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

## Vision

A2CR starts with a modest goal: make AI handoffs small, explicit, testable, and
safer than copying a whole conversation history. Longer design notes and future
directions live in `VISION.md`.

## Install

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

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

## Security Boundary

WorkBaton and WorkStash bodies are encrypted locally by the stdio MCP wrapper
before upload. A2CR stores ciphertext and cannot decrypt those bodies.

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, full transcripts, long logs, or large source-code
bodies in WorkBaton or WorkStash.

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 MCP wrapper/spec, encrypt WorkBaton and WorkStash bodies locally before upload through the official wrapper, avoid storing user decryption keys in the hosted service, 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.

## Configure MCP

Create an A2CR API key from the hosted A2CR dashboard, then configure exactly
one local stdio MCP server named `a2cr`. `A2CR_BASE_URL` is optional; omit it to
use `https://a2cr.app`.

Codex-style TOML:

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

[mcp_servers."a2cr".env]
A2CR_API_KEY = "YOUR_A2CR_API_KEY"
A2CR_BASE_URL = "https://a2cr.app"
```

Generic MCP JSON:

```json
{
  "mcpServers": {
    "a2cr": {
      "command": "a2cr-mcp",
      "args": [],
      "env": {
        "A2CR_API_KEY": "YOUR_A2CR_API_KEY",
        "A2CR_BASE_URL": "https://a2cr.app"
      }
    }
  }
}
```

The local wrapper creates a client key file on first encrypted save. If you need
to resume the same WorkBaton from another PC, you need both the A2CR API key and
the same local client key file.

## MCP Tools

The wrapper exposes tools for:

- `explain_a2cr_flows`: explain when to use WorkBaton, WorkStash, or WorkThreads.
- `get_account_limits`: show the current account limits for Slots, retention, and WorkStash.
- `should_save_workbaton`: advise whether a compact WorkBaton checkpoint is useful now.
- `save_context`: save a client-encrypted WorkBaton checkpoint.
- `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 client-encrypted temporary supporting note.
- `get_work_stash`: retrieve and decrypt 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/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` | Hosted relay service, dashboard, billing, operations | Proprietary SaaS |

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

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.
