Mark van Renswoude
2e2a77a7ae
- Consume calls still in the TapetiClient task queue while it is reconnecting would not be cancelled, but new calls were added as well after the reconnect - Unrelated but useful: added LocalPort and Disconnect event to logging
44 lines
1.3 KiB
C#
44 lines
1.3 KiB
C#
using System;
|
|
using System.Threading.Tasks;
|
|
using RabbitMQ.Client;
|
|
using Tapeti.Default;
|
|
|
|
namespace Tapeti.Connection
|
|
{
|
|
/// <inheritdoc />
|
|
/// <summary>
|
|
/// Implements the bridge between the RabbitMQ Client consumer and a Tapeti Consumer
|
|
/// </summary>
|
|
internal class TapetiBasicConsumer : DefaultBasicConsumer
|
|
{
|
|
private readonly IConsumer consumer;
|
|
private readonly Func<ulong, ConsumeResult, Task> onRespond;
|
|
|
|
|
|
/// <inheritdoc />
|
|
public TapetiBasicConsumer(IConsumer consumer, Func<ulong, ConsumeResult, Task> onRespond)
|
|
{
|
|
this.consumer = consumer;
|
|
this.onRespond = onRespond;
|
|
}
|
|
|
|
|
|
/// <inheritdoc />
|
|
public override void HandleBasicDeliver(string consumerTag, ulong deliveryTag, bool redelivered, string exchange, string routingKey, IBasicProperties properties, byte[] body)
|
|
{
|
|
Task.Run(async () =>
|
|
{
|
|
try
|
|
{
|
|
var response = await consumer.Consume(exchange, routingKey, new RabbitMQMessageProperties(properties), body);
|
|
await onRespond(deliveryTag, response);
|
|
}
|
|
catch
|
|
{
|
|
await onRespond(deliveryTag, ConsumeResult.Error);
|
|
}
|
|
});
|
|
}
|
|
}
|
|
}
|