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

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)

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.0.tar.gz (4.4 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.0-py3-none-any.whl (4.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: grantex_adk-0.1.0.tar.gz
  • Upload date:
  • Size: 4.4 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.0.tar.gz
Algorithm Hash digest
SHA256 9d1f8115bda1a63499ff437f3d0f758135373a1da3adf6fa72d1e026481ac68f
MD5 7990d89470826b4804c24f10eb2e967a
BLAKE2b-256 a770d99340cccdb5cb77093335cff4c47e9e5d3b7dc08e3ef4e7552c4020d113

See more details on using hashes here.

File details

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

File metadata

  • Download URL: grantex_adk-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 4.0 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.0-py3-none-any.whl
Algorithm Hash digest
SHA256 158a296cdc444af799e2262bc62f21c9682ef4b07c6401c67bf1eb46c2749bfe
MD5 53b3d52d5d98f6b958b053330196b368
BLAKE2b-256 d24d37b3d13e2b6d244b4d580be760193cd22d2dc7543bf31fdecd10f8393efb

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