Skip to main content

No project description provided

Project description

Unique User Memory

Persistent per-user memory for Unique AI agents.

unique_user_memory stores a compact Markdown profile for each user and updates it after every agent turn. The profile is loaded before the next turn so the assistant can remember stable user context such as communication preferences, work context, expertise, recent topics, and open follow-ups.

What It Does

The package provides:

  • UserMemoryConfig - Pydantic configuration for the consolidation model, profile token budget, and memory folder.
  • load_user_memory(...) - resolves the user's private memory folder, downloads memory.md, and enforces the configured token budget. The language_model argument is used to tokenize memory.md when capping it, so it must be the same effective model the postprocessor uses for consolidation (see Integration below).
  • UserMemoryPostprocessor - runs after the assistant response, consolidates the latest turn into the profile, and uploads the updated memory.md.

The memory file is intentionally small and structured. It is rewritten as a full Markdown profile rather than appended to as an event log.

Lifecycle

  1. The orchestrator enables memory when space.allow_user_memory is true.
  2. load_user_memory(...) resolves the pre-provisioned root folder, ensures a private child folder for the current user, and downloads /user-memory/<user_id>/memory.md if it exists.
  3. The loaded memory text is passed into the agent context for the current turn.
  4. UserMemoryPostprocessor runs after the assistant response.
  5. The package asks the configured language model to either return NOOP or a complete rewritten profile.
  6. If the profile changed, memory.md is uploaded back to the user's folder with ingestion skipped and the content hidden from chat.

Storage Model

Memory is stored in Unique content as Markdown:

/<root_folder>/<user_id>/memory.md

By default, root_folder is user-memory. The root folder must already exist. The package creates the per-user child folder when needed.

Profile Format

Profiles contain YAML frontmatter followed by fixed Markdown sections:

---
user_id: user_123
schema_version: 1
last_updated: 2026-06-17T12:00:00+00:00
turn_count: 1
---

# User Memory

## Identity
_(empty)_

## Communication Preferences
- Prefers concise answers with concrete examples.

## Work Context
_(empty)_

## Skills & Expertise
_(empty)_

## Recent Topics
_(empty)_

## Open Questions / Follow-ups
_(empty)_

The consolidation prompt preserves the schema, keeps bullets short, and returns NOOP when a turn has no durable user facts.

Configuration

Memory is activated by the orchestrator when space.allow_user_memory is true. UserMemoryConfig only configures how active memory is consolidated and stored.

from unique_user_memory import UserMemoryConfig

config = UserMemoryConfig(
    max_tokens=2000,
    root_folder="user-memory",
)
Field Default Description
use_orchestrator_language_model True When true, consolidation and load-time token capping use the model the orchestrator passes in and language_model is ignored. Set to False to use the configured language_model for both.
language_model DEFAULT_GPT_4o Model used to consolidate the latest turn and to tokenize memory.md at load time when use_orchestrator_language_model is False.
max_tokens 2000 Maximum profile size. Must be between 500 and 8000 tokens.
root_folder user-memory Root KB folder that contains per-user memory folders.

Integration

Typical orchestration code loads memory before the agent loop and registers the postprocessor for the same turn.

load_user_memory and UserMemoryPostprocessor must be given the same effective language model: the postprocessor consolidates memory with either the orchestrator model or the configured one depending on use_orchestrator_language_model, and load-time token capping must use that same model so the loaded baseline is tokenized the way consolidation expects. Resolve the effective model once and pass it to both:

from unique_user_memory.user_memory import load_user_memory
from unique_user_memory.user_memory_postprocessor import UserMemoryPostprocessor

user_memory_config = config.agent.services.user_memory_config

# Resolve the effective model once and reuse it for load-time capping and
# consolidation so both use the same tokenizer.
memory_language_model = (
    config.space.language_model
    if user_memory_config.use_orchestrator_language_model
    else user_memory_config.language_model
)

user_memory_state = await load_user_memory(
    event=event,
    config=user_memory_config,
    language_model=memory_language_model,
    logger=logger,
)

if user_memory_state is not None:
    user_memory_text = user_memory_state.text
    postprocessor_manager.add_postprocessor(
        UserMemoryPostprocessor(
            config=user_memory_config,
            language_model=memory_language_model,
            event=event,
            state=user_memory_state,
            logger=logger,
        )
    )

Note that UserMemoryPostprocessor re-derives the effective model internally from use_orchestrator_language_model, so passing memory_language_model (rather than the raw orchestrator model) keeps its behavior identical while ensuring load_user_memory caps with the matching tokenizer.

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

unique_user_memory-2026.30.0.dev0.tar.gz (14.8 kB view details)

Uploaded Source

Built Distribution

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

unique_user_memory-2026.30.0.dev0-py3-none-any.whl (17.5 kB view details)

Uploaded Python 3

File details

Details for the file unique_user_memory-2026.30.0.dev0.tar.gz.

File metadata

  • Download URL: unique_user_memory-2026.30.0.dev0.tar.gz
  • Upload date:
  • Size: 14.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.5 {"installer":{"name":"uv","version":"0.11.5","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for unique_user_memory-2026.30.0.dev0.tar.gz
Algorithm Hash digest
SHA256 3a5195df05eb940dd7cf8aba89305dd6c067943ec4f51d1ebb8065bf8bf4f055
MD5 8868eb09dbc412bf0ba45eb7d185527a
BLAKE2b-256 4b74002c55964ba0e89d9a479bdf74d523bc7e7537d8788e9dcb5babf7e9f70b

See more details on using hashes here.

File details

Details for the file unique_user_memory-2026.30.0.dev0-py3-none-any.whl.

File metadata

  • Download URL: unique_user_memory-2026.30.0.dev0-py3-none-any.whl
  • Upload date:
  • Size: 17.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.5 {"installer":{"name":"uv","version":"0.11.5","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for unique_user_memory-2026.30.0.dev0-py3-none-any.whl
Algorithm Hash digest
SHA256 2359dc47b8070a239903b0e294cd4c12fbc1b4e565663e760ddaddaf906c9fc7
MD5 39bbcf5b620854c648bf5ec89d182a6f
BLAKE2b-256 2b87a093fb24c423a1575c23ea3b48c55e42acd940f70924a8ea5f38661f58fe

See more details on using hashes here.

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