Skip to content

Commit

Permalink
Fix OidcBuildStep#findSecurityEventObservers()
Browse files Browse the repository at this point in the history
- this build step should consume RuntimeConfigSetupCompleteBuildItem
because DefaultTenantConfigResolver injects a runtime config property
- resolves #26236
  • Loading branch information
mkouba committed Jun 22, 2022
1 parent 5aac1c4 commit df21e16
Showing 1 changed file with 7 additions and 10 deletions.
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
package io.quarkus.oidc.deployment;

import java.util.Collection;
import java.util.function.BooleanSupplier;

import javax.inject.Singleton;
Expand All @@ -9,11 +8,8 @@
import org.jboss.jandex.DotName;

import io.quarkus.arc.deployment.AdditionalBeanBuildItem;
import io.quarkus.arc.deployment.SynthesisFinishedBuildItem;
import io.quarkus.arc.deployment.SyntheticBeanBuildItem;
import io.quarkus.arc.deployment.ValidationPhaseBuildItem;
import io.quarkus.arc.deployment.ValidationPhaseBuildItem.ValidationErrorBuildItem;
import io.quarkus.arc.processor.BuildExtension;
import io.quarkus.arc.processor.ObserverInfo;
import io.quarkus.deployment.Capabilities;
import io.quarkus.deployment.Capability;
import io.quarkus.deployment.Feature;
Expand All @@ -23,6 +19,7 @@
import io.quarkus.deployment.annotations.Record;
import io.quarkus.deployment.builditem.ExtensionSslNativeSupportBuildItem;
import io.quarkus.deployment.builditem.FeatureBuildItem;
import io.quarkus.deployment.builditem.RuntimeConfigSetupCompleteBuildItem;
import io.quarkus.deployment.builditem.nativeimage.ReflectiveClassBuildItem;
import io.quarkus.oidc.SecurityEvent;
import io.quarkus.oidc.TokenIntrospectionCache;
Expand Down Expand Up @@ -130,14 +127,14 @@ public SyntheticBeanBuildItem setup(

@BuildStep(onlyIf = IsEnabled.class)
@Record(ExecutionTime.RUNTIME_INIT)
public ValidationErrorBuildItem findSecurityEventObservers(
public void findSecurityEventObservers(
OidcRecorder recorder,
ValidationPhaseBuildItem validationPhase) {
Collection<ObserverInfo> observers = validationPhase.getContext().get(BuildExtension.Key.OBSERVERS);
boolean isSecurityEventObserved = observers.stream()
SynthesisFinishedBuildItem synthesisFinished,
// Note that DefaultTenantConfigResolver injects quarkus.http.proxy.enable-forwarded-prefix
RuntimeConfigSetupCompleteBuildItem runtimeConfigComplete) {
boolean isSecurityEventObserved = synthesisFinished.getObservers().stream()
.anyMatch(observer -> observer.asObserver().getObservedType().name().equals(DOTNAME_SECURITY_EVENT));
recorder.setSecurityEventObserved(isSecurityEventObserved);
return new ValidationErrorBuildItem();
}

public static class IsEnabled implements BooleanSupplier {
Expand Down

0 comments on commit df21e16

Please sign in to comment.