2025-06-23 10:15:22 +08:00
|
|
|
|
package controller
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
2025-07-15 18:10:25 +00:00
|
|
|
|
"blazing/common/data/share"
|
2025-10-20 23:59:49 +08:00
|
|
|
|
"blazing/common/data/xmlres"
|
2025-10-16 18:59:38 +00:00
|
|
|
|
"blazing/cool"
|
2025-10-15 22:53:14 +00:00
|
|
|
|
"fmt"
|
2025-09-04 02:00:57 +08:00
|
|
|
|
|
2025-07-31 07:31:25 +00:00
|
|
|
|
"blazing/common/socket/errorcode"
|
2025-09-04 02:00:57 +08:00
|
|
|
|
|
2025-10-10 20:46:16 +08:00
|
|
|
|
"blazing/logic/service/common"
|
2025-09-22 09:15:26 +00:00
|
|
|
|
"blazing/logic/service/user"
|
|
|
|
|
|
|
2025-08-24 17:33:19 +08:00
|
|
|
|
"blazing/logic/service/maps"
|
2025-09-14 01:35:16 +08:00
|
|
|
|
"blazing/logic/service/player"
|
2025-08-17 21:55:15 +08:00
|
|
|
|
"blazing/logic/service/space"
|
2025-08-22 22:40:32 +08:00
|
|
|
|
blservice "blazing/modules/blazing/service"
|
2025-08-17 21:55:15 +08:00
|
|
|
|
"context"
|
2025-08-28 21:57:30 +00:00
|
|
|
|
"time"
|
2025-08-17 21:55:15 +08:00
|
|
|
|
|
2025-10-23 01:02:19 +08:00
|
|
|
|
"github.com/gogf/gf/v2/os/gtime"
|
2025-10-13 23:38:48 +08:00
|
|
|
|
"github.com/jinzhu/copier"
|
2025-10-14 03:07:55 +08:00
|
|
|
|
"github.com/panjf2000/gnet/v2"
|
2025-06-23 10:15:22 +08:00
|
|
|
|
)
|
|
|
|
|
|
|
2025-08-31 06:53:42 +00:00
|
|
|
|
func IsToday(t time.Time) bool {
|
|
|
|
|
|
// 获取当前时间
|
|
|
|
|
|
now := time.Now()
|
|
|
|
|
|
|
|
|
|
|
|
// 比较年、月、日是否相同
|
|
|
|
|
|
return t.Year() == now.Year() &&
|
|
|
|
|
|
t.Month() == now.Month() &&
|
|
|
|
|
|
t.Day() == now.Day()
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-06-23 10:15:22 +08:00
|
|
|
|
// 处理命令: 1001
|
2025-10-14 03:07:55 +08:00
|
|
|
|
func (h *Controller) Login(data *user.MAIN_LOGIN_IN, c gnet.Conn) (result *user.LoginMSInfo, err errorcode.ErrorCode) { //这个时候player应该是空的
|
2025-10-31 00:53:22 +08:00
|
|
|
|
tt := data.CheakSession()
|
|
|
|
|
|
if !tt {
|
|
|
|
|
|
err = errorcode.ErrorCodes.ErrLoginServerError
|
|
|
|
|
|
return
|
|
|
|
|
|
}
|
2025-06-26 19:40:51 +08:00
|
|
|
|
|
2025-10-31 00:53:22 +08:00
|
|
|
|
cool.Loger.Info(context.TODO(), "准备踢人")
|
|
|
|
|
|
err1 := h.RPCClient.Kick(data.Head.UserID) //先踢人
|
|
|
|
|
|
if err1 != nil {
|
|
|
|
|
|
fmt.Println("踢人失败", err)
|
|
|
|
|
|
}
|
|
|
|
|
|
//player.KickPlayer(data.Head.UserID)
|
|
|
|
|
|
cool.Loger.Info(context.TODO(), "踢人请求完成,继续登录流程")
|
|
|
|
|
|
|
|
|
|
|
|
// <-time.After(time.Millisecond * 3000)
|
|
|
|
|
|
share.ShareManager.SetUserOnline(data.Head.UserID, h.Port) //设置用户登录服务器
|
|
|
|
|
|
t := player.GetPlayer(c, data.Head.UserID)
|
|
|
|
|
|
t.Service = blservice.NewUserService(data.Head.UserID)
|
|
|
|
|
|
t.Info = t.Service.Person(data.Head.UserID)
|
|
|
|
|
|
if t.Info == nil {
|
|
|
|
|
|
err = errorcode.ErrorCodes.ErrLoginServerError
|
|
|
|
|
|
return
|
|
|
|
|
|
}
|
|
|
|
|
|
t.Info.UserID = data.Head.UserID
|
|
|
|
|
|
t.Onlinetime = uint32(time.Now().Unix()) //保存时间戳
|
|
|
|
|
|
t.Changemap = true
|
|
|
|
|
|
cool.Loger.Info(context.Background(), "用户上次重置日期", t.Info.LastResetTime.String())
|
|
|
|
|
|
if !IsToday(t.Info.LastResetTime) { //判断是否是今天
|
|
|
|
|
|
t.Info.LastResetTime = gtime.Now().Time
|
|
|
|
|
|
//每天login时候检查重置时间,然后把电池,任务,挖矿重置
|
|
|
|
|
|
//挖矿需要单独存,因为防止多开挖矿
|
|
|
|
|
|
t.Info.TimeToday = 0 //重置电池
|
|
|
|
|
|
|
|
|
|
|
|
for i := 400; i < 500; i++ { //每日任务区段
|
|
|
|
|
|
|
|
|
|
|
|
tttL, ok := xmlres.TaskMap[i]
|
|
|
|
|
|
if ok {
|
|
|
|
|
|
if tttL.Type == 1 { //日常任务
|
|
|
|
|
|
t.Info.TaskList[i-1] = 0 //重置每日任务
|
2025-10-20 23:59:49 +08:00
|
|
|
|
|
2025-10-31 00:53:22 +08:00
|
|
|
|
}
|
2025-10-20 23:59:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2025-10-31 00:53:22 +08:00
|
|
|
|
}
|
|
|
|
|
|
for i := 0; i < 50; i++ { //每日任务区段
|
|
|
|
|
|
t.Info.DailyResArr[i] = 0 //重置每日任务
|
2025-09-10 02:26:25 +00:00
|
|
|
|
|
2025-08-31 06:53:42 +00:00
|
|
|
|
}
|
2025-10-31 00:53:22 +08:00
|
|
|
|
defer t.Service.Talk(func(m map[uint32]uint32) bool { //挖矿
|
|
|
|
|
|
m = map[uint32]uint32{}
|
|
|
|
|
|
return true
|
|
|
|
|
|
})
|
2025-09-19 00:29:55 +08:00
|
|
|
|
|
2025-10-31 00:53:22 +08:00
|
|
|
|
}
|
2025-08-28 21:35:56 +00:00
|
|
|
|
|
2025-10-31 00:53:22 +08:00
|
|
|
|
t.CompleteLogin() //通知客户端登录成功
|
2025-08-30 21:59:52 +08:00
|
|
|
|
|
2025-10-31 00:53:22 +08:00
|
|
|
|
result = user.NewOutInfo() //设置登录消息
|
2025-10-23 06:00:33 +00:00
|
|
|
|
|
2025-10-31 00:53:22 +08:00
|
|
|
|
result.PlayerInfo = *t.Info
|
2025-10-28 02:28:15 +08:00
|
|
|
|
|
2025-10-31 00:53:22 +08:00
|
|
|
|
defer func() {
|
|
|
|
|
|
tt := maps.NewOutInfo()
|
|
|
|
|
|
copier.CopyWithOption(tt, t.Info, copier.Option{DeepCopy: true})
|
|
|
|
|
|
//copier.Copy(t.Info, tt)
|
|
|
|
|
|
t1 := player.NewTomeeHeader(2001, t.Info.UserID)
|
2025-10-10 20:46:16 +08:00
|
|
|
|
|
2025-10-31 00:53:22 +08:00
|
|
|
|
space.GetSpace(t.Info.MapID).User.IterCb(func(playerID uint32, player common.PlayerI) {
|
|
|
|
|
|
player.SendPack(t1.Pack(tt))
|
2025-08-15 19:24:02 +08:00
|
|
|
|
|
2025-10-31 00:53:22 +08:00
|
|
|
|
})
|
|
|
|
|
|
space.GetSpace(t.Info.MapID).User.Set(t.Info.UserID, t)
|
|
|
|
|
|
}()
|
2025-07-25 23:37:02 +08:00
|
|
|
|
|
2025-10-31 00:53:22 +08:00
|
|
|
|
return result, 0
|
2025-08-13 23:37:16 +08:00
|
|
|
|
|
2025-06-23 10:15:22 +08:00
|
|
|
|
}
|