io.hyperfoil.tools.horreum.server.RolesInterceptor Maven / Gradle / Ivy
package io.hyperfoil.tools.horreum.server;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.function.Function;
import jakarta.annotation.Priority;
import jakarta.inject.Inject;
import jakarta.interceptor.AroundInvoke;
import jakarta.interceptor.Interceptor;
import jakarta.interceptor.InvocationContext;
import jakarta.persistence.EntityManager;
import jakarta.transaction.Status;
import jakarta.transaction.TransactionManager;
import io.hyperfoil.tools.horreum.svc.Roles;
import io.hyperfoil.tools.horreum.svc.Util;
import io.quarkus.security.identity.SecurityIdentity;
@Interceptor
@Priority(Interceptor.Priority.APPLICATION + 100)
@WithRoles
public class RolesInterceptor {
private static final ThreadLocal currentIdentity = new ThreadLocal<>();
@Inject
RoleManager roleManager;
@Inject
SecurityIdentity identity;
@Inject
EntityManager em;
@Inject
TransactionManager tm;
public static void setCurrentIdentity(SecurityIdentity identity) {
currentIdentity.set(identity);
}
@AroundInvoke
public Object intercept(InvocationContext ctx) throws Exception {
SecurityIdentity identity = currentIdentity.get();
if (identity == null) {
identity = this.identity;
}
WithRoles annotation = Util.getAnnotation(ctx.getMethod(), WithRoles.class);
boolean hasParams = annotation.fromParams() != WithRoles.IgnoreParams.class;
if (identity.isAnonymous() && annotation.extras().length == 0 && !hasParams) {
return ctx.proceed();
}
Collection roles = identity.getRoles();
if (annotation.extras().length != 0 || annotation.addUsername() || hasParams) {
roles = new ArrayList<>(roles);
Collections.addAll(roles, annotation.extras());
if (annotation.addUsername()) {
roles.add(identity.getPrincipal().getName());
}
if (hasParams) {
Function
© 2015 - 2025 Weber Informatics LLC | Privacy Policy