server-master/srcs/_plugins/Plugin.FamilyImpl/FamilyWarehouseLogsOpenEventHandler.cs
2026-02-10 18:21:30 +01:00

77 lines
No EOL
3.1 KiB
C#

using System.Collections.Generic;
using System.Threading;
using System.Threading.Tasks;
using PhoenixLib.Events;
using WingsAPI.Data.Families;
using WingsAPI.Game.Extensions.Families;
using WingsEmu.Game._enum;
using WingsEmu.Game._i18n;
using WingsEmu.Game.Characters;
using WingsEmu.Game.Extensions;
using WingsEmu.Game.Families;
using WingsEmu.Game.Families.Event;
using WingsEmu.Game.Networking;
namespace Plugin.FamilyImpl
{
public class FamilyWarehouseLogsOpenEventHandler : IAsyncEventProcessor<FamilyWarehouseLogsOpenEvent>
{
private readonly IFamilyWarehouseManager _familyWarehouseManager;
private readonly IGameLanguageService _languageService;
public FamilyWarehouseLogsOpenEventHandler(IGameLanguageService languageService, IFamilyWarehouseManager familyWarehouseManager)
{
_languageService = languageService;
_familyWarehouseManager = familyWarehouseManager;
}
public async Task HandleAsync(FamilyWarehouseLogsOpenEvent e, CancellationToken cancellation)
{
IClientSession session = e.Sender;
IPlayerEntity character = e.Sender.PlayerEntity;
IFamily family = session.PlayerEntity.Family;
if (e.Refresh && !character.IsFamilyWarehouseLogsOpen || character.IsFamilyWarehouseOpen || session.CantPerformActionOnAct4() || character.HasShopOpened || character.IsInExchange())
{
return;
}
if (family == null)
{
session.SendInfo(_languageService.GetLanguage(GameDialogKey.FAMILY_INFO_NO_FAMILY, session.UserLanguage));
return;
}
if (family.GetWarehouseCapacity() == 0)
{
session.SendInfo(_languageService.GetLanguage(GameDialogKey.FAMILY_INFO_NO_FAMILY_WAREHOUSE, session.UserLanguage));
return;
}
if (!session.CheckLogHistoryPermission())
{
session.SendInfo(_languageService.GetLanguage(GameDialogKey.FAMILY_INFO_WAREHOUSE_NOT_ENOUGH_PERMISSION, session.UserLanguage));
return;
}
(IList<FamilyWarehouseLogEntryDto> logs, ManagerResponseType? responseType) = await _familyWarehouseManager.GetWarehouseLogs(family.Id, character.Id);
if (responseType == null)
{
e.Sender.SendInfo(_languageService.GetLanguage(GameDialogKey.FAMILY_INFO_WAREHOUSE_UNEXPECTED_ERROR, e.Sender.UserLanguage));
return;
}
if (responseType == ManagerResponseType.Success)
{
session.PlayerEntity.IsFamilyWarehouseLogsOpen = true;
session.SendFamilyWarehouseLogs(logs ?? new List<FamilyWarehouseLogEntryDto>());
return;
}
e.Sender.SendInfo(responseType == ManagerResponseType.Maintenance
? _languageService.GetLanguage(GameDialogKey.FAMILY_INFO_SERVICE_MAINTENANCE_MODE, e.Sender.UserLanguage)
: _languageService.GetLanguage(GameDialogKey.FAMILY_INFO_WAREHOUSE_UNEXPECTED_ERROR, e.Sender.UserLanguage));
}
}
}