bilibili-backup/app/service/main/point/rpc/server/rpc.go
2019-04-22 02:59:20 +00:00

78 lines
1.9 KiB
Go

package server
import (
"go-common/app/service/main/point/conf"
"go-common/app/service/main/point/model"
"go-common/app/service/main/point/service"
"go-common/library/net/rpc"
"go-common/library/net/rpc/context"
)
// RPC represent rpc server
type RPC struct {
s *service.Service
}
// New init rpc.
func New(c *conf.Config, s *service.Service) (svr *rpc.Server) {
r := &RPC{s: s}
svr = rpc.NewServer(c.RPCServer)
if err := svr.Register(r); err != nil {
panic(err)
}
return
}
// Ping check connection success.
func (r *RPC) Ping(c context.Context, arg *struct{}, res *struct{}) (err error) {
return
}
// Auth check connection success.
func (r *RPC) Auth(c context.Context, arg *rpc.Auth, res *struct{}) (err error) {
return
}
// PointInfo point info.
func (r *RPC) PointInfo(c context.Context, a *model.ArgRPCMid, res *model.PointInfo) (err error) {
var p *model.PointInfo
if p, err = r.s.PointInfo(c, a.Mid); err == nil && p != nil {
*res = *p
}
return
}
// ConsumePoint point consume.
func (r *RPC) ConsumePoint(c context.Context, a *model.ArgPointConsume, status *int8) (err error) {
*status, err = r.s.ConsumePoint(c, a)
return
}
// PointAddByBp point add by bp.
func (r *RPC) PointAddByBp(c context.Context, arg *model.ArgPointAdd, res *int64) (err error) {
*res, err = r.s.PointAddByBp(c, arg)
return
}
// PointAdd point add.
func (r *RPC) PointAdd(c context.Context, a *model.ArgPoint, status *int8) (err error) {
*status, err = r.s.AddPoint(c, a)
return
}
// PointHistory point history.
func (r *RPC) PointHistory(c context.Context, arg *model.ArgRPCPointHistory, res *model.PointHistoryResp) (err error) {
var (
phs []*model.OldPointHistory
total int
)
if phs, total, err = r.s.OldPointHistory(c, arg.Mid, arg.PN, arg.PS); err == nil && len(phs) > 0 {
p := &model.PointHistoryResp{
Phs: phs,
Total: total,
}
*res = *p
}
return
}