price.go 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. package helper
  2. import (
  3. "fmt"
  4. "github.com/gin-gonic/gin"
  5. "one-api/common"
  6. relaycommon "one-api/relay/common"
  7. "one-api/setting"
  8. "one-api/setting/operation_setting"
  9. )
  10. type PriceData struct {
  11. ModelPrice float64
  12. ModelRatio float64
  13. CompletionRatio float64
  14. CacheRatio float64
  15. GroupRatio float64
  16. UsePrice bool
  17. ShouldPreConsumedQuota int
  18. }
  19. func ModelPriceHelper(c *gin.Context, info *relaycommon.RelayInfo, promptTokens int, maxTokens int) (PriceData, error) {
  20. modelPrice, usePrice := operation_setting.GetModelPrice(info.OriginModelName, false)
  21. groupRatio := setting.GetGroupRatio(info.Group)
  22. var preConsumedQuota int
  23. var modelRatio float64
  24. var completionRatio float64
  25. var cacheRatio float64
  26. if !usePrice {
  27. preConsumedTokens := common.PreConsumedQuota
  28. if maxTokens != 0 {
  29. preConsumedTokens = promptTokens + maxTokens
  30. }
  31. var success bool
  32. modelRatio, success = operation_setting.GetModelRatio(info.OriginModelName)
  33. if !success {
  34. if info.UserId == 1 {
  35. return PriceData{}, fmt.Errorf("模型 %s 倍率或价格未配置,请设置或开始自用模式;Model %s ratio or price not set, please set or start self-use mode", info.OriginModelName, info.OriginModelName)
  36. } else {
  37. return PriceData{}, fmt.Errorf("模型 %s 倍率或价格未配置, 请联系管理员设置;Model %s ratio or price not set, please contact administrator to set", info.OriginModelName, info.OriginModelName)
  38. }
  39. }
  40. completionRatio = operation_setting.GetCompletionRatio(info.OriginModelName)
  41. cacheRatio, _ = operation_setting.GetCacheRatio(info.OriginModelName)
  42. ratio := modelRatio * groupRatio
  43. preConsumedQuota = int(float64(preConsumedTokens) * ratio)
  44. } else {
  45. preConsumedQuota = int(modelPrice * common.QuotaPerUnit * groupRatio)
  46. }
  47. return PriceData{
  48. ModelPrice: modelPrice,
  49. ModelRatio: modelRatio,
  50. CompletionRatio: completionRatio,
  51. GroupRatio: groupRatio,
  52. UsePrice: usePrice,
  53. CacheRatio: cacheRatio,
  54. ShouldPreConsumedQuota: preConsumedQuota,
  55. }, nil
  56. }