SimpleMetadata __load(String id, String version)
throws BackingStoreException {
SimpleMetadata result = null;
SipTransactionPersistentManager repMgr
= (SipTransactionPersistentManager)this.getSipSessionManager();
ReplicationState localCachedState
= repMgr.removeFromSipApplicationSessionReplicationCache(id);
//check if we got a hit from our own replica cache
//and check if we can trust it. If so save and return it immediately
boolean trustCachedState = canTrustLocallyCachedState(id, version, localCachedState);
if(_logger.isLoggable(Level.FINE)) {
_logger.fine("SipApplicationSessionStoreImpl>>__load:id= " + id + ", localCachedState=" +
localCachedState + ", trustCachedState=" + trustCachedState);
}
ReplicationState bestState = null;
if(trustCachedState) {
bestState = localCachedState;
} else {
ReplicationState broadcastResultState =
findSessionViaBroadcastOrUnicast(id, version);
bestState = ReplicationState.getBestResult(localCachedState, broadcastResultState);
if(_logger.isLoggable(Level.FINE)) {
_logger.fine("SipApplicationSessionStoreImpl>>__load:id=" + id + ", broadcastResultState " +
"from broadcast or unicast=" + broadcastResultState + ", bestState = " + bestState);