Manage Claude Code & Codex sessions, cost, and data from your terminal
Project description
agent-session-manager
One terminal dashboard for everything Claude Code and Codex leave behind.
See cost, browse sessions, and clean up ~/.claude and ~/.codex — side by side, with a Claude / Codex filter.
asm · 한국어
⚠️ Heads up This is a personal tool that reads and edits the internal data of Claude Code and OpenAI Codex (
~/.claude,~/.codex). Every delete goes to the OS trash and is logged, but you should still back up before bulk operations. Not affiliated with Anthropic or OpenAI.
What it is
If you live in Claude Code and Codex, the two of them quietly fill ~/.claude and ~/.codex with session transcripts, cost logs, debug files, task lists, and snapshots. After a few weeks it's impossible to tell which projects burned the most tokens, or which files are orphaned and safe to delete.
agent-session-manager (asm) puts all of it in one terminal dashboard. Both agents show up together, and a single keystroke filters the view to All / Claude / Codex so you can compare spend or drill into one tool.
💡 Why it exists
- Problem: cost and session data for two different coding agents live in two opaque directories with no shared view.
- Solution: one TUI that reads both, prices every model accurately, and lets you clean up safely — to the trash, with recovery snapshots.
Demo
The combined dashboard (cost across both agents, source-tagged rows), then the same view filtered to Claude and to Codex:
✨ Features
Combined dashboard
- Cost across both agents with a source filter — click
All / Claude / Codexor presss - Per-model token & cost breakdown (Opus / Sonnet / Haiku / GPT-5.x), each row tagged by source
- Daily / weekly / monthly usage tables (one scan, all periods) and a Top-10 project cost chart
- Accurate, current pricing from a LiteLLM-sourced rate table (new Opus/GPT models priced correctly, not at stale rates)
Unified sessions (Claude + Codex)
- One tree: Claude projects and Codex working directories together, each session tagged C / X
- Expand a project to preview conversations from either agent; trash individual sessions
- Edit instructions: per project, view/edit/create
CLAUDE.md,CLAUDE.local.md,AGENTS.md,AGENTS.local.mdin a built-in editor (Ctrl+S to save) - Move a Codex session to another working directory (rewrites its
cwd, which is howcodex resume --cdassociates sessions) - Orphan cleanup: detect and bulk-clean Claude sessions, file-history, debug, and task entries with no matching project
- Duplicate sessions: find the same session copied across projects and delete individual copies
- Empty sessions: clean stub sessions that hold only a title/metadata and no conversation (can't be resumed)
- Migration: copy Claude sessions between projects (originals preserved), with paths auto-rewritten
Safe by default
- Every delete goes to the OS trash and is recorded in an audit log
- Recovery snapshots are taken before trashing (Claude and Codex), with a size/age cap so they don't pile up
- Backups and restore for Claude (config / settings / plugins / sessions / full) and Codex (sessions, excluding huge caches); restore is rollback-safe (the live dir is moved aside and put back if the copy fails), and credential-bearing backups are written owner-only (0600)
How it works
~/.claude ┐
├──► asm ──► one dashboard ──► filter: All / Claude / Codex
~/.codex ┘ (cost · sessions · cleanup · backup)
asm reads both data directories directly — no daemon, no config. Claude data is grouped by project; Codex sessions are grouped by working directory. Pricing is computed from each session's recorded token usage.
| Path | What's there |
|---|---|
~/.claude.json · ~/.claude/projects/ |
Claude projects, costs, session JSONL |
~/.claude/file-history/ · debug/ · tasks/ |
Snapshots, debug logs, per-session task lists |
~/.codex/sessions/ |
Codex rollout session files |
~/.asm/backups/ · trash-log.jsonl |
Backups (auto-migrated from old ~/.cc-tui) and the deletion audit log |
🛠️ Tech Stack
- TUI: Textual + Rich
- Safety: send2trash (OS trash, not
rm) - Sessions: claude-agent-sdk with a JSONL fallback parser
- Python: 3.11+
🚀 Getting started
Install (recommended)
# uv
uv tool install agent-session-manager
# pip
pip install agent-session-manager
Both install a single asm command. On first run, data from the previous ~/.cc-tui location is migrated to ~/.asm automatically.
Run from source
git clone https://github.com/Bae-ChangHyun/agent-session-manager.git
cd agent-session-manager
uv sync && uv run asm
Usage
asm # Launch — shows Claude + Codex together
asm --source codex # Start with the dashboard filtered to Codex
asm --path /your/project # Limit to one Claude project
asm --lang ko # Korean UI (or set ASM_LANG=ko)
asm --no-update-check # Skip the startup update check
Both sources are always available; --source only sets the dashboard's initial filter, which you change anytime with s.
Headless CLI
Every feature is also available as a subcommand — handy for scripts and AI agents. In a terminal you get rich tables; piped output is plain text, and --json gives machine-readable output.
# Read-only
asm cost --period weekly # Cost/token stats per model & period
asm projects # All projects (Claude + Codex)
asm sessions --search "firewall" # Search sessions by title
asm preview <session-id> # Print a conversation
asm backup list / asm recovery list
# Destructive — always confirms first (skip with --yes); everything goes
# through the OS trash + recovery snapshots, same as the TUI.
asm clean empty --dry-run # empty | orphaned | debug | todos
asm trash <session-id>
asm backup create --type full # config|full|settings|plugins|sessions|codex
asm backup restore <path> / asm recovery restore <id>
asm migrate /old/project /new/project
Keyboard
| Key | Action |
|---|---|
F1–F6 |
Switch tabs |
s / click |
Dashboard source filter (All / Claude / Codex) |
Tab / Shift+Tab · 1 2 3 |
Dashboard period (Daily / Weekly / Monthly) |
d / D |
Trash selected / all orphaned |
Space · Enter |
Toggle selection · Preview conversation |
r · q |
Refresh all · Quit |
Staying up to date
When a newer release is on PyPI, asm offers a y/N upgrade prompt on startup (via uv tool or pip). It's skipped in non-interactive shells and when offline.
🗺️ Roadmap
- Per-source disk-usage in the data overview
- Incremental (mtime-based) usage scan for very large
~/.claudetrees - ruff + mypy in CI
⚠️ Status & scope
- Personal / pre-release, under active development.
- Operates directly on Claude Code and Codex internal data — back up before bulk deletes.
- Deletes go to the OS trash with recovery snapshots; nothing is
rm'd in place. - No warranty. Not affiliated with Anthropic or OpenAI.
📄 License
Made with Claude Code · and now Codex too
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file agent_session_manager-0.11.0.tar.gz.
File metadata
- Download URL: agent_session_manager-0.11.0.tar.gz
- Upload date:
- Size: 143.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
29b6642ce6a8e27da144164d5468e31329091d22c1b9bd1ea1e2bc5674121daa
|
|
| MD5 |
1c44f1cd0559580b261a911e96b48e97
|
|
| BLAKE2b-256 |
faf1ac1982e5adb3349ff44bb11ecef220e59e0cdbc66d2473d966bf4eacbd9c
|
File details
Details for the file agent_session_manager-0.11.0-py3-none-any.whl.
File metadata
- Download URL: agent_session_manager-0.11.0-py3-none-any.whl
- Upload date:
- Size: 90.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9da449e632cc9933d704b648ff32f6d135ba7d3b64a025fe98000da939ae7857
|
|
| MD5 |
391f5f13d2fd2af68ccec91af935cef9
|
|
| BLAKE2b-256 |
6ad5975631fe4bf96959e5af7206e97d6c8f3cd59ee1d9f9b27a46fb738f7c5f
|