Merge pull request #2147 from mposolda/master
KEYCLOAK-2235 Fix transaction leaks
This commit is contained in:
commit
f660e4e757
2 changed files with 34 additions and 28 deletions
|
@ -1,6 +1,7 @@
|
||||||
package org.keycloak.models;
|
package org.keycloak.models;
|
||||||
|
|
||||||
import org.jboss.logging.Logger;
|
import org.jboss.logging.Logger;
|
||||||
|
import org.keycloak.models.utils.KeycloakModelUtils;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
@ -104,19 +105,19 @@ public class UserFederationManager implements UserProvider {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void deleteInvalidUser(RealmModel realm, UserModel user) {
|
protected void deleteInvalidUser(final RealmModel realm, final UserModel user) {
|
||||||
KeycloakSession tx = session.getKeycloakSessionFactory().create();
|
KeycloakModelUtils.runJobInTransaction(session.getKeycloakSessionFactory(), new KeycloakSessionTask() {
|
||||||
try {
|
|
||||||
tx.getTransaction().begin();
|
@Override
|
||||||
RealmModel realmModel = tx.realms().getRealm(realm.getId());
|
public void run(KeycloakSession session) {
|
||||||
|
RealmModel realmModel = session.realms().getRealm(realm.getId());
|
||||||
if (realmModel == null) return;
|
if (realmModel == null) return;
|
||||||
UserModel deletedUser = tx.userStorage().getUserById(user.getId(), realmModel);
|
UserModel deletedUser = session.userStorage().getUserById(user.getId(), realmModel);
|
||||||
tx.userStorage().removeUser(realmModel, deletedUser);
|
session.userStorage().removeUser(realmModel, deletedUser);
|
||||||
logger.debugf("Removed invalid user '%s'", user.getUsername());
|
logger.debugf("Removed invalid user '%s'", user.getUsername());
|
||||||
tx.getTransaction().commit();
|
|
||||||
} finally {
|
|
||||||
tx.close();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -258,29 +258,34 @@ public class KeycloakApplication extends Application {
|
||||||
|
|
||||||
public void importRealm(RealmRepresentation rep, String from) {
|
public void importRealm(RealmRepresentation rep, String from) {
|
||||||
KeycloakSession session = sessionFactory.create();
|
KeycloakSession session = sessionFactory.create();
|
||||||
|
boolean exists = false;
|
||||||
try {
|
try {
|
||||||
session.getTransaction().begin();
|
session.getTransaction().begin();
|
||||||
|
|
||||||
|
try {
|
||||||
RealmManager manager = new RealmManager(session);
|
RealmManager manager = new RealmManager(session);
|
||||||
manager.setContextPath(getContextPath());
|
manager.setContextPath(getContextPath());
|
||||||
|
|
||||||
if (rep.getId() != null && manager.getRealm(rep.getId()) != null) {
|
if (rep.getId() != null && manager.getRealm(rep.getId()) != null) {
|
||||||
logger.realmExists(rep.getRealm(), from);
|
logger.realmExists(rep.getRealm(), from);
|
||||||
return;
|
exists = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (manager.getRealmByName(rep.getRealm()) != null) {
|
if (manager.getRealmByName(rep.getRealm()) != null) {
|
||||||
logger.realmExists(rep.getRealm(), from);
|
logger.realmExists(rep.getRealm(), from);
|
||||||
return;
|
exists = true;
|
||||||
}
|
}
|
||||||
|
if (!exists) {
|
||||||
try {
|
|
||||||
RealmModel realm = manager.importRealm(rep);
|
RealmModel realm = manager.importRealm(rep);
|
||||||
session.getTransaction().commit();
|
|
||||||
logger.importedRealm(realm.getName(), from);
|
logger.importedRealm(realm.getName(), from);
|
||||||
|
}
|
||||||
|
session.getTransaction().commit();
|
||||||
} catch (Throwable t) {
|
} catch (Throwable t) {
|
||||||
session.getTransaction().rollback();
|
session.getTransaction().rollback();
|
||||||
|
if (!exists) {
|
||||||
logger.unableToImportRealm(t, rep.getRealm(), from);
|
logger.unableToImportRealm(t, rep.getRealm(), from);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
} finally {
|
} finally {
|
||||||
session.close();
|
session.close();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue