Co-authored-by: Eric Gustin <eric@arcade-ai.com> Co-authored-by: Nate Barbettini <nathanaelb@gmail.com> Co-authored-by: Nate Barbettini <nate@arcade-ai.com>
10 KiB
Docs • Integrations • Cookbook • Python Client • JavaScript Client
What is Arcade AI?
Arcade AI offers developer-focused tooling and APIs designed to improve the capabilities of LLM applications and agents.
By providing an authentication and authorization layer for agents and the tools agents use, Arcade AI connects agentic applications with your users' data and services - like accessing their Gmail, GitHub, Zoom, Spotify, LinkedIn, and more.
To learn more, check out our documentation.
Pst. hey, you, join our stargazers! It's free!
Quickstart
Requirements
- An Arcade AI account (current a waitlist)
- Python 3.10+. Verify your Python version by running
python --versionorpython3 --versionin your terminal - pip, the Python package installer that is typically included with Python
Installation
pip install 'arcade-ai[fastapi]'
Then login to your account (we're working through the waitlist as fast as we can!)
arcade login
This will open a browser window to login.
Verify Installation using arcade chat
The arcade-ai package comes with a CLI app called arcade chat that is used to test tools as you develop them.
By default, arcade chat will connect to the hosted version of Arcade AI with built-in tools (found in toolkits).
arcade chat
This launches a chat with the Arcade Cloud Engine (hosted at api.arcade-ai.com). All pre-built Arcade tools are available to use.
For example, try asking:
star the ArcadeAI/arcade-ai repo on Github
Arcade AI will ask you to authorize with GitHub, and then the AI assistant will star the ArcadeAI/arcade-ai repo on your behalf.
You'll see output similar to this:
Assistant (gpt-4o):
I starred the ArcadeAI/arcade-ai repo on Github for you!
You can use Ctrl-C to exit the chat at any time.
Arcade Engine APIs
/auth: Generic OAuth 2.0 flow for authorizing agents across many services/tools: Manage, authorize, and execute tools. Tool-calling where the tools are actually called/chat: An OpenAI-compatible LLM API that enables tool execution with newtool_choiceoptions:tool_choice='execute': Return the predicted tool call's output as content in the responsetool_choice='generate': Generate a response informed by predicted tool call(s) execution.
See the full API spec here.
Arcade Cloud Engine
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
Arcade AI offers a number of prebuilt toolkits that can be used to interact with a variety of services.
Calling tools directly
from arcadepy import Arcade
client = Arcade()
USER_ID = "you@example.com"
TOOL_NAME = "Github.SetStarred"
# Perform User Authorization
auth_response = client.tools.authorize(
tool_name=TOOL_NAME,
user_id=USER_ID,
)
if auth_response.status != "completed":
print(f"Click this link to authorize: {auth_response.auth_url}")
input("After you have authorized, press Enter to continue...")
# Run the tool
inputs = {"owner": "ArcadeAI", "name": "Hello-World", "starred": True}
response = client.tools.run(
tool_name=TOOL_NAME,
inputs=inputs,
user_id=USER_ID,
)
print(response)
Calling tools with the LLM API
import os
from openai import OpenAI
USER_ID = "you@example.com"
PROMPT = "Star the ArcadeAI/arcade-ai repository."
TOOL_NAME = "Github.SetStarred"
# Use "generate" to have the LLM generate a response after the tool executes. Use 'execute' to get the tool's output directly.
TOOL_CHOICE = "generate"
client = OpenAI(
base_url="https://api.arcade-ai.com",
api_key=os.environ.get("ARCADE_API_KEY"))
response = client.chat.completions.create(
messages=[
{"role": "user", "content": PROMPT},
],
model="gpt-4o-mini",
user=USER_ID,
tools=[TOOL_NAME],
tool_choice=TOOL_CHOICE,
)
print(response.choices[0].message.content)
Building Your Own Tools
Learn how to build your own tools by following our creating a custom toolkit guide.
Evaluating Tools
Arcade AI enables you to evaluate your custom tools to ensure they function correctly with the AI assistant, including defining evaluation cases and using different critics.
Learn how to evaluate your tools by following our evaluating tools guide.
Auth
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
Learn how to use Arcade AI to obtain user authorization for accessing third-party services in our authorizing agents with Arcade AI guide.
Learn how to use Arcade AI's auth providers to enable tools and agents to call other services on behalf of users in our tools with auth guide.
To see all available auth providers, refer to the auth providers documentation.
Models
![]()
![]()
![]()
Arcade AI supports a variety of model providers when using the Arcade AI LLM API.
To see all available models, refer to the models documentation.
Contributing
We love contributions! Please read our contributing guide before submitting a pull request. If you'd like to self-host, refer to the self-hosting documentation.