Skip to main content

Reference keel-llm-protocol adapter for Anthropic's Messages API — the divergent-provider grounding for the standard.

Project description

keel-llm-adapter-anthropic

A reference keel-llm-protocol adapter for Anthropic's Messages API (Claude).

This package is the divergent-provider grounding for the protocol standard. Where keel-llm-adapter-openai proves the standard against the OpenAI-compatible family, this proves it against an API that diverges on purpose — and the protocol absorbs every difference in the adapter, without changing the standard. That is the standard generalizing.

Install

pip install keel-llm-adapter-anthropic     # pulls in keel-llm-protocol + httpx

Use

from keel_llm_adapter_anthropic import AnthropicAdapter
from keel_llm_protocol import system, user

adapter = AnthropicAdapter(model="claude-sonnet-4-5", api_key="...", provider="anthropic")
resp = await adapter.generate([system("Be terse."), user("What is a circuit breaker?")])
print(resp.text, resp.usage.total_tokens, resp.finish_reason)

Same keel-llm-protocol types as every other adapter — swap AnthropicAdapter for OpenAIAdapter and your code is unchanged. It implements ModelAdapter, StreamingModelAdapter, and ToolCallingModelAdapter.

How Anthropic diverges — and where it's handled

Every divergence below is absorbed inside the adapter; the protocol's types are untouched:

Anthropic divergence Protocol stays the same because…
System prompt is a top-level system field, not a message the adapter lifts Message(role="system") into the system param
Only user / assistant roles exist tool messages → tool_result content blocks; assistant tool_callstool_use blocks
Tool input arrives as a parsed dict the adapter json.dumps it into ToolCall.arguments (a JSON string)
Tools use input_schema + tool_choice: {type: auto|any|tool} the adapter maps ToolSpec / tool_choice accordingly
max_tokens is required the adapter supplies default_max_tokens (4096) when unset
Distinct SSE events (message_start / content_block_delta / message_delta) the adapter maps them onto StreamChunk
529 overloaded status mapped to retryable TransientError
{"type":"error","error":{...}} envelope + stop_reason values mapped to the standard error taxonomy + FinishReason

Known limitation

Anthropic has no native response_format parameter — structured output is done via tools or prompt instructions. This adapter therefore treats ResponseFormat as a best-effort hint and does not enforce it. (A finding worth keeping: in the standard, response_format is a request, not a guarantee — provider support varies.)

Status

0.1.0 — first release. Pin exact versions while in 0.x. Source: Keel monorepo.

License

MIT — see LICENSE.

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

keel_llm_adapter_anthropic-0.1.0.tar.gz (9.7 kB view details)

Uploaded Source

Built Distribution

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

keel_llm_adapter_anthropic-0.1.0-py3-none-any.whl (7.1 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for keel_llm_adapter_anthropic-0.1.0.tar.gz
Algorithm Hash digest
SHA256 81a9d0f47694b575e8d91048731eefe99add6823e9d275a3e3c54762ea2f5676
MD5 2b7ea0285164c0923cf2bd45b5aa7850
BLAKE2b-256 bac2521ce1f092be7b31a3802f27d7324ce4c077e3d9e5602bf7c9e61b4cbbff

See more details on using hashes here.

Provenance

The following attestation bundles were made for keel_llm_adapter_anthropic-0.1.0.tar.gz:

Publisher: publish-py.yml on keelplatform/keel

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

File details

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

File metadata

File hashes

Hashes for keel_llm_adapter_anthropic-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3fb174c796e987d163b7594c9d15ce393e09ceb8035ae99a72ab569c48b7b6c4
MD5 06902be48a11ba2e9e8ae0937ae50589
BLAKE2b-256 24e90e6bcfd3a117d2e70a46790687462cff875bd640dc15fb82576abb4a2e45

See more details on using hashes here.

Provenance

The following attestation bundles were made for keel_llm_adapter_anthropic-0.1.0-py3-none-any.whl:

Publisher: publish-py.yml on keelplatform/keel

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