MCP server for reading Claude Code session history from the local filesystem
Project description
node804-claude-code-mcp
MCP server for reading Claude Code session history from the local filesystem. Exposes project and session data to any MCP-compatible client — Claude Cowork, Claude Chat, scheduled agents, or your own tooling.
Reads directly from ~/.claude/projects/ — no external dependencies, no network calls, no API keys.
Why this exists
Claude Code stores every session as a local JSONL file containing the full conversation: user messages, assistant responses, tool calls, token counts, and timing. That history is rich and detailed, but it's locked inside the CLI with no way to query it from other tools.
This server opens it up.
Use cases
Personal Knowledge Management and daily logging Claude Code sessions are a detailed record of decisions made, problems solved, and code written. This server lets a Cowork or Chat session pull that raw material into a daily note, work log, or PKM entry automatically — capturing not just what changed but the reasoning behind it, without any manual copy-paste.
Cross-session continuity Starting a new Claude Code session on a project that was last touched weeks ago means re-explaining context from scratch. With this server, a fresh session can search prior conversations for relevant background — design decisions, dead ends already explored, environment quirks — before writing a single line of code.
Standup and progress reporting
search_claude_sessions and get_claude_session_stats give enough signal to reconstruct what was worked on across a day or week. A scheduled agent can draft standup notes or weekly summaries without you keeping a separate activity log.
Token and time auditing
get_claude_session_stats returns per-session input/output token counts, cache hit rates, and duration. Useful for understanding which projects are consuming the most AI time, or for back-of-envelope cost tracking across a team.
Recovering decisions and rationale The assistant messages in a session contain reasoning that never makes it into git history or documentation. When a colleague asks "why did we pick X over Y?", a search across sessions is often faster than reading commits — and captures the full deliberation, not just the outcome.
Handoff and onboarding A new team member or a handoff to another AI session can be primed with the actual conversation history from a project rather than a manually written summary that may already be stale.
Research and spike synthesis Exploratory sessions — spiking on a library, investigating an incident, prototyping an approach — produce valuable findings that are easy to lose. Searching across those sessions lets later work build on earlier exploration rather than repeat it.
Installation
pip install node804-claude-code-mcp
Or install from source:
git clone https://github.com/Node804/node804-claude-code-mcp
cd node804-claude-code-mcp
pip install -e .
Setup
Claude Desktop / Claude Chat
Add to claude_desktop_config.json:
Windows: %APPDATA%\Claude\claude_desktop_config.json
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
{
"mcpServers": {
"claude-code-logs": {
"command": "python",
"args": ["-m", "node804_claude_code_mcp.server"]
}
}
}
Restart Claude Desktop after saving.
Claude Code (settings.json)
Add to .claude/settings.json in your project, or to the global ~/.claude/settings.json:
{
"mcpServers": {
"claude-code-logs": {
"command": "python",
"args": ["-m", "node804_claude_code_mcp.server"]
}
}
}
Environment variables
| Variable | Default | Description |
|---|---|---|
CLAUDE_DIR |
~/.claude |
Override the Claude Code data directory |
Tools
server_status
Show the current server version and resolved data directory.
list_claude_projects
List all Claude Code projects in the local session store, sorted by most recent activity.
Returns: project slug, session count, last activity timestamp.
list_claude_sessions
List sessions for a specific project or all projects.
| Argument | Type | Default | Description |
|---|---|---|---|
project_slug |
string | — | Filter to one project (optional) |
limit |
int | 20 | Max sessions to return |
get_claude_session
Get the full conversation transcript from a session. Returns user and assistant messages in order, with timestamps and tool call names.
| Argument | Type | Default | Description |
|---|---|---|---|
session_id |
string | — | Session UUID |
project_slug |
string | — | Project the session belongs to |
include_thinking |
bool | false | Include assistant thinking blocks |
get_claude_session_stats
Token usage, timing, and message counts for a session.
| Argument | Type | Description |
|---|---|---|
session_id |
string | Session UUID |
project_slug |
string | Project slug |
Returns: input/output tokens, cache read tokens, duration in minutes, models used, working directory.
search_claude_sessions
Case-insensitive full-text search across all session messages. Returns matching snippets with surrounding context.
| Argument | Type | Default | Description |
|---|---|---|---|
query |
string | — | Text to search for |
project_slug |
string | — | Limit to one project (optional) |
limit |
int | 20 | Max hits to return |
Known limitations
Session files are read linearly from top to bottom. Claude Code's JSONL format is actually a tree — every record links to its parent via parentUuid, which means a session can contain forks (abandoned tool call branches, retries, compaction summaries). Linear reading is correct for the vast majority of normal interactive sessions, but a forked session could include abandoned branches in the output. Fork-aware traversal that follows the primary thread and discards dead branches is a potential future improvement.
Data locations
Claude Code stores session data at:
- Windows:
%USERPROFILE%\.claude\projects\ - macOS / Linux:
~/.claude/projects/
Each project directory contains one .jsonl file per session. Records include user messages, assistant messages (with tool calls and token usage), and internal control messages.
License
MIT — see LICENSE.
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 node804_claude_code_mcp-1.0.0.tar.gz.
File metadata
- Download URL: node804_claude_code_mcp-1.0.0.tar.gz
- Upload date:
- Size: 9.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5db7818598573b1e9dda5244df0f1d8ef4184ed628a7fcc63fbb17efb65a78b1
|
|
| MD5 |
29c44570a0ce8e0dde598b0724ade743
|
|
| BLAKE2b-256 |
d8cf6a7fca776192f3a9f094da568604c78cb2965834f98e48750b1da6896200
|
Provenance
The following attestation bundles were made for node804_claude_code_mcp-1.0.0.tar.gz:
Publisher:
publish.yml on Node804/node804-claude-code-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
node804_claude_code_mcp-1.0.0.tar.gz -
Subject digest:
5db7818598573b1e9dda5244df0f1d8ef4184ed628a7fcc63fbb17efb65a78b1 - Sigstore transparency entry: 1974345158
- Sigstore integration time:
-
Permalink:
Node804/node804-claude-code-mcp@38611b6cd64f321c12ae905d339647c17a85cb1b -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/Node804
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@38611b6cd64f321c12ae905d339647c17a85cb1b -
Trigger Event:
push
-
Statement type:
File details
Details for the file node804_claude_code_mcp-1.0.0-py3-none-any.whl.
File metadata
- Download URL: node804_claude_code_mcp-1.0.0-py3-none-any.whl
- Upload date:
- Size: 10.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bd18fa3b9777b83c0c087b4356ced6ed83edff4a0b99b95ff641445584eff1fa
|
|
| MD5 |
6cc5d70d13727b85324e4baff700e839
|
|
| BLAKE2b-256 |
de566387a324583335f2a431557cb55479161727e96cbb17bca8c5f002a48b8f
|
Provenance
The following attestation bundles were made for node804_claude_code_mcp-1.0.0-py3-none-any.whl:
Publisher:
publish.yml on Node804/node804-claude-code-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
node804_claude_code_mcp-1.0.0-py3-none-any.whl -
Subject digest:
bd18fa3b9777b83c0c087b4356ced6ed83edff4a0b99b95ff641445584eff1fa - Sigstore transparency entry: 1974345229
- Sigstore integration time:
-
Permalink:
Node804/node804-claude-code-mcp@38611b6cd64f321c12ae905d339647c17a85cb1b -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/Node804
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@38611b6cd64f321c12ae905d339647c17a85cb1b -
Trigger Event:
push
-
Statement type: