Mark van Renswoude
3aee6f1c53
Caused by non thread-safe code when applying bindings. Replaced Task.WhenAll with a simple loop, as the performance benefits are negligable and it's only at startup anyways. Also changed binding methods to use ValueTask.
62 lines
1.6 KiB
C#
62 lines
1.6 KiB
C#
using System;
|
|
using System.Threading.Tasks;
|
|
using Tapeti.Config;
|
|
|
|
namespace Tapeti.Transient
|
|
{
|
|
/// <inheritdoc />
|
|
/// <summary>
|
|
/// Implements a binding for transient request response messages.
|
|
/// Register this binding using the WithTransient config extension method.
|
|
/// </summary>
|
|
internal class TransientGenericBinding : IBinding
|
|
{
|
|
private readonly TransientRouter router;
|
|
private readonly string dynamicQueuePrefix;
|
|
|
|
/// <inheritdoc />
|
|
public string QueueName { get; private set; }
|
|
|
|
/// <inheritdoc />
|
|
public QueueType QueueType => QueueType.Dynamic;
|
|
|
|
|
|
/// <summary>
|
|
/// </summary>
|
|
public TransientGenericBinding(TransientRouter router, string dynamicQueuePrefix)
|
|
{
|
|
this.router = router;
|
|
this.dynamicQueuePrefix = dynamicQueuePrefix;
|
|
}
|
|
|
|
|
|
/// <inheritdoc />
|
|
public async ValueTask Apply(IBindingTarget target)
|
|
{
|
|
QueueName = await target.BindDynamicDirect(dynamicQueuePrefix);
|
|
router.TransientResponseQueueName = QueueName;
|
|
}
|
|
|
|
|
|
/// <inheritdoc />
|
|
public bool Accept(Type messageClass)
|
|
{
|
|
return true;
|
|
}
|
|
|
|
|
|
/// <inheritdoc />
|
|
public ValueTask Invoke(IMessageContext context)
|
|
{
|
|
router.HandleMessage(context);
|
|
return default;
|
|
}
|
|
|
|
|
|
/// <inheritdoc />
|
|
public ValueTask Cleanup(IMessageContext context, ConsumeResult consumeResult)
|
|
{
|
|
return default;
|
|
}
|
|
}
|
|
} |