log_info_generate.go 3.7 KB

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