Back to Oh My Openagent

Coding Agent Sessions

packages/shared-skills/skills/coding-agent-sessions/SKILL.md

4.14.19.4 KB
Original Source

Coding Agent Sessions

Find local coding-agent sessions across agent products before answering from memory. Prefer the bundled finder for broad cross-platform search, then read the selected session or raw file when you need exact evidence.

PHASE 0 - PLATFORM ROUTER

  1. IF the user names a platform, load its reference first.

    PlatformRead
    Codex / OpenAI Codex CLIreferences/codex.md
    Claude Code / Claude Desktop historiesreferences/claude.md
    Senpi / pi coding-agent logsreferences/senpi.md
    OpenCode / oh-my-openagent (formerly oh-my-opencode) storagereferences/opencode.md
    OpenClaw, Droid, Amp, Gemini, Kimi, Qwen, Codebuff, Roo/Kilo/Cline, Kodu, Cursor CLI, Aider, Kiro, Goose, Hermes, Crush, Zedreferences/all-platforms.md
    Unknown / "any session" / cross-agent searchreferences/all-platforms.md
  2. Run the broad finder first unless the user gave an exact file path. For fuzzy recall, expand the query first.

When the user remembers a task vaguely ("that OpenCode bug", "the dashboard PR", "when did we fix X"), derive 3-6 short query lanes before searching: product/tool aliases, repo/package names, exact error text, issue/PR/session IDs, English/Korean phrasing, and likely verbs such as fix, review, plan, deploy, or merge. Run the lanes together with repeated --query so match_reasons shows which wording found the hit.

bash
python3 scripts/find-agent-sessions.py list --limit 20
python3 scripts/find-agent-sessions.py find "commit" --from 7d --platform senpi --platform opencode
python3 scripts/find-agent-sessions.py find "proxy" --platform openclaw --platform droid --platform amp
python3 scripts/find-agent-sessions.py find --query "deploy" --query "token usage" --workers 64
python3 scripts/find-agent-sessions.py find --query "opencode bug" --query "fix opencode" --query "OpenCode parent session" --include-subagents --workers 64
python3 scripts/find-agent-sessions.py read <session-id>

Use python instead of python3 on systems where that is the available executable.

  1. Use explorer-style parallel lanes when one query batch is not enough.

If scope is broad (multi-month, many repos/platforms, or a vague "what happened with X"), split independent searches by names/errors, repos/cwds, platforms/models, and time windows. Use available subagent/delegation tools for these lanes when they exist; otherwise run the finder calls in parallel. Merge candidates by id/path, then read the most likely sessions.

  1. Read details from search results before ad hoc digging. Search results include detail_hint; run that read <session-id> --platform <platform> command to see the first user prompt, last user prompt, events, and child sessions together.

  2. Verify by opening raw transcripts for claims. The finder normalizes formats; the raw path remains the source of truth.

Output Contract

The finder prints JSON for stdout and jq. Every result includes:

FieldMeaning
platformRegistered platform key such as codex, claude, opencode, openclaw, droid, amp, kodu, cursor-cli, aider, roo-code, kilo-code, kilo-cli, or kiro
idSession ID or stable file-derived ID
pathRaw transcript/index file
cwdWorking directory when recoverable
created_at, updated_atISO-like timestamps when recoverable
provider, modelModel metadata when recoverable
first_user_messageFirst user prompt preview (for subagents: task description + delegated prompt)
last_user_messageLast user prompt preview when recoverable
usageToken/cost clues when present in the platform log
parent_idParent session/thread ID when this is a subagent or child session, else null
agentSubagent label (Claude agentType, Codex nickname (role), OpenCode agent name)
subagent_countNumber of child sessions spawned by this session
detail_hintReady-to-run read command for detailed inspection
match_reasonsSearch-only array explaining which field/content matched each query

Each match_reasons entry includes query, platform, field, and snippet, so you can tell which platform matched and what content caused the hit without opening every transcript.

Filters

list and search share these filters:

FilterMeaning
--platformRepeatable platform filter; pass one platform per flag
--rootExtra root to scan, repeatable
--from, --toDate bounds: YYYY-MM-DD, YYYY-MM, YYYY, today, yesterday, 7d
--cwdWorking-directory substring
--modelModel substring
--limitMaximum results
--queryRepeatable search query; multiple queries return per-query groups plus a de-duplicated merged result list
--workersParallel worker count for platform scans, transcript parsing, OpenCode message joins, and multi-query matching
--include-subagentsInclude subagent/child sessions as standalone list/search results (hidden by default)

When --platform is omitted, the finder searches every registered platform in parallel. Each optional platform first probes fixed, known transcript roots and returns immediately when the product has no local store, so broad default searches stay cheap. Use repeatable flags such as --platform openclaw --platform droid only when narrowing. Comma-separated platform values are intentionally unsupported.

For OpenCode, the finder uses opencode db path plus direct SQLite queries first, then opencode session list --format json as a fallback. It avoids heavy messages/ or parts/ scans during normal list/search, and only falls back to file joins when the OpenCode DB/CLI is unavailable or explicit --root values request a nonstandard store.

Usage-only sources such as Copilot OTEL, Mux, Antigravity tokscale cache rows, Synthetic provider retagging, and Cursor IDE usage CSV are excluded from default transcript search because they do not reconstruct user prompts.

Subagent / Child Sessions

list and find/search return main sessions only by default, each annotated with subagent_count. read <main-session-id> (alias: get) always returns a prompts object and a subagents array containing every child session (id, agent label, parent_id, prompt preview, raw path), so opening a main session reveals its whole delegation tree. read <child-id> works too and returns that child's own events.

PlatformWhere children liveLinkage
Claude Codeprojects/<proj>/<session-id>/subagents/agent-*.jsonl (Task tool) and .../subagents/workflows/wf_*/agent-*.jsonl (Workflow)Directory name = parent session ID; agent-*.meta.json holds agentType + task description
CodexRegular threads in state_*.sqlite + own rollout JSONLthread_spawn_edges table and threads.source / rollout session_meta.payload.source.subagent.thread_spawn
OpenCodeRegular sessions in opencode.db / storage/session/session.parent_id column / parentID field; agent column names the subagent

When the user asks whether some specific work was ever done, search with --include-subagents — delegated work often lives only in child transcripts, not in the main session. Workflow journal.jsonl files are orchestration logs, not sessions.

Codex Notes

For Codex sessions, use the same broad finder. It reads state_*.sqlite, rollout JSONL, and archived rollout files:

bash
python3 scripts/find-agent-sessions.py list --platform codex --from 7d
python3 scripts/find-agent-sessions.py find "deploy" --platform codex
python3 scripts/find-agent-sessions.py read <session-id> --platform codex

Use references/codex.md for Codex storage details.

Troubleshooting

ProblemFix
Missing Codex sessionsSet CODEX_HOME or pass --root /path/to/.codex.
Missing OpenCode sessionsPass the data dir that contains messages/ and parts/, often ~/.opencode or ~/.local/share/opencode.
Missing Claude sessionsSearch ~/.claude/projects, ~/.claude/transcripts, and ~/.claude/pre-compact-session-histories; use --root for nonstandard config dirs.
Missing optional platform sessionsCheck references/all-platforms.md for the exact local store. For project-local tools such as Aider, pass --root /path/to/workspace if the repo is outside the bounded default roots.
Date filter misses local sessionsTimestamps are compared as UTC instants when parseable; otherwise file mtime is used.
Search is slowNarrow with repeated --platform flags or date/cwd filters. Optional stores are probed before parsing; avoid passing your whole home as --root unless you really want every bounded project-local scan.

Activation

Use this skill for any request to find, read, or inspect a local coding-agent session, regardless of product name — including memory-recall questions ("what did I work on a few days ago", "did we already migrate X", "when did I fix Y"). If the user only says "that session where we did X", do not rely on one literal query: expand to multiple discriminative terms first, add --include-subagents when the work may have been delegated, then narrow by --platform, cwd, model, and time (--from 7d for "a few days ago"). Prefer the detail_hint from the chosen search result for the next read step. If the first query batch is still ambiguous, use explorer-style lanes by keyword, repo/cwd, platform/model, and time window before summarizing.