diff --git a/core/src/main/java/org/keycloak/representations/idm/RealmRepresentation.java b/core/src/main/java/org/keycloak/representations/idm/RealmRepresentation.java index 3359f2195f..ed5fd9351e 100755 --- a/core/src/main/java/org/keycloak/representations/idm/RealmRepresentation.java +++ b/core/src/main/java/org/keycloak/representations/idm/RealmRepresentation.java @@ -642,11 +642,6 @@ public class RealmRepresentation { identityProviders.add(identityProviderRepresentation); } - @Deprecated - public boolean isIdentityFederationEnabled() { - return identityProviders != null && !identityProviders.isEmpty(); - } - public List getProtocolMappers() { return protocolMappers; } diff --git a/forms/common-themes/src/main/resources/theme/base/admin/resources/js/controllers/clients.js b/forms/common-themes/src/main/resources/theme/base/admin/resources/js/controllers/clients.js index 9729c9cd90..eb58ca0d8e 100755 --- a/forms/common-themes/src/main/resources/theme/base/admin/resources/js/controllers/clients.js +++ b/forms/common-themes/src/main/resources/theme/base/admin/resources/js/controllers/clients.js @@ -1615,7 +1615,7 @@ module.controller('ClientProtocolMapperCtrl', function($scope, realm, serverInfo }; $scope.remove = function() { - Dialog.confirmDelete($scope.mapper.name, 'mapper', function() { + Dialog.confirmDelete($scope.model.mapper.name, 'mapper', function() { ClientProtocolMapper.remove({ realm: realm.realm, client: client.id, id : $scope.model.mapper.id }, function() { Notifications.success("The mapper has been deleted."); $location.url("/realms/" + realm.realm + '/clients/' + client.id + "/mappers"); diff --git a/services/src/main/java/org/keycloak/provider/ProviderManager.java b/services/src/main/java/org/keycloak/provider/ProviderManager.java index 6246d83973..3f250da672 100644 --- a/services/src/main/java/org/keycloak/provider/ProviderManager.java +++ b/services/src/main/java/org/keycloak/provider/ProviderManager.java @@ -3,6 +3,7 @@ package org.keycloak.provider; import org.jboss.logging.Logger; import java.util.HashMap; +import java.util.IdentityHashMap; import java.util.LinkedList; import java.util.List; import java.util.Map; @@ -52,10 +53,17 @@ public class ProviderManager { List factories = cache.get(spi.getName()); if (factories == null) { factories = new LinkedList(); + IdentityHashMap factoryClasses = new IdentityHashMap(); for (ProviderLoader loader : loaders) { List f = loader.load(spi); if (f != null) { - factories.addAll(f); + for (ProviderFactory pf: f) { + // make sure there are no duplicates + if (!factoryClasses.containsKey(pf.getClass())) { + factories.add(pf); + factoryClasses.put(pf.getClass(), pf); + } + } } } } diff --git a/testsuite/integration-arquillian/tests/base/src/test/resources/keycloak-add-user.json b/testsuite/integration-arquillian/tests/base/src/test/resources/keycloak-add-user.json new file mode 100644 index 0000000000..635f144a8e --- /dev/null +++ b/testsuite/integration-arquillian/tests/base/src/test/resources/keycloak-add-user.json @@ -0,0 +1,16 @@ +[ { + "realm" : "master", + "users" : [ { + "username" : "admin", + "enabled" : true, + "credentials" : [ { + "type" : "password", + "hashedSaltedValue" : "6K5rvcPu3dXndZOhpzLAVbFtcdlUhbGCrUyV0NNzeS61IdhMpjH8Mf4y/Ag/vHZkw4Ayvtvb9/1iMNOzxR0M6g==", + "salt" : "/6M1jTMUB0uR8EOkksFn/A==", + "hashIterations" : 100000, + "algorithm" : "pbkdf2" + } ], + "realmRoles" : [ "admin" ] + } ], + "identityFederationEnabled" : false +} ] \ No newline at end of file diff --git a/testsuite/integration-arquillian/tests/pom.xml b/testsuite/integration-arquillian/tests/pom.xml index bfac920ae3..a4c09e6100 100644 --- a/testsuite/integration-arquillian/tests/pom.xml +++ b/testsuite/integration-arquillian/tests/pom.xml @@ -91,6 +91,7 @@ ${auth.server.management.port.jmx} ${auth.server.ssl.required} ${startup.timeout.sec} + ${project.build.directory}/undertow-configuration @@ -127,6 +128,31 @@ + + maven-resources-plugin + 2.7 + + + copy-admin-user-json-file + process-resources + + copy-resources + + + ${project.build.directory}/undertow-configuration + + + src/test/resources + + keycloak-add-user.json + + true + + + + + + @@ -413,6 +439,31 @@ + + maven-resources-plugin + 2.7 + + + copy-admin-user-json-file + process-resources + + copy-resources + + + ${auth.server.wildfly.home}/standalone/configuration + + + src/test/resources + + keycloak-add-user.json + + true + + + + + + @@ -473,6 +524,31 @@ + + maven-resources-plugin + 2.7 + + + copy-admin-user-json-file + process-resources + + copy-resources + + + ${auth.server.eap6.home}/standalone/configuration + + + src/test/resources + + keycloak-add-user.json + + true + + + + + +