openai

package
v0.0.5 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 10, 2025 License: MIT Imports: 6 Imported by: 0

Documentation

Index

Constants

View Source
const (
	APITypeOpenAI  APIType = APIType(openai.APITypeOpenAI)
	APITypeAzure           = APIType(openai.APITypeAzure)
	APITypeAzureAD         = APIType(openai.APITypeAzureAD)
)
View Source
const DefaultAPIVersion = "2023-05-15"

Variables

View Source
var (
	ErrEmptyResponse              = fmt.Errorf("no response")
	ErrMissingToken               = fmt.Errorf("missing the OpenAI API key, set it in the OPENAI_API_KEY environment variable")
	ErrMissingAzureModel          = fmt.Errorf("model needs to be provided when using Azure API")
	ErrMissingAzureEmbeddingModel = fmt.Errorf("embeddings model needs to be provided when using Azure API")
	ErrUnexpectedResponseLength   = fmt.Errorf("unexpected length of response")
)
View Source
var ResponseFormatJSON = &ResponseFormat{Type: "json_object"}

ResponseFormatJSON is the JSON response format.

Functions

func ExtractToolParts

func ExtractToolParts(msg *openai.ChatMessage) ([]llm.ContentPart, []llm.ToolCall)

ExtractToolParts extracts the tool parts from a message.

Types

type APIType

type APIType openai.APIType

type Option

type Option func(*options)

Option is a functional option for the OpenAI client.

func WithAPIType

func WithAPIType(apiType APIType) Option

WithAPIType passes the api type to the client. If not set, the default value is APITypeOpenAI.

func WithAPIVersion

func WithAPIVersion(apiVersion string) Option

WithAPIVersion passes the api version to the client. If not set, the default value is DefaultAPIVersion.

func WithBaseURL

func WithBaseURL(baseURL string) Option

WithBaseURL passes the OpenAI base url to the client. If not set, the base url is read from the OPENAI_BASE_URL environment variable. If still not set in ENV VAR OPENAI_BASE_URL, then the default value is https://api.openai.com/v1 is used.

func WithEmbeddingModel

func WithEmbeddingModel(embeddingModel string) Option

WithEmbeddingModel passes the OpenAI model to the client. Required when ApiType is Azure.

func WithHTTPClient

func WithHTTPClient(client openai.Doer) Option

WithHTTPClient allows setting a custom HTTP client. If not set, the default value is http.DefaultClient.

func WithHooks

func WithHooks(hooks llm.ProviderHooks) Option

WithHooks allows setting a custom Callback Handler.

func WithModel

func WithModel(model string) Option

WithModel passes the OpenAI model to the client. If not set, the model is read from the OPENAI_MODEL environment variable. Required when ApiType is Azure.

func WithOrganization

func WithOrganization(organization string) Option

WithOrganization passes the OpenAI organization to the client. If not set, the organization is read from the OPENAI_ORGANIZATION.

func WithResponseFormat

func WithResponseFormat(responseFormat *ResponseFormat) Option

WithResponseFormat allows setting a custom response format.

func WithToken

func WithToken(token string) Option

WithToken passes the OpenAI API token to the client. If not set, the token is read from the OPENAI_API_KEY environment variable.

type Provider

type Provider struct {
	// contains filtered or unexported fields
}

Provider is an llm.Provider implementation for OpenAI.

func New

func New(opts ...Option) (*Provider, error)

New creates a new OpenAI llm.Provider implementation.

func (*Provider) Call

func (o *Provider) Call(ctx context.Context, prompt string, options ...llm.ContentOption) (string, error)

Call requests a completion for the given prompt.

func (*Provider) CreateEmbedding

func (o *Provider) CreateEmbedding(ctx context.Context, inputTexts []string) ([][]float32, error)

CreateEmbedding creates embeddings for the given input texts.

func (*Provider) GenerateContent

func (o *Provider) GenerateContent(ctx context.Context, messages []llm.Message, options ...llm.ContentOption) (*llm.ContentResponse, error)

GenerateContent implements the llm.Provider interface.

type ResponseFormat

type ResponseFormat = openai.ResponseFormat

ResponseFormat is the response format for the OpenAI client.

type ResponseFormatJSONSchema

type ResponseFormatJSONSchema = openai.ResponseFormatJSONSchema

ResponseFormatJSONSchema is the JSON Schema response format in structured output.

type ResponseFormatJSONSchemaProperty

type ResponseFormatJSONSchemaProperty = openai.ResponseFormatJSONSchemaProperty

ResponseFormatJSONSchemaProperty is the JSON Schema property in structured output.

Directories

Path Synopsis
internal

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL