互动
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

51 lines
2.3 KiB

package models
import (
"github.com/ouxuanserver/osmanthuswine/src/core"
"time"
)
const LiveRedPackInfoTN = TableNamePrefix + "live_red_pack_info"
type LiveRedPackInfo struct {
Id int64 `json:"live_red_pack_info_id" xorm:"not null pk autoincr INT(11)"`
IsDelete bool `json:"-" xorm:"not null default 0 comment('是否删除') TINYINT(1)"`
CreatedAt time.Time `json:"created_at" xorm:"not null created comment('创建时间') DATETIME"`
UpdatedAt time.Time `json:"updated_at" xorm:"not null updated default CURRENT_TIMESTAMP comment('更新时间') TIMESTAMP"`
UserId int64 `json:"user_id" xorm:"not null default 0 comment('用户id') INT(11)"`
ActivityId int64 `json:"activity_id" xorm:"not null default 0 comment('互动id') INT(11)"`
GroupId string `json:"group_id" xorm:"not null default '' comment('聊天室地址') VARCHAR(128)"`
Prompt string `json:"prompt" xorm:"not null default 0 comment('祝福语') VARCHAR(255)"`
Amount int64 `json:"amount" xorm:"not null default 0 comment('红包金额, 分') INT(18)"`
OutTradeNo string `json:"out_trade_no" xorm:"not null default '' comment('订单号') VARCHAR(128)"`
Error string `json:"error" xorm:"not null default '' comment('出现错误') VARCHAR(255)"`
Status int `json:"status" xorm:"not null default 0 comment('-1尚未支付0支付成功1已推送2已作废')"`
}
func (t *LiveRedPackInfo) TableName() string {
return LiveRedPackInfoTN
}
func (t *LiveRedPackInfo) Add() (int64, error) {
return core.GetXormAuto().InsertOne(t)
}
func GetLiveRedPackInfos(status int) ([]*LiveRedPackInfo, error) {
infos := make([]*LiveRedPackInfo, 0)
err := core.GetXormAuto().Where("is_delete=0 and status=?", status).Find(&infos)
return infos, err
}
func (t *LiveRedPackInfo) GetByOutTradeNo(outTradeNo string) (bool, error) {
return core.GetXormAuto().Where("is_delete=0 and out_trade_no=?", outTradeNo).Get(t)
}
func (t *LiveRedPackInfo) UpdateStatusById(id interface{}, status int) (int64, error) {
return core.GetXormAuto().Where("id=?", id).Cols("status").Update(&LiveRedPack{Status: status})
}
func (t *LiveRedPackInfo) UpdateStatusByOutTradeNo(outTradeNo string, status int) (int64, error) {
t.Status = status
return core.GetXormAuto().Where("is_delete=0 and status=0 and out_trade_no=?", outTradeNo).Update(t)
}