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.
53 lines
2.5 KiB
53 lines
2.5 KiB
package models
|
|
|
|
import (
|
|
"github.com/ouxuanserver/osmanthuswine/src/core"
|
|
"time"
|
|
)
|
|
|
|
const LiveRedPackTN = TableNamePrefix + "live_red_pack"
|
|
|
|
type LiveRedPack struct {
|
|
Id int64 `json:"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"`
|
|
|
|
LiveRedPackInfoId int64 `json:"live_red_pack_info_id" xorm:"not null default 0 comment('红包信息id') INT(11)"`
|
|
ActivityId int64 `json:"activity_id" xorm:"not null default 0 comment('互动id') INT(11)"`
|
|
Receiver int64 `json:"receiver" xorm:"not null default 0 comment('[0未领取/非0领取用户id]') INT(11)"`
|
|
OpenId string `json:"open_id" xorm:"not null default '' comment('用户openid') VARCHAR(128)"`
|
|
Amount int `json:"amount" xorm:"not null default 0 comment('红包金额, 分') INT(18)"`
|
|
TransferType int `json:"transfer_type" xorm:"not null default 0 comment('转账方式[0微信红包1微信零钱]') TINYINT(1)"`
|
|
PartnerTradeNo string `json:"partner_trade_no" xorm:"not null default '' comment('转账单号') VARCHAR(128) "`
|
|
Status int `json:"status" xorm:"not null default 0 comment('0 未被领取 1 已被领取 2 已发送 3 出现错误') TINYINT(1)"`
|
|
Version int `json:"version" xorm:"not null version comment('乐观锁') INT(11)"`
|
|
}
|
|
|
|
func (t LiveRedPack) TableName() string {
|
|
return LiveRedPackTN
|
|
}
|
|
|
|
func (t *LiveRedPack) Add() (int64, error) {
|
|
return core.GetXormAuto().InsertOne(t)
|
|
}
|
|
|
|
func (t *LiveRedPack) GetByInfoId(infoId int64) (bool, error) {
|
|
return core.GetXormAuto().Where("live_red_package_info_id=? and is_delete=0", infoId).Get(t)
|
|
}
|
|
|
|
func (t *LiveRedPack) UpdateStatusById(id interface{}, status int) (int64, error) {
|
|
t.Status = status
|
|
return core.GetXormAuto().Where("id=?", id).
|
|
Cols("receiver, open_id, transfer_type, transfer_no, status").Update(t)
|
|
}
|
|
|
|
func GetRedPacksByStatus(status interface{}) ([]*LiveRedPack, error) {
|
|
redPacks := make([]*LiveRedPack, 0)
|
|
err := core.GetXormAuto().Where("is_delete=0 and status=?", status).Find(&redPacks)
|
|
return redPacks, err
|
|
}
|
|
|
|
func (t *LiveRedPack) GetByTransferNo(transferNo string) (bool, error) {
|
|
return core.GetXormAuto().Where("is_delete=0 and transfer_no=?", transferNo).Get(t)
|
|
}
|