1d3eecbf9d
Add `mempalace sync` CLI command and `mempalace_sync` MCP tool that prune drawers whose source files are gitignored, deleted, or moved out of the project. Reuses the existing GitignoreMatcher infrastructure in mempalace/miner.py so the same gitignore rules that block ingest also drive the corresponding cleanup. Closes #1252.
396 lines
12 KiB
Markdown
396 lines
12 KiB
Markdown
# MCP Tools Reference
|
||
|
||
Detailed parameter schemas for all 30 MCP tools.
|
||
|
||
## Palace — Read Tools
|
||
|
||
### `mempalace_status`
|
||
|
||
Palace overview: total drawers, wing and room counts, AAAK spec, and memory protocol.
|
||
|
||
**Parameters:** None
|
||
|
||
**Returns:** `{ total_drawers, wings, rooms, protocol, aaak_dialect }`
|
||
|
||
---
|
||
|
||
### `mempalace_list_wings`
|
||
|
||
List all wings with drawer counts.
|
||
|
||
**Parameters:** None
|
||
|
||
**Returns:** `{ wings: { "wing_name": count } }`
|
||
|
||
---
|
||
|
||
### `mempalace_list_rooms`
|
||
|
||
List rooms within a wing (or all rooms if no wing given).
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `wing` | string | No | Wing to list rooms for |
|
||
|
||
**Returns:** `{ wing, rooms: { "room_name": count } }`
|
||
|
||
---
|
||
|
||
### `mempalace_get_taxonomy`
|
||
|
||
Full wing → room → drawer count tree.
|
||
|
||
**Parameters:** None
|
||
|
||
**Returns:** `{ taxonomy: { "wing": { "room": count } } }`
|
||
|
||
---
|
||
|
||
### `mempalace_search`
|
||
|
||
Semantic search. Returns verbatim drawer content with similarity scores.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `query` | string | **Yes** | What to search for |
|
||
| `limit` | integer | No | Max results (default: 5) |
|
||
| `wing` | string | No | Filter by wing |
|
||
| `room` | string | No | Filter by room |
|
||
|
||
**Returns:** `{ query, filters, results: [{ text, wing, room, source_file, similarity }] }`
|
||
|
||
---
|
||
|
||
### `mempalace_check_duplicate`
|
||
|
||
Check if content already exists in the palace before filing.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `content` | string | **Yes** | Content to check |
|
||
| `threshold` | number | No | Similarity threshold 0–1 (default: 0.85–0.87) |
|
||
|
||
**Returns:** `{ is_duplicate, matches: [{ id, wing, room, similarity, content }] }`
|
||
|
||
---
|
||
|
||
### `mempalace_get_aaak_spec`
|
||
|
||
Returns the AAAK dialect specification.
|
||
|
||
**Parameters:** None
|
||
|
||
**Returns:** `{ aaak_spec: "..." }`
|
||
|
||
---
|
||
|
||
## Palace — Write Tools
|
||
|
||
### `mempalace_add_drawer`
|
||
|
||
File verbatim content into the palace. Identical content (same deterministic drawer ID) is silently skipped. For similarity-based duplicate detection before filing, use `mempalace_check_duplicate`.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `wing` | string | **Yes** | Wing (project name) |
|
||
| `room` | string | **Yes** | Room (aspect: backend, decisions, etc.) |
|
||
| `content` | string | **Yes** | Verbatim content to store |
|
||
| `source_file` | string | No | Where this came from |
|
||
| `added_by` | string | No | Who is filing (default: "mcp") |
|
||
|
||
**Returns:** `{ success, drawer_id, wing, room }`
|
||
|
||
---
|
||
|
||
### `mempalace_delete_drawer`
|
||
|
||
Delete a drawer by ID. Irreversible.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `drawer_id` | string | **Yes** | ID of the drawer to delete |
|
||
|
||
**Returns:** `{ success, drawer_id }`
|
||
|
||
---
|
||
|
||
### `mempalace_sync`
|
||
|
||
Prune drawers whose source files are gitignored, deleted, or moved. Returns a dry-run report by default; pass `apply=true` to commit deletions.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `project_dir` | string | No | Project root to scope the sync (auto-detected from drawer metadata if omitted) |
|
||
| `wing` | string | No | Limit to one wing |
|
||
| `apply` | boolean | No | Actually delete drawers; default is dry-run preview |
|
||
|
||
**Returns:** `{ scanned, kept, gitignored, missing, no_source, out_of_scope, removed_drawers, removed_closets, dry_run, by_source }`
|
||
|
||
---
|
||
|
||
### `mempalace_get_drawer`
|
||
|
||
Fetch a single drawer by ID — returns full content and metadata.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `drawer_id` | string | **Yes** | ID of the drawer to fetch |
|
||
|
||
**Returns:** `{ drawer_id, content, wing, room, metadata }` where `metadata.source_file`, when present, is the basename only — the absolute path written by the miners is reduced before the dict is returned to MCP clients.
|
||
|
||
---
|
||
|
||
### `mempalace_list_drawers`
|
||
|
||
List drawers with pagination. Optional wing/room filter. Returns IDs, wings, rooms, and content previews.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `wing` | string | No | Filter by wing |
|
||
| `room` | string | No | Filter by room |
|
||
| `limit` | integer | No | Max results per page (default 20, max 100) |
|
||
| `offset` | integer | No | Offset for pagination (default 0) |
|
||
|
||
**Returns:** `{ drawers: [...], total, limit, offset }`
|
||
|
||
---
|
||
|
||
### `mempalace_update_drawer`
|
||
|
||
Update an existing drawer's content and/or metadata (wing, room). Fetches the existing drawer first; returns an error if not found.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `drawer_id` | string | **Yes** | ID of the drawer to update |
|
||
| `content` | string | No | New content (omit to keep existing) |
|
||
| `wing` | string | No | New wing (omit to keep existing) |
|
||
| `room` | string | No | New room (omit to keep existing) |
|
||
|
||
**Returns:** `{ success, drawer_id, updated_fields }`
|
||
|
||
---
|
||
|
||
## Knowledge Graph Tools
|
||
|
||
### `mempalace_kg_query`
|
||
|
||
Query entity relationships with time filtering.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `entity` | string | **Yes** | Entity to query (e.g. "Max", "MyProject") |
|
||
| `as_of` | string | No | Date filter — only facts valid at this date (YYYY-MM-DD) |
|
||
| `direction` | string | No | `outgoing`, `incoming`, or `both` (default: `both`) |
|
||
|
||
**Returns:** `{ entity, as_of, facts: [{ direction, subject, predicate, object, valid_from, valid_to, current }], count }`
|
||
|
||
---
|
||
|
||
### `mempalace_kg_add`
|
||
|
||
Add a fact to the knowledge graph.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `subject` | string | **Yes** | The entity doing/being something |
|
||
| `predicate` | string | **Yes** | Relationship type (e.g. "loves", "works_on") |
|
||
| `object` | string | **Yes** | The entity being connected to |
|
||
| `valid_from` | string | No | When this became true (YYYY-MM-DD) |
|
||
| `source_closet` | string | No | Closet ID where this fact appears |
|
||
|
||
**Returns:** `{ success, triple_id, fact }`
|
||
|
||
---
|
||
|
||
### `mempalace_kg_invalidate`
|
||
|
||
Mark a fact as no longer true.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `subject` | string | **Yes** | Entity |
|
||
| `predicate` | string | **Yes** | Relationship |
|
||
| `object` | string | **Yes** | Connected entity |
|
||
| `ended` | string | No | When it stopped being true (default: today) |
|
||
|
||
**Returns:** `{ success, fact, ended }`
|
||
|
||
---
|
||
|
||
### `mempalace_kg_timeline`
|
||
|
||
Chronological timeline of facts.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `entity` | string | No | Entity to get timeline for (omit for full timeline) |
|
||
|
||
**Returns:** `{ entity, timeline: [{ subject, predicate, object, valid_from, valid_to, current }], count }`
|
||
|
||
---
|
||
|
||
### `mempalace_kg_stats`
|
||
|
||
Knowledge graph overview.
|
||
|
||
**Parameters:** None
|
||
|
||
**Returns:** `{ entities, triples, current_facts, expired_facts, relationship_types }`
|
||
|
||
---
|
||
|
||
## Navigation Tools
|
||
|
||
### `mempalace_traverse`
|
||
|
||
Walk the palace graph from a room. Find connected ideas across wings.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `start_room` | string | **Yes** | Room to start from |
|
||
| `max_hops` | integer | No | How many connections to follow (default: 2) |
|
||
|
||
**Returns:** `[{ room, wings, halls, count, hop, connected_via }]`
|
||
|
||
---
|
||
|
||
### `mempalace_find_tunnels`
|
||
|
||
Find rooms that bridge two wings.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `wing_a` | string | No | First wing |
|
||
| `wing_b` | string | No | Second wing |
|
||
|
||
**Returns:** `[{ room, wings, halls, count, recent }]`
|
||
|
||
---
|
||
|
||
### `mempalace_graph_stats`
|
||
|
||
Palace graph overview: nodes, tunnels, edges, connectivity.
|
||
|
||
**Parameters:** None
|
||
|
||
**Returns:** `{ total_rooms, tunnel_rooms, total_edges, rooms_per_wing, top_tunnels }`
|
||
|
||
---
|
||
|
||
### `mempalace_create_tunnel`
|
||
|
||
Create a cross-wing tunnel linking two palace locations. Use when content in one project relates to another — e.g., an API design in `project_api` connects to a database schema in `project_database`.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `source_wing` | string | **Yes** | Wing of the source |
|
||
| `source_room` | string | **Yes** | Room in the source wing |
|
||
| `target_wing` | string | **Yes** | Wing of the target |
|
||
| `target_room` | string | **Yes** | Room in the target wing |
|
||
| `label` | string | No | Description of the connection |
|
||
| `source_drawer_id` | string | No | Specific source drawer ID |
|
||
| `target_drawer_id` | string | No | Specific target drawer ID |
|
||
|
||
**Returns:** `{ success, tunnel_id, source, target }`
|
||
|
||
---
|
||
|
||
### `mempalace_list_tunnels`
|
||
|
||
List all explicit cross-wing tunnels. Optionally filter by wing.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `wing` | string | No | Filter tunnels by wing (source or target) |
|
||
|
||
**Returns:** `{ tunnels: [...], count }`
|
||
|
||
---
|
||
|
||
### `mempalace_delete_tunnel`
|
||
|
||
Delete an explicit tunnel by its ID.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `tunnel_id` | string | **Yes** | Tunnel ID to delete |
|
||
|
||
**Returns:** `{ success, tunnel_id }`
|
||
|
||
---
|
||
|
||
### `mempalace_follow_tunnels`
|
||
|
||
Follow tunnels from a room to see what it connects to in other wings. Returns connected rooms with drawer previews.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `wing` | string | **Yes** | Wing to start from |
|
||
| `room` | string | **Yes** | Room to follow tunnels from |
|
||
|
||
**Returns:** `[{ wing, room, label, previews }]`
|
||
|
||
---
|
||
|
||
## Agent Diary Tools
|
||
|
||
### `mempalace_diary_write`
|
||
|
||
Write to your personal agent diary.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `agent_name` | string | **Yes** | Your name — each agent gets its own wing |
|
||
| `entry` | string | **Yes** | Diary entry (in AAAK format recommended) |
|
||
| `topic` | string | No | Topic tag (default: "general") |
|
||
|
||
**Returns:** `{ success, entry_id, agent, topic, timestamp }`
|
||
|
||
---
|
||
|
||
### `mempalace_diary_read`
|
||
|
||
Read recent diary entries.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `agent_name` | string | **Yes** | Your name |
|
||
| `last_n` | integer | No | Number of recent entries (default: 10) |
|
||
|
||
**Returns:** `{ agent, entries: [{ date, timestamp, topic, content }], total, showing }`
|
||
|
||
---
|
||
|
||
## System Tools
|
||
|
||
### `mempalace_hook_settings`
|
||
|
||
Get or set auto-save hook behaviour. `silent_save=true` saves directly without MCP-level clutter; `silent_save=false` uses the legacy blocking path. `desktop_toast=true` surfaces a desktop notification when a save completes. Call with no arguments to view the current settings.
|
||
|
||
| Parameter | Type | Required | Description |
|
||
|-----------|------|----------|-------------|
|
||
| `silent_save` | boolean | No | `true` = silent direct save, `false` = blocking MCP calls |
|
||
| `desktop_toast` | boolean | No | `true` = show desktop toast via `notify-send` |
|
||
|
||
**Returns:** `{ silent_save, desktop_toast }`
|
||
|
||
---
|
||
|
||
### `mempalace_memories_filed_away`
|
||
|
||
Check whether a recent palace checkpoint was saved. Returns message count and timestamp of the last save.
|
||
|
||
**Parameters:** None
|
||
|
||
**Returns:** `{ filed, message_count, timestamp }`
|
||
|
||
---
|
||
|
||
### `mempalace_reconnect`
|
||
|
||
Force a reconnect to the palace database. Use this after external scripts or CLI commands modified the palace directly, which can leave the in-memory HNSW index stale.
|
||
|
||
**Parameters:** None
|
||
|
||
**Returns:** `{ success, message, drawers, vector_disabled[, vector_disabled_reason] }` (on no-palace: `{ success: false, message, drawers, vector_disabled }`; on exception: `{ success: false, error }`)
|