gameshield.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. package repository
  2. import (
  3. "context"
  4. "github.com/go-nunu/nunu-layout-advanced/internal/model"
  5. )
  6. type GameShieldRepository interface {
  7. GetGameShieldById(ctx context.Context, id int64) (*model.GameShield, error)
  8. GetGameShieldDuplicateName(ctx context.Context, appName string) (int64, error)
  9. AddGameShield(ctx context.Context, gameShield *model.GameShield) error
  10. UpdateGameShield(ctx context.Context, gameShield *model.GameShield) error
  11. DeleteGameShield(ctx context.Context, ruleId int) error
  12. GetGameShieldIsBuy(ctx context.Context, uid int64) (int64, error)
  13. GetGameShieldNextduedate(ctx context.Context, uid int64, productID string) (string, error)
  14. }
  15. func NewGameShieldRepository(
  16. repository *Repository,
  17. ) GameShieldRepository {
  18. return &gameShieldRepository{
  19. Repository: repository,
  20. }
  21. }
  22. type gameShieldRepository struct {
  23. *Repository
  24. }
  25. func (r *gameShieldRepository) GetGameShieldById(ctx context.Context, id int64) (*model.GameShield, error) {
  26. var res model.GameShield
  27. if err := r.DB(ctx).Where("id = ?", id).First(&res).Error; err != nil {
  28. return nil, err
  29. }
  30. return &res, nil
  31. }
  32. func (r *gameShieldRepository) GetGameShieldDuplicateName(ctx context.Context, appName string) (int64, error) {
  33. var count int64
  34. if err := r.DB(ctx).Model(&model.GameShield{}).Where("app_name = ?", appName).Count(&count).Error; err != nil {
  35. return 0, err
  36. }
  37. return count, nil
  38. }
  39. func (r *gameShieldRepository) AddGameShield(ctx context.Context, gameShield *model.GameShield) error {
  40. if err := r.DB(ctx).Create(gameShield).Error; err != nil {
  41. return err
  42. }
  43. return nil
  44. }
  45. func (r *gameShieldRepository) UpdateGameShield(ctx context.Context, gameShield *model.GameShield) error {
  46. if err := r.DB(ctx).Where("rule_id", gameShield.RuleId).Updates(gameShield).Error; err != nil {
  47. return err
  48. }
  49. return nil
  50. }
  51. func (r *gameShieldRepository) DeleteGameShield(ctx context.Context, ruleId int) error {
  52. if err := r.DB(ctx).Where("rule_id = ?", ruleId).Delete(&model.GameShield{}).Error; err != nil {
  53. return err
  54. }
  55. return nil
  56. }
  57. func (r *gameShieldRepository) GetGameShieldIsBuy(ctx context.Context, uid int64) (int64, error) {
  58. var count int64
  59. if err := r.DB(ctx).Table("shd_host").
  60. Where("domainstatus = ?", "Active").
  61. Where("productid = ?", 67).
  62. Where("uid = ?", uid).
  63. Count(&count).Error; err != nil {
  64. return 0, err
  65. }
  66. return count, nil
  67. }
  68. func (r *gameShieldRepository) GetGameShieldNextduedate(ctx context.Context, uid int64, productID string) (string, error) {
  69. var nextDueDate string
  70. err := r.DB(ctx).Table("shd_host").
  71. Select("nextduedate").
  72. Where("domain = ?", productID).
  73. Where("productid = ?", 67).
  74. Where("uid = ?", uid).
  75. Scan(&nextDueDate).Error
  76. if err != nil {
  77. return "", err
  78. }
  79. return nextDueDate, nil
  80. }