rerank.go 2.2 KB

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