Kimss Python SDK & MCP server for conversational AI agents
Project description
Kimss Python SDK & MCP server
Lightweight client for the Kimss API — call agents, run model completions, upload files, and manage vector stores from Python. Optional Model Context Protocol (MCP) server for Cursor, Windsurf, and other MCP-capable IDEs.
AI assistants: read docs/llm-context.md or the repo root .llms.txt for dense integration context.
Cursor & Windsurf (MCP) — zero local venv with uvx
Install the MCP extra on the fly and expose tools to your IDE:
{
"mcpServers": {
"kimss": {
"command": "uvx",
"args": ["--with", "kimss[mcp]", "kimss-mcp-server"],
"env": {
"KIMSS_API_KEY": "your_key_here",
"KIMSS_BASE_URL": "https://api.kimss.ai",
"KIMSS_WORKSPACE_ID": ""
}
}
}
}
- Set
KIMSS_API_KEYto a long-lived key from Developer Settings → API Keys (never commit it). - Optional
KIMSS_WORKSPACE_IDstampsX-Workspace-ID/tenant_idfor workspace-scoped calls. - MCP tools are non-streaming in v1 (
kimss_chat,kimss_create_agent,kimss_run_agent,kimss_complete,kimss_upload_file,kimss_create_vector_store,kimss_add_function_to_agent).
Alternatively, after pip install 'kimss[mcp]', use "command": "kimss-mcp-server" on your PATH with the same env.
Install (library)
pip install kimss
Optional PII redaction (Microsoft Presidio + spaCy; e.g. python -m spacy download en_core_web_lg):
pip install 'kimss[privacy]'
Other extras:
pip install 'kimss[mcp]' # MCP server (stdio)
pip install 'kimss[types]' # Pydantic (reserved for future typed models)
pip install 'kimss[dev]' # pytest, responses, ruff
Editable from a checkout of this package root:
cd kimss_sdk && pip install -e ".[dev,mcp]"
Authentication
Use a long-lived API key (not a browser session token). Create keys in your Kimss app under Developer Settings → API Keys. The key is scoped to your tenant and user.
Headless workers can also authenticate with Microsoft Entra ID by passing an Azure credential plus a Kimss API token scope:
from azure.identity import DefaultAzureCredential
from kimss import KimssClient
client = KimssClient(
base_url="https://api.kimss.ai",
credential=DefaultAzureCredential(),
token_scope="api://<kimss-api-app-id>/.default",
workspace_id="worksfusion",
)
Usage
Use the canonical Kimss API host. Production is https://api.kimss.ai and staging is https://stg.kimss.ai; do not include a trailing slash.
from kimss import KimssClient, Agent
client = KimssClient(
api_key="kimss_xxxxxxxxxxxxxxxxxxxxxxxx", # from Developer Settings
base_url="https://api.kimss.ai", # no trailing slash
)
# Get an agent and send a message
agent = client.get_agent(agent_id="asst_xxxx")
result = agent.query("Hello")
# result is the API "res" payload (run_id, thread_id, messages, usage, etc.)
# Continue a thread
result2 = agent.query("What did I just say?", thread_id=result.get("thread_id"))
# Or use the client directly
result3 = client.chat(assistant_id="asst_xxxx", message="Hi", thread_id=result.get("thread_id"))
Streaming
client.models.create(..., stream=True) and client.agents.run(..., stream=True) return an SSE iterator of JSON objects. The MCP server does not expose streaming tools in v1.
API
KimssClient(..., retry=None)– authenticated client. Provide eitherapi_key(usesX-Kimss-Key) orcredential+token_scope(usesAuthorization: Bearer).workspace_idoptionally stampsX-Workspace-IDandtenant_idfor isolated worker telemetry. Uses arequests.Sessionwith retry on 5xx (not 429) and Retry-After by default so credit exhaustion and rate limits surface immediately as typed errors (KimssCreditExhausted,KimssRateLimited,KimssSubscriptionRequired).client.get_agent(agent_id)– returns anAgentfor that assistant.agent.query(message, thread_id=None, chat_type="user_chat")– send a message; returns theresobject fromPOST /assistant_chat/.client.chat(assistant_id, message, thread_id=None, chat_type="user_chat")– one-off chat without an Agent handle.client.agents.create/client.agents.run– v1 agent management and orchestration (/v1/agents/create,/v1/agents/run).client.models.create–/v1/models/completions.client.files.upload–/v1/files/upload.client.vector_stores.create–/v1/vector_stores/create.before_request_hooks– list of callableshook(ctx)wherectxis{"path": str, "json": dict, "headers": dict}; hooks may mutatejson/headersbefore the HTTP POST.privacy– shortcut forPresidioRedactor()fromkimss.privacy(requireskimss[privacy]).
from kimss import KimssClient, PresidioRedactor
client = KimssClient(
api_key="kimss_...",
base_url="https://api.kimss.ai",
privacy=PresidioRedactor(),
)
API-key requests use the X-Kimss-Key header. Credential requests use
Authorization: Bearer <token>. Non-streaming responses are full JSON dicts from the API res envelope where applicable.
Examples
See examples/ — set KIMSS_API_KEY (and KIMSS_ASSISTANT_ID / KIMSS_MODEL where noted).
Usage Hub (execution context)
For agent and model calls, the SDK automatically adds an optional X-Kimss-SDK-Context header (base64url JSON) with:
host_environment— e.g. AzureWEBSITE_SITE_NAME,GitHub:org/repo, orLocal/Devsource_location— best-effort path to the caller's Python file (relative togetcwd()when possible)resource_type/resource_name—agentormodelplus assistant id or model id
Paths are resolved in your process and sent as metadata for the workspace Usage dashboard. Use before_request_hooks to remove that header from ctx["headers"] if your policy forbids file paths.
Contributing & release
See CONTRIBUTING.md for tests, mirror workflow, and PyPI trusted publishing.
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
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 kimss-1.0.0.tar.gz.
File metadata
- Download URL: kimss-1.0.0.tar.gz
- Upload date:
- Size: 24.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4e7ce90788c25ea5f622b2a19a44b664c25616c8b836acf16ee5919d6d0a379f
|
|
| MD5 |
b9767278b273af2614ce7e956fde8d0c
|
|
| BLAKE2b-256 |
cd4ce98927c5942a578f6df00fd71ab6ed903f7325408756508e9123721a4fa7
|
Provenance
The following attestation bundles were made for kimss-1.0.0.tar.gz:
Publisher:
publish.yml on eyal81/kimss-python-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
kimss-1.0.0.tar.gz -
Subject digest:
4e7ce90788c25ea5f622b2a19a44b664c25616c8b836acf16ee5919d6d0a379f - Sigstore transparency entry: 1633084872
- Sigstore integration time:
-
Permalink:
eyal81/kimss-python-sdk@04d1a51c0263c26e188761f933c2798bde88dd8f -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/eyal81
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@04d1a51c0263c26e188761f933c2798bde88dd8f -
Trigger Event:
push
-
Statement type:
File details
Details for the file kimss-1.0.0-py3-none-any.whl.
File metadata
- Download URL: kimss-1.0.0-py3-none-any.whl
- Upload date:
- Size: 19.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 |
6c2caceeed3577fdf7f76ba2b30a080cefbdca63cf48cd307f050e000e2a9460
|
|
| MD5 |
c96c4f4a1e91b6dbdcf5634b1bdc2498
|
|
| BLAKE2b-256 |
10fa4d5d24e5fe230d4738a63ce731948fbf2619850c974a64477c28965db066
|
Provenance
The following attestation bundles were made for kimss-1.0.0-py3-none-any.whl:
Publisher:
publish.yml on eyal81/kimss-python-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
kimss-1.0.0-py3-none-any.whl -
Subject digest:
6c2caceeed3577fdf7f76ba2b30a080cefbdca63cf48cd307f050e000e2a9460 - Sigstore transparency entry: 1633084881
- Sigstore integration time:
-
Permalink:
eyal81/kimss-python-sdk@04d1a51c0263c26e188761f933c2798bde88dd8f -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/eyal81
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@04d1a51c0263c26e188761f933c2798bde88dd8f -
Trigger Event:
push
-
Statement type: