Richard DiCroce created DELTASPIKE-600:
------------------------------------------

             Summary: ViewConfig @Secured AccessDecisionVoter is being called 
twice
                 Key: DELTASPIKE-600
                 URL: https://issues.apache.org/jira/browse/DELTASPIKE-600
             Project: DeltaSpike
          Issue Type: Bug
          Components: JSF-Module
    Affects Versions: 0.7
         Environment: WildFly 8.0.0.Final (Mojarra 2.2.5-jbossorg-3)
            Reporter: Richard DiCroce


I have the following ViewConfig:
{code}
public interface Pages extends ViewConfig {

        @Dependent
        class Index implements Pages {}
        
        @Secured({AuthenticatedDecisionVoter.class, 
PermissionDecisionVoter.class})
        interface SecuredByRoleAttribute extends Pages {
                @Dependent
                class TestPage implements SecuredByRoleAttribute {}
        }
        
        @Secured(AuthenticatedDecisionVoter.class)
        interface NoAuthorization extends Pages {
                @Dependent
                class TestPage implements NoAuthorization {}
        }
        
}
{code}

The DecisionVoters are being called twice during each request, with different 
metadata. The first time, the metadata contains the @View for the appropriate 
page. The second time, the metadata does not contain the @View and instead 
contains the @Folder for the folder that contains the view.

The documentation regarding @Secured in the JSF module is very light, so maybe 
this is the intended behavior, but it seems wrong to me.

I'm not sure if this is a DS issue or a Mojarra issue or both, but the stack is 
exactly the same on both invocations:
{noformat}
11:12:39,867 ERROR [stderr] (default task-7) java.lang.Exception
11:12:39,868 ERROR [stderr] (default task-7)    at 
com.lapis.throwaway.picketlink.PermissionDecisionVoter.checkPermission(PermissionDecisionVoter.java:37)
11:12:39,868 ERROR [stderr] (default task-7)    at 
com.lapis.throwaway.picketlink.PermissionDecisionVoter$Proxy$_$$_WeldClientProxy.checkPermission(Unknown
 Source)
11:12:39,868 ERROR [stderr] (default task-7)    at 
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
11:12:39,868 ERROR [stderr] (default task-7)    at 
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
11:12:39,869 ERROR [stderr] (default task-7)    at 
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
11:12:39,869 ERROR [stderr] (default task-7)    at 
java.lang.reflect.Method.invoke(Method.java:606)
11:12:39,869 ERROR [stderr] (default task-7)    at 
org.apache.deltaspike.core.api.config.view.metadata.ExecutableCallbackDescriptor.execute(ExecutableCallbackDescriptor.java:57)
11:12:39,870 ERROR [stderr] (default task-7)    at 
org.apache.deltaspike.security.api.authorization.Secured$Descriptor.execute(Secured.java:93)
11:12:39,870 ERROR [stderr] (default task-7)    at 
org.apache.deltaspike.jsf.impl.util.SecurityUtils.invokeVoters(SecurityUtils.java:80)
11:12:39,870 ERROR [stderr] (default task-7)    at 
org.apache.deltaspike.jsf.impl.security.ViewRootAccessHandler.checkAccessTo(ViewRootAccessHandler.java:87)
11:12:39,871 ERROR [stderr] (default task-7)    at 
org.apache.deltaspike.jsf.impl.security.ViewRootAccessHandler$Proxy$_$$_WeldClientProxy.checkAccessTo(Unknown
 Source)
11:12:39,871 ERROR [stderr] (default task-7)    at 
org.apache.deltaspike.jsf.impl.security.SecurityAwareViewHandler.createView(SecurityAwareViewHandler.java:113)
11:12:39,871 ERROR [stderr] (default task-7)    at 
org.apache.deltaspike.jsf.impl.view.DeltaSpikeViewHandler.createView(DeltaSpikeViewHandler.java:70)
11:12:39,872 ERROR [stderr] (default task-7)    at 
javax.faces.application.ViewHandlerWrapper.createView(ViewHandlerWrapper.java:173)
11:12:39,872 ERROR [stderr] (default task-7)    at 
javax.faces.application.ViewHandlerWrapper.createView(ViewHandlerWrapper.java:173)
11:12:39,872 ERROR [stderr] (default task-7)    at 
com.sun.faces.application.view.ViewMetadataImpl.createMetadataView(ViewMetadataImpl.java:107)
11:12:39,872 ERROR [stderr] (default task-7)    at 
com.sun.faces.lifecycle.RestoreViewPhase.execute(RestoreViewPhase.java:241)
11:12:39,873 ERROR [stderr] (default task-7)    at 
com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
11:12:39,873 ERROR [stderr] (default task-7)    at 
com.sun.faces.lifecycle.RestoreViewPhase.doPhase(RestoreViewPhase.java:121)
11:12:39,873 ERROR [stderr] (default task-7)    at 
com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:198)
11:12:39,874 ERROR [stderr] (default task-7)    at 
org.apache.deltaspike.jsf.impl.listener.request.DeltaSpikeLifecycleWrapper.execute(DeltaSpikeLifecycleWrapper.java:89)
11:12:39,874 ERROR [stderr] (default task-7)    at 
javax.faces.lifecycle.LifecycleWrapper.execute(LifecycleWrapper.java:77)
11:12:39,874 ERROR [stderr] (default task-7)    at 
javax.faces.webapp.FacesServlet.service(FacesServlet.java:646)
11:12:39,875 ERROR [stderr] (default task-7)    at 
io.undertow.servlet.handlers.ServletHandler.handleRequest(ServletHandler.java:85)
11:12:39,875 ERROR [stderr] (default task-7)    at 
io.undertow.servlet.handlers.security.ServletSecurityRoleHandler.handleRequest(ServletSecurityRoleHandler.java:61)
11:12:39,875 ERROR [stderr] (default task-7)    at 
io.undertow.servlet.handlers.ServletDispatchingHandler.handleRequest(ServletDispatchingHandler.java:36)
11:12:39,876 ERROR [stderr] (default task-7)    at 
org.wildfly.extension.undertow.security.SecurityContextAssociationHandler.handleRequest(SecurityContextAssociationHandler.java:78)
11:12:39,876 ERROR [stderr] (default task-7)    at 
io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:25)
11:12:39,876 ERROR [stderr] (default task-7)    at 
io.undertow.servlet.handlers.security.SSLInformationAssociationHandler.handleRequest(SSLInformationAssociationHandler.java:113)
11:12:39,877 ERROR [stderr] (default task-7)    at 
io.undertow.security.handlers.AuthenticationCallHandler.handleRequest(AuthenticationCallHandler.java:52)
11:12:39,877 ERROR [stderr] (default task-7)    at 
io.undertow.security.handlers.AbstractConfidentialityHandler.handleRequest(AbstractConfidentialityHandler.java:45)
11:12:39,878 ERROR [stderr] (default task-7)    at 
io.undertow.servlet.handlers.security.ServletConfidentialityConstraintHandler.handleRequest(ServletConfidentialityConstraintHandler.java:61)
11:12:39,878 ERROR [stderr] (default task-7)    at 
io.undertow.servlet.handlers.security.CachedAuthenticatedSessionHandler.handleRequest(CachedAuthenticatedSessionHandler.java:70)
11:12:39,878 ERROR [stderr] (default task-7)    at 
io.undertow.security.handlers.SecurityInitialHandler.handleRequest(SecurityInitialHandler.java:76)
11:12:39,879 ERROR [stderr] (default task-7)    at 
io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:25)
11:12:39,879 ERROR [stderr] (default task-7)    at 
org.wildfly.extension.undertow.security.jacc.JACCContextIdHandler.handleRequest(JACCContextIdHandler.java:61)
11:12:39,879 ERROR [stderr] (default task-7)    at 
io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:25)
11:12:39,880 ERROR [stderr] (default task-7)    at 
io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:25)
11:12:39,880 ERROR [stderr] (default task-7)    at 
io.undertow.servlet.handlers.ServletInitialHandler.handleFirstRequest(ServletInitialHandler.java:240)
11:12:39,880 ERROR [stderr] (default task-7)    at 
io.undertow.servlet.handlers.ServletInitialHandler.dispatchRequest(ServletInitialHandler.java:227)
11:12:39,881 ERROR [stderr] (default task-7)    at 
io.undertow.servlet.handlers.ServletInitialHandler.access$000(ServletInitialHandler.java:73)
11:12:39,881 ERROR [stderr] (default task-7)    at 
io.undertow.servlet.handlers.ServletInitialHandler$1.handleRequest(ServletInitialHandler.java:146)
11:12:39,881 ERROR [stderr] (default task-7)    at 
io.undertow.server.Connectors.executeRootHandler(Connectors.java:168)
11:12:39,882 ERROR [stderr] (default task-7)    at 
io.undertow.server.HttpServerExchange$1.run(HttpServerExchange.java:687)
11:12:39,882 ERROR [stderr] (default task-7)    at 
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
11:12:39,882 ERROR [stderr] (default task-7)    at 
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
11:12:39,883 ERROR [stderr] (default task-7)    at 
java.lang.Thread.run(Thread.java:744)
{noformat}



--
This message was sent by Atlassian JIRA
(v6.2#6252)

Reply via email to