Skip to main content

Mimir persistent, local, encrypted memory for Pydantic AI agents — exposed as a Toolset.

Project description

pydantic-ai-mimir

Persistent, local-first, encrypted memory for Pydantic AI agents — backed by Mimir.

MimirToolset gives a Pydantic AI Agent durable memory that survives across runs and processes. Your agent can mimir_remember facts and mimir_recall them later, with full-text + semantic search, all stored in a local SQLite database that never leaves the machine (and can be AES-256-GCM encrypted at rest).

Why this package?

Pydantic AI already speaks the Model Context Protocol natively via MCPToolset, and Mimir is an MCP stdio server — so you could wire them together by hand. MimirToolset is the ergonomic shortcut: it subclasses MCPToolset, resolves the mimir binary, manages the database path, optionally enables encryption, and spawns mimir serve for you. One line instead of a transport assembly. Because it is an MCPToolset, every Pydantic AI MCP feature (tool caching, include_instructions, process_tool_call, tool filtering/renaming) works unchanged.

Prerequisite: the mimir binary

Mimir is a single self-contained binary. Install it and make sure it is on your PATH:

# Build from source (Rust toolchain required):
git clone https://github.com/Perseus-Computing-LLC/mimir
cd mimir && cargo build --release
# then put target/release/mimir on your PATH

# ...or download a prebuilt binary from the releases page:
#   https://github.com/Perseus-Computing-LLC/mimir/releases

Verify:

mimir --version

Install

pip install pydantic-ai-mimir

This pulls in pydantic-ai-slim[mcp]. If you already use the full pydantic-ai, that satisfies the dependency too.

Usage

import asyncio

from pydantic_ai import Agent
from pydantic_ai_mimir import MimirToolset

# Spawns `mimir serve --db ~/.mimir/agent.db` and exposes its memory tools.
memory = MimirToolset(db_path="~/.mimir/agent.db")

agent = Agent(
    "openai:gpt-5",
    toolsets=[memory],
    instructions=(
        "You have a persistent memory. Use mimir_remember to store durable "
        "facts about the user, and mimir_recall to look them up before "
        "answering."
    ),
)


async def main() -> None:
    async with agent:  # opens the MCP connection for the agent's lifetime
        await agent.run("My favourite colour is teal. Please remember that.")
        result = await agent.run("What's my favourite colour?")
        print(result.output)  # -> teal


asyncio.run(main())

Encryption at rest

memory = MimirToolset(
    db_path="~/.mimir/agent.db",
    encryption_key="~/.mimir/key.b64",  # base64-encoded 32-byte AES-256-GCM key
)

Custom binary location

memory = MimirToolset(
    db_path="~/.mimir/agent.db",
    mimir_binary="/opt/mimir/bin/mimir",  # explicit path; otherwise resolved from PATH
)

Passing through MCPToolset options

Any MCPToolset keyword is forwarded:

memory = MimirToolset(
    db_path="~/.mimir/agent.db",
    id="mimir-memory",          # stable id (needed for Temporal/DBOS durability)
    include_instructions=True,  # inject Mimir's server instructions into the agent
    cache_tools=True,
)

What tools does the agent get?

All of Mimir's MCP tools, including:

Tool Purpose
mimir_remember Store a durable memory (category, key, body, tags)
mimir_recall Hybrid full-text + semantic search over memories
mimir_get_entity Fetch a specific memory by id/key
mimir_timeline Time-ordered view of memories
mimir_forget / mimir_supersede Delete or replace memories
mimir_link / mimir_traverse Relate and walk between memories
... and many more (stats, journaling, vault import/export, etc.)

The exact set depends on your installed Mimir version.

Development

pip install -e ".[test]"
pytest

The unit tests mock the subprocess and run with no mimir binary installed. A real end-to-end smoke test runs automatically when a mimir binary is on PATH, and is skipped otherwise.

License

MIT © 2026 Perseus Computing LLC

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pydantic_ai_mimir-0.1.0.tar.gz (9.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pydantic_ai_mimir-0.1.0-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

File details

Details for the file pydantic_ai_mimir-0.1.0.tar.gz.

File metadata

  • Download URL: pydantic_ai_mimir-0.1.0.tar.gz
  • Upload date:
  • Size: 9.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pydantic_ai_mimir-0.1.0.tar.gz
Algorithm Hash digest
SHA256 66ece17b16dd18897c3bdc74835582bd42ce92b36c2c4fd029a323b75640157d
MD5 84d8211fd23529ff72a0de721c1c650b
BLAKE2b-256 fc80870a6d8faa3693b54d8b01639ca2d5c488a98f29dcb11a88c83945a642f9

See more details on using hashes here.

Provenance

The following attestation bundles were made for pydantic_ai_mimir-0.1.0.tar.gz:

Publisher: publish.yml on Perseus-Computing-LLC/pydantic-ai-mimir

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pydantic_ai_mimir-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pydantic_ai_mimir-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 25c8d8fa8a663be14737e271293f03d2a016aedb736e4eb3e1e0b0d07c10e868
MD5 036707b1cba4a2ab29b9e8aae3aeff31
BLAKE2b-256 2a1ee858c5039f186ad75e66b56c6207c3736982f6ff0b056a538f47b7e418c4

See more details on using hashes here.

Provenance

The following attestation bundles were made for pydantic_ai_mimir-0.1.0-py3-none-any.whl:

Publisher: publish.yml on Perseus-Computing-LLC/pydantic-ai-mimir

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page