Merge pull request #2563 from eclipse/jetty-9.4.x-issue-2556-jettybase-file-scheme

Issue #2556 - bad "file:" scheme present in Xml usage of "jetty.base" and "jetty.home" properties
This commit is contained in:
Joakim Erdfelt 2018-06-04 13:39:52 -05:00 committed by GitHub
commit d54da40f8f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 78 additions and 20 deletions

View File

@ -31,6 +31,8 @@ import java.net.InetAddress;
import java.net.MalformedURLException; import java.net.MalformedURLException;
import java.net.URL; import java.net.URL;
import java.net.UnknownHostException; import java.net.UnknownHostException;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.security.AccessController; import java.security.AccessController;
import java.security.PrivilegedExceptionAction; import java.security.PrivilegedExceptionAction;
import java.util.ArrayList; import java.util.ArrayList;
@ -134,20 +136,21 @@ public class XmlConfiguration
{ {
if (server!=null) if (server!=null)
getIdMap().put("Server", server); getIdMap().put("Server", server);
Resource home = Resource.newResource(System.getProperty("jetty.home","."));
getProperties().put("jetty.home",home.toString());
getProperties().put("jetty.home.uri",normalizeURI(home.getURI().toString()));
Resource base = Resource.newResource(System.getProperty("jetty.base",home.toString())); Path home = Paths.get(System.getProperty("jetty.home", "."));
getProperties().put("jetty.home",home.toString());
getProperties().put("jetty.home.uri",normalizeURI(home.toUri().toASCIIString()));
Path base = Paths.get(System.getProperty("jetty.base", home.toString()));
getProperties().put("jetty.base",base.toString()); getProperties().put("jetty.base",base.toString());
getProperties().put("jetty.base.uri",normalizeURI(base.getURI().toString())); getProperties().put("jetty.base.uri",normalizeURI(base.toUri().toASCIIString()));
if (webapp!=null) if (webapp!=null)
{ {
getProperties().put("jetty.webapp",webapp.toString()); Path webappPath = webapp.getFile().toPath().toAbsolutePath();
getProperties().put("jetty.webapps",webapp.getFile().toPath().getParent().toString()); getProperties().put("jetty.webapp", webappPath.toString());
getProperties().put("jetty.webapps.uri",normalizeURI(webapp.getURI().toString())); getProperties().put("jetty.webapps", webappPath.getParent().toString());
getProperties().put("jetty.webapps.uri", normalizeURI(webapp.getURI().toString()));
} }
} }
catch(Exception e) catch(Exception e)

View File

@ -18,28 +18,27 @@
package org.eclipse.jetty.xml; package org.eclipse.jetty.xml;
import static org.hamcrest.CoreMatchers.is;
import static org.hamcrest.CoreMatchers.not;
import static org.hamcrest.CoreMatchers.notNullValue;
import static org.hamcrest.CoreMatchers.nullValue;
import static org.hamcrest.CoreMatchers.startsWith;
import static org.hamcrest.Matchers.containsString;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertThat;
import static org.junit.Assert.assertTrue;
import java.io.ByteArrayInputStream; import java.io.ByteArrayInputStream;
import java.net.URL; import java.net.URL;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.Properties;
import java.util.concurrent.atomic.AtomicInteger; import java.util.concurrent.atomic.AtomicInteger;
import org.eclipse.jetty.util.log.Log;
import org.hamcrest.Matchers;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Ignore; import org.junit.Ignore;
import org.junit.Test; import org.junit.Test;
import static org.hamcrest.CoreMatchers.is;
import static org.hamcrest.CoreMatchers.not;
import static org.hamcrest.CoreMatchers.nullValue;
import static org.hamcrest.Matchers.containsString;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertThat;
import static org.junit.Assert.assertTrue;
public class XmlConfigurationTest public class XmlConfigurationTest
{ {
protected String[] _configure=new String [] {"org/eclipse/jetty/xml/configureWithAttr.xml","org/eclipse/jetty/xml/configureWithElements.xml"}; protected String[] _configure=new String [] {"org/eclipse/jetty/xml/configureWithAttr.xml","org/eclipse/jetty/xml/configureWithElements.xml"};
@ -937,4 +936,60 @@ public class XmlConfigurationTest
DefaultTestConfiguration config = (DefaultTestConfiguration)xmlConfiguration.configure(); DefaultTestConfiguration config = (DefaultTestConfiguration)xmlConfiguration.configure();
assertEquals(value, config.getFirst()); assertEquals(value, config.getFirst());
} }
@Test
public void testJettyStandardIdsAndProperties_JettyHome_JettyBase() throws Exception
{
String propNames[] = new String[] {
"jetty.base",
"jetty.home"
};
for(String propName: propNames)
{
XmlConfiguration configuration =
new XmlConfiguration("" +
"<Configure class=\"org.eclipse.jetty.xml.TestConfiguration\">" +
" <Set name=\"TestString\">" +
" <Property name=\"" + propName + "\"/>" +
" </Set>" +
"</Configure>");
configuration.setJettyStandardIdsAndProperties(null, null);
TestConfiguration tc = new TestConfiguration();
configuration.configure(tc);
assertThat(propName, tc.getTestString(), is(notNullValue()));
assertThat(propName, tc.getTestString(), not(startsWith("file:")));
}
}
@Test
public void testJettyStandardIdsAndProperties_JettyHomeUri_JettyBaseUri() throws Exception
{
String propNames[] = new String[] {
"jetty.base.uri",
"jetty.home.uri"
};
for(String propName: propNames)
{
XmlConfiguration configuration =
new XmlConfiguration("" +
"<Configure class=\"org.eclipse.jetty.xml.TestConfiguration\">" +
" <Set name=\"TestString\">" +
" <Property name=\"" + propName + "\"/>" +
" </Set>" +
"</Configure>");
configuration.setJettyStandardIdsAndProperties(null, null);
TestConfiguration tc = new TestConfiguration();
configuration.configure(tc);
assertThat(propName, tc.getTestString(), is(notNullValue()));
assertThat(propName, tc.getTestString(), startsWith("file:"));
}
}
} }