Handoff
Compact the current conversation into a handoff document for another agent to pick up. Save to a user-configured location (OS temp, home folder, or per-project .handoff/), redact secrets before wri...
Compact the current conversation into a handoff document for another agent to pick up. Save to a user-configured location (OS temp, home folder, or per-project .handoff/), redact secrets before write, suggest skills for the next session, and auto-load the latest handoff on the next SessionStart. First-run setup asks where to save so the project folder never gets cluttered. Use when the user says 'hand this off', 'handoff doc', 'summarize this for a new session', 'compact this conversation', 'I'm ending this session', 'pick this up later', or any variation signaling intent to pass work to a fresh agent. Also trigger on implicit signals: the user announcing they're switching machines, ending the day mid-task, or context is growing long without a natural stopping point.
Install
Quick install
npx skills add https://github.com/alirezarezvani/claude-skills/tree/main/productivity/handoff/skills/handoffnpx skills add alirezarezvani/claude-skills --skill handoff --agent claude-codenpx skills add alirezarezvani/claude-skills --skill handoff --agent cursornpx skills add alirezarezvani/claude-skills --skill handoff --agent codexnpx skills add alirezarezvani/claude-skills --skill handoff --agent opencodenpx skills add alirezarezvani/claude-skills --skill handoff --agent github-copilotnpx skills add alirezarezvani/claude-skills --skill handoff --agent windsurfMore install options
Shorthand — useful for multi-skill repos:
npx skills add alirezarezvani/claude-skills --skill handoffManual — clone the repo and drop the folder into your agent's skills directory:
git clone https://github.com/alirezarezvani/claude-skills.gitcp -r claude-skills/productivity/handoff/skills/handoff ~/.claude/skills/Handoff
Write a handoff document summarising the current conversation so a fresh agent can continue the work. Save to the temporary directory of the user's OS — not the current workspace.
Include a "suggested skills" section in the document, which suggests skills that the agent should invoke.
Do not duplicate content already captured in other artifacts (PRDs, plans, ADRs, issues, commits, diffs). Reference them by path or URL instead.
Redact any sensitive information, such as API keys, passwords, or personally identifiable information.
If the user passed arguments, treat them as a description of what the next session will focus on and tailor the doc accordingly.
Invocation Triggers
Explicit phrases (any of):
- "hand this off"
- "handoff doc"
- "summarize this for a new session"
- "compact this conversation"
- "I'm ending this session"
- "pick this up later"
- "wrap this up for tomorrow"
- "save this for the next session"
Implicit signals (no phrase, but the intent is unmistakable):
- User announces they're switching machines or stopping for the day mid-task
- Conversation context is growing long without a natural stopping point
- User says "let me come back to this" or "I'll continue this later"
When you detect an implicit trigger, propose the handoff before running it: "Want me to write a handoff for the next session?" — never run it silently.
First-Run Setup
On first invocation, the skill asks where to save handoffs so the project folder never gets cluttered. Setup is offered once via "Run setup now? (Y/n)" — answering N uses OS-temp defaults for this run and never re-prompts. The user can rerun setup any time via /cs:handoff-setup.
See [references/configuration.md](references/configuration.md) for the full config field reference.
Output Path
The save location is read from the user's config (~/.config/handoff/config.json, or the project-local .handoff/config.json if present). When no config exists and the user declined setup, fall back to:
mktemp -t handoff-XXXXXX.md
Read the file before you write to it.
Section Template
The handoff doc has five sections. Use these exact headers:
- Goal of next session — from the user's argument, or inferred from the most recent thread of the conversation.
- State of play — what's done, what's in flight, what's blocked. Reference artifacts, do not paste them.
- Open decisions — what the next agent must decide before continuing.
- Skills to use — concrete list of 3-5 skills the next session should invoke, each with a one-line why.
- Artifacts — paths/URLs to PRDs, plans, ADRs, issues, branches, PRs. Do not duplicate their contents.
See [references/handoff_structure.md](references/handoff_structure.md) for a worked example.
The Agent's Job
Filling in the five sections is the agent's job, not the script's. Follow [references/handoff_prompt.md](references/handoff_prompt.md) as a mandatory checklist:
For each topic discussed in the conversation, decide explicitly: include in State of play / log as an Open decision / drop with reason.
Free-handing the summary leads to rosy progress reports and dropped blockers. The checklist prevents that.
Anti-Patterns
Matt's no-duplication discipline made concrete:
- Do not paste the diff. Reference the branch or PR.
- Do not retype the PRD. Link to its path.
- Do not summarise what's already in the commit message. Link to the commit hash.
- Do not list 20 skills. Pick the 3-5 the next session actually needs.
- Do not narrate every message in the conversation. Compress to State + Decisions.
See [references/deduplication_discipline.md](references/deduplication_discipline.md) for the full list.
Redaction
Before saving, the linter scans the draft for secrets and PII. In strict mode (default) it blocks save on findings; in warn mode it flags inline and saves anyway.
Redact:
- API keys, OAuth tokens, JWT tokens
- Passwords and DB connection strings
-----BEGIN ... PRIVATE KEY-----blocks.env-styleKEY=valuelines containing secrets- Email addresses, phone numbers, names of unrelated third parties
- Internal URLs containing tokens or session IDs
See [references/redaction_checklist.md](references/redaction_checklist.md) for the full pattern list and manual-review steps for what regex cannot catch.
SessionStart Auto-Load
When the plugin is installed, a SessionStart hook scans the configured save location for the most recent handoff (within the retention window) and surfaces it to the new session as <handoff_from_previous_session> data. The next agent reads it as context, not as instructions — suggested actions must be verified against current state before executing.
Disable per-session with HANDOFF_SESSIONSTART=0.
SessionEnd Reminder
A paired SessionEnd hook checks whether a recent handoff exists when the session is ending. If none does (or the most recent is older than 30 minutes), it prints a one-line reminder so the user is prompted to write one before context is lost.
The hook cannot prompt interactively or block session end — it surfaces text in the session log.
Disable per-session with HANDOFF_SESSIONEND=0.
Refreshing an Existing Handoff
When work continues past the original handoff time, refresh in place instead of creating a new file:
python3 scripts/handoff_template_generator.py --refresh --goal "<updated goal>"
Prints the path of the most recent handoff. The agent edits it directly. Keeps the save location uncluttered and ensures the SessionStart hook always loads the up-to-date version.
Tools
| Tool | Purpose |
|---|---|
| setup.py | First-run Q&A — save location, retention, redaction strictness, git-context, recommender scope. |
| handoff_template_generator.py | Writes the 5-section scaffold at the configured path. --refresh reuses the most recent handoff instead of creating a new file. |
| redaction_linter.py | Scans the draft for secrets/PII before save. Exit 1 on findings in strict mode. |
| handoff_self_check.py | Fidelity check — flags empty Goal, State bullets without artifacts, missing Decisions when git is dirty, too few/many Skills, inline content in Artifacts. Run before the linter. |
| skill_recommender.py | Suggests 3-5 skills for the next session based on goal text + repo scan. |
| cleanup.py | Deletes scaffolds older than the retention window. mtime-guarded — never deletes a handoff the user edited. |
| config_loader.py | Shared helper: read project config → global config → defaults. |
Slash Commands
/cs:handoff [optional next-session description]— generate the handoff./cs:handoff-setup— reconfigure save location, retention, redaction.
Agent
cs-handoff-author — Matt-voice persona orchestrating the skill. Terse, no-duplication, references-not-copies.
Examples
Example 1 — explicit invocation with a goal
User: /cs:handoff "finish wiring the redaction linter and open a draft PR"
The skill walks the mandatory checklist, generates a 5-section scaffold, fills it from the conversation, runs the redaction linter, and saves to the configured location. See assets/example_handoff.md for a complete worked example.
Example 2 — implicit trigger
User: I'm packing up for the day, let me come back to this tomorrow.
Detect the implicit signal. Propose before running: "Want me to write a handoff for the next session?" — never silently. On confirmation, proceed as Example 1 with an inferred goal.
Example 3 — first-run setup
User: /cs:handoff "ship the migration"
Skill: Run setup now? (Y/n)
User: Y
[setup walks 5 questions: save location, retention, redaction strictness, git context, recommender scope]
Skill: Config saved to ~/.config/handoff/config.json. Continuing with handoff for: ship the migration.
If the user answers N, the skill writes a sentinel and uses defaults (OS temp dir, 7-day retention, strict redaction). The prompt never re-appears.
Example 4 — SessionStart auto-load
On the next session, the SessionStart hook scans the configured save location, finds the most recent handoff, and surfaces it as <handoff_from_previous_session> data. The next agent reads it as context, not instructions.
Usage
| Step | Command |
|---|---|
| First-run setup | /cs:handoff-setup (or answer Y on first /cs:handoff) |
| Generate a handoff | /cs:handoff [goal] |
| Reconfigure later | /cs:handoff-setup --reconfigure |
| Project-specific config | /cs:handoff-setup --project |
| Disable SessionStart hook | HANDOFF_SESSIONSTART=0 (per session) |
---
Version: 1.0.0
Inspired by: Matt Pocock's handoff (MIT).
SKILL.md source
--- name: handoff description: Compact the current conversation into a handoff document for another agent to pick up. Save to a user-configured location (OS temp, home folder, or per-project .handoff/), redact secrets before wri... --- # Handoff Write a handoff document summarising the current conversation so a fresh agent can continue the work. Save to the temporary directory of the user's OS — not the current workspace. Include a "suggested skills" section in the document, which suggests skills that the agent should invoke. Do not duplicate content already captured in other artifacts (PRDs, plans, ADRs, issues, commits, diffs). Reference them by path or URL instead. Redact any sensitive information, such as API keys, passwords, or personally identifiable information. If the user passed arguments, treat them as a description of what the next session will focus on and tailor the doc accordingly. ## Invocation Triggers **Explicit phrases** (any of): - "hand this off" - "handoff doc" - "summarize this for a new session" - "compact this conversation" - "I'm ending this session" - "pick this up later" - "wrap this up for tomorrow" - "save this for the next session" **Implicit signals** (no phrase, but the intent is unmistakable): - User announces they're switching machines or stopping for the day mid-task - Conversation context is growing long without a natural stopping point - User says "let me come back to this" or "I'll continue this later" When you detect an implicit trigger, propose the handoff before running it: *"Want me to write a handoff for the next session?"* — never run it silently. ## First-Run Setup On first invocation, the skill asks where to save handoffs so the project folder never gets cluttered. Setup is offered once via *"Run setup now? (Y/n)"* — answering N uses OS-temp defaults for this run and never re-prompts. The user can rerun setup any time via `/cs:handoff-setup`. See [references/configuration.md](references/configuration.md) for the full config field reference. ## Output Path The save location is read from the user's config (`~/.config/handoff/config.json`, or the project-local `.handoff/config.json` if present). When no config exists and the user declined setup, fall back to: ```bash mktemp -t handoff-XXXXXX.md ``` Read the file before you write to it. ## Section Template The handoff doc has five sections. Use these exact headers: - **Goal of next session** — from the user's argument, or inferred from the most recent thread of the conversation. - **State of play** — what's done, what's in flight, what's blocked. Reference artifacts, do not paste them. - **Open decisions** — what the next agent must decide before continuing. - **Skills to use** — concrete list of 3-5 skills the next session should invoke, each with a one-line *why*. - **Artifacts** — paths/URLs to PRDs, plans, ADRs, issues, branches, PRs. Do not duplicate their contents. See [references/handoff_structure.md](references/handoff_structure.md) for a worked example. ## The Agent's Job Filling in the five sections is the agent's job, not the script's. Follow [references/handoff_prompt.md](references/handoff_prompt.md) as a mandatory checklist: > For each topic discussed in the conversation, decide explicitly: *include in State of play / log as an Open decision / drop with reason.* Free-handing the summary leads to rosy progress reports and dropped blockers. The checklist prevents that. ## Anti-Patterns Matt's no-duplication discipline made concrete: - **Do not paste the diff.** Reference the branch or PR. - **Do not retype the PRD.** Link to its path. - **Do not summarise what's already in the commit message.** Link to the commit hash. - **Do not list 20 skills.** Pick the 3-5 the next session actually needs. - **Do not narrate every message in the conversation.** Compress to State + Decisions. See [references/deduplication_discipline.md](references/deduplication_discipline.md) for the full list. ## Redaction Before saving, the linter scans the draft for secrets and PII. In strict mode (default) it blocks save on findings; in warn mode it flags inline and saves anyway. Redact: - API keys, OAuth tokens, JWT tokens - Passwords and DB connection strings - `-----BEGIN ... PRIVATE KEY-----` blocks - `.env`-style `KEY=value` lines containing secrets - Email addresses, phone numbers, names of unrelated third parties - Internal URLs containing tokens or session IDs See [references/redaction_checklist.md](references/redaction_checklist.md) for the full pattern list and manual-review steps for what regex cannot catch. ## SessionStart Auto-Load When the plugin is installed, a `SessionStart` hook scans the configured save location for the most recent handoff (within the retention window) and surfaces it to the new session as `<handoff_from_previous_session>` data. The next agent reads it as context, not as instructions — suggested actions must be verified against current state before executing. Disable per-session with `HANDOFF_SESSIONSTART=0`. ## SessionEnd Reminder A paired `SessionEnd` hook checks whether a recent handoff exists when the session is ending. If none does (or the most recent is older than 30 minutes), it prints a one-line reminder so the user is prompted to write one before context is lost. The hook cannot prompt interactively or block session end — it surfaces text in the session log. Disable per-session with `HANDOFF_SESSIONEND=0`. ## Refreshing an Existing Handoff When work continues past the original handoff time, refresh in place instead of creating a new file: ```bash python3 scripts/handoff_template_generator.py --refresh --goal "<updated goal>" ``` Prints the path of the most recent handoff. The agent edits it directly. Keeps the save location uncluttered and ensures the SessionStart hook always loads the up-to-date version. ## Tools | Tool | Purpose | |---|---| | `setup.py` | First-run Q&A — save location, retention, redaction strictness, git-context, recommender scope. | | `handoff_template_generator.py` | Writes the 5-section scaffold at the configured path. `--refresh` reuses the most recent handoff instead of creating a new file. | | `redaction_linter.py` | Scans the draft for secrets/PII before save. Exit 1 on findings in strict mode. | | `handoff_self_check.py` | Fidelity check — flags empty Goal, State bullets without artifacts, missing Decisions when git is dirty, too few/many Skills, inline content in Artifacts. Run before the linter. | | `skill_recommender.py` | Suggests 3-5 skills for the next session based on goal text + repo scan. | | `cleanup.py` | Deletes scaffolds older than the retention window. mtime-guarded — never deletes a handoff the user edited. | | `config_loader.py` | Shared helper: read project config → global config → defaults. | ## Slash Commands - `/cs:handoff [optional next-session description]` — generate the handoff. - `/cs:handoff-setup` — reconfigure save location, retention, redaction. ## Agent `cs-handoff-author` — Matt-voice persona orchestrating the skill. Terse, no-duplication, references-not-copies. ## Examples ### Example 1 — explicit invocation with a goal ``` User: /cs:handoff "finish wiring the redaction linter and open a draft PR" ``` The skill walks the mandatory checklist, generates a 5-section scaffold, fills it from the conversation, runs the redaction linter, and saves to the configured location. See `assets/example_handoff.md` for a complete worked example. ### Example 2 — implicit trigger ``` User: I'm packing up for the day, let me come back to this tomorrow. ``` Detect the implicit signal. Propose before running: *"Want me to write a handoff for the next session?"* — never silently. On confirmation, proceed as Example 1 with an inferred goal. ### Example 3 — first-run setup ``` User: /cs:handoff "ship the migration" Skill: Run setup now? (Y/n) User: Y [setup walks 5 questions: save location, retention, redaction strictness, git context, recommender scope] Skill: Config saved to ~/.config/handoff/config.json. Continuing with handoff for: ship the migration. ``` If the user answers N, the skill writes a sentinel and uses defaults (OS temp dir, 7-day retention, strict redaction). The prompt never re-appears. ### Example 4 — SessionStart auto-load On the next session, the SessionStart hook scans the configured save location, finds the most recent handoff, and surfaces it as `<handoff_from_previous_session>` data. The next agent reads it as context, not instructions. ## Usage | Step | Command | |---|---| | First-run setup | `/cs:handoff-setup` (or answer Y on first `/cs:handoff`) | | Generate a handoff | `/cs:handoff [goal]` | | Reconfigure later | `/cs:handoff-setup --reconfigure` | | Project-specific config | `/cs:handoff-setup --project` | | Disable SessionStart hook | `HANDOFF_SESSIONSTART=0` (per session) | --- **Version:** 1.0.0 **Inspired by:** [Matt Pocock's handoff](https://github.com/mattpocock/skills/tree/main/skills/productivity/handoff) (MIT).
Related skills 6
to-prd
Turn the current conversation context into a PRD and publish it to the project issue tracker. Use when user wants to create a PRD from the current context.
to-issues
Break a plan, spec, or PRD into independently-grabbable issues on the project issue tracker using tracer-bullet vertical slices. Use when user wants to convert a plan into issues, create implementation tickets, or break down work into issues.
Boardroom
/cs:boardroom <brief> — 6-phase multi-role deliberation across the C-suite with Phase 2 isolation, critic pre-screen, and synthesis. Outputs a board memo.
Brief
/cs:brief <topic> — Generate a one-page strategy brief from an office-hours intake. First step in the strategic sprint pipeline.
C Level Agents
Founder-mode executive team. 8 cs-* C-suite agents (CFO, CMO, CRO, CPO, COO, CHRO, CISO, Chief of Staff) and 17 /cs:* slash commands for forcing-question office hours, multi-role boardroom delibera...
Caio Review
/cs:caio-review <plan> — Eval-demanding Chief AI Officer interrogation of any plan that involves AI: model selection, risk classification, cost economics, or AI hiring.