| 123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- package siliconflow
- import (
- "encoding/json"
- "io"
- "net/http"
- "github.com/QuantumNous/new-api/dto"
- relaycommon "github.com/QuantumNous/new-api/relay/common"
- "github.com/QuantumNous/new-api/service"
- "github.com/QuantumNous/new-api/types"
- "github.com/gin-gonic/gin"
- )
- func siliconflowRerankHandler(c *gin.Context, info *relaycommon.RelayInfo, resp *http.Response) (*dto.Usage, *types.NewAPIError) {
- responseBody, err := io.ReadAll(resp.Body)
- if err != nil {
- return nil, types.NewOpenAIError(err, types.ErrorCodeReadResponseBodyFailed, http.StatusInternalServerError)
- }
- service.CloseResponseBodyGracefully(resp)
- var siliconflowResp SFRerankResponse
- err = json.Unmarshal(responseBody, &siliconflowResp)
- if err != nil {
- return nil, types.NewOpenAIError(err, types.ErrorCodeBadResponseBody, http.StatusInternalServerError)
- }
- usage := &dto.Usage{
- PromptTokens: siliconflowResp.Meta.Tokens.InputTokens,
- CompletionTokens: siliconflowResp.Meta.Tokens.OutputTokens,
- TotalTokens: siliconflowResp.Meta.Tokens.InputTokens + siliconflowResp.Meta.Tokens.OutputTokens,
- }
- rerankResp := &dto.RerankResponse{
- Results: siliconflowResp.Results,
- Usage: *usage,
- }
- jsonResponse, err := json.Marshal(rerankResp)
- if err != nil {
- return nil, types.NewError(err, types.ErrorCodeBadResponseBody)
- }
- c.Writer.Header().Set("Content-Type", "application/json")
- c.Writer.WriteHeader(resp.StatusCode)
- service.IOCopyBytesGracefully(c, resp, jsonResponse)
- return usage, nil
- }
|