ai-gateway/providers/openai/chat.go

83 lines
2.5 KiB
Go
Raw Permalink Normal View History

package openai
2023-11-28 10:32:26 +00:00
import (
"net/http"
"one-api/common"
"one-api/types"
)
func (c *OpenAIProviderChatResponse) ResponseHandler(resp *http.Response) (OpenAIResponse any, errWithCode *types.OpenAIErrorWithStatusCode) {
2023-11-28 10:32:26 +00:00
if c.Error.Type != "" {
errWithCode = &types.OpenAIErrorWithStatusCode{
2023-11-28 10:32:26 +00:00
OpenAIError: c.Error,
StatusCode: resp.StatusCode,
}
return
}
return nil, nil
2023-11-28 10:32:26 +00:00
}
func (c *OpenAIProviderChatStreamResponse) responseStreamHandler() (responseText string) {
2023-11-28 10:32:26 +00:00
for _, choice := range c.Choices {
responseText += choice.Delta.Content
}
return
}
func (p *OpenAIProvider) ChatAction(request *types.ChatCompletionRequest, isModelMapped bool, promptTokens int) (usage *types.Usage, errWithCode *types.OpenAIErrorWithStatusCode) {
2023-12-01 09:20:22 +00:00
requestBody, err := p.GetRequestBody(&request, isModelMapped)
2023-11-28 10:32:26 +00:00
if err != nil {
2023-12-01 19:28:18 +00:00
return nil, common.ErrorWrapper(err, "json_marshal_failed", http.StatusInternalServerError)
2023-11-28 10:32:26 +00:00
}
fullRequestURL := p.GetFullRequestURL(p.ChatCompletions, request.Model)
headers := p.GetRequestHeaders()
if request.Stream && headers["Accept"] == "" {
headers["Accept"] = "text/event-stream"
}
client := common.NewClient()
req, err := client.NewRequest(p.Context.Request.Method, fullRequestURL, common.WithBody(requestBody), common.WithHeader(headers))
if err != nil {
2023-12-01 19:28:18 +00:00
return nil, common.ErrorWrapper(err, "new_request_failed", http.StatusInternalServerError)
2023-11-28 10:32:26 +00:00
}
if request.Stream {
openAIProviderChatStreamResponse := &OpenAIProviderChatStreamResponse{}
var textResponse string
errWithCode, textResponse = p.sendStreamRequest(req, openAIProviderChatStreamResponse)
if errWithCode != nil {
2023-11-28 10:32:26 +00:00
return
}
usage = &types.Usage{
PromptTokens: promptTokens,
CompletionTokens: common.CountTokenText(textResponse, request.Model),
TotalTokens: promptTokens + common.CountTokenText(textResponse, request.Model),
}
} else {
openAIProviderChatResponse := &OpenAIProviderChatResponse{}
errWithCode = p.SendRequest(req, openAIProviderChatResponse, true)
if errWithCode != nil {
2023-11-28 10:32:26 +00:00
return
}
usage = openAIProviderChatResponse.Usage
if usage.TotalTokens == 0 {
completionTokens := 0
for _, choice := range openAIProviderChatResponse.Choices {
completionTokens += common.CountTokenText(choice.Message.StringContent(), openAIProviderChatResponse.Model)
}
usage = &types.Usage{
PromptTokens: promptTokens,
CompletionTokens: completionTokens,
TotalTokens: promptTokens + completionTokens,
}
}
}
return
}