Hi Patrizio,

We recently moved all JAAS dependencies from Restlet Core to a JAAS 
extension. This should solve your issue. Could you test with a recent 
2.0 snapshot and let us know?

Best regards,
Jerome Louvel
--
Restlet ~ Founder and Lead developer ~ http://www.restlet.org
Noelios Technologies ~ Co-founder ~ http://www.noelios.com


Patrizio Munzi a écrit :
> Ok, thank you.
> 
> Thierry Boileau wrote:
>> Hello Patrizio,
>>
>> I've entered a new issue for this problem : 
>> http://restlet.tigris.org/issues/show_bug.cgi?id=893.
>> Thanks for your report.
>>
>> Best regards,
>> Thierry Boileau
>>
>>   
>>> Hi everybody,
>>>
>>> I think I've found a problem of Restlet Authentication mechanism with GAE.
>>>
>>> I have got this simple guard:
>>> --------------------------
>>>     public Restlet createRoot() { 
>>>         // Create a router Restlet that defines routes. 
>>>         Router router = new Router(getContext()); 
>>>
>>>         // Defines a route for the resource "list of items" 
>>>         router.attach("/addcall", CallResource.class); 
>>>         router.attach("/addsms", SMSResource.class); 
>>>
>>>         ChallengeAuthenticator authenticator = new 
>>> ChallengeAuthenticator(getContext(), ChallengeScheme.HTTP_BASIC, 
>>> "com.eris4.warp4.callfriends.server.restlet");
>>>         MapVerifier verifier = new MapVerifier();
>>>         verifier.getSecrets().put("callFriends", 
>>> "callFriends".toCharArray());
>>>         authenticator.setVerifier(verifier);
>>>         authenticator.setNext(router);
>>>        
>>>         Router guardedRouter = new Router(getContext());
>>>         guardedRouter.attach("/", authenticator);
>>>        
>>>         return guardedRouter; 
>>>    } 
>>> --------------------------
>>>
>>> and this simple client:
>>> --------------------------
>>>     public static void main(String[] args) throws ResourceException {
>>>         //        Client client = new Client(new Context(), 
>>> Protocol.HTTP); 
>>>         //        client.getContext().getParameters().add("converter",  
>>> "com.noelios.restlet.http.HttpClientConverter"); 
>>>
>>>         Engine.getInstance().getRegisteredClients().add(new 
>>> HttpClientHelper(null));
>>>         Client client = new Client(Protocol.HTTP);
>>>         Status resultStatus = null;
>>>         try {
>>>             Form form = new Form(); 
>>>             form.add("param1", "1");
>>>             Representation callRepresentation = form.getWebRepresentation();
>>>
>>>             Request request = new Request(Method.POST, url);
>>>             ChallengeResponse authentication = new 
>>> ChallengeResponse(ChallengeScheme.HTTP_BASIC, "login", "psw");
>>>             request.setChallengeResponse(authentication);
>>>
>>>             request.setEntity(callRepresentation);
>>>             Response response = client.handle(request);
>>>             resultStatus = response.getStatus();
>>>         } catch (Throwable t) {
>>>             System.err.println("Exception: " + t);
>>>         }       
>>>    }
>>> --------------------------
>>>
>>> and GAE side I get the following exception:
>>> --------------------------
>>> SEVERE: Unhandled exception or error intercepted
>>> java.security.AccessControlException: access denied 
>>> (javax.security.auth.AuthPermission modifyPrincipals)
>>>     at java.security.AccessControlContext.checkPermission(Unknown Source)
>>>     at java.security.AccessController.checkPermission(Unknown Source)
>>>     at java.lang.SecurityManager.checkPermission(Unknown Source)
>>>     at 
>>> com.google.appengine.tools.development.DevAppServerFactory$CustomSecurityManager.checkPermission(DevAppServerFactory.java:139)
>>>     at javax.security.auth.Subject$SecureSet.add(Unknown Source)
>>>     at java.util.Collections$SynchronizedCollection.add(Unknown Source)
>>>     at org.restlet.security.SecretVerifier.verify(SecretVerifier.java:114)
>>>     at 
>>> org.restlet.security.ChallengeAuthenticator.authenticate(ChallengeAuthenticator.java:134)
>>>     at 
>>> org.restlet.security.Authenticator.beforeHandle(Authenticator.java:107)
>>>     at org.restlet.routing.Filter.handle(Filter.java:199)
>>>     at org.restlet.routing.Filter.doHandle(Filter.java:156)
>>>     at org.restlet.routing.Filter.handle(Filter.java:201)
>>>     at org.restlet.routing.Router.doHandle(Router.java:321)
>>>     at org.restlet.routing.Router.handle(Router.java:520)
>>>     at org.restlet.routing.Filter.doHandle(Filter.java:156)
>>>     at org.restlet.routing.Filter.handle(Filter.java:201)
>>>     at org.restlet.routing.Filter.doHandle(Filter.java:156)
>>>     at org.restlet.routing.Filter.handle(Filter.java:201)
>>>     at org.restlet.routing.Filter.doHandle(Filter.java:156)
>>>     at 
>>> org.restlet.engine.application.StatusFilter.doHandle(StatusFilter.java:152)
>>>     at org.restlet.routing.Filter.handle(Filter.java:201)
>>>     at org.restlet.routing.Filter.doHandle(Filter.java:156)
>>>     at org.restlet.routing.Filter.handle(Filter.java:201)
>>>     at org.restlet.engine.ChainHelper.handle(ChainHelper.java:111)
>>>     at 
>>> org.restlet.engine.application.ApplicationHelper.handle(ApplicationHelper.java:72)
>>>     at org.restlet.Application.handle(Application.java:344)
>>>     at org.restlet.routing.Filter.doHandle(Filter.java:156)
>>>     at org.restlet.routing.Filter.handle(Filter.java:201)
>>>     at org.restlet.routing.Router.doHandle(Router.java:321)
>>>     at org.restlet.routing.Router.handle(Router.java:520)
>>>     at org.restlet.routing.Filter.doHandle(Filter.java:156)
>>>     at org.restlet.routing.Filter.handle(Filter.java:201)
>>>     at org.restlet.routing.Router.doHandle(Router.java:321)
>>>     at org.restlet.routing.Router.handle(Router.java:520)
>>>     at org.restlet.routing.Filter.doHandle(Filter.java:156)
>>>     at org.restlet.routing.Filter.handle(Filter.java:201)
>>>     at org.restlet.engine.ChainHelper.handle(ChainHelper.java:111)
>>>     at org.restlet.Component.handle(Component.java:403)
>>>     at org.restlet.Server.handle(Server.java:350)
>>>     at org.restlet.engine.ServerHelper.handle(ServerHelper.java:71)
>>>     at 
>>> org.restlet.engine.http.HttpServerHelper.handle(HttpServerHelper.java:149)
>>>     at org.restlet.ext.servlet.ServerServlet.service(ServerServlet.java:967)
>>>     at javax.servlet.http.HttpServlet.service(HttpServlet.java:806)
>>>     at 
>>> org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:487)
>>>     at 
>>> org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1093)
>>>     at 
>>> com.google.apphosting.utils.servlet.TransactionCleanupFilter.doFilter(TransactionCleanupFilter.java:43)
>>>     at 
>>> org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1084)
>>>     at 
>>> com.google.appengine.tools.development.StaticFileFilter.doFilter(StaticFileFilter.java:121)
>>>     at 
>>> org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1084)
>>>     at 
>>> org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:360)
>>>     at 
>>> org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
>>>     at 
>>> org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181)
>>>     at 
>>> org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:712)
>>>     at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:405)
>>>     at 
>>> com.google.apphosting.utils.jetty.DevAppEngineWebAppContext.handle(DevAppEngineWebAppContext.java:54)
>>>     at 
>>> org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:139)
>>>     at 
>>> com.google.appengine.tools.development.JettyContainerService$ApiProxyHandler.handle(JettyContainerService.java:313)
>>>     at 
>>> org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:139)
>>>     at org.mortbay.jetty.Server.handle(Server.java:313)
>>>     at 
>>> org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:506)
>>>     at 
>>> org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:844)
>>>     at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:644)
>>>     at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:205)
>>>     at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:381)
>>>     at 
>>> org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:396)
>>>     at 
>>> org.mortbay.thread.BoundedThreadPool$PoolThread.run(BoundedThreadPool.java:442)
>>> -----------------------
>>>
>>> has anybody any idea on how I can work around this???
>>> Is it a bug??
>>>
>>> Thanks
>>>
>>> ------------------------------------------------------
>>> http://restlet.tigris.org/ds/viewMessage.do?dsForumId=4447&dsMessageId=2392516
>>>
>>>
>>>     
>>
>> ------------------------------------------------------
>> http://restlet.tigris.org/ds/viewMessage.do?dsForumId=4447&dsMessageId=2393621
>>
>>   
> 
> -- 
> 
> *Patrizio Munzi*
> Product Specialist
> Viale Bruno Buozzi, 19 - 00197 Roma (Italy)
> tel: +39 06 4543 3540
> fax: +39 06 4543 3587
> mobile: +39 393 7195 164
> mail: [email protected] <mailto:[email protected]>
> web: http://www.eris4.com <http://www.eris4.com/>
> skype: eris4_munzi <skype:eris4_munzi?add>
>

------------------------------------------------------
http://restlet.tigris.org/ds/viewMessage.do?dsForumId=4447&dsMessageId=2407600

Reply via email to