Skip to main content

Documentation Index

Fetch the complete documentation index at: https://docs.agnost.ai/llms.txt

Use this file to discover all available pages before exploring further.

Install

pip install agnost-mcp

Integrate

Call track after defining your server and handlers, before running:
from mcp.server import Server
from agnost_mcp import track, config

server = Server("your-server-name")

# ... your list_tools and call_tool handlers ...

track(server, "your-org-id", config(
    endpoint="https://api.agnost.ai",
    disable_input=False,
    disable_output=False,
))
Get your org ID from app.agnost.ai.

Identify users

Pass an identify function to resolve a user from the incoming request context. It receives the raw request object and the process environment, and should return a dict with at least a userId key:
from agnost_mcp import track, config

track(server, "your-org-id", config(
    identify=lambda req, env: {
        "userId": req.get("headers", {}).get("x-user-id") or env.get("USER_ID", "anonymous"),
        "email":  req.get("headers", {}).get("x-user-email") or env.get("USER_EMAIL"),
        "role":   req.get("headers", {}).get("x-user-role")  or env.get("USER_ROLE", "user"),
    }
))
The function can also be async. Return None to skip user attribution for a request.

Options

FieldTypeDefaultDescription
endpointstrhttps://api.agnost.aiAPI endpoint
disable_inputboolFalseSkip capturing tool input arguments
disable_outputboolFalseSkip capturing tool output / result
log_levelstr"INFO"Log verbosity: DEBUG, INFO, WARNING, ERROR
identifyCallableNoneFunction (request, env) → UserIdentity to resolve user identity per request
UserIdentity is a Dict[str, Any] that must contain a userId key. Other fields are optional and forwarded as user traits.

Checkpoints

Per-step latency checkpoints are currently available only in the TypeScript SDK. Tool-level latency is captured automatically across all SDKs.