mirascope.core.openai.tool | Mirascope
MirascopeLilypad

mirascope.core.openai.tool

Module tool

The OpenAITool class for easy tool usage with OpenAI LLM calls.

Usage

Class GenerateOpenAIStrictToolJsonSchema

Bases:

GenerateJsonSchemaNoTitles

Class OpenAIToolConfig

A tool configuration for OpenAI-specific features.

Bases:

ToolConfig

Attributes

NameTypeDescription
strictbool-

Class OpenAITool

A class for defining tools for OpenAI LLM calls.

Example:

from mirascope.core import prompt_template
from mirascope.core.openai import openai_call


def format_book(title: str, author: str) -> str:
    return f"{title} by {author}"


@openai_call("gpt-4o-mini", tools=[format_book])
def recommend_book(genre: str) -> str:
    return f"Recommend a {genre} book"


response = recommend_book("fantasy")
if tool := response.tool:  # returns an `OpenAITool` instance
    print(tool.call())

Bases:

BaseTool

Attributes

NameTypeDescription
tool_callSkipJsonSchema[ChatCompletionMessageToolCall]-

Function tool_schema

Constructs a JSON Schema tool schema from the BaseModel schema defined.

Example:

from mirascope.core.openai import OpenAITool


def format_book(title: str, author: str) -> str:
    return f"{title} by {author}"


tool_type = OpenAITool.type_from_fn(format_book)
print(tool_type.tool_schema())  # prints the OpenAI-specific tool schema

Parameters

NameTypeDescription
clsAny-

Returns

TypeDescription
ChatCompletionToolParam-

Function from_tool_call

Constructs an OpenAITool instance from a tool_call.

Parameters

NameTypeDescription
clsAny-
tool_callChatCompletionMessageToolCallThe OpenAI tool call from which to construct this tool instance.
allow_partial= FalseboolWhether to allow partial JSON data.

Returns

TypeDescription
OpenAITool-