2025-12-11 10:32:39 +08:00
|
|
|
package controller
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"blazing/common/data/share"
|
|
|
|
|
"blazing/cool"
|
|
|
|
|
|
|
|
|
|
"blazing/common/socket/errorcode"
|
|
|
|
|
|
|
|
|
|
"blazing/logic/service/user"
|
|
|
|
|
|
|
|
|
|
"blazing/logic/service/player"
|
|
|
|
|
"blazing/logic/service/space"
|
2026-01-19 18:51:56 +08:00
|
|
|
"blazing/modules/player/service"
|
2025-12-11 10:32:39 +08:00
|
|
|
"context"
|
|
|
|
|
"time"
|
|
|
|
|
|
|
|
|
|
"github.com/panjf2000/gnet/v2"
|
|
|
|
|
)
|
|
|
|
|
|
2025-12-24 19:03:11 +08:00
|
|
|
// Login 处理命令: 1001
|
2026-04-05 07:24:36 +08:00
|
|
|
func (h Controller) Login(data *MAIN_LOGIN_IN, c gnet.Conn) (result *user.LoginMSInfo, err errorcode.ErrorCode) { //这个时候player应该是空的
|
2026-02-07 18:26:22 +08:00
|
|
|
|
|
|
|
|
if data.Head.UserID == 0 {
|
|
|
|
|
defer c.Close()
|
|
|
|
|
return
|
|
|
|
|
}
|
2026-02-08 02:11:46 +08:00
|
|
|
isSessionValid, hashcode := data.CheakSession()
|
2025-12-24 19:03:11 +08:00
|
|
|
if !isSessionValid {
|
2025-12-11 10:32:39 +08:00
|
|
|
|
|
|
|
|
defer c.Close()
|
|
|
|
|
return
|
|
|
|
|
}
|
2026-03-04 00:14:30 +08:00
|
|
|
_, erre := share.ShareManager.GetUserOnline(data.Head.UserID)
|
|
|
|
|
if erre == nil {
|
|
|
|
|
error := Maincontroller.RPCClient.Kick(data.Head.UserID) //通知其他服务器踢人
|
|
|
|
|
if error != nil {
|
|
|
|
|
cool.Logger.Error(context.Background(), "踢人失败", err)
|
|
|
|
|
|
|
|
|
|
defer c.Close()
|
|
|
|
|
return
|
|
|
|
|
}
|
2026-02-07 23:09:11 +08:00
|
|
|
}
|
2026-03-04 00:14:30 +08:00
|
|
|
|
2026-03-21 00:24:34 +08:00
|
|
|
data1, ok := c.Context().(*player.ClientData)
|
|
|
|
|
if !ok {
|
|
|
|
|
cool.Logger.Error(context.Background(), "已空指针", data.Head.UserID)
|
|
|
|
|
|
|
|
|
|
defer c.Close()
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
currentPlayer := data1.GetPlayer(data.Head.UserID)
|
2026-02-08 02:11:46 +08:00
|
|
|
|
2025-12-24 19:03:11 +08:00
|
|
|
if currentPlayer == nil {
|
2025-12-25 12:14:04 +08:00
|
|
|
cool.Logger.Error(context.Background(), "获取玩家失败", data.Head.UserID)
|
2025-12-11 10:32:39 +08:00
|
|
|
|
|
|
|
|
defer c.Close()
|
|
|
|
|
return
|
|
|
|
|
}
|
2026-02-08 02:11:46 +08:00
|
|
|
currentPlayer.Hash = hashcode
|
2026-01-19 18:51:56 +08:00
|
|
|
currentPlayer.Service = service.NewUserService(data.Head.UserID)
|
2025-12-12 19:10:09 +00:00
|
|
|
|
2026-03-08 11:22:00 +08:00
|
|
|
currentPlayer.Info = currentPlayer.Service.Info.GetLogin()
|
2025-12-24 19:03:11 +08:00
|
|
|
if currentPlayer.Info == nil {
|
2025-12-11 10:32:39 +08:00
|
|
|
defer c.Close()
|
|
|
|
|
return
|
|
|
|
|
}
|
2026-03-04 00:14:30 +08:00
|
|
|
share.ShareManager.SetUserOnline(data.Head.UserID, h.UID) //设置用户登录服务器
|
|
|
|
|
|
2025-12-24 19:03:11 +08:00
|
|
|
currentPlayer.Info.UserID = data.Head.UserID
|
|
|
|
|
currentPlayer.Logintime = uint32(time.Now().Unix()) //保存时间戳
|
2025-12-11 10:32:39 +08:00
|
|
|
|
2026-01-25 23:17:46 +08:00
|
|
|
result = user.NewOutInfo(currentPlayer.Info) //设置登录消息
|
2025-12-11 10:32:39 +08:00
|
|
|
|
2025-12-24 19:03:11 +08:00
|
|
|
defer space.GetSpace(currentPlayer.Info.MapID).EnterMap(currentPlayer)
|
2025-12-11 10:32:39 +08:00
|
|
|
|
2026-03-05 23:51:07 +08:00
|
|
|
// for i := 0; i < 10; i++ {
|
2026-02-27 23:43:00 +08:00
|
|
|
|
2026-03-05 23:51:07 +08:00
|
|
|
// fmt.Println("任务", 291+i, currentPlayer.Info.GetTask(291+i))
|
2026-02-27 23:43:00 +08:00
|
|
|
// }
|
2026-03-04 13:01:24 +08:00
|
|
|
// currentPlayer.Info.SetTask(314, model.Completed)
|
2026-02-27 23:43:00 +08:00
|
|
|
// currentPlayer.Info.SetTask(315, model.Completed)
|
2026-03-20 04:58:23 +08:00
|
|
|
//fmt.Println("任务", 291, currentPlayer.Info.GetTask(145))
|
2026-02-07 00:18:14 +08:00
|
|
|
currentPlayer.IsLogin = true
|
2025-12-11 10:32:39 +08:00
|
|
|
return result, 0
|
|
|
|
|
|
|
|
|
|
}
|