2024-01-21 15:21:42 +00:00
|
|
|
package zhipu
|
|
|
|
|
|
|
|
import (
|
2024-02-17 16:15:31 +00:00
|
|
|
"errors"
|
|
|
|
"fmt"
|
2024-01-21 15:21:42 +00:00
|
|
|
"github.com/gin-gonic/gin"
|
2024-02-17 16:15:31 +00:00
|
|
|
"github.com/songquanpeng/one-api/relay/channel"
|
2024-03-01 19:05:25 +00:00
|
|
|
"github.com/songquanpeng/one-api/relay/channel/openai"
|
2024-02-17 16:15:31 +00:00
|
|
|
"github.com/songquanpeng/one-api/relay/model"
|
2024-04-05 16:44:33 +00:00
|
|
|
"github.com/songquanpeng/one-api/relay/relaymode"
|
2024-02-17 16:15:31 +00:00
|
|
|
"github.com/songquanpeng/one-api/relay/util"
|
|
|
|
"io"
|
2024-03-16 05:39:30 +00:00
|
|
|
"math"
|
2024-01-21 15:21:42 +00:00
|
|
|
"net/http"
|
2024-03-01 19:05:25 +00:00
|
|
|
"strings"
|
2024-01-21 15:21:42 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type Adaptor struct {
|
2024-03-01 19:05:25 +00:00
|
|
|
APIVersion string
|
2024-01-21 15:21:42 +00:00
|
|
|
}
|
|
|
|
|
2024-02-18 08:17:19 +00:00
|
|
|
func (a *Adaptor) Init(meta *util.RelayMeta) {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2024-03-01 19:05:25 +00:00
|
|
|
func (a *Adaptor) SetVersionByModeName(modelName string) {
|
|
|
|
if strings.HasPrefix(modelName, "glm-") {
|
|
|
|
a.APIVersion = "v4"
|
|
|
|
} else {
|
|
|
|
a.APIVersion = "v3"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-02-17 16:15:31 +00:00
|
|
|
func (a *Adaptor) GetRequestURL(meta *util.RelayMeta) (string, error) {
|
2024-04-05 16:30:08 +00:00
|
|
|
switch meta.Mode {
|
2024-04-05 16:44:33 +00:00
|
|
|
case relaymode.ImagesGenerations:
|
2024-04-05 16:30:08 +00:00
|
|
|
return fmt.Sprintf("%s/api/paas/v4/images/generations", meta.BaseURL), nil
|
2024-04-05 16:44:33 +00:00
|
|
|
case relaymode.Embeddings:
|
2024-04-05 16:30:08 +00:00
|
|
|
return fmt.Sprintf("%s/api/paas/v4/embeddings", meta.BaseURL), nil
|
|
|
|
}
|
2024-03-01 19:05:25 +00:00
|
|
|
a.SetVersionByModeName(meta.ActualModelName)
|
|
|
|
if a.APIVersion == "v4" {
|
|
|
|
return fmt.Sprintf("%s/api/paas/v4/chat/completions", meta.BaseURL), nil
|
|
|
|
}
|
2024-02-17 16:15:31 +00:00
|
|
|
method := "invoke"
|
|
|
|
if meta.IsStream {
|
|
|
|
method = "sse-invoke"
|
|
|
|
}
|
|
|
|
return fmt.Sprintf("%s/api/paas/v3/model-api/%s/%s", meta.BaseURL, meta.ActualModelName, method), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a *Adaptor) SetupRequestHeader(c *gin.Context, req *http.Request, meta *util.RelayMeta) error {
|
|
|
|
channel.SetupCommonRequestHeader(c, req, meta)
|
|
|
|
token := GetToken(meta.APIKey)
|
|
|
|
req.Header.Set("Authorization", token)
|
2024-01-21 15:21:42 +00:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2024-02-17 16:15:31 +00:00
|
|
|
func (a *Adaptor) ConvertRequest(c *gin.Context, relayMode int, request *model.GeneralOpenAIRequest) (any, error) {
|
|
|
|
if request == nil {
|
|
|
|
return nil, errors.New("request is nil")
|
|
|
|
}
|
2024-04-04 15:32:59 +00:00
|
|
|
switch relayMode {
|
2024-04-05 16:44:33 +00:00
|
|
|
case relaymode.Embeddings:
|
2024-04-04 15:32:59 +00:00
|
|
|
baiduEmbeddingRequest := ConvertEmbeddingRequest(*request)
|
|
|
|
return baiduEmbeddingRequest, nil
|
|
|
|
default:
|
|
|
|
// TopP (0.0, 1.0)
|
|
|
|
request.TopP = math.Min(0.99, request.TopP)
|
|
|
|
request.TopP = math.Max(0.01, request.TopP)
|
|
|
|
|
|
|
|
// Temperature (0.0, 1.0)
|
|
|
|
request.Temperature = math.Min(0.99, request.Temperature)
|
|
|
|
request.Temperature = math.Max(0.01, request.Temperature)
|
|
|
|
a.SetVersionByModeName(request.Model)
|
|
|
|
if a.APIVersion == "v4" {
|
|
|
|
return request, nil
|
|
|
|
}
|
|
|
|
return ConvertRequest(*request), nil
|
2024-03-01 19:05:25 +00:00
|
|
|
}
|
2024-02-17 16:15:31 +00:00
|
|
|
}
|
|
|
|
|
2024-04-05 10:09:54 +00:00
|
|
|
func (a *Adaptor) ConvertImageRequest(request *model.ImageRequest) (any, error) {
|
|
|
|
if request == nil {
|
|
|
|
return nil, errors.New("request is nil")
|
|
|
|
}
|
2024-04-05 16:30:08 +00:00
|
|
|
newRequest := ImageRequest{
|
|
|
|
Model: request.Model,
|
|
|
|
Prompt: request.Prompt,
|
|
|
|
UserId: request.User,
|
|
|
|
}
|
|
|
|
return newRequest, nil
|
2024-04-05 10:09:54 +00:00
|
|
|
}
|
|
|
|
|
2024-02-17 16:15:31 +00:00
|
|
|
func (a *Adaptor) DoRequest(c *gin.Context, meta *util.RelayMeta, requestBody io.Reader) (*http.Response, error) {
|
|
|
|
return channel.DoRequestHelper(a, c, meta, requestBody)
|
|
|
|
}
|
|
|
|
|
2024-03-01 19:05:25 +00:00
|
|
|
func (a *Adaptor) DoResponseV4(c *gin.Context, resp *http.Response, meta *util.RelayMeta) (usage *model.Usage, err *model.ErrorWithStatusCode) {
|
|
|
|
if meta.IsStream {
|
|
|
|
err, _, usage = openai.StreamHandler(c, resp, meta.Mode)
|
|
|
|
} else {
|
|
|
|
err, usage = openai.Handler(c, resp, meta.PromptTokens, meta.ActualModelName)
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-02-17 16:15:31 +00:00
|
|
|
func (a *Adaptor) DoResponse(c *gin.Context, resp *http.Response, meta *util.RelayMeta) (usage *model.Usage, err *model.ErrorWithStatusCode) {
|
2024-04-05 16:30:08 +00:00
|
|
|
switch meta.Mode {
|
2024-04-05 16:44:33 +00:00
|
|
|
case relaymode.Embeddings:
|
2024-04-05 16:30:08 +00:00
|
|
|
err, usage = EmbeddingsHandler(c, resp)
|
|
|
|
return
|
2024-04-05 16:44:33 +00:00
|
|
|
case relaymode.ImagesGenerations:
|
2024-04-05 16:30:08 +00:00
|
|
|
err, usage = openai.ImageHandler(c, resp)
|
|
|
|
return
|
|
|
|
}
|
2024-03-01 19:05:25 +00:00
|
|
|
if a.APIVersion == "v4" {
|
|
|
|
return a.DoResponseV4(c, resp, meta)
|
|
|
|
}
|
2024-02-17 16:15:31 +00:00
|
|
|
if meta.IsStream {
|
|
|
|
err, usage = StreamHandler(c, resp)
|
|
|
|
} else {
|
2024-04-05 16:44:33 +00:00
|
|
|
if meta.Mode == relaymode.Embeddings {
|
2024-04-04 15:32:59 +00:00
|
|
|
err, usage = EmbeddingsHandler(c, resp)
|
|
|
|
} else {
|
|
|
|
err, usage = Handler(c, resp)
|
|
|
|
}
|
2024-02-17 16:15:31 +00:00
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-04-04 15:32:59 +00:00
|
|
|
func ConvertEmbeddingRequest(request model.GeneralOpenAIRequest) *EmbeddingRequest {
|
|
|
|
return &EmbeddingRequest{
|
|
|
|
Model: "embedding-2",
|
|
|
|
Input: request.Input.(string),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-02-17 16:15:31 +00:00
|
|
|
func (a *Adaptor) GetModelList() []string {
|
|
|
|
return ModelList
|
2024-01-21 15:21:42 +00:00
|
|
|
}
|
|
|
|
|
2024-02-17 16:15:31 +00:00
|
|
|
func (a *Adaptor) GetChannelName() string {
|
|
|
|
return "zhipu"
|
2024-01-21 15:21:42 +00:00
|
|
|
}
|