//
// PacketNotFoundResponder.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.Packets;
using Remora.Results;
namespace FileClient.Responders;
///
/// Responds to packets that were not found.
///
public class PacketNotFoundResponder : IPacketResponder, IPacketResponder
{
private readonly ILogger _logger;
///
/// Initializes a new instance of the class.
///
/// The logger.
public PacketNotFoundResponder(ILogger logger)
{
_logger = logger;
}
///
public Task Respond(PacketEventArgs packetArgs, CancellationToken ct = default)
{
_logger.LogWarning($"Could not find packet {packetArgs.PacketString}");
return Task.FromResult(Result.FromSuccess());
}
///
public Task Respond(PacketEventArgs packetArgs, CancellationToken ct = default)
{
_logger.LogWarning($"Could not parse packet {packetArgs.PacketString}");
_logger.LogResultError(packetArgs.Packet.SerializerResult);
return Task.FromResult(Result.FromSuccess());
}
}