io.quarkus.oidc.runtime.OidcAuthenticationMechanism Maven / Gradle / Ivy
package io.quarkus.oidc.runtime;
import java.util.Collections;
import java.util.Set;
import javax.annotation.PostConstruct;
import javax.enterprise.context.ApplicationScoped;
import javax.inject.Inject;
import io.quarkus.oidc.OIDCException;
import io.quarkus.oidc.OidcTenantConfig;
import io.quarkus.security.identity.IdentityProviderManager;
import io.quarkus.security.identity.SecurityIdentity;
import io.quarkus.security.identity.request.AuthenticationRequest;
import io.quarkus.security.identity.request.TokenAuthenticationRequest;
import io.quarkus.vertx.http.runtime.security.ChallengeData;
import io.quarkus.vertx.http.runtime.security.HttpAuthenticationMechanism;
import io.quarkus.vertx.http.runtime.security.HttpCredentialTransport;
import io.smallrye.mutiny.Uni;
import io.vertx.ext.web.RoutingContext;
@ApplicationScoped
public class OidcAuthenticationMechanism implements HttpAuthenticationMechanism {
@Inject
DefaultTenantConfigResolver resolver;
private BearerAuthenticationMechanism bearerAuth = new BearerAuthenticationMechanism();
private CodeAuthenticationMechanism codeAuth = new CodeAuthenticationMechanism();
@PostConstruct
public void init() {
bearerAuth.setResolver(resolver);
codeAuth.setResolver(resolver);
}
@Override
public Uni authenticate(RoutingContext context,
IdentityProviderManager identityProviderManager) {
OidcTenantConfig oidcConfig = resolve(context);
if (oidcConfig.tenantEnabled == false) {
return Uni.createFrom().nullItem();
}
return isWebApp(context, oidcConfig) ? codeAuth.authenticate(context, identityProviderManager)
: bearerAuth.authenticate(context, identityProviderManager);
}
@Override
public Uni getChallenge(RoutingContext context) {
OidcTenantConfig oidcConfig = resolve(context);
if (oidcConfig.tenantEnabled == false) {
return Uni.createFrom().nullItem();
}
return isWebApp(context, oidcConfig) ? codeAuth.getChallenge(context)
: bearerAuth.getChallenge(context);
}
private OidcTenantConfig resolve(RoutingContext context) {
OidcTenantConfig oidcConfig = resolver.resolveConfig(context);
if (oidcConfig == null) {
throw new OIDCException("Tenant configuration has not been resolved");
}
return oidcConfig;
}
private boolean isWebApp(RoutingContext context, OidcTenantConfig oidcConfig) {
if (OidcTenantConfig.ApplicationType.HYBRID == oidcConfig.applicationType) {
return context.request().getHeader("Authorization") == null;
}
return OidcTenantConfig.ApplicationType.WEB_APP == oidcConfig.applicationType;
}
@Override
public Set> getCredentialTypes() {
return Collections.singleton(TokenAuthenticationRequest.class);
}
@Override
public HttpCredentialTransport getCredentialTransport() {
//not 100% correct, but enough for now
//if OIDC is present we don't really want another bearer mechanism
return new HttpCredentialTransport(HttpCredentialTransport.Type.AUTHORIZATION, "bearer");
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy