244 lines
6.0 KiB
Go
Raw Permalink Normal View History

2019-04-22 02:59:20 +00:00
package dao
import (
"context"
"math/rand"
"strconv"
"go-common/app/service/main/passport-game/model"
"go-common/library/cache/memcache"
"go-common/library/log"
)
const (
_keyPrefixInfoPB = "pa2_"
_keyPrefixTokenPB = "pt_"
_keyPrefixOriginMissMatchFlag = "m_"
_keyPrefixOriginToken = "pot_"
_missMatchFlagExpireSeconds = 30 // 30 seconds
)
func keyInfoPB(mid int64) string {
return _keyPrefixInfoPB + strconv.FormatInt(mid, 10)
}
func keyTokenPB(accessToken string) string {
return _keyPrefixTokenPB + accessToken
}
func keyOriginToken(accessToken string) string {
return _keyPrefixOriginToken + accessToken
}
func keyOriginMissMatchFlag(identify string) string {
return _keyPrefixOriginMissMatchFlag + identify
}
// pingMC check connection success.
func (d *Dao) pingMC(c context.Context) (err error) {
item := &memcache.Item{
Key: "ping",
Value: []byte{1},
Expiration: d.mcExpire,
}
conn := d.mc.Get(c)
defer conn.Close()
if err = conn.Set(item); err != nil {
log.Error("conn.Set(%v) error(%v)", item, err)
}
return
}
// SetInfoCache set info into cache.
func (d *Dao) SetInfoCache(c context.Context, info *model.Info) (err error) {
item := &memcache.Item{
Key: keyInfoPB(info.Mid),
Object: info,
Flags: memcache.FlagProtobuf,
Expiration: d.mcExpire,
}
conn := d.mc.Get(c)
defer conn.Close()
if err = conn.Set(item); err != nil {
log.Error("conn.Set(%s) error(%v)", item.Key, err)
}
return
}
// InfoCache get info cache from cache.
func (d *Dao) InfoCache(c context.Context, mid int64) (info *model.Info, err error) {
key := keyInfoPB(mid)
conn := d.mc.Get(c)
defer conn.Close()
var item *memcache.Item
if item, err = conn.Get(key); err != nil {
if err == memcache.ErrNotFound {
err = nil
return
}
log.Error("conn.Get(%s) error(%v)", key, err)
return
}
info = new(model.Info)
if err = conn.Scan(item, info); err != nil {
log.Error("conn.Scan(%s, %s) error(%v)", key, item.Value, err)
}
return
}
// SetTokenCache set token into cache.
func (d *Dao) SetTokenCache(c context.Context, token *model.Perm) (err error) {
item := &memcache.Item{
Key: keyTokenPB(token.AccessToken),
Object: token,
Flags: memcache.FlagProtobuf,
Expiration: d.mcExpire,
}
conn := d.mc.Get(c)
defer conn.Close()
if err = conn.Set(item); err != nil {
log.Error("conn.Set(%s) error(%v)", item.Key, err)
}
return
}
// TokenCache get token from cache.
func (d *Dao) TokenCache(c context.Context, accessToken string) (token *model.Perm, err error) {
key := keyTokenPB(accessToken)
conn := d.mc.Get(c)
defer conn.Close()
item, err := conn.Get(key)
if err != nil {
if err == memcache.ErrNotFound {
err = nil
return
}
log.Error("conn.Get(%s) error(%v)", key, err)
return
}
token = new(model.Perm)
if err = conn.Scan(item, token); err != nil {
log.Error("conn.Scan(%s, %s) error(%v)", item.Key, item.Value, err)
}
return
}
// DelTokenCache delete token from cache.
func (d *Dao) DelTokenCache(c context.Context, accessToken string) (err error) {
key := keyTokenPB(accessToken)
conn := d.mc.Get(c)
defer conn.Close()
if err = conn.Delete(key); err != nil {
if err == memcache.ErrNotFound {
err = nil
return
}
log.Error("conn.Delete(%s) error(%v)", key, err)
}
return
}
// SetOriginMissMatchFlagCache set origin miss match flag cache.
func (d *Dao) SetOriginMissMatchFlagCache(c context.Context, identify string, flag []byte) (err error) {
item := &memcache.Item{
Key: keyOriginMissMatchFlag(identify),
Value: flag,
Expiration: _missMatchFlagExpireSeconds,
}
conn := d.mc.Get(c)
defer conn.Close()
if err = conn.Set(item); err != nil {
log.Error("conn.Set(%s) error(%v)", item.Key, err)
}
return
}
// OriginMissMatchFlagCache get origin miss match flag.
func (d *Dao) OriginMissMatchFlagCache(c context.Context, identify string) (res []byte, err error) {
key := keyOriginMissMatchFlag(identify)
conn := d.mc.Get(c)
defer conn.Close()
var item *memcache.Item
if item, err = conn.Get(key); err != nil {
if err == memcache.ErrNotFound {
err = nil
return
}
log.Error("conn.Get(%s) error(%v)", key, err)
return
}
res = item.Value
return
}
// DelOriginMissMatchFlagCache delete origin miss match flag.
func (d *Dao) DelOriginMissMatchFlagCache(c context.Context, identify string) (err error) {
key := keyOriginMissMatchFlag(identify)
conn := d.mc.Get(c)
defer conn.Close()
if err = conn.Delete(key); err != nil {
if err == memcache.ErrNotFound {
err = nil
return
}
log.Error("conn.Delete(%s) error(%v)", key, err)
}
return
}
// SetOriginTokenCache set passport token into cache.
func (d *Dao) SetOriginTokenCache(c context.Context, token *model.Token) (err error) {
item := &memcache.Item{
Key: keyOriginToken(token.AccessToken),
Object: token,
Flags: memcache.FlagJSON,
Expiration: 60 + rand.Int31n(600),
}
conn := d.mc.Get(c)
defer conn.Close()
if err = conn.Set(item); err != nil {
log.Error("conn.Set(%s) error(%v)", item.Key, err)
return
}
return
}
// OriginTokenCache set passport token into cache.
func (d *Dao) OriginTokenCache(c context.Context, accessToken string) (token *model.Token, err error) {
key := keyOriginToken(accessToken)
conn := d.mc.Get(c)
defer conn.Close()
item, err := conn.Get(key)
if err != nil {
if err == memcache.ErrNotFound {
err = nil
return
}
log.Error("conn.Get(%s) error(%v)", key, err)
return
}
token = new(model.Token)
if err = conn.Scan(item, token); err != nil {
log.Error("conn.Scan(%s, %s) error(%v)", item.Key, item.Value, err)
return
}
return
}
// DelOriginTokenCache delete passport token from cache.
func (d *Dao) DelOriginTokenCache(c context.Context, accessToken string) (err error) {
key := keyOriginToken(accessToken)
conn := d.mc.Get(c)
defer conn.Close()
if err = conn.Delete(key); err != nil {
if err == memcache.ErrNotFound {
err = nil
return
}
log.Error("conn.Delete(%s) error(%v)", key, err)
return
}
return
}