make sure that servlet configurations are injected even upon reloading the servlet context

git-svn-id: http://google-refine.googlecode.com/svn/trunk@929 7d457c2a-affb-35e4-300a-418c747d4874
This commit is contained in:
Stefano Mazzocchi 2010-06-01 08:02:16 +00:00
parent ba2d94cc63
commit 6dbab84ba6

View File

@ -150,8 +150,6 @@ class GridworksServer extends Server {
logger.info("Initializing context: '" + contextPath + "' from '" + webapp.getAbsolutePath() + "'");
WebAppContext context = new WebAppContext(webapp.getAbsolutePath(), contextPath);
context.setMaxFormContentSize(1048576);
//context.setCopyWebDir(false);
//context.setDefaultsDescriptor(null);
this.setHandler(context);
this.setStopAtShutdown(true);
@ -165,12 +163,7 @@ class GridworksServer extends Server {
// start the server
this.start();
// inject configuration parameters in the servlets
// NOTE: this is done *after* starting the server because jetty might override the init
// parameters if we set them in the webapp context upon reading the web.xml file
ServletHolder servlet = context.getServletHandler().getServlet("gridworks");
servlet.setInitParameter("gridworks.data", getDataDir());
servlet.doStart();
configure(context);
}
@Override
@ -215,6 +208,8 @@ class GridworksServer extends Server {
logger.info("Starting context: " + contextRoot.getAbsolutePath());
context.start();
configure(context);
} catch (Exception ex) {
throw new RuntimeException(ex);
}
@ -237,6 +232,15 @@ class GridworksServer extends Server {
});
}
// inject configuration parameters in the servlets
// NOTE: this is done *after* starting the server because jetty might override the init
// parameters if we set them in the webapp context upon reading the web.xml file
static private void configure(WebAppContext context) throws Exception {
ServletHolder servlet = context.getServletHandler().getServlet("gridworks");
servlet.setInitParameter("gridworks.data", getDataDir());
servlet.doStart();
}
static private String getDataDir() {
String data_dir = Configurations.get("gridworks.data_dir");