Skip to main content

Use Composio to get array of strongly typed tools for Smol Agents

Project description

🚀🔗 Leveraging Smol Agents with Composio

Integrate Smol Agents with Composio to enable direct interaction with external applications, enhancing their capabilities through strongly-typed, validated tools.

Objective

  • Automate GitHub operations using type-safe instructions via Smol Agent's Tool system.
  • Demonstrate how to use Composio's tools with Smol Agent's CodeAgent.

Installation and Setup

Install the necessary packages and connect your GitHub account to enable agent interactions with GitHub:

# Install Composio Smol Agents package
pip install composio-smol

# Connect your GitHub account
composio add github

# View available applications you can connect with
composio apps

Usage Steps

1. Import Required Packages

Set up your environment by importing the necessary components from Composio & Smol Agents:

from dotenv import load_dotenv
import os

from composio import Action
from composio_smol import ComposioToolSet
from smolagents import HfApiModel, CodeAgent

2. Initialize Tools with Composio

Configure and fetch GitHub tools provided by Composio:

# Initialize toolset
composio_toolset = ComposioToolSet()

# Get GitHub tools with retry configuration
tools = composio_toolset.get_tools(
    actions=[Action.GITHUB_STAR_A_REPOSITORY_FOR_THE_AUTHENTICATED_USER],
)

3. Set Up the Smol Agent

Create and configure a Smol agent with the Composio tools:

# Create an agent with the tools
agent = CodeAgent(
    tools=tools,
    model=HfApiModel()
)

4. Execute Tasks

Run your agent with specific tasks:

# Define task
agent.run("Star the composiohq/composio repo")

Advanced Usage

The integration supports more complex scenarios:

# Using multiple tools
tools = composio_toolset.get_tools(
    actions=[
        Action.GITHUB_STAR_A_REPOSITORY_FOR_THE_AUTHENTICATED_USER,
        Action.GITHUB_CREATE_REPOSITORY
    ],
)

# Using app-specific tools
tools = composio_toolset.get_tools(
    apps=[App.GITHUB],
)

Best Practices

  1. Always use proper type hints in your code
  2. Handle validation errors appropriately
  3. Use the latest version of both Smol Agent and Composio
  4. Leverage async operations for better performance
  5. Keep your API keys secure using environment variables
  6. Configure retries based on the specific needs of each tool

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

composio_smol-0.7.16rc1.tar.gz (4.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

composio_smol-0.7.16rc1-py3-none-any.whl (4.6 kB view details)

Uploaded Python 3

File details

Details for the file composio_smol-0.7.16rc1.tar.gz.

File metadata

  • Download URL: composio_smol-0.7.16rc1.tar.gz
  • Upload date:
  • Size: 4.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for composio_smol-0.7.16rc1.tar.gz
Algorithm Hash digest
SHA256 8a05aaa480df30a7b74a18da14e325d634f1f87e795067af9eb377eff60a740f
MD5 4c24cbc5105cc649b27f5256b5788c3e
BLAKE2b-256 3e0e064ba3710f48e2a72622e8e1e13881e48e2b80995c4732a1710c5dc68954

See more details on using hashes here.

File details

Details for the file composio_smol-0.7.16rc1-py3-none-any.whl.

File metadata

File hashes

Hashes for composio_smol-0.7.16rc1-py3-none-any.whl
Algorithm Hash digest
SHA256 bbcbe5246918e852d5bbac04d8fd41cd389dfa0e3d812731ac24b9620018b97e
MD5 930fe00659d1091e622af76f07a1a913
BLAKE2b-256 e33b6eee79774854c5c25dc89c00edb22bb1ea43b559baf9732848b8d2b07844

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page