go-common/app/job/main/tv/dao/upper/refresh.go
2019-04-22 18:49:16 +08:00

111 lines
3.3 KiB
Go

package upper
import (
"context"
"fmt"
ugcMdl "go-common/app/job/main/tv/model/ugc"
"go-common/library/database/sql"
"go-common/library/ecode"
"go-common/library/log"
)
const (
_countUpper = "SELECT count(1) FROM ugc_uploader WHERE deleted = 0"
_pickUppers = "SELECT mid FROM ugc_uploader WHERE deleted = 0 AND mid > ? ORDER BY mid LIMIT 0,%d"
_setUpperName = "UPDATE ugc_uploader SET ori_name = ?, cms_name = ? WHERE mid = ? AND deleted = 0"
_setUpperFace = "UPDATE ugc_uploader SET ori_face = ?, cms_face = ? WHERE mid = ? AND deleted = 0"
_sendUpper = "UPDATE ugc_uploader SET submit = 1 WHERE mid = ? AND deleted = 0"
_importUpper = "REPLACE INTO ugc_uploader (ori_name, cms_name, ori_face, cms_face, mid) VALUES (?,?,?,?,?)"
_upName = 1
_upFace = 2
)
// CountUP counts the uppers
func (d *Dao) CountUP(c context.Context) (count int64, err error) {
if err = d.DB.QueryRow(c, _countUpper).Scan(&count); err != nil {
log.Error("d.CountUP.Query error(%v)", err)
}
return
}
// PickUppers picks data by Piece to refresh uppers
func (d *Dao) PickUppers(ctx context.Context, LastID int64, nbData int) (res []int64, myLast int64, err error) {
var (
rows *sql.Rows
query = fmt.Sprintf(_pickUppers, nbData)
)
if rows, err = d.DB.Query(ctx, query, LastID); err != nil {
log.Error("d.refreshArcMC.Query: %s error(%v)", query, err)
return
}
defer rows.Close()
for rows.Next() {
var li int64
if err = rows.Scan(&li); err != nil {
log.Error("refreshArcMC row.Scan() error(%v)", err)
return
}
res = append(res, li)
}
if err = rows.Err(); err != nil {
log.Error("d.PickUppers.Query error(%v)", err)
return
}
// record the max ID in this piece
if len(res) > 0 {
myLast = res[len(res)-1]
}
return
}
// SendUpper updates one upper's submit to 1
func (d *Dao) SendUpper(ctx context.Context, mid int64) (err error) {
if _, err = d.DB.Exec(ctx, _sendUpper, mid); err != nil {
log.Error("SendUpper Error: %v", mid, err)
}
return
}
// setUpperV updates the upper's name or face value
func (d *Dao) setUpperV(ctx context.Context, req *ugcMdl.ReqSetUp, oriUp *ugcMdl.Upper) (err error) {
var sql string
if req.UpType == _upName {
sql = _setUpperName
oriUp.CMSName = req.Value
oriUp.OriName = req.Value
} else if req.UpType == _upFace {
sql = _setUpperFace
oriUp.CMSFace = req.Value
oriUp.OriFace = req.Value
} else {
return ecode.TvDangbeiWrongType
}
if _, err = d.DB.Exec(ctx, sql, req.Value, req.Value, req.MID); err != nil {
log.Error("SetUpperName Error: %v", req.MID, err)
}
return
}
// ImportUp is used to import a new up when we manually add an archive
func (d *Dao) ImportUp(ctx context.Context, up *ugcMdl.EasyUp) (err error) {
if _, err = d.DB.Exec(ctx, _importUpper, up.Name, up.Name, up.Face, up.Face, up.MID); err != nil {
log.Error("ImportUp Error: %v", up.MID, err)
}
d.addUpMetaCache(ctx, up.ToUpper(nil)) // add this upper into the cache
return
}
// RefreshUp refreshes the upper's name and face in both DB and cache
func (d *Dao) RefreshUp(ctx context.Context, req *ugcMdl.ReqSetUp) (err error) {
var oriUp *ugcMdl.Upper
if oriUp, err = d.LoadUpMeta(ctx, req.MID); err != nil || oriUp == nil {
return
}
if err = d.setUpperV(ctx, req, oriUp); err != nil { // update DB
return
}
d.addUpMetaCache(ctx, oriUp) // update cache
return
}