Skip to main content

Centralized, governed memory for AI agents

Project description

memoryhub

Centralized, governed memory for AI agents.

MemoryHub provides a persistent memory layer for AI agents running on OpenShift AI, with scope-based access control, multi-tenant isolation, and an immutable audit trail. It works with any agent framework — LlamaStack, LangChain, Claude Code, Cursor, and more.

Status: Alpha (v0.5.1). Core operations are stable; curation and relationship APIs may evolve.

Installation

pip install memoryhub

Requires Python 3.10+.

Quick start

import asyncio
from memoryhub import MemoryHubClient

async def main():
    # API key mode (simplest):
    client = MemoryHubClient(
        url="https://mcp-server.apps.example.com/mcp/",
        api_key="mh-dev-abc123",
    )

    async with client:
        # Search memories
        results = await client.search("deployment patterns", max_results=5)
        for memory in results.results:
            print(f"[{memory.scope}] {memory.content[:80]}")

        # Write a memory
        written = await client.write(
            "FastAPI is the preferred web framework",
            scope="project",
            weight=0.85,
        )
        print(f"Created: {written.memory.id}")

asyncio.run(main())

server_url is accepted as an alias for url for backward compatibility.

OAuth 2.1 mode

Recommended for production multi-agent deployments:

import asyncio
from memoryhub import MemoryHubClient

async def main():
    # OAuth 2.1 mode (recommended for production):
    client = MemoryHubClient(
        url="https://mcp-server.apps.example.com/mcp/",
        auth_url="https://auth-server.apps.example.com",
        client_id="my-agent",
        client_secret="my-secret",
    )

    async with client:
        # Search memories
        results = await client.search("deployment patterns", max_results=5)
        for memory in results.results:
            print(f"[{memory.scope}] {memory.content[:80]}")

        # Write a memory
        written = await client.write(
            "FastAPI is the preferred web framework",
            scope="project",
            weight=0.85,
        )
        print(f"Created: {written.memory.id}")

        # Read it back
        memory = await client.read(written.memory.id)
        print(memory.content)

        # Update it
        updated = await client.update(written.memory.id, weight=0.9)
        print(f"Version: {updated.version}")

        # Campaign-scoped search (requires project enrollment)
        campaign_results = await client.search(
            "shared patterns",
            project_id="my-project",
            domains=["React", "Spring Boot"],
        )

asyncio.run(main())

Environment variables

Instead of passing credentials directly, use MemoryHubClient.from_env():

API key mode

export MEMORYHUB_URL="https://mcp-server.apps.example.com/mcp/"
export MEMORYHUB_API_KEY="mh-dev-abc123"

MEMORYHUB_SERVER_URL is accepted as an alias for MEMORYHUB_URL.

OAuth 2.1 mode

export MEMORYHUB_URL="https://mcp-server.apps.example.com/mcp/"
export MEMORYHUB_AUTH_URL="https://auth-server.apps.example.com"
export MEMORYHUB_CLIENT_ID="my-agent"
export MEMORYHUB_CLIENT_SECRET="my-secret"
client = MemoryHubClient.from_env()

Project configuration

MemoryHubClient.from_env() (and construction without an explicit project_config argument) auto-discovers .memoryhub.yaml by walking up from the current working directory. If found, the file's retrieval_defaults are applied to outbound calls whenever the caller omits the corresponding argument, and memory_loading.live_subscription controls whether the client subscribes to push updates on connect.

In practice that means a caller can write a plain search and inherit the project's retrieval policy:

client = MemoryHubClient.from_env()
async with client:
    # .memoryhub.yaml sets retrieval_defaults.max_results: 20
    # so this call transparently uses max_results=20
    results = await client.search("deployment patterns")

To opt out of auto-discovery, pass auto_discover_config=False:

client = MemoryHubClient.from_env(auto_discover_config=False)

Or pass an explicit ProjectConfig to the constructor to use a fixed policy regardless of cwd. The recommended way to generate .memoryhub.yaml is the memoryhub-cli wizard (memoryhub config init); see the repo root README for the split between project config (.memoryhub.yaml, committed) and connection config (~/.config/memoryhub/config.json, per-developer).

Sync usage

For non-async contexts, use the _sync variants:

from memoryhub import MemoryHubClient

client = MemoryHubClient(
    url="https://mcp-server.apps.example.com/mcp/",
    api_key="mh-dev-abc123",
)

results = client.search_sync("deployment patterns")

API reference

Core operations

Method Description
search(query, *, scope, max_results, project_id, domains, ...) Semantic similarity search
read(memory_id, *, include_versions, project_id) Read a memory by ID
write(content, *, scope, weight, project_id, domains, ...) Create a new memory
update(memory_id, *, content, weight, project_id, domains, ...) Update an existing memory
delete(memory_id, *, project_id) Soft-delete a memory and its version chain

Lifecycle

Method Description
report_contradiction(memory_id, observed_behavior, *, project_id) Flag stale memories

Relationships and curation

Method Description
get_similar(memory_id, *, threshold, project_id) Find similar memories
get_relationships(node_id, *, relationship_type, direction, project_id) Get memory relationships
create_relationship(source_id, target_id, relationship_type, *, project_id) Create a relationship (use conflicts_with + merge metadata to suggest merges)
set_curation_rule(name, *, tier, action, config) Configure curation rules

Session focus

Method Description
set_session_focus(focus, project) Declare the session's focus topic for history tracking
get_focus_history(project, *, start_date, end_date) Retrieve per-project session focus histogram

Push notifications

Method Description
on_memory_updated(callback) Register a callback fired when another agent writes a memory (requires live_subscription: true in .memoryhub.yaml)

Utilities

Method Description
get_injection_block(results) Render search results as a stable text block for prompt injection (static method)

Version history is accessed via read(memory_id, include_versions=True, history_offset=0, history_max_versions=10).

All methods accepting project_id use it for campaign enrollment verification. When a target memory has scope="campaign", the server resolves campaign membership through project_id. The domains parameter on search() boosts domain-matching results (non-matching results still appear); on write()/update() it tags the memory with crosscutting knowledge domains.

Authentication

The SDK supports two authentication modes:

API key — Calls register_session automatically on connect. Suitable for development and single-operator deployments.

OAuth 2.1 — Uses the client_credentials grant. Token management is fully automatic: the SDK fetches, caches, and refreshes JWT access tokens transparently. Recommended for production multi-agent deployments.

The two modes are mutually exclusive. If both are provided, the constructor raises ValueError.

Further documentation

The SDK is one surface of the memory-hub monorepo. For deeper context:

Links

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

memoryhub-0.7.0.tar.gz (43.3 kB view details)

Uploaded Source

Built Distribution

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

memoryhub-0.7.0-py3-none-any.whl (24.0 kB view details)

Uploaded Python 3

File details

Details for the file memoryhub-0.7.0.tar.gz.

File metadata

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

File hashes

Hashes for memoryhub-0.7.0.tar.gz
Algorithm Hash digest
SHA256 3cf3bea4f186c6bf6c8e3ae306540dbe9578f6c6c752d6cc4287eb60e15e3600
MD5 914628564c4b0b10fc90ed39cbc377f2
BLAKE2b-256 dc6e7fbe781c5f5bdb564c0dfb7bd0ccb285891c45a59f0d80a605dbdb4cc9e3

See more details on using hashes here.

Provenance

The following attestation bundles were made for memoryhub-0.7.0.tar.gz:

Publisher: release.yml on redhat-ai-americas/memory-hub

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

File details

Details for the file memoryhub-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: memoryhub-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 24.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for memoryhub-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e635bc18b88c4420f68aca88c0cb7227a61db5c8aecf735531d61248f25b701d
MD5 689fc2c0d918bcc0d1bd2f4934668916
BLAKE2b-256 3dd3abc4ac35b21899963c5bd075a3e33c339c089cf2159dfa9ffd3106ded85f

See more details on using hashes here.

Provenance

The following attestation bundles were made for memoryhub-0.7.0-py3-none-any.whl:

Publisher: release.yml on redhat-ai-americas/memory-hub

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