Memory Crystal MCP Server

Memory Crystal MCP Server

Enables AI agents to maintain persistent memory across sessions by capturing conversations, extracting durable knowledge, and injecting relevant context, supporting various MCP-compatible platforms.

Category
Visit Server

README

<!-- This repository is the open-source mirror of Memory Crystal. The hosted service and web app are maintained separately. -->

<p align="center"> <a href="https://memorycrystal.ai"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://raw.githubusercontent.com/memorycrystal/memorycrystal/main/assets/logo-dark.svg"> <source media="(prefers-color-scheme: light)" srcset="https://raw.githubusercontent.com/memorycrystal/memorycrystal/main/assets/logo-light.svg"> <img src="https://raw.githubusercontent.com/memorycrystal/memorycrystal/main/assets/logo-light.svg" alt="Memory Crystal" width="320"> </picture> </a> </p>

<p align="center"> <strong>Persistent memory for AI agents.</strong><br> <sub>Every conversation remembered. Every decision recalled. Every session informed.</sub> </p>

<p align="center"> <a href="LICENSE"><img src="https://img.shields.io/badge/License-MIT-blue.svg?style=flat-square" alt="MIT License"></a> <a href="https://www.npmjs.com/package/@memorycrystal/crystal-memory"><img src="https://img.shields.io/npm/v/@memorycrystal/crystal-memory?style=flat-square&color=cb3837" alt="npm"></a> <a href="https://memorycrystal.ai"><img src="https://img.shields.io/badge/Cloud-Online-00c853?style=flat-square" alt="Cloud"></a> <a href="https://docs.memorycrystal.ai"><img src="https://img.shields.io/badge/Docs-docs.memorycrystal.ai-2180D6?style=flat-square" alt="Docs"></a> </p>

<p align="center"> <a href="https://memorycrystal.ai">Website</a> · <a href="https://docs.memorycrystal.ai">Docs</a> · <a href="https://memorycrystal.ai/dashboard">Dashboard</a> · <a href="https://memorycrystal.ai/pricing">Pricing</a> </p>


Your AI forgets everything between sessions — who you are, what you decided, what failed, what works. Memory Crystal fixes that.

It captures conversations in real time, extracts durable knowledge, manages raw sensory retention, and injects the right context before every response. One install. No prompting gymnastics. Your AI just knows.

curl -fsSL https://memorycrystal.ai/crystal | bash

Works with everything

Install Memory Crystal on any MCP-compatible AI tool in one command:

Platform Install
Claude Code curl -fsSL https://memorycrystal.ai/install-claude-mcp.sh | bash
Codex CLI curl -fsSL https://memorycrystal.ai/install-codex-mcp.sh | bash
Factory Droid curl -fsSL https://memorycrystal.ai/install-droid-mcp.sh | bash
OpenClaw curl -fsSL https://memorycrystal.ai/crystal | bash
Claude Desktop Add the MCP server in settings (guide)
Any MCP host Point at https://api.memorycrystal.ai/mcp with a Bearer token

The universal installer supports cloud, local, and self-hosted backends. It can register MCP clients, configure OpenClaw, install Codex/Claude hook assets, and stage a Dockerized local Convex backend for offline or self-hosted work.


How it works

  You send a message
       │
       ▼
┌─────────────────────────────────────────┐
│           CONTEXT ENGINE                │
│                                         │
│  Semantic search + BM25 across STM/LTM  │
│  Knowledge graph boost                  │
│  Multi-signal reranker                  │
│  Diversity filter + context budgeting   │
│  → Inject top memories into context     │
└─────────────────────────────────────────┘
       │
       ▼
  AI responds with full context
       │
       ▼
┌─────────────────────────────────────────┐
│         MEMORY EXTRACTION               │
│                                         │
│  Raw message → Short-term memory        │
│  LLM extracts facts/decisions → LTM     │
│  Graph enrichment links related memories│
└─────────────────────────────────────────┘

Every response is informed by what came before. Every conversation feeds the next one.


Two memory layers

Layer Stores Retention
Short-term (STM) Recent raw messages, verbatim Rolling window by tier
Long-term (LTM) Facts, decisions, lessons, people, rules Permanent, vector-indexed
Sensory raw content Raw sensory payloads behind memory records Summarized, tombstoned, or protected by policy

STM gives recent continuity. LTM gives permanent knowledge. Sensory retention lets Memory Crystal keep durable recall value without keeping every raw payload forever.

Five memory stores

Store Purpose Example
sensory Raw signals "the user sounds frustrated about the deploy"
episodic Events "We shipped v2 on March 15"
semantic Facts "The API uses Convex for the backend"
procedural How-to "Deploy with npm run convex:deploy"
prospective Plans "Add billing webhooks next sprint"

Knowledge graph

Memories don't exist in isolation. An async background job connects related memories — decisions link to the lessons that informed them, people link to their projects, rules link to the events that created them.

When the Context Engine searches, graph-connected memories rank higher. Your AI doesn't just remember facts — it understands relationships.

Adaptive recall

Six modes, automatically selected:

Mode Prioritizes
General Broad recall across STM + LTM
Decision Decisions, lessons, and rules before risky changes
Project Goals, workflows, and implementation context
People Ownership, collaborators, and relationships
Workflow Procedures, rules, and how-to memory
Conversation Recent session context and continuity

The Context Engine picks the right mode. You don't configure anything.


Knowledge bases

First-class immutable reference collections for docs, policies, runbooks, and imported source material. They sit alongside conversational memory so your agent can keep learned context and stable reference data separate.

  • Immutable — imported chunks stay stable, not rewritten by conversation
  • Scoped — tenant and scope filters keep KBs private to the right workspace
  • Bulk import — standard import or high-volume bulk-insert without blocking on embedding
  • Background enrichment — embedding and graph backfill run asynchronously

24 memory tools

Every tool works in any MCP host or automatically within OpenClaw hooks.

Tool What it does
crystal_recall Semantic search across all long-term memory
crystal_remember Store a memory — decisions, facts, lessons
crystal_what_do_i_know Everything known about a topic
crystal_why_did_we Decision archaeology — why a past choice was made
crystal_preflight Pre-flight check before risky actions
crystal_search_messages Hybrid search over verbatim conversation history
crystal_checkpoint Snapshot memory state at a milestone
crystal_wake Session startup — briefing and guardrails
crystal_trace Trace a memory back to its source conversation
crystal_who_owns Find ownership of a file, module, or area
crystal_explain_connection Explain relationships between concepts
crystal_dependency_chain Trace dependency chains between entities
crystal_recent Recent messages for short-term context
crystal_edit Update an existing memory
crystal_forget Archive or delete a memory
crystal_stats Memory and usage statistics
crystal_set_scope Override channel scope for the session
crystal_list_knowledge_bases List available knowledge bases
crystal_query_knowledge_base Search a knowledge base
crystal_import_knowledge Import reference chunks into a KB
crystal_ideas List active Organic ideas and discoveries
crystal_idea_action Act on Organic ideas
memory_search Search LTM and return crystal paths
memory_get Read a full memory by ID or path

HTTP API

All core operations available over authenticated HTTP:

POST /api/mcp/capture              Create a memory
POST /api/mcp/recall               Hybrid recall over all memory
POST /api/mcp/search-messages      Search short-term history

GET  /api/knowledge-bases          List knowledge bases
POST /api/knowledge-bases          Create a knowledge base
POST /api/knowledge-bases/:id/import       Import chunks
POST /api/knowledge-bases/:id/bulk-insert  High-volume migration
POST /api/knowledge-bases/:id/query        Query a knowledge base

All endpoints require Authorization: Bearer <api-key>. Per-key rate limiting enforced.


Architecture

memorycrystal/
├── plugin/                 OpenClaw plugin — hooks into conversation lifecycle
├── plugins/shared/         Shared hook script for Claude Code, Codex, Factory
├── mcp-server/             MCP server — stdio/HTTP compatibility layer
├── packages/mcp-server/    Streamable HTTP MCP variant
├── convex/                 Backend — schema, capture, recall, graph, retention
│   └── crystal/            All Memory Crystal Convex functions
├── apps/
│   ├── web/                Next.js 15 dashboard (Tailwind 4, Convex Auth)
│   └── docs/               Mintlify documentation site
├── scripts/                Install, bootstrap, doctor, enable/disable
└── assets/                 Logos and brand assets

Local development

Contributors can run an opt-in Dockerized Convex backend and dashboard locally, then seed fixture data without touching the managed production deployment:

npm run convex:local:up
npm run convex:local:seed
npm run convex:local:doctor

Provider keys are intentionally split: MEMORY_CRYSTAL_API_KEY is client bearer auth, GEMINI_API_KEY powers Gemini embeddings, and optional OPENROUTER_API_KEY powers organic model features.

The local stack uses http://127.0.0.1:3210 for Convex RPC, http://127.0.0.1:3211 for HTTP actions, and http://127.0.0.1:6791 for the dashboard. See the Local-First Setup guide for end-user setup, local endpoints, backup and rollback behavior, and troubleshooting.

Self-hosted

Run everything on your own infrastructure:

git clone https://github.com/memorycrystal/memorycrystal.git
cd memorycrystal && npm install

# Deploy to your own Convex project
CONVEX_DEPLOYMENT=prod:your-project-123 npx convex deploy

# Configure
echo 'CONVEX_URL=https://your-project-123.convex.cloud' > mcp-server/.env
echo 'GEMINI_API_KEY=your-key' >> mcp-server/.env

# Enable and verify
npm run crystal:enable
npm run crystal:doctor

For install-script OpenClaw installs, verify the loaded plugin directly:

openclaw plugins info crystal-memory
openclaw crystal_status

Full guide: docs.memorycrystal.ai/configuration/self-hosting


Security

  • Multi-tenant isolation — owner checks on every retrieval, database-level separation
  • API keys — SHA-256 hashed at rest, plaintext never stored
  • Content scanner — blocks prompt injection, encoded payloads, credential patterns
  • Prompt injection mitigation — recalled memories injected as informational context only
  • Rate limiting — per-key enforcement on all endpoints
  • Audit logging — all actions logged to crystalAuditLog
  • Device flow auth — RFC 8628-style for CLI key provisioning
  • Local mode — SQLite fallback, data never leaves your machine

Pricing

Plan Price Memories STM Retention
Free $0/mo 500 7 days
Pro $29/mo 25,000 30 days
Ultra $79/mo Unlimited 90 days
Enterprise Custom Custom Custom

Self-hosting is always free. Paid plans are for the managed cloud at memorycrystal.ai.


Contributing

Memory Crystal is MIT open source. PRs welcome.

git clone https://github.com/memorycrystal/memorycrystal.git
cd memorycrystal && npm install && npm run dev

Star History

<a href="https://www.star-history.com/?repos=memorycrystal%2Fmemorycrystal&type=date&legend=top-left"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://api.star-history.com/chart?repos=memorycrystal/memorycrystal&type=date&theme=dark&legend=top-left" /> <source media="(prefers-color-scheme: light)" srcset="https://api.star-history.com/chart?repos=memorycrystal/memorycrystal&type=date&legend=top-left" /> <img alt="Star History Chart" src="https://api.star-history.com/chart?repos=memorycrystal/memorycrystal&type=date&legend=top-left" /> </picture> </a>


<p align="center"> <sub>MIT License — <a href="https://memorycrystal.ai">memorycrystal.ai</a> — Operated by Illumin8 Inc.</sub> </p>

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured