You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
128 lines
3.3 KiB
128 lines
3.3 KiB
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 |
|
}
|
|
|