If you're accumulating ChatGPT or Claude export files and want to query them without manually pasting logs into your context window, Chronicle normalizes those archives into searchable JSON and lets you pull specific message ranges on demand. It parses ChatGPT's recursive node structures and Claude's flat message lists into a standard format, then exposes 27 tools including keyword search, pagination, and range reads. The real hook is the token optimization: code blocks get collapsed into metadata summaries and long messages truncate automatically, cutting context usage by up to 40%. The CLI handles cross-platform IDE config for Cursor, Cline, and Claude Desktop, and includes a split subcommand to break monolithic conversation dumps into individual threads. Useful when you want past conversations indexed locally instead of retyped.
Chronicle is a production-grade Model Context Protocol (MCP) server designed to sync, clean, format, and index local artificial intelligence chat transcripts. By bridging the gap between local editor history and large language model contexts, Chronicle allows agents to search, compare, retrieve, and reference past conversation logs. It features optimized token-saving heuristics that compress code blocks and limit message lengths, reducing context window utilization by up to 40 percent.
AI providers and editor clients save conversation logs in diverse formats. Chronicle normalizes these structures into a standard role-and-content message format:
Large chat logs can quickly exhaust context windows and increase API costs. Chronicle implements proactive token-saving mechanisms:
The cli.py file serves as the system's entry point, registering a unified chronicle command on the system path via the pyproject.toml configuration (chronicle = "cli:main"). The CLI contains several advanced capabilities designed for platform compatibility and developer ergonomics:
When run without subcommands, the chronicle command launches the stdio transport server for MCP clients:
chronicle
It accepts options like --chats-folder to configure custom storage directories, and exposes the subcommands add and split.
The CLI implements path resolution logic using Python's sys.platform and pathlib.Path to match standard OS conventions for user directories:
~/Library/Application Support/.%APPDATA% environment variable, falling back to ~/AppData/Roaming/ if the variable is not set.~/.config/.The CLI wrapper provides out-of-the-box support for leading AI-assisted development tools and editors:
~/.cursor/mcp.json.~/.claude.json.~/Library/Application Support/Code/User/globalStorage/saoudrizwan.claude-dev/settings/cline_mcp_settings.json%APPDATA%/Code/User/globalStorage/saoudrizwan.claude-dev/settings/cline_mcp_settings.json~/.config/Code/User/globalStorage/saoudrizwan.claude-dev/settings/cline_mcp_settings.json~/Library/Application Support/Trae/mcp.json%APPDATA%/Trae/mcp.json~/.config/Trae/mcp.json~/.<app_name>/mcp.json). If that directory is missing, it creates the app-specific configuration in the standard application support folder for the respective platform (e.g. ~/Library/Application Support/<app_name>/mcp.json on macOS).Host clients (like Claude Desktop or Cline) spawn MCP servers within isolated subprocesses that often do not inherit the user's login shell environment variables (such as custom paths defined in .bashrc or .zshrc). Attempting to call uvx or global scripts directly can raise an ENOENT connection error if the host application cannot find the executable.
To solve this, the chronicle add utility uses Python's shutil.which("uvx") to scan the host machine path during configuration. It resolves the absolute system path of uvx (such as /opt/homebrew/bin/uvx or /usr/local/bin/uvx) and writes this absolute path directly to the IDE's JSON configuration file.
Users downloading conversational archives from ChatGPT or Claude are often provided with a single monolithic JSON file (such as conversations.json) containing hundreds of distinct threads.
The chronicle split subcommand parses these large payloads and splits them into individual JSON files:
title, name, and chat_title)./, \, *, ?, :, ", <, >, and |) and limits length.chronicle split /path/to/conversations.json --out /path/to/output_directory
By default, Chronicle stores processed archives in ~/.chronicle/chats. You can configure a custom global storage folder using the --chats-folder parameter:
chronicle --chats-folder /path/to/custom/chats
This saves the target path to a local settings file (~/.chronicle_settings.json), allowing you to centralize your archives across multiple development environments.
Chronicle consolidates its behaviors into 6 versatile, parameterized tools. This design avoids cognitive overhead for client AI models while preserving the server's complete feature set.
search_historyquery (str, default: ""): The search query string or keywords list.method (str, default: "semantic"): Search methodology. Supported options:
semantic: Standard semantic retrieval using TF-IDF cosine similarity.keyword: Exact string matching against terms in files.date_range: Filters files modified within a date interval (requires start_date and end_date).related: Finds archives semantically close to a reference file.keywords (list of strings, optional): Optional list of keywords for keyword search.start_date (str, optional): Start date string (YYYY-MM-DD) for date range filtering.end_date (str, optional): End date string (YYYY-MM-DD) for date range filtering.limit (int, default: 50): Maximum result count for keyword or date range searches.top_k (int, default: 10): Maximum matches for semantic or related chat searches.client (str, default: "default"): Subfolder client identifier.file_name (str, optional): Reference chat filename for related search.get_chat_logschat_id (str, optional): Filename of the target chat. If omitted, lists all available files.view_type (str, default: "content"): The type of information to retrieve. Supported options:
content: Message text slice within specified index ranges.metadata: File statistics including message counts and modification dates.summary: Structural summary highlighting the opener and closer context.start_msg (int, default: 1): Message slice start index (1-indexed).end_msg (int, default: 20): Message slice end index.max_msg_len (int, default: 1000): Character limit for messages to prevent token inflation. Set to 0 for unlimited.summarize_code (bool, default: True): Summarizes markdown code blocks into metadata headers.page (int, default: 1): Page index for folder listing (used when chat_id is omitted).per_page (int, default: 50): Page result limit for folder listing.client (str, default: "default"): Subfolder client identifier.sync_workspace_datasource_type (str): Source type identifier. Supported options:
raw_content: Direct JSON import from text buffers or clipboard paste.local_path: Copies a JSON file from a local path on disk.agent_transcripts: Syncs transcripts (JSON, JSONL, MD) from configured third-party client folders.cursor_agent_transcripts: Deprecated. Scans Cursor workspace project transcript folders.payload (str, dict, or list, optional): Input data payload (raw JSON text, file path on disk, or folder path).title (str, optional): Target file name or title for imports.source_dir (str, optional): Override folder directory for scanning transcripts.limit (int, default: 50): Maximum files to synchronize.client (str, default: "default"): Subfolder client identifier.compile_project_insightsinsight_type (str): Compilation format. Supported options:
action_items: Extract todos, checkboxes, and task lists.knowledge_index: Rebuild or list the topic-categorized index of files.compare_chats: Analyze and detail shared and unique terms across two files.project_brief: Synthesize summaries and action items from multiple chats into one markdown document.target_chats (list of strings, optional): List of target chat filenames for briefs or comparisons.file_name (str, optional): Target chat filename for action item extraction.file_name_a (str, optional): First chat filename for comparison.file_name_b (str, optional): Second chat filename for comparison.brief_title (str, default: "Project Brief"): Title header for compiled briefs.rebuild (bool, default: False): Re-scans all files to update the knowledge index.summary_only (bool, default: False): Returns topic file counts instead of full file lists in index lookup.client (str, default: "default"): Subfolder client identifier.maintain_storageop_type (str): Maintenance operation name. Supported options:
compress: Compresses historical archives older than a set age using Gzip.deduplicate: Content-hash based search and deletion of duplicate logs.configure: Updates auto-save message limits, paths, and transcripts.capabilities: Returns server meta-capabilities and client configurations.settings (dict, optional): Settings payload dict (for configure).days_old (int, optional): Cutoff threshold age in days for compression.dry_run (bool, default: True): Lists duplicates without performing deletions.client (str, default: "default"): Subfolder client identifier.manage_session_stateaction (str): Operation to perform. Supported options:
save: Commits active messages list to storage.register_auto_save: Registers the session for auto-saving on connection termination.trigger_auto_save: Instantly flushes pending sessions to disk.watch_folder: Reports file changes since the last execution.merge: Appends new messages to an existing chat archive.export_markdown: Converts a JSON transcript to a Markdown document.delete: Permanently deletes an archive file (requires confirm=True).conversation_name (str, optional): Active conversation name.messages (list of dicts, optional): Message list payload.force_save (bool, default: False): Saves the chat session even if below message limit thresholds.file_name (str, optional): Target file name.confirm (bool, default: False): Confirms deletion.new_messages (list of dicts, optional): Message list to merge.client (str, default: "default"): Subfolder client identifier.mcp (Model Context Protocol SDK).setuptools (for installation as a package).git clone https://github.com/Leviathan0x0/Chronicle-MCP.git
cd Chronicle-MCP
python3 -m venv venv
source venv/bin/activate
pip install -e .
You can automatically add Chronicle-MCP to your preferred IDE configuration using the add subcommand. This utility resolves the absolute path of uvx dynamically to guarantee error-free connections:
chronicle add cursor
chronicle add claude
chronicle add vscode
chronicle add trae
chronicle add <editor-name>
Alternatively, you can configure the editor manually to execute the following startup command:
{
"mcpServers": {
"chronicle-mcp": {
"command": "/absolute/path/to/uvx",
"args": [
"--from",
"chronicle-mcp-server",
"chronicle"
]
}
}
}
Since editors (like Cursor or VS Code) do not notify MCP servers when a chat window or tab is closed, Chronicle implements a multi-step solution to ensure your conversation history is saved automatically:
The Chronicle server includes an exit handler registered via Python's atexit module. When you close a chat tab or close the editor, the editor terminates the stdio connection, shutting down the Chronicle process. Upon receiving this shutdown trigger, the server automatically flushes the registered pending session to the local chats folder.
For this flush to succeed, the active chat session must be registered during the conversation. Chronicle handles this setup automatically: upon server startup, it checks the active project workspace root directory and automatically creates or appends the required rules to the .cursorrules and .clinerules files.
This ensures that the AI agent in Cursor or VS Code (via Cline) is automatically instructed to register the session at the start of the chat. The appended rule states:
At the beginning of the chat session, you must call the "register_session_for_auto_save" tool to register this conversation. Provide a descriptive title based on the user's initial prompt. As the conversation progresses, periodically update the registration payload to keep it current.
This ensures that the chat history is registered dynamically, and Chronicle will write the complete history to your storage folder as soon as the editor terminates the connection.
Chronicle contains unit and integration tests to verify platform path resolution, parsing logic, and tool compatibility:
To execute the suite of unit tests verifying core business logic:
python3 -m unittest test_chat_connector.py
To test all 27 tools against the live storage connector:
python3 test_all_tools.py
This project is licensed under the MIT License. See the LICENSE file for details.
io.github.mindstone/mcp-server-microsoft-teams
helbertparanhos/resend-email-mcp
marlinjai/email-mcp
io.github.mindstone/mcp-server-email-imap
io.github.osamahassouna/email-playbook-mcp
gongrzhe/gmail-mcp-server