ai-brain
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., "@ai-brainsearch for notes about machine learning"
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.
AI Brain
A self-hosted, web-first Markdown knowledge base that doubles as an AI brain. Documents and the links between them are stored in Postgres and exposed over both a REST API and an MCP server, so Claude, Codex, and other tooling can read, write, search, and traverse your notes. A drop-in replacement for Obsidian, built AI-native from the ground up.
Stack
Layer | Choice |
Frontend | Next.js (App Router) + Tailwind CSS v4 |
Backend | TypeScript service layer shared by the web API and the MCP server |
Database | Postgres 16 + pgvector (Drizzle ORM) |
Search | Hybrid: Postgres full-text + pgvector semantic (RRF) |
Auth | Auth.js credentials login + hashed Personal Access Tokens |
AI interface | MCP server (stdio + streamable HTTP) + REST, one shared core |
Deployment | Docker Compose |
Related MCP server: Notemd MCP Server
Repository layout
apps/
web/ Next.js app — UI, REST API, Auth.js
mcp/ MCP server (added in Phase 6)
packages/
core/ Domain/service layer (documents, links, search, embeddings, auth)
db/ Drizzle schema, migrations, Postgres + pgvector client
infra/
postgres/ First-boot init (enables the vector extension)Deploy with Docker Compose
The whole stack runs from one image:
cp .env.example .env # set AUTH_SECRET (openssl rand -base64 32)
docker compose up -d --build
# web → http://localhost:3002 · MCP → http://localhost:8787/mcpdocker compose brings up db (Postgres+pgvector), a one-shot migrate, then
web, mcp, and worker (async embedding + trash purge). The first registered
user becomes the admin. For a dev mail catcher (captures password-reset/verification
emails, UI on :1080): docker compose --profile mail up -d and set SMTP_HOST=maildev,
SMTP_PORT=1025.
Local development
pnpm install
cp .env.example .env # edit AUTH_SECRET etc.
docker compose up -d db # just Postgres
pnpm db:migrate # apply the schema
pnpm dev # web :3002, mcp, and worker (turbo)Connect Claude / Codex (MCP)
Generate a Personal Access Token at /settings/tokens, then point your client at the
MCP server. Tools exposed: search_documents, list_documents, get_document,
create_document, update_document, delete_document, get_backlinks, list_links,
plus a brain://documents/{id} resource.
Local (stdio) — e.g. Claude Code:
claude mcp add ai-brain \
--env AI_BRAIN_TOKEN=<your-PAT> \
-- node --import tsx /absolute/path/to/ai-brain/apps/mcp/src/stdio.tsRemote (Streamable HTTP) — run pnpm --filter @ai-brain/mcp start:http (defaults to
:8787), then:
claude mcp add --transport http ai-brain http://localhost:8787/mcp \
-H "Authorization: Bearer <your-PAT>"REST API
All endpoints accept Authorization: Bearer <PAT> (or a session cookie):
Method | Path | Scope |
GET/POST |
|
|
GET/PATCH/DELETE |
| read / write |
GET |
|
|
GET |
|
|
Build phases — all complete ✅
Scaffold — monorepo, Next.js + Tailwind, Postgres + pgvector, base schema.
Auth — login + Personal Access Tokens.
Documents — CRUD, Markdown parsing, editor.
Links —
[[wiki-links]]+ backlinks.Search — full-text + semantic (hybrid).
MCP — stdio + HTTP server over the service layer.
Each phase has a verify-phaseN*.mts script under packages/core/scripts (or
apps/mcp/scripts) demonstrating it end-to-end.
Production-readiness (added)
Async embedding via a Postgres-backed job queue + worker; real index-status badges.
Version history (coalesced snapshots) + soft-delete/Trash with retention purge.
Markdown import/export (zip) for spaces and documents.
Account hardening: password reset, email verification, admin + registration modes.
Full Docker Compose stack (db + migrate + web + mcp + worker).
Not yet done (follow-ups)
Graph view, folders/workspaces, SSO, real-time collaboration, attachments/images.
This server cannot be installed
Maintenance
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/TheJoshGriffith/ai-brain'
If you have feedback or need assistance with the MCP directory API, please join our Discord server