Commit f902de50 authored by Guus der Kinderen's avatar Guus der Kinderen

OF-1105: Plugin servlet mapping should be case insensitive.

Although I'd rather have this case sensitive, that would break backwards compatiblity.
This way, paths with capital letters can be used at least.
parent 6f9f814c
...@@ -74,7 +74,7 @@ public class PluginServlet extends HttpServlet { ...@@ -74,7 +74,7 @@ public class PluginServlet extends HttpServlet {
private static final Logger Log = LoggerFactory.getLogger(PluginServlet.class); private static final Logger Log = LoggerFactory.getLogger(PluginServlet.class);
private static Map<String, GenericServlet> servlets; private static Map<String, GenericServlet> servlets; // mapped using lowercase path (OF-1105)
private static PluginManager pluginManager; private static PluginManager pluginManager;
private static ServletConfig servletConfig; private static ServletConfig servletConfig;
...@@ -179,7 +179,7 @@ public class PluginServlet extends HttpServlet { ...@@ -179,7 +179,7 @@ public class PluginServlet extends HttpServlet {
if (instance instanceof GenericServlet) { if (instance instanceof GenericServlet) {
// Initialize the servlet then add it to the map.. // Initialize the servlet then add it to the map..
((GenericServlet)instance).init(servletConfig); ((GenericServlet)instance).init(servletConfig);
servlets.put(pluginName + url, (GenericServlet)instance); servlets.put((pluginName + url).toLowerCase(), (GenericServlet)instance);
} }
else { else {
Log.warn("Could not load " + (pluginName + url) + ": not a servlet."); Log.warn("Could not load " + (pluginName + url) + ": not a servlet.");
...@@ -217,11 +217,11 @@ public class PluginServlet extends HttpServlet { ...@@ -217,11 +217,11 @@ public class PluginServlet extends HttpServlet {
Element nameElement = (Element)names.get(i); Element nameElement = (Element)names.get(i);
String url = nameElement.element("url-pattern").getTextTrim(); String url = nameElement.element("url-pattern").getTextTrim();
// Destroy the servlet than remove from servlets map. // Destroy the servlet than remove from servlets map.
GenericServlet servlet = servlets.get(pluginName + url); GenericServlet servlet = servlets.get((pluginName + url).toLowerCase());
if (servlet != null) { if (servlet != null) {
servlet.destroy(); servlet.destroy();
} }
servlets.remove(pluginName + url); servlets.remove((pluginName + url).toLowerCase());
servlet = null; servlet = null;
} }
} }
...@@ -251,7 +251,7 @@ public class PluginServlet extends HttpServlet { ...@@ -251,7 +251,7 @@ public class PluginServlet extends HttpServlet {
throw new ServletException("Servlet is missing"); throw new ServletException("Servlet is missing");
} }
String pluginServletUrl = pluginName + relativeUrl; String pluginServletUrl = pluginName + relativeUrl;
servlets.put(pluginName + relativeUrl, servlet); servlets.put((pluginName + relativeUrl).toLowerCase(), servlet);
return PLUGINS_WEBROOT + pluginServletUrl; return PLUGINS_WEBROOT + pluginServletUrl;
} }
...@@ -271,7 +271,7 @@ public class PluginServlet extends HttpServlet { ...@@ -271,7 +271,7 @@ public class PluginServlet extends HttpServlet {
throw new ServletException("Servlet URL is missing"); throw new ServletException("Servlet URL is missing");
} }
String fullUrl = pluginName + url; String fullUrl = pluginName + url;
GenericServlet servlet = servlets.remove(fullUrl); GenericServlet servlet = servlets.remove(fullUrl.toLowerCase());
return servlet; return servlet;
} }
...@@ -291,7 +291,7 @@ public class PluginServlet extends HttpServlet { ...@@ -291,7 +291,7 @@ public class PluginServlet extends HttpServlet {
// Strip the starting "/" from the path to find the JSP URL. // Strip the starting "/" from the path to find the JSP URL.
String jspURL = pathInfo.substring(1); String jspURL = pathInfo.substring(1);
GenericServlet servlet = servlets.get(jspURL); GenericServlet servlet = servlets.get(jspURL.toLowerCase());
if (servlet != null) { if (servlet != null) {
servlet.service(request, response); servlet.service(request, response);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment