using Microsoft.Extensions.Logging; using Tiger.Communication.Messages.Interfaces; using Tiger.Communication.Messages.Outgoing.Generic.Alerts; using Tiger.Communication.Messages.Outgoing.Handshake; using Tiger.Communication.Messages.Types; using Tiger.Game.Habbos; using Tiger.Game.Settings; using Tiger.Networking.Game.Sessions; using Tiger.Storage; namespace Tiger.Communication.Messages.Incoming.Handshake; public class SsoTicketEvent : IMessageEvent { private readonly IRepository _habboRepository; private readonly IGameSessionManager _gameSessionManager; private readonly ISettingManager _settingManager; private readonly ILogger _logger; public SsoTicketEvent(IRepository habboRepository, IGameSessionManager gameSessionManager, ISettingManager settingManager, ILogger logger) { _habboRepository = habboRepository; _gameSessionManager = gameSessionManager; _settingManager = settingManager; _logger = logger; } public IncomingHeaders Header => IncomingHeaders.SSoTicketEvent; public async Task HandleAsync(GameSession gameSession, ClientMessage request) { var sso = request.ReadString(); if (sso == null) { await _gameSessionManager.CloseAsync("Malformed packet", gameSession); return; } var habbo = await _habboRepository.FindOneByAsync(h => h.SsoTicket == sso); if (habbo == null) { await _gameSessionManager.CloseAsync("User not found", gameSession); return; } gameSession.Habbo = habbo; gameSession.Habbo.LastLogin = DateTime.Now; gameSession.Habbo.Online = true; _habboRepository.SaveAsync(gameSession.Habbo); _logger.LogInformation("{User} logged in", gameSession.Habbo.Username); await gameSession.SendComposerAsync(new AuthenticationOkMessageComposer()); await gameSession.SendComposerAsync(new HabboBroadcastMessageComposer( _settingManager.GetSetting("welcome.message") .Replace("{user}", gameSession.Habbo.Username) )); } }