Search in sources :

Example 6 with StoreException

use of com.swiftmq.swiftlet.store.StoreException in project swiftmq-ce by iitsoftware.

the class StoreTransactionImpl method checkClosedAsync.

protected boolean checkClosedAsync(AsyncCompletionCallback callback) {
    if (closed) {
        callback.setException(new StoreException("Transaction is closed"));
        callback.notifyCallbackStack(false);
    }
    return closed;
}
Also used : StoreException(com.swiftmq.swiftlet.store.StoreException)

Example 7 with StoreException

use of com.swiftmq.swiftlet.store.StoreException in project swiftmq-ce by iitsoftware.

the class StoreTransactionImpl method commit.

public void commit() throws StoreException {
    if (ctx.traceSpace.enabled)
        ctx.traceSpace.trace("sys$store", toString() + "/commit...");
    if (closed)
        throw new StoreException("Transaction is closed");
    try {
        if (journal != null && journal.size() > 0) {
            ctx.recoveryManager.commit(new CommitLogRecord(txId, sem, journal, this, null, messagePageRefs));
            sem.waitHere();
        }
        ctx.transactionManager.removeTxId(txId);
        close();
    } catch (Exception e) {
        throw new StoreException(e.toString());
    }
    if (ctx.traceSpace.enabled)
        ctx.traceSpace.trace("sys$store", toString() + "/commit...done.");
}
Also used : CommitLogRecord(com.swiftmq.impl.store.standard.log.CommitLogRecord) StoreException(com.swiftmq.swiftlet.store.StoreException) StoreException(com.swiftmq.swiftlet.store.StoreException)

Example 8 with StoreException

use of com.swiftmq.swiftlet.store.StoreException in project swiftmq-ce by iitsoftware.

the class CompositeStoreTransactionImpl method abortTransaction.

public void abortTransaction(AsyncCompletionCallback callback) {
    AsyncCompletionCallback localCallback = createLocalCallback(callback);
    checkClosedAsync(localCallback);
    if (localCallback.isNotified())
        return;
    boolean doNotify = true;
    if (journal != null && journal.size() > 0) {
        try {
            doNotify = false;
            if (keysRemoved != null && markRedelivered)
                ctx.recoveryManager.abort(new AbortLogRecord(txId, null, journal, this, null));
            else
                ctx.recoveryManager.abort(new AbortLogRecord(txId, null, journal, this, localCallback));
        } catch (Exception e) {
            localCallback.setException(new StoreException(e.toString()));
            localCallback.notifyCallbackStack(false);
            removeTxId();
            return;
        }
    }
    if (keysRemoved != null && markRedelivered) {
        List newJournal = new ArrayList();
        try {
            for (int i = 0; i < keysRemoved.size(); i++) {
                RemovedKeyEntry entry = keysRemoved.get(i);
                entry.queueIndex.setJournal(newJournal);
                entry.queueIndex.incDeliveryCount(entry.key);
            }
            doNotify = false;
            // don't wonder, we are committing the redelivered settings
            ctx.recoveryManager.commit(new CommitLogRecord(txId, null, newJournal, this, localCallback, null));
        } catch (Exception e) {
            localCallback.setException(new StoreException(e.toString()));
            localCallback.notifyCallbackStack(false);
            removeTxId();
            return;
        }
    }
    if (doNotify)
        callback.notifyCallbackStack(true);
}
Also used : AsyncCompletionCallback(com.swiftmq.tools.concurrent.AsyncCompletionCallback) CommitLogRecord(com.swiftmq.impl.store.standard.log.CommitLogRecord) ArrayList(java.util.ArrayList) ArrayList(java.util.ArrayList) List(java.util.List) AbortLogRecord(com.swiftmq.impl.store.standard.log.AbortLogRecord) StoreException(com.swiftmq.swiftlet.store.StoreException) StoreException(com.swiftmq.swiftlet.store.StoreException)

Example 9 with StoreException

use of com.swiftmq.swiftlet.store.StoreException in project swiftmq-ce by iitsoftware.

the class CompositeStoreTransactionImpl method abortTransaction.

public void abortTransaction() throws StoreException {
    if (ctx.traceSpace.enabled)
        ctx.traceSpace.trace("sys$store", toString() + "/abortTransaction...");
    if (closed)
        throw new StoreException("Transaction is closed");
    try {
        if (journal != null && journal.size() > 0) {
            if (keysRemoved != null && markRedelivered)
                ctx.recoveryManager.abort(new AbortLogRecord(txId, null, journal, null));
            else {
                ctx.recoveryManager.abort(new AbortLogRecord(txId, sem, journal, this));
                sem.waitHere();
            }
        }
        if (keysRemoved != null && markRedelivered) {
            List newJournal = new ArrayList();
            for (int i = 0; i < keysRemoved.size(); i++) {
                RemovedKeyEntry entry = keysRemoved.get(i);
                entry.queueIndex.setJournal(newJournal);
                entry.queueIndex.incDeliveryCount(entry.key);
            }
            // don't wonder, we are committing the redelivered settings
            ctx.recoveryManager.commit(new CommitLogRecord(txId, sem, newJournal, this, null));
            sem.waitHere();
        }
        removeTxId();
        close();
    } catch (Exception e) {
        throw new StoreException(e.getMessage());
    }
    if (ctx.traceSpace.enabled)
        ctx.traceSpace.trace("sys$store", toString() + "/abortTransaction...done.");
}
Also used : CommitLogRecord(com.swiftmq.impl.store.standard.log.CommitLogRecord) ArrayList(java.util.ArrayList) ArrayList(java.util.ArrayList) List(java.util.List) AbortLogRecord(com.swiftmq.impl.store.standard.log.AbortLogRecord) StoreException(com.swiftmq.swiftlet.store.StoreException) StoreException(com.swiftmq.swiftlet.store.StoreException)

Example 10 with StoreException

use of com.swiftmq.swiftlet.store.StoreException in project swiftmq-ce by iitsoftware.

the class CompositeStoreTransactionImpl method checkClosedAsync.

protected void checkClosedAsync(AsyncCompletionCallback callback) {
    if (closed) {
        callback.setException(new StoreException("Transaction is closed"));
        callback.notifyCallbackStack(false);
    }
}
Also used : StoreException(com.swiftmq.swiftlet.store.StoreException)

Aggregations

StoreException (com.swiftmq.swiftlet.store.StoreException)23 CommitLogRecord (com.swiftmq.impl.store.standard.log.CommitLogRecord)8 IOException (java.io.IOException)8 ArrayList (java.util.ArrayList)6 SwapAddress (com.swiftmq.impl.store.standard.swap.SwapAddress)4 QueueIndexEntry (com.swiftmq.impl.store.standard.index.QueueIndexEntry)3 AbortLogRecord (com.swiftmq.impl.store.standard.log.AbortLogRecord)3 AsyncCompletionCallback (com.swiftmq.tools.concurrent.AsyncCompletionCallback)3 MessagePageReference (com.swiftmq.impl.store.standard.index.MessagePageReference)2 PrepareLogRecordImpl (com.swiftmq.impl.store.standard.xa.PrepareLogRecordImpl)2 HashMap (java.util.HashMap)2 List (java.util.List)2 Map (java.util.Map)2 SwapFile (com.swiftmq.impl.store.standard.swap.SwapFile)1 DurableStoreEntry (com.swiftmq.swiftlet.store.DurableStoreEntry)1 StoreEntry (com.swiftmq.swiftlet.store.StoreEntry)1 Semaphore (com.swiftmq.tools.concurrent.Semaphore)1