log_info_generate.go 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. package service
  2. import (
  3. "one-api/dto"
  4. relaycommon "one-api/relay/common"
  5. "one-api/relay/helper"
  6. "github.com/gin-gonic/gin"
  7. )
  8. func GenerateTextOtherInfo(ctx *gin.Context, relayInfo *relaycommon.RelayInfo, modelRatio, groupRatio, completionRatio float64,
  9. cacheTokens int, cacheRatio float64, modelPrice float64, userGroupRatio float64) map[string]interface{} {
  10. other := make(map[string]interface{})
  11. other["model_ratio"] = modelRatio
  12. other["group_ratio"] = groupRatio
  13. other["completion_ratio"] = completionRatio
  14. other["cache_tokens"] = cacheTokens
  15. other["cache_ratio"] = cacheRatio
  16. other["model_price"] = modelPrice
  17. other["user_group_ratio"] = userGroupRatio
  18. other["frt"] = float64(relayInfo.FirstResponseTime.UnixMilli() - relayInfo.StartTime.UnixMilli())
  19. if relayInfo.ReasoningEffort != "" {
  20. other["reasoning_effort"] = relayInfo.ReasoningEffort
  21. }
  22. if relayInfo.IsModelMapped {
  23. other["is_model_mapped"] = true
  24. other["upstream_model_name"] = relayInfo.UpstreamModelName
  25. }
  26. adminInfo := make(map[string]interface{})
  27. adminInfo["use_channel"] = ctx.GetStringSlice("use_channel")
  28. other["admin_info"] = adminInfo
  29. return other
  30. }
  31. func GenerateWssOtherInfo(ctx *gin.Context, relayInfo *relaycommon.RelayInfo, usage *dto.RealtimeUsage, modelRatio, groupRatio, completionRatio, audioRatio, audioCompletionRatio, modelPrice, userGroupRatio float64) map[string]interface{} {
  32. info := GenerateTextOtherInfo(ctx, relayInfo, modelRatio, groupRatio, completionRatio, 0, 0.0, modelPrice, userGroupRatio)
  33. info["ws"] = true
  34. info["audio_input"] = usage.InputTokenDetails.AudioTokens
  35. info["audio_output"] = usage.OutputTokenDetails.AudioTokens
  36. info["text_input"] = usage.InputTokenDetails.TextTokens
  37. info["text_output"] = usage.OutputTokenDetails.TextTokens
  38. info["audio_ratio"] = audioRatio
  39. info["audio_completion_ratio"] = audioCompletionRatio
  40. return info
  41. }
  42. func GenerateAudioOtherInfo(ctx *gin.Context, relayInfo *relaycommon.RelayInfo, usage *dto.Usage, modelRatio, groupRatio, completionRatio, audioRatio, audioCompletionRatio, modelPrice, userGroupRatio float64) map[string]interface{} {
  43. info := GenerateTextOtherInfo(ctx, relayInfo, modelRatio, groupRatio, completionRatio, 0, 0.0, modelPrice, userGroupRatio)
  44. info["audio"] = true
  45. info["audio_input"] = usage.PromptTokensDetails.AudioTokens
  46. info["audio_output"] = usage.CompletionTokenDetails.AudioTokens
  47. info["text_input"] = usage.PromptTokensDetails.TextTokens
  48. info["text_output"] = usage.CompletionTokenDetails.TextTokens
  49. info["audio_ratio"] = audioRatio
  50. info["audio_completion_ratio"] = audioCompletionRatio
  51. return info
  52. }
  53. func GenerateClaudeOtherInfo(ctx *gin.Context, relayInfo *relaycommon.RelayInfo, modelRatio, groupRatio, completionRatio float64,
  54. cacheTokens int, cacheRatio float64, cacheCreationTokens int, cacheCreationRatio float64, modelPrice float64, userGroupRatio float64) map[string]interface{} {
  55. info := GenerateTextOtherInfo(ctx, relayInfo, modelRatio, groupRatio, completionRatio, cacheTokens, cacheRatio, modelPrice, userGroupRatio)
  56. info["claude"] = true
  57. info["cache_creation_tokens"] = cacheCreationTokens
  58. info["cache_creation_ratio"] = cacheCreationRatio
  59. return info
  60. }
  61. func GenerateMjOtherInfo(priceData helper.PerCallPriceData) map[string]interface{} {
  62. other := make(map[string]interface{})
  63. other["model_price"] = priceData.ModelPrice
  64. other["group_ratio"] = priceData.GroupRatioInfo.GroupRatio
  65. if priceData.GroupRatioInfo.HasSpecialRatio {
  66. other["user_group_ratio"] = priceData.GroupRatioInfo.GroupSpecialRatio
  67. }
  68. return other
  69. }