coaching-session-summarizer
Original:🇺🇸 English
Translated
2 scriptsChecked / no sensitive code detected
This skill should be used to summarize coaching or therapy session transcripts after a Fathom/Granola sync. The agent analyzes the transcript itself (no API key, runs on the subscription) and appends key insights, decisions, action items, and trail connections. Supports quick extraction or deep analysis with cross-session pattern detection.
4installs
Sourceglebis/claude-skills
Added on
NPX Install
npx skill4agent add glebis/claude-skills coaching-session-summarizerTags
Translated version includes tags in frontmatterSKILL.md Content
View Translation Comparison →Coaching Session Summarizer
Overview
Analyzes a coaching/therapy session transcript and appends a structured summary
(key insights, decisions, action items, deep analysis, connected trails) to the
note.
The agent (Claude Code) performs the analysis directly — reading the
transcript and writing the summary in this session. There is no Anthropic API
call and no billing; it runs entirely on the active subscription. A legacy
API-based script is kept only as a headless fallback (see bottom).
When to Use This Skill
- A new Fathom/Granola transcript was synced to the vault (coaching or therapy)
- User asks to summarize/analyze a session (or similar)
/summarize-session [file] - After or a Granola export, when a new
calendar-sync,*-coaching.md, or*-therapy.mdfile appears — offer to summarize it*-session.md
Workflow (agent-driven — default)
Do this in-session with native tools. No API key required.
Step 1 — Gather context
Run the deterministic helper to get the transcript text, previous sessions, and
the trail list in one shot:
bash
python3 ~/.claude/skills/coaching-session-summarizer/scripts/gather_context.py \
<transcript-file> --vault ~/Brains/brainIt prints:
- Previous sessions with the same participant (paths) — these only in deep mode, for cross-session pattern detection
Read - Available trails — pick 2–4 most relevant to link
- Session content — the summary + transcript to analyze (any prior AI-Generated Summary is stripped so re-runs stay clean)
Pass if the filename doesn't encode the person
(e.g. Granola exports titled by topic): .
--participant <name-slug>--participant gleb-kalininStep 2 — Analyze
Read the session content and extract, in the analytical voice of a session
analyst (objective, using the speaker's authentic language where it matters):
- Key Insights — 3–5 main realizations / breakthroughs / observations
- Decisions Made — concrete choices or commitments
- Action Items — specific next steps; prefix time-sensitive ones with
and scheduling items with
[URGENT][SCHEDULING] - Session Themes — 2–3 recurring topics or patterns
Deep mode (default for therapy and milestone sessions) — also the
previous sessions and add:
Read- Pattern Detection — themes recurring across sessions
- Progress Assessment — movement on earlier commitments
- Energy/Motivation Markers — shifts in energy, resistance, affect
- Potential Obstacles — what might block progress
Step 3 — Append with Edit
Append the summary to the end of the transcript file using (never
overwrite existing content). Match this exact structure:
Editmarkdown
## AI-Generated Summary
*Generated: YYYY-MM-DD*
### Key Insights
- ...
### Decisions Made
- ...
### Action Items
- [URGENT] ...
- ...
### Session Themes
- ...
## Deep Analysis
- **Pattern Detection**: ...
- **Progress Assessment**: ...
- **Energy/Motivation Markers**: ...
- **Potential Obstacles**: ...
## Connected Trails
- [[Trails/Trail - <Name>|<Name>]]
- [[Trails/Trail - <Name>|<Name>]]Use the current date () in the Generated line. Omit the Deep
Analysis section in quick mode. Verify trail link names against the printed
trail list — case and exact wording matter for Obsidian links.
date +%Y-%m-%dModes
- quick — Key Insights, Decisions, Action Items, Themes. Skip Deep Analysis and previous-session reads.
- deep (recommended for therapy / milestones) — everything, including reading previous sessions for pattern detection.
Integration with Sync
After or a Granola/Fathom export, check for new session files
(, , ). If one appears, offer:
"New session detected — summarize now?" Default to deep mode for therapy.
calendar-sync*-coaching.md*-therapy.md*-session.mdNotes
- Preserves the original transcript intact; the summary is always appended.
- Trail linking requires the directory in the vault root.
Trails/ - Cross-session comparison works best with consistent naming:
/
YYYYMMDD-name-coaching.md.YYYYMMDD-name-therapy.md - Re-running is safe: strips any prior AI-Generated Summary before printing, so the agent analyzes only the raw session. (Delete the old
gather_context.pyblock from the file before re-appending if you want to replace rather than stack summaries.)## AI-Generated Summary
Resources
scripts/
- gather_context.py — (default path) deterministic context gatherer, no API. Prints transcript text + previous sessions + trail list for the agent to analyze in-session.
- summarize_session.py — legacy / headless fallback. Calls the Anthropic
API directly (model via , default
SUMMARIZER_MODEL) and bills a fundedclaude-sonnet-4-6. Use only when no interactive agent is available (e.g. cron). Exits with a clear message if the key has no credit.ANTHROPIC_API_KEY