ProjectBrain
Local MCP server providing project cognition capabilities for AI coding agents, including context packs, impact analysis, and git diff review through stdio communication.
README
ProjectBrain
ProjectBrain is a local project cognition layer for AI coding agents.
It turns code-structure facts and human project experience into task-scoped artifacts that an AI agent can use before changing code:
- Context Pack: the files, symbols, flows, risks, and human notes relevant to a task.
- Impact Analysis: the files, symbols, callers, dependencies, tests, and review risks likely affected by a change.
- Git Diff Impact: a local review of staged, branch, or last-commit changes based on changed file names from Git.
ProjectBrain is not a code search UI, a generic RAG chatbot, or an automatic code modifier. The first public version is a small local prototype that is useful for experimenting with project memory and impact analysis workflows.
Status
Prototype / local MVP.
Current capabilities:
- CodeGraph SQLite adapter.
- ProjectBrain JSON schema models and validation.
- Context Pack builder.
- Impact Analysis builder.
- Git diff Impact Analysis from local Git changed files.
- Agent-friendly compact output for Context Pack and Impact Analysis.
- Local experience claim authoring.
- JSON-file local runtime.
- Local-only stdio MCP server.
- Optional FastAPI API skeleton.
- Synthetic public demo under
examples/payment-mini/.
Quickstart
Install with Homebrew:
brew tap yinshaojun001/projectbrain https://github.com/yinshaojun001/projectbrain
brew trust yinshaojun001/projectbrain
brew install projectbrain
projectbrain doctor
For local formula testing from a checkout:
brew tap yinshaojun001/projectbrain /path/to/projectbrain
brew trust yinshaojun001/projectbrain
brew install --build-from-source projectbrain
projectbrain doctor
Or install from source:
python3 -m venv .venv
.venv/bin/python -m pip install -e .
.venv/bin/projectbrain doctor
Run the tests:
python3 -m unittest discover -s tests
Generate a Context Pack from the synthetic public demo:
.venv/bin/projectbrain facts context \
--export-json examples/payment-mini/projectbrain-codegraph-export.json \
--experience-seed examples/payment-mini/experience-seed.md \
--task "Explain the settlement entrypoint"
Generate an Impact Analysis:
.venv/bin/projectbrain facts impact \
--export-json examples/payment-mini/projectbrain-codegraph-export.json \
--experience-seed examples/payment-mini/experience-seed.md \
--task "Change the settlement contract" \
--changed-file contract/src/main/java/example/payment/settlement/SettlementService.java
See Quickstart for a fuller walkthrough. A Chinese walkthrough is available at 中文快速上手.
Use With Your Own Repository
One command sets up a local repository for agent use:
projectbrain --store-root ~/.projectbrain-work setup /path/to/my/project \
--id my_project
setup runs CodeGraph init/index, imports ProjectBrain facts, runs a Context Pack smoke test, detects local agents, and prompts you to install the MCP server into supported agents such as Codex CLI, Claude Code, Cursor, and Trae. It also prints an MCP config for manual setup:
projectbrain --store-root /absolute/path/to/.projectbrain-work mcp serve
Ask the agent to call projectbrain_context_pack before editing and projectbrain_review_git_diff after editing, both with output_format: "agent".
For non-interactive setup, pass one or more agents:
projectbrain --store-root ~/.projectbrain-work setup /path/to/my/project \
--id my_project \
--agent codex
For manual or advanced setup, ProjectBrain expects CodeGraph facts at:
<your-project>/.codegraph/codegraph.db
Import a local project into the JSON runtime:
.venv/bin/projectbrain import /path/to/my/project \
--id my_project \
--name "My Project" \
--path-prefix src/ \
--kind class \
--kind interface \
--kind method
If installed with Homebrew, run the same commands from any directory without the .venv/bin/ prefix:
projectbrain --store-root ~/.projectbrain-work import /path/to/my/project \
--id my_project \
--path-prefix src/ \
--kind class \
--kind interface \
--kind method
projectbrain --store-root ~/.projectbrain-work context my_project "Explain the checkout flow" --format agent
Then generate artifacts from the stored facts:
.venv/bin/projectbrain context my_project "Explain the checkout flow"
.venv/bin/projectbrain impact my_project "Change checkout validation" \
--changed-file src/checkout/CheckoutService.java
.venv/bin/projectbrain impact-diff my_project "Review staged checkout changes" --staged
.venv/bin/projectbrain impact-diff my_project "Review branch impact" --from main --to HEAD
Use compact output when an AI coding agent needs the next actions without the full artifact:
.venv/bin/projectbrain context my_project "Explain the checkout flow" --format agent
.venv/bin/projectbrain impact-diff my_project "Review staged checkout changes" --staged --format agent
Add local project experience so future context and impact results include human constraints:
.venv/bin/projectbrain claim add my_project \
--id exp_checkout_validation \
--applies-to checkout \
--risk high \
--review-state approved \
--claim-type HUMAN_CONFIRMED \
--statement "Checkout validation changes require compatibility review."
Review and archive local claims without deleting their history:
.venv/bin/projectbrain claim list my_project
.venv/bin/projectbrain claim review my_project exp_checkout_validation \
--review-state needs_review \
--risk medium
.venv/bin/projectbrain claim archive my_project exp_checkout_validation \
--reason "Superseded by newer checkout guidance."
Runtime artifacts are written under .projectbrain/, which is ignored by Git.
Optional FastAPI Server
python3 -m venv .venv
.venv/bin/python -m pip install -e '.[api]'
PYTHONPATH=apps/api:packages/adapters:packages/runtime:packages/schema \
.venv/bin/uvicorn projectbrain_api.main:app --reload
Routes:
GET /health
POST /api/v1/projects/import
GET /api/v1/projects
POST /api/v1/projects/{project_id}/context-pack
POST /api/v1/projects/{project_id}/impact-analysis
Local MCP Server
ProjectBrain can run as a local stdio MCP server for AI coding agents:
.venv/bin/projectbrain --store-root /absolute/path/to/.projectbrain mcp serve
It is a local child process. It does not open network sockets or upload source code. See Local MCP Usage.
MCP tools include project import, project listing, experience claim authoring, Context Packs, Impact Analysis, and Git diff review through projectbrain_review_git_diff. The read tools accept output_format: "agent" for compact agent-oriented results.
Privacy note: ProjectBrain controls the tool side, not the AI client side. MCP results may contain file paths, symbol names, and inferred risk notes. Whether those results are sent to a model provider depends on your AI client and model settings. For strict private-code environments, use a local model or an approved enterprise endpoint.
For additional local output controls, add .projectbrain-policy.json or .projectbrain-policy.yml to the imported project root:
{
"deny_paths": ["private/**", "src/main/resources/config/**"],
"output_limits": {
"max_items_per_section": 8,
"max_recommended_files": 8,
"max_recommended_tests": 5
},
"include_source_snippets": false
}
Context Pack, Impact Analysis, Git diff review, API, and MCP read outputs apply the policy. Source snippets remain disabled by default.
Inspect the policy that an imported project is using:
.venv/bin/projectbrain policy inspect my_project
Repository Layout
apps/
tools/ CLI tools
api/projectbrain_api/ optional FastAPI API
packages/
adapters/ CodeGraph adapter and artifact builders
runtime/ local JSON runtime and repository abstraction
schema/ dataclass schemas and validation
examples/payment-mini/ synthetic public demo data
tests/ unit and API tests
docs/ design and implementation notes
Public Data Boundary
This repository intentionally does not include real project source code, real CodeGraph databases, private configs, or production runtime stores.
The public demo is synthetic. If you use ProjectBrain on a private repository, keep these paths out of Git:
docs/payment/.projectbrain/.codegraph/generated from private code- private experience seeds
- private exported facts
Design Docs
| Document | Purpose |
|---|---|
| Design Document | Product positioning, architecture, components, APIs, and roadmap. |
| Domain Model | Project cognition domain model and bounded contexts. |
| Knowledge Schema | Knowledge graph, source refs, claims, confidence, and lifecycle. |
| MVP Architecture | Local MVP architecture, service boundaries, storage, and acceptance criteria. |
| Implementation Plan | Engineering phases, tests, operations, and open-source setup. |
| Agent Skills | Agent-facing skills for project understanding and impact analysis. |
| API Contract | REST and MCP contract draft. |
| CodeGraph Integration | CodeGraph as the first code-fact provider. |
| Local Runtime | CLI/runtime/API usage for the current local prototype. |
| MCP Usage | Local-only stdio MCP server usage and privacy boundary. |
| v0.2 Release Readiness | Release gate checks for tests, CLI/MCP smoke, policy, and privacy boundary. |
| 中文快速上手 | Chinese quickstart for local install, demo, MCP, claims, and privacy policy. |
| Delivery Gap Analysis | Remaining gaps between design and implementation. |
| Evaluation Plan | How to evaluate context quality, impact quality, and agent outcomes. |
Roadmap
- Add typed API request/response models.
- Add OpenAPI snapshot tests.
- Add richer Git diff symbol matching.
- Add richer agent output controls.
- Add project experience review and stale-claim workflow.
- Add database-backed repository implementation.
- Add more language adapters and richer source-fact extraction.
License
MIT
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.