muninn-memory

TotalClaw 作者 KakāpōHiko (KH) v1.0.5

AI 代理的记忆系统。通过语义搜索、实体提取和显着性评分来存储、调用和管理记忆。在本地与 SQLite 和 Ollama 配合使用。免费套餐:功能齐全,无限制。

源码 ↗

安装 / 下载方式

TotalClaw CLI推荐
totalclaw install totalclaw:totalclaw~phillipneho-muninn-memory
cURL直接下载,无需登录
curl -fsSL https://skills.taituai.com/api/skills/totalclaw%3Atotalclaw~phillipneho-muninn-memory/file -o phillipneho-muninn-memory.md
Git 仓库获取源码
git clone https://github.com/openclaw/muninn-memory
## 概述(中文)

AI 代理的记忆系统。通过语义搜索、实体提取和显着性评分来存储、调用和管理记忆。在本地与 SQLite 和 Ollama 配合使用。免费套餐:功能齐全,无限制。

## 原文

# Muninn Memory

A local-first memory system for AI agents. Store episodic, semantic, and procedural memories with intelligent retrieval.

## Installation

```bash
clawhub install muninn-memory
```

Or install from source:
```bash
cd ~/.openclaw/workspace/skills
git clone https://github.com/openclaw/muninn-memory.git
cd muninn-memory
npm install && npm run build
```

## Requirements

- **Node.js** 18+
- **Ollama** running locally (for embeddings)
- **SQLite** (included)

## Quick Start

```typescript
import { MemoryStore } from 'muninn-memory';

// Initialize (creates SQLite DB)
const memory = new MemoryStore('./memories.db');

// Store a memory
const mem = await memory.remember(
  'Phillip lives in Brisbane, Australia',
  'semantic',
  { entities: ['Phillip', 'Brisbane', 'Australia'], salience: 0.8 }
);
console.log('Stored:', mem.id);

// Recall memories
const results = await memory.recall('Where does Phillip live?');
console.log(results[0].content);
// "Phillip lives in Brisbane, Australia"

// Get stats
console.log(memory.getStats());
// { total: 1, byType: { episodic: 0, semantic: 1, procedural: 0 }, entities: 3, edges: 0, procedures: 0 }

memory.close();
```

## Memory Types

| Type | Use Case |
|------|----------|
| `episodic` | Events, conversations, experiences |
| `semantic` | Facts, knowledge, relationships |
| `procedural` | Skills, workflows, step-by-step processes |

## API

### `remember(content, type, options?)`

Store a new memory.

```typescript
await memory.remember(
  'Meeting with Sarah about Q3 roadmap',
  'episodic',
  { 
    entities: ['Sarah', 'Q3 roadmap'],
    salience: 0.7,
    title: 'Q3 Planning Meeting'
  }
);
```

**Options:**
- `title?: string` - Short title
- `summary?: string` - Brief summary
- `entities?: string[]` - Extracted entities
- `topics?: string[]` - Topics/tags
- `salience?: number` - Importance 0-1 (default: 0.5)

**Returns:** `Memory` object with id, content, type, entities, etc.

### `recall(query, options?)`

Search memories using hybrid search.

```typescript
const results = await memory.recall('Sarah Q3', {
  limit: 5,
  types: ['episodic', 'semantic'],
  entities: ['Sarah'],
  topics: ['planning']
});
```

**Options:**
- `types?: MemoryType[]` - Filter by type
- `entities?: string[]` - Filter by entity
- `topics?: string[]` - Filter by topic
- `limit?: number` - Max results (default: 10)

**Returns:** Array of `Memory` objects sorted by relevance.

### `forget(id, hard?)`

Delete a memory.

```typescript
// Soft delete (can be recovered)
memory.forget('m_abc123');

// Hard delete (permanent)
memory.forget('m_abc123', true);
```

### `getEntities()`

List all extracted entities.

```typescript
const entities = memory.getEntities();
// [{ name: 'Phillip', memory_count: 5, last_seen: '2026-02-24...' }, ...]
```

### `getStats()`

Get vault statistics.

```typescript
const stats = memory.getStats();
// { total: 42, byType: {...}, entities: 15, edges: 8, procedures: 3 }
```

## CLI Usage

```bash
# Run tests
node dist/index.js test

# Start MCP server (for agent integration)
npm run mcp
```

## MCP Server

Start the MCP server for agent integration:

```bash
npm run mcp
```

**Security Verification:**

| Claim | Evidence |
|-------|----------|
| **stdio-only transport** | `src/mcp/server.ts:5` imports `StdioServerTransport` from `@modelcontextprotocol/sdk/server/stdio.js` — no HTTP/TCP listeners |
| **Local-only network** | Only `fetch('http://localhost:11434/...')` for Ollama embeddings — no external servers |
| **No postinstall scripts** | `package.json` has no `postinstall`, `preinstall`, or `postbuild` scripts |
| **Dependencies** | Only `better-sqlite3` (local DB), `ollama` (local embeddings), `uuid` — all from npm |
| **Credentials** | No environment variables, no secrets in code |

**Database:** Default location is `./openclaw-memory.db` (SQLite, local file).

**Known Limitations:**
- Memory content is passed to LLM prompts — users could inject instructions via stored memories
- Calls local Ollama at `localhost:11434` for embeddings — requires Ollama running

## Security Notes

1. ✅ **No external network** — MCP server uses stdio, not HTTP/TCP. Only calls `localhost:11434` for local Ollama embeddings.
2. ✅ **No authentication required** — Only accessible to the parent process
3. ✅ **Local-only database** — SQLite file, no remote connections
4. ✅ **No credentials needed** — Only requires local Ollama for embeddings
5. ✅ **No postinstall scripts** — Clean npm install
6. ⚠️ **Prompt injection risk** — Memory content is passed to LLM prompts. If users store malicious content, it could affect LLM behavior. This is inherent to all memory systems.

## Database Location

Default: `./openclaw-memory.db`

Custom path:
```typescript
const memory = new MemoryStore('/path/to/custom.db');
```

## Features

- **Hybrid Search** — BM25 + semantic (embedding) with reciprocal rank fusion
- **Entity Extraction** — Auto-extract people, orgs, projects, technologies
- **Spelling Variants** — UK↔US English expansion (colour/color, etc.)
- **Question-Type Aware** — Factual questions prioritize semantic memories
- **Entity Boost** — Memories with matching entities rank higher

## Benchmark

| System | LOCOMO Score |
|--------|--------------|
| **Muninn** | **93%** |
| Engram | 79.6% |
| Mem0 | 66.9% |

Muninn Phase 1.5 includes knowledge graph integration for temporal reasoning and contradiction detection.

## License

MIT — Free, open source, no restrictions.

---

🦜 *Built by KakāpōHiko (KH)*