Utilities for integration of AI DIAL API with Langchain library
Project description
Overview
The package provides helpers facilitating integration of DIAL API with Langchain library.
Passing DIAL-specific extra fields in Langchain requests/responses
Unlike openai library, langchain-openai library doesn't allow to pass extra request/response parameters to/from the upstream model.
The minimal example highlighting the issue could be found in the example folder:
cd example
python -m venv .venv
source .venv/bin/activate
pip install -q -r requirements.txt
python -m app
Received the following extra fields:
(1) ☑ request.extra_field
(2) ☑ request.tools[0].extra_field
(3) ☐ request.messages[0].extra_field
(4) ☐ response.message.extra_field
(5) ☐ response.extra_field
langchain-openai ignores certain extra fields, meaning that the upstream endpoint won't receive (2) and the client won't receive (4) and (5) if they were sent by the upstream.
Note that top-level request extra fields and tool definition extra fields do actually reach the upstream.
Solution
One way to fix the issue, is to modify the Langchain methods that ignore these extra fields so that they are taken into account.
This is achieved via monkey-patching certain private methods in langchain-openai that do the conversion from the Langchain datatypes to dictionaries and vice versa.
Usage
Install the aidial-integration-langchain package as a dependency in your project:
pip install aidial-integration-langchain
Then import aidial_integration_langchain before importing any Langchain module to apply the patches:
import aidial_integration_langchain.patch # isort:skip # noqa: F401 # type: ignore
from langchain_openai import AzureChatOpenAI
...
The same example as above, but with the patch applied:
cd example
python -m venv .venv
source .venv/bin/activate
pip install -q -r requirements.txt
pip install -q aidial-integration-langchain
python -m app patch
Received the following extra fields:
(1) ☑ request.extra_field
(2) ☑ request.tools[0].extra_field
(3) ☑ request.messages[0].extra_field
(4) ☑ response.message.extra_field
(5) ☑ response.extra_field
Supported Langchain versions
The following langchain-openai versions have been tested for Python 3.9, 3.10, 3.11, 3.12, and 3.13:
| Version | Request per-message | Response per-message | Response top-level |
|---|---|---|---|
| >=0.1.1,<=0.1.22 | 🟢 | 🟢 | 🔴 |
| >=0.1.23,<=0.1.25 | 🟢 | 🟢 | 🟢 |
| >=0.2.0,<=0.2.14 | 🟢 | 🟢 | 🟢 |
| >=0.3.0,<=0.3.18 | 🟢 | 🟢 | 🟢 |
[!NOTE] The patched
langchain-openai<=0.1.22doesn't support response top-level extra fields, since the structure of the code back then was not very amicable for monkey-patching in this particular respect.
Configuration
The list of extra fields that are allowed to pass-through is controlled by the following environment variables.
| Name | Default | Description |
|---|---|---|
| LC_EXTRA_REQUEST_MESSAGE_FIELDS | custom_content | A comma-separated list of extra message fields allowed to pass-through in chat completion requests. |
| LC_EXTRA_RESPONSE_MESSAGE_FIELDS | custom_content | A comma-separated list of extra message fields allowed to pass-through in chat completion responses. |
| LC_EXTRA_RESPONSE_FIELDS | statistics | A comma-separated list of extra fields allowed to pass-through on the top-level of the chat completion responses. |
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_integration_langchain-0.1.0.tar.gz.
File metadata
- Download URL: aidial_integration_langchain-0.1.0.tar.gz
- Upload date:
- Size: 4.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f82c9b6f20ae8e551b27b4dd85be06227af524b79c3125ac894da535a5b2595b
|
|
| MD5 |
cc73f7f3ee0d9c773b92ed8474b63db4
|
|
| BLAKE2b-256 |
9c88e3aa03f58d42c9f403a55bda56eefd468c2c5617d8d70a40b8713ef81214
|
File details
Details for the file aidial_integration_langchain-0.1.0-py3-none-any.whl.
File metadata
- Download URL: aidial_integration_langchain-0.1.0-py3-none-any.whl
- Upload date:
- Size: 5.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
652fc753d1a69e9e105d6aba9dd9a4c23c8021995057afc091a98101dbd53e22
|
|
| MD5 |
48bdd1d4bf8479c0658dbe6b104c6810
|
|
| BLAKE2b-256 |
8af34e719f9059bc13bcfc482ac386e7ff1fbbaad6545929fd837be97b291d14
|