/// <summary>
        /// Adds all sagas in the specified assemblies matching the namespace. If you are using both state machine and regular sagas, be
        /// sure to call AddSagaStateMachinesFromNamespaceContaining prior to calling this one.
        /// </summary>
        /// <param name="configurator"></param>
        /// <param name="type">The type to use to identify the assembly and namespace to scan</param>
        /// <param name="filter"></param>
        public static void AddSagaStateMachinesFromNamespaceContaining(this IContainerBuilderConfigurator configurator, Type type, Func <Type, bool> filter =
                                                                       null)
        {
            var registrar = new AutofacSagaStateMachineRegistrar(configurator.Builder);

            configurator.AddSagaStateMachinesFromNamespaceContaining(registrar, type, filter);
        }
        /// <summary>
        /// Adds a SagaStateMachine to the registry, using the factory method, and updates the registrar prior to registering so that the default
        /// saga registrar isn't notified.
        /// </summary>
        /// <param name="configurator"></param>
        /// <typeparam name="TStateMachine"></typeparam>
        /// <typeparam name="TInstance"></typeparam>
        public static void AddSagaStateMachine <TStateMachine, TInstance>(this IContainerBuilderConfigurator configurator)
            where TStateMachine : class, SagaStateMachine <TInstance>
            where TInstance : class, SagaStateMachineInstance
        {
            var registrar = new AutofacSagaStateMachineRegistrar(configurator.Builder);

            configurator.AddSagaStateMachine <TStateMachine, TInstance>(registrar);
        }
 /// <summary>
 /// Decorates the IPublishEndpoint and ISendEndpointProvider with a Transaction Outbox. Messages will not be
 /// released/sent until the ambient transaction is committed. This is only meant to be used outside of a consumer.
 /// If you want an outbox for Consumers, it is recommended to use the InMemoryOutbox.
 /// </summary>
 public static void AddTransactionOutbox(this IContainerBuilderConfigurator builder)
 {
     builder.Builder
     .Register(c =>
     {
         var busControl = c.Resolve <IBusControl>();
         return(new TransactionOutbox(busControl, busControl, c.ResolveOptional <ILoggerFactory>()));
     })
     .SingleInstance()
     .AsImplementedInterfaces();
 }
        /// <summary>
        /// Adds SagaStateMachines to the registry, using the factory method, and updates the registrar prior to registering so that the default
        /// saga registrar isn't notified.
        /// </summary>
        /// <param name="configurator"></param>
        /// <param name="types">The state machine types to add</param>
        public static void AddSagaStateMachines(this IContainerBuilderConfigurator configurator, params Type[] types)
        {
            var registrar = new AutofacSagaStateMachineRegistrar(configurator.Builder);

            configurator.AddSagaStateMachines(registrar, types);
        }
        /// <summary>
        /// Adds all sagas in the specified assemblies matching the namespace. If you are using both state machine and regular sagas, be
        /// sure to call AddSagaStateMachinesFromNamespaceContaining prior to calling this one.
        /// </summary>
        /// <param name="configurator"></param>
        /// <typeparam name="T">The anchor type</typeparam>
        public static void AddSagaStateMachinesFromNamespaceContaining <T>(this IContainerBuilderConfigurator configurator)
        {
            var registrar = new AutofacSagaStateMachineRegistrar(configurator.Builder);

            configurator.AddSagaStateMachinesFromNamespaceContaining(registrar, typeof(T));
        }
示例#6
0
 partial void AddConsumers(IContainerBuilderConfigurator massTransit, params Assembly[] assemblies);