game_sync/dbproxy/svc/u_player.go

1683 lines
47 KiB
Go

package svc
import (
"encoding/json"
"errors"
"fmt"
"net/rpc"
"os"
"reflect"
"strconv"
"strings"
"time"
"mongo.games.com/goserver/core/basic"
"mongo.games.com/goserver/core/task"
"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 (
PlayerDBName = "user"
PlayerCollName = "user_playerinfo"
PlayerDelBackupCollName = "user_playerinfo_del_backup"
PlayerColError = errors.New("Playerinfo collection open failed")
)
func PlayerDataCollection(plt string) *mongo.Collection {
s := mongo.MgoSessionMgrSington.GetPltMgoSession(plt, PlayerDBName)
if s != nil {
c_playerdata, first := s.DB().C(PlayerCollName)
if first {
c_playerdata.EnsureIndex(mgo.Index{Key: []string{"accountid"}, Unique: true, Background: true, Sparse: true})
c_playerdata.EnsureIndex(mgo.Index{Key: []string{"snid"}, Unique: true, Background: true, Sparse: true})
c_playerdata.EnsureIndex(mgo.Index{Key: []string{"channel"}, Background: true, Sparse: true})
c_playerdata.EnsureIndex(mgo.Index{Key: []string{"tel"}, Background: true, Sparse: true})
c_playerdata.EnsureIndex(mgo.Index{Key: []string{"bankaccount"}, Background: true, Sparse: true})
c_playerdata.EnsureIndex(mgo.Index{Key: []string{"alipayaccount"}, Background: true, Sparse: true})
c_playerdata.EnsureIndex(mgo.Index{Key: []string{"alipayaccname"}, Background: true, Sparse: true})
c_playerdata.EnsureIndex(mgo.Index{Key: []string{"bankaccname"}, Background: true, Sparse: true})
c_playerdata.EnsureIndex(mgo.Index{Key: []string{"invitecode"}, Background: true, Sparse: true})
c_playerdata.EnsureIndex(mgo.Index{Key: []string{"invitesnid"}, Background: true, Sparse: true})
c_playerdata.EnsureIndex(mgo.Index{Key: []string{"name"}, Background: true, Sparse: true})
}
return c_playerdata
}
return nil
}
type PlayerDelBackupDataSvc struct {
}
func PlayerDelBackupDataCollection(plt string) *mongo.Collection {
s := mongo.MgoSessionMgrSington.GetPltMgoSession(plt, PlayerDBName)
if s != nil {
c_playerdata, _ := s.DB().C(PlayerDelBackupCollName)
return c_playerdata
}
return nil
}
type PlayerDataSvc struct {
}
//func (svc *PlayerDataSvc) SavePlayerRebate(pd *model.PlayerData, ret *bool) error {
// cplayerdata := PlayerDataCollection(pd.Platform)
// if cplayerdata == nil {
// return nil
// }
// err := cplayerdata.Update(bson.M{"snid": pd.SnId}, bson.D{{"$set", bson.D{{"rebatedata", pd.RebateData}, {"totalconvertibleflow", pd.TotalConvertibleFlow}}}})
// if err != nil {
// logger.Logger.Trace("SavePlayerRebate failed:", err)
// ret.Err = err
// return err
// }
// return nil
//}
// 获取代理信息
func (svc *PlayerDataSvc) GetAgentInfo(args *model.GetAgentInfoArgs, ret *model.PlayerData) error {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return nil
}
err := cplayerdata.Find(bson.M{"tel": args.Tel}).One(ret)
if err != nil {
logger.Logger.Error("GetAgentInfo failed:", err)
return err
}
if CorrectData(ret) {
}
return nil
}
func (svc *PlayerDataSvc) GetPlayerData(args *model.GetPlayerDataArgs, ret *model.PlayerDataRet) error {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return nil
}
pd := &model.PlayerData{}
fileName := fmt.Sprintf("%v.json", args.Acc)
_, err := os.Stat(fileName)
if err == nil || os.IsExist(err) {
pd = model.RestorePlayerData(fileName)
err = os.Remove(fileName)
} else {
if args.Acc != "" {
err = cplayerdata.Find(bson.M{"accountid": args.Acc}).One(pd)
}
}
if err != nil && err.Error() == mgo.ErrNotFound.Error() {
logger.Logger.Trace("GetPlayerinfo Find failed:", err)
if !bson.IsObjectIdHex(args.Acc) {
logger.Logger.Warn("NewPlayer failed: acc is illeage ", args.Acc)
return nil
}
a, err := _AccountSvc.getAccount(args.Plt, args.Acc)
if err != nil {
logger.Logger.Warnf("model.GetAccount(%v) failed:%v", args.Acc, err)
return nil
}
id := a.SnId
if id == 0 {
id, err = GetOnePlayerIdFromBucket()
if err != nil {
logger.Logger.Warn("NewPlayer failed:", err)
return err
}
}
var dataParams model.PlayerParams
json.Unmarshal([]byte(a.Params), &dataParams)
name := dataParams.Name
if name == "" {
name = model.GameParamData.GuestDefaultName //fmt.Sprintf("Guest%v", id)
}
if name == "" {
name = "Guest"
}
pd = model.NewPlayerData(args.Acc, name, id, a.Channel, a.Platform, a.Promoter, a.InviterId, a.PromoterTree, a.Params,
a.Tel, a.PackegeTag, dataParams.Ip, 0, dataParams.UnionId, a.DeviceInfo, a.SubPromoter, a.TagKey, a.AccountType)
if pd != nil {
err = cplayerdata.Insert(pd)
if err != nil {
logger.Logger.Errorf("GetPlayerinfo Insert err:%v acc:%v snid:%v", err, args.Acc, id)
return err
}
ret.IsNew = true
ret.Pd = pd
return nil
}
return nil
}
//todo 修正玩家的离线时间,上次登录时间,创建时间
pd.LastLogoutTime = pd.LastLogoutTime.Local()
pd.LastLoginTime = pd.LastLoginTime.Local()
pd.CreateTime = pd.CreateTime.Local()
if CorrectData(pd) {
}
ret.Pd = pd
return nil
}
// 谷歌 facebook 账号数据
func (svc *PlayerDataSvc) CreatePlayerDataByThird(args *model.CreatePlayer, ret *model.PlayerDataRet) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
acc := args.AccId
pd := &model.PlayerData{}
fileName := fmt.Sprintf("%v.json", acc)
_, err = os.Stat(fileName)
if err == nil || os.IsExist(err) {
pd = model.RestorePlayerData(fileName)
err = os.Remove(fileName)
} else {
if acc != "" {
err = cplayerdata.Find(bson.M{"accountid": acc}).One(pd)
}
}
if err != nil && err.Error() == mgo.ErrNotFound.Error() {
logger.Logger.Trace("CreatePlayerDataByThird Find failed:", err)
if !bson.IsObjectIdHex(acc) {
logger.Logger.Warn("NewPlayer failed: acc is illeage ", acc)
return
}
var a *model.Account
a, err = _AccountSvc.getAccount(args.Plt, args.AccId)
if err != nil {
logger.Logger.Warnf("_AccountSvc.getAccount(%v,%v) failed:%v", args.Plt, args.AccId, err)
return
}
id := a.SnId
if id == 0 {
id, err = GetOnePlayerIdFromBucket()
if err != nil {
logger.Logger.Warn("NewPlayer failed:", err)
return
}
}
//name := model.GameParamData.GuestDefaultName //fmt.Sprintf("db%v", id)
name := args.NickName
if name == "" {
name = "Guest"
}
var dataParams model.PlayerParams
json.Unmarshal([]byte(a.Params), &dataParams)
pd = model.NewPlayerDataThird(acc, name, args.HeadUrl, id, a.Channel, a.Platform, a.Promoter, a.InviterId,
a.PromoterTree, a.Params, a.Tel, a.PackegeTag, dataParams.Ip, a.SubPromoter, a.TagKey, a.AccountType, a.DeviceOs)
if pd != nil {
err = cplayerdata.Insert(pd)
if err != nil {
logger.Logger.Trace("CreatePlayerDataByThird Insert failed:", err)
return
}
ret.Pd = pd
ret.IsNew = true
return
}
return
}
if CorrectData(pd) {
}
ret.Pd = pd
return nil
}
func (svc *PlayerDataSvc) CreatePlayerDataOnRegister(args *model.PlayerDataArg, ret *model.PlayerDataRet) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
acc := args.AccId
pd := &model.PlayerData{}
fileName := fmt.Sprintf("%v.json", acc)
_, err = os.Stat(fileName)
if err == nil || os.IsExist(err) {
pd = model.RestorePlayerData(fileName)
err = os.Remove(fileName)
} else {
if acc != "" {
err = cplayerdata.Find(bson.M{"accountid": acc}).One(pd)
}
}
if err != nil && err.Error() == mgo.ErrNotFound.Error() {
logger.Logger.Trace("CreatePlayerDataOnRegister Find failed:", err)
if !bson.IsObjectIdHex(acc) {
logger.Logger.Warn("NewPlayer failed: acc is illeage ", acc)
return
}
var a *model.Account
a, err = _AccountSvc.getAccount(args.Plt, args.AccId)
if err != nil {
logger.Logger.Warnf("_AccountSvc.getAccount(%v,%v) failed:%v", args.Plt, args.AccId, err)
return
}
id := a.SnId
if id == 0 {
id, err = GetOnePlayerIdFromBucket()
if err != nil {
logger.Logger.Warn("NewPlayer failed:", err)
return
}
}
name := model.GameParamData.GuestDefaultName //fmt.Sprintf("Guest%v", id)
if name == "" && args.Name != "" {
name = args.Name
}
if name == "" {
name = "Guest"
}
var dataParams model.PlayerParams
json.Unmarshal([]byte(a.Params), &dataParams)
pd = model.NewPlayerData(acc, name, id, a.Channel, a.Platform, a.Promoter, a.InviterId,
a.PromoterTree, a.Params, a.Tel, a.PackegeTag, dataParams.Ip, int64(args.AddCoin),
"", a.DeviceInfo, a.SubPromoter, a.TagKey, a.AccountType)
pd.HeadUrl = args.HeadUrl
if pd != nil {
err = cplayerdata.Insert(pd)
if err != nil {
logger.Logger.Trace("CreatePlayerDataOnRegister Insert failed:", err)
return
}
ret.Pd = pd
ret.IsNew = true
return
}
return
}
if CorrectData(pd) {
}
ret.Pd = pd
return
}
func (svc *PlayerDataSvc) GetPlayerDataBySnId(args *model.GetPlayerDataBySnIdArgs, ret *model.PlayerDataRet) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return nil
}
var code string
err = cplayerdata.Find(bson.M{"snid": args.SnId}).One(&ret.Pd)
if err != nil {
logger.Logger.Tracef("from %v Get %v player data error:%v", args.Plt, args.SnId, err)
if args.CreateIfNotExist && err == mgo.ErrNotFound {
a, err := _AccountSvc.getAccountBySnId(args.Plt, args.SnId)
if err != nil {
logger.Logger.Warnf("model.getAccountBySnId(%v) failed:%v", args.SnId, err)
return err
}
var dataParams model.PlayerParams
json.Unmarshal([]byte(a.Params), &dataParams)
name := dataParams.Name
if name == "" {
name = model.GameParamData.GuestDefaultName //fmt.Sprintf("Guest%v", id)
}
if name == "" {
name = "Guest"
}
pd := model.NewPlayerData(a.AccountId.Hex(), name, a.SnId, a.Channel, a.Platform, a.Promoter, a.InviterId, a.PromoterTree, a.Params,
a.Tel, a.PackegeTag, dataParams.Ip, 0, dataParams.UnionId, a.DeviceInfo, a.SubPromoter, a.TagKey, a.AccountType)
if pd != nil {
err = cplayerdata.Insert(pd)
if err != nil {
logger.Logger.Errorf("GetPlayerDataBySnId Insert err:%v acc:%v snid:%v", err, a.AccountId.Hex(), a.SnId)
return err
}
if pd.InviteCode == "" {
code, err = GetInviteCode(pd.Platform, pd.SnId)
pd.InviteCode = code
}
ret.IsNew = true
ret.Pd = pd
return nil
}
}
return err
}
if ret.Pd.InviteCode == "" {
code, err = GetInviteCode(ret.Pd.Platform, ret.Pd.SnId)
ret.Pd.InviteCode = code
}
if args.CorrectData && ret.Pd != nil {
CorrectData(ret.Pd)
}
return nil
}
//func (svc *PlayerDataSvc) UpdateCreateCreateClubNum(snId int32, ret *model.PlayerDataRet) error {
// cplayerdata := PlayerDataCollection()
// if cplayerdata == nil {
// return nil
// }
// err := cplayerdata.Update(bson.M{"snid": snId}, bson.D{{"$inc", bson.D{{"createclubnum", 1}}}})
// if err != nil {
// logger.Logger.Error("Update player safeboxcoin error:", err)
// ret.Err = err
// return err
// }
// return nil
//}
func (svc *PlayerDataSvc) GetPlayerDatasBySnIds(args *model.GetPlayerDatasBySnIdsArgs, ret *[]*model.PlayerData) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return nil
}
err = cplayerdata.Find(bson.M{"snid": bson.M{"$in": args.SnIds}}).All(ret)
if err != nil {
logger.Logger.Tracef("GetPlayerDatasBySnIds(snids=%v) error:%v", args.SnIds, err)
return
}
if args.CorrectData {
for _, e := range *ret {
if CorrectData(e) {
}
}
}
return
}
func (svc *PlayerDataSvc) GetPlayerDataByUnionId(args *model.GetPlayerDataByUnionIdArgs, ret *model.PlayerDataRet) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
err = cplayerdata.Find(bson.M{"unionid": args.UnionId}).One(&ret.Pd)
if err != nil {
logger.Logger.Tracef("GetPlayerDataByUnionId % player data error:%v", args.UnionId, err)
return
}
if args.CorrectData {
if CorrectData(ret.Pd) {
}
}
return
}
func (svc *PlayerDataSvc) GetPlayerTel(args *model.GetPlayerTelArgs, ret *model.GetPlayerTelRet) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
err = cplayerdata.Find(bson.M{"tel": args.Tel}).Select(bson.M{"snid": 1}).One(ret)
if err != nil {
logger.Logger.Warn("model.PlayerData.Find err:", err)
return
}
return
}
func (svc *PlayerDataSvc) GetPlayerCoin(args *model.GetPlayerCoinArgs, ret *model.GetPlayerCoinRet) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
err = cplayerdata.Find(bson.M{"snid": args.SnId}).Select(bson.M{"coin": 1, "safeboxcoin": 1}).One(ret)
if err != nil {
logger.Logger.Trace("GetPlayerCoin error:", err)
ret.Err = err
return
}
return
}
func SavePlayerData(pd *model.PlayerData) (err error) {
cplayerdata := PlayerDataCollection(pd.Platform)
if cplayerdata == nil {
return
}
if pd != nil {
model.RecalcuPlayerCheckSum(pd)
_, err = cplayerdata.Upsert(bson.M{"_id": pd.Id}, pd)
if err != nil {
logger.Logger.Errorf("model.SavePlayerData %v err:%v", pd.SnId, err)
return
}
//清理coinWAL
task.New(nil, task.CallableWrapper(func(o *basic.Object) interface{} {
RemoveCoinWALByCoinType(pd.Platform, pd.SnId, PayCoinLogType_Coin, pd.CoinPayTs)
RemoveCoinWALInGame(pd.Platform, pd.SnId, 0, pd.GameCoinTs)
return nil
}), nil, "RemoveCoinWAL").StartByFixExecutor("RemoveCoinWAL")
}
return
}
/*
* 保存玩家的全部信息
*/
func (svc *PlayerDataSvc) SavePlayerData(pd *model.PlayerData, ret *bool) (err error) {
err = SavePlayerData(pd)
*ret = err == nil
return
}
func (svc *PlayerDataSvc) RemovePlayer(args *model.RemovePlayerArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return nil
}
err = cplayerdata.Remove(bson.M{"snid": args.SnId})
if err != nil {
logger.Logger.Info("Remove player failed.")
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) RemovePlayerByAcc(args *model.RemovePlayerByAccArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return nil
}
err = cplayerdata.Remove(bson.M{"accountid": args.Acc})
if err != nil {
logger.Logger.Info("Remove player failed.")
return
}
*ret = true
return
}
/*
* 检查手机号是否存在
*/
func (svc *PlayerDataSvc) GetPlayerSnid(args *model.GetPlayerSnidArgs, ret *int32) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
err = cplayerdata.Find(bson.M{"accountid": args.Acc}).Select(bson.M{"snid": 1}).One(ret)
if err != nil {
logger.Logger.Error("svc.GetPlayerSnid is error ", err)
return
}
return
}
/*
* 检查昵称是否存在
*/
func (svc *PlayerDataSvc) PlayerNickIsExist(args *model.PlayerNickIsExistArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
err = cplayerdata.Find(bson.M{"name": args.Name}).One(nil)
if err != nil {
logger.Logger.Error("svc.PlayerNickIsExist is error", err)
return err
}
*ret = true
return
}
/*
* 检查玩家是否存在
*/
func (svc *PlayerDataSvc) PlayerIsExistBySnId(args *model.PlayerIsExistBySnIdArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
err = cplayerdata.Find(bson.M{"snid": args.SnId}).One(nil)
if err != nil {
logger.Logger.Error("svc.GetPlayerIsExistBySnId is error", err)
return
}
*ret = true
return
}
// 修改推广包标识
func (svc *PlayerDataSvc) UpdatePlayerPackageId(args *model.UpdatePackageId, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.PlatformStr)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.M{"packageid": args.Tag,
"platform": strconv.Itoa(int(args.Platform)), "channel": strconv.Itoa(int(args.Channel)),
"beunderagentcode": strconv.Itoa(int(args.Promoter)), "inviterid": args.Inviterid, "promotertree": args.PromoterTree}}})
if err != nil {
logger.Logger.Error("Update player packageid error:", err)
return err
}
*ret = true
return nil
}
func (svc *PlayerDataSvc) UpdatePlayerPackageIdByStr(args *model.UpdatePackageId, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.PlatformStr)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.M{"packageid": args.Tag,
"platform": args.PlatformStr, "channel": args.ChannelStr,
"beunderagentcode": args.PromoterStr, "inviterid": args.Inviterid, "promotertree": args.PromoterTree}}})
if err != nil {
logger.Logger.Trace("UpdatePlayerPackageIdByStr error:", err)
return err
}
*ret = true
return nil
}
func (svc *PlayerDataSvc) UpdatePlayerPackageIdByAcc(args *model.UpdatePackageId, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.PlatformStr)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"accountid": args.AccId}, bson.D{{"$set", bson.M{"packageid": args.Tag,
"platform": args.PlatformStr, "channel": args.ChannelStr,
"beunderagentcode": args.PromoterStr, "inviterid": args.Inviterid, "promotertree": args.PromoterTree}}})
if err != nil {
logger.Logger.Trace("UpdatePlayerPackageIdByAcc error:", err)
return
}
*ret = true
return
}
// 修改平台
func (svc *PlayerDataSvc) UpdatePlayerPlatform(args *model.UpdatePackageId, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.PlatformStr)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set",
bson.D{{"platform", args.PlatformStr}, {"channel", args.ChannelStr}}}})
if err != nil {
logger.Logger.Trace("Update player nick error:", err)
return
}
*ret = true
return
}
// 修改玩家无级代推广员id
func (svc *PlayerDataSvc) UpdatePlayerPromoterTree(args *model.UpdatePackageId, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.PlatformStr)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{{"promotertree", args.PromoterTree}}}})
if err != nil {
logger.Logger.Trace("UpdatePlayerPromoterTree error:", err)
return
}
*ret = true
return
}
// 修改玩家全民推广
func (svc *PlayerDataSvc) UpdatePlayerInviteID(args *model.UpdatePackageId, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.PlatformStr)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{{"inviterid", args.Inviterid}}}})
if err != nil {
logger.Logger.Trace("UpdatePlayerInviteID error:", err)
return
}
*ret = true
return
}
/*
* 修改昵称
*/
func (svc *PlayerDataSvc) UpdatePlayerNick(args *model.UpdatePlayerInfo, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
err = cplayerdata.Update(bson.M{"accountid": args.Acc}, bson.D{{"$set", bson.D{{"name", args.Nick}}}})
if err != nil {
logger.Logger.Trace("Update player nick error:", err)
return
}
*ret = true
return
}
/*
* 修改黑名单类型
*/
func (svc *PlayerDataSvc) UpdatePlayerBlacklistType(args *model.UpdatePlayerBlacklistTypeArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{{"blacklisttype", args.BlackListType}}}})
if err != nil {
logger.Logger.Trace("Update player blacklisttype error:", err)
return
}
*ret = true
return
}
/*
* 修改玩家备注信息
*/
func (svc *PlayerDataSvc) UpdatePlayerMarkInfo(args *model.UpdatePlayerMarkInfoArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{{"markinfo", args.MarkInfo}}}})
if err != nil {
logger.Logger.Warnf("Update player mark error:", err)
return
}
*ret = true
return
}
/*
* 修改玩家特殊白名单
*/
func (svc *PlayerDataSvc) UpdatePlayerWhiteFlag(args *model.UpdatePlayerWhiteFlagArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{{"whiteflag", args.WhiteFlag}}}})
if err != nil {
logger.Logger.Warnf("Update player whiteFlag error:", err)
}
*ret = true
return
}
/*
* 修改玩家支付信息
*/
func (svc *PlayerDataSvc) UpdatePlayerPayAct(args *model.UpdatePlayerPayActArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{{"payactstate", args.PayActState}}}})
if err != nil {
logger.Logger.Warnf("Update player payact error:", err)
return
}
*ret = true
return
}
/*
* 修改玩家电销标记
*/
func (svc *PlayerDataSvc) UpdatePlayerTelephonePromoter(args *model.UpdatePlayerTelephonePromoterArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set",
bson.D{{"telephonepromoter", args.TelephonePromoter}}}})
if err != nil {
logger.Logger.Warnf("Update player telephonepromoter error:", err)
return
}
*ret = true
return
}
/*
* 修改玩家电销标记
*/
func (svc *PlayerDataSvc) UpdatePlayerTelephoneCallNum(args *model.UpdatePlayerTelephonePromoterArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set",
bson.D{{"telephonecallnum", args.TelephoneCallNum}}}})
if err != nil {
logger.Logger.Warnf("Update player telephonecallnum error:", err)
return
}
*ret = true
return
}
/*
* 修改头像
*/
func (svc *PlayerDataSvc) UpdatePlayeIcon(args *model.UpdatePlayeIconArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
err = cplayerdata.Update(bson.M{"accountid": args.Acc}, bson.D{{"$set", bson.D{{"head", args.Head}}}})
if err != nil {
logger.Logger.Trace("Update player icon error:", err)
return
}
*ret = true
return
}
/*
* 修改性别
*/
func (svc *PlayerDataSvc) UpdatePlayeSex(args *model.UpdatePlayeSexArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
err = cplayerdata.Update(bson.M{"accountid": args.Acc}, bson.D{{"$set", bson.D{{"sex", args.Sex}}}})
if err != nil {
logger.Logger.Trace("Update player sex error:", err)
return
}
*ret = true
return
}
/*
* 检查手机号是否存在
*/
func (svc *PlayerDataSvc) PlayerTelIsExist(args *model.PlayerTelIsExistArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return
}
err = cplayerdata.Find(bson.M{"tel": args.Tel, "tagkey": args.TagKey}).One(nil)
if err != nil {
return
}
*ret = true
return
}
/*
* 绑定手机号
*/
func (svc *PlayerDataSvc) UpdatePlayerTel(args *model.UpdatePlayerTelArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{{"tel", args.Tel}}}})
if err != nil {
logger.Logger.Warn("UpdatePlayerTel error:", err)
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) ResetPlayer(args *model.ResetPlayerArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{{"tel", ""}, {"delete", 1}}}})
if err != nil {
logger.Logger.Warn("UpdatePlayerTel error:", err)
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) CountAlipayAccountCount(args *model.CountAlipayAccountCountArgs, ret *int) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return
}
n, err := cplayerdata.Find(bson.M{"alipayaccount": args.AliPayAccount}).Count()
if err != nil {
logger.Logger.Warn("CountAlipayAccountCount error:", err)
return err
}
*ret = n
return
}
func (svc *PlayerDataSvc) CountBankAlipayNameCount(args *model.CountBankAlipayNameCountArgs, ret *int) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return
}
var conds []bson.M
conds = append(conds, bson.M{"alipayaccname": args.AliPayAccName})
conds = append(conds, bson.M{"bankaccname": args.BankAccName})
n, err := cplayerdata.Find(bson.M{"snid": bson.M{"$ne": args.SnId}, "$or": conds}).Count()
if err != nil {
logger.Logger.Warn("CountBankAlipayNameCount error:", err)
return
}
*ret = n
return
}
/*
* 绑定支付宝账号
*/
func (svc *PlayerDataSvc) UpdatePlayerAlipay(args *model.UpdatePlayerAlipayArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set",
bson.D{{"alipayaccount", args.AliPayAccount}, {"alipayaccname", args.AliPayAccName}}}})
if err != nil {
logger.Logger.Warn("UpdatePlayerAlipay error:", err)
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) UpdatePlayerAlipayAccount(args *model.UpdatePlayerAlipayArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{{"alipayaccount", args.AliPayAccount}}}})
if err != nil {
logger.Logger.Warn("UpdatePlayerAlipay error:", err)
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) UpdatePlayerAlipayName(args *model.UpdatePlayerAlipayArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set",
bson.D{{"alipayaccname", args.AliPayAccName}}}})
if err != nil {
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) CountBankAccountCount(args *model.CountBankAccountCountArgs, ret *int) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return
}
n, err := cplayerdata.Find(bson.M{"bankaccount": args.BankAccount}).Count()
if err != nil {
logger.Logger.Warn("CountBankAccountCount error:", err)
return
}
*ret = n
return
}
/*
* 绑定银行账号
*/
func (svc *PlayerDataSvc) UpdatePlayerBank(args *model.UpdatePlayerBankArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return errors.New("user_playerinfo not open")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{{"bank", args.Bank},
{"bankaccount", args.BankAccount}, {"bankaccname", args.BankAccName}}}})
if err != nil {
logger.Logger.Warn("UpdatePlayerBank error:", err)
return
}
*ret = true
return
}
/*
* 修改玩家是否返利
*/
func (svc *PlayerDataSvc) UpdatePlayerIsRebate(args *model.UpdatePlayerIsRebateArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{{"iscanrebate", args.IsCanRebate}}}})
if err != nil {
logger.Logger.Trace("Update player isRebate error:", err)
return
}
*ret = true
return
}
/*
* 修改玩家是否可以修改昵称
*/
func (svc *PlayerDataSvc) UpdatePlayerIsStopRename(args *model.UpdatePlayerIsStopRenameArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return errors.New("param err")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{{"isstoprename", args.IsStopReName}}}})
if err != nil {
logger.Logger.Trace("Update player isRename error:", err)
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) PlayerRebindSnId(args *model.PlayerRebindSnIdArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return errors.New("cplayerdata == nil")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{{"snid", args.NewSnId}}}})
if err != nil {
logger.Logger.Trace("PlayerRebindSnId error:", err)
return
}
*ret = true
return
}
/*
* 修改保险箱密码
*/
func (svc *PlayerDataSvc) UpdateSafeBoxPassword(args *model.PlayerSafeBoxArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return
}
err = cplayerdata.Update(bson.M{"accountid": args.Acc, "safeboxpassword": args.OldPassWord},
bson.D{{"$set", bson.D{{"safeboxpassword", args.PassWord}}}})
if err != nil {
logger.Logger.Trace("Update player safeboxpassword error:", err)
return
}
*ret = true
return
}
/*
* 找回保险箱密码
*/
func (svc *PlayerDataSvc) GetBackSafeBoxPassword(args *model.PlayerSafeBoxArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return errors.New("GetBackSafeBoxPassword error")
}
err = cplayerdata.Update(bson.M{"tel": args.Tel, "tagkey": args.TagKey},
bson.D{{"$set", bson.D{{"safeboxpassword", args.PassWord}}}})
if err != nil {
logger.Logger.Trace("Update player safeboxpassword error:", err)
return
}
*ret = true
return
}
/*
* 重置保险箱密码
*/
func (svc *PlayerDataSvc) ResetSafeBoxPassword(args *model.PlayerSafeBoxArgs, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return PlayerColError
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{{"safeboxpassword", args.PassWord}}}})
if err != nil {
logger.Logger.Trace("Reset player safeboxpassword error:", err)
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) UpdatePlayerCoin(args *model.PlayerSafeBoxCoin, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return fmt.Errorf("db may be closed")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{
{"coin", args.Coin},
{"diamond", args.Diamond},
{"safeboxcoin", args.SafeBoxCoin},
{"coinpayts", args.CoinPayTs},
{"safeboxcoints", args.SafeBoxCoinTs},
{"moneypaytotal", args.Money},
{"shopid", args.ShopId}}}})
if err != nil {
logger.Logger.Error("UpdatePlayerCoin error:", err)
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) UpdatePlayerSetCoin(args *model.PlayerSafeBoxCoin, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return fmt.Errorf("db may be closed")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{
{"coin", args.Coin}}}})
if err != nil {
logger.Logger.Error("svc.UpdatePlayerSetCoin error:", err)
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) UpdatePlayerLastExchangeTime(args *model.PlayerSafeBoxCoin, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return fmt.Errorf("db may be closed")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{
{"lastexchangetime", args.LastexChangeTime}}}})
if err != nil {
logger.Logger.Error("svc.UpdateLastExchangeTime error:", err)
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) UpdatePlayerExchageFlow(args *model.PlayerSafeBoxCoin, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return fmt.Errorf("db may be closed")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{
{"totalconvertibleflow", args.TotalConvertibleFlow},
{"totalflow", args.TotalFlow}}}})
if err != nil {
logger.Logger.Error("svc.UpdatePlayerExchageFlow error:", err)
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) UpdatePlayerExchageFlowAndOrder(args *model.PlayerSafeBoxCoin, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return fmt.Errorf("db may be closed")
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bson.D{
{"totalconvertibleflow", args.TotalConvertibleFlow},
{"lastexchangeorder", args.LastexChangeOrder}}}})
if err != nil {
logger.Logger.Error("svc.UpdatePlayerExchageFlowAndOrder error:", err)
return
}
*ret = true
return
}
/*
* 查找用户
*/
func (svc *PlayerDataSvc) FindPlayerList(args *model.PlayerSelect, ret *[]*model.PlayerBaseInfo) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return
}
var conds []bson.M
if args.Id != 0 {
conds = append(conds, bson.M{"snid": args.Id})
}
if len(args.Tel) > 0 {
conds = append(conds, bson.M{"tel": args.Tel})
}
if len(args.NickName) > 0 {
conds = append(conds, bson.M{"name": args.NickName})
}
if args.Coinl > 0 || args.Coinh > 0 {
conds = append(conds, bson.M{"coin": bson.M{"$gt": args.Coinl, "$lt": args.Coinh}})
}
if len(args.Alipay) > 0 {
conds = append(conds, bson.M{"alipayaccount": args.Alipay})
}
if args.Registerl > 0 || args.Registerh > 0 {
conds = append(conds, bson.M{"createtime": bson.M{"$gt": time.Unix(int64(args.Registerl), 0), "$lt": time.Unix(int64(args.Registerh), 0)}})
}
if len(args.Channel) > 0 {
conds = append(conds, bson.M{"channel": args.Channel})
}
selecter := bson.M{"$or": conds}
if args.Limit > 0 {
err = cplayerdata.Find(selecter).Limit(args.Limit).All(ret)
} else {
err = cplayerdata.Find(selecter).All(ret)
}
if err != nil {
logger.Logger.Error("svc.FindPlayerList is error", err)
return nil
}
return
}
func (svc *PlayerDataSvc) UpdatePlayerElement(args *model.UpdateElement, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return fmt.Errorf("db may be close")
}
playerMap := make(map[string]interface{})
json.Unmarshal([]byte(args.PlayerMap), &playerMap)
var o model.PlayerData
r_t := reflect.TypeOf(o)
var bsonInfo bson.D
var docelem bson.DocElem
for k, v := range playerMap {
if f, ok := r_t.FieldByName(k); ok {
if reflect.TypeOf(v).ConvertibleTo(f.Type) {
docelem.Name = strings.ToLower(k)
docelem.Value = v
bsonInfo = append(bsonInfo, docelem)
} else {
logger.Logger.Warnf("UpdatePlayerElement Type not fit %v field, get %v", k, v)
}
} else {
logger.Logger.Warnf("UpdatePlayerElement no %v field", k)
}
}
err = cplayerdata.Update(bson.M{"snid": args.SnId}, bson.D{{"$set", bsonInfo}})
if err != nil {
logger.Logger.Warnf("UpdatePlayerElement error:%v", err)
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) GetPlayerBaseInfo(args *model.GetPlayerBaseInfoArgs, ret *model.PlayerBaseInfo) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
err = cplayerdata.Find(bson.M{"snid": args.SnId, "platform": &args.Plt}).One(ret)
if err != nil && err != mgo.ErrNotFound {
logger.Logger.Error("svc.GetPlayerBaseInfo is error: ", err)
return
}
return
}
func (svc *PlayerDataSvc) SetBlackWhiteLevel(args *model.BlackWhiteLevel, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return nil
}
cond := bson.M{"snid": args.SnId}
if args.Platform != "" {
cond["platform"] = args.Platform
}
err = cplayerdata.Update(cond, bson.D{{"$set", bson.D{{"wblevel", args.WBLevel},
{"wbcointotalin", args.WbCoinTotalIn},
{"wbcointotalout", args.WbCoinTotalOut}, {"wbcoinlimit", args.WbCoinLimit},
{"wbtime", args.T}, {"wbmaxnum", args.WbMaxNum}, {"wbstate", args.WbState}}}})
if err != nil {
logger.Logger.Info("SetBlackWhiteLevel error ", err)
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) SetBlackWhiteLevelUnReset(args *model.BlackWhiteLevel, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return nil
}
cond := bson.M{"snid": args.SnId}
err = cplayerdata.Update(cond, bson.D{{"$set", bson.D{{"wblevel", args.WBLevel},
{"wbcoinlimit", args.WbCoinLimit},
{"wbtime", args.T}, {"wbmaxnum", args.WbMaxNum}, {"wbstate", args.WbState}}}})
if err != nil {
logger.Logger.Info("SetBlackWhiteLevel error ", err)
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) UpdateAllPlayerPackageTag(args *model.UpdatePackageId, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.PlatformStr)
if cplayerdata == nil {
return nil
}
info, err := cplayerdata.UpdateAll(bson.M{"packageid": args.PackageTag}, bson.D{{"$set",
bson.D{{"platform", args.PlatformStr}, {"channel", args.ChannelStr},
{"beunderagentcode", args.PromoterStr}, {"promotertree", args.PromoterTree}}}})
if err != nil {
logger.Logger.Info("svc.UpdateAllPlayerPackageTag error ", err)
return
}
logger.Logger.Info("svc.UpdateAllPlayerPackageTag result:", info)
*ret = true
return
}
func (svc *PlayerDataSvc) SetVipLevel(args *model.SetPlayerAtt, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return nil
}
cond := bson.M{"snid": args.SnId}
err = cplayerdata.Update(cond, bson.D{{"$set", bson.D{{"forcevip", args.VipLevel},
{"vip", args.VipLevel}}}})
if err != nil {
logger.Logger.Info("SetVipLevel error ", err)
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) SetGMLevel(args *model.SetPlayerAtt, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return nil
}
cond := bson.M{"snid": args.SnId}
err = cplayerdata.Update(cond, bson.D{{"$set", bson.D{{"gmlevel", args.GmLevel}}}})
if err != nil {
logger.Logger.Info("SetGMLevel error ", err)
return
}
*ret = true
return
}
func (svc *PlayerDataSvc) GetSameIpPlayer(args *model.GetSameParamPlayerArgs, ret *[]int32) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
//临时结构
var t []struct {
SnId int32
}
err = cplayerdata.Find(bson.M{"ip": args.Param}).Select(bson.M{"snid": 1}).All(&t)
if err != nil {
logger.Logger.Error("svc.GetSameIpPlayer is error", err)
return
}
for _, v := range t {
*ret = append(*ret, v.SnId)
}
fmt.Println("GetSameIpPlayer....", ret)
return
}
func (svc *PlayerDataSvc) GetSameBankNamePlayer(args *model.GetSameParamPlayerArgs, ret *[]int32) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
//临时结构
var t []struct {
SnId int32
}
err = cplayerdata.Find(bson.M{"bankaccname": args.Param}).Select(bson.M{"snid": 1}).All(&t)
if err != nil {
logger.Logger.Error("svc.GetSameBankNamePlayer is error", err)
return
}
for _, value := range t {
*ret = append(*ret, value.SnId)
}
return
}
func (svc *PlayerDataSvc) GetSameBankCardPlayer(args *model.GetSameParamPlayerArgs, ret *[]int32) (err error) {
cplayerdata := PlayerDataCollection(args.Plt)
if cplayerdata == nil {
return
}
//临时结构
var t []struct {
SnId int32
}
err = cplayerdata.Find(bson.M{"bankaccount": args.Param}).Select(bson.M{"snid": 1}).All(&t)
if err != nil {
logger.Logger.Error("svc.GetSameBankCardPlayer is error", err)
return
}
for _, value := range t {
*ret = append(*ret, value.SnId)
}
return
}
func (svc *PlayerDataSvc) GetRobotPlayers(limit int, ret *[]*model.PlayerData) (err error) {
cplayerdata := PlayerDataCollection(mongo.G_P)
if cplayerdata == nil {
return
}
data := make([]*model.PlayerData, 0, limit)
err = cplayerdata.Find(bson.M{"isrob": true}).Limit(limit).All(&ret)
if err != nil {
logger.Logger.Error("svc.GetRobotPlayers is error", err)
return
}
*ret = data
return
}
/*
* 保存玩家的删除备份全部信息
*/
func (svc *PlayerDelBackupDataSvc) SaveDelBackupPlayerData(pd *model.PlayerData, ret *bool) (err error) {
tPlayerDelBackup := PlayerDelBackupDataCollection(pd.Platform)
if tPlayerDelBackup == nil {
return nil
}
if pd != nil {
model.RecalcuPlayerCheckSum(pd)
_, err = tPlayerDelBackup.UpsertId(pd.Id, pd)
if err != nil {
logger.Logger.Errorf("svc.SaveDelBackupPlayerData %v err:%v", pd.SnId, err)
return
}
*ret = true
return
}
return
}
func (svc *PlayerDelBackupDataSvc) GetPlayerData(req *model.PlayerIsExistBySnIdArgs, ret *model.PlayerData) error {
tPlayerDelBackup := PlayerDelBackupDataCollection(req.Plt)
if tPlayerDelBackup == nil {
return nil
}
return tPlayerDelBackup.Find(bson.M{"snid": req.SnId}).One(ret)
}
func (svc *PlayerDataSvc) SetLogicLevel(args *model.LogicInfoArg, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return
}
cond := bson.M{"snid": bson.M{"$in": args.SnIds}}
var info *mgo.ChangeInfo
if args.LogicLevel == 0 { //清空所有分层信息
info, err = cplayerdata.UpdateAll(cond, bson.D{{"$set", bson.D{{"logiclevels", []int32{}}}}})
} else {
info, err = cplayerdata.UpdateAll(cond, bson.D{{"$addToSet", bson.D{{"logiclevels", args.LogicLevel}}}})
}
if err != nil {
logger.Logger.Error("SetLogicLevel error ", err)
return
}
*ret = true
logger.Logger.Tracef("SetLogicLevel UpdataAll:%#v", info)
return
}
func (svc *PlayerDataSvc) ClrLogicLevel(args *model.LogicInfoArg, ret *bool) (err error) {
cplayerdata := PlayerDataCollection(args.Platform)
if cplayerdata == nil {
return nil
}
cond := bson.M{"snid": bson.M{"$in": args.SnIds}}
info, err := cplayerdata.UpdateAll(cond, bson.D{{"$pull", bson.D{{"logiclevels", args.LogicLevel}}}})
if err != nil {
logger.Logger.Error("ClrLogicLevel error ", err)
return err
}
*ret = true
logger.Logger.Tracef("ClrLogicLevel UpdataAll:%#v", info)
return nil
}
func (svc *PlayerDataSvc) GetPlayerInviteSnid(req *model.PlayerIsExistBySnIdArgs, resp *int32) error {
c := PlayerDataCollection(req.Plt)
if c == nil {
return PlayerColError
}
type t struct {
InviteSnId int32
}
res := &t{}
err := c.Find(bson.M{"snid": req.SnId}).Select(bson.M{"invitesnid": 1}).One(res)
if err != nil && errors.Is(err, mgo.ErrNotFound) {
return err
}
*resp = res.InviteSnId
return nil
}
func (svc *PlayerDataSvc) GetInviteNum(req *model.PlayerIsExistBySnIdArgs, resp *int32) error {
n, err := GetInviteNum(req.Plt, req.SnId)
if err != nil {
return err
}
*resp = n
return nil
}
func GetInviteNum(platform string, snId int32) (int32, error) {
c := PlayerDataCollection(platform)
if c == nil {
return 0, PlayerColError
}
n, err := c.Find(bson.M{"invitesnid": snId}).Count()
if err != nil {
return 0, err
}
return int32(n), nil
}
func BindInviteSnId(platform string, snId, inviteSnId int32, ts int64) error {
c := PlayerDataCollection(platform)
if c == nil {
return PlayerColError
}
err := c.Update(bson.M{"snid": snId}, bson.M{"$set": bson.M{"invitesnid": inviteSnId}})
if err != nil {
logger.Logger.Error("BindInviteSnId error ", err)
return err
}
return nil
}
func CorrectData(pd *model.PlayerData) bool {
//var coinTotal int64
dirty := false
//金币冲账
//coinlogs, err := GetCoinWALBySnidAndCoinTypeAndGreaterTs(pd.Platform, pd.SnId, PayCoinLogType_Coin, pd.CoinPayTs)
//if err == nil && len(coinlogs) != 0 {
// oldTs := pd.CoinPayTs
// oldCoin := pd.Coin
// var cnt int64
//
// for i := 0; i < len(coinlogs); i++ {
// cnt = coinlogs[i].Count
// pd.Coin += cnt
// coinTotal += cnt
//
// if coinlogs[i].LogType == common.GainWay_ShopBuy {
// pd.CoinPayTotal += cnt
// if pd.TodayGameData == nil {
// pd.TodayGameData = model.NewPlayerGameCtrlData()
// }
// pd.TodayGameData.RechargeCoin += cnt //累加当天充值金额
// }
// if coinlogs[i].Ts > pd.CoinPayTs {
// pd.CoinPayTs = coinlogs[i].Ts
// }
// dirty = true
// }
//
// newTs := pd.CoinPayTs
// newCoin := pd.Coin
// logger.Logger.Warnf("PlayerData(%v) CorrectData before:CoinPayTs=%v before:Coin=%v after:CoinPayTs=%v after:Coin=%v", pd.SnId, oldTs, oldCoin, newTs, newCoin)
//}
////保险箱冲账
//boxCoinLogs, err := GetCoinWALBySnidAndCoinTypeAndGreaterTs(pd.Platform, pd.SnId, PayCoinLogType_SafeBoxCoin, pd.SafeBoxCoinTs)
//if err == nil && len(boxCoinLogs) != 0 {
// oldTs := pd.SafeBoxCoinTs
// oldCoin := pd.SafeBoxCoin
// for i := 0; i < len(boxCoinLogs); i++ {
// pd.SafeBoxCoin += boxCoinLogs[i].Count
// coinTotal += boxCoinLogs[i].Count
// if boxCoinLogs[i].LogType == common.GainWay_ShopBuy {
// pd.CoinPayTotal += boxCoinLogs[i].Count
// if pd.TodayGameData == nil {
// pd.TodayGameData = model.NewPlayerGameCtrlData()
// }
// pd.TodayGameData.RechargeCoin += boxCoinLogs[i].Count //累加当天充值金额
// }
// if boxCoinLogs[i].Ts > pd.SafeBoxCoinTs {
// pd.SafeBoxCoinTs = boxCoinLogs[i].Ts
// }
// dirty = true
// }
//
// newTs := pd.SafeBoxCoinTs
// newCoin := pd.SafeBoxCoin
// logger.Logger.Warnf("PlayerData(%v) CorrectData before:SafeBoxCoinTs=%v before:SafeBoxCoin=%v after:SafeBoxCoinTs=%v after:SafeBoxCoin=%v", pd.SnId, oldTs, oldCoin, newTs, newCoin)
//}
//
////比赛入场券冲账
//ticketLogs, err := GetCoinWALBySnidAndCoinTypeAndGreaterTs(pd.Platform, pd.SnId, PayCoinLogType_Ticket, pd.TicketPayTs)
//if err == nil && len(ticketLogs) != 0 {
// oldTs := pd.TicketPayTs
// oldTicket := pd.Ticket
// for i := 0; i < len(ticketLogs); i++ {
// pd.Ticket += ticketLogs[i].Count
// pd.TicketTotal += ticketLogs[i].Count
// if ticketLogs[i].Ts > pd.TicketPayTs {
// pd.TicketPayTs = ticketLogs[i].Ts
// }
// dirty = true
// }
//
// newTs := pd.TicketPayTs
// newTicket := pd.Ticket
// logger.Logger.Warnf("PlayerData(%v) CorrectData before:TicketPayTs=%v before:Ticket=%v after:TicketPayTs=%v after:Ticket=%v", pd.SnId, oldTs, oldTicket, newTs, newTicket)
//}
//同步游服丢失的金币变化
if SyncGameCoin(pd, 0, pd.GameCoinTs) {
dirty = true
}
//确保金币不小于0
if pd.Coin < 0 {
logger.Logger.Warnf("PlayerData(%v) CorrectData found pd.Coin<0(%v)", pd.SnId, pd.Coin)
if pd.SafeBoxCoin > 0 {
pd.SafeBoxCoin += pd.Coin
if pd.SafeBoxCoin < 0 {
logger.Logger.Warnf("PlayerData(%v) CorrectData found pd.SafeBoxCoin<0(%v)", pd.SnId, pd.SafeBoxCoin)
pd.SafeBoxCoin = 0
}
}
pd.Coin = 0
dirty = true
}
if dirty {
SavePlayerData(pd)
}
return dirty
}
func SyncGameCoin(pd *model.PlayerData, sceneid int, enterts int64) bool {
dirty := false
//游服金币冲账
endts := time.Now().UnixNano()
gamecoinlogs, err := GetCoinWALBySnidAndInGameAndGreaterTs(pd.Platform, pd.SnId, int32(sceneid), enterts)
if err == nil && len(gamecoinlogs) != 0 {
oldCoin := pd.Coin
var cnt int64
for i := 0; i < len(gamecoinlogs); i++ {
ts := gamecoinlogs[i].Ts
if ts >= enterts && ts <= endts {
cnt = gamecoinlogs[i].Count
pd.Coin += cnt
if ts > pd.GameCoinTs {
pd.GameCoinTs = ts
}
dirty = true
}
}
newCoin := pd.Coin
newTs := pd.GameCoinTs
logger.Logger.Warnf("PlayerData(%v) SyncGameCoin before:enterts=%v before:Coin=%v after:GameCoinTs=%v after:Coin=%v", pd.SnId, enterts, oldCoin, newTs, newCoin)
}
return dirty
}
func init() {
rpc.Register(&PlayerDataSvc{})
rpc.Register(&PlayerDelBackupDataSvc{})
}