go-common/app/service/live/xuser/dao/guard/mysql.go
2019-04-22 18:49:16 +08:00

198 lines
7.6 KiB
Go

package guard
import (
"context"
"fmt"
"go-common/library/xstr"
"time"
confm "go-common/app/service/live/xuser/conf"
"go-common/app/service/live/xuser/model"
dhhm "go-common/app/service/live/xuser/model/dhh"
"go-common/library/log"
"github.com/pkg/errors"
)
const (
_guardTable = "ap_user_privilege"
)
var (
// add guard info
_addGuardInfo = "REPLACE INTO `%s` (`uid`,`target_id`,`privilege_type`,`start_time`,`expired_time`) VALUES(?,?,?,?,?);"
// get guard info
_getGuardInfo = "SELECT `id`,`uid`,`target_id`,`privilege_type`,`start_time`,`expired_time` FROM `%s` WHERE `uid`=? AND `expired_time`>=? ORDER BY `privilege_type` ASC;"
// get guard info
_getGuardInfo2 = "SELECT `id`,`uid`,`target_id`,`privilege_type`,`start_time`,`expired_time` FROM `%s` WHERE `uid`=? AND `target_id`=? AND `expired_time`>=? ORDER BY `privilege_type` ASC;"
// update guard info
_updGuardInfo = "UPDATE `%s` SET `expired_time`=date_add(expired_time, interval ? day) WHERE `uid`=? AND `target_id`=? AND `expired_time`>=? AND `privilege_type`%s?"
// upsert guard info
_upsertGuardInfo = "INSERT INTO `%s` (`uid`,`target_id`,`privilege_type`,`start_time`,`expired_time`) VALUES(?,?,?,?,?) ON DUPLICATE KEY UPDATE `start_time`=?,`expired_time`=?;"
// 查询大航海信息
_selUID = "SELECT id,uid,target_id,privilege_type,start_time,expired_time,ctime,utime FROM ap_user_privilege where uid IN (%s) AND expired_time >= '%s' "
_selAnchorUID = "SELECT id,uid,target_id,privilege_type,start_time,expired_time,ctime,utime FROM ap_user_privilege where target_id IN (%s) AND expired_time >= '%s' "
_errorDBLogPrefix = "xuser.dahanghai.dao.mysql|"
)
// GetByUIDs 批量查询
func (d *GuardDao) GetByUIDs(c context.Context, uids []int64) (dhhs []*dhhm.DHHDB, err error) {
reqStartTime := confm.RecordTimeCost()
dhhs = make([]*dhhm.DHHDB, 0)
tm := time.Now()
timeNow := tm.Format("2006-1-2 15:04:05")
rows, err1 := d.db.Query(c, fmt.Sprintf(_selUID, xstr.JoinInts(uids), timeNow))
if err1 != nil {
reqAfterTime := confm.RecordTimeCost()
err = err1
log.Error(_errorDBLogPrefix+confm.GetFromDHHDBError+"|GetByUIDs err: %v|cost:%dms", err, reqAfterTime-reqStartTime)
return
}
for rows.Next() {
ele := &dhhm.DHHDB{}
if err = rows.Scan(&ele.ID, &ele.UID, &ele.TargetId, &ele.PrivilegeType, &ele.StartTime, &ele.ExpiredTime, &ele.Ctime, &ele.Utime); err != nil {
log.Error(_errorDBLogPrefix+confm.ScanFromDHHDBError+"|GetByUIDs rows.Scan err: %v", err)
return
}
dhhs = append(dhhs, ele)
}
return
}
// GetByUIDsWithMap 批量查询
func (d *GuardDao) GetByUIDsWithMap(c context.Context, uids []int64) (dhhs map[int64][]*dhhm.DHHDB, err error) {
reqStartTime := confm.RecordTimeCost()
dhhs = make(map[int64][]*dhhm.DHHDB)
tm := time.Now()
timeNow := tm.Format("2006-1-2 15:04:05")
rows, err1 := d.db.Query(c, fmt.Sprintf(_selUID, xstr.JoinInts(uids), timeNow))
if err1 != nil {
reqAfterTime := confm.RecordTimeCost()
err = err1
log.Error(_errorDBLogPrefix+confm.GetFromDHHDBError+"|GetByUIDs err: %v|cost:%dms", err, reqAfterTime-reqStartTime)
return
}
for rows.Next() {
ele := &dhhm.DHHDB{}
if err = rows.Scan(&ele.ID, &ele.UID, &ele.TargetId, &ele.PrivilegeType, &ele.StartTime, &ele.ExpiredTime, &ele.Ctime, &ele.Utime); err != nil {
log.Error(_errorDBLogPrefix+confm.ScanFromDHHDBError+"|GetByUIDs rows.Scan err: %v", err)
return
}
if _, exist := dhhs[ele.UID]; !exist {
dhhs[ele.UID] = make([]*dhhm.DHHDB, 0)
}
dhhs[ele.UID] = append(dhhs[ele.UID], ele)
}
return
}
// GetByAnchorUIDs 批量查询
func (d *GuardDao) GetByAnchorUIDs(c context.Context, uids []int64) (dhhs []*dhhm.DHHDB, err error) {
reqStartTime := confm.RecordTimeCost()
dhhs = make([]*dhhm.DHHDB, 0)
tm := time.Now()
timeNow := tm.Format("2006-1-2 15:04:05")
rows, err1 := d.db.Query(c, fmt.Sprintf(_selAnchorUID, xstr.JoinInts(uids), timeNow))
if err1 != nil {
reqAfterTime := confm.RecordTimeCost()
err = err1
log.Error(_errorDBLogPrefix+confm.GetFromDHHDBError+"|GetByUIDs err: %v|cost:%dms", err, reqAfterTime-reqStartTime)
return
}
for rows.Next() {
ele := &dhhm.DHHDB{}
if err = rows.Scan(&ele.ID, &ele.UID, &ele.TargetId, &ele.PrivilegeType, &ele.StartTime, &ele.ExpiredTime, &ele.Ctime, &ele.Utime); err != nil {
log.Error(_errorDBLogPrefix+confm.ScanFromDHHDBError+"|GetByUIDs rows.Scan err: %v", err)
return
}
dhhs = append(dhhs, ele)
}
return
}
// GetGuardByUID get guard info by uid
func (d *GuardDao) GetGuardByUID(ctx context.Context, uid int64) (info []*model.GuardInfo, err error) {
sql := fmt.Sprintf(_getGuardInfo, _guardTable)
rows, err := d.db.Query(ctx, sql, uid, time.Now().Format("2006-01-02 15:04:05"))
if err != nil {
log.Error("[dao.guard.mysql|GetGuardByUID] get user guard record error(%v), uid(%d)", err, uid)
return nil, err
}
defer rows.Close()
for rows.Next() {
var inf model.GuardInfo
err = rows.Scan(&inf.Id, &inf.Uid, &inf.TargetId, &inf.PrivilegeType, &inf.StartTime, &inf.ExpiredTime)
if err != nil {
log.Error("[dao.guard.mysql|GetGuardByUID] scan user guard record error(%v), uid(%d)", err, uid)
return nil, err
}
info = append(info, &inf)
}
return
}
// GetGuardByUIDRuid get guard info by uid and ruid
func (d *GuardDao) GetGuardByUIDRuid(ctx context.Context, uid int64, ruid int64) (info []*model.GuardInfo, err error) {
sql := fmt.Sprintf(_getGuardInfo2, _guardTable)
rows, err := d.db.Query(ctx, sql, uid, ruid, time.Now().Format("2006-01-02 15:04:05"))
if err != nil {
log.Error("[dao.guard.mysql|GetGuardByUIDRuid] get user guard record error(%v), uid(%d), ruid(%d)", err, uid, ruid)
return nil, err
}
defer rows.Close()
for rows.Next() {
var inf model.GuardInfo
err = rows.Scan(&inf.Id, &inf.Uid, &inf.TargetId, &inf.PrivilegeType, &inf.StartTime, &inf.ExpiredTime)
if err != nil {
log.Error("[dao.guard.mysql|GetGuardByUIDRuid] scan user guard record error(%v), uid(%d), ruid(%d)", err, uid, ruid)
return nil, err
}
info = append(info, &inf)
}
return
}
// AddGuard insert guard
func (d *GuardDao) AddGuard(ctx context.Context, req *model.GuardBuy) (err error) {
sql := fmt.Sprintf(_addGuardInfo, _guardTable)
now := time.Now()
endTime := time.Date(now.Year(), now.Month(), now.Day(), int(23), int(59), int(59), int(999), time.Local).AddDate(0, 0, req.Num*30)
res, err := d.db.Exec(ctx, sql, req.Uid, req.Ruid, req.GuardLevel, now.Format("2006-01-02 15:04:05"), endTime.Format("2006-01-02 15:04:05"))
if err != nil {
// unique key exists error
log.Error("[dao.guard.mysql|AddGuard] add user guard record error(%v), req(%v)", err, req)
return
}
if _, err = res.LastInsertId(); err != nil {
err = errors.WithStack(err)
log.Error("[dao.guard.mysql|AddGuard] get last insert id error(%v), req(%v)", err, req)
}
return
}
// UpdateGuard update guard info
func (d *GuardDao) UpdateGuard(ctx context.Context, req *model.GuardBuy, cond string) (err error) {
sql := fmt.Sprintf(_updGuardInfo, _guardTable, cond)
_, err = d.db.Exec(ctx, sql, req.Num*30, req.Uid, req.Ruid, time.Now().Format("2006-01-02 15:04:05"), req.GuardLevel)
if err != nil {
log.Error("[dao.guard.mysql|UpdateGuard] update user guard record error(%v), req(%v)", err, req)
return
}
return
}
// UpsertGuard upsert guard info
func (d *GuardDao) UpsertGuard(ctx context.Context, req *model.GuardBuy, expiredTime string) (err error) {
sql := fmt.Sprintf(_upsertGuardInfo, _guardTable)
now := time.Now()
_, err = d.db.Exec(ctx, sql, req.Uid, req.Ruid, req.GuardLevel, now.Format("2006-01-02 15:04:05"), expiredTime, now.Format("2006-01-02 15:04:05"), expiredTime)
if err != nil {
log.Error("[dao.guard.mysql|UpsertGuard] upsert user guard record error(%v), req(%v)", err, req)
return
}
return
}