Package implementing adapter from DIAL Chat Completions API to Anthropic API
Project description
Python SDK for adapter from DIAL API to Anthropic API
Overview
The framework provides adapter from AI DIAL Chat Completion API to Anthropic Messages API.
Prompt caching
Automatic caching
Automatic caching is the simplest way to use prompt caching. A single top-level cache breakpoint instructs Anthropic to automatically apply a cache point to the last cacheable block of the request. This is ideal for multi-turn conversations where the growing message history should be cached automatically. See Automatic caching in the Anthropic docs.
To enable automatic caching, set custom_fields.cache_breakpoint at the top level of the Chat Completion request:
Top-level cache breakpoint
{
"model": "claude-3-5-sonnet-20241022",
"messages": [
{"role": "user", "content": "Hello!"}
],
"custom_fields": {
"cache_breakpoint": {}
}
}
Explicit cache breakpoints
Explicit cache breakpoints give fine-grained control over which parts of the prompt get cached. You can place a cache breakpoint on individual system messages, user/assistant messages, or tool definitions. See Explicit cache breakpoints in the Anthropic docs.
To add a breakpoint, set custom_fields.cache_breakpoint on a message or tool object:
System cache breakpoint
{
"model": "claude-3-5-sonnet-20241022",
"messages": [
{
"role": "system",
"content": "You are a helpful assistant with extensive knowledge.",
"custom_fields": {
"cache_breakpoint": {}
}
},
{"role": "user", "content": "Hello!"}
]
}
Message cache breakpoint
{
"model": "claude-3-5-sonnet-20241022",
"messages": [
{"role": "system", "content": "You are a helpful assistant."},
{
"role": "user",
"content": "Here is a long document: ...",
"custom_fields": {
"cache_breakpoint": {}
}
},
{"role": "user", "content": "Summarize it."}
]
}
Tools cache breakpoint
{
"model": "claude-3-5-sonnet-20241022",
"messages": [
{"role": "user", "content": "What's the weather?"}
],
"tools": [
{
"type": "function",
"function": {
"name": "get_weather",
"description": "Get the current weather",
"parameters": {
"type": "object",
"properties": {
"location": {"type": "string"}
},
"required": ["location"]
}
},
"custom_fields": {
"cache_breakpoint": {}
}
}
]
}
TTL support
A cache breakpoint may include an optional ttl field. Supported values are 5m (5 minutes, default) and 1h (one hour). The ttl field is supported on both top-level and explicit breakpoints. See TTL support in the Anthropic docs.
Top-level cache breakpoint with TTL
{
"model": "claude-3-5-sonnet-20241022",
"messages": [
{"role": "user", "content": "Hello!"}
],
"custom_fields": {
"cache_breakpoint": {
"ttl": "1h"
}
}
}
Development Environment
This project requires Python ≥3.11 and Poetry ≥2.1.1 for dependency management.
Setup
-
Install Poetry. See the official installation guide.
-
(Optional) Specify custom Python or Poetry executables in
.env.dev. This is useful if multiple versions are installed. By default,pythonandpoetryare used.POETRY_PYTHON=path-to-python-exe POETRY=path-to-poetry-exe
-
Create and activate the virtual environment:
make init_env source .venv/bin/activate
-
Install project dependencies (including linting, formatting, and test tools):
make install
Lint
Run the linting before committing:
make lint
To auto-fix formatting issues run:
make format
Test
Run unit tests locally for available python versions:
make test
Run unit tests for the specific python version:
make test PYTHON=3.13
Clean
To remove the virtual environment and build artifacts run:
make clean
Build
To build the package run:
make build
Publish
To publish the package to PyPI run:
make publish
Git hooks
You may optionally install Git hooks that will automatically run the linting step on Git push. You only need to do it once for the given repository.
make install_git_hooks
[!IMPORTANT] This command doesn't work if you have already installed Git hooks locally or globally.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file aidial_adapter_anthropic-0.8.0.dev4.tar.gz.
File metadata
- Download URL: aidial_adapter_anthropic-0.8.0.dev4.tar.gz
- Upload date:
- Size: 37.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.11.15 Linux/6.17.0-1010-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b141b03d049eae00966f57ce377d42bcfeeb230e35b9ff08e62dacd0261b1f36
|
|
| MD5 |
4c2922d408e8d2af7ebc6d75dacb89a6
|
|
| BLAKE2b-256 |
a0b036212d8c3c055cbc05572688dc77f5676c29fd646c01b31bee00af71b0fc
|
File details
Details for the file aidial_adapter_anthropic-0.8.0.dev4-py3-none-any.whl.
File metadata
- Download URL: aidial_adapter_anthropic-0.8.0.dev4-py3-none-any.whl
- Upload date:
- Size: 50.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.11.15 Linux/6.17.0-1010-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2309d65b4f8fbd2f25aae493299526859086d7ac339173e2f7f8caec4e1c1832
|
|
| MD5 |
9c08cea57818601de27aa383995ab40e
|
|
| BLAKE2b-256 |
63faf0f16978f2390045a09d2644013afc89b3f691b1d4c7cc7c21b73d0d1e71
|