109 lines
2.9 KiB
Go
109 lines
2.9 KiB
Go
package upper
|
|
|
|
import (
|
|
"context"
|
|
"database/sql"
|
|
"fmt"
|
|
|
|
upMdl "go-common/app/interface/main/tv/model/upper"
|
|
"go-common/library/cache/memcache"
|
|
xsql "go-common/library/database/sql"
|
|
"go-common/library/ecode"
|
|
"go-common/library/log"
|
|
)
|
|
|
|
const (
|
|
_loadUpper = "SELECT id,mid,toinit,submit,ori_name,cms_name,ori_face,cms_face,valid,deleted FROM ugc_uploader WHERE mid = ?"
|
|
)
|
|
|
|
func upperMetaKey(MID int64) string {
|
|
return fmt.Sprintf("up_cms_%d", MID)
|
|
}
|
|
|
|
// LoadUpMeta loads the upper meta cms data from cache, for missed ones, pick them from the DB
|
|
func (d *Dao) LoadUpMeta(ctx context.Context, mid int64) (upper *upMdl.Upper, err error) {
|
|
if upper, err = d.upMetaCache(ctx, mid); err != nil { // mc error
|
|
log.Error("LoadUpMeta Get Mid [%d] from CMS Error (%v)", mid, err)
|
|
return
|
|
}
|
|
if upper != nil { // mc found
|
|
return
|
|
}
|
|
if upper, err = d.upMetaDB(ctx, mid); err != nil { // db error
|
|
log.Error("LoadUpMeta Get Mid ERROR (%d) (%v)", mid, err)
|
|
return
|
|
}
|
|
if upper == nil { // db not found
|
|
err = ecode.NothingFound
|
|
return
|
|
}
|
|
d.addUpMetaCache(upper) // db found, re-fill the cache
|
|
return
|
|
}
|
|
|
|
// upMetaCache get upper meta cache.
|
|
func (d *Dao) upMetaCache(c context.Context, mid int64) (upper *upMdl.Upper, err error) {
|
|
var (
|
|
key = upperMetaKey(mid)
|
|
conn = d.mc.Get(c)
|
|
item *memcache.Item
|
|
)
|
|
defer conn.Close()
|
|
if item, err = conn.Get(key); err != nil {
|
|
if err == memcache.ErrNotFound {
|
|
err = nil
|
|
missedCount.Add("tv-meta", 1)
|
|
} else {
|
|
log.Error("conn.Get(%s) error(%v)", key, err)
|
|
}
|
|
return
|
|
}
|
|
if err = conn.Scan(item, &upper); err != nil {
|
|
log.Error("conn.Get(%s) error(%v)", key, err)
|
|
}
|
|
cachedCount.Add("tv-meta", 1)
|
|
return
|
|
}
|
|
|
|
// upMetaDB gets upper meta info from DB
|
|
func (d *Dao) upMetaDB(c context.Context, mid int64) (upper *upMdl.Upper, err error) {
|
|
var row *xsql.Row
|
|
if row = d.DB.QueryRow(c, _loadUpper, mid); err != nil {
|
|
log.Error("d.db.QueryRow(%d) error(%v)", mid, err)
|
|
return
|
|
}
|
|
upper = &upMdl.Upper{}
|
|
// "SELECT id,mid,to_init,submit,ori_name,cms_name,ori_face,cms_face,valid,deleted FROM ugc_uploader WHERE mid = ?"
|
|
if err = row.Scan(&upper.ID, &upper.MID, &upper.Toinit, &upper.Submit, &upper.OriName,
|
|
&upper.CMSName, &upper.OriFace, &upper.CMSFace, &upper.Valid, &upper.Deleted); err != nil {
|
|
if err == sql.ErrNoRows {
|
|
err = nil
|
|
upper = nil
|
|
} else {
|
|
log.Error("row.Scan(mid %d) error(%v)", mid, err)
|
|
}
|
|
}
|
|
return
|
|
}
|
|
|
|
// setUpMetaCache save upMdl.Upper to memcache
|
|
func (d *Dao) setUpMetaCache(c context.Context, upper *upMdl.Upper) (err error) {
|
|
var (
|
|
key = upperMetaKey(upper.MID)
|
|
conn = d.mc.Get(c)
|
|
)
|
|
defer conn.Close()
|
|
if err = conn.Set(&memcache.Item{Key: key, Object: upper, Flags: memcache.FlagJSON, Expiration: d.mcExpire}); err != nil {
|
|
log.Error("conn.Set error(%v)", err)
|
|
return
|
|
}
|
|
return
|
|
}
|
|
|
|
// addUpMetaCache add upper meta cache
|
|
func (d *Dao) addUpMetaCache(upper *upMdl.Upper) {
|
|
d.addCache(func() {
|
|
d.setUpMetaCache(context.TODO(), upper)
|
|
})
|
|
}
|