From 9102881fc11c66641ce112939dad2de7ad52ebfd Mon Sep 17 00:00:00 2001 From: Savorboard Date: Thu, 12 Oct 2017 23:31:58 +0800 Subject: [PATCH] rafactor subscriber handler. --- .../Internal/ISubscriberExecutor.Default.cs | 54 +++++++++++++++++++ .../Internal/ISubscriberExecutor.cs | 10 ++++ 2 files changed, 64 insertions(+) create mode 100644 src/DotNetCore.CAP/Internal/ISubscriberExecutor.Default.cs create mode 100644 src/DotNetCore.CAP/Internal/ISubscriberExecutor.cs diff --git a/src/DotNetCore.CAP/Internal/ISubscriberExecutor.Default.cs b/src/DotNetCore.CAP/Internal/ISubscriberExecutor.Default.cs new file mode 100644 index 0000000..dbf1b9d --- /dev/null +++ b/src/DotNetCore.CAP/Internal/ISubscriberExecutor.Default.cs @@ -0,0 +1,54 @@ +using System; +using System.Threading.Tasks; +using DotNetCore.CAP.Abstractions; +using DotNetCore.CAP.Models; +using Microsoft.Extensions.Logging; + +namespace DotNetCore.CAP.Internal +{ + public class DefaultSubscriberExecutor : ISubscriberExecutor + { + private readonly IConsumerInvokerFactory _consumerInvokerFactory; + private readonly ILogger _logger; + private readonly MethodMatcherCache _selector; + + public DefaultSubscriberExecutor(MethodMatcherCache selector, + IConsumerInvokerFactory consumerInvokerFactory, + ILogger logger) + { + _selector = selector; + _consumerInvokerFactory = consumerInvokerFactory; + _logger = logger; + } + + + public async Task ExecuteAsync(CapReceivedMessage receivedMessage) + { + try + { + var executeDescriptorGroup = _selector.GetTopicExector(receivedMessage.Name); + + if (!executeDescriptorGroup.ContainsKey(receivedMessage.Group)) + { + var error = $"Topic:{receivedMessage.Name}, can not be found subscriber method."; + throw new SubscriberNotFoundException(error); + } + + // If there are multiple consumers in the same group, we will take the first + var executeDescriptor = executeDescriptorGroup[receivedMessage.Group][0]; + var consumerContext = new ConsumerContext(executeDescriptor, receivedMessage.ToMessageContext()); + + await _consumerInvokerFactory.CreateInvoker(consumerContext).InvokeAsync(); + + return OperateResult.Success; + } + catch (Exception ex) + { + _logger.ConsumerMethodExecutingFailed($"Group:{receivedMessage.Group}, Topic:{receivedMessage.Name}", + ex); + + return OperateResult.Failed(ex); + } + } + } +} \ No newline at end of file diff --git a/src/DotNetCore.CAP/Internal/ISubscriberExecutor.cs b/src/DotNetCore.CAP/Internal/ISubscriberExecutor.cs new file mode 100644 index 0000000..cdfe5dc --- /dev/null +++ b/src/DotNetCore.CAP/Internal/ISubscriberExecutor.cs @@ -0,0 +1,10 @@ +using System.Threading.Tasks; +using DotNetCore.CAP.Models; + +namespace DotNetCore.CAP.Internal +{ + public interface ISubscriberExecutor + { + Task ExecuteAsync(CapReceivedMessage receivedMessage); + } +}