SQL
PM> Install-Package Shuttle.Esb.Sql.Subscription
Contains a sql-based ISubscriptionService implementation. The subscription service caches all subscriptions but a timeout for the cache may be set. If you need to be sure that a new subscriber is picked up by a publisher the safest is to restart the relevant publisher(s).
Registration
The required components may be registered by calling:
c#
services.AddSqlSubscription();
The SubscriptionService that implements the ISubscriptionService interface makes use of the SubscriptionOptions configured with the ServiceBusOptions to register, or ensure, any subscriptions:
c#
services.AddServiceBus(builder => {
	builder.Subscription.SubscribeType = SubscribeType.Normal; // default
    builder.Subscription.ConnectionString = "Subscription"; // default
    // add subscription to message types directly; else below options on builder
    builder.Subscription.MessageTypes.Add(messageType);
    // using type
    builder.AddSubscription(typeof(Event1));
    builder.AddSubscription(typeof(Event2));
    // using a full type name
    builder.AddSubscription(typeof(Event1).FullName);
    builder.AddSubscription(typeof(Event2).FullName);
    // using a generic
    builder.AddSubscription<Event1>();
    builder.AddSubscription<Event2>();
});
And the JSON configuration structure:
json
{
  "Shuttle": {
    "ServiceBus": {
      "Subscription": {
        "SubscribeType": "Normal",
        "ConnectionStringName": "connection-string",
        "CacheTimeout": "00:05:00",
        "MessageTypes": [
          "message-type-a",
          "message-type-b"
        ]
      }
    }
  }
}
Options
| Option | Default | Description | 
|---|---|---|
| ConnectionStringName | Subscription | The name of the ConnectionStringto use to connect to the subscription store. | 
| SubscribeType | Normal | Indicates subscriptions are dealt with: - Normalis the default and will subscribe to the given message type(s) if they have not been subscribed to yet.- Ensurewill check to see that the subscription exists and if not will throw anApplicationException.- Ignorewill simply ignore the subscription request. | 
| CacheTimeout | 00:05:00 | How long event subscribers should be cached for before refreshing the list. | 
Should the endpoint be configured as a worker no new subscriptions will be registered against the endpoint since any published events should be subscribed to only by the distributor endpoint. When using a broker all the endpoints feed off the same work queue uri and any of the endpoints could create the subscription.
When moving to a non-development environment it is recommended that you make use of the Ensure option for the SubscribeType.
Supported providers
- Microsoft.Data.SqlClient
- System.Data.SqlClient
- Npgsql/ thanks to hopla
If you'd like support for another SQL-based provider please feel free to give it a bash and send a pull request if you do go this route. You are welcome to create an issue and assistance will be provided where possible.