rerank.go 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. package ali
  2. import (
  3. "encoding/json"
  4. "io"
  5. "net/http"
  6. "one-api/common"
  7. "one-api/dto"
  8. relaycommon "one-api/relay/common"
  9. "one-api/types"
  10. "github.com/gin-gonic/gin"
  11. )
  12. func ConvertRerankRequest(request dto.RerankRequest) *AliRerankRequest {
  13. returnDocuments := request.ReturnDocuments
  14. if returnDocuments == nil {
  15. t := true
  16. returnDocuments = &t
  17. }
  18. return &AliRerankRequest{
  19. Model: request.Model,
  20. Input: AliRerankInput{
  21. Query: request.Query,
  22. Documents: request.Documents,
  23. },
  24. Parameters: AliRerankParameters{
  25. TopN: &request.TopN,
  26. ReturnDocuments: returnDocuments,
  27. },
  28. }
  29. }
  30. func RerankHandler(c *gin.Context, resp *http.Response, info *relaycommon.RelayInfo) (*types.NewAPIError, *dto.Usage) {
  31. responseBody, err := io.ReadAll(resp.Body)
  32. if err != nil {
  33. return types.NewError(err, types.ErrorCodeReadResponseBodyFailed), nil
  34. }
  35. common.CloseResponseBodyGracefully(resp)
  36. var aliResponse AliRerankResponse
  37. err = json.Unmarshal(responseBody, &aliResponse)
  38. if err != nil {
  39. return types.NewError(err, types.ErrorCodeBadResponseBody), nil
  40. }
  41. if aliResponse.Code != "" {
  42. return types.WithOpenAIError(types.OpenAIError{
  43. Message: aliResponse.Message,
  44. Type: aliResponse.Code,
  45. Param: aliResponse.RequestId,
  46. Code: aliResponse.Code,
  47. }, resp.StatusCode), nil
  48. }
  49. usage := dto.Usage{
  50. PromptTokens: aliResponse.Usage.TotalTokens,
  51. CompletionTokens: 0,
  52. TotalTokens: aliResponse.Usage.TotalTokens,
  53. }
  54. rerankResponse := dto.RerankResponse{
  55. Results: aliResponse.Output.Results,
  56. Usage: usage,
  57. }
  58. jsonResponse, err := json.Marshal(rerankResponse)
  59. if err != nil {
  60. return types.NewError(err, types.ErrorCodeBadResponseBody), nil
  61. }
  62. c.Writer.Header().Set("Content-Type", "application/json")
  63. c.Writer.WriteHeader(resp.StatusCode)
  64. c.Writer.Write(jsonResponse)
  65. return nil, &usage
  66. }