Skip to main content

Expose djangorestframework-services services and selectors as a Pydantic-AI toolset.

Project description

djangorestframework-pydantic-ai

CI PyPI Python versions Django versions Docs Coverage Ruff License

Expose djangorestframework-services services and selectors as a Pydantic-AI toolset, so a plain pydantic_ai.Agent can call them as tools — no MCP server and no AG-UI bridge in the path.

Every tool call routes through drf-services' transport-neutral surface (dispatch_spec plus its off-HTTP helpers), so a tool call runs the same input validation, the same permission_classes — both class-level has_permission and object-level has_object_permission on the resolved row — and the same serializer rendering your DRF views apply, just without the HTTP hop.

Install

pip install djangorestframework-pydantic-ai

It depends only on djangorestframework-services and pydantic-ai-slim. A model provider is pulled in separately, the usual Pydantic-AI way (e.g. pip install "pydantic-ai-slim[anthropic]").

Quickstart

from pydantic_ai import Agent
from rest_framework_pydantic_ai import AgentDeps, SpecToolset

toolset = SpecToolset({
    "list_orders":  orders_selector_spec,   # SelectorSpec -> read-only tool
    "create_order": create_order_spec,      # ServiceSpec  -> mutation tool
})

agent = Agent("anthropic:claude-opus-4-8", deps_type=AgentDeps, toolsets=[toolset])

result = await agent.run(
    "create an order of 3 widgets",
    deps=AgentDeps(user=request.user),
)

The agent acts as deps.user: each call builds an off-HTTP request/view context, enforces the spec's permission_classes (class- and object-level), dispatches the spec, and renders the result through the spec's serializer. List selectors gain page / limit / order tool args.

Failures map onto the model loop so the agent self-corrects: invalid input, a bad page / limit / order value, and unexpected (hallucinated) arguments come back as ModelRetry; a business error or missing row becomes a readable {"error": ...}; a denied permission raises PermissionDenied and aborts the run. Unexpected arguments are rejected by default — pass unknown_arguments= to SpecToolset (IGNORE / PASSTHROUGH) to change that.

See the documentation for the full reference.

License

MIT

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

djangorestframework_pydantic_ai-0.2.2.tar.gz (108.7 kB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file djangorestframework_pydantic_ai-0.2.2.tar.gz.

File metadata

File hashes

Hashes for djangorestframework_pydantic_ai-0.2.2.tar.gz
Algorithm Hash digest
SHA256 2dc00d67fae840bdb861725da18c5cdc34488ca0d3933b32a2263e45508b7f03
MD5 a4fda7d9d8772c3243a316292cae5b13
BLAKE2b-256 77a3db1940c15b5070bedc5b8191b9c96d87efe7975bed2255b90df2e5c9a40a

See more details on using hashes here.

Provenance

The following attestation bundles were made for djangorestframework_pydantic_ai-0.2.2.tar.gz:

Publisher: release.yml on Artui/djangorestframework-pydantic-ai

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

File details

Details for the file djangorestframework_pydantic_ai-0.2.2-py3-none-any.whl.

File metadata

File hashes

Hashes for djangorestframework_pydantic_ai-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 a744344a763cc0f402bc17d09a57fec75616de59a42318b185ab918843f63863
MD5 573a7d62298631c1bad3a4086c29e2a0
BLAKE2b-256 229c471129fb1bf0871faf76e41483183ec4d1080aadc7cefc3a34c2428e37d6

See more details on using hashes here.

Provenance

The following attestation bundles were made for djangorestframework_pydantic_ai-0.2.2-py3-none-any.whl:

Publisher: release.yml on Artui/djangorestframework-pydantic-ai

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