Skip to main content

Universal AI chat to local agent handover tool

Project description

handover

Design in chat. Build in terminal. Zero context lost.

handover is an open-source CLI tool that bridges AI chat interfaces (Claude, ChatGPT, Gemini, and others) to local terminal coding agents (Claude Code, Codex CLI, Copilot, Aider, Goose, etc.). It extracts decisions, plans, and intent from a chat conversation and generates agent-specific handover artifacts — the exact files each coding agent expects — so a local agent can immediately act on your intent without re-explaining anything.

Each target adapter knows what its agent needs: Claude Code gets CLAUDE.md + PLAN.md, Codex gets AGENTS.md + TASKS.md, Copilot gets .github/copilot-instructions.md, and so on. The parsing and extraction happen once; each target decides how to express the result.

PyPI version Python versions License: MIT CI


Install

pip install handover

Optional extras:

pip install handover[watch]   # enables: handover watch (session file monitoring)
pip install handover[mcp]     # enables: handover mcp (MCP server for Claude Code)

Quickstart

# Basic usage — single conversation file
handover --input conversation.json --output ./my-project/

# List all conversations in a bulk export
handover list export.jsonl

# Bulk export — select a specific conversation by title
handover --input export.jsonl --title "API Design Discussion" --output ./my-project/

# Incremental update — merge new context into existing .handover/ (v1.2.0)
handover update --input follow-up.json --output ./my-project/

# List conversations grouped by project (v1.2.0)
handover list export.jsonl --by-project

# Merge conversations by project name (v1.2.0)
handover merge --input export.jsonl --project "API Design" --output ./my-project/

--dry-run Demo

$ handover --input chat.json --output ./my-project/ --no-llm --dry-run

Parsing: 'API Design Discussion'
  Source : claude (single-json v1.0)
  Messages: 34

Extracted:
  Goal       : Build a FastAPI REST API with JWT auth and PostgreSQL
  Tech Stack : Python, FastAPI, PostgreSQL, pytest
  Decisions  : 2
  Tasks      : 6
  Constraints: 2
  Questions  : 1

Target: claude-code  |  Would write to ./my-project/:
  -> CLAUDE.md
  -> PLAN.md

Run without --dry-run to write files.

Supported Input Formats

Source Format How to Export
Claude.ai bulk export .jsonl Settings → Privacy → Export Data
Claude.ai single chat .json / .md Claude Conversation Exporter browser extension
ChatGPT .json Settings → Data Controls → Export Data
Gemini .json Google Takeout → Gemini Apps Activity
Perplexity .json Settings → Account → Export Data

Two-Layer Output (v1.1.0)

Every run produces two layers:

  1. .handover/ — vendor-neutral knowledge base (always generated): manifest, context (overview, architecture, ADR-style decisions, constraints, risks, acceptance criteria), work plan (spec, tasks, milestones, backlog JSON), standards, and 6 drop-in prompts. Portable across any agent.
  2. Per-target workspace — for claude-code, a thin CLAUDE.md index plus .claude/agents, .claude/skills, .claude/commands, .claude/hooks, and settings.json, populated by domain detection on the chat.
your-project/
├── .handover/
│   ├── manifest.yaml
│   ├── context/   overview.md, architecture.md, decisions.md, ...
│   ├── work/      spec.md, tasks.md, milestones.md, backlog.json
│   ├── standards/ coding-standards.md, testing-standards.md, ...
│   ├── prompts/   implement.md, review.md, debug.md, ...
│   └── codebase/  structure.json, symbols.json, dependencies.json, index.md
├── .claude/
│   ├── agents/    backend-agent.md, database-agent.md, ...
│   ├── skills/    rest-conventions.md, ...
│   ├── commands/  run-tests.md, lint.md
│   ├── hooks/     pre-tool-use.sh
│   └── settings.json
├── CLAUDE.md      (thin index pointing into .handover/)
└── PLAN.md

Skip Layer 1 with --no-handover-dir, write only Layer 1 with --handover-dir-only, replace existing layers with --overwrite-handover-dir. See docs/handover-directory.md for the full layout and how to extend it.

Agent-Aware Output

handover parses your chat once and generates the files your chosen coding agent expects. Each target adapter owns its own filenames and format — Claude is one target, not the default mental model for the whole product.

Target Generated Files Agent
claude-code (default) CLAUDE.md + PLAN.md Claude Code
codex AGENTS.md + TASKS.md Codex CLI
copilot .github/copilot-instructions.md GitHub Copilot
aider .aider.conf.yml Aider
goose goose-context.json Goose
all All of the above All agents
handover --input chat.json --output ./my-project/ --target codex
handover --input chat.json --output ./my-project/ --target copilot
handover --input chat.json --output ./my-project/ --target all

CLI Reference

Chat export → agent context

handover --input <file> --output <dir> [OPTIONS]
Flag Default Description
--input, -i required Chat export file (.json, .jsonl, .md)
--output, -o required Directory to write output files
--source auto Force parser: claude, chatgpt, gemini, perplexity
--title Select conversation by title (substring match, for bulk exports)
--id Select conversation by ID (for bulk exports)
--target claude-code Output target (coding agent): claude-code, codex, copilot, aider, goose, all
--no-llm off Rule-based extraction only — no API key required
--dry-run off Preview what would be written, without writing
--launch off Run claude in output directory after writing
--template Path to custom Jinja2 templates directory (claude-code target only)
--publish off Publish generated artifacts to GitHub Gist after writing (requires gh CLI)
--no-handover-dir off Skip the .handover/ knowledge base (legacy v1.0.x output only)
--handover-dir-only off Generate .handover/ only, skip target-specific files
--overwrite-handover-dir off Replace an existing .handover/ (and .claude/) directory
--no-index off Skip the .handover/codebase/ index pass

Incremental update (v1.2.0)

Update an existing .handover/ directory with new conversation context — preserves completed task marks and manual edits.

handover update --input follow-up.json --output ./my-project/
handover update --input follow-up.json --output ./my-project/ --no-llm --dry-run
handover update --input follow-up.json --output ./my-project/ --no-conflict  # no conflict markers
Flag Default Description
--input, -i required New chat export file
--output, -o required Directory containing existing .handover/
--source auto Force parser
--title Select conversation by title
--id Select conversation by ID
--no-llm off Heuristic-only extraction
--dry-run off Show delta summary without writing
--no-conflict off Take latest decision silently (no conflict markers)

Explore exports

handover list <export_file>            # list all conversations in a bulk export
handover list export.jsonl --source claude
handover list export.jsonl --by-project  # group by project (v1.2.0)

Scaffold custom templates

handover init       # copies default templates to ~/.handover/templates/ for editing

Reverse handover — Claude Code session → HANDOVER.md

Generates HANDOVER.md from Claude Code session logs: what was accomplished, files changed, decisions made, and recommended next steps.

handover reverse --project .                          # auto-discover latest session
handover reverse --session ~/.claude/projects/…/abc.jsonl
handover reverse --project . --no-llm --dry-run

handover sessions                                     # list recent Claude Code sessions
handover sessions --project ~/my-app --limit 20

handover watch --project .                            # auto-generate when session goes idle
handover watch --project . --idle 30 --daemon         # background mode
# requires: pip install handover[watch]

Local bridge for browser extension

Starts an HTTP server that the Chrome/Firefox extension uses to send conversations directly from the browser.

handover serve                                   # port 7437 (H-A-N-D on phone keypad)
handover serve --port 7437 --output ~/my-app/
handover serve --no-llm --daemon                 # background mode

Endpoints: GET /health, POST /handover, POST /config
See docs/browser-extension.md for extension setup.

History & re-run

Every successful non-dry-run invocation is logged to ~/.handover/history.jsonl.

handover history                          # last 20 runs
handover history --limit 50
handover history --project ~/my-app/     # filter by output directory

handover rerun h_4a2955ab                # re-run a past handover by ID

Merge multiple exports

Combine two or more chat sessions into one unified CLAUDE.md + PLAN.md. Deduplicates tasks and decisions automatically.

handover merge --input session1.json --input session2.json --output ./my-project/
handover merge --input s1.json --input s2.json --output . --no-llm --target all
handover merge --input export.jsonl --project "API Design" --output ./my-project/  # v1.2.0

Share via GitHub Gist

# Publish after generating (requires gh CLI authenticated)
handover --input chat.json --output ./my-project/ --publish

# Pull shared handover artifacts
handover pull https://gist.github.com/user/abc123
handover pull abc123 --output ./my-project/

MCP server for Claude Code

Exposes handover as an MCP server so Claude Code (or any MCP client) can call it directly. Since v1.1.1 the server exposes four tools.

handover mcp
# requires: pip install handover[mcp]

Add to ~/.claude/mcp.json:

{
  "mcpServers": {
    "handover": {
      "command": "handover",
      "args": ["mcp"],
      "env": { "ANTHROPIC_API_KEY": "${ANTHROPIC_API_KEY}" }
    }
  }
}
Tool What it does
run_handover Parse a chat export and write .handover/ + .claude/
handover_status Read .handover/work/backlog.json and report progress
handover_reverse Summarise the latest Claude Code session into HANDOVER.md
handover_list List conversations inside a chat export file

Full reference: docs/mcp-server.md.


Roadmap

Version Phase What ships Status
v0.2.0 1 + 2 Claude, ChatGPT, Gemini, Perplexity → Claude Code ✅ Released
v0.3.0–v0.4.0 3 + 4 handover serve + browser extension; reverse handover (handover reverse, handover sessions, handover watch) ✅ Released
v0.5.0 5 Multi-target: Codex CLI, Aider, Goose; --target all ✅ Released
v1.0.0 6 MCP server, handover history, handover merge, Gist publish/pull ✅ Released
v1.1.0 Two-layer scaffold (.handover/ + .claude/) ✅ Released
v1.1.1 MCP server: four tools (run_handover, handover_status, handover_reverse, handover_list) ✅ Released
v1.1.2 Codebase indexer (.handover/codebase/): structure, symbols, dependencies, change impact ✅ Released
v1.2.0 Incremental update (handover update), multi-chat project grouping (--by-project, --project) ✅ Released
VS Code extension, GitHub Action Coming soon

Contributing

The primary contribution path is adding a new source adapter or output target. Each adapter is an isolated Python class anyone can own end-to-end.


License

MIT © 2026 Mohan Krishnaa Alavala

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

handover-1.2.0.tar.gz (178.8 kB view details)

Uploaded Source

Built Distribution

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

handover-1.2.0-py3-none-any.whl (119.2 kB view details)

Uploaded Python 3

File details

Details for the file handover-1.2.0.tar.gz.

File metadata

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

File hashes

Hashes for handover-1.2.0.tar.gz
Algorithm Hash digest
SHA256 9920b42e748c1241130913234b538cfe2bde991f130e1d34f568899963651c69
MD5 83b6f350467f2d6acff1529e4cb8fd9a
BLAKE2b-256 0721666023f80d3000129b58416a0bb2b5005cc849ca8c8a33b74c15a02f57db

See more details on using hashes here.

Provenance

The following attestation bundles were made for handover-1.2.0.tar.gz:

Publisher: release.yml on mohankrishnaalavala/handover

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

File details

Details for the file handover-1.2.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for handover-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1c95fcb8e8b322623df19082851b3c7c42be715423de4cdc6f0fee13877b60e0
MD5 cd8e617887f618c03544810186672989
BLAKE2b-256 2967387c8b5b635cd1b1c34d5902cdaa879c13a63499e04e8c17c832ac965d8b

See more details on using hashes here.

Provenance

The following attestation bundles were made for handover-1.2.0-py3-none-any.whl:

Publisher: release.yml on mohankrishnaalavala/handover

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