LangChain & LangGraph extensions that parse LLM prompts into Timbr semantic SQL and execute them.
Project description
Timbr LangChain LLM SDK
Timbr LangChain LLM SDK is a Python SDK that extends LangChain and LangGraph with custom agents, chains, and nodes for seamless integration with the Timbr semantic layer. It enables converting natural language prompts into optimized semantic-SQL queries and executing them directly against your data.
Dependencies
- Access to a timbr-server
- Python 3.10 or newer
Installation
Using pip
python -m pip install langchain-timbr
Install with selected LLM providers
One of: openai, anthropic, google, azure_openai, snowflake, databricks, vertex_ai, bedrock (or 'all')
python -m pip install 'langchain-timbr[<your selected providers, separated by comma w/o space>]'
Using pip from github
pip install git+https://github.com/WPSemantix/langchain-timbr
Documentation
For comprehensive documentation and usage examples, please visit:
Configuration
The SDK uses environment variables for configuration. All configurations are optional - when set, they serve as default values for langchain-timbr provided tools. Below are all available configuration options:
Configuration Options
Timbr Connection Settings
TIMBR_URL- The URL of your Timbr serverTIMBR_TOKEN- Authentication token for accessing the Timbr serverTIMBR_ONTOLOGY- The ontology to use (also acceptsONTOLOGYas an alias)IS_JWT- Whether the token is a JWT token (true/false)JWT_TENANT_ID- Tenant ID for JWT authentication
Cache and Data Processing
CACHE_TIMEOUT- Timeout for caching operations in secondsIGNORE_TAGS- Comma-separated list of tags to ignore during processingIGNORE_TAGS_PREFIX- Comma-separated list of tag prefixes to ignore during processing
LLM Configuration
LLM_TYPE- The type of LLM provider to useLLM_MODEL- The specific model to use with the LLM providerLLM_API_KEY- API key or client secret for the LLM providerLLM_TEMPERATURE- Temperature setting for LLM responses (controls randomness)LLM_ADDITIONAL_PARAMS- Additional parameters to pass to the LLMLLM_TIMEOUT- Timeout for LLM requests in secondsLLM_TENANT_ID- LLM provider tenant/directory ID (Used for Service Principal authentication)LLM_CLIENT_ID- LLM provider client ID (Used for Service Principal authentication)LLM_CLIENT_SECRET- LLM provider client secret (Used for Service Principal authentication)LLM_ENDPOINT- LLM provider OpenAI endpoint URLLLM_API_VERSION- LLM provider API versionLLM_SCOPE- LLM provider authentication scope
Monitoring & History
TIMBR_ENABLE_TRACE- Enable detailed trace logging for agent/chain execution (true/false, default:false)TIMBR_ENABLE_HISTORY- Enable query history tracking (true/false, default:false)TIMBR_HISTORY_SAVE_RESULTS- Whether to save query result rows in history (true/false, default:false)
Monitoring & Tracing
The SDK supports optional execution tracing and query history recording. These can be enabled via environment variables (see above) or set directly on TimbrSqlAgent:
from langchain_timbr import TimbrSqlAgent
agent = TimbrSqlAgent(
llm=llm,
url="https://your-timbr-server",
token="your-token",
ontology="your_ontology",
enable_trace=True, # Enable chain-level trace logging
enable_history=True, # Enable query history storage
save_results=True, # Save result rows in history
conversation_id="conv-123", # Group calls into a multi-turn conversation
)
| Parameter | Type | Default | Description |
|---|---|---|---|
enable_trace |
Optional[bool] |
TIMBR_ENABLE_TRACE |
Enable detailed trace logging per chain step |
enable_history |
Optional[bool] |
TIMBR_ENABLE_HISTORY |
Store query execution history |
save_results |
Optional[bool] |
TIMBR_HISTORY_SAVE_RESULTS |
Include result rows in history entries |
conversation_id |
Optional[str] |
None |
Associate multiple agent calls under one conversation |
Benchmarking
The SDK includes a benchmarking utility to evaluate LLM query accuracy against a named benchmark defined in your Timbr server.
from langchain_timbr.utils.benchmark import run_benchmark
results = run_benchmark(
benchmark_name="my_benchmark",
url="https://your-timbr-server",
token="your-token",
ontology="your_ontology",
execution="full", # "full" or "generate_sql_only"
number_of_iterations=1,
use_deterministic=True, # Row-comparison scoring
use_llm_judge=False, # LLM-as-judge scoring
llm_params={ # Optional: override LLM at runtime
"llm_type": "openai",
"llm_model": "gpt-4o",
"api_key": "sk-...",
},
)
The llm_params dict accepts: llm_type, llm_model / model, llm_api_key / api_key. Temperature and timeout are managed automatically.
Results are returned as a dict keyed by question ID, with a "_summary" key containing aggregate statistics. Each result includes a selected_entity field identifying which ontology entity was used.
Conversation Memory
TIMBR_ENABLE_MEMORY- Enable conversation memory for follow-up question detection (true/false, default: false)TIMBR_MEMORY_WINDOW_SIZE- Number of past conversation turns to consider when detecting follow-ups (default: 3)
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 langchain_timbr-5.2.1.tar.gz.
File metadata
- Download URL: langchain_timbr-5.2.1.tar.gz
- Upload date:
- Size: 118.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f26c98f0e7a3edf52629cb85de74720511c56177acd099481433deb7da2ac76d
|
|
| MD5 |
218c4ff8804bc0f201049f0d245dff46
|
|
| BLAKE2b-256 |
7713239e25ff72d6f8ca18385aae0c8c4d0c2169daeb5c980def69563036c88b
|
File details
Details for the file langchain_timbr-5.2.1-py3-none-any.whl.
File metadata
- Download URL: langchain_timbr-5.2.1-py3-none-any.whl
- Upload date:
- Size: 104.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
84f85ad5207e1e4fda8856613b5360e824dd0fe6fe8c47630363e7947ef0e48d
|
|
| MD5 |
4934fd852ca9afd20bdd8808f9d7e121
|
|
| BLAKE2b-256 |
56eeb0d075902c8976d7ae8c43e37a1263c603790ebb2a7e842cbb7329b1d8b2
|