mem0-plugin/skills/pin/SKILL.md
Pin a memory to mark it as high-priority and protect from pruning.
The user provides either a search query or memory ID.
If memory ID:
get_memory with the ID.If search query:
search_memories with the query, filters={"AND": [{"user_id": "<id>"}, {"app_id": "<pid>"}]}, top_k=5.Call get_memory with the selected memory ID. Store:
original_text — the memory's text contentoriginal_metadata — the existing metadata dictThe MCP update_memory tool only accepts memory_id, text, and source — it
does not accept a metadata parameter. To pin, append a pin marker to the text:
pinned_text = "[PINNED] " + original_text if not original_text.startswith("[PINNED]") else original_text
update_memory(memory_id=<selected_id>, text=pinned_text)
For new memories (user wants to pin text that isn't stored yet):
add_memory with:
text="[PINNED] <the user's text>"user_id=<active_user_id>app_id=<active_project_id>metadata={"pinned": true, "type": "decision", "confidence": 1.0}infer=Falseevent_id. Call get_event_status(event_id=<event_id>) once to retrieve the memory ID, then confirm.Pinned: "<memory content, first 80 chars>"
Memory ID: <id>
Append ... only if content exceeds 80 characters.
If the user says "unpin":
get_memory to read current content.unpinned_text = original_text.removeprefix("[PINNED] ")
update_memory(memory_id=<id>, text=unpinned_text)
Unpinned: "<content>..."