Skip to content

Commit

Permalink
Merge pull request #42179 from danilopiazza/identity-providers-sort-b…
Browse files Browse the repository at this point in the history
…y-priority

Sort identity providers by priority in QuarkusIdentityProviderManagerImpl
  • Loading branch information
geoand authored Aug 5, 2024
2 parents 0fecbde + c743eca commit 09f6957
Show file tree
Hide file tree
Showing 2 changed files with 89 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -224,6 +224,14 @@ public QuarkusIdentityProviderManagerImpl build() {
throw new IllegalStateException(
"No AnonymousIdentityProvider registered. An instance of AnonymousIdentityProvider must be provided to allow the Anonymous identity to be created.");
}
for (List<IdentityProvider> providers : providers.values()) {
providers.sort(new Comparator<IdentityProvider>() {
@Override
public int compare(IdentityProvider o1, IdentityProvider o2) {
return Integer.compare(o2.priority(), o1.priority());
}
});
}
if (blockingExecutor == null) {
throw new IllegalStateException("no blocking executor specified");
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
package io.quarkus.security.runtime;

import static org.junit.jupiter.api.Assertions.assertEquals;

import java.util.concurrent.Executors;

import org.junit.jupiter.api.Test;

import io.quarkus.security.AuthenticationFailedException;
import io.quarkus.security.identity.AuthenticationRequestContext;
import io.quarkus.security.identity.IdentityProvider;
import io.quarkus.security.identity.IdentityProviderManager;
import io.quarkus.security.identity.SecurityIdentity;
import io.quarkus.security.identity.request.BaseAuthenticationRequest;
import io.smallrye.mutiny.Uni;

class QuarkusIdentityProviderManagerImplTest {

@Test
void testIdentityProviderPriority() {
IdentityProviderManager identityProviderManager = QuarkusIdentityProviderManagerImpl.builder()
.addProvider(new TestIdentityProviderSystemLastPriority())
.addProvider(new TestIdentityProviderUserLastPriority())
.addProvider(new TestIdentityProviderUserFirstPriority())
.addProvider(new TestIdentityProviderSystemFirstPriority())
.addProvider(new AnonymousIdentityProvider())
.setBlockingExecutor(Executors.newSingleThreadExecutor())
.build();

SecurityIdentity identity = identityProviderManager.authenticateBlocking(new TestAuthenticationRequest());

assertEquals(new QuarkusPrincipal("Bob"), identity.getPrincipal());
}

static class TestAuthenticationRequest extends BaseAuthenticationRequest {
}

abstract static class TestIdentityProvider implements IdentityProvider<TestAuthenticationRequest> {
@Override
public Class<TestAuthenticationRequest> getRequestType() {
return TestAuthenticationRequest.class;
}

@Override
public Uni<SecurityIdentity> authenticate(TestAuthenticationRequest request, AuthenticationRequestContext context) {
throw new AuthenticationFailedException(getClass().getSimpleName());
}
}

static class TestIdentityProviderUserFirstPriority extends TestIdentityProvider {
@Override
public int priority() {
return Integer.MAX_VALUE;
}

@Override
public Uni<SecurityIdentity> authenticate(TestAuthenticationRequest request, AuthenticationRequestContext context) {
SecurityIdentity identity = QuarkusSecurityIdentity.builder()
.setPrincipal(new QuarkusPrincipal("Bob"))
.build();
return Uni.createFrom().item(identity);
}
}

static class TestIdentityProviderUserLastPriority extends TestIdentityProvider {
}

static class TestIdentityProviderSystemFirstPriority extends TestIdentityProvider {
@Override
public int priority() {
return SYSTEM_FIRST;
}
}

static class TestIdentityProviderSystemLastPriority extends TestIdentityProvider {
@Override
public int priority() {
return SYSTEM_LAST;
}
}
}

0 comments on commit 09f6957

Please sign in to comment.