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
- Sign up at https://contextkit.outhad.com.
- Open the dashboard → API keys.
- Click Create key, copy the one-shot secret (looks like
ock_live_<8-char-prefix>_<32-byte-secret>). - Either pass it as
MemoryClient(api_key=…)or export it in your shell asOUTHAD_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
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 outhad_contextkit_sdk-1.8.0.tar.gz.
File metadata
- Download URL: outhad_contextkit_sdk-1.8.0.tar.gz
- Upload date:
- Size: 21.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d445cb4541a85e6e568eea308940f776de1d9205da023832ca13d5c98248d273
|
|
| MD5 |
57d9c81f3888d616e123deca75d568e4
|
|
| BLAKE2b-256 |
b1930dc4bc8afc22f47795db81e923f78491eeb7506f9ae3929e98f65456a8c4
|
File details
Details for the file outhad_contextkit_sdk-1.8.0-py3-none-any.whl.
File metadata
- Download URL: outhad_contextkit_sdk-1.8.0-py3-none-any.whl
- Upload date:
- Size: 18.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d984b9694ab9fd2ad732f8c5150c84ba7a300ad2b62c22e6243c860767f9fa5e
|
|
| MD5 |
23a967cb9a0c41cd7b0ca8d28c94f143
|
|
| BLAKE2b-256 |
59d107ac7fe3d9680293c95ce5cb97cabe4b2421f2473379f750f976737be840
|