Skip to main content

Local MCP memory arbiter with dual timeline conflict handling.

Project description

mcp-name: io.github.billy12151/memory-arbiter-mcp

memory-arbiter-mcp

中文 | English


English

A lightweight, fully local MCP Server that gives your AI coding tools a shared memory store with built-in conflict arbitration.

Every tool — ZCode, Codex, Cursor, Claude Code — has its own memory. They don't talk to each other. Memory Arbiter fixes this: one SQLite database, all tools read and write through the same MCP protocol, conflicts are resolved by structured rules (not LLM guesswork).

Features

  • Structured memory write: content, agent_id, workspace, tags, source_type, event_time, ingest_time, confidence, protection_level, and more.
  • Source trust levels: user_confirmed > document_extracted > agent_generated > unknown.
  • Dual timeline arbitration: resolves conflicts by user confirmation → event time → source trust → ingest time. Every decision comes with an explainable rationale.
  • Locked protection: user_confirmed memories are automatically locked — no agent can overwrite them.
  • Client policy system: per-client enable/disable, agent allow/deny lists for multi-agent governance.
  • Graceful degradation: sqlite-vec → FTS5 → LIKE → JSONL backup. Never crashes.
  • Zero cloud, zero LLM calls: pure local SQLite. No Postgres, Redis, or external services.

Quick Start

Requirements: Python 3.11+

# Clone
git clone https://github.com/billy12151/memory-arbiter-mcp.git
cd memory-arbiter-mcp

# Setup
python3.11 -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
pip install -e .

# Optional: semantic recall via sqlite-vec
pip install '.[vec]'

# Run
memory-arbiter-mcp

Connect Your Tool

Add to your tool's MCP config (see examples/ for ready-made templates):

{
  "mcpServers": {
    "memory-arbiter": {
      "command": "/path/to/memory-arbiter-mcp/.venv/bin/memory-arbiter-mcp",
      "env": {
        "MEMORY_ARBITER_CLIENT": "zcode",
        "MEMORY_ARBITER_AGENT_ID": "zcode-default",
        "MEMORY_ARBITER_DB_PATH": "~/.local/share/memory-arbiter/memory.sqlite3"
      }
    }
  }
}

Change MEMORY_ARBITER_CLIENT for each tool (zcode, codex, cursor, claude-code). All tools share the same DB_PATH — that's the whole point.

⚠️ New session required: MCP servers are loaded at session startup. Already-open sessions won't see the new tools. Start a fresh session after configuring.

Client Config Locations

Client Config Location
ZCode ~/.zcode/v2/ MCP config
Codex CLI ~/.codex/ MCP config
Claude Code .mcp.json in project root
Cursor ~/.cursor/mcp.json

MCP Tools

Tool Description
memory_write Write a memory (source_type=user_confirmed auto-locks)
memory_search Search memories (FTS5 → LIKE fallback)
memory_compare Compare two memories, returns explanation only
memory_arbitrate Arbitrate conflict, can record result (apply=true)
memory_confirm Promote a memory to user-confirmed and locked
memory_list_conflicts List unresolved conflicts
memory_status Show current mode, degradation status, storage paths

Data Migration

Moving to a new machine? Just copy the SQLite file:

# Copy the database
cp ~/.local/share/memory-arbiter/memory.sqlite3 /new/machine/~/.local/share/memory-arbiter/

# Reinstall the project (don't copy .venv — rebuild it)
python3.11 -m venv .venv
source .venv/bin/activate
pip install -e .

Testing

python3.11 -m pip install -r requirements.txt
python3.11 -m pytest

License

MIT


中文

一个轻量、完全本地运行的 MCP Server,给你的 AI 编程工具提供共享记忆库,内置冲突仲裁机制。

你同时用 ZCode、Codex、Cursor、Claude Code——每个工具都有各自的记忆,互不相通。Memory Arbiter 解决这个问题:一个 SQLite 数据库,所有工具通过同一个 MCP 协议读写,冲突由结构化规则仲裁,不依赖大模型。

核心能力

  • 结构化写入contentagent_idworkspacetagssource_typeevent_timeingest_timeconfidenceprotection_level 等。
  • 来源可信度user_confirmed > document_extracted > agent_generated > unknown
  • 双时间轴仲裁:按 用户确认 → 事件发生时间 → 来源可信度 → 录入时间 的优先级判定,输出可解释的裁决理由。
  • 锁定保护user_confirmed 的记忆自动锁定,任何 Agent 都不能自动覆盖。
  • 客户端策略:按客户端启用/禁用,Agent 级别的 allow/deny 白名单控制。
  • 逐级降级sqlite-vec → FTS5 → LIKE → JSONL 备份,不会崩。
  • 零云依赖、零大模型调用:纯本地 SQLite,不需要 Postgres、Redis 或外部服务。

快速开始

要求:Python 3.11+

# 克隆
git clone https://github.com/billy12151/memory-arbiter-mcp.git
cd memory-arbiter-mcp

# 安装
python3.11 -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
pip install -e .

# 可选:启用语义召回增强(sqlite-vec)
pip install '.[vec]'

# 启动
memory-arbiter-mcp

接入工具

在你的工具的 MCP 配置中加入(完整示例见 examples/ 目录):

{
  "mcpServers": {
    "memory-arbiter": {
      "command": "/path/to/memory-arbiter-mcp/.venv/bin/memory-arbiter-mcp",
      "env": {
        "MEMORY_ARBITER_CLIENT": "zcode",
        "MEMORY_ARBITER_AGENT_ID": "zcode-default",
        "MEMORY_ARBITER_DB_PATH": "~/.local/share/memory-arbiter/memory.sqlite3"
      }
    }
  }
}

每个工具改一下 MEMORY_ARBITER_CLIENT 标识(zcodecodexcursorclaude-code),共享同一个 DB_PATH——这就是跨工具记忆共享的关键。

⚠️ 需要新建会话:MCP Server 在客户端启动时加载,已经打开的会话不会识别新添加的 Server。配置好后请新建一个会话。

客户端配置位置

客户端 配置文件位置
ZCode ~/.zcode/v2/ 下 MCP 配置
Codex CLI ~/.codex/ 下 MCP 配置
Claude Code 项目根目录 .mcp.json
Cursor ~/.cursor/mcp.json

MCP 工具

工具 说明
memory_write 写入记忆(source_type=user_confirmed 自动锁定)
memory_search 搜索记忆(FTS5 → LIKE 自动降级)
memory_compare 比较两条记忆,只返回解释
memory_arbitrate 仲裁冲突,自动判定胜者(apply=true 时落记录)
memory_confirm 用户确认某条记忆,锁定保护
memory_list_conflicts 列出未解决的冲突
memory_status 查看运行状态、模式、降级原因

数据迁移

换电脑只需拷贝一个文件:

# 拷贝数据库
cp ~/.local/share/memory-arbiter/memory.sqlite3 新电脑:~/.local/share/memory-arbiter/

# 重新安装项目(.venv 不要拷贝,新机器上重建)
python3.11 -m venv .venv
source .venv/bin/activate
pip install -e .

测试

python3.11 -m pip install -r requirements.txt
python3.11 -m pytest

License

MIT

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

memory_arbiter_mcp-0.2.0.tar.gz (19.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

memory_arbiter_mcp-0.2.0-py3-none-any.whl (18.1 kB view details)

Uploaded Python 3

File details

Details for the file memory_arbiter_mcp-0.2.0.tar.gz.

File metadata

  • Download URL: memory_arbiter_mcp-0.2.0.tar.gz
  • Upload date:
  • Size: 19.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for memory_arbiter_mcp-0.2.0.tar.gz
Algorithm Hash digest
SHA256 c36fe0758d799c68af9335076694825516810ce597f3932a08be70836c632766
MD5 9d8178f9c5b86d008e43ea6b6a8d38e5
BLAKE2b-256 f9868cd3647ac126629c86542c7f7fd19de11d13dc60d19cbb7042cbfd145896

See more details on using hashes here.

File details

Details for the file memory_arbiter_mcp-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for memory_arbiter_mcp-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c268c8a03c34b4426217d71c5ae490efab7026a9794faac37bcf95add3b0d5be
MD5 b6e0fe84053c0eb3be1c48ec6712a800
BLAKE2b-256 046e49de64b2b5176e08893c6c720b93371ae0f309b65332aab3ede822d03864

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page