Files
go-common/app/interface/main/app-feed/dao/upper/dao.go
2019-04-22 18:49:16 +08:00

129 lines
3.3 KiB
Go

package upper
import (
"context"
"time"
"go-common/app/interface/main/app-feed/conf"
article "go-common/app/interface/openplatform/article/model"
feed "go-common/app/service/main/feed/model"
feedrpc "go-common/app/service/main/feed/rpc/client"
"go-common/library/cache/redis"
"go-common/library/ecode"
"go-common/library/net/metadata"
"github.com/pkg/errors"
)
// Dao is feed dao.
type Dao struct {
// rpc
feedRPC *feedrpc.Service
// redis
redis *redis.Pool
expireRds int32
}
// New new a archive dao.
func New(c *conf.Config) (d *Dao) {
d = &Dao{
// rpc
feedRPC: feedrpc.New(c.FeedRPC),
// redis init
redis: redis.NewPool(c.Redis.Upper.Config),
expireRds: int32(time.Duration(c.Redis.Upper.ExpireUpper) / time.Second),
}
return
}
// Ping check redis connection
func (d *Dao) Ping(c context.Context) (err error) {
conn := d.redis.Get(c)
_, err = conn.Do("SET", "PING", "PONG")
conn.Close()
return
}
func (d *Dao) Feed(c context.Context, mid int64, pn, ps int) (fs []*feed.Feed, err error) {
ip := metadata.String(c, metadata.RemoteIP)
arg := &feed.ArgFeed{Mid: mid, Pn: pn, Ps: ps, RealIP: ip}
if fs, err = d.feedRPC.AppFeed(c, arg); err != nil {
if err == ecode.NothingFound {
err = nil
return
}
err = errors.Wrapf(err, "%v", arg)
}
return
}
func (d *Dao) ArchiveFeed(c context.Context, mid int64, pn, ps int) (fs []*feed.Feed, err error) {
ip := metadata.String(c, metadata.RemoteIP)
arg := &feed.ArgFeed{Mid: mid, Pn: pn, Ps: ps, RealIP: ip}
if fs, err = d.feedRPC.ArchiveFeed(c, arg); err != nil {
if err == ecode.NothingFound {
err = nil
return
}
err = errors.Wrapf(err, "%v", arg)
}
return
}
func (d *Dao) BangumiFeed(c context.Context, mid int64, pn, ps int) (fs []*feed.Feed, err error) {
ip := metadata.String(c, metadata.RemoteIP)
arg := &feed.ArgFeed{Mid: mid, Pn: pn, Ps: ps, RealIP: ip}
if fs, err = d.feedRPC.BangumiFeed(c, arg); err != nil {
if err == ecode.NothingFound {
err = nil
return
}
err = errors.Wrapf(err, "%v", arg)
}
return
}
func (d *Dao) Recent(c context.Context, mid, aid int64) (fs []*feed.Feed, err error) {
ip := metadata.String(c, metadata.RemoteIP)
arg := &feed.ArgFold{Mid: mid, Aid: aid, RealIP: ip}
if fs, err = d.feedRPC.Fold(c, arg); err != nil {
if err == ecode.NothingFound {
err = nil
return
}
err = errors.Wrapf(err, "%v", arg)
}
return
}
func (d *Dao) AppUnreadCount(c context.Context, mid int64, withoutBangumi bool) (unread int, err error) {
ip := metadata.String(c, metadata.RemoteIP)
arg := &feed.ArgUnreadCount{Mid: mid, WithoutBangumi: withoutBangumi, RealIP: ip}
if unread, err = d.feedRPC.AppUnreadCount(c, arg); err != nil {
err = errors.Wrapf(err, "%v", arg)
}
return
}
func (d *Dao) ArticleFeed(c context.Context, mid int64, pn, ps int) (fs []*article.Meta, err error) {
ip := metadata.String(c, metadata.RemoteIP)
arg := &feed.ArgFeed{Mid: mid, Pn: pn, Ps: ps, RealIP: ip}
if fs, err = d.feedRPC.ArticleFeed(c, arg); err != nil {
if err == ecode.NothingFound {
err = nil
return
}
err = errors.Wrapf(err, "%v", arg)
}
return
}
func (d *Dao) ArticleUnreadCount(c context.Context, mid int64) (unread int, err error) {
ip := metadata.String(c, metadata.RemoteIP)
arg := &feed.ArgMid{Mid: mid, RealIP: ip}
if unread, err = d.feedRPC.ArticleUnreadCount(c, arg); err != nil {
err = errors.Wrapf(err, "%v", arg)
}
return
}