Set<String> resourceNames = new HashSet<String>();
XaDataSourceManager dsManager = ((AbstractGraphDatabase) graphDb).getConfig().getTxModule().getXaDataSourceManager();
for ( Pair<String, Long> txEntry : context.lastAppliedTransactions() )
{
String resourceName = txEntry.first();
final XaDataSource dataSource = dsManager.getXaDataSource( resourceName );
if ( dataSource == null )
{
throw new RuntimeException( "No data source '" + resourceName + "' found" );
}
resourceNames.add( resourceName );
long masterLastTx = dataSource.getLastCommittedTxId();
for ( long txId = txEntry.other() + 1; txId <= masterLastTx; txId++ )
{
if ( filter.accept( txId ) )
{
final long tx = txId;
TxExtractor extractor = new TxExtractor()
{
@Override
public ReadableByteChannel extract()
{
try
{
return dataSource.getCommittedTransaction( tx );
}
catch ( IOException e )
{
throw new RuntimeException( e );
}
}
@Override
public void extract( LogBuffer buffer )
{
try
{
dataSource.getCommittedTransaction( tx, buffer );
}
catch ( IOException e )
{
throw new RuntimeException( e );
}