in src/org/apache/kandula/participant/ba/BAParticipantTransactionSentCoordinator.java [35:69]
public void completed(ParticipantContext context) throws AbstractKandulaException {
context.lock();
switch (context.getStatus()) {
case (Status.BAParticipantStatus.STATUS_COMPLETING):
case (Status.BAParticipantStatus.STATUS_COMPLETED):
context.unlock();
try {
BAParticipantCompletionCoordinatorServiceStub serviceStub = new BAParticipantCompletionCoordinatorServiceStub(
MessageContext.getCurrentMessageContext().getConfigurationContext(), null);
serviceStub._getServiceClient().getOptions().setTo(context.getCoordinationEPR());
Completed completed = new Completed();
completed.setCompleted(new NotificationType());
context.setStatus(Status.BAParticipantStatus.STATUS_COMPLETED);
serviceStub.CompletedOperation(completed);
} catch (Exception e) {
log.fatal("WS_BA : " + context.getCoordinationContext().getActivityID()
+ " : completed :" + context.getID() + " : " + e);
throw new KandulaGeneralException(e);
}
break;
case (Status.BAParticipantStatus.STATUS_CANCELLING):
case (Status.BAParticipantStatus.STATUS_COMPENSATING):
case (Status.BAParticipantStatus.STATUS_ACTIVE):
case (Status.BAParticipantStatus.STATUS_CLOSING):
case (Status.BAParticipantStatus.STATUS_FAULTING):
case (Status.BAParticipantStatus.STATUS_EXITING):
case (Status.BAParticipantStatus.STATUS_ENDED):
log.fatal("WS_BA : " + context.getCoordinationContext().getActivityID()
+ " : completed :" + context.getID() + " : " + " Participant is in"
+ context.getStatus() + " (invalid) state");
throw new InvalidStateException(" Participant is in" + context.getStatus()
+ " (invalid) state");
}
}