Skip to main content

simpletool

Project description

Simpletool

SimpleTool is a lightweight Python framework designed for creating simple, strict, and explicit type-safe tools with minimal complexity. It supports both synchronous and asynchronous execution patterns, with the async functionality available in the dedicated simpletool.asyncio module. It embodies some of the Python design Zen principles, such as "Simple is better than complex" and "Explicit is better than implicit".

⚠️ Disclaimer [2025-03]

  • 🛠️ Under active development: Expect frequent updates, bugs, and breaking changes.
  • 🤓 Check the release notes: Always check the release notes to verify if there are any breaking changes.

💡 Overview

Simpletool is a powerful SDK that provides a structured approach to building tools with:

  • Standardized input and output content types
  • Automatic JSON schema generation
  • Both synchronous and asynchronous support
  • Environment variable handling
  • Timeout management in asyncio (def. 60s)

⚡️ Architecture Overview

classDiagram
    class Content {
        <<abstract>>
        +type: Literal["text", "image", "file", "error"]
        AutoValidation
    }
    
    class TextContent {
        +text: str
    }
    
    class ImageContent {
        +data: str
        +description: str
        +mime_type: str
    }
    
    class FileContent {
        +data: str
        +file_name: str
        +mime_type: str
        AutoValidation
    }
    
    class ErrorContent {
        +code: int
        +message: str
        +data: Any
    }
    
    class SimpleTool {
        <<abstract>>
        +name: str
        +description: str
        +input_model: Type[SimpleInputModel]
        +input_schema: Dict (auto generated)
        +output_schema: Dict (auto generated)
        +get_env(arguments: dict, prefix: str)
        +run(arguments: dict) Sequence[Content]
    }
    
    class AsyncSimpleTool {
        <<abstract>>
        +name: str
        +description: str
        +input_model: Type[SimpleInputModel]
        +input_schema: Dict (auto generated)
        +output_schema: Dict (auto generated)
        +get_env(arguments: dict, prefix: str)
        +run(arguments: dict) Sequence[Content]
    }
    
    class SimpleInputModel {
        <<interface>>
        AutoValidation
    }
    
    SimpleTool <-- SimpleInputModel: arguments (Dict[str, Any])
    SimpleTool <-- SimpleInputModel: input_model (Type[SimpleInputModel])_
    AsyncSimpleTool <-- SimpleInputModel: arguments (Dict[str, Any])
    AsyncSimpleTool <-- SimpleInputModel: input_model (Type[SimpleInputModel])_

    Content --|> TextContent
    Content --|> ImageContent
    Content --|> FileContent
    Content --|> ErrorContent
    
    SimpleTool --> Content: returns Sequence[Content]
    AsyncSimpleTool --> Content: returns Sequence[Content]

💻 Core Components

SimpleTool Base Class and Key Features

The SimpleTool class provides a robust framework for building tools with the following key features:

  • Input Validation:

    • Uses Pydantic models for strict input validation (SimpleInputModel)
    • Automatic type checking and conversion based on Pydantic models
    • SimpleInputModel have own model_json_schema (removes titles and descriptions from the schema) for easy dump to text schema
  • Output Type Management:

    • Supports multiple content types (text, image, file, resource, error) for flexible output representation
    • Strict output type checking allow List or Seqence of Content Types Objects
  • Dynamic Schema Generation:

    • Input model needs to be defined as child of SimpleInputModel Type and assign to input_model attribute inside SimpleTool - them magic begins and automaticly:
      • Automatically creates output JSON schemas (output_schema / output_model) based on the defined run method typing
      • Automatically creates input JSON schemas (input_schema) based on the input model
  • Execution Models:

    • Synchronous Execution: Default mode with the standard run method
    • Asynchronous Execution: Available via the simpletool.asyncio module with the AsyncSimpleTool class
    • Configurable timeout management
    • Context manager for easy resource management release
  • Environment Integration:

    • Easy retrieval of environment variables via the env parameter
    • Support for random API key selection from provided list of API keys

Content Types

Simpletool defines several content types to standardize tool inputs and outputs:

  • TextContent: Represents text-based content
  • ImageContent: Handles base64 encoded images with optional metadata
  • FileContent: Represents files with base64 encoded data
  • ResourceContent: Manages external resource references
  • ErrorContent: Provides structured error reporting
  • BoolContents: Simple boolean content type

📦 Installation

Install the package using pip:

pip install simpletool

🔄 Quick Start

🛠️ Creating a Synchronous Tool

from simpletool import SimpleTool, SimpleInputModel, Sequence, Field
from simpletool.types import TextContent

class InputModel(SimpleInputModel):
    name: str = Field(description="Name to greet")

class MyTool(SimpleTool):
    name = "greeting_tool"
    description = "A simple greeting tool"
    input_model = InputModel

    def run(self, arguments: dict) -> Sequence[TextContent]:
        # Validation and parsing of input arguments
        arg: InputModel = InputModel(**arguments)

        return [TextContent(text=f"Hello, {arg.name}!")]

🛠️ Creating an Asynchronous Tool

from simpletool.asyncio import AsyncSimpleTool
from simpletool import SimpleInputModel, Sequence, Field
from simpletool.types import TextContent

class InputModel(SimpleInputModel):
    name: str = Field(description="Name to greet")

class MyAsyncTool(AsyncSimpleTool):
    name = "greeting_tool"
    description = "A simple greeting tool"
    input_model = InputModel

    async def run(self, arguments: dict) -> Sequence[TextContent]:
        # Validation and parsing of input arguments
        arg: InputModel = InputModel(**arguments)

        return [TextContent(text=f"Hello, {arg.name}!")]

📝 Development Guidelines

  • Inherit Tool model from SimpleTool (or AsyncSimpleTool for async tools)
  • Define an input_model using Pydantic (SimpleInputModel)
  • Implement the run method (synchronous or asynchronous depending on your base class)
  • Return a list/sequence of content types
  • Use the env parameter for environment variables

📝 Contributing

Contributions are welcome! Please follow Python best practices and maintain the existing code style.

📄 License

This project is licensed under the MIT License.

📞 Contact

Contributions are welcome! Please submit a pull request with your changes.

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

simpletool-0.0.32.tar.gz (29.3 kB view details)

Uploaded Source

Built Distribution

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

simpletool-0.0.32-py2.py3-none-any.whl (23.5 kB view details)

Uploaded Python 2Python 3

File details

Details for the file simpletool-0.0.32.tar.gz.

File metadata

  • Download URL: simpletool-0.0.32.tar.gz
  • Upload date:
  • Size: 29.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for simpletool-0.0.32.tar.gz
Algorithm Hash digest
SHA256 2d95fd48c095ce9c97439bd9934cedcb04acc9c509d60f92c7f3a048b20e0b4d
MD5 78824d05e2840dfcacf76c1b5dd876fb
BLAKE2b-256 9c683f204fcea84366f1456b32dfc0b5a1ab45c0ac45c8c2c453a57fc876906e

See more details on using hashes here.

Provenance

The following attestation bundles were made for simpletool-0.0.32.tar.gz:

Publisher: publish.yml on getsimpletool/simpletool-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file simpletool-0.0.32-py2.py3-none-any.whl.

File metadata

  • Download URL: simpletool-0.0.32-py2.py3-none-any.whl
  • Upload date:
  • Size: 23.5 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for simpletool-0.0.32-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 94698736b882ff67e5f2a73e2f9cf5e362a49cc142dd671cd21a2c65acac6d32
MD5 c7f869bfae95c032fd69188da2b29f23
BLAKE2b-256 a141c864f9a355c3ccf4e8c485cb8f0f99679b98bb721ab04be5b633a6729600

See more details on using hashes here.

Provenance

The following attestation bundles were made for simpletool-0.0.32-py2.py3-none-any.whl:

Publisher: publish.yml on getsimpletool/simpletool-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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