Skip to main content

Thin Python client for the Outhad ContextKit cloud — paywalled by API key minted at https://contextkit.outhad.com

Project description

outhad-contextkit-sdk

Thin Python client for the Outhad ContextKit cloud — long-term memory for AI agents, with multimodal + temporal-causal recall, personalised retrieval, and tenant isolation built in.

This package ships client only. There is no local memory engine, no vector store driver, no LLM provider. Calls go to the Outhad ContextKit cloud where the heavy lifting happens — billed against the API key you mint at https://contextkit.outhad.com.

Install

pip install outhad-contextkit-sdk

Quickstart

from outhad_contextkit_sdk import MemoryClient

client = MemoryClient(api_key="ock_live_...")  # or set OUTHAD_CONTEXTKIT_API_KEY

client.add(
    messages=[
        {"role": "user", "content": "Hi, my name is Alice and I love sushi."},
    ],
    user_id="alice",
)

hits = client.search(query="What food does Alice like?", user_id="alice")
for hit in hits["results"]:
    print(hit["score"], hit["memory"])

Switching the LLM at runtime

The default model is whatever the project has saved in Dashboard → Settings. You can override it on a single call without touching the project default:

client.add(
    messages=[{"role": "user", "content": "I love sushi."}],
    user_id="alice",
    llm={"provider": "anthropic", "model": "claude-haiku-4-5-20251001"},
)

# Same override shape works on search:
client.search(
    query="What food do I like?",
    user_id="alice",
    llm={"provider": "anthropic", "model": "claude-haiku-4-5-20251001"},
)

Pass api_key inside the dict to bring your own upstream key for that single call (never persisted server-side):

client.add(
    messages=[...],
    user_id="alice",
    llm={
        "provider": "anthropic",
        "model": "claude-haiku-4-5-20251001",
        "api_key": "sk-ant-…",
    },
)

Override the embedder the same way with embedder={"provider": "...", "model": "...", "api_key": "..."}.

Without overrides every call uses the project's saved defaults — set those once in the dashboard and forget about them.

Get an API key

  1. Sign up at https://contextkit.outhad.com.
  2. Open the dashboard → API keys.
  3. Click Create key, copy the one-shot secret (looks like ock_live_<8-char-prefix>_<32-byte-secret>).
  4. Either pass it as MemoryClient(api_key=…) or export it in your shell as OUTHAD_CONTEXTKIT_API_KEY.

Auth header

The SDK sends Authorization: Token <api-key> on every request. The cloud dispatcher also accepts Bearer and X-API-Key if you prefer to hit the HTTP API directly (e.g. from curl).

Host resolution

Resolution order Default
host= constructor arg (none)
OUTHAD_CONTEXTKIT_HOST env var (none)
Production default https://contextkit.outhad.com
Dev fallback (transparent retry on connection error) http://localhost:8000

When the production default is unreachable (DNS failure / connection refused) the client transparently retries against http://localhost:8000 and pins itself there for the rest of the session — useful while you are working against make cloud-up locally. The fallback is disabled when you pass host= or set OUTHAD_CONTEXTKIT_HOST explicitly.

Async

from outhad_contextkit_sdk import AsyncMemoryClient

async def main():
    async with AsyncMemoryClient(api_key="ock_live_...") as client:
        await client.add(
            messages=[{"role": "user", "content": "I prefer dark mode."}],
            user_id="alice",
        )

API surface

  • add(messages, *, user_id, agent_id, run_id, metadata, infer, llm, embedder)
  • get_all(*, user_id, agent_id, run_id, limit)
  • get(memory_id)
  • search(query, *, user_id, agent_id, run_id, filters, limit, llm, embedder)
  • update(memory_id, *, text)
  • history(memory_id)
  • delete(memory_id)
  • delete_all(*, user_id, agent_id, run_id)

llm / embedder (optional, since 1.1.0) — per-request model override (see Switching the LLM at runtime above).

For dashboard-style operations the same client also exposes list_api_keys(), create_api_key(), revoke_api_key() — those require a Clerk session JWT and are intended for interactive tooling.

License

Apache-2.0.

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

outhad_contextkit_sdk-1.6.0.tar.gz (19.8 kB view details)

Uploaded Source

Built Distribution

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

outhad_contextkit_sdk-1.6.0-py3-none-any.whl (17.6 kB view details)

Uploaded Python 3

File details

Details for the file outhad_contextkit_sdk-1.6.0.tar.gz.

File metadata

  • Download URL: outhad_contextkit_sdk-1.6.0.tar.gz
  • Upload date:
  • Size: 19.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.13

File hashes

Hashes for outhad_contextkit_sdk-1.6.0.tar.gz
Algorithm Hash digest
SHA256 7a176e6ec01df221bdec842a3a3f80aeec68c4700976bbe5b0e1708727093b8b
MD5 5650800524e47d4a1f870ae53bd37c51
BLAKE2b-256 b2b04c44e9d4e44f8683e006e6c19a421c0e39e7942c37600f763eb8a51a0f28

See more details on using hashes here.

File details

Details for the file outhad_contextkit_sdk-1.6.0-py3-none-any.whl.

File metadata

File hashes

Hashes for outhad_contextkit_sdk-1.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 728b5d3c4fc788d014ab20066ae80881ae1bb7dc6390a212350c68edf7057b61
MD5 71042b179493095560179e20bf4943ae
BLAKE2b-256 f0a12ad6d5d7c708bdd3be06e0d29cb97cfa594ae26dfee4cca37660d98b9cab

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