mcp-session-insight
Collects git commit history across all Claude Code projects, allowing filtering by date range and project.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@mcp-session-insightsummarize my last session's file changes and errors"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
MCP Session Insight
AI-Native Session Observability for Claude Code
简体中文 | English
Why session-insight?
Claude Code sessions accumulate rich context — file changes, user requests, decisions, errors, git history — but that context vanishes when the session ends. CLAUDE.md stores static rules, but can't answer "what did I work on today?" or "what went wrong in that last session?".
session-insight gives your AI assistant a read-only lens into all past sessions:
Session analytics — extract structured insights from JSONL: file changes, decisions, errors, tool usage, todo progress
EnrichedSummary — returns structured JSON instead of Markdown templates, letting the calling LLM synthesize concise summaries at zero extra API cost
Cross-project git logs — collect commit history across all projects with date range, project, and author filters
Semantic classification — bash commands classified into 9 categories (build/test/deploy/debug/network/run/git/explore/other)
Session handoff — generate structured context for seamless session continuation
Quick Start
# Install
npm install -g @morningljn/mcp-session-insight
# One-command setup
claude mcp add session-insight -- npx @morningljn/mcp-session-insightRestart your AI assistant and it can now query all past sessions.
Manual Setup
Add to ~/.claude/mcp.json:
{
"mcpServers": {
"session-insight": {
"command": "npx",
"args": ["@morningljn/mcp-session-insight"]
}
}
}Tools
Tool | Description |
| List all sessions with optional project filter and limit |
| Show session metadata (supports prefix matching on session ID) |
| Search sessions by keyword in content or ID |
| Returns EnrichedSummary JSON for LLM synthesis |
| Get file changes (created / modified / read) |
| Get deduplicated user requests |
| Get todo progress snapshots |
| Get errors and issues with context |
| Get key decisions from thinking blocks |
| Get conversation history with role filter |
| Collect git commit logs across projects |
get_session_summary (EnrichedSummary)
Returns structured JSON instead of formatted text. The calling LLM reads the data and synthesizes a concise summary — zero extra API cost.
{
"sessionDuration": "116min",
"messageDensity": "low",
"classifiedBash": [{ "cmd": "npm test", "category": "test" }],
"errorsWithContext": [{ "message": "...", "trigger": "Bash", "relatedFile": "src/server.ts" }],
"fileChangeGroups": [{ "directory": "src", "created": ["git.ts"], "modified": [] }],
"dedupedRequests": ["refactor summary to structured JSON"],
"decisions": ["use Jaccard trigram for dedup"],
"toolStats": { "Bash": 93, "Read": 39, "Edit": 38 },
"gitActions": ["git commit -m \"feat: ...\"", "git push origin main"]
}get_git_logs
Collect git commit history across all Claude Code projects:
[
{
"project": "/Users/user/project",
"projectName": "my-app",
"commits": [
{ "hash": "a1b2c3d", "message": "feat: add auth", "author": "user", "date": "2026-05-20T10:00:00+08:00", "files": ["src/auth.ts"] }
]
}
]Architecture
┌───────────────────┐ stdio ┌──────────────────┐ read ┌──────────────────────────┐
│ MCP Client │◄─────────►│ session-insight │◄──────────►│ ~/.claude/projects/ │
│ (Claude / Codex) │ JSON │ server │ │ │
└───────────────────┘ └───────┬──────────┘ │ ┌─project-a/ │
│ │ │ ├─session-1.jsonl │
┌──────┴──────┐ │ │ └─session-2.jsonl │
│ │ │ └─project-b/ │
│ Extractor │ Git Log │ └─session-3.jsonl │
│ (summary, │ Collector │ │
│ classify, │ (git log └──────────────────────────┘
│ dedup, │ per project)
│ errors) │
└─────────────┘Key design decisions:
Stateless — no database, no persistence, reads JSONL directly on each request
Zero dependencies — only
@modelcontextprotocol/sdk, all processing is pure computationLLM-friendly output — structured JSON that the calling LLM synthesizes into natural language
Development
npm install
npm test # run tests with vitest
npm run build # compile TypeScript
npm start # start MCP serverLicense
MIT
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/ArtLjn/mcp-session-insight'
If you have feedback or need assistance with the MCP directory API, please join our Discord server