Skip to main content

GoodMem's Convenient SDK for Python

Project description

GoodMem Python SDK

An OpenAI-style API for Goodmem with auto-inference of model parameters, streaming retrieval, async support, and auto-pagination. The SDK stays in sync with the server's OpenAPI spec — except for hand-written convenience methods (model registry auto-inference, flat post-processor kwargs, etc.) that wrap the generated layer. Please see ../notes/client_gen.md for the SDK generation details and ../notes/doc_gen.md for the doc generation details.

Installation

pip install goodmem

Usage

The programmatic way

from goodmem import Goodmem

client = Goodmem(
    base_url="http://localhost:8080",
    api_key="gm_..."
)

embedder = client.embedders.create(
    display_name="OpenAI Embedder",
    model_identifier="text-embedding-3-large",
    api_key="sk-your-openai-key",
)

print(f"Created: {embedder.embedder_id}")

The Skill way

# One-time setup — copy the skill into your Claude Code skills directory
cp -r $(python -c "import goodmem; print(goodmem.__path__[0])")/skills ~/.claude/skills/goodmem

Once installed, Claude Code automatically loads the GoodMem SDK reference when you ask it to create embedders, store memories, run retrieval, etc.

Project structure

clients/v2/
├── python/              # Python SDK (this directory, published to PyPI as "goodmem")
├── _client_gen/         # Code generation (spec → SDK + MCP)
├── _doc_gen/            # Doc generation (ref pages, skills, sdk2rest)
├── mcp/                 # MCP server (published to npm as @pairsystems/goodmem-mcp)
├── claude/              # Claude Code plugin (git subtree → public repo)
├── vibe/                # Cross-SDK vibe auditing (audit_docs.sh, audit_ref_doc.sh, ...)
├── registries/          # Shared model registries (copied into each SDK)
├── ci/                  # CI infrastructure
├── notes/               # Internal dev notes (client_gen.md, doc_gen.md)
├── client_gen.sh        # Full SDK generation pipeline
└── doc_gen.sh           # Full doc generation pipeline

Development commands

# Generation (run from clients/v2/, not python/)
cd ..
./client_gen.sh                # compile server → IR → Python SDK → MCP → test
./client_gen.sh -y             # same, but skip server-reset confirmation (unattended/CI)
./doc_gen.sh                   # ref pages + skills + snippets
./doc_gen.sh --sdk2rest        # translate SDK test snippets → REST equivalents

# Publishing (run from python/)
cd python
./publish.sh                   # Publish to PyPI
./publish.sh --test            # Publish to TestPyPI

# Vibe auditing (Claude Code non-interactive)
../vibe/audit_docs.sh          # run all doc audits (ref docs + skill docs)
../vibe/audit_ref_doc.sh       # audit generated MDX ref docs against SDK source
../vibe/audit_skill_doc.sh     # audit generated skill reference (SDK, REST, patterns)

In client_gen.sh, integration test is only activated when environment variables GOODMEM_BASE_URL and GOODMEM_API_KEY are set.

Warning: Before the integration tests, client_gen.sh and CI all run goodmem-reset.sh to delete ALL resources on the target server. Never point GOODMEM_BASE_URL at a production server. We have a dedicated test server on Fly.io for this purpose. See ci/README.md for more details.

See notes/client_gen.md for the full regeneration workflow and notes/doc_gen.md for the doc and auditing pipelines.

Documentation

TODO

  1. Add gemini-embedding-001 to embedder registry once backend adds OPENAI_COMPATIBLE to ProviderType.
  2. Add Anthropic, Google, Cohere, and Mistral LLMs to registry once backend adds matching LLMProviderType values.
  3. Automate model registry updates to add new models as they are released.
  4. Generate SDK to an intermediate representation, then map that to cURL, HTTPie, HTTPX, Go, JavaScript, etc.

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

goodmem-0.1.20.tar.gz (147.5 kB view details)

Uploaded Source

Built Distribution

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

goodmem-0.1.20-py3-none-any.whl (164.4 kB view details)

Uploaded Python 3

File details

Details for the file goodmem-0.1.20.tar.gz.

File metadata

  • Download URL: goodmem-0.1.20.tar.gz
  • Upload date:
  • Size: 147.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.11

File hashes

Hashes for goodmem-0.1.20.tar.gz
Algorithm Hash digest
SHA256 044e11c1c297bb52a7bc280360f23085b41fe5d2c3c93dd12c143b68332b2c6b
MD5 0326aace2d927125dec23ccde3825f44
BLAKE2b-256 84dc67cd6159f257c2f9eb5926171e7fe398c82bee9d90f6a345834e7c0b5d72

See more details on using hashes here.

File details

Details for the file goodmem-0.1.20-py3-none-any.whl.

File metadata

  • Download URL: goodmem-0.1.20-py3-none-any.whl
  • Upload date:
  • Size: 164.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.11

File hashes

Hashes for goodmem-0.1.20-py3-none-any.whl
Algorithm Hash digest
SHA256 1e1ccf317bbb52a21aa0fa40b877a0d9bf82df00e9d0d089f5a12517b6316cce
MD5 5af7d9f8942aab9edf58422daaccad74
BLAKE2b-256 3c323207e4af7f8cde5c2746593bbe79f7016b8d7c7ec49763c6f6b9fd1bcbe1

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