171 lines
3.8 KiB
Go
171 lines
3.8 KiB
Go
package svc
|
|
|
|
import (
|
|
"errors"
|
|
"net/rpc"
|
|
"time"
|
|
|
|
"github.com/globalsign/mgo"
|
|
"github.com/globalsign/mgo/bson"
|
|
"mongo.games.com/goserver/core/logger"
|
|
|
|
"mongo.games.com/game/common"
|
|
"mongo.games.com/game/dbproxy/mongo"
|
|
"mongo.games.com/game/model"
|
|
)
|
|
|
|
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()
|
|
}
|
|
var vCard int64 // v卡返还
|
|
for id, v := range args.BagItem {
|
|
if item, exist := bag.BagItem[id]; !exist {
|
|
if v.ItemNum <= 0 {
|
|
err = errors.New("item num not enough")
|
|
break
|
|
}
|
|
bag.BagItem[id] = &model.Item{
|
|
ItemId: v.ItemId,
|
|
ItemNum: v.ItemNum,
|
|
ObtainTime: time.Now().Unix(),
|
|
}
|
|
} else {
|
|
if v.ItemNum < 0 && -v.ItemNum > item.ItemNum {
|
|
err = errors.New("item num not enough")
|
|
break
|
|
}
|
|
item.ItemNum += v.ItemNum
|
|
}
|
|
// v卡返还
|
|
if id == common.ItemIDVCard && args.GainWay == common.GainWay_Exchange && v.ItemNum > 0 {
|
|
vCard = v.ItemNum
|
|
}
|
|
}
|
|
|
|
if err != nil {
|
|
*ret = false
|
|
logger.Logger.Errorf("AddBagItem error: %v", err)
|
|
return err
|
|
}
|
|
|
|
_, err = cbag.Upsert(bson.M{"_id": bag.BagId}, bag)
|
|
if err != nil {
|
|
*ret = false
|
|
logger.Logger.Info("AddBagItem error ", err)
|
|
return err
|
|
}
|
|
|
|
// v卡返还
|
|
if vCard > 0 {
|
|
c := PlayerDataCollection(args.Platform)
|
|
if c != nil {
|
|
err = c.Update(bson.M{"snid": args.SnId}, bson.M{"$inc": bson.M{"vcardcost": -vCard}})
|
|
}
|
|
}
|
|
|
|
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)
|
|
}
|