@Override public LoginSession getCreateSession( long loggedEntity, AuthenticationRealm realm, String entityLabel, boolean outdatedCredential, Date absoluteExpiration) { Object transaction = tokensManagement.startTokenTransaction(); try { try { LoginSession ret = getOwnedSession(new EntityParam(loggedEntity), realm.getName(), transaction); if (ret != null) { ret.setLastUsed(new Date()); byte[] contents = ret.getTokenContents(); tokensManagement.updateToken( SESSION_TOKEN_TYPE, ret.getId(), null, contents, transaction); if (log.isDebugEnabled()) log.debug( "Using existing session " + ret.getId() + " for logged entity " + ret.getEntityId() + " in realm " + realm.getName()); tokensManagement.commitTokenTransaction(transaction); return ret; } } catch (EngineException e) { throw new InternalException( "Can't retrieve current sessions of the " + "authenticated user", e); } LoginSession ret = createSession( loggedEntity, realm, entityLabel, outdatedCredential, absoluteExpiration, transaction); tokensManagement.commitTokenTransaction(transaction); if (log.isDebugEnabled()) log.debug( "Created a new session " + ret.getId() + " for logged entity " + ret.getEntityId() + " in realm " + realm.getName()); return ret; } finally { tokensManagement.closeTokenTransaction(transaction); cleanScheduledRemoval(loggedEntity); } }