Hello fellows,
I'm building on Google App Engine and I'll like to know how to resolve
GAE restrictions of writing to a disk. I've been able to achieve this in
1.4 but
while Migrating to 1.5.3 I'm getting the following exceptions:
[java] SEVERE: Unexpected error occurred
[java] org.apache.wicket.WicketRuntimeException: SecurityException
occurred while creating DiskDataStore. Consider using a non-disk based
IDataStore implementation. See
org.apache.wicket.Application.setPageManagerProvider(IPageManagerProvider)
[java] at
org.apache.wicket.pageStore.DiskDataStore.<init>(DiskDataStore.java:93)
[java] at
org.apache.wicket.DefaultPageManagerProvider.newDataStore(DefaultPageManagerProvider.java:83)
[java] at
org.apache.wicket.DefaultPageManagerProvider.get(DefaultPageManagerProvider.java:53)
[java] at
org.apache.wicket.DefaultPageManagerProvider.get(DefaultPageManagerProvider.java:37)
[java] at
org.apache.wicket.Application.internalGetPageManager(Application.java:1366)
[java] at
org.apache.wicket.Application.fetchCreateAndSetSession(Application.java:1523)
[java] at org.apache.wicket.Session.get(Session.java:159)
[java] at
org.apache.wicket.request.mapper.BufferedResponseMapper.getSessionId(BufferedResponseMapper.java:50)
[java] at
org.apache.wicket.request.mapper.BufferedResponseMapper.hasBufferedResponse(BufferedResponseMapper.java:55)
[java] at
org.apache.wicket.request.mapper.BufferedResponseMapper.getCompatibilityScore(BufferedResponseMapper.java:125)
[java] at
org.apache.wicket.request.mapper.CompoundRequestMapper.mapRequest(CompoundRequestMapper.java:122)
[java] at
org.apache.wicket.request.cycle.RequestCycle.resolveRequestHandler(RequestCycle.java:181)
[java] at
org.apache.wicket.request.cycle.RequestCycle.processRequest(RequestCycle.java:206)
[java] at
org.apache.wicket.request.cycle.RequestCycle.processRequestAndDetach(RequestCycle.java:280)
[java] at
org.apache.wicket.protocol.http.WicketFilter.processRequest(WicketFilter.java:162)
[java] at
org.apache.wicket.protocol.http.WicketFilter.doFilter(WicketFilter.java:218)
[java] at
org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
[java] at
com.google.appengine.tools.development.HeaderVerificationFilter.doFilter(HeaderVerificationFilter.java:35)
[java] at
org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
[java] at
com.google.appengine.api.blobstore.dev.ServeBlobFilter.doFilter(ServeBlobFilter.java:58)
[java] at
org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
[java] at
com.google.apphosting.utils.servlet.TransactionCleanupFilter.doFilter(TransactionCleanupFilter.java:43)
[java] at
org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
[java] at
com.google.appengine.tools.development.StaticFileFilter.doFilter(StaticFileFilter.java:122)
[java] at
org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
[java] at
com.google.appengine.tools.development.BackendServersFilter.doFilter(BackendServersFilter.java:94)
[java] at
org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
[java] at
org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:388)
[java] at
org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
[java] at
org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:182)
[java] at
org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:765)
[java] at
org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:418)
[java] at
com.google.apphosting.utils.jetty.DevAppEngineWebAppContext.handle(DevAppEngineWebAppContext.java:70)
[java] at
org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
[java] at
com.google.appengine.tools.development.JettyContainerService$ApiProxyHandler.handle(JettyContainerService.java:351)
[java] at
org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
[java] at org.mortbay.jetty.Server.handle(Server.java:326)
[java] at
org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:542)
[java] at
org.mortbay.jetty.HttpConnection$RequestHandler.headerComplete(HttpConnection.java:923)
[java] at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:547)
[java] at
org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:212)
[java] at
org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:404)
[java] at
org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:409)
[java] at
org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:582)
[java] Caused by: java.security.AccessControlException: access denied
(java.io.FilePermission
C:\DOCUME~1\ADMINI~1\LOCALS~1\Temp\Jetty_localhost_8888_web____.g0v3xf read)
[java] at
java.security.AccessControlContext.checkPermission(AccessControlContext.java:374)
[java] at
java.security.AccessController.checkPermission(AccessController.java:546)
[java] at
java.lang.SecurityManager.checkPermission(SecurityManager.java:532)
[java] at
com.google.appengine.tools.development.DevAppServerFactory$CustomSecurityManager.checkPermission(DevAppServerFactory.java:166)
[java] at java.lang.SecurityManager.checkRead(SecurityManager.java:871)
[java] at java.io.File.exists(File.java:731)
[java] at
org.apache.wicket.pageStore.DiskDataStore.<init>(DiskDataStore.java:82)
[java] ... 43 more
[java] Jan 20, 2012 11:57:56 AM
org.apache.wicket.DefaultExceptionMapper map
I will like to know, what do I need to override and configure to get passed
this.
Thanks
--
Odeyemi 'Kayode O.
http://www.sinati.com. t: @charyorde