GoodMem integration for Microsoft Agent Framework.
Project description
agent-framework-goodmem
GoodMem integration for the Microsoft Agent Framework.
This package gives Agent Framework agents persistent, semantic long-term memory backed by a GoodMem server. It exposes:
GoodMemClient— an async REST client for the GoodMem v1 API.GoodMemContextProvider— aBaseContextProviderthat automatically retrieves relevant memories before each agent run and stores conversations afterwards.create_goodmem_tools— a factory that returns ready-to-use function tools so the model itself can manage spaces and memories.
Installation
pip install agent-framework-goodmem
For local development:
pip install -e .
Quickstart
import asyncio
from agent_framework_goodmem import GoodMemClient, create_goodmem_tools
async def main():
client = GoodMemClient(
base_url="https://localhost:8080",
api_key="gm_xxxxxxxxxxxxxxxxxxxxxxxx",
verify_ssl=False, # self-signed local server
)
embedders = await client.list_embedders()
embedder_id = embedders[0]["embedderId"]
space = await client.create_space(name="quickstart", embedder_id=embedder_id)
space_id = space["spaceId"]
await client.create_memory(
space_id=space_id,
text_content="The capital of France is Paris.",
)
results = await client.retrieve_memories(
query="What is the capital of France?",
space_ids=[space_id],
max_results=3,
wait_for_indexing=True,
)
print(results)
await client.close()
asyncio.run(main())
Available tools
create_goodmem_tools(client) returns the following 11 function tools:
| Tool | Description |
|---|---|
goodmem_list_embedders |
List embedder models available on the server |
goodmem_list_spaces |
List all spaces accessible to the API key |
goodmem_get_space |
Fetch a space by ID |
goodmem_create_space |
Create a space (idempotent by name) |
goodmem_update_space |
Update a space's name/labels/visibility |
goodmem_delete_space |
Delete a space |
goodmem_create_memory |
Store text or a file as a memory |
goodmem_list_memories |
List memories in a space |
goodmem_retrieve_memories |
Semantic retrieval, with optional reranker/LLM |
goodmem_get_memory |
Fetch a memory by ID (with original content) |
goodmem_delete_memory |
Delete a memory |
Retrieval options
goodmem_retrieve_memories (and GoodMemClient.retrieve_memories) accept the
GoodMem post-processor parameters:
| Parameter | Type | Description |
|---|---|---|
reranker_id |
UUID | Reranker model to improve result ordering |
llm_id |
UUID | LLM used to generate a contextual abstract reply |
relevance_threshold |
0–1 | Minimum score for including a result |
llm_temperature |
0–2 | Creativity for the LLM post-processor |
max_results |
int | Cap on returned chunks |
chronological_resort |
bool | Reorder results by memory creation time |
Context provider
from agent_framework import Agent
from agent_framework.openai import OpenAIChatClient
from agent_framework_goodmem import GoodMemClient, GoodMemContextProvider
client = GoodMemClient(base_url="https://localhost:8080", api_key="gm_...", verify_ssl=False)
provider = GoodMemContextProvider(
client=client,
space_id=space_id,
max_results=5,
store_conversations=True,
)
agent = Agent(
client=OpenAIChatClient(model="gpt-4o"),
name="memory-agent",
instructions="You are a helpful assistant with persistent memory.",
context_providers=[provider],
)
Running the integration tests
export GOODMEM_API_KEY=gm_xxxxxxxxxxxxxxxxxxxxxxxx
export GOODMEM_BASE_URL=https://localhost:8080
pip install -e ".[dev]"
pytest -m integration -v tests/test_goodmem_integration.py
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file agent_framework_goodmem-0.1.0.tar.gz.
File metadata
- Download URL: agent_framework_goodmem-0.1.0.tar.gz
- Upload date:
- Size: 13.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
aeea9c20aeab1cef2a6736c81d3d21b836c5250f99f6aff547231f53a3f4564e
|
|
| MD5 |
8dd9b23f7a39a39d7928e7165d62ed15
|
|
| BLAKE2b-256 |
9a6fc9bfd162a9e57c2cfc2892e05da8ecc623e26ad2de16ca7b9aa747e67cc9
|
Provenance
The following attestation bundles were made for agent_framework_goodmem-0.1.0.tar.gz:
Publisher:
release.yml on PAIR-Systems-Inc/goodmem_agent-framework
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
agent_framework_goodmem-0.1.0.tar.gz -
Subject digest:
aeea9c20aeab1cef2a6736c81d3d21b836c5250f99f6aff547231f53a3f4564e - Sigstore transparency entry: 1520443187
- Sigstore integration time:
-
Permalink:
PAIR-Systems-Inc/goodmem_agent-framework@bbac5ee0b1581795bf408067724f263af92626c2 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/PAIR-Systems-Inc
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@bbac5ee0b1581795bf408067724f263af92626c2 -
Trigger Event:
push
-
Statement type:
File details
Details for the file agent_framework_goodmem-0.1.0-py3-none-any.whl.
File metadata
- Download URL: agent_framework_goodmem-0.1.0-py3-none-any.whl
- Upload date:
- Size: 15.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9f676c91945ea28fad04dda6419c3aea684799fec9fdb94a09b3c18947d50b49
|
|
| MD5 |
77206d9c4a3c6af0dc5fb1ccbb162fe7
|
|
| BLAKE2b-256 |
37df81ef7f75b3038b78cd3e60544b30f6b84997c3f7862baf3101dd62881d9b
|
Provenance
The following attestation bundles were made for agent_framework_goodmem-0.1.0-py3-none-any.whl:
Publisher:
release.yml on PAIR-Systems-Inc/goodmem_agent-framework
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
agent_framework_goodmem-0.1.0-py3-none-any.whl -
Subject digest:
9f676c91945ea28fad04dda6419c3aea684799fec9fdb94a09b3c18947d50b49 - Sigstore transparency entry: 1520443225
- Sigstore integration time:
-
Permalink:
PAIR-Systems-Inc/goodmem_agent-framework@bbac5ee0b1581795bf408067724f263af92626c2 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/PAIR-Systems-Inc
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@bbac5ee0b1581795bf408067724f263af92626c2 -
Trigger Event:
push
-
Statement type: