123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- 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
- }
|