Files
bl/logic/controller/login.go
2025-08-28 21:57:30 +00:00

53 lines
1.7 KiB
Go

package controller
import (
"blazing/common/data/share"
"blazing/common/data/socket"
"blazing/common/socket/errorcode"
"blazing/common/socket/handler"
"blazing/logic/service"
"blazing/logic/service/login"
"blazing/logic/service/maps"
"blazing/logic/service/space"
blservice "blazing/modules/blazing/service"
"context"
"time"
"github.com/gogf/gf/v2/os/glog"
"github.com/jinzhu/copier"
)
// 处理命令: 1001
func (h *Controller) Login(data *login.InInfo, c *socket.Conn) (result *login.OutInfo, err errorcode.ErrorCode) { //这个时候player应该是空的
if tt := data.CheakSession(); tt { //说明sid正确
h.RPCClient.Kick(data.Head.UserID) //先踢人
playerinfo := blservice.NewUserService(data.Head.UserID).Person()
t := service.SetPlayer(c, playerinfo)
t.Onlinetime = uint32(time.Now().Unix()) //保存时间戳
copier.Copy(playerinfo, t) //先复制给内存信息
share.ShareManager.SetUserOnline(data.Head.UserID, h.Port) //设置用户登录服务器
t.CompleteLogin() //通知客户端登录成功
glog.Debug(context.Background(), "登录成功,初始地图 人数:", space.GetSpace(t.Info.MapID).Len())
result = login.NewOutInfo() //设置登录消息
copier.Copy(playerinfo, result)
defer space.GetSpace(t.Info.MapID).Set(t.Info.UserID, t).Range(func(playerID uint32, player *socket.Player) bool {
tt := maps.NewOutInfo()
copier.Copy(playerinfo, tt)
t1 := handler.NewTomeeHeader(2001, t.Info.UserID)
player.SendPack(t1.Pack(&tt))
return true
})
return result, 0
} else {
err = errorcode.ErrorCodes.ErrLoginServerError
}
return
}