| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- package ali
- import (
- "encoding/json"
- "io"
- "net/http"
- "one-api/common"
- "one-api/dto"
- relaycommon "one-api/relay/common"
- "one-api/types"
- "github.com/gin-gonic/gin"
- )
- func ConvertRerankRequest(request dto.RerankRequest) *AliRerankRequest {
- returnDocuments := request.ReturnDocuments
- if returnDocuments == nil {
- t := true
- returnDocuments = &t
- }
- return &AliRerankRequest{
- Model: request.Model,
- Input: AliRerankInput{
- Query: request.Query,
- Documents: request.Documents,
- },
- Parameters: AliRerankParameters{
- TopN: &request.TopN,
- ReturnDocuments: returnDocuments,
- },
- }
- }
- func RerankHandler(c *gin.Context, resp *http.Response, info *relaycommon.RelayInfo) (*types.NewAPIError, *dto.Usage) {
- responseBody, err := io.ReadAll(resp.Body)
- if err != nil {
- return types.NewError(err, types.ErrorCodeReadResponseBodyFailed), nil
- }
- common.CloseResponseBodyGracefully(resp)
- var aliResponse AliRerankResponse
- err = json.Unmarshal(responseBody, &aliResponse)
- if err != nil {
- return types.NewError(err, types.ErrorCodeBadResponseBody), nil
- }
- if aliResponse.Code != "" {
- return types.WithOpenAIError(types.OpenAIError{
- Message: aliResponse.Message,
- Type: aliResponse.Code,
- Param: aliResponse.RequestId,
- Code: aliResponse.Code,
- }, resp.StatusCode), nil
- }
- usage := dto.Usage{
- PromptTokens: aliResponse.Usage.TotalTokens,
- CompletionTokens: 0,
- TotalTokens: aliResponse.Usage.TotalTokens,
- }
- rerankResponse := dto.RerankResponse{
- Results: aliResponse.Output.Results,
- Usage: usage,
- }
- jsonResponse, err := json.Marshal(rerankResponse)
- if err != nil {
- return types.NewError(err, types.ErrorCodeBadResponseBody), nil
- }
- c.Writer.Header().Set("Content-Type", "application/json")
- c.Writer.WriteHeader(resp.StatusCode)
- c.Writer.Write(jsonResponse)
- return nil, &usage
- }
|