Skip to main content

Agent-ready provider API wrappers with typed schemas, OAuth scope mappings, and LLM function-calling definitions.

Project description

apron-tools

Agent-ready provider API wrappers with typed schemas, OAuth scope mappings, and LLM function-calling definitions.

What is apron-tools?

Provider SDKs are designed for human developers — they expose hundreds or thousands of operations per provider. apron-tools adds what agents need:

  • LLM function-calling schemas — structured tool definitions generated from Pydantic models.
  • Curation — a selected subset of operations useful for agents, not the entire API surface.
  • Tool-to-scope mappings — which OAuth scopes each tool requires.
  • Provider quirk handling — surfaced and handled, not buried in SDK internals.

apron-tools defines tools, not transport. The same definitions can be served as MCP, OpenAPI, GraphQL, or plain Python callables. Tool definitions are more durable than wire protocols.

Installation

# Core only (tool definitions and schemas, no provider SDK dependencies).

# via uv
uv add apron-tools
# via pip
pip install apron-tools

# With specific provider extras (installs provider SDK dependencies).

# via uv
uv add apron-tools --extra slack --extra google
# via pip
pip install apron-tools[slack,google]

# All providers.

# via uv
uv add apron-tools --extra all
# via pip
pip install apron-tools[all]

Usage

Discover available tools

from apron_tools import discover_tools, get_tools_for_provider

# Discover tools across all installed providers.
# Only providers whose dependencies are installed will be found.
tools = discover_tools()

# Tools for a specific provider.
typeform_tools = get_tools_for_provider("typeform")

for td in typeform_tools:
    print(f"{td.name}: {td.description}")
    print(f"  scopes: {td.scopes}")
    print(f"  docs: {td.api_docs_url}")

Call a tool

from apron_tools.providers.typeform.tools import list_forms
from apron_tools.providers.typeform.types import ListFormsParams

result = await list_forms(ListFormsParams(page_size=10), token="your-typeform-token")

# Typed attribute access.
for form in result.items:
    print(f"{form.title} ({form.id})")

# LLM-readable string.
print(str(result))

# Dict or JSON.
result.model_dump()
result.model_dump_json()

Access tool metadata

Every tool function decorated with @tool has a _tool_definition attribute containing its metadata:

from apron_tools.providers.typeform.tools import list_forms

td = list_forms._tool_definition
td.name           # "list_forms"
td.provider        # "typeform"
td.scopes          # ["forms:read"]
td.input_schema    # JSON Schema from the Pydantic input model
td.output_schema   # JSON Schema from the Pydantic output model
td.api_docs_url    # "https://www.typeform.com/developers/create/reference/retrieve-forms/"

Adding a provider

Each provider is a directory under src/apron_tools/providers/:

src/apron_tools/providers/yourprovider/
├── __init__.py     # Export tool functions
├── types.py        # Pydantic input/output models
├── tools.py        # Async tool functions with @tool decorator
└── scopes.py       # OAuth scope enum and mappings

See src/apron_tools/providers/typeform/ for the reference implementation.

Provider PR checklist

  1. Create provider directory with types.py, tools.py, scopes.py, __init__.py.
  2. Add API docs URLs in @tool decorator and provider __init__.py docstring.
  3. Capture real API response snapshots in tests/providers/yourprovider/testdata/.
  4. Write tests — model validation, tool function tests (mocked HTTP), contract snapshots.
  5. Optionally add integration tests in test_integration.py.

Development

Requires uv.

make setup              # Install uv, create venv, sync deps, install pre-commit hooks
make test               # Run unit tests (integration tests skipped by default)
make lint               # Run pre-commit hooks (ruff, ty, detect-secrets)
make test-integration   # Run integration tests (requires provider tokens)

Or using uv directly:

uv sync --group dev     # Sync all dev dependencies
uv run pytest tests     # Run tests
uv run pre-commit run --all-files  # Run linters

Integration tests

Integration tests call real provider APIs and are skipped by default. To run them:

APRON_TOOLS_INTEGRATION_TESTS=1 TYPEFORM_TOKEN=xxx make test-integration

Each provider has its own token env var. Only providers with credentials set will run; the rest skip cleanly:

# Run just Slack integration tests.
APRON_TOOLS_INTEGRATION_TESTS=1 SLACK_TOKEN=xoxb-... make test-integration

# Run Google + Notion integration tests.
APRON_TOOLS_INTEGRATION_TESTS=1 GOOGLE_TOKEN=... NOTION_TOKEN=... make test-integration

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

apron_tools-0.3.0.tar.gz (495.6 kB view details)

Uploaded Source

Built Distribution

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

apron_tools-0.3.0-py3-none-any.whl (207.3 kB view details)

Uploaded Python 3

File details

Details for the file apron_tools-0.3.0.tar.gz.

File metadata

  • Download URL: apron_tools-0.3.0.tar.gz
  • Upload date:
  • Size: 495.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for apron_tools-0.3.0.tar.gz
Algorithm Hash digest
SHA256 0b0e864d96fe081b9ee27d84b300391f160c51ad488710154dd8f8f78c392ec9
MD5 c8a0ada15d5adf60db9ea8984bcf8a69
BLAKE2b-256 907ea32726d6142ff3293d7b2bf3cd0dcca1b34051872d1c0640cff06a1183bc

See more details on using hashes here.

Provenance

The following attestation bundles were made for apron_tools-0.3.0.tar.gz:

Publisher: release.yaml on mozilla-ai/apron-tools

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file apron_tools-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: apron_tools-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 207.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for apron_tools-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2eb60ed8fd81326ec641800c61ef3544b452865451847cc9010ee83428137ea7
MD5 a4ade713e8520dbd26e068444af62879
BLAKE2b-256 95637a8333a26a0af5c4e515d8d1d205439a77ac87378e2ccd83699d5b20decb

See more details on using hashes here.

Provenance

The following attestation bundles were made for apron_tools-0.3.0-py3-none-any.whl:

Publisher: release.yaml on mozilla-ai/apron-tools

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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