A local proxy for Claude Code that archives every request and response to a SQLite database, with a web UI for browsing sessions, searching transcripts, and inspecting raw API traffic.
Project description
cctape
A local proxy for Claude Code that archives every request and response, with a web UI for browsing sessions, searching transcripts, inspecting raw API traffic, tracking token usage and cost, and an MCP server for Claude to inspect past sessions.
Features
- Find any past conversation. Full-text search across every session you've ever run, with ranked results and highlighted snippets.
- See what Claude costs you. Token and dollar spend broken down by session, account, and model, plus a live chart of how close you are to your 5-hour and weekly rate limits.
- Let Claude search its own history. A built-in MCP server so the agent can look up what you discussed last week instead of re-deriving context you already paid for.
Quick start
Run cctape with uv:
uvx cctape
On first run, your browser opens to a setup page at http://127.0.0.1:5555/setup with the one env var you need to copy. After that, run claude as usual — sessions appear in the UI as they happen.
Pass --no-browser to skip the auto-open.
Configuration
Shell
Add to ~/.zshrc (or ~/.bashrc):
export ANTHROPIC_BASE_URL=http://127.0.0.1:5555/proxy
Claude Code VS Code extension
Add to user settings:
"claudeCode.environmentVariables": [
{"name": "ANTHROPIC_BASE_URL", "value": "http://127.0.0.1:5555/proxy"}
]
MCP server
Register the MCP server with the claude CLI so Claude Code can search its own archive:
claude mcp add --transport http cctape http://127.0.0.1:5555/mcp
This exposes search_transcripts and get_session_window to the agent.
Flags and environment variables
--host/--port— bind address (defaults:127.0.0.1,5555)--no-browser— don't auto-open the browser on first runCCTAPE_DB— database path (default:~/.cctape/cctape.db)
Running it as a service
cctape is a regular HTTP server; run it under whatever supervisor you like (launchd, systemd, tmux, etc.). Once it's up on 127.0.0.1:5555 and your ANTHROPIC_BASE_URL points at /proxy, it just stays out of the way.
Development
Clone the repo and run the frontend + backend separately during development.
Build the frontend once (output is served by the backend from backend/src/cctape/static/):
cd frontend && npm install && npm run build
Start the backend with reload:
cd backend && uv run uvicorn --reload --factory --port=5555 cctape:create_app
Open http://127.0.0.1:5555.
The frontend can also run on its own dev server with HMR:
cd frontend && npm run dev
Pre-commit hooks run ruff, pyright, pytest, eslint, and tsc.
Project details
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 cctape-0.3.0.tar.gz.
File metadata
- Download URL: cctape-0.3.0.tar.gz
- Upload date:
- Size: 1.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6b653dee1b06f70d969a94d022fb9acb5c33af6625da3e6ba5dbc3ac6aa88cda
|
|
| MD5 |
b6e3f980716c16343d6c66a176181dd9
|
|
| BLAKE2b-256 |
2ffe140130fa7fca376212e1439b36fcc5bc6f60e1d9f022ff06ffc076f5d089
|
Provenance
The following attestation bundles were made for cctape-0.3.0.tar.gz:
Publisher:
main.yaml on tillahoffmann/cctape
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cctape-0.3.0.tar.gz -
Subject digest:
6b653dee1b06f70d969a94d022fb9acb5c33af6625da3e6ba5dbc3ac6aa88cda - Sigstore transparency entry: 1365483747
- Sigstore integration time:
-
Permalink:
tillahoffmann/cctape@219e08b85f2cb4a46bb8c9f5a13c2ebdadb55c78 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/tillahoffmann
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
main.yaml@219e08b85f2cb4a46bb8c9f5a13c2ebdadb55c78 -
Trigger Event:
push
-
Statement type:
File details
Details for the file cctape-0.3.0-py3-none-any.whl.
File metadata
- Download URL: cctape-0.3.0-py3-none-any.whl
- Upload date:
- Size: 1.3 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7238a707673ef9fc7d564d4e6751aa48098791a7fa1ec92d13cdd3f14b0ddc53
|
|
| MD5 |
d753fd0ac6c145e37b0abff0894f6edf
|
|
| BLAKE2b-256 |
8397ce06fccf27b1c477d1647d6a96fe4778c681e16c56bdf448126463cdae0f
|
Provenance
The following attestation bundles were made for cctape-0.3.0-py3-none-any.whl:
Publisher:
main.yaml on tillahoffmann/cctape
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cctape-0.3.0-py3-none-any.whl -
Subject digest:
7238a707673ef9fc7d564d4e6751aa48098791a7fa1ec92d13cdd3f14b0ddc53 - Sigstore transparency entry: 1365483750
- Sigstore integration time:
-
Permalink:
tillahoffmann/cctape@219e08b85f2cb4a46bb8c9f5a13c2ebdadb55c78 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/tillahoffmann
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
main.yaml@219e08b85f2cb4a46bb8c9f5a13c2ebdadb55c78 -
Trigger Event:
push
-
Statement type: