From posthog
Finds the most informative PostHog session replay for an error tracking issue by ranking linked recordings on recency, activity score, journey completeness, and summarizing pre-error context.
npx claudepluginhub anthropics/claude-plugins-official --plugin posthogThis skill uses the workspace's default tool permissions.
When a user says "show me a replay for this error" or "find a recording for issue X",
Investigates PostHog session recordings by fetching metadata, person profiles, same-session events via SQL, and linked error tracking issues in parallel. Use on provided recording or session ID.
Generates reproducible bug steps from Amplitude Session Replays by finding error sessions, extracting interaction timelines, and identifying failure sequences. Useful for user bug reports, repro requests, or error spikes.
Analyzes Sentry session replays from external users to surface UX patterns, pain points, and user journeys for product areas like issues, traces, or dashboards.
Share bugs, ideas, or general feedback.
When a user says "show me a replay for this error" or "find a recording for issue X", the goal isn't just any linked session — it's the one that best shows what led to the error. Popular issues can have hundreds of linked sessions, and most are crash-only fragments or duplicate occurrences. This skill picks the most useful one.
| Tool | Purpose |
|---|---|
posthog:error-tracking-issues-retrieve | Get issue details (fingerprint, status, volume) |
posthog:execute-sql | Query exception events to find linked sessions |
posthog:query-session-recordings-list | Fetch recording metadata for candidate sessions |
posthog:session-recording-get | Get full details for the selected recording |
posthog:session-recording-summarize | AI summary of the selected recording (optional, slow) |
Fetch the error tracking issue to understand what you're looking for:
posthog:error-tracking-issues-retrieve
{
"id": "<issue_id>"
}
Note the issue's fingerprint, name, and description — you'll need the fingerprint
to find linked sessions.
Query exception events to get session IDs where this error occurred. Order by recency and include basic context:
posthog:execute-sql
SELECT
$session_id AS session_id,
count() AS occurrences,
min(timestamp) AS first_seen,
max(timestamp) AS last_seen,
any(properties.$current_url) AS url
FROM events
WHERE event = '$exception'
AND properties.$exception_fingerprint = '<fingerprint>'
AND $session_id IS NOT NULL
AND timestamp > now() - INTERVAL 30 DAY
GROUP BY session_id
ORDER BY last_seen DESC
LIMIT 20
This gives you up to 20 candidate sessions. More candidates means better selection.
Fetch recording metadata for the candidate sessions to rank them:
posthog:query-session-recordings-list
{
"session_ids": ["<id1>", "<id2>", "<id3>", ...],
"date_from": "-30d"
}
Pick the best recording by filtering out bad candidates, then ranking what's left:
Filter out:
Rank by:
active_seconds to recording_duration. A 20-minute
recording with 10 seconds of activity is mostly idle tabs — the user walked away.
Prefer sessions where active_seconds / recording_duration is above 0.3 (30%).activity_score means the user was actively interacting,
not idle. More interesting to watch.Fetch full details for the selected recording:
posthog:session-recording-get
{
"id": "<best_recording_id>"
}
Present to the user:
url and first_seen columns)If the user wants a narrative summary without watching:
posthog:session-recording-summarize
{
"session_ids": ["<best_recording_id>"],
"focus_area": "<error description or type>"
}
Warn that this takes ~5 minutes for first-time summaries.
$session_id is null on many exception events, session replay may not be enabled
for the affected users. Mention this as a possible gap.focus_area parameter on session-recording-summarize is powerful here —
pass the exception type or message so the summary focuses on the error context
rather than the entire session.