Some more interface foundations
This commit is contained in:
parent
e62aa7d482
commit
68399db095
@ -16,7 +16,7 @@ namespace Tapeti.Connection
|
|||||||
private readonly IMessageSerializer messageSerializer;
|
private readonly IMessageSerializer messageSerializer;
|
||||||
private readonly IRoutingKeyStrategy routingKeyStrategy;
|
private readonly IRoutingKeyStrategy routingKeyStrategy;
|
||||||
private readonly Lazy<SingleThreadTaskQueue> taskQueue = new Lazy<SingleThreadTaskQueue>();
|
private readonly Lazy<SingleThreadTaskQueue> taskQueue = new Lazy<SingleThreadTaskQueue>();
|
||||||
private IConnection connection;
|
private RabbitMQ.Client.IConnection connection;
|
||||||
private IModel channel;
|
private IModel channel;
|
||||||
|
|
||||||
|
|
||||||
|
9
IConnection.cs
Normal file
9
IConnection.cs
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
using System;
|
||||||
|
|
||||||
|
namespace Tapeti
|
||||||
|
{
|
||||||
|
public interface IConnection : IDisposable
|
||||||
|
{
|
||||||
|
ISubscriber Subscribe();
|
||||||
|
}
|
||||||
|
}
|
20
ITopology.cs
Normal file
20
ITopology.cs
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
|
namespace Tapeti
|
||||||
|
{
|
||||||
|
public interface ITopology
|
||||||
|
{
|
||||||
|
IEnumerable<IQueue> Queues();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public interface IQueue
|
||||||
|
{
|
||||||
|
IEnumerable<IBinding> Bindings();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public interface IBinding
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
@ -59,10 +59,13 @@
|
|||||||
<Compile Include="Connection\TapetiWorker.cs" />
|
<Compile Include="Connection\TapetiWorker.cs" />
|
||||||
<Compile Include="Default\ConsoleLogger.cs" />
|
<Compile Include="Default\ConsoleLogger.cs" />
|
||||||
<Compile Include="Default\DevNullLogger.cs" />
|
<Compile Include="Default\DevNullLogger.cs" />
|
||||||
|
<Compile Include="IConnection.cs" />
|
||||||
<Compile Include="ILogger.cs" />
|
<Compile Include="ILogger.cs" />
|
||||||
|
<Compile Include="ITopology.cs" />
|
||||||
<Compile Include="MessageController.cs" />
|
<Compile Include="MessageController.cs" />
|
||||||
<Compile Include="TapetiConnectionExtensions.cs" />
|
<Compile Include="TapetiConnectionBuilder.cs" />
|
||||||
<Compile Include="TapetiConnectionParams.cs" />
|
<Compile Include="TapetiConnectionParams.cs" />
|
||||||
|
<Compile Include="TapetiTopologyBuilder.cs" />
|
||||||
<Compile Include="TapetiTypes.cs" />
|
<Compile Include="TapetiTypes.cs" />
|
||||||
<Compile Include="Tasks\SingleThreadTaskQueue.cs" />
|
<Compile Include="Tasks\SingleThreadTaskQueue.cs" />
|
||||||
<Compile Include="Default\DefaultControllerFactory.cs" />
|
<Compile Include="Default\DefaultControllerFactory.cs" />
|
||||||
|
@ -60,37 +60,6 @@ namespace Tapeti
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public TapetiConnection RegisterController(Type type)
|
|
||||||
{
|
|
||||||
var queueAttribute = type.GetCustomAttribute<MessageController>();
|
|
||||||
if (queueAttribute == null)
|
|
||||||
throw new ArgumentException("Queue attribute required on class", nameof(type));
|
|
||||||
|
|
||||||
if (queueAttribute.Dynamic)
|
|
||||||
{
|
|
||||||
if (!string.IsNullOrEmpty(queueAttribute.Name))
|
|
||||||
throw new ArgumentException("Dynamic queue attributes must not have a Name");
|
|
||||||
|
|
||||||
registrations.Value.Add(new ControllerDynamicQueueRegistration(
|
|
||||||
DependencyResolver.Resolve<IControllerFactory>,
|
|
||||||
DependencyResolver.Resolve<IRoutingKeyStrategy>,
|
|
||||||
type, SubscribeExchange));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (string.IsNullOrEmpty(queueAttribute.Name))
|
|
||||||
throw new ArgumentException("Non-dynamic queue attribute must have a Name");
|
|
||||||
|
|
||||||
registrations.Value.Add(new ControllerQueueRegistration(
|
|
||||||
DependencyResolver.Resolve<IControllerFactory>,
|
|
||||||
type, SubscribeExchange, queueAttribute.Name));
|
|
||||||
}
|
|
||||||
|
|
||||||
(DependencyResolver as IDependencyInjector)?.RegisterController(type);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public async Task<ISubscriber> Subscribe()
|
public async Task<ISubscriber> Subscribe()
|
||||||
{
|
{
|
||||||
if (!registrations.IsValueCreated || registrations.Value.Count == 0)
|
if (!registrations.IsValueCreated || registrations.Value.Count == 0)
|
||||||
|
30
TapetiConnectionBuilder.cs
Normal file
30
TapetiConnectionBuilder.cs
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
using System;
|
||||||
|
|
||||||
|
namespace Tapeti
|
||||||
|
{
|
||||||
|
public class TapetiConnectionBuilder
|
||||||
|
{
|
||||||
|
public IConnection Build()
|
||||||
|
{
|
||||||
|
throw new NotImplementedException();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public TapetiConnectionBuilder SetExchange(string exchange)
|
||||||
|
{
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public TapetiConnectionBuilder SetDependencyResolver(IDependencyResolver dependencyResolver)
|
||||||
|
{
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public TapetiConnectionBuilder SetTopology(ITopology topology)
|
||||||
|
{
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,23 +0,0 @@
|
|||||||
using System.Linq;
|
|
||||||
using System.Reflection;
|
|
||||||
using Tapeti.Annotations;
|
|
||||||
|
|
||||||
namespace Tapeti
|
|
||||||
{
|
|
||||||
public static class TapetiConnectionExtensions
|
|
||||||
{
|
|
||||||
public static TapetiConnection RegisterAllControllers(this TapetiConnection connection, Assembly assembly)
|
|
||||||
{
|
|
||||||
foreach (var type in assembly.GetTypes().Where(t => t.IsDefined(typeof(DynamicQueueAttribute))))
|
|
||||||
connection.RegisterController(type);
|
|
||||||
|
|
||||||
return connection;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public static TapetiConnection RegisterAllControllers(this TapetiConnection connection)
|
|
||||||
{
|
|
||||||
return RegisterAllControllers(connection, Assembly.GetCallingAssembly());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
146
TapetiTopologyBuilder.cs
Normal file
146
TapetiTopologyBuilder.cs
Normal file
@ -0,0 +1,146 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Reflection;
|
||||||
|
using Tapeti.Annotations;
|
||||||
|
|
||||||
|
|
||||||
|
namespace Tapeti
|
||||||
|
{
|
||||||
|
public class TopologyConfigurationException : Exception
|
||||||
|
{
|
||||||
|
public TopologyConfigurationException(string message) : base(message) { }
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public class TapetiTopologyBuilder
|
||||||
|
{
|
||||||
|
private readonly List<HandlerRegistration> registrations = new List<HandlerRegistration>();
|
||||||
|
|
||||||
|
|
||||||
|
public ITopology Build()
|
||||||
|
{
|
||||||
|
throw new NotImplementedException();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public TapetiTopologyBuilder RegisterController(Type controller)
|
||||||
|
{
|
||||||
|
var controllerRegistration = GetAttributesRegistration(controller);
|
||||||
|
|
||||||
|
foreach (var method in controller.GetMembers(BindingFlags.Public | BindingFlags.Instance)
|
||||||
|
.Where(m => m.MemberType == MemberTypes.Method && m.DeclaringType != typeof(object))
|
||||||
|
.Select(m => (MethodInfo)m))
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
if (queueAttribute.Dynamic)
|
||||||
|
{
|
||||||
|
if (!string.IsNullOrEmpty(queueAttribute.Name))
|
||||||
|
throw new ArgumentException("Dynamic queue attributes must not have a Name");
|
||||||
|
|
||||||
|
registrations.Value.Add(new ControllerDynamicQueueRegistration(
|
||||||
|
DependencyResolver.Resolve<IControllerFactory>,
|
||||||
|
DependencyResolver.Resolve<IRoutingKeyStrategy>,
|
||||||
|
type, SubscribeExchange));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (string.IsNullOrEmpty(queueAttribute.Name))
|
||||||
|
throw new ArgumentException("Non-dynamic queue attribute must have a Name");
|
||||||
|
|
||||||
|
registrations.Value.Add(new ControllerQueueRegistration(
|
||||||
|
DependencyResolver.Resolve<IControllerFactory>,
|
||||||
|
type, SubscribeExchange, queueAttribute.Name));
|
||||||
|
}
|
||||||
|
|
||||||
|
(DependencyResolver as IDependencyInjector)?.RegisterController(type);
|
||||||
|
*/
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public TapetiTopologyBuilder RegisterAllControllers(Assembly assembly)
|
||||||
|
{
|
||||||
|
foreach (var type in assembly.GetTypes().Where(t => t.IsDefined(typeof(MessageControllerAttribute))))
|
||||||
|
RegisterController(type);
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public TapetiTopologyBuilder RegisterAllControllers()
|
||||||
|
{
|
||||||
|
return RegisterAllControllers(Assembly.GetCallingAssembly());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
protected HandlerRegistration GetAttributesRegistration(MemberInfo member)
|
||||||
|
{
|
||||||
|
var registration = new HandlerRegistration();
|
||||||
|
|
||||||
|
var dynamicQueueAttribute = member.GetCustomAttribute<DynamicQueueAttribute>();
|
||||||
|
var staticQueueAttribute = member.GetCustomAttribute<StaticQueueAttribute>();
|
||||||
|
|
||||||
|
if (dynamicQueueAttribute != null && staticQueueAttribute != null)
|
||||||
|
throw new TopologyConfigurationException($"Cannot combine static and dynamic queue attributes on {member.Name}");
|
||||||
|
|
||||||
|
if (dynamicQueueAttribute != null)
|
||||||
|
registration.Dynamic = true;
|
||||||
|
else if (staticQueueAttribute != null)
|
||||||
|
{
|
||||||
|
registration.Dynamic = false;
|
||||||
|
registration.QueueName = staticQueueAttribute.Name;
|
||||||
|
}
|
||||||
|
|
||||||
|
return registration;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
protected class HandlerRegistration
|
||||||
|
{
|
||||||
|
public bool? Dynamic { get; set; }
|
||||||
|
public string QueueName { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
protected class Topology : ITopology
|
||||||
|
{
|
||||||
|
private readonly List<Queue> queues = new List<Queue>();
|
||||||
|
|
||||||
|
|
||||||
|
public void Add(Queue queue)
|
||||||
|
{
|
||||||
|
queues.Add(queue);
|
||||||
|
}
|
||||||
|
|
||||||
|
public IEnumerable<IQueue> Queues()
|
||||||
|
{
|
||||||
|
return queues;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
protected class Queue : IQueue
|
||||||
|
{
|
||||||
|
private readonly List<Binding> bindings = new List<Binding>();
|
||||||
|
|
||||||
|
|
||||||
|
public void Add(Binding binding)
|
||||||
|
{
|
||||||
|
bindings.Add(binding);
|
||||||
|
}
|
||||||
|
|
||||||
|
public IEnumerable<IBinding> Bindings()
|
||||||
|
{
|
||||||
|
return bindings;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
protected class Binding : IBinding
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -11,13 +11,14 @@ namespace Test
|
|||||||
{
|
{
|
||||||
var container = new Container();
|
var container = new Container();
|
||||||
|
|
||||||
using (var connection = new TapetiConnection
|
using (var connection = new TapetiConnectionBuilder()
|
||||||
{
|
.SetExchange("test")
|
||||||
PublishExchange = "test",
|
.SetDependencyResolver(new SimpleInjectorDependencyResolver(container))
|
||||||
SubscribeExchange = "test"
|
.SetTopology(
|
||||||
}
|
new TapetiTopologyBuilder()
|
||||||
.WithDependencyResolver(new SimpleInjectorDependencyResolver(container))
|
.RegisterAllControllers()
|
||||||
.RegisterAllControllers(typeof(Program).Assembly))
|
.Build())
|
||||||
|
.Build())
|
||||||
{
|
{
|
||||||
container.Register<MarcoEmitter>();
|
container.Register<MarcoEmitter>();
|
||||||
|
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Threading.Tasks;
|
|
||||||
using Tapeti;
|
using Tapeti;
|
||||||
using Tapeti.Annotations;
|
using Tapeti.Annotations;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user