topup.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. package model
  2. import (
  3. "errors"
  4. "fmt"
  5. "one-api/common"
  6. "gorm.io/gorm"
  7. )
  8. type TopUp struct {
  9. Id int `json:"id"`
  10. UserId int `json:"user_id" gorm:"index"`
  11. Amount int64 `json:"amount"`
  12. Money float64 `json:"money"`
  13. TradeNo string `json:"trade_no" gorm:"unique;type:varchar(255);index"`
  14. CreateTime int64 `json:"create_time"`
  15. CompleteTime int64 `json:"complete_time"`
  16. Status string `json:"status"`
  17. }
  18. func (topUp *TopUp) Insert() error {
  19. var err error
  20. err = DB.Create(topUp).Error
  21. return err
  22. }
  23. func (topUp *TopUp) Update() error {
  24. var err error
  25. err = DB.Save(topUp).Error
  26. return err
  27. }
  28. func GetTopUpById(id int) *TopUp {
  29. var topUp *TopUp
  30. var err error
  31. err = DB.Where("id = ?", id).First(&topUp).Error
  32. if err != nil {
  33. return nil
  34. }
  35. return topUp
  36. }
  37. func GetTopUpByTradeNo(tradeNo string) *TopUp {
  38. var topUp *TopUp
  39. var err error
  40. err = DB.Where("trade_no = ?", tradeNo).First(&topUp).Error
  41. if err != nil {
  42. return nil
  43. }
  44. return topUp
  45. }
  46. func Recharge(referenceId string, customerId string) (err error) {
  47. if referenceId == "" {
  48. return errors.New("未提供支付单号")
  49. }
  50. var quota float64
  51. topUp := &TopUp{}
  52. refCol := "`trade_no`"
  53. if common.UsingPostgreSQL {
  54. refCol = `"trade_no"`
  55. }
  56. err = DB.Transaction(func(tx *gorm.DB) error {
  57. err := tx.Set("gorm:query_option", "FOR UPDATE").Where(refCol+" = ?", referenceId).First(topUp).Error
  58. if err != nil {
  59. return errors.New("充值订单不存在")
  60. }
  61. if topUp.Status != common.TopUpStatusPending {
  62. return errors.New("充值订单状态错误")
  63. }
  64. topUp.CompleteTime = common.GetTimestamp()
  65. topUp.Status = common.TopUpStatusSuccess
  66. err = tx.Save(topUp).Error
  67. if err != nil {
  68. return err
  69. }
  70. quota = topUp.Money * common.QuotaPerUnit
  71. err = tx.Model(&User{}).Where("id = ?", topUp.UserId).Updates(map[string]interface{}{"stripe_customer": customerId, "quota": gorm.Expr("quota + ?", quota)}).Error
  72. if err != nil {
  73. return err
  74. }
  75. return nil
  76. })
  77. if err != nil {
  78. return errors.New("充值失败," + err.Error())
  79. }
  80. RecordLog(topUp.UserId, LogTypeTopup, fmt.Sprintf("使用在线充值成功,充值金额: %v,支付金额:%d", common.FormatQuota(int(quota)), topUp.Amount))
  81. return nil
  82. }