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.1.0.tar.gz (492.4 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.1.0-py3-none-any.whl (205.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: apron_tools-0.1.0.tar.gz
  • Upload date:
  • Size: 492.4 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.1.0.tar.gz
Algorithm Hash digest
SHA256 ec3eecc004f157cb5d64c25161dc99dc70b57d17141a33575eeb9bc33c2615a2
MD5 16d9f9b0a7ad397d44dfcaad70f7d2fa
BLAKE2b-256 5ec1bfd6a4c2ca4873fa5c74b345aced811da5fb8994d8e3f30b0fa85bd264b4

See more details on using hashes here.

Provenance

The following attestation bundles were made for apron_tools-0.1.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.1.0-py3-none-any.whl.

File metadata

  • Download URL: apron_tools-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 205.7 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.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 54d1997162df39968a49a13513041c123e1123a0dcd3c07c6b1ca58c1db47ff8
MD5 a655c2cdca42e70f49a892559c3fd4c9
BLAKE2b-256 8fbd2afb46d7ca1def8cb223df957b09a54a10fec286d7f9210ae9ae1b0486da

See more details on using hashes here.

Provenance

The following attestation bundles were made for apron_tools-0.1.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