123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345 |
- package unicom
- import (
- "context"
- "fmt"
- "go-common/app/interface/main/app-wall/model/unicom"
- "go-common/library/cache/memcache"
- "go-common/library/log"
- )
- const (
- _prefix = "unicoms_user_%v"
- _userbindkey = "unicoms_user_bind_%d"
- _userpackkey = "unicom_user_pack_%d"
- _userflowkey = "unicom_user_flow_%v"
- _userflowlistkey = "unicom_user_flow_list"
- _userflowWait = "u_flowwait_%d"
- )
- func keyUnicom(usermob string) string {
- return fmt.Sprintf(_prefix, usermob)
- }
- func keyUserBind(mid int64) string {
- return fmt.Sprintf(_userbindkey, mid)
- }
- func keyUserPack(id int64) string {
- return fmt.Sprintf(_userpackkey, id)
- }
- func keyUserFlow(key string) string {
- return fmt.Sprintf(_userflowkey, key)
- }
- func keyUserflowWait(phone int) string {
- return fmt.Sprintf(_userflowWait, phone)
- }
- // AddUnicomCache
- func (d *Dao) AddUnicomCache(c context.Context, usermob string, u []*unicom.Unicom) (err error) {
- var (
- key = keyUnicom(usermob)
- conn = d.mc.Get(c)
- )
- if err = conn.Set(&memcache.Item{Key: key, Object: u, Flags: memcache.FlagJSON, Expiration: d.expire}); err != nil {
- log.Error("addUnicomCache d.mc.Set(%s,%v) error(%v)", key, u, err)
- }
- conn.Close()
- return
- }
- // UnicomCache
- func (d *Dao) UnicomCache(c context.Context, usermob string) (u []*unicom.Unicom, err error) {
- var (
- key = keyUnicom(usermob)
- conn = d.mc.Get(c)
- r *memcache.Item
- )
- defer conn.Close()
- if r, err = conn.Get(key); err != nil {
- log.Error("unicomCache MemchDB.Get(%s) error(%v)", key, err)
- return
- }
- if err = conn.Scan(r, &u); err != nil {
- log.Error("r.Scan(%s) error(%v)", r.Value, err)
- }
- return
- }
- // UpdateUnicomCache
- func (d *Dao) UpdateUnicomCache(c context.Context, usermob string, u *unicom.Unicom) (err error) {
- var (
- us []*unicom.Unicom
- unicoms []*unicom.Unicom
- uspid = map[int]struct{}{}
- )
- if u.Spid == 979 && u.TypeInt == 1 {
- return d.DeleteUnicomCache(c, usermob)
- }
- if us, err = d.UnicomCache(c, usermob); err != nil {
- if err == memcache.ErrNotFound {
- err = nil
- return
- }
- log.Error("d.UnicomCache error(%v)", err)
- return
- }
- if len(us) > 0 {
- for _, um := range us {
- if um.Spid == 979 && um.TypeInt == 1 {
- return d.DeleteUnicomCache(c, usermob)
- }
- tmp := &unicom.Unicom{}
- *tmp = *um
- if tmp.Spid == u.Spid {
- tmp = u
- uspid[u.Spid] = struct{}{}
- }
- unicoms = append(unicoms, tmp)
- }
- if _, ok := uspid[u.Spid]; !ok {
- unicoms = append(unicoms, u)
- }
- if err = d.AddUnicomCache(c, usermob, unicoms); err != nil {
- log.Error("d.AddUnicomCache error(%v)", err)
- return
- }
- }
- return
- }
- // DeleteUnicomCache
- func (d *Dao) DeleteUnicomCache(c context.Context, usermob string) (err error) {
- var (
- key = keyUnicom(usermob)
- conn = d.mc.Get(c)
- )
- defer conn.Close()
- if err = conn.Delete(key); err != nil {
- if err == memcache.ErrNotFound {
- err = nil
- return
- }
- log.Error("unicomCache MemchDB.Delete(%s) error(%v)", key, err)
- return
- }
- return
- }
- // UserBindCache user bind cache
- func (d *Dao) UserBindCache(c context.Context, mid int64) (ub *unicom.UserBind, err error) {
- var (
- key = keyUserBind(mid)
- conn = d.mc.Get(c)
- r *memcache.Item
- )
- defer conn.Close()
- if r, err = conn.Get(key); err != nil {
- log.Error("UserBindCache MemchDB.Get(%s) error(%v)", key, err)
- return
- }
- if err = conn.Scan(r, &ub); err != nil {
- log.Error("r.Scan(%s) error(%v)", r.Value, err)
- }
- return
- }
- // AddUserBindCache add user user bind cache
- func (d *Dao) AddUserBindCache(c context.Context, mid int64, ub *unicom.UserBind) (err error) {
- var (
- key = keyUserBind(mid)
- conn = d.mc.Get(c)
- )
- if err = conn.Set(&memcache.Item{Key: key, Object: ub, Flags: memcache.FlagJSON, Expiration: 0}); err != nil {
- log.Error("AddUserBindCache d.mc.Set(%s,%v) error(%v)", key, ub, err)
- }
- conn.Close()
- return
- }
- // DeleteUserBindCache delete user bind cache
- func (d *Dao) DeleteUserBindCache(c context.Context, mid int64) (err error) {
- var (
- key = keyUserBind(mid)
- conn = d.mc.Get(c)
- )
- defer conn.Close()
- if err = conn.Delete(key); err != nil {
- if err == memcache.ErrNotFound {
- err = nil
- return
- }
- log.Error("DeleteUserBindCache MemchDB.Delete(%s) error(%v)", key, err)
- return
- }
- return
- }
- // UserPackCache user packs
- func (d *Dao) UserPackCache(c context.Context, id int64) (res *unicom.UserPack, err error) {
- var (
- key = keyUserPack(id)
- conn = d.mc.Get(c)
- r *memcache.Item
- )
- defer conn.Close()
- if r, err = conn.Get(key); err != nil {
- log.Error("UserBindCache MemchDB.Get(%s) error(%v)", key, err)
- return
- }
- if err = conn.Scan(r, &res); err != nil {
- log.Error("r.Scan(%s) error(%v)", r.Value, err)
- }
- return
- }
- // AddUserPackCache add user pack cache
- func (d *Dao) AddUserPackCache(c context.Context, id int64, u *unicom.UserPack) (err error) {
- var (
- key = keyUserPack(id)
- conn = d.mc.Get(c)
- )
- if err = conn.Set(&memcache.Item{Key: key, Object: u, Flags: memcache.FlagJSON, Expiration: d.flowKeyExpired}); err != nil {
- log.Error("AddUserPackCache d.mc.Set(%s,%v) error(%v)", key, u, err)
- }
- conn.Close()
- return
- }
- // DeleteUserPackCache delete user pack cache
- func (d *Dao) DeleteUserPackCache(c context.Context, id int64) (err error) {
- var (
- key = keyUserPack(id)
- conn = d.mc.Get(c)
- )
- defer conn.Close()
- if err = conn.Delete(key); err != nil {
- if err == memcache.ErrNotFound {
- err = nil
- return
- }
- log.Error("DeleteUserPackCache MemchDB.Delete(%s) error(%v)", key, err)
- return
- }
- return
- }
- //UserFlowCache unicom flow cache
- func (d *Dao) UserFlowCache(c context.Context, keyStr string) (err error) {
- var (
- key = keyUserFlow(keyStr)
- conn = d.mc.Get(c)
- r *memcache.Item
- res struct{}
- )
- defer conn.Close()
- if r, err = conn.Get(key); err != nil {
- log.Error("UserFlowCache MemchDB.Get(%s) error(%v)", key, err)
- return
- }
- if err = conn.Scan(r, &res); err != nil {
- log.Error("r.Scan(%s) error(%v)", r.Value, err)
- }
- return
- }
- // AddUserFlowCache add user pack cache
- func (d *Dao) AddUserFlowCache(c context.Context, keyStr string) (err error) {
- var (
- key = keyUserFlow(keyStr)
- conn = d.mc.Get(c)
- )
- if err = conn.Set(&memcache.Item{Key: key, Object: struct{}{}, Flags: memcache.FlagJSON, Expiration: d.flowKeyExpired}); err != nil {
- log.Error("AddUserPackCache d.mc.Set(%s) error(%v)", key, err)
- }
- conn.Close()
- return
- }
- // DeleteUserPackCache delete user pack cache
- func (d *Dao) DeleteUserFlowCache(c context.Context, keyStr string) (err error) {
- var (
- key = keyUserFlow(keyStr)
- conn = d.mc.Get(c)
- )
- defer conn.Close()
- if err = conn.Delete(key); err != nil {
- if err == memcache.ErrNotFound {
- err = nil
- return
- }
- log.Error("DeleteUserFlowCache MemchDB.Delete(%s) error(%v)", key, err)
- return
- }
- return
- }
- //UserFlowListCache unicom flow cache
- func (d *Dao) UserFlowListCache(c context.Context) (res map[string]*unicom.UnicomUserFlow, err error) {
- var (
- key = _userflowlistkey
- conn = d.mc.Get(c)
- r *memcache.Item
- )
- defer conn.Close()
- if r, err = conn.Get(key); err != nil {
- if err == memcache.ErrNotFound {
- err = nil
- return
- }
- log.Error("UserFlowListCache MemchDB.Get(%s) error(%v)", key, err)
- return
- }
- if err = conn.Scan(r, &res); err != nil {
- log.Error("r.Scan(%s) error(%v)", r.Value, err)
- }
- return
- }
- // AddUserFlowListCache add user pack cache
- func (d *Dao) AddUserFlowListCache(c context.Context, list map[string]*unicom.UnicomUserFlow) (err error) {
- var (
- key = _userflowlistkey
- conn = d.mc.Get(c)
- )
- if err = conn.Set(&memcache.Item{Key: key, Object: list, Flags: memcache.FlagJSON, Expiration: d.flowKeyExpired}); err != nil {
- log.Error("AddUserFlowListCache d.mc.Set(%s,%v) error(%v)", key, list, err)
- }
- conn.Close()
- return
- }
- //UserFlowWaitCache unicom flow wait
- func (d *Dao) UserFlowWaitCache(c context.Context, phone int) (err error) {
- var (
- key = keyUserflowWait(phone)
- conn = d.mc.Get(c)
- r *memcache.Item
- res struct{}
- )
- defer conn.Close()
- if r, err = conn.Get(key); err != nil {
- log.Error("UserFlowWaitCache MemchDB.Get(%s) error(%v)", key, err)
- return
- }
- if err = conn.Scan(r, &res); err != nil {
- log.Error("r.Scan(%s) error(%v)", r.Value, err)
- }
- return
- }
- // AddUserFlowWaitCache add user flow wait
- func (d *Dao) AddUserFlowWaitCache(c context.Context, phone int) (err error) {
- var (
- key = keyUserflowWait(phone)
- conn = d.mc.Get(c)
- )
- if err = conn.Set(&memcache.Item{Key: key, Object: struct{}{}, Flags: memcache.FlagJSON, Expiration: d.flowWait}); err != nil {
- log.Error("AddUserFlowWaitCache d.mc.Set(%s) error(%v)", key, err)
- }
- conn.Close()
- return
- }
|