Skip to main content

Google ADK integration for the Grantex delegated authorization protocol — scope-enforced agent tools

Project description

grantex-adk

Google Agent Development Kit (ADK) integration for the Grantex delegated authorization protocol — scope-enforced agent tools.

Wrap any function with Grantex grant token verification so your agents can only use tools they've been authorized for.

PyPI Python License

Homepage | Docs | Sign Up Free | GitHub

Install

pip install grantex-adk

You also need the Google ADK installed (it's a peer dependency):

pip install google-adk

Quick start

from grantex_adk import create_grantex_tool
from google.adk import Agent

# Create a scope-enforced tool from any function
read_calendar = create_grantex_tool(
    name="read_calendar",
    description="Read upcoming calendar events",
    grant_token=grant_token,       # JWT from Grantex authorization flow
    required_scope="calendar:read",
    func=get_calendar_events,      # your function
)

# Google ADK uses plain functions as tools — just pass them directly
agent = Agent(
    model="gemini-2.0-flash",
    name="assistant",
    tools=[read_calendar],
)

If the grant token doesn't include the required scope, create_grantex_tool raises a PermissionError immediately — the tool is never created.

API reference

create_grantex_tool()

Creates a plain function with the correct __name__ and __doc__ for ADK tool discovery, with offline scope enforcement.

Parameter Type Description
name str Tool name (becomes __name__)
description str Tool description (becomes __doc__)
grant_token str JWT grant token from Grantex
required_scope str Scope that must be present in the token
func Callable[..., str] The function to wrap

get_tool_scopes()

Returns the scopes embedded in a grant token (offline, no network call).

decode_jwt_payload()

Decodes the payload of a JWT without verifying the signature. Useful for inspecting token claims.

Requirements

  • Python 3.9+
  • grantex >= 0.1.0
  • google-adk >= 0.2.0 (peer dependency)

Grantex Ecosystem

This package is part of the Grantex ecosystem. See also:

License

Apache-2.0

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

grantex_adk-0.1.1.tar.gz (4.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

grantex_adk-0.1.1-py3-none-any.whl (4.2 kB view details)

Uploaded Python 3

File details

Details for the file grantex_adk-0.1.1.tar.gz.

File metadata

  • Download URL: grantex_adk-0.1.1.tar.gz
  • Upload date:
  • Size: 4.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.1

File hashes

Hashes for grantex_adk-0.1.1.tar.gz
Algorithm Hash digest
SHA256 ef91f57e0628a26432b93a8d97284b36532bd75b5f583d612b64d2646c571a5f
MD5 66e0a1efd1e9faeaf678c6c5b654a69d
BLAKE2b-256 f69016ca233b69f84a9afaf5c3d73900011e1ddd5e2dbd29e4b7ad33732876ac

See more details on using hashes here.

File details

Details for the file grantex_adk-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: grantex_adk-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 4.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.1

File hashes

Hashes for grantex_adk-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8d5ce28d3cfcb44ea41305d9b4d105cecb6fa95cc04af23270ea1a785d1963f5
MD5 847bdc4819b4de676eaaa1c30c110d28
BLAKE2b-256 26cad6bc45c8b41f8c112671667e9c7fb1ddf6b897a3392334af4cc6bfa524f8

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page