2023-09-23 16:51:16 +00:00
|
|
|
using Microsoft.Extensions.Logging;
|
2023-09-23 11:11:07 +00:00
|
|
|
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;
|
2023-09-23 12:20:45 +00:00
|
|
|
using Tiger.Storage;
|
2023-09-23 11:11:07 +00:00
|
|
|
|
|
|
|
namespace Tiger.Communication.Messages.Incoming.Handshake;
|
|
|
|
|
|
|
|
public class SsoTicketEvent : IMessageEvent
|
|
|
|
{
|
2023-09-23 12:20:45 +00:00
|
|
|
private readonly IRepository<Habbo> _habboRepository;
|
2023-09-23 11:11:07 +00:00
|
|
|
private readonly IGameSessionManager _gameSessionManager;
|
2023-09-23 12:20:45 +00:00
|
|
|
private readonly ISettingManager _settingManager;
|
2023-09-23 16:51:16 +00:00
|
|
|
private readonly ILogger<SsoTicketEvent> _logger;
|
2023-09-23 11:11:07 +00:00
|
|
|
|
2023-09-23 16:51:16 +00:00
|
|
|
public SsoTicketEvent(IRepository<Habbo> habboRepository, IGameSessionManager gameSessionManager, ISettingManager settingManager, ILogger<SsoTicketEvent> logger)
|
2023-09-23 11:11:07 +00:00
|
|
|
{
|
2023-09-23 12:20:45 +00:00
|
|
|
_habboRepository = habboRepository;
|
2023-09-23 11:11:07 +00:00
|
|
|
_gameSessionManager = gameSessionManager;
|
2023-09-23 12:20:45 +00:00
|
|
|
_settingManager = settingManager;
|
2023-09-23 16:51:16 +00:00
|
|
|
_logger = logger;
|
2023-09-23 11:11:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2023-09-23 12:20:45 +00:00
|
|
|
var habbo = await _habboRepository.FindOneByAsync(h => h.SsoTicket == sso);
|
2023-09-23 11:11:07 +00:00
|
|
|
|
|
|
|
if (habbo == null)
|
|
|
|
{
|
|
|
|
await _gameSessionManager.CloseAsync("User not found", gameSession);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
gameSession.Habbo = habbo;
|
2023-09-23 16:51:16 +00:00
|
|
|
gameSession.Habbo.LastLogin = DateTime.Now;
|
|
|
|
gameSession.Habbo.Online = true;
|
|
|
|
_habboRepository.SaveAsync(gameSession.Habbo);
|
|
|
|
|
|
|
|
_logger.LogInformation("{User} logged in", gameSession.Habbo.Username);
|
2023-09-23 11:11:07 +00:00
|
|
|
|
|
|
|
await gameSession.SendComposerAsync(new AuthenticationOkMessageComposer());
|
|
|
|
await gameSession.SendComposerAsync(new HabboBroadcastMessageComposer(
|
2023-09-23 12:20:45 +00:00
|
|
|
_settingManager.GetSetting<string>("welcome.message")
|
2023-09-23 11:11:07 +00:00
|
|
|
.Replace("{user}", gameSession.Habbo.Username)
|
|
|
|
));
|
|
|
|
}
|
|
|
|
}
|