Skip to main content

Install

pip install agnost-mcp

Integrate

Call track after defining your server and tools, before running:
from mcp.server.fastmcp import FastMCP
from agnost_mcp import track, config

server = FastMCP("Your Server Name")

# ... your tools ...

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

if __name__ == "__main__":
    server.run()
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