audio_handler.go 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. package relay
  2. import (
  3. "errors"
  4. "fmt"
  5. "net/http"
  6. "github.com/QuantumNous/new-api/common"
  7. "github.com/QuantumNous/new-api/dto"
  8. relaycommon "github.com/QuantumNous/new-api/relay/common"
  9. "github.com/QuantumNous/new-api/relay/helper"
  10. "github.com/QuantumNous/new-api/service"
  11. "github.com/QuantumNous/new-api/types"
  12. "github.com/gin-gonic/gin"
  13. )
  14. func AudioHelper(c *gin.Context, info *relaycommon.RelayInfo) (newAPIError *types.NewAPIError) {
  15. info.InitChannelMeta(c)
  16. audioReq, ok := info.Request.(*dto.AudioRequest)
  17. if !ok {
  18. return types.NewError(errors.New("invalid request type"), types.ErrorCodeInvalidRequest, types.ErrOptionWithSkipRetry())
  19. }
  20. request, err := common.DeepCopy(audioReq)
  21. if err != nil {
  22. return types.NewError(fmt.Errorf("failed to copy request to AudioRequest: %w", err), types.ErrorCodeInvalidRequest, types.ErrOptionWithSkipRetry())
  23. }
  24. err = helper.ModelMappedHelper(c, info, request)
  25. if err != nil {
  26. return types.NewError(err, types.ErrorCodeChannelModelMappedError, types.ErrOptionWithSkipRetry())
  27. }
  28. adaptor := GetAdaptor(info.ApiType)
  29. if adaptor == nil {
  30. return types.NewError(fmt.Errorf("invalid api type: %d", info.ApiType), types.ErrorCodeInvalidApiType, types.ErrOptionWithSkipRetry())
  31. }
  32. adaptor.Init(info)
  33. ioReader, err := adaptor.ConvertAudioRequest(c, info, *request)
  34. if err != nil {
  35. return types.NewError(err, types.ErrorCodeConvertRequestFailed, types.ErrOptionWithSkipRetry())
  36. }
  37. resp, err := adaptor.DoRequest(c, info, ioReader)
  38. if err != nil {
  39. return types.NewError(err, types.ErrorCodeDoRequestFailed)
  40. }
  41. statusCodeMappingStr := c.GetString("status_code_mapping")
  42. var httpResp *http.Response
  43. if resp != nil {
  44. httpResp = resp.(*http.Response)
  45. if httpResp.StatusCode != http.StatusOK {
  46. newAPIError = service.RelayErrorHandler(c.Request.Context(), httpResp, false)
  47. // reset status code 重置状态码
  48. service.ResetStatusCode(newAPIError, statusCodeMappingStr)
  49. return newAPIError
  50. }
  51. }
  52. usage, newAPIError := adaptor.DoResponse(c, httpResp, info)
  53. if newAPIError != nil {
  54. // reset status code 重置状态码
  55. service.ResetStatusCode(newAPIError, statusCodeMappingStr)
  56. return newAPIError
  57. }
  58. postConsumeQuota(c, info, usage.(*dto.Usage), "")
  59. return nil
  60. }