pet_home_server/src/server/game/RegisterNetworkFunc.go
2025-01-17 11:30:03 +08:00

3526 lines
92 KiB
Go

package game
import (
"errors"
"fmt"
"math"
"server/GoUtil"
"server/MergeConst"
"server/conf"
cardCfg "server/conf/card"
limitedTimeEventCfg "server/conf/limitedTimeEvent"
mergeDataCfg "server/conf/mergeData"
miningCfg "server/conf/mining"
"server/db"
"server/game/internal"
"server/game/mod/card"
"server/game/mod/friend"
"server/game/mod/item"
"server/game/mod/limitedTimeEvent"
MsqMod "server/game/mod/msg"
"server/game/mod/order"
"server/game/mod/piggyBank"
"server/game/mod/playroom"
"server/game/mod/quest"
"server/msg"
"strconv"
"server/pkg/github.com/name5566/leaf/gate"
"server/pkg/github.com/name5566/leaf/log"
"google.golang.org/protobuf/proto"
)
func ReqPlayerAsset(args []interface{}) error {
_, player, _ := ParseArgs(args)
player.PushClientRes(player.PlayerBaseMod.BackAsset())
return nil
}
// 请求玩家基础信息
func ReqPlayerBaseInfofunction(args []interface{}) error {
// 消息的发送者
_, player, buf := ParseArgs(args)
detail := &msg.ReqPlayerBaseInfo{}
proto.Unmarshal(buf, detail)
player.PlayerBaseMod.ResPlayerBaseInfo(player)
return nil
}
func ReqPlayerBriefProfileDataFunc(args []interface{}) error {
_, player, buf := ParseArgs(args)
detail := &msg.ReqPlayerBriefProfileData{}
proto.Unmarshal(buf, detail)
Uid := int(detail.DwUin)
PlayerSimpleData := G_GameLogicPtr.GetSimplePlayerByUid(Uid)
player.PushClientRes(&msg.ResPlayerBriefProfileData{
DwUin: player.M_DwUin,
ImageFrame: int32(PlayerSimpleData.Avatar),
ImageIcon: int32(PlayerSimpleData.Face),
DecorateCnt: int32(PlayerSimpleData.Decorate),
PicURL: PlayerSimpleData.FaceBookPic,
ActiveTime: int32(max(PlayerSimpleData.Loginout, PlayerSimpleData.Login)),
})
return nil
}
// 移除广告
func ReqRemoveAdFunc(args []interface{}) error {
_, player, buf := ParseArgs(args)
player.PlayerBaseMod.ReqRemoveAd(player, buf)
return nil
}
// 更新玩家物品
func UpdateBaseItemInfofunction(args []interface{}) error {
_, player, buf := ParseArgs(args)
detail := &msg.UpdateBaseItemInfo{}
proto.Unmarshal(buf, detail)
player.PlayerBaseMod.UpdateBaseItemInfo(detail)
return nil
}
// 请求玩家棋盘信息
func ReqPlayerChessDataFunc(args []interface{}) error {
_, player, buf := ParseArgs(args)
detail := &msg.ReqPlayerChessData{}
proto.Unmarshal(buf, detail)
playerChessData := &PlayerChessData{}
playerChessData.ResPlayerChessData(player)
return nil
}
func ReqBindFacebookAccount(args []interface{}) error {
_, player, buf := ParseArgs(args)
player.PlayerBaseMod.ReqBindFacebookAccount(player, buf)
return nil
}
func ReqUnBindFacebook(args []interface{}) error {
_, player, buf := ParseArgs(args)
player.PlayerBaseMod.ReqUnBindFacebook(player, buf)
return nil
}
func ReqOnlyBindFacebook(args []interface{}) error {
_, player, buf := ParseArgs(args)
player.PlayerBaseMod.ReqOnlyBindFacebook(player, buf)
return nil
}
func ReqSynGameData(args []interface{}) error {
_, player, buf := ParseArgs(args)
player.PlayerBaseMod.ReqSynGameData(player, buf)
return nil
}
func RegSetEneryFunc(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqSetEnergyMul{}
proto.Unmarshal(buf, req)
MaxEnergyMul := player.GetPlayerBaseMod().GetMaxEnergyMul(player)
if int(req.EnergyMul) > MaxEnergyMul {
player.SendErrClienRes(&msg.ResSetEnergyMul{
ResultCode: msg.RES_CODE_FAIL,
Msg: "能量倍数超过最大值",
})
return errors.New("能量倍数超过最大值")
}
player.TeLog("mutil_merge_change", map[string]interface{}{
"change_from": math.Pow(2, float64(MaxEnergyMul)),
"change_to": math.Pow(2, float64(req.EnergyMul)),
"is_auto": false,
})
player.PlayMod.getBaseMod().SetEnergyMul(int(req.EnergyMul))
OrderMod := player.PlayMod.getOrderMod()
Lv := player.GetPlayerBaseMod().GetLevel()
Emit := player.PlayMod.getChessMod().GetOrderEmit()
ChessList := player.PlayMod.getChessMod().GetChessList()
OrderMod.ChangeEnergyMul(Lv, Emit, int(req.EnergyMul), ChessList)
player.PushClientRes(OrderMod.BackData())
player.PushClientRes(player.PlayMod.getBaseMod().BackData())
return nil
}
// 领取图鉴奖励
func ReqGetHandbookReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqGetHandbookReward{}
proto.Unmarshal(buf, req)
err := player.PlayMod.getHandbookMod().GetHandbookReward(int(req.ChessId))
if err != nil {
player.SendErrClienRes(&msg.ResGetHandbookReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
var itemList []*item.Item
itemList = append(itemList, &item.Item{Id: item.ITEM_ENERGY_ID, Num: 5})
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_HandbookReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResGetHandbookReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PushClientRes(&msg.ResGetHandbookReward{
Code: msg.RES_CODE_SUCCESS,
})
player.PushClientRes(player.PlayMod.getHandbookMod().BackData())
player.PlayMod.save()
player.TeLog("collection_reward", map[string]interface{}{
"item_id": int(req.ChessId),
"item_name": mergeDataCfg.GetNameById(int(req.ChessId)),
})
return nil
}
// 领取订单奖励
func ReqRewardOrder(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqRewardOrder{}
proto.Unmarshal(buf, req)
OrderMod := player.PlayMod.getOrderMod()
ChessMod := player.PlayMod.getChessMod()
CardMod := player.PlayMod.getCardMod()
LimitedTimeEventMod := player.PlayMod.getLimitedTimeEventMod()
Item, mergeList, OrderType, Star, err := OrderMod.RewardOrder(int(req.OrderId))
if OrderType == order.Trigger_type { // playroom触发式订单获取额外道具
PlayroomMod := player.PlayMod.getPlayroomMod()
Item1 := PlayroomMod.GetReward()
Item = item.Merge(Item, Item1)
}
if !OrderMod.CheckSuperOrder() {
if LimitedTimeEventMod.RemoveSuperOrder() {
player.PushClientRes(&msg.LimitEventNotify{
Id: limitedTimeEvent.EVENT_TYPE_SUPER_ORDER,
Type: limitedTimeEvent.EVENT_NOTIFY_TYPE_DEL,
})
}
}
if LimitedTimeEventMod.CheckExist(limitedTimeEvent.EVENT_TYPE_METEOR_SHOW) { //流星雨活动
AddItem := LimitedTimeEventMod.GetMeteorReward(mergeList)
if len(AddItem) > 0 {
player.TeLog("time_limited_event_action", map[string]interface{}{
"event_type": "meteor_show",
"item_list": AddItem,
})
}
Item = item.Merge(Item, AddItem)
}
if err != nil {
player.SendErrClienRes(&msg.ResRewardOrder{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = ChessMod.FinishOrder(mergeList)
if err != nil {
player.SendErrClienRes(&msg.ResRewardOrder{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(Item, msg.ITEM_POP_LABEL_OrderReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResRewardOrder{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
if LimitedTimeEventMod.CheckExist(limitedTimeEvent.EVENT_TYPE_CHEST_RAIN) { //宝箱雨活动
AddItem, CardLv, ProductLv, Jackpot := LimitedTimeEventMod.GetChestReward(mergeList)
ChestRainItems := make([]*item.Item, 0)
if len(AddItem) > 0 {
ChestRainItems = AddItem
}
JackpotId := 0
if CardLv > 0 {
CardId := CardMod.RandCard(CardLv)
ItemId := cardCfg.GetItemIdByCardId(CardId)
ChestRainItems = []*item.Item{{Id: ItemId, Num: 1}}
}
if ProductLv > 0 {
Color := order.RandChessColor(ChessMod.GetOrderEmit())
ChessId := mergeDataCfg.GetChessIdByLvAndColor(ProductLv, Color)
ChestRainItems = append(ChestRainItems, &item.Item{Id: ChessId, Num: 1})
}
if Jackpot > 0 {
ProbList := limitedTimeEventCfg.GetSenceJackpotProb()
JackpotId = GoUtil.RandMap(ProbList)
ChestRainItems = limitedTimeEventCfg.GetSenceJackpotReward(JackpotId)
}
player.args["ResItemPopId"] = JackpotId
err = player.HandleItem(ChestRainItems, msg.ITEM_POP_LABEL_LimitEventChestRain.String())
if err != nil {
player.SendErrClienRes(&msg.ResRewardOrder{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
if len(ChestRainItems) > 0 {
player.PushClientRes(&msg.ResChessRainReward{
Items: item.ItemToMsg(ChestRainItems),
Id: int32(JackpotId),
})
player.TeLog("time_limited_event_action", map[string]interface{}{
"event_type": "chest_rain",
"item_list": ChestRainItems,
})
}
}
data := &PlayerChessData{}
err = data.UpdateChessData(player, req.MChessData)
if err != nil {
player.SendErrClienRes(&msg.ResGetChessFromBuff{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
// 每日任务
player.QuestTrigger(&quest.Trigger{Label: quest.TRIGGER_LABEL_FINISHORDER})
player.TeLog("order_finish", map[string]interface{}{
"order_id": int(req.OrderId),
"order_item_id": mergeList,
"order_type": OrderType,
"order_star_reward": Star,
})
EmitRetireTrigger2(player)
Lv := player.GetPlayerBaseMod().GetLevel()
EnergyMul := player.PlayMod.getBaseMod().GetEnergyMul()
Emit := ChessMod.GetOrderEmit()
OrderMod.CreateOrder(Lv, Emit, EnergyMul)
// 存钱罐增加钻石
PiggyBankMod := player.PlayMod.getPiggyBankMod()
PiggyBankMod.Trigger()
// 锦标赛增加积分
if player.GetPlayerBaseMod().GetLevel() >= 6 {
ChampshipMod := player.PlayMod.getChampshipMod()
ChampshipMod.AddScore(mergeList)
player.HandleInChampshipRank()
}
// playroom 触发式订单
err = PlayroomOrderTrigger(player)
if err != nil {
player.SendErrClienRes(&msg.ResRewardOrder{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
FriendTreasureMod := player.PlayMod.getFriendTreasureMod()
FriendTreasureMod.AddStar(Star / 10)
player.PushClientRes(FriendTreasureMod.NotifyStar())
// 限时事件增加进度
LimitedTimeEventMod.AddProgress(player.GetPlayerBaseMod().GetLevel())
player.PlayMod.save()
player.PushClientRes(PiggyBankMod.BackData())
player.PushClientRes(OrderMod.BackData())
BackChampship(player)
player.PushClientRes(LimitedTimeEventMod.BackData())
player.PushClientRes(LimitedTimeEventMod.ProgressBackData())
return nil
}
// 场景装饰
func ReqDecorate(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqDecorate{}
proto.Unmarshal(buf, req)
DecorateMod := player.PlayMod.getDecorateMod()
DecorateId := int(req.DecorateId)
AreaId := int(req.AreaId)
CostItem := DecorateMod.GetDecorateCostItem(AreaId, DecorateId)
err := player.HandleItem(CostItem, msg.ITEM_POP_LABEL_DecorateCost.String()) // 扣除道具
if err != nil {
player.SendErrClienRes(&msg.ResDecorate{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
AddItem, err := DecorateMod.Decorate(AreaId, DecorateId) // 装饰
if err != nil {
player.SendErrClienRes(&msg.ResDecorate{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(AddItem, msg.ITEM_POP_LABEL_DecorateAdd.String()) // 增加道具
if err != nil {
player.SendErrClienRes(&msg.ResDecorate{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
_, err = player.GetPlayerBaseMod().AddExp(player, 10)
if err != nil {
player.SendErrClienRes(&msg.ResDecorate{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
if AddItem != nil {
player.TeLog("scene_reward", map[string]interface{}{
"deco_step_id": DecorateId,
"item_list": AddItem,
})
}
if DecorateMod.GetAreaId() != AreaId { // 解锁上报
player.TeLog("plot_unlock", map[string]interface{}{
"plot_id": AreaId,
})
}
player.TeLog("finish_deco", map[string]interface{}{
"deco_step_id": DecorateId,
})
player.PlayMod.save()
player.PushClientRes(DecorateMod.BackData())
player.PushClientRes(&msg.ResDecorate{
Code: msg.RES_CODE_SUCCESS,
})
player.HandleInUserRank()
BackUserInfo(player)
player.UpdateUserInfo()
return nil
}
// 场景装饰
func ReqDecorateAll(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqDecorateAll{}
proto.Unmarshal(buf, req)
DecorateMod := player.PlayMod.getDecorateMod()
PlayerBaseMod := player.GetPlayerBaseMod()
CostItem, AddItem, DecorateNum, DecorateList := DecorateMod.DecorateAll(PlayerBaseMod.GetStar())
err := player.HandleItem(CostItem, msg.ITEM_POP_LABEL_DecorateCost.String()) // 扣除道具
if err != nil {
player.SendErrClienRes(&msg.ResDecorateAll{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(AddItem, msg.ITEM_POP_LABEL_DecorateAdd.String()) // 增加道具
if err != nil {
player.SendErrClienRes(&msg.ResDecorateAll{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
_, err = player.GetPlayerBaseMod().AddExp(player, 10*DecorateNum)
if err != nil {
player.SendErrClienRes(&msg.ResDecorateAll{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.TeLog("one_click_decoration", map[string]interface{}{
"deco_step_id": DecorateList,
})
player.PlayMod.save()
player.PushClientRes(DecorateMod.BackData())
player.PushClientRes(&msg.ResDecorate{
Code: msg.RES_CODE_SUCCESS,
})
player.HandleInUserRank()
BackUserInfo(player)
player.UpdateUserInfo()
return nil
}
// -----------------------ChessApi----------------------
// 更新棋盘信息
func UpdatePlayerChessDataFunc(args []interface{}) error {
_, player, buf := ParseArgs(args)
data := &PlayerChessData{}
err := data.UpdatePlayerChessData(player, buf)
RedBackData(player)
player.UpdateUserInfo()
return err
}
// 从缓存中获取棋子
func ReqGetChessFromBuff(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqGetChessFromBuff{}
proto.Unmarshal(buf, req)
ChessMod := player.PlayMod.getChessMod()
HandbookMod := player.PlayMod.getHandbookMod()
OrderMod := player.PlayMod.getOrderMod()
BaseMod := player.PlayMod.getBaseMod()
ChessId := int(req.ChessId)
err := ChessMod.GetChessFromBuff(ChessId)
Update := HandbookMod.SetHandbook(ChessId)
AddNewEmit := make([]int, 0)
if Update {
player.PushClientRes(HandbookMod.BackData())
AddNewEmit = append(AddNewEmit, ChessId)
}
if err != nil {
player.SendErrClienRes(&msg.ResGetChessFromBuff{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
data := &PlayerChessData{}
err = data.UpdateChessData(player, req.MChessData)
if err != nil {
player.SendErrClienRes(&msg.ResGetChessFromBuff{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
Update = OrderMod.CreateExtraOrder([]int{ChessId}, AddNewEmit, ChessMod.GetChessList(), BaseMod.GetEnergyMul())
if Update {
player.PushClientRes(OrderMod.BackData())
}
EmitRetireTrigger1(player)
player.PlayMod.save()
player.PushClientRes(ChessMod.BackData())
player.PushClientRes(&msg.ResGetChessFromBuff{
Code: msg.RES_CODE_SUCCESS,
})
player.UpdateUserInfo()
return nil
}
// 放置棋子进背包
func ReqPutChessInBag(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqPutChessInBag{}
proto.Unmarshal(buf, req)
ChessMod := player.PlayMod.getChessMod()
err := ChessMod.PutChessInBag(int(req.BagId), int(req.ChessId), int(req.EmitId))
if err != nil {
player.SendErrClienRes(&msg.ResPutChessInBag{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
data := &PlayerChessData{}
err = data.UpdateChessData(player, req.MChessData)
if err != nil {
player.SendErrClienRes(&msg.ResPutChessInBag{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(ChessMod.BackData())
player.PushClientRes(&msg.ResPutChessInBag{
Code: msg.RES_CODE_SUCCESS,
})
player.UpdateUserInfo()
return nil
}
func ReqTakeChessOutBag(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqTakeChessOutBag{}
proto.Unmarshal(buf, req)
ChessMod := player.PlayMod.getChessMod()
err := ChessMod.TakeChessOutBag(int(req.BagId))
if err != nil {
player.SendErrClienRes(&msg.ResTakeChessOutBag{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
data := &PlayerChessData{}
err = data.UpdateChessData(player, req.MChessData)
if err != nil {
player.SendErrClienRes(&msg.ResTakeChessOutBag{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(ChessMod.BackData())
player.PushClientRes(&msg.ResTakeChessOutBag{
Code: msg.RES_CODE_SUCCESS,
})
player.UpdateUserInfo()
return nil
}
func ReqBuyChessBagGrid(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqBuyChessBagGrid{}
proto.Unmarshal(buf, req)
ChessMod := player.PlayMod.getChessMod()
CostItem := ChessMod.GetBuyChessBagGridCost()
err := player.HandleItem(CostItem, msg.ITEM_POP_LABEL_BuyChessBagGrid.String())
if err != nil {
player.SendErrClienRes(&msg.ResBuyChessBagGrid{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = ChessMod.BuyChessBagGrid()
if err != nil {
player.SendErrClienRes(&msg.ResBuyChessBagGrid{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(ChessMod.BackData())
player.PushClientRes(&msg.ResBuyChessBagGrid{
Code: msg.RES_CODE_SUCCESS,
})
if len(CostItem) > 0 {
player.TeLog("warehouse_unlock", map[string]interface{}{
"unlock_type": "diamond",
"unlock_cost": CostItem[0].Num,
})
}
return nil
}
func ReqSeparateChess(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqSeparateChess{}
proto.Unmarshal(buf, req)
ChessMod := player.PlayMod.getChessMod()
err := ChessMod.SeparateChess(int(req.ChessId))
if err != nil {
player.SendErrClienRes(&msg.ResSeparateChess{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
data := &PlayerChessData{}
err = data.UpdateChessData(player, req.MChessData)
if err != nil {
player.SendErrClienRes(&msg.ResSeparateChess{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(ChessMod.BackData())
player.PushClientRes(&msg.ResSeparateChess{
Code: msg.RES_CODE_SUCCESS,
})
player.UpdateUserInfo()
return nil
}
// 棋子转换
func ReqChessEx(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqChessEx{}
proto.Unmarshal(buf, req)
ChessMod := player.PlayMod.getChessMod()
if req.CostDia < 0 {
var itemList []*item.Item
item := item.NewItem(item.ITEM_DIAMOND_ID, int(req.CostDia))
itemList = append(itemList, item)
err := player.HandleItem(itemList, msg.ITEM_POP_LABEL_ChessEx.String())
if err != nil {
player.SendErrClienRes(&msg.ResChessEx{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
}
err := ChessMod.ExChess(int(req.OldChessId), int(req.NewChessId))
if err != nil {
player.SendErrClienRes(&msg.ResChessEx{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
HandbookMod := player.PlayMod.getHandbookMod()
HandbookMod.SetHandbook(int(req.NewChessId))
data := &PlayerChessData{}
err = data.UpdateChessData(player, req.MChessData)
if err != nil {
player.SendErrClienRes(&msg.ResChessEx{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(ChessMod.BackData())
player.PushClientRes(&msg.ResChessEx{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
func ReqSourceChest(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqSourceChest{}
proto.Unmarshal(buf, req)
ChessMod := player.PlayMod.getChessMod()
ChestId := int(req.ChestId)
Items, err := ChessMod.SourceChest(ChestId)
if err != nil {
player.SendErrClienRes(&msg.ResSourceChest{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(Items, msg.ITEM_POP_LABEL_SourceChest.String())
if err != nil {
player.SendErrClienRes(&msg.ResSourceChest{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
data := &PlayerChessData{}
err = data.UpdateChessData(player, req.MChessData)
if err != nil {
player.SendErrClienRes(&msg.ResSourceChest{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(ChessMod.BackData())
player.PushClientRes(&msg.ResSourceChest{
Code: msg.RES_CODE_SUCCESS,
})
player.UpdateUserInfo()
return nil
}
// ---------------------CardApi----------------------
func ReqCardInfo(args []interface{}) error {
_, player, _ := ParseArgs(args)
CardMod := player.PlayMod.getCardMod()
player.PushClientRes(CardMod.BackData())
return nil
}
// 领取卡牌系列收集奖励
func ReqCardCollectReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqCardCollectReward{}
proto.Unmarshal(buf, req)
CardMod := player.PlayMod.getCardMod()
itemList, chess, err := CardMod.GetCollectReward(int(req.Color))
if err != nil {
player.SendErrClienRes(&msg.ResCardCollectReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_CardCollectReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResCardCollectReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
if chess != 0 {
player.PlayMod.getChessMod().AddChessBuff(chess)
player.PushClientRes(player.PlayMod.getOrderMod().BackData())
}
player.PlayMod.save()
player.PushClientRes(CardMod.NotifyCard())
player.PushClientRes(&msg.ResCardCollectReward{
Code: msg.RES_CODE_SUCCESS,
})
player.TeLog("card_book", map[string]interface{}{
"season_id": CardMod.EndTime,
"card_book_id": int(req.Color),
"item_list": itemList,
})
return nil
}
// 兑换星星奖励
func ReqExStarReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqExStarReward{}
proto.Unmarshal(buf, req)
CardMod := player.PlayMod.getCardMod()
itemList, err := CardMod.ExStarReward(int(req.Id))
if err != nil {
player.SendErrClienRes(&msg.ResExStarReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_ExStarReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResExStarReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(&msg.ResExStarReward{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
// 领取全收集奖励
func ReqAllCollectReward(args []interface{}) error {
_, player, _ := ParseArgs(args)
CardMod := player.PlayMod.getCardMod()
itemList, err := CardMod.AllCollectReward()
if err != nil {
player.SendErrClienRes(&msg.ResAllCollectReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_AllCollectReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResAllCollectReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(CardMod.NotifyCard())
player.PushClientRes(&msg.ResAllCollectReward{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
// ---------------------GuildApi----------------------
func ReqGuideReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqGuideReward{}
proto.Unmarshal(buf, req)
GuildMod := player.PlayMod.getGuildMod()
itemList, err := GuildMod.GetReward(int(req.Id))
if err != nil {
player.SendErrClienRes(&msg.ResGuideReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.args["ResItemPopId"] = int(req.Id)
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_GuideReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResGuideReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(GuildMod.BackData())
player.PushClientRes(&msg.ResGuideReward{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
// -----------------dailyTaskApi---------------------
func ReqGetDailyTaskReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqGetDailyTaskReward{}
proto.Unmarshal(buf, req)
DailyTaskMod := player.PlayMod.getDailyTaskMod()
itemList, err := DailyTaskMod.GetDailyReward(int(req.Id))
if err != nil {
player.SendErrClienRes(&msg.ResGetDailyTaskReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.args["ResItemPopId"] = int(req.Id)
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_DailyTaskReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResGetDailyTaskReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(DailyTaskMod.BackData())
player.PushClientRes(&msg.ResGetDailyTaskReward{
Code: msg.RES_CODE_SUCCESS,
})
player.TeLog("daily_task", map[string]interface{}{
"task_id": int(req.Id),
"item_list": itemList,
"task_type": "daily",
"task_score_reward": 0,
})
return nil
}
func ReqGetDailyWeekReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqGetDailyWeekReward{}
proto.Unmarshal(buf, req)
DailyTaskMod := player.PlayMod.getDailyTaskMod()
itemList, err := DailyTaskMod.GetWeekReward(int(req.Id))
if err != nil {
player.SendErrClienRes(&msg.ResGetDailyWeekReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.args["ResItemPopId"] = int(req.Id)
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_DailyWeekReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResGetDailyWeekReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(DailyTaskMod.BackData())
player.PushClientRes(&msg.ResGetDailyWeekReward{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
func ReqDailyUnlock(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqDailyUnlock{}
proto.Unmarshal(buf, req)
DailyTaskMod := player.PlayMod.getDailyTaskMod()
DailyTaskMod.Unlock()
player.PlayMod.save()
player.PushClientRes(DailyTaskMod.BackData())
player.PushClientRes(&msg.ResDailyUnlock{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
// 头像框
func ReqSetAvatar(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqSetAvatar{}
proto.Unmarshal(buf, req)
avatarMod := player.PlayMod.getAvatarMod()
err := avatarMod.SetAvatar(int(req.Avatar))
if err != nil {
player.SendErrClienRes(&msg.ResSetAvatar{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(&msg.ResSetAvatar{
Code: msg.RES_CODE_SUCCESS,
})
BackUserInfo(player)
player.UpdateUserInfo()
b := false
if req.Avatar == 0 {
b = true
}
player.TeLog("avatar_set", map[string]interface{}{
"avatar_id": req.Avatar,
"is_platform": b,
})
return nil
}
// 头像
func ReqSetFace(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqSetFace{}
proto.Unmarshal(buf, req)
FaceMod := player.PlayMod.getFaceMod()
err := FaceMod.SetFace(int(req.Face))
if err != nil {
player.SendErrClienRes(&msg.ResSetFace{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(&msg.ResSetFace{
Code: msg.RES_CODE_SUCCESS,
})
BackUserInfo(player)
player.UpdateUserInfo()
return nil
}
// 购买能量
func ReqBuyEnergy(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqBuyEnergy{}
proto.Unmarshal(buf, req)
BaseMod := player.PlayMod.getBaseMod()
Item, Energy, Diamond := BaseMod.BuyEnergy(int(req.Energy))
err := player.HandleItem(Item, msg.ITEM_POP_LABEL_BuyEnergy.String())
if err != nil {
player.SendErrClienRes(&msg.ResBuyEnergy{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(BaseMod.BackData())
player.PushClientRes(&msg.ResBuyEnergy{
Code: msg.RES_CODE_SUCCESS,
})
player.TeLog("buy_energy_diamond", map[string]interface{}{
"diamond_cost": Diamond,
"energy_num": Energy,
})
return nil
}
func ReqGetEnergyByAD(args []interface{}) error {
_, player, _ := ParseArgs(args)
BaseMod := player.PlayMod.getBaseMod()
Item, err := BaseMod.GetEnergyByAD()
if err != nil {
player.SendErrClienRes(&msg.ResGetEnergyByAD{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(Item, msg.ITEM_POP_LABEL_GetEnergyByAD.String())
if err != nil {
player.SendErrClienRes(&msg.ResGetEnergyByAD{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(BaseMod.BackData())
player.PushClientRes(&msg.ResGetEnergyByAD{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
// 领取七日签到奖励
func ReqGetSevenLoginReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqGetSevenLoginReward{}
proto.Unmarshal(buf, req)
SevenLoginMod := player.PlayMod.getSevenLoginMod()
itemList, err := SevenLoginMod.GetReward(int(req.Id))
if err != nil {
player.SendErrClienRes(&msg.ResGetSevenLoginReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.args["ResItemPopId"] = int(req.Id)
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_SevenLoginRewardLabel.String())
if err != nil {
player.SendErrClienRes(&msg.ResGetSevenLoginReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(SevenLoginMod.BackData())
player.PushClientRes(&msg.ResGetSevenLoginReward{
Code: msg.RES_CODE_SUCCESS,
})
player.TeLog("weekly_gift", map[string]interface{}{
"reward_type": "week",
"reward_step": int(req.Id),
"item_list": itemList,
})
return nil
}
// 领取月进度奖励
func ReqGetMonthLoginReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqGetMonthLoginReward{}
proto.Unmarshal(buf, req)
SevenLoginMod := player.PlayMod.getSevenLoginMod()
itemList, err := SevenLoginMod.GetMonthReward(int(req.Id))
if err != nil {
player.SendErrClienRes(&msg.ResGetMonthLoginReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.args["ResItemPopId"] = int(req.Id)
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_MonthLoginReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResGetMonthLoginReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(SevenLoginMod.BackData())
player.PushClientRes(&msg.ResGetMonthLoginReward{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
// 连击快手奖励
func ReqFastProduceReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqFastProduceReward{}
proto.Unmarshal(buf, req)
LimitedTimeEventMod := player.PlayMod.getLimitedTimeEventMod()
itemList, err := LimitedTimeEventMod.GetFastProduceReward(int(req.Energy))
if err != nil {
player.SendErrClienRes(&msg.ResFastProduceReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_FastProduceReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResFastProduceReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(LimitedTimeEventMod.BackData())
player.PushClientRes(&msg.ResFastProduceReward{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
func ReqLimitSenceReward(args []interface{}) error {
_, player, _ := ParseArgs(args)
limitedTimeEventMod := player.PlayMod.getLimitedTimeEventMod()
if !limitedTimeEventMod.CheckExist(limitedTimeEvent.EVENT_TYPE_SENCE_DASH) { // 场景冲刺奖励
player.SendErrClienRes(&msg.ResLimitSenceReward{
Code: msg.RES_CODE_FAIL,
Msg: "not exist",
})
return fmt.Errorf("not exist")
}
Id, Items := limitedTimeEventMod.GetSceneDashReward()
player.args["ResItemPopId"] = Id
err := player.HandleItem(Items, msg.ITEM_POP_LABEL_LimitSenceReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResLimitSenceReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(&msg.ResLimitSenceReward{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
func ReqGetGoldCard(args []interface{}) error {
_, player, _ := ParseArgs(args)
data := G_GameLogicPtr.VarMgr.GetVar(VAR_GOLD_CARD)
if data == nil {
player.SendErrClienRes(&msg.ResGetGoldCard{
Four: 0,
Five: 0,
})
return fmt.Errorf("not exist")
}
gold := data.(*VarGoldCard)
player.PushClientRes(&msg.ResGetGoldCard{
Four: int32(gold.Four),
Five: int32(gold.Five),
})
return nil
}
// 搜索用户
func ReqSearchPlayer(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqSearchPlayer{}
proto.Unmarshal(buf, req)
Uid, err := strconv.Atoi(req.Uid)
list := make([]*msg.ResPlayerSimple, 0)
if err == nil {
SearchPlayer := G_GameLogicPtr.GetResSimplePlayerByUid(Uid)
if SearchPlayer != nil && SearchPlayer.Level != 0 {
list = append(list, SearchPlayer)
}
}
data, err := db.SearchPlayer(req.Uid)
if err != nil {
player.SendErrClienRes(&msg.ResSearchPlayer{
Code: 0,
})
}
for _, v := range data {
if player.M_DwUin == v.DwUin {
continue
}
if player.PlayMod.getFriendMod().CheckFriend(int(v.DwUin)) {
continue
}
if player.PlayMod.getFriendMod().CheckApply(int(v.DwUin)) {
continue
}
SearchPlayer := G_GameLogicPtr.GetResSimplePlayerByUid(int(v.DwUin))
list = append(list, SearchPlayer)
}
player.PushClientRes(&msg.ResSearchPlayer{
List: list,
})
return nil
}
// 申请好友
func ReqApplyFriend(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqApplyFriend{}
proto.Unmarshal(buf, req)
Uid := int(req.Uid)
m := &MsqMod.Msg{
Type: MsqMod.HANDLE_TYPE_APPLY,
From: int(player.M_DwUin),
To: Uid,
SendT: GoUtil.Now(),
}
G_GameLogicPtr.FriendMgrSend(m)
player.PushClientRes(&msg.ResApplyFriend{
Code: msg.RES_CODE_SUCCESS,
})
player.TeLog("friend_add", map[string]interface{}{
"player_id": Uid,
"add_type": "apply",
})
return nil
}
// 同意申请
func ReqAgreeFriend(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqAgreeFriend{}
proto.Unmarshal(buf, req)
Uid := int(req.Uid)
FriendMod := player.PlayMod.getFriendMod()
if !FriendMod.CheckApply(Uid) {
player.SendErrClienRes(&msg.ResAgreeFriend{
Code: msg.RES_CODE_FAIL,
Msg: "apply uid not exist",
})
return fmt.Errorf("apply uid not exist")
}
m := &MsqMod.Msg{
Type: MsqMod.HADNLE_TYPE_AGREE,
From: int(player.M_DwUin),
To: Uid,
SendT: GoUtil.Now(),
}
G_GameLogicPtr.FriendMgrSend(m)
FriendMod.AddFriend(Uid)
player.PlayMod.save()
player.PushClientRes(&msg.ResAgreeFriend{
Code: msg.RES_CODE_SUCCESS,
Uid: req.Uid,
Player: G_GameLogicPtr.GetResSimplePlayerByUid(int(req.Uid)),
})
player.AddLog(Uid, friend.LOG_TYPE_FRIEND_BECOME, "")
FriendApplyBackData(player)
return nil
}
// 删除好友
func ReqDelFriend(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqDelFriend{}
proto.Unmarshal(buf, req)
Uid := int(req.Uid)
m := &MsqMod.Msg{
Type: MsqMod.HANDLE_TYPE_DEL,
From: int(player.M_DwUin),
To: Uid,
SendT: GoUtil.Now(),
}
G_GameLogicPtr.FriendMgrSend(m)
FriendMod := player.PlayMod.getFriendMod()
FriendMod.DelFriend(Uid)
player.PlayMod.save()
player.PushClientRes(&msg.ResDelFriend{
Code: msg.RES_CODE_SUCCESS,
Uid: req.Uid,
})
player.AddLog(Uid, friend.LOG_TYPE_FRIEND_DELETE, "")
FriendListBackData(player)
player.TeLog("friend_delete", map[string]interface{}{
"player_id": Uid,
})
return nil
}
// 拒绝申请
func ReqRefuseFriend(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqRefuseFriend{}
proto.Unmarshal(buf, req)
Uid := int(req.Uid)
FriendMod := player.PlayMod.getFriendMod()
FriendMod.RefuseApply(Uid)
player.PlayMod.save()
player.PushClientRes(&msg.ResRefuseFriend{
Code: msg.RES_CODE_SUCCESS,
Uid: req.Uid,
})
m := &MsqMod.Msg{
Type: MsqMod.HANDLE_TYPE_DEL,
From: int(player.M_DwUin),
To: Uid,
SendT: GoUtil.Now(),
}
G_GameLogicPtr.FriendMgrSend(m)
FriendApplyBackData(player)
return nil
}
// 向好友请求卡牌
func ReqCardGive(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqCardGive{}
proto.Unmarshal(buf, req)
CardMod := player.PlayMod.getCardMod()
EndTime := GoUtil.Now() + 86400
FriendMod := player.PlayMod.getFriendMod()
err := CardMod.RequestCard()
if err != nil {
player.SendErrClienRes(&msg.ResCardGive{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
if len(req.Uid) == 0 { // 请求的UID列表不为空
player.SendErrClienRes(&msg.ResCardGive{
Code: msg.RES_CODE_FAIL,
Msg: "uid empty",
})
return fmt.Errorf("uid empty")
}
CardId := int(req.CardId)
if CardId == 0 { // 请求交换的卡牌ID不为空
player.SendErrClienRes(&msg.ResCardGive{
Code: msg.RES_CODE_FAIL,
Msg: "card id empty",
})
return fmt.Errorf("card id empty")
}
err = CardMod.SubCard(CardId)
if err != nil {
player.SendErrClienRes(&msg.ResCardGive{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
}
Id := GoUtil.CreateCardId(int(player.M_DwUin), 0, int(req.CardId))
for _, v := range req.Uid {
Uid := int(v)
if !FriendMod.CheckFriend(Uid) {
player.SendErrClienRes(&msg.ResCardGive{
Code: msg.RES_CODE_FAIL,
Msg: "not friend",
})
return fmt.Errorf("not friend")
}
CardInfo := &card.CardInfo{
Id: Id,
AUid: int(player.M_DwUin),
BUid: Uid,
CardId: CardId,
StartTime: GoUtil.Now(),
EndTime: EndTime,
Type: card.TYPE_CARD_GIVE,
Status: card.STATUS_CARD_GIVE_1,
}
player.AddLog(Uid, friend.LOG_TYPE_CARD_GIVE, strconv.Itoa(CardId))
err = CardMod.AddRequestCard(CardInfo) // 添加请求卡牌
if err != nil {
player.SendErrClienRes(&msg.ResCardGive{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
m := &MsqMod.Msg{
Type: MsqMod.HANDLE_TYPE_REQ_CARD,
From: int(player.M_DwUin),
To: Uid,
SendT: GoUtil.Now(),
End: EndTime,
Extra: *CardInfo,
}
FriendMgrSend(m)
}
player.PushClientRes(&msg.ResCardGive{
Code: msg.RES_CODE_SUCCESS,
})
player.PushClientRes(CardMod.NotifyCard())
player.PushClientRes(CardMod.NotifyTimes())
player.PlayMod.save()
player.TeLog("card_require", map[string]interface{}{
"card_id": CardId,
"player_id_target": req.Uid,
})
return nil
}
// 同意卡牌请求
func ReqAgreeCardGive(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqAgreeCardGive{}
proto.Unmarshal(buf, req)
FriendMod := player.PlayMod.getFriendMod()
CardInfo := FriendMod.GetCardInfo(req.Id)
if CardInfo == nil {
player.SendErrClienRes(&msg.ResAgreeCardGive{
Code: msg.RES_CODE_FAIL,
Msg: "card apply not exist",
})
return fmt.Errorf("card apply not exist")
}
CardMod := player.PlayMod.getCardMod()
err := CardMod.SubCard(CardInfo.CardId)
if err != nil {
player.SendErrClienRes(&msg.ResAgreeCardGive{
Code: msg.RES_CODE_FAIL,
Msg: "card not exist",
})
return fmt.Errorf("card not exist")
}
CardInfo.Status = card.STATUS_CARD_GIVE_2
CardInfo.EndTime = 0
m := &MsqMod.Msg{
Type: MsqMod.HANDLE_TYPE_AGREE_CARD,
From: int(player.M_DwUin),
To: CardInfo.AUid,
SendT: GoUtil.Now(),
Extra: *CardInfo,
}
FriendMgrSend(m)
player.PushClientRes(CardMod.NotifyCard())
player.PushClientRes(CardMod.NotifyTimes())
player.PushClientRes(&msg.ResAgreeCardGive{
Code: msg.RES_CODE_SUCCESS,
Id: req.Id,
})
player.PlayMod.save()
player.TeLog("card_require_reply", map[string]interface{}{
"card_id": CardInfo.CardId,
"player_id_requirer": CardInfo.AUid,
})
return nil
}
// 拒绝卡牌请求
func ReqRefuseCardGive(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqRefuseCardGive{}
proto.Unmarshal(buf, req)
FriendMod := player.PlayMod.getFriendMod()
CardInfo := FriendMod.GetCardInfo(req.Id)
if CardInfo == nil {
player.SendErrClienRes(&msg.ResRefuseCardGive{
Code: msg.RES_CODE_FAIL,
Msg: "card apply not exist",
})
return fmt.Errorf("card apply not exist")
}
FriendMod.DelCardInfo(req.Id)
player.PlayMod.save()
player.PushClientRes(&msg.ResRefuseCardGive{
Code: msg.RES_CODE_SUCCESS,
Id: req.Id,
})
m := &MsqMod.Msg{
Type: MsqMod.HANDLE_TYPE_REG_CARD_REFUSE,
From: int(player.M_DwUin),
To: CardInfo.AUid,
SendT: GoUtil.Now(),
Extra: *CardInfo,
}
FriendMgrSend(m)
return nil
}
// 赠送卡牌
func ReqCardSend(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqCardSend{}
proto.Unmarshal(buf, req)
CardMod := player.PlayMod.getCardMod()
CardId := int(req.CardId)
CardInfo, err := CardMod.SendCard(int(player.M_DwUin), int(req.Uid), CardId)
if err != nil {
player.SendErrClienRes(&msg.ResCardSend{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
m := &MsqMod.Msg{
Type: MsqMod.HANDLE_TYPE_SEND_CARD,
From: int(player.M_DwUin),
To: int(req.Uid),
SendT: GoUtil.Now(),
End: GoUtil.Now() + 86400,
Extra: *CardInfo,
}
player.AddLog(int(req.Uid), friend.LOG_TYPE_CARD_SEND, strconv.Itoa(CardId))
player.PushClientRes(&msg.ResCardSend{
Code: msg.RES_CODE_SUCCESS,
})
player.PushClientRes(CardMod.NotifyCard())
player.PlayMod.save()
player.PushClientRes(CardMod.NotifyTimes())
FriendMgrSend(m)
return nil
}
// 卡牌交换
func ReqCardExchange(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqCardExchange{}
proto.Unmarshal(buf, req)
CardMod := player.PlayMod.getCardMod()
CardId := int(req.CardId)
CardInfo, err := CardMod.ExchangeCard(int(player.M_DwUin), int(req.Uid), CardId)
if err != nil {
player.SendErrClienRes(&msg.ResCardExchange{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
m := &MsqMod.Msg{
Type: MsqMod.HANDLE_TYPE_EX_CARD,
From: int(player.M_DwUin),
To: int(req.Uid),
SendT: GoUtil.Now(),
End: GoUtil.Now() + 86400,
Extra: *CardInfo,
}
player.AddLog(int(req.Uid), friend.LOG_TYPE_CARD_EX_SEND, "")
player.PushClientRes(&msg.ResCardExchange{
Code: msg.RES_CODE_SUCCESS,
})
player.PushClientRes(CardMod.NotifyCard())
player.PlayMod.save()
player.PushClientRes(CardMod.NotifyTimes())
FriendMgrSend(m)
player.TeLog("card_exchange", map[string]interface{}{
"card_id": CardId,
"player_id_target": int(req.Uid),
"is_gift": 0,
})
return nil
}
// 选择卡牌进行交换
func ReqSelectCardExchange(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqSelectCardExchange{}
proto.Unmarshal(buf, req)
CardId := int(req.CardId)
CardMod := player.PlayMod.getCardMod()
FriendMod := player.PlayMod.getFriendMod()
CardInfo := FriendMod.GetCardInfo(req.Id)
if CardInfo == nil || CardInfo.EndTime < GoUtil.Now() {
player.SendErrClienRes(&msg.ResSelectCardExchange{
Code: msg.RES_CODE_FAIL,
Msg: "exchange time out",
})
return fmt.Errorf("exchange time out")
}
if CardInfo.ExId != 0 {
player.SendErrClienRes(&msg.ResSelectCardExchange{
Code: msg.RES_CODE_FAIL,
Msg: "card already selected",
})
return fmt.Errorf("card already selected")
}
CardInfo.ExId = CardId
CardInfo.Status = card.STATUS_CARD_EX_2
if cardCfg.CheckCardIsGold(CardInfo.CardId) || cardCfg.CheckCardIsGold(CardInfo.ExId) {
err := CardMod.SubGoldTimes()
if err != nil {
player.SendErrClienRes(&msg.ResSelectCardExchange{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
}
FriendMod.DelCardInfo(req.Id)
player.AddLog(CardInfo.AUid, friend.LOG_TYPE_CARD_SELECT_SEND, fmt.Sprintf("%d", CardInfo.ExId))
err := CardMod.SubCard(CardId)
if err != nil {
player.SendErrClienRes(&msg.ResSelectCardExchange{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(CardMod.NotifyCard())
player.PushClientRes(&msg.ResSelectCardExchange{
Code: msg.RES_CODE_SUCCESS,
Id: req.Id,
})
player.PushClientRes(CardMod.NotifyCard())
m := &MsqMod.Msg{
Type: MsqMod.HANDLE_TYPE_SELECT_EX_CARD,
From: int(player.M_DwUin),
To: CardInfo.AUid,
Extra: *CardInfo,
}
FriendMgrSend(m)
player.TeLog("card_exchange_reply", map[string]interface{}{
"palyer_id_giver": CardInfo.AUid,
"card_id_giver": CardInfo.CardId,
"card_id_reply": CardInfo.ExId,
})
return nil
}
// 同意卡牌交换
func ReqAgreeCardExchange(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqSelectCardExchange{}
proto.Unmarshal(buf, req)
CardMod := player.PlayMod.getCardMod()
FriendMod := player.PlayMod.getFriendMod()
CardInfo := FriendMod.GetCardInfo(req.Id)
if CardInfo == nil || CardInfo.EndTime < GoUtil.Now() {
player.SendErrClienRes(&msg.ResAgreeCardExchange{
Code: msg.RES_CODE_FAIL,
Msg: "exchange time out",
})
return fmt.Errorf("exchange time out")
}
CardMod.AddCard(CardInfo.ExId)
CardMod.DelExCard(CardInfo)
FriendMod.DelCardInfo(req.Id)
if cardCfg.CheckCardIsGold(CardInfo.CardId) || cardCfg.CheckCardIsGold(CardInfo.ExId) {
err := CardMod.SubGoldTimes()
if err != nil {
player.SendErrClienRes(&msg.ResAgreeCardExchange{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
}
player.AddLog(CardInfo.BUid, friend.LOG_TYPE_CARD_EX_SUCCESS_1, fmt.Sprintf("%d_%d", CardInfo.CardId, CardInfo.ExId))
CardInfo.Status = card.STATUS_CARD_EX_3
CardInfo.EndTime = 0
player.PlayMod.save()
player.PushClientRes(CardMod.NotifyCard())
player.PushClientRes(&msg.ResAgreeCardExchange{
Code: msg.RES_CODE_SUCCESS,
Id: req.Id,
})
m := &MsqMod.Msg{
Type: MsqMod.HANDLE_TYPE_ARGREE_EX_CARD,
From: int(player.M_DwUin),
To: CardInfo.BUid,
Extra: *CardInfo,
}
player.PushClientRes(CardMod.NotifyCard())
player.PushClientRes(CardMod.NotifyTimes())
FriendMgrSend(m)
player.TeLog("card_exchange_finish", map[string]interface{}{
"player_id_giver": CardInfo.AUid,
"card_id_giver": CardInfo.CardId,
"card_id_reply": CardInfo.ExId,
"player_id_reply": CardInfo.BUid,
})
return nil
}
// 拒绝选择卡牌
func ReqRefuseCardSelect(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqRefuseCardSelect{}
proto.Unmarshal(buf, req)
FriendMod := player.PlayMod.getFriendMod()
CardInfo := FriendMod.GetCardInfo(req.Id)
if CardInfo == nil {
player.SendErrClienRes(&msg.ResRefuseCardSelect{
Code: msg.RES_CODE_FAIL,
Msg: "exchange time out",
})
return fmt.Errorf("exchange time out")
}
if CardInfo.Status != 1 {
player.SendErrClienRes(&msg.ResRefuseCardSelect{
Code: msg.RES_CODE_FAIL,
Msg: "card is not select status",
})
return fmt.Errorf("card is not select status")
}
FriendMod.DelCardInfo(req.Id)
m := &MsqMod.Msg{
Type: MsqMod.HANDLE_TYPE_REFUSE_SELECT_CARD,
From: int(player.M_DwUin),
To: CardInfo.AUid,
Extra: *CardInfo,
}
FriendMgrSend(m)
player.PushClientRes(&msg.ResRefuseCardSelect{
Code: msg.RES_CODE_SUCCESS,
Id: req.Id,
})
player.PlayMod.save()
return nil
}
// 拒绝进行交换
func ReqRefuseCardExchange(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqRefuseCardExchange{}
proto.Unmarshal(buf, req)
CardMod := player.PlayMod.getCardMod()
FriendMod := player.PlayMod.getFriendMod()
CardInfo := FriendMod.GetCardInfo(req.Id)
if CardInfo == nil || CardInfo.EndTime < GoUtil.Now() {
player.SendErrClienRes(&msg.ResRefuseCardExchange{
Code: msg.RES_CODE_FAIL,
Msg: "exchange time out",
})
return fmt.Errorf("exchange time out")
}
if CardInfo.Status != 2 {
player.SendErrClienRes(&msg.ResRefuseCardExchange{
Code: msg.RES_CODE_FAIL,
Msg: "card is not status 2",
})
return fmt.Errorf("card is not status 2")
}
FriendMod.DelCardInfo(req.Id)
CardMod.AddCard(CardInfo.CardId)
CardMod.DelExCard(CardInfo)
CardMod.AddExTimes(CardInfo)
player.PlayMod.save()
player.PushClientRes(&msg.ResRefuseCardExchange{
Code: msg.RES_CODE_SUCCESS,
Id: req.Id,
})
m := &MsqMod.Msg{
Type: MsqMod.HANDLE_TYPE_REFUSE_EX_CARD,
From: int(player.M_DwUin),
To: CardInfo.BUid,
Extra: *CardInfo,
}
player.PushClientRes(CardMod.NotifyCard())
player.PushClientRes(CardMod.NotifyTimes())
FriendMgrSend(m)
return nil
}
// 领取好友卡牌
func ReqGetFriendCard(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqRefuseCardExchange{}
proto.Unmarshal(buf, req)
CardMod := player.PlayMod.getCardMod()
FriendMod := player.PlayMod.getFriendMod()
CardInfo := FriendMod.GetCardInfo(req.Id)
if CardInfo == nil || CardInfo.EndTime != 0 {
player.SendErrClienRes(&msg.ResGetFriendCard{
Code: msg.RES_CODE_FAIL,
Msg: "exchange time out",
})
return fmt.Errorf("exchange time out")
}
FriendMod.DelCardInfo(req.Id)
CardMod.AddCard(CardInfo.CardId)
// if CardInfo.ExId != 0 {
// player.AddLog(CardInfo.BUid, friend.LOG_TYPE_CARD_EX_SUCCESS_2, fmt.Sprintf("%d_%d", CardInfo.ExId, CardInfo.CardId))
// }
player.PlayMod.save()
player.PushClientRes(&msg.ResGetFriendCard{
Code: msg.RES_CODE_SUCCESS,
Id: req.Id,
CardId: int32(CardInfo.CardId),
})
player.PushClientRes(CardMod.NotifyCard())
return nil
}
// 请求玩家榜单
func ReqRank(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqRank{}
proto.Unmarshal(buf, req)
m := &MsqMod.Msg{
From: int(player.M_DwUin),
Type: MsqMod.HANDLE_TYPE_RANK_INFO,
Extra: RankMsg{RankType: int(req.Type)},
}
RankInfo := G_GameLogicPtr.RankMgrCall(m).(*RankInfo)
res := make(map[int32]*msg.ResPlayerSimple)
for k, rank := range RankInfo.List {
res[int32(k+1)] = G_GameLogicPtr.GetResSimplePlayerByUid(rank.Uid)
}
player.PushClientRes(&msg.ResRank{
Type: req.Type,
RankList: res,
MyRank: int32(RankInfo.MyRank),
MyScore: float32(RankInfo.MyScore),
})
return nil
}
// 请求竞标赛榜单
func ReqChampshipRank(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqRank{}
proto.Unmarshal(buf, req)
m := G_GameLogicPtr.ChampshipMgr.GetRankMsg(int(player.M_DwUin))
player.PushClientRes(m)
return nil
}
func ReqChampshipPreRank(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqRank{}
proto.Unmarshal(buf, req)
m := G_GameLogicPtr.ChampshipMgr.GetPreRankMsg(int(player.M_DwUin))
player.PushClientRes(m)
return nil
}
// 请求邮件列表
func ReqMailList(args []interface{}) error {
_, player, _ := ParseArgs(args)
MailMod := player.PlayMod.getMailMod()
player.PushClientRes(MailMod.BackData())
return nil
}
// 读邮件
func ReqReadMail(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqReadMail{}
proto.Unmarshal(buf, req)
MailMod := player.PlayMod.getMailMod()
err := MailMod.Read(int(req.Id))
if err != nil {
player.SendErrClienRes(&msg.ResReadMail{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(MailMod.NotifyMail(int(req.Id)))
player.PushClientRes(&msg.ResReadMail{
Code: msg.RES_CODE_SUCCESS,
Id: req.Id,
})
return nil
}
// 领取邮件奖励
func ReqGetMailReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqGetMailReward{}
proto.Unmarshal(buf, req)
MailMod := player.PlayMod.getMailMod()
itemList, err := MailMod.Reward(int(req.Id))
if err != nil {
player.SendErrClienRes(&msg.ResGetMailReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_MailReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResGetMailReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(MailMod.NotifyMail(int(req.Id)))
player.PushClientRes(&msg.ResGetMailReward{
Code: msg.RES_CODE_SUCCESS,
Id: req.Id,
})
return nil
}
// 删除邮件
func ReqDeleteMail(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqDeleteMail{}
proto.Unmarshal(buf, req)
MailMod := player.PlayMod.getMailMod()
err := MailMod.Del(int(req.Id))
if err != nil {
player.SendErrClienRes(&msg.ResDeleteMail{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(MailMod.NotifyMail(int(req.Id)))
player.PushClientRes(&msg.ResDeleteMail{
Code: msg.RES_CODE_SUCCESS,
Id: req.Id,
})
return nil
}
// 领取商店免费奖励
func ReqFreeShop(args []interface{}) error {
_, player, _ := ParseArgs(args)
ChargeMod := player.PlayMod.getChargeMod()
Item, err := ChargeMod.FireFreeShop()
if err != nil {
player.SendErrClienRes(&msg.ResFreeShop{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(Item, msg.ITEM_POP_LABEL_FreeShop.String())
if err != nil {
player.SendErrClienRes(&msg.ResFreeShop{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(ChargeMod.BackData())
player.PushClientRes(&msg.ResFreeShop{
Code: msg.RES_CODE_SUCCESS,
})
player.TeLog("gift_free", map[string]interface{}{
"gift_type": "store",
"item_id": Item[0].Id,
"num": Item[0].Num,
})
return nil
}
// 购买棋子商店物品
func ReqBuyChessShop(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqBuyChessShop{}
proto.Unmarshal(buf, req)
ChargeMod := player.PlayMod.getChargeMod()
LostItem, Item, _, err := ChargeMod.BuyChess(int(req.Id))
if err != nil {
player.SendErrClienRes(&msg.ResBuyChessShop{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleLoseItem(LostItem, "ChessShop")
if err != nil {
player.SendErrClienRes(&msg.ResBuyChessShop2{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(Item, msg.ITEM_POP_LABEL_ChessShop.String())
if err != nil {
player.SendErrClienRes(&msg.ResBuyChessShop{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.TeLog("store_buy", map[string]interface{}{
"item_id": int(req.Id),
"change_num": 1,
"cost_type": "diamond",
"cost_num": Item[0].Num,
})
player.PlayMod.save()
player.PushClientRes(ChargeMod.BackData())
player.PushClientRes(&msg.ResBuyChessShop{
Code: msg.RES_CODE_SUCCESS,
})
player.TeLog("buy_product_diamond", map[string]interface{}{
"diamond_cost": Item[0].Num,
"product_id": int(req.Id),
"product_name": mergeDataCfg.GetNameById(int(req.Id)),
})
return nil
}
// 购买棋子商店物品
func ReqBuyChessShop2(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqBuyChessShop2{}
proto.Unmarshal(buf, req)
ChargeMod := player.PlayMod.getChargeMod()
LostItem, _, ChessId, err := ChargeMod.BuyChess(int(req.Id))
if err != nil {
player.SendErrClienRes(&msg.ResBuyChessShop2{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleLoseItem(LostItem, "ChessShop")
if err != nil {
player.SendErrClienRes(&msg.ResBuyChessShop2{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
ChessMod := player.PlayMod.getChessMod()
err = ChessMod.AddChess(ChessId)
if err != nil {
player.SendErrClienRes(&msg.ResBuyChessShop2{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
data := &PlayerChessData{}
err = data.UpdateChessData(player, req.MChessData)
if err != nil {
player.SendErrClienRes(&msg.ResBuyChessShop2{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.TeLog("store_buy", map[string]interface{}{
"item_id": int(req.Id),
"change_num": 1,
"cost_type": "diamond",
"cost_num": LostItem[0].Num,
})
player.PlayMod.save()
player.PushClientRes(ChargeMod.BackData())
player.PushClientRes(&msg.ResBuyChessShop2{
Code: msg.RES_CODE_SUCCESS,
})
player.TeLog("buy_product_diamond", map[string]interface{}{
"diamond_cost": LostItem[0].Num,
"product_id": int(req.Id),
"product_name": mergeDataCfg.GetNameById(int(req.Id)),
})
return nil
}
// 刷新棋子商店
func ReqRefreshChessShop(args []interface{}) error {
_, player, _ := ParseArgs(args)
ChargeMod := player.PlayMod.getChargeMod()
ChessMod := player.PlayMod.getChessMod()
ChargeMod.InitChessShop(ChessMod.GetEmitList())
Cost := []*item.Item{item.NewItem(item.ITEM_DIAMOND_ID, -20)}
err := player.HandleItem(Cost, msg.ITEM_POP_LABEL_RefreshChessShop.String())
if err != nil {
player.SendErrClienRes(&msg.ResRefreshChessShop{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(ChargeMod.BackData())
player.TeLog("refresh_store_diamond", map[string]interface{}{
"diamond_cost": 20,
})
return nil
}
// 领取无尽礼包免费奖励
func ReqEndlessReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqEndlessReward{}
proto.Unmarshal(buf, req)
EndlessMod := player.PlayMod.getEndlessMod()
itemList, err := EndlessMod.GetReward()
if err != nil {
player.SendErrClienRes(&msg.ResEndlessReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_EndlessReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResEndlessReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(EndlessMod.BackData())
player.PushClientRes(&msg.ResEndlessReward{
Code: msg.RES_CODE_SUCCESS,
})
Ids := make([]int, 0)
Nums := make([]int, 0)
for _, v := range itemList {
Ids = append(Ids, v.Id)
Nums = append(Nums, v.Num)
}
player.TeLog("gift_ad", map[string]interface{}{
"gift_type": "endless",
"item_id": Ids,
"item_number": Nums,
})
return nil
}
// 请求无尽礼包数据
func ReqEndless(args []interface{}) error {
_, player, _ := ParseArgs(args)
EndlessMod := player.PlayMod.getEndlessMod()
player.PushClientRes(EndlessMod.BackData())
return nil
}
// 请求存钱罐奖励
func ReqPiggyBankReward(args []interface{}) error {
_, player, _ := ParseArgs(args)
PiggyBankMod := player.PlayMod.getPiggyBankMod()
itemList := PiggyBankMod.Fire(0)
err := player.HandleItem(itemList, msg.ITEM_POP_LABEL_PiggyBankReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResPiggyBankReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(PiggyBankMod.BackData())
player.PushClientRes(&msg.ResPiggyBankReward{
Code: msg.RES_CODE_SUCCESS,
})
player.TeLog("piggy_bank_open", map[string]interface{}{
"piggy_bank_type": piggyBank.PIGGY_BANK_TYPE_AD,
"item_list": itemList,
})
return nil
}
// 生成订单号
func ReqCreateOrderSn(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqCreateOrderSn{}
proto.Unmarshal(buf, req)
OrderSn, err := CreateOrderSn(player, int(req.ChargeId), req.PlatForm, req.Channel)
if err != nil {
return err
}
player.PushClientRes(&msg.ResCreateOrderSn{
OrderSn: OrderSn,
})
return nil
}
// 订单发货
func ReqShippingOrder(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqShippingOrder{}
proto.Unmarshal(buf, req)
OrderSn := req.OrderSn
Status := int(req.Status)
if Status == MergeConst.ORDER_STATUS_CANCEL { // 取消支付
CancelOrder(player, OrderSn)
player.PushClientRes(&msg.ResShippingOrder{
Code: msg.RES_CODE_SUCCESS,
Msg: "cancel success",
})
return nil
}
OrderData, err := GoogleVerify(player, OrderSn, req.ProduceId, req.Token)
if err != nil {
return err
}
if OrderData.PayStatus != MergeConst.ORDER_STATUS_PAY {
player.PushClientRes(&msg.ResShippingOrder{
Code: msg.RES_CODE_FAIL,
Msg: "order status error",
})
return errors.New("order status error")
}
if OrderData.PayStatus == MergeConst.ORDER_STATUS_PAY {
Charge(player, int(OrderData.ProductId))
OrderData.PayStatus = MergeConst.ORDER_STATUS_SHIP
db.UpdatePlayerChargeData(OrderData)
}
player.PlayMod.save()
orderDataMap := map[string]interface{}{
"AppId": conf.Server.AppID,
"ServerId": conf.Server.ServerID,
"OrderId": OrderData.OrderId,
"PayChannelOrderId": OrderData.PayChannelOrderId,
"ProductId": OrderData.ProductId,
"CreateTime": OrderData.CreateTime,
"PayTime": OrderData.PayTime,
"Price": OrderData.Price,
"PayType": OrderData.PayType,
}
player.Kafka("pay", orderDataMap)
player.PushClientRes(&msg.ResShippingOrder{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
// 锦标赛
func ReqChampshipReward(args []interface{}) error {
_, player, _ := ParseArgs(args)
ChampshipMod := player.PlayMod.getChampshipMod()
itemList := ChampshipMod.GetReward()
err := player.HandleItem(itemList, msg.ITEM_POP_LABEL_ChampshipReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResChampshipReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
BackChampship(player)
player.PushClientRes(&msg.ResChampshipReward{
Code: msg.RES_CODE_SUCCESS,
})
player.TeLog("championship_reward", map[string]interface{}{
"season_id": GoUtil.ZeroTimestamp(),
"champship_step_id": ChampshipMod.Reward,
"reward_type": "step",
"item_list": itemList,
"champship_score": ChampshipMod.Score,
})
return nil
}
// 选取限时事件进度奖励
func ReqLimitEventReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqLimitEventReward{}
proto.Unmarshal(buf, req)
LimitedTimeEventMod := player.PlayMod.getLimitedTimeEventMod()
itemList, err := LimitedTimeEventMod.SelectProgressReward(int(req.Id))
if err != nil {
player.SendErrClienRes(&msg.ResLimitEventReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_LimitEventReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResLimitEventReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(LimitedTimeEventMod.ProgressBackData())
player.PushClientRes(&msg.ResLimitEventReward{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
func ReqLimitEvent(args []interface{}) error {
_, player, _ := ParseArgs(args)
LimitedTimeEventMod := player.PlayMod.getLimitedTimeEventMod()
player.PushClientRes(LimitedTimeEventMod.BackData())
return nil
}
func ReqKv(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqKv{}
proto.Unmarshal(buf, req)
KvMod := player.PlayMod.getKvMod()
KvMod.SetVar(int(req.Key), req.Value)
return nil
}
func ReqFriendRecommend(args []interface{}) error {
_, player, _ := ParseArgs(args)
FriendMod := player.PlayMod.getFriendMod()
RecommendList := make([]*msg.ResPlayerSimple, 0)
FriendNum := FriendMod.GetFriendNum()
var n int
if FriendNum < 10 {
n = 3
} else {
Active := 0
for k := range FriendMod.FriendList {
PlayerSimpleData := G_GameLogicPtr.GetSimplePlayerByUid(k)
if PlayerSimpleData.Login > GoUtil.Now()-86400 {
Active++
}
}
n = max(0, 3-(Active/10))
}
PlayerList := GetRecommendPlayer(player, n)
for _, v := range PlayerList {
PlayerSimpleData := G_GameLogicPtr.GetResSimplePlayerByUid(v)
RecommendList = append(RecommendList, PlayerSimpleData)
}
player.PushClientRes(&msg.ResFriendRecommend{
List: RecommendList,
})
player.PlayMod.save()
return nil
}
func ReqFriendList(args []interface{}) error {
_, player, _ := ParseArgs(args)
FriendListBackData(player)
return nil
}
func ReqFriendApply(args []interface{}) error {
_, player, _ := ParseArgs(args)
FriendApplyBackData(player)
return nil
}
func ReqFriendCardMsg(args []interface{}) error {
_, player, _ := ParseArgs(args)
FriendCardBackData(player)
return nil
}
func ReqFriendTimeLine(args []interface{}) error {
_, player, _ := ParseArgs(args)
FriendLogBackData(player)
return nil
}
func ReqChampshipRankReward(args []interface{}) error {
_, player, _ := ParseArgs(args)
MyLastRank := G_GameLogicPtr.ChampshipMgr.getLastMyRank(int(player.M_DwUin))
ChampshipMod := player.PlayMod.getChampshipMod()
itemList, err := ChampshipMod.GetRankReward(MyLastRank)
if err != nil {
player.SendErrClienRes(&msg.ResChampshipRankReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_ChampshipRankReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResChampshipRankReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
BackChampship(player)
player.PushClientRes(&msg.ResChampshipRankReward{
Code: msg.RES_CODE_SUCCESS,
})
player.TeLog("championship_reward", map[string]interface{}{
"season_id": GoUtil.ZeroTimestamp() - 86400,
"champship_step_id": MyLastRank,
"reward_type": "rank",
"item_list": itemList,
"champship_score": ChampshipMod.Score,
})
return nil
}
func ReqSetName(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqSetName{}
proto.Unmarshal(buf, req)
BaseMod := player.PlayMod.getBaseMod()
BaseMod.SetNickName(req.Name)
player.PushClientRes(&msg.ResSetName{
ResultCode: msg.RES_CODE_SUCCESS,
})
player.PlayMod.save()
BackUserInfo(player)
player.UpdateUserInfo()
player.TeLog("nickname_set", map[string]interface{}{
"nickname_name": req.Name,
})
return nil
}
func ReqSetPetName(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqSetPetName{}
proto.Unmarshal(buf, req)
BaseMod := player.PlayMod.getBaseMod()
BaseMod.SetNickName(req.Name)
player.PushClientRes(&msg.ResSetPetName{
ResultCode: msg.RES_CODE_SUCCESS,
})
player.PlayMod.save()
BackUserInfo(player)
player.UpdateUserInfo()
player.TeLog("petname_set", map[string]interface{}{
"petname": req.Name,
})
player.UpdateUserInfo()
return nil
}
func ReqUserInfo(args []interface{}) error {
_, player, _ := ParseArgs(args)
BackUserInfo(player)
return nil
}
func ReqMasterCard(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqMasterCard{}
proto.Unmarshal(buf, req)
CardMod := player.PlayMod.getCardMod()
err := CardMod.MasterCardEx(int(req.Id), int(req.CardId))
if err != nil {
player.SendErrClienRes(&msg.ResMasterCard{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(&msg.ResMasterCard{
Code: msg.RES_CODE_SUCCESS,
MasterId: req.Id,
CardId: req.CardId,
})
player.PushClientRes(CardMod.NotifyCard())
player.TeLog("master_card", map[string]interface{}{
"wild_card_type": req.Id,
"card_id": req.CardId,
})
return nil
}
func ReqSetFacebookUrl(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqSetFacebookUrl{}
proto.Unmarshal(buf, req)
BaseMod := player.PlayMod.getBaseMod()
BaseMod.SetFacebookUrl(req.Url)
player.PlayMod.save()
player.PushClientRes(&msg.ResSetFacebookUrl{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
func ReqInviteFriendData(args []interface{}) error {
_, player, _ := ParseArgs(args)
InviteMod := player.PlayMod.getInviteMod()
player.PushClientRes(InviteMod.BackData())
return nil
}
func ReqSelfInvited(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqSelfInvited{}
proto.Unmarshal(buf, req)
G_GameLogicPtr.FriendMgrSend(&MsqMod.Msg{
Type: MsqMod.HANDLE_TYPE_INVITE_FRIEND,
From: int(player.M_DwUin),
To: int(req.InviterId),
})
player.PushClientRes(&msg.ResSelfInvited{
ResultCode: 1,
})
return nil
}
func ReqGetInviteReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqGetInviteReward{}
proto.Unmarshal(buf, req)
InviteMod := player.PlayMod.getInviteMod()
Items, err := InviteMod.GetReward(int(req.GetIndex))
if err != nil {
log.Debug("ReqGetInviteReward err :%v", err)
return err
}
err = player.HandleItem(Items, msg.ITEM_POP_LABEL_invite.String())
if err != nil {
log.Debug("ReqGetInviteReward err :%v", err)
return err
}
player.PlayMod.save()
player.PushClientRes(&msg.ResGetInviteReward{
ResultCode: 1,
})
player.PushClientRes(InviteMod.BackData())
Str := ""
for k := range InviteMod.InviteList {
Str += strconv.Itoa(k) + ","
}
player.TeLog("register_invite_reward", map[string]interface{}{
"register_type": "facebook",
"item_id": Items,
"register_score": InviteMod.GetIndex,
"player_id": Str,
})
return nil
}
func ReqAutoAddInviteFriend(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqAutoAddInviteFriend{}
proto.Unmarshal(buf, req)
FriendMod := player.PlayMod.getFriendMod()
FriendMod.AddFriend(int(req.Id))
player.PlayMod.save()
player.PushClientRes(&msg.ResAutoAddInviteFriend{
ResultCode: 1,
})
G_GameLogicPtr.FriendMgrSend(&MsqMod.Msg{
From: int(player.M_DwUin),
To: int(req.Id),
Type: MsqMod.HANDLE_TYPE_INVITE_ADD_FRIEND,
})
player.TeLog("friend_add", map[string]interface{}{
"player_id": req.Id,
"add_type": "invite add friend",
})
return nil
}
func ReqSelectLimitEvent(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqSelectLimitEvent{}
proto.Unmarshal(buf, req)
LimitedTimeEventMod := player.PlayMod.getLimitedTimeEventMod()
Items, err := LimitedTimeEventMod.SelectProgressReward(int(req.Id))
if err != nil {
player.SendErrClienRes(&msg.ResSelectLimitEvent{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(Items, msg.ITEM_POP_LABEL_SelectLimitEvent.String())
if err != nil {
player.SendErrClienRes(&msg.ResSelectLimitEvent{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(LimitedTimeEventMod.BackData())
player.PushClientRes(LimitedTimeEventMod.ProgressBackData())
player.PushClientRes(&msg.ResSelectLimitEvent{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
// 请求挖矿基础数据
func ReqMining(args []interface{}) error {
_, player, _ := ParseArgs(args)
MiningBackData(player)
return nil
}
// 请求挖矿
func ReqMiningTake(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqMiningTake{}
proto.Unmarshal(buf, req)
MiningMod := player.PlayMod.getMiningMod()
ActivityInfo := GetActivityInfo(player, ACT_TYPE_MINING)
Status := GetActivityStatus(player, ACT_TYPE_MINING)
if Status != ACT_STATUS_START {
player.SendErrClienRes(&msg.ResMiningTake{
Code: msg.RES_CODE_FAIL,
Msg: "activity not start",
})
return fmt.Errorf("activity not start")
}
LoseItem := miningCfg.GetLoseItem(ActivityInfo.Id)
err := player.HandleLoseItem(LoseItem, "MiningLose")
if err != nil {
player.SendErrClienRes(&msg.ResMiningTake{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
itemList, err := MiningMod.Take(req.Map, int(req.Gem))
if err != nil {
player.SendErrClienRes(&msg.ResMiningTake{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_MiningTake.String())
if err != nil {
player.SendErrClienRes(&msg.ResMiningTake{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.NotifyRed(ACT_TYPE_MINING)
MiningBackData(player)
return nil
}
// 领取关卡奖励
func ReqMiningReward(args []interface{}) error {
_, player, _ := ParseArgs(args)
MiningMod := player.PlayMod.getMiningMod()
Status := GetActivityStatus(player, ACT_TYPE_MINING)
if Status != ACT_STATUS_START {
player.SendErrClienRes(&msg.ResMiningReward{
Code: msg.RES_CODE_FAIL,
Msg: "activity not start",
})
return fmt.Errorf("activity not start")
}
itemList, err := MiningMod.GetReward()
if err != nil {
player.SendErrClienRes(&msg.ResMiningReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_MiningReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResMiningReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
MiningBackData(player)
return nil
}
// 请求猜颜色基础数据
func ReqGuessColor(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqGuessColor{}
proto.Unmarshal(buf, req)
GuessColorMod := player.PlayMod.getGuessColorMod()
Items := GuessColorMod.FirstIn()
err := player.HandleItem(Items, msg.ITEM_POP_LABEL_GuessColor.String())
if err != nil {
return err
}
player.PlayMod.save()
GuessColorBackData(player)
return nil
}
// 请求猜颜色
func ReqGuessColorTake(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqGuessColorTake{}
proto.Unmarshal(buf, req)
Status := GetActivityStatus(player, ACT_TYPE_GUESS_COLOR)
if Status != ACT_STATUS_START {
player.SendErrClienRes(&msg.ResGuessColorTake{
Code: msg.RES_CODE_FAIL,
Msg: "activity not start",
})
return fmt.Errorf("activity not start")
}
GuessColorMod := player.PlayMod.getGuessColorMod()
LoseItem := GuessColorMod.GetLoseItem()
err := player.HandleLoseItem(LoseItem, "GuessColorLose")
if err != nil {
player.SendErrClienRes(&msg.ResGuessColorTake{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
GuessColorMod.Take(req.Map)
player.PlayMod.save()
GuessColorBackData(player)
player.NotifyRed(ACT_TYPE_GUESS_COLOR)
return nil
}
// 请求猜颜色奖励
func ReqGuessColorReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqGuessColorReward{}
proto.Unmarshal(buf, req)
Status := GetActivityStatus(player, ACT_TYPE_GUESS_COLOR)
if Status != ACT_STATUS_START {
player.SendErrClienRes(&msg.ResGuessColorReward{
Code: msg.RES_CODE_FAIL,
Msg: "activity not start",
})
return fmt.Errorf("activity not start")
}
GuessColorMod := player.PlayMod.getGuessColorMod()
itemList, err := GuessColorMod.GetReward()
if err != nil {
player.SendErrClienRes(&msg.ResGuessColorReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(itemList, msg.ITEM_POP_LABEL_GuessColorReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResGuessColorReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
GuessColorBackData(player)
return nil
}
// 请求竞赛基础数据
func ReqRace(args []interface{}) error {
_, player, _ := ParseArgs(args)
RaceBackData(player)
return nil
}
// 请求竞赛开始
func ReqRaceStart(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqRaceStart{}
proto.Unmarshal(buf, req)
RaceMod := player.PlayMod.getRaceMod()
err := RaceMod.StartGame()
if err != nil {
player.SendErrClienRes(&msg.ResRaceStart{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
RaceBackData(player)
player.PushClientRes(&msg.ResRaceStart{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
// 领取竞赛奖励
func ReqRaceReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ResRaceReward{}
proto.Unmarshal(buf, req)
RaceMod := player.PlayMod.getRaceMod()
Items, err := RaceMod.GetReward()
if err != nil {
player.SendErrClienRes(&msg.ResRaceReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(Items, msg.ITEM_POP_LABEL_RaceReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResRaceReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
RaceBackData(player)
player.PushClientRes(&msg.ResRaceReward{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
// 请求playroom基础数据
func ReqPlayroom(args []interface{}) error {
_, player, _ := ParseArgs(args)
PlayroomBackData(player)
return nil
}
// 请求playroom拜访信息
func ReqPlayroomInfo(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqPlayroomInfo{}
proto.Unmarshal(buf, req)
PlayroomMod := player.PlayMod.getPlayroomMod()
Targer := int(req.Uid)
if req.Uid == 0 {
Targer = PlayroomMod.GetTarget()
}
if req.Uid == -1 {
Targer = GetVisitorPlayer(player)
}
if Targer == 0 {
return fmt.Errorf("ReqPlayroomInfo no target")
}
PlayerData := G_GameLogicPtr.GetSimplePlayerByUid(Targer)
PlayroomMod.SetTarget(Targer)
if PlayerData.Loginout < GoUtil.Now()-300 { // todo DEBUG
PlayroomMod.SetGameId(1)
Star := min(500, max(PlayerData.Star/10, 10))
ChessMod := player.PlayMod.getChessMod()
EmitList := ChessMod.GetOrderEmit()
ColorList := make([]string, 0)
for _, v := range EmitList {
Color := mergeDataCfg.GetEmitProduceChessType(v)
ColorList = append(ColorList, Color...)
}
RandList := make([]int, 0)
for _, v := range PlayerData.Chess {
Color := mergeDataCfg.GetColorById(v)
Lv := mergeDataCfg.GetLvById(v)
if GoUtil.InStringArray(Color, ColorList) && Lv <= 8 {
RandList = append(RandList, v)
}
}
if len(RandList) == 0 {
PlayroomMod.SetGameReward(0, 0, Star)
} else if len(RandList) == 1 {
PlayroomMod.SetGameReward(0, RandList[0], Star)
} else {
ChessList := GoUtil.RandSliceNum(RandList, 2)
PlayroomMod.SetGameReward(ChessList[0], ChessList[1], Star)
}
} else {
PlayroomMod.SetGameId(2)
PlayroomMod.SetGameRewardFlip(int(float64(PlayerData.Star)*0.03), int(float64(PlayerData.Star)*0.05), int(float64(PlayerData.Star)*0.1))
}
PlayroomVisit(player, Targer)
return nil
}
// 请求playroom交互
func ReqPlayroomInteract(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqPlayroomInteract{}
proto.Unmarshal(buf, req)
PlayroomMod := player.PlayMod.getPlayroomMod()
Items, MoodType, err := PlayroomMod.Interact(int(req.Id), int(req.Type))
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomInteract{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleLoseItem(Items, "PlayroomInteract")
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomInteract{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
LimitedTimePlayroomTrigger(player, MoodType)
player.PushClientRes(PlayroomMod.NotifyMood())
player.PushClientRes(&msg.ResPlayroomInteract{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
// 请求playroom设置房间
func ReqPlayroomSetRoom(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqPlayroomSetRoom{}
proto.Unmarshal(buf, req)
PlayroomMod := player.PlayMod.getPlayroomMod()
err := PlayroomMod.SetRoom(GoUtil.MapInt32ToInt(req.Playroom))
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomSetRoom{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
PlayroomBackData(player)
player.PushClientRes(&msg.ResPlayroomSetRoom{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
// 玩游戏
func ReqPlayroomGame(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqPlayroomGame{}
proto.Unmarshal(buf, req)
PlayroomMod := player.PlayMod.getPlayroomMod()
Target := PlayroomMod.GetTarget()
if Target == 0 {
player.SendErrClienRes(&msg.ResPlayroomGame{
Code: msg.RES_CODE_FAIL,
Msg: "no target",
})
return fmt.Errorf("no target")
}
PlayerData := G_GameLogicPtr.GetSimplePlayerByUid(Target)
Items := make([]*item.Item, 0)
if req.Type == playroom.GAME_RESULT_LOW {
Items = append(Items, item.NewItem(item.ITEM_STAR_ID, PlayerData.Level*2))
PlayroomMod.ResetGame()
}
if req.Type == playroom.GAME_RESULT_MIDDLE {
Items = append(Items, item.NewItem(item.ITEM_STAR_ID, PlayerData.Level*3))
PlayroomMod.ResetGame()
}
err := player.HandleItem(Items, msg.ITEM_POP_LABEL_PlayroomGame.String())
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomGame{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
// PlayroomBackData(player)
// PlayroomVisit(player, PlayroomMod.GetTarget())
ItemsMsg := make(map[int32]*msg.ItemInfo, 0)
for k, v := range PlayroomMod.GameReward {
ItemsMsg[int32(k)] = &msg.ItemInfo{
Id: int32(v.Id),
Num: int32(v.Num),
}
}
player.PushClientRes(&msg.ResPlayroomGame{
Code: msg.RES_CODE_SUCCESS,
Type: req.Type,
Items: ItemsMsg,
})
return nil
}
// 选择奖励
func ReqPlayroomSelectReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqPlayroomSelectReward{}
proto.Unmarshal(buf, req)
PlayroomMod := player.PlayMod.getPlayroomMod()
Items := PlayroomMod.SelectReward(int(req.Id))
err := player.HandleItem(Items, msg.ITEM_POP_LABEL_PlayroomGame.String())
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomSelectReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
Target := PlayroomMod.GetTarget()
G_GameLogicPtr.FriendMgrSend(&MsqMod.Msg{
From: int(player.M_DwUin),
To: Target,
Type: MsqMod.HANDLE_TYPE_PLAYROOM_LOSE,
SendT: GoUtil.Now(),
Extra: Items,
})
PlayroomMod.ResetGame()
player.PlayMod.save()
PlayroomBackData(player)
PlayroomVisit(player, PlayroomMod.GetTarget())
player.PushClientRes(&msg.ResPlayroomSelectReward{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
// 处理偷取物品
func ReqPlayroomLose(args []interface{}) error {
_, player, _ := ParseArgs(args)
PlayroomMod := player.PlayMod.getPlayroomMod()
PlayroomMod.ResetLose()
player.PushClientRes(PlayroomMod.NotifyLose())
return nil
}
// 宠物开始工作
func ReqPlayroomWork(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqPlayroomWork{}
proto.Unmarshal(buf, req)
PlayroomMod := player.PlayMod.getPlayroomMod()
Items, err := PlayroomMod.Work()
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomWork{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
// 开始工作 设置定时器
if Items != nil {
LimitedTimePlayroomWorkTrigger(player)
player.UpdateUserInfo()
}
err = player.HandleLoseItem(Items, "playroomWork")
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomWork{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(PlayroomMod.NotifyWork())
// PlayroomBackData(player)
player.PushClientRes(&msg.ResPlayroomWork{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
// 宠物休息
func ReqPlayroomRest(args []interface{}) error {
_, player, _ := ParseArgs(args)
PlayroomMod := player.PlayMod.getPlayroomMod()
PlayroomMod.Rest()
player.PlayMod.save()
player.PushClientRes(PlayroomMod.NotifyWork())
return nil
}
// 抽取转盘
func ReqPlayroomDraw(args []interface{}) error {
_, player, _ := ParseArgs(args)
PlayroomMod := player.PlayMod.getPlayroomMod()
Id, Items, err := PlayroomMod.Draw()
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomDraw{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.args["ResItemPopId"] = Id
err = player.HandleItem(Items, msg.ITEM_POP_LABEL_PlayroomDraw.String())
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomDraw{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
// PlayroomBackData(player)
player.PushClientRes(PlayroomMod.NotifyMood())
player.PushClientRes(&msg.ResPlayroomDraw{
Code: msg.RES_CODE_SUCCESS,
Id: int32(Id),
})
return nil
}
// 清理碎片
func ReqPlayroomChip(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqPlayroomChip{}
proto.Unmarshal(buf, req)
PlayroomMod := player.PlayMod.getPlayroomMod()
Items := PlayroomMod.RemoveChip(int(req.Num))
err := player.HandleItem(Items, msg.ITEM_POP_LABEL_PlayroomChip.String())
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomChip{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
PlayroomBackData(player)
player.PushClientRes(&msg.ResPlayroomChip{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
// 翻牌游戏
func ReqPlayroomFlip(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqPlayroomFlip{}
proto.Unmarshal(buf, req)
PlayroomMod := player.PlayMod.getPlayroomMod()
CardId, err := PlayroomMod.FlipCard(int(req.Id))
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomFlip{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.Kafka("playroom_flip", map[string]interface{}{
"CardID": CardId,
"Id": req.Id,
})
player.PlayMod.save()
PlayroomBackData(player)
player.PushClientRes(&msg.ResPlayroomFlip{
Code: msg.RES_CODE_SUCCESS,
Id: req.Id,
CardId: int32(CardId),
})
return nil
}
func ReqPlayroomFlipReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqPlayroomFlipReward{}
proto.Unmarshal(buf, req)
PlayroomMod := player.PlayMod.getPlayroomMod()
Items, err := PlayroomMod.GetFlipReward()
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomFlipReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
Items1 := Items
LimitedTimeEventMod := player.PlayMod.getLimitedTimeEventMod()
if LimitedTimeEventMod.CheckExist(limitedTimeEvent.EVENT_TYPE_PET_THIEF) {
Items1 = item.Merge(Items1, Items1)
}
err = player.HandleItem(Items1, msg.ITEM_POP_LABEL_PlayroomFlip.String())
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomFlip{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
Target := PlayroomMod.GetTarget()
G_GameLogicPtr.FriendMgrSend(&MsqMod.Msg{
From: int(player.M_DwUin),
To: Target,
Type: MsqMod.HANDLE_TYPE_PLAYROOM_LOSE,
SendT: GoUtil.Now(),
Extra: Items,
})
player.PlayMod.save()
PlayroomBackData(player)
player.PushClientRes(&msg.ResPlayroomFlipReward{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
func ReqPlayroomBuyItem(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqPlayroomBuyItem{}
proto.Unmarshal(buf, req)
PlayroomMod := player.PlayMod.getPlayroomMod()
AddItems, CostItem := PlayroomMod.BuyItem(int(req.Id))
if CostItem == nil {
err := fmt.Errorf("can not buy item")
player.SendErrClienRes(&msg.ResPlayroomBuyItem{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err := player.HandleLoseItem(CostItem, msg.ITEM_POP_LABEL_PlayroomBuyItem.String())
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomBuyItem{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(AddItems, msg.ITEM_POP_LABEL_PlayroomBuyItem.String())
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomBuyItem{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
// PlayroomBackData(player)
player.PushClientRes(&msg.ResPlayroomBuyItem{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
func ReqOfflineReconnectFunc(args []interface{}) error {
a := args[0].(gate.Agent)
buf := args[1].([]byte)
req := &msg.ReqOfflineReconnect{}
proto.Unmarshal(buf, req)
res := &msg.ResOfflineReconnect{}
res.DwUin = req.DwUin
if v, ok := G_GameLogicPtr.M_Players.Load(req.DwUin); ok {
player := v.(*Player)
agent := player.GetAgentByPlayer()
if agent != a {
player.SetAgent(a)
internal.AsignPlayerToAgents(a, player)
internal.Agents.Delete(agent)
}
res.Result = 3
} else {
res.Result = 2
}
data, _ := proto.Marshal(res)
G_GameLogicPtr.PackResInfo(a, "ResOfflineReconnect", data)
return nil
}
// playroom 打工离线
func ReqPlayroomOutline(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqPlayroomOutline{}
proto.Unmarshal(buf, req)
ChessMod := player.PlayMod.getChessMod()
if req.CostDia < 0 {
var itemList []*item.Item
item := item.NewItem(item.ITEM_DIAMOND_ID, int(req.CostDia))
itemList = append(itemList, item)
err := player.HandleItem(itemList, msg.ITEM_POP_LABEL_ChessEx.String())
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomOutline{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
}
err := ChessMod.ExChess(int(req.OldChessId), int(req.NewChessId))
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomOutline{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
HandbookMod := player.PlayMod.getHandbookMod()
HandbookMod.SetHandbook(int(req.NewChessId))
data := &PlayerChessData{}
err = data.UpdateChessData(player, req.MChessData)
if err != nil {
player.SendErrClienRes(&msg.ResPlayroomOutline{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(ChessMod.BackData())
player.PushClientRes(&msg.ResPlayroomOutline{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
func ReqPlayroomWrokOutline(args []interface{}) error {
_, player, _ := ParseArgs(args)
PlayroomMod := player.PlayMod.getPlayroomMod()
PlayroomMod.SetWorkOutline(0)
player.PlayMod.save()
player.PushClientRes(PlayroomMod.NotifyStatus())
player.PushClientRes(&msg.ResPlayroomWrokOutline{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
func ReqFriendTreasure(args []interface{}) error {
_, player, _ := ParseArgs(args)
player.PushClientRes(player.PlayMod.getFriendTreasureMod().BackData())
return nil
}
func ReqFriendTreasureStart(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqFriendTreasureStart{}
proto.Unmarshal(buf, req)
// FriendMod := player.PlayMod.getFriendMod()
FriendTreasureMod := player.PlayMod.getFriendTreasureMod()
if FriendTreasureMod.Status == 1 {
player.SendErrClienRes(&msg.ResFriendTreasureStart{
Code: msg.RES_CODE_FAIL,
Msg: "game not over",
})
return fmt.Errorf("game not over")
}
if FriendTreasureMod.Star < 100 {
player.SendErrClienRes(&msg.ResFriendTreasureStart{
Code: msg.RES_CODE_FAIL,
Msg: "not enough star",
})
return fmt.Errorf("not enough star")
}
// FriendList := FriendMod.GetFriendList()
// FriendList2 := GoUtil.SubSlices(FriendList, FriendTreasureMod.GetFriendList())
// if len(FriendList2) < 5 {
// player.SendErrClienRes(&msg.ResFriendTreasureStart{
// Code: msg.RES_CODE_FAIL,
// Msg: "not enough friends",
// })
// return fmt.Errorf("not enough friends")
// }
// Alive := make([]int, 0)
// NotAlive := make([]int, 0)
// Now := GoUtil.Now()
// for _, v := range FriendList2 {
// PD := G_GameLogicPtr.GetSimplePlayerByUid(v)
// if PD.Login < Now-86400 {
// NotAlive = append(NotAlive, v)
// } else {
// Alive = append(Alive, v)
// }
// }
FriendTreasureMod.InitGame(req.List, req.List2)
player.PlayMod.save()
player.PushClientRes(&msg.ResFriendTreasureStart{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
func ReqFriendTreasureFilp(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqFriendTreasureFilp{}
proto.Unmarshal(buf, req)
FriendTreasureMod := player.PlayMod.getFriendTreasureMod()
Items, err := FriendTreasureMod.Flip(int(req.Pos))
if err != nil {
player.SendErrClienRes(
&msg.ResFriendTreasureFilp{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
},
)
return err
}
err = player.HandleItem(Items, msg.ITEM_POP_LABEL_FriendtreasureFilp.String())
if err != nil {
player.SendErrClienRes(
&msg.ResFriendTreasureFilp{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
},
)
return err
}
player.PlayMod.save()
player.PushClientRes(&msg.ResFriendTreasureFilp{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
func ReqFriendTreasureEnd(args []interface{}) error {
_, player, _ := ParseArgs(args)
FriendTreasureMod := player.PlayMod.getFriendTreasureMod()
Items, FriendItemNum, err := FriendTreasureMod.EndGame()
if err != nil {
player.SendErrClienRes(
&msg.ResFriendTreasureEnd{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
},
)
return err
}
for _, v := range FriendTreasureMod.List {
if v.Status != 1 {
continue
}
G_GameLogicPtr.FriendMgrSend(&MsqMod.Msg{
From: int(player.M_DwUin),
To: int(v.Uid),
Type: MsqMod.FRIEND_TREASURE_HANDLE,
SendT: GoUtil.Now(),
Extra: []*item.Item{item.NewItem(item.ITEM_STAR_ID, FriendItemNum)},
})
}
err = player.HandleItem(Items, msg.ITEM_POP_LABEL_FriendtreasureEnd.String())
if err != nil {
player.SendErrClienRes(
&msg.ResFriendTreasureEnd{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
},
)
return err
}
player.PlayMod.save()
player.PushClientRes(&msg.ResFriendTreasureEnd{
Code: msg.RES_CODE_SUCCESS,
})
return nil
}
func ReqKafkaLog(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqKafkaLog{}
proto.Unmarshal(buf, req)
player.Kafka(req.Event, map[string]interface{}{
"data": req.Data,
})
return nil
}
func ReqCardHandbookReward(args []interface{}) error {
_, player, buf := ParseArgs(args)
req := &msg.ReqCardHandbookReward{}
proto.Unmarshal(buf, req)
CardMod := player.PlayMod.getCardMod()
Items, err := CardMod.GetHandbookReward(int(req.CardId))
if err != nil {
player.SendErrClienRes(&msg.ResCardHandbookReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
err = player.HandleItem(Items, msg.ITEM_POP_LABEL_CardHandbookReward.String())
if err != nil {
player.SendErrClienRes(&msg.ResCardHandbookReward{
Code: msg.RES_CODE_FAIL,
Msg: err.Error(),
})
return err
}
player.PlayMod.save()
player.PushClientRes(&msg.ResCardHandbookReward{
Code: msg.RES_CODE_SUCCESS,
CardId: req.CardId,
})
return nil
}