123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198 |
- package cms
- import (
- "context"
- "fmt"
- "go-common/app/interface/main/tv/model"
- "go-common/library/cache/memcache"
- "go-common/library/log"
- )
- const (
- _mcEPKey = "ep_%d"
- _mcSeasonKey = "sn_%d"
- )
- // SeaCacheKey .
- func (d *Dao) SeaCacheKey(sid int64) string {
- return fmt.Sprintf(_mcSeasonKey, sid)
- }
- // EPCacheKey .
- func (d *Dao) EPCacheKey(epid int64) string {
- return fmt.Sprintf(_mcEPKey, epid)
- }
- // GetSeasonCache get SnAuth cache.
- func (d *Dao) GetSeasonCache(c context.Context, sid int64) (s *model.SnAuth, err error) {
- var (
- key = d.SeaCacheKey(sid)
- 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
- } else {
- log.Error("conn.Get(%s) error(%v)", key, err)
- }
- return
- }
- if err = conn.Scan(item, &s); err != nil {
- log.Error("conn.Get(%s) error(%v)", key, err)
- }
- return
- }
- // GetEPCache get EpAuth cache.
- func (d *Dao) GetEPCache(c context.Context, epid int64) (ep *model.EpAuth, err error) {
- var (
- key = d.EPCacheKey(epid)
- 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
- } else {
- log.Error("conn.Get(%s) error(%v)", key, err)
- }
- return
- }
- if err = conn.Scan(item, &ep); err != nil {
- log.Error("conn.Get(%s) error(%v)", key, err)
- }
- return
- }
- // AddSnAuthCache save model.SnAuth to memcache
- func (d *Dao) AddSnAuthCache(c context.Context, s *model.SnAuth) (err error) {
- var (
- key = d.SeaCacheKey(s.ID)
- conn = d.mc.Get(c)
- )
- defer conn.Close()
- if err = conn.Set(&memcache.Item{Key: key, Object: s, Flags: memcache.FlagJSON, Expiration: d.expireCMS}); err != nil {
- log.Error("conn.Set error(%v)", err)
- return
- }
- return
- }
- // AddEpAuthCache save model.EpAuth to memcache
- func (d *Dao) AddEpAuthCache(c context.Context, ep *model.EpAuth) (err error) {
- var (
- key = d.EPCacheKey(ep.EPID)
- conn = d.mc.Get(c)
- )
- defer conn.Close()
- if err = conn.Set(&memcache.Item{Key: key, Object: ep, Flags: memcache.FlagJSON, Expiration: d.expireCMS}); err != nil {
- log.Error("conn.Set error(%v)", err)
- return
- }
- return
- }
- // snAuthCache season auth cache
- func (d *Dao) snAuthCache(c context.Context, ids []int64) (cached map[int64]*model.SnAuth, missed []int64, err error) {
- if len(ids) == 0 {
- return
- }
- cached = make(map[int64]*model.SnAuth, len(ids))
- idmap, allKeys := keysTreat(ids, d.SeaCacheKey)
- conn := d.mc.Get(c)
- defer conn.Close()
- replys, err := conn.GetMulti(allKeys)
- if err != nil {
- PromError("mc:获取Season信息缓存")
- log.Error("conn.Gets(%v) error(%v)", allKeys, err)
- return
- }
- for key, item := range replys {
- art := &model.SnAuth{}
- if err = conn.Scan(item, art); err != nil {
- PromError("mc:获取Season信息缓存json解析")
- log.Error("item.Scan(%s) error(%v)", item.Value, err)
- err = nil
- continue
- }
- cached[idmap[key]] = art
- delete(idmap, key)
- }
- missed = missedTreat(idmap, len(cached))
- return
- }
- // epAuthCache ep auth cache
- func (d *Dao) epAuthCache(c context.Context, ids []int64) (cached map[int64]*model.EpAuth, missed []int64, err error) {
- if len(ids) == 0 {
- return
- }
- cached = make(map[int64]*model.EpAuth, len(ids))
- idmap, allKeys := keysTreat(ids, d.EPCacheKey)
- conn := d.mc.Get(c)
- defer conn.Close()
- replys, err := conn.GetMulti(allKeys)
- if err != nil {
- PromError("mc:获取EP信息缓存")
- log.Error("conn.Gets(%v) error(%v)", allKeys, err)
- return
- }
- for key, item := range replys {
- art := &model.EpAuth{}
- if err = conn.Scan(item, art); err != nil {
- PromError("mc:获取EP信息缓存json解析")
- log.Error("item.Scan(%s) error(%v)", item.Value, err)
- err = nil
- continue
- }
- cached[idmap[key]] = art
- delete(idmap, key)
- }
- missed = missedTreat(idmap, len(cached))
- return
- }
- // SnAuth get's season auth info from Cache & DB
- func (d *Dao) SnAuth(c context.Context, sid int64) (sn *model.SnAuth, err error) {
- if sn, err = d.GetSeasonCache(c, sid); err != nil { // mc Error
- return
- } else if sn == nil { // mc not found, go DB
- if sn, err = d.SnAuthDB(c, int64(sid)); err != nil { // DB error
- log.Error("SnAuthDB (%d) ERROR (%v)", sid, err)
- return
- }
- if sn == nil { // DB not found, build a fake item in MC to avoid checking DB next time
- log.Error("SnAuthDB (%d) not found(%v) in DB", sid)
- sn = &model.SnAuth{ID: int64(sid), Check: 0, IsDeleted: 1}
- }
- if err = d.AddSnAuthCache(c, sn); err != nil { // set item in MC ( not found - fake, or true )
- log.Error("AddSnAuthCache fail(%v)", err)
- }
- }
- return
- }
- // EpAuth get's ep auth info from Cache & DB
- func (d *Dao) EpAuth(c context.Context, epid int64) (ep *model.EpAuth, err error) {
- if ep, err = d.GetEPCache(c, epid); err != nil { // MC error
- log.Error("GetEPCache(%d) Error(%v)", epid, err)
- return
- } else if ep == nil { // MC not found, go DB
- if ep, err = d.EpAuthDB(c, epid); err != nil { // DB error
- log.Error("DBSimpleEP(%d) ERROR (%v)", epid, err)
- return
- }
- if ep == nil { // DB not found, build a fake item in MC to avoid checking DB next time
- log.Error("EPID(%d) not found", epid)
- ep = &model.EpAuth{EPID: epid, State: 4, IsDeleted: 1}
- }
- if err = d.AddEpAuthCache(c, ep); err != nil {
- log.Error("AddEpAuthCache fail(%v)", err)
- }
- }
- return
- }
|