Transaction Support
The notify container can be configured with transaction support, so the event action can be performed under a transaction. Exceptions thrown by the event listener cause the operations performed within the listener to be rolled back automatically.
When using transactions, only the event listener operations are rolled back. The notifications are not sent again in case of a transaction rollback. If this behavior is required, please consider using the Polling Event Container. Adding transaction support to the polling container is very simple. It is done by setting the TransactionType
property. There are two transaction types: Distributed and Manual.
- Distributed transaction - an embedded distributed transaction manager will be created and it will be used for creating transaction (Only one transaction manager will be created per AppDomain).
- Manual transaction - transactions will be created by the transaction manager that is stored in the
TransactionManager
property. By default no transaction manager is stored and therefore, no transaction will be used. For example:
[NotifyEventDriven]
[TransactionalEvent(TransactionType = TransactionType.Distributed)]
public class SimpleListener
{
...
}
ISpaceProxy spaceProxy = // either create the SpaceProxy or obtain a reference to it
NotifyEventListenerContainer<Data> notifyEventListenerContainer = new NotifyEventListenerContainer<Data>(spaceProxy);
notifyEventListenerContainer.TransactionType = TransactionType.Distributed;
It is possible to receive a reference to the on going transaction as part of the event handling method, if for instance, the event handling is doing some extra space operations which should be executed under the same transaction context and rolled back upon failure. This is done be adding a transaction parameter to the event handler method. For example:
[NotifyEventDriven]
[TransactionalEvent(TransactionType = TransactionType.Distributed)]
public class SimpleListener
{
...
[DataEventHandler]
public Data ProcessData(Data event, ISpaceProxy spaceProxy, ITransaction transaction)
{
//process Data here and return processed data
}
}
ISpaceProxy spaceProxy = // either create the SpaceProxy or obtain a reference to it
NotifyEventListenerContainer<Data> notifyEventListenerContainer = new NotifyEventListenerContainer<Data>(spaceProxy);
notifyEventListenerContainer.TransactionType = TransactionType.Distributed;
notifyEventListenerContainer.DataEventArrived += new DelegateDataEventArrivedAdapter<Data,Data>(ProcessData).WriteBackDataEventHandler;
The order of parameters of the event handling method is strict, please refer to Data Event Handler Adapters for more information about it.