This is the Python SDK for Toolhouse.
Toolhouse allows you to unlock the best LLM knowledge and actions. It works across a wide ranges or LLMs and providers.
With Toolhouse, you can install tools from the Tool Store and execute them in the cloud, without the need to handling their execution locally.
For more details, you can check out our documentation.
With pip
:
pip install toolhouse
With poetry
:
poetry add toolhouse
In order to use the SDK, you will need a Toolhouse API key. To get the API key:
Copy the API Key and save it where you save your secrets. We'll assume you have a .env file.
We suggest saving your API Key as TOOLHOUSE_API_KEY
in your environment file. This allows Toolhouse to pick up its value directly in your code.
TOOLHOUSE_API_KEY=<Your API Key value>
Alternatively, you can set the API key when you initialize the SDK. You can do this in the constructor:
tools = Toolhouse('YOUR_API_KEY')
You can also use the set_api_key
method:
tools = Toolhouse()
tools.set_api_key('YOUR_API_KEY')
Our Quick start guide has all you need to get you set up quickly.
Toolhouse works with the widest possible range of LLMs across different providers. By default, the Toolhouse API will work with any LLM that is compatible with the OpenAI chat completions API.
You can switch providers when initializing the SDK through the constructor:
from toolhouse import Toolhouse, Provider
tools = Toolhouse(provider=provider.ANTHROPIC)
If you are passing your API key:
from toolhouse import Toolhouse, Provider
tools = Toolhouse('YOUR_API_KEY', provider.ANTHROPIC)
In this example, we'll use the OpenAI SDK as well as dotenv.
pip install python-dotenv
Create a .env
and add your API keys there.
TOOLHOUSE_API_KEY=
OPENAI_API_KEY=
Head over to Toolhouse and install the Current time tool.
import os
from dotenv import load_dotenv
from toolhouse import Toolhouse
from openai import OpenAI
from typing import List
load_dotenv()
client = OpenAI()
tools = Toolhouse()
#Metadata to convert UTC time to your localtime
th.set_metadata("timezone", -7)
messages: List = [{
"role": "user",
"content": "What's the current time?"
}]
response = client.chat.completions.create(
model='gpt-4o',
messages=messages,
tools=tools.get_tools(),
tool_choice="auto"
)
messages += th.run_tools(response)
response = client.chat.completions.create(
model="gpt-4o-mini",
messages=messages,
tools=tools.get_tools(),
tool_choice="auto"
)
print(response.choices[0].message.content)
To utilize a local tool, you need to define the tool, its JSON schema, and register it with the Toolhouse SDK. Here's a step-by-step guide:
Here is a sample code:
"""OpenAI Sample"""
import os
from typing import List
from dotenv import load_dotenv
from openai import OpenAI
from toolhouse import Toolhouse
# Make sure to set up the .env file according to the .env.example file.
load_dotenv()
local_tools = [
{'type': 'function',
'function':
{
'name': 'hello',
'description': 'The user receives a customized hello message from a city and returns it to the user.',
'parameters': {
'type': 'object',
'properties': {
'city': {'type': 'string', 'description': 'The city where you are from'}
}},
'required': ['city']
}}]
th = Toolhouse(provider="openai")
th.set_metadata("id", "fabio")
th.set_metadata("timezone", 5)
@th.register_local_tool("hello") # the name used to register the tool should be the same as the name in the json schema
def hello_tool(city: str):
"""Return a Hello message from a specific city."""
return f"Hello from {city}!!!"
client = OpenAI()
messages: List = [{
"role": "user",
"content":
"Can I get a hello from Rome?"
}]
response = client.chat.completions.create(
model='gpt-4o',
messages=messages,
tools=th.get_tools() + local_tools
)
messages += th.run_tools(response)
response = client.chat.completions.create(
model="gpt-4o",
messages=messages,
tools=th.get_tools() + local_tools
)
print(response.choices[0].message.content)
Bundles help you define groups of tools you want to pass to the LLM based on specific contextual need. For example, if you want to enhance your LLM's knowledge with live stock market data, you can create a Bundle with a stock price API call, a RAG for stock news, and summarization of SEC filings. In order to create a bundle, you need to:
Here is a sample code:
import os
from typing import List
from dotenv import load_dotenv
from openai import OpenAI
from toolhouse import Toolhouse
# Make sure to set up the .env file according to the .env.example file.
load_dotenv()
th = Toolhouse(provider="openai")
th.set_metadata("id", "fabio") # metadata is optional based on the tools you are using
th.set_metadata("timezone", 5) # metadata is optional based on the tools you are using
client = OpenAI()
messages: List = [{
"role": "user",
"content": "What is the stock price of Apple?"
}]
response = client.chat.completions.create(
model='gpt-4o',
messages=messages,
tools=th.get_tools(bundle="stock_bundle")
)
We welcome pull requests that add meaningful additions to these code samples, particularly for issues that can expand compability.
You can submit issues (for example for feature requests or improvements) by using the Issues tab.
Developers can also contribute to Toolhouse by publishing tools for the Tool Store. The Tool Store allows developers to submit their tools and monetize them every time they're executed. Developers and tools must go through an review and approval process, which includes adhering to the Toolhouse Privacy and Data Protection policy. If you're interested in becoming a publisher, submit your application.