game_sync/dbproxy/svc/u_bag.go

139 lines
3.1 KiB
Go

package svc
import (
"errors"
"net/rpc"
"time"
"github.com/globalsign/mgo"
"github.com/globalsign/mgo/bson"
"mongo.games.com/game/dbproxy/mongo"
"mongo.games.com/game/model"
"mongo.games.com/goserver/core/logger"
)
var (
BagDBName = "user"
BagCollName = "user_bag"
ErrBagDBNotOpen = model.NewDBError(BagDBName, BagCollName, model.NOT_OPEN)
)
func BagCollection(plt string) *mongo.Collection {
s := mongo.MgoSessionMgrSington.GetPltMgoSession(plt, BagDBName)
if s != nil {
c, first := s.DB().C(BagCollName)
if first {
// c.EnsureIndex(mgo.Index{Key: []string{"platform"}, Background: true, Sparse: true})
c.EnsureIndex(mgo.Index{Key: []string{"snid"}, Background: true, Sparse: true})
}
return c
}
return nil
}
type BagSvc struct {
}
func (svc *BagSvc) GetBagItem(args *model.GetBagInfoArgs, ret *model.BagInfo) error {
cbag := BagCollection(args.Plt)
if cbag == nil {
return errors.New("cbag is nil")
}
err := cbag.Find(bson.M{"snid": args.SnId, "platform": &args.Plt}).One(ret)
if err != nil && err != mgo.ErrNotFound {
//if err == mgo.ErrNotFound {
// ret = model.NewBagInfo(args.SnId, args.Plt)
// err = cbag.Insert(ret) // 考虑创建失败~
// logger.Logger.Error("svc.GetBagItem is Insert", err)
// return nil
//}
logger.Logger.Error("svc.GetBagItem is error: ", err)
return nil
}
return nil
}
func (svc *BagSvc) UpgradeBag(args *model.BagInfo, ret *bool) error {
cbag := BagCollection(args.Platform)
if cbag == nil {
return ErrBagDBNotOpen
}
*ret = true
bag := &model.BagInfo{}
err := cbag.Find(bson.M{"snid": args.SnId}).One(bag)
if err != nil && err != mgo.ErrNotFound {
*ret = false
logger.Logger.Error("UpgradeBag err:", err)
return err
}
args.BagId = bag.BagId
if args.BagId == "" {
args.BagId = bson.NewObjectId()
}
_, err = cbag.Upsert(bson.M{"_id": args.BagId}, args)
if err != nil {
*ret = false
logger.Logger.Info("UpgradeBag error ", err)
}
return err
}
func (svc *BagSvc) AddBagItem(args *model.BagInfo, ret *bool) error {
cbag := BagCollection(args.Platform)
if cbag == nil {
return ErrBagDBNotOpen
}
*ret = true
bag := &model.BagInfo{}
err := cbag.Find(bson.M{"snid": args.SnId}).One(bag)
if err != nil && err != mgo.ErrNotFound {
*ret = false
logger.Logger.Error("AddBagItem err:", err)
return err
}
if bag.BagId == "" {
bag.BagId = bson.NewObjectId()
}
for id, v := range args.BagItem {
if item, exist := bag.BagItem[id]; !exist {
bag.BagItem[id] = &model.Item{
ItemId: v.ItemId,
ItemNum: v.ItemNum,
ObtainTime: time.Now().Unix(),
}
} else {
item.ItemNum += v.ItemNum
}
}
_, err = cbag.Upsert(bson.M{"_id": bag.BagId}, bag)
if err != nil {
*ret = false
logger.Logger.Info("AddBagItem error ", err)
}
return err
}
func (svc *BagSvc) UpdateBag(args *model.BagInfo, ret *bool) error {
cbag := BagCollection(args.Platform)
if cbag == nil {
*ret = false
return ErrBagDBNotOpen
}
*ret = true
err := cbag.UpdateId(args.BagId, args)
if err != nil {
*ret = false
logger.Logger.Info("UpdateBag error:", err)
}
return err
}
var _BagSvc = &BagSvc{}
func init() {
rpc.Register(_BagSvc)
}