user.go 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. package model
  2. import (
  3. "database/sql/driver"
  4. "fmt"
  5. "time"
  6. )
  7. /* code 结构体 */
  8. type CodeData struct {
  9. Code string `form:"code" binding:"required"`
  10. Gid string `form:"gid" binding:"required"`
  11. Pf string `form:"pf" binding:"required"`
  12. Secret string `form:"secret"`
  13. }
  14. type Users struct {
  15. ID int `json:"id" gorm:"not null;"`
  16. OpenId string `json:"openId" gorm:"not null;column:openId;"`
  17. Pf string `json:"pf" gorm:"not null;"`
  18. UserId int `json:"userId" gorm:"not null;column:userId;"`
  19. CreatedAt time.Time `json:"createdAt" gorm:"column:createdAt;"`
  20. UpdatedAt time.Time `json:"updatedAt" gorm:"column:updatedAt;"`
  21. }
  22. type User struct {
  23. ID int `json:"id" gorm:"not null;"`
  24. Pf string `json:"pf" gorm:"not null;"`
  25. Gid string `json:"gid" gorm:"not null;"`
  26. UserId int `json:"userId" gorm:"not null;column:userId;"`
  27. OpenId string `json:"openId" gorm:"not null;column:openId;"`
  28. CreatedAt time.Time `json:"createdAt" gorm:"column:createdAt;"`
  29. }
  30. type UserLogin struct {
  31. ID int `json:"id" gorm:"not null;"`
  32. Pf string `json:"pf" gorm:"not null;"`
  33. Gid string `json:"gid" gorm:"not null;"`
  34. UserId int `json:"userId" gorm:"not null;column:userId;"`
  35. LoginTime time.Time `json:"loginTime" gorm:"column:loginTime;"`
  36. }
  37. type UserOnline struct {
  38. ID int `json:"id" gorm:"not null;"`
  39. Pf string `json:"pf" gorm:"not null;"`
  40. Gid string `json:"gid" gorm:"not null;"`
  41. UserId int `json:"userId" gorm:"not null;column:userId;"`
  42. Type int `json:"type" gorm:"not null;"`
  43. Date string `json:"date" gorm:"not null;"`
  44. LogTime time.Time `json:"logTime" gorm:"column:logTime;"`
  45. }
  46. type UserSeeAds struct {
  47. ID int `json:"id" gorm:"not null;"`
  48. Pf string `json:"pf" gorm:"not null;"`
  49. Gid string `json:"gid" gorm:"not null;"`
  50. UserId int `json:"userId" gorm:"not null;column:userId;"`
  51. Date string `json:"date" gorm:"not null;"`
  52. CreatedAt time.Time `json:"createdAt" gorm:"column:createdAt;"`
  53. StartTime time.Time `json:"startTime" gorm:"column:startTime;"`
  54. AdsId string `json:"adsId" gorm:"not null;column:adsId;"`
  55. AdsType string `json:"adsType" gorm:"not null;column:adsType;"`
  56. AdsScene string `json:"adsScene" gorm:"not null;column:adsScene;"`
  57. AdsState int `json:"adsState" gorm:"not null;column:adsState;"`
  58. }
  59. // 1. 创建 time.Time 类型的副本 XTime;
  60. type XTime struct {
  61. time.Time
  62. }
  63. // 2. 为 Xtime 重写 MarshaJSON 方法,在此方法中实现自定义格式的转换;
  64. func (t XTime) MarshalJSON() ([]byte, error) {
  65. output := fmt.Sprintf("\"%s\"", t.Format("2006-01-02 15:04:05"))
  66. return []byte(output), nil
  67. }
  68. // 3. 为 Xtime 实现 Value 方法,写入数据库时会调用该方法将自定义时间类型转换并写入数据库;
  69. func (t XTime) Value() (driver.Value, error) {
  70. var zeroTime time.Time
  71. if t.Time.UnixNano() == zeroTime.UnixNano() {
  72. return nil, nil
  73. }
  74. return t.Time, nil
  75. }
  76. // 4. 为 Xtime 实现 Scan 方法,读取数据库时会调用该方法将时间数据转换成自定义时间类型;
  77. func (t *XTime) Scan(v interface{}) error {
  78. value, ok := v.(time.Time)
  79. if ok {
  80. *t = XTime{Time: value}
  81. return nil
  82. }
  83. return fmt.Errorf("can not convert %v to timestamp", v)
  84. }
  85. type GameAction struct {
  86. ID int `json:"id" gorm:"not null;"`
  87. Gid string `json:"gid" gorm:"not null;"`
  88. ActionId string `json:"actionId" gorm:"not null;column:actionId;"`
  89. ActionName string `json:"actionName" gorm:"not null;column:actionName;"`
  90. Status int `json:"status" gorm:"not null;column:status;"`
  91. Remark string `json:"remark" gorm:"not null;column:remark;"`
  92. CreatedAt XTime `json:"createdAt" gorm:"column:createdAt;type:date;"`
  93. UpdatedAt XTime `json:"updatedAt" gorm:"column:updatedAt;type:date;"`
  94. }
  95. type GameActionOption struct {
  96. ID int `json:"id" gorm:"not null;"`
  97. ActionId int `json:"actionId" gorm:"not null;column:actionId;"`
  98. OptionId string `json:"optionId" gorm:"not null;column:optionId;"`
  99. OptionName string `json:"optionName" gorm:"not null;column:optionName;"`
  100. OptionType string `json:"optionType" gorm:"not null;column:optionType;"`
  101. Status int `json:"status" gorm:"not null;column:status;"`
  102. CreatedAt XTime `json:"createdAt" gorm:"column:createdAt;"`
  103. UpdatedAt XTime `json:"updatedAt" gorm:"column:updatedAt;"`
  104. }
  105. type UserAction struct {
  106. ID int `json:"id" gorm:"not null;"`
  107. Pf string `json:"pf" gorm:"not null;"`
  108. Gid string `json:"gid" gorm:"not null;"`
  109. ActionId string `json:"actionId" gorm:"not null;column:actionId;"`
  110. UserId int `json:"userId" gorm:"not null;column:userId;"`
  111. CreatedAt XTime `json:"createdAt" gorm:"column:createdAt;type:date;"`
  112. }
  113. type UserActionOption struct {
  114. ID int `json:"id" gorm:"not null;"`
  115. OptionId string `json:"optionId" gorm:"not null;column:optionId;"`
  116. UserActionId int `json:"userActionId" gorm:"not null;column:userActionId;"`
  117. CreatedAt XTime `json:"createdAt" gorm:"column:createdAt;type:date;"`
  118. Value string `json:"value" gorm:"not null;column:value;"`
  119. }