-
Notifications
You must be signed in to change notification settings - Fork 2.7k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Support OpenTelemetry End User attributes added as Span attributes
- Loading branch information
1 parent
fb12a4d
commit aa8da2c
Showing
22 changed files
with
1,198 additions
and
12 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
35 changes: 35 additions & 0 deletions
35
...src/main/java/io/quarkus/opentelemetry/runtime/tracing/security/EndUserSpanProcessor.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
package io.quarkus.opentelemetry.runtime.tracing.security; | ||
|
||
import jakarta.enterprise.context.Dependent; | ||
|
||
import io.opentelemetry.context.Context; | ||
import io.opentelemetry.sdk.trace.ReadWriteSpan; | ||
import io.opentelemetry.sdk.trace.ReadableSpan; | ||
import io.opentelemetry.sdk.trace.SpanProcessor; | ||
|
||
/** | ||
* Main purpose of this processor is to cover adding of the End User attributes to user-created Spans. | ||
*/ | ||
@Dependent | ||
public class EndUserSpanProcessor implements SpanProcessor { | ||
|
||
@Override | ||
public void onStart(Context context, ReadWriteSpan span) { | ||
SecurityEventUtil.addEndUserAttributes(span); | ||
} | ||
|
||
@Override | ||
public boolean isStartRequired() { | ||
return true; | ||
} | ||
|
||
@Override | ||
public void onEnd(ReadableSpan readableSpan) { | ||
|
||
} | ||
|
||
@Override | ||
public boolean isEndRequired() { | ||
return false; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
43 changes: 43 additions & 0 deletions
43
...e/src/main/java/io/quarkus/it/opentelemetry/reactive/CustomSecurityIdentityAugmentor.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
package io.quarkus.it.opentelemetry.reactive; | ||
|
||
import java.util.Map; | ||
|
||
import jakarta.inject.Singleton; | ||
|
||
import io.quarkus.security.identity.AuthenticationRequestContext; | ||
import io.quarkus.security.identity.SecurityIdentity; | ||
import io.quarkus.security.identity.SecurityIdentityAugmentor; | ||
import io.quarkus.security.runtime.QuarkusSecurityIdentity; | ||
import io.quarkus.vertx.http.runtime.security.HttpSecurityUtils; | ||
import io.smallrye.mutiny.Uni; | ||
|
||
@Singleton | ||
public class CustomSecurityIdentityAugmentor implements SecurityIdentityAugmentor { | ||
@Override | ||
public Uni<SecurityIdentity> augment(SecurityIdentity securityIdentity, | ||
AuthenticationRequestContext authenticationRequestContext) { | ||
return augment(securityIdentity, authenticationRequestContext, Map.of()); | ||
} | ||
|
||
@Override | ||
public Uni<SecurityIdentity> augment(SecurityIdentity identity, AuthenticationRequestContext context, | ||
Map<String, Object> attributes) { | ||
var routingContext = HttpSecurityUtils.getRoutingContextAttribute(attributes); | ||
if (routingContext != null) { | ||
var augmentorScenario = routingContext.normalizedPath().contains("-augmentor"); | ||
var configRolesMappingScenario = routingContext.normalizedPath().contains("roles-mapping-http-perm"); | ||
if (augmentorScenario || configRolesMappingScenario) { | ||
var builder = QuarkusSecurityIdentity.builder(identity); | ||
if (augmentorScenario) { | ||
builder.addRole("AUGMENTOR"); | ||
} | ||
if (configRolesMappingScenario) { | ||
// this role is supposed to be re-mapped by HTTP roles mapping (not path-specific) | ||
builder.addRole("ROLES-ALLOWED-MAPPING-ROLE"); | ||
} | ||
return Uni.createFrom().item(builder.build()); | ||
} | ||
} | ||
return Uni.createFrom().item(identity); | ||
} | ||
} |
Oops, something went wrong.