What it does
This example demonstrates thegrantex-openai-agents integration by building scope-enforced tools for the OpenAI Agents SDK:
- Register an agent and obtain a grant token via the sandbox flow
- Create scoped tools using
create_grantex_tool— each tool is bound to a specific scope (calendar:read,email:send) - Invoke tools directly (in a full Agents workflow, the LLM would select and call these tools)
- Demonstrate scope enforcement — attempting to create a tool with
account:delete(a scope not in the grant) raises aPermissionError - Inspect the audit trail to see the logged actions
Prerequisites
- Python 3.9+
- Docker (Docker Desktop or Docker Engine with Compose)
Run
Start the local Grantex stack from the repository root:Expected output
Environment variables
| Variable | Default | Description |
|---|---|---|
GRANTEX_URL | http://localhost:3001 | Base URL of the Grantex auth service |
GRANTEX_API_KEY | sandbox-api-key-local | API key. Use a sandbox key for auto-approval |
Source code
The full source is inexamples/openai-agents/main.py.