~ruther/NosSmooth

ref: ed3cc81862dc539872cc6bafee351b9c688ff21e NosSmooth/Core/NosSmooth.Game/PacketHandlers/Map/ThrowResponder.cs -rw-r--r-- 2.2 KiB
ed3cc818 — František Boháček feat(game): respond to rest, raidfhp, tp, throw, mapclear, die, char_sc packets 2 years ago
                                                                                
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
//
//  ThrowResponder.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.Packets.Server.Maps;
using Remora.Results;

namespace NosSmooth.Game.PacketHandlers.Map;

/// <summary>
/// A responder to <see cref="ThrowResponder"/>.
/// </summary>
public class ThrowResponder : IPacketResponder<ThrowPacket>
{
    private readonly Game _game;
    private readonly IInfoService _infoService;
    private readonly ILogger<ThrowResponder> _logger;

    /// <summary>
    /// Initializes a new instance of the <see cref="ThrowResponder"/> class.
    /// </summary>
    /// <param name="game">The game.</param>
    /// <param name="infoService">The info service.</param>
    /// <param name="logger">The logger.</param>
    public ThrowResponder(Game game, IInfoService infoService, ILogger<ThrowResponder> logger)
    {
        _game = game;
        _infoService = infoService;
        _logger = logger;
    }

    /// <inheritdoc />
    public async Task<Result> Respond(PacketEventArgs<ThrowPacket> packetArgs, CancellationToken ct = default)
    {
        var packet = packetArgs.Packet;
        var map = _game.CurrentMap;

        if (map is null)
        {
            return Result.FromSuccess();
        }

        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());
        }

        map.Entities.AddEntity
        (
            new GroundItem
            {
                Position = new Position(packet.TargetX, packet.TargetY),
                Amount = packet.Amount,
                Id = packet.DropId,
                ItemInfo = itemInfo,
                VNum = packet.ItemVNum
            }
        );

        return Result.FromSuccess();
    }
}
Do not follow this link