//
// DropResponder.cs
//
// Copyright (c) František Boháček. All rights reserved.
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
using Microsoft.Extensions.Logging;
using NosSmooth.Core.Extensions;
using NosSmooth.Core.Packets;
using NosSmooth.Data.Abstractions;
using NosSmooth.Game.Data.Entities;
using NosSmooth.Game.Data.Info;
using NosSmooth.Game.Events.Core;
using NosSmooth.Game.Events.Entities;
using NosSmooth.Packets.Server.Maps;
using Remora.Results;
namespace NosSmooth.Game.PacketHandlers.Map;
///
/// Responds to drop packet.
///
public class DropResponder : IPacketResponder
{
private readonly Game _game;
private readonly EventDispatcher _eventDispatcher;
private readonly IInfoService _infoService;
private readonly ILogger _logger;
///
/// Initializes a new instance of the class.
///
/// The game.
/// The event dispatcher.
/// The info service.
/// The logger.
public DropResponder
(
Game game,
EventDispatcher eventDispatcher,
IInfoService infoService,
ILogger logger
)
{
_game = game;
_eventDispatcher = eventDispatcher;
_infoService = infoService;
_logger = logger;
}
///
public async Task Respond(PacketEventArgs packetArgs, CancellationToken ct = default)
{
var packet = packetArgs.Packet;
var itemInfoResult = await _infoService.GetItemInfoAsync(packet.ItemVNum, ct);
if (!itemInfoResult.IsDefined(out var itemInfo))
{
_logger.LogWarning("Could not obtain item info for vnum {vnum}: {error}", packet.ItemVNum, itemInfoResult.ToFullString());
}
var entity = new GroundItem
{
Amount = packet.Amount,
Id = packet.DropId,
IsQuestRelated = packet.IsQuestRelated,
ItemInfo = itemInfo,
OwnerId = null,
Position = new Position
(
packet.X,
packet.Y
),
VNum = packet.ItemVNum
};
var map = _game.CurrentMap;
if (map is not null)
{
map.Entities.AddEntity(entity);
}
return await _eventDispatcher.DispatchEvent(new ItemDroppedEvent(entity), ct);
}
}