log_info_generate.go 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. package service
  2. import (
  3. "github.com/gin-gonic/gin"
  4. "one-api/dto"
  5. relaycommon "one-api/relay/common"
  6. )
  7. func GenerateTextOtherInfo(ctx *gin.Context, relayInfo *relaycommon.RelayInfo, modelRatio, groupRatio, completionRatio, modelPrice float64) map[string]interface{} {
  8. other := make(map[string]interface{})
  9. other["model_ratio"] = modelRatio
  10. other["group_ratio"] = groupRatio
  11. other["completion_ratio"] = completionRatio
  12. other["model_price"] = modelPrice
  13. other["frt"] = float64(relayInfo.FirstResponseTime.UnixMilli() - relayInfo.StartTime.UnixMilli())
  14. if relayInfo.ReasoningEffort != "" {
  15. other["reasoning_effort"] = relayInfo.ReasoningEffort
  16. }
  17. adminInfo := make(map[string]interface{})
  18. adminInfo["use_channel"] = ctx.GetStringSlice("use_channel")
  19. other["admin_info"] = adminInfo
  20. return other
  21. }
  22. func GenerateWssOtherInfo(ctx *gin.Context, relayInfo *relaycommon.RelayInfo, usage *dto.RealtimeUsage, modelRatio, groupRatio, completionRatio, audioRatio, audioCompletionRatio, modelPrice float64) map[string]interface{} {
  23. info := GenerateTextOtherInfo(ctx, relayInfo, modelRatio, groupRatio, completionRatio, modelPrice)
  24. info["ws"] = true
  25. info["audio_input"] = usage.InputTokenDetails.AudioTokens
  26. info["audio_output"] = usage.OutputTokenDetails.AudioTokens
  27. info["text_input"] = usage.InputTokenDetails.TextTokens
  28. info["text_output"] = usage.OutputTokenDetails.TextTokens
  29. info["audio_ratio"] = audioRatio
  30. info["audio_completion_ratio"] = audioCompletionRatio
  31. return info
  32. }
  33. func GenerateAudioOtherInfo(ctx *gin.Context, relayInfo *relaycommon.RelayInfo, usage *dto.Usage, modelRatio, groupRatio, completionRatio, audioRatio, audioCompletionRatio, modelPrice float64) map[string]interface{} {
  34. info := GenerateTextOtherInfo(ctx, relayInfo, modelRatio, groupRatio, completionRatio, modelPrice)
  35. info["audio"] = true
  36. info["audio_input"] = usage.PromptTokensDetails.AudioTokens
  37. info["audio_output"] = usage.CompletionTokenDetails.AudioTokens
  38. info["text_input"] = usage.PromptTokensDetails.TextTokens
  39. info["text_output"] = usage.CompletionTokenDetails.TextTokens
  40. info["audio_ratio"] = audioRatio
  41. info["audio_completion_ratio"] = audioCompletionRatio
  42. return info
  43. }