LaunchDarkly AI SDK LangChain Provider
Project description
LaunchDarkly AI SDK - LangChain Provider
[!CAUTION] This package is in pre-release and not subject to backwards compatibility guarantees. The API may change based on feedback.
Pin to a specific minor version and review the changelog before upgrading.
This package provides LangChain integration for the LaunchDarkly Server-Side AI SDK, allowing you to use LangChain models and chains with LaunchDarkly's tracking and configuration capabilities.
Installation
pip install launchdarkly-server-sdk-ai-langchain
You'll also need to install the LangChain provider packages for the models you want to use:
# For OpenAI
pip install langchain-openai
# For Anthropic
pip install langchain-anthropic
# For Google
pip install langchain-google-genai
Quick Start
import asyncio
from ldclient import LDClient, Config, Context
from ldai import LDAIClient
from ldai.models import AICompletionConfigDefault, ModelConfig, ProviderConfig
# Initialize LaunchDarkly client
ld_client = LDClient(Config("your-sdk-key"))
ai_client = LDAIClient(ld_client)
context = Context.builder("user-123").build()
async def main():
# Create a ManagedModel backed by the LangChain provider
model = ai_client.create_model(
"ai-config-key",
context,
AICompletionConfigDefault(
enabled=True,
model=ModelConfig("gpt-4"),
provider=ProviderConfig("langchain"),
),
)
if model:
result = await model.run("Hello, how are you?")
print(result.content)
asyncio.run(main())
Usage
Using create_model (recommended)
The recommended entry point is LDAIClient.create_model, which evaluates a
LaunchDarkly AI config flag, selects the LangChain runner automatically, and
returns a ManagedModel that wraps the runner:
model = ai_client.create_model("ai-config-key", context)
if model:
result = await model.run("What is feature flagging?")
print(result.content)
Using the runner directly
If you need to construct a runner manually (e.g. for testing), you can use
LangChainModelRunner from the ldai_langchain package:
from langchain_openai import ChatOpenAI
from ldai_langchain import LangChainModelRunner
llm = ChatOpenAI(model="gpt-4", temperature=0.7)
runner = LangChainModelRunner(llm)
result = await runner.run("Hello!")
print(result.content)
Structured Output
Pass a JSON schema dict as output_type to request structured output:
response_structure = {
"type": "object",
"properties": {
"sentiment": {"type": "string", "enum": ["positive", "negative", "neutral"]},
"confidence": {"type": "number"},
},
"required": ["sentiment", "confidence"],
}
result = await runner.run(messages, output_type=response_structure)
print(result.parsed) # {"sentiment": "positive", "confidence": 0.95}
Tracking Metrics
ManagedModel.run() automatically tracks metrics via the associated
LDAIConfigTracker. For manual tracking, use the tracker directly:
model = ai_client.create_model("ai-config-key", context)
if model:
result = await model.run("Explain feature flags.")
# Metrics are tracked automatically; access them via result.metrics
print(result.metrics.tokens)
Static Utility Methods
The ldai_langchain helper module provides several utility functions:
Converting Messages
from ldai.models import LDMessage
from ldai_langchain.langchain_helper import convert_messages_to_langchain
messages = [
LDMessage(role="system", content="You are helpful."),
LDMessage(role="user", content="Hello!"),
]
langchain_messages = convert_messages_to_langchain(messages)
Extracting Metrics
from ldai_langchain.langchain_helper import get_ai_metrics_from_response
# After getting a response from LangChain
metrics = get_ai_metrics_from_response(ai_message)
print(f"Success: {metrics.success}")
print(f"Tokens used: {metrics.tokens.total if metrics.tokens else 'N/A'}")
Provider Name Mapping
from ldai_langchain.langchain_helper import map_provider_name
# Map LaunchDarkly provider names to LangChain provider names
langchain_provider = map_provider_name("gemini") # Returns "google-genai"
Documentation
For full documentation, please refer to the LaunchDarkly AI SDK documentation.
Contributing
See CONTRIBUTING.md in the repository root.
License
Apache-2.0
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 launchdarkly_server_sdk_ai_langchain-0.8.0.tar.gz.
File metadata
- Download URL: launchdarkly_server_sdk_ai_langchain-0.8.0.tar.gz
- Upload date:
- Size: 28.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
975fb18ce8a9878ede16abbf80b220f2080bed68c10fbe7ffeee7ca7383251b2
|
|
| MD5 |
e8714a34dc5593c51e7d459533f74a62
|
|
| BLAKE2b-256 |
0c95f49f54bbbc717af799a7babcfed58edf47c3d4da4b11367f39e38eda92e4
|
File details
Details for the file launchdarkly_server_sdk_ai_langchain-0.8.0-py3-none-any.whl.
File metadata
- Download URL: launchdarkly_server_sdk_ai_langchain-0.8.0-py3-none-any.whl
- Upload date:
- Size: 17.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
629bf1fbccb2ee33a31be568060c11767c7e9e5adf8d4e00fb95c29e2aa92cf7
|
|
| MD5 |
ab2a80ec26cfbc04f2e6c8184a9806d3
|
|
| BLAKE2b-256 |
4414abeb7e73c0eae14b0c43309ec77a8bb06b1736250d49b2cd44b30f26820d
|