rerank.go 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. package ali
  2. import (
  3. "encoding/json"
  4. "io"
  5. "net/http"
  6. "github.com/QuantumNous/new-api/dto"
  7. relaycommon "github.com/QuantumNous/new-api/relay/common"
  8. "github.com/QuantumNous/new-api/service"
  9. "github.com/QuantumNous/new-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.NewOpenAIError(err, types.ErrorCodeReadResponseBodyFailed, http.StatusInternalServerError), nil
  34. }
  35. service.CloseResponseBodyGracefully(resp)
  36. var aliResponse AliRerankResponse
  37. err = json.Unmarshal(responseBody, &aliResponse)
  38. if err != nil {
  39. return types.NewOpenAIError(err, types.ErrorCodeBadResponseBody, http.StatusInternalServerError), 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. }