76 lines
1.8 KiB
Go
76 lines
1.8 KiB
Go
package dao
|
|
|
|
import (
|
|
"context"
|
|
"strconv"
|
|
|
|
"go-common/app/interface/main/dm2/model"
|
|
"go-common/library/cache/redis"
|
|
"go-common/library/log"
|
|
)
|
|
|
|
const (
|
|
_prefixRecent = "dm_rct_"
|
|
)
|
|
|
|
func keyRecent(mid int64) string {
|
|
return _prefixRecent + strconv.FormatInt(mid, 10)
|
|
}
|
|
|
|
// RecentDM get recent dm of up.
|
|
func (d *Dao) RecentDM(c context.Context, mid, start, end int64) (dms []*model.DM, oids []int64, total int64, err error) {
|
|
var (
|
|
conn = d.dmRctRds.Get(c)
|
|
key = keyRecent(mid)
|
|
oidMap = make(map[int64]struct{})
|
|
)
|
|
defer conn.Close()
|
|
if err = conn.Send("ZREVRANGE", key, start, end); err != nil {
|
|
log.Error("conn.Send(ZREVRANGE %s) error(%s)", key, err)
|
|
return
|
|
}
|
|
if err = conn.Send("ZCARD", key); err != nil {
|
|
log.Error("conn.Send(ZCARD %s) error(%v)", key, err)
|
|
return
|
|
}
|
|
if err = conn.Flush(); err != nil {
|
|
log.Error("conn.Flush() error(%v)", err)
|
|
return
|
|
}
|
|
values, err := redis.ByteSlices(conn.Receive())
|
|
if err != nil {
|
|
log.Error("conn.Receive(%s) error(%v)", key, err)
|
|
return
|
|
}
|
|
if total, err = redis.Int64(conn.Receive()); err != nil {
|
|
log.Error("conn.Receive(%s) error(%v)", key, err)
|
|
return
|
|
}
|
|
for _, value := range values {
|
|
dm := &model.DM{}
|
|
if err = dm.Unmarshal(value); err != nil {
|
|
log.Error("dm.Unmarshal(%s) error(%v)", value, err)
|
|
return
|
|
}
|
|
dms = append(dms, dm)
|
|
if _, ok := oidMap[dm.Oid]; !ok {
|
|
oidMap[dm.Oid] = struct{}{}
|
|
oids = append(oids, dm.Oid)
|
|
}
|
|
}
|
|
return
|
|
}
|
|
|
|
// TrimUpRecent zrange remove recent dm of up.
|
|
func (d *Dao) TrimUpRecent(c context.Context, mid, count int64) (err error) {
|
|
var (
|
|
conn = d.dmRctRds.Get(c)
|
|
key = keyRecent(mid)
|
|
)
|
|
defer conn.Close()
|
|
if _, err = conn.Do("ZREMRANGEBYRANK", key, 0, count-1); err != nil {
|
|
log.Error("conn.Do(ZREMRANGEBYRANK %s) error(%v)", key, err)
|
|
}
|
|
return
|
|
}
|