price.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. package helper
  2. import (
  3. "fmt"
  4. "github.com/gin-gonic/gin"
  5. "one-api/common"
  6. constant2 "one-api/constant"
  7. relaycommon "one-api/relay/common"
  8. "one-api/setting"
  9. "one-api/setting/operation_setting"
  10. )
  11. type PriceData struct {
  12. ModelPrice float64
  13. ModelRatio float64
  14. CompletionRatio float64
  15. CacheRatio float64
  16. GroupRatio float64
  17. UsePrice bool
  18. CacheCreationRatio float64
  19. ShouldPreConsumedQuota int
  20. }
  21. func (p PriceData) ToSetting() string {
  22. return fmt.Sprintf("ModelPrice: %f, ModelRatio: %f, CompletionRatio: %f, CacheRatio: %f, GroupRatio: %f, UsePrice: %t, CacheCreationRatio: %f, ShouldPreConsumedQuota: %d", p.ModelPrice, p.ModelRatio, p.CompletionRatio, p.CacheRatio, p.GroupRatio, p.UsePrice, p.CacheCreationRatio, p.ShouldPreConsumedQuota)
  23. }
  24. func ModelPriceHelper(c *gin.Context, info *relaycommon.RelayInfo, promptTokens int, maxTokens int) (PriceData, error) {
  25. modelPrice, usePrice := operation_setting.GetModelPrice(info.OriginModelName, false)
  26. groupRatio := setting.GetGroupRatio(info.Group)
  27. var preConsumedQuota int
  28. var modelRatio float64
  29. var completionRatio float64
  30. var cacheRatio float64
  31. var cacheCreationRatio float64
  32. if !usePrice {
  33. preConsumedTokens := common.PreConsumedQuota
  34. if maxTokens != 0 {
  35. preConsumedTokens = promptTokens + maxTokens
  36. }
  37. var success bool
  38. modelRatio, success = operation_setting.GetModelRatio(info.OriginModelName)
  39. if !success {
  40. acceptUnsetRatio := false
  41. if accept, ok := info.UserSetting[constant2.UserAcceptUnsetRatioModel]; ok {
  42. b, ok := accept.(bool)
  43. if ok {
  44. acceptUnsetRatio = b
  45. }
  46. }
  47. if !acceptUnsetRatio {
  48. if info.UserId == 1 {
  49. return PriceData{}, fmt.Errorf("模型 %s 倍率或价格未配置,请设置或开始自用模式;Model %s ratio or price not set, please set or start self-use mode", info.OriginModelName, info.OriginModelName)
  50. } else {
  51. return PriceData{}, fmt.Errorf("模型 %s 倍率或价格未配置, 请联系管理员设置;Model %s ratio or price not set, please contact administrator to set", info.OriginModelName, info.OriginModelName)
  52. }
  53. }
  54. }
  55. completionRatio = operation_setting.GetCompletionRatio(info.OriginModelName)
  56. cacheRatio, _ = operation_setting.GetCacheRatio(info.OriginModelName)
  57. cacheCreationRatio, _ = operation_setting.GetCreateCacheRatio(info.OriginModelName)
  58. ratio := modelRatio * groupRatio
  59. preConsumedQuota = int(float64(preConsumedTokens) * ratio)
  60. } else {
  61. preConsumedQuota = int(modelPrice * common.QuotaPerUnit * groupRatio)
  62. }
  63. priceData := PriceData{
  64. ModelPrice: modelPrice,
  65. ModelRatio: modelRatio,
  66. CompletionRatio: completionRatio,
  67. GroupRatio: groupRatio,
  68. UsePrice: usePrice,
  69. CacheRatio: cacheRatio,
  70. CacheCreationRatio: cacheCreationRatio,
  71. ShouldPreConsumedQuota: preConsumedQuota,
  72. }
  73. if common.DebugEnabled {
  74. println(fmt.Sprintf("model_price_helper result: %s", priceData.ToSetting()))
  75. }
  76. return priceData, nil
  77. }