mirror of https://github.com/apache/lucene.git
SOLR-13941: Configure JettySolrRunner same as in web.xml (#1018)
(cherry picked from commit f00bcd5609
)
This commit is contained in:
parent
cebd6eddd2
commit
58d5680a90
|
@ -105,6 +105,8 @@ Bug Fixes
|
||||||
|
|
||||||
* SOLR-13921: Processing UpdateRequest with delegation token throws NullPointerException (Istvan Farkas via Kevin Risden)
|
* SOLR-13921: Processing UpdateRequest with delegation token throws NullPointerException (Istvan Farkas via Kevin Risden)
|
||||||
|
|
||||||
|
* SOLR-13941: Tests configure Jetty differently than when running via start.jar (janhoy, Uwe Schindler)
|
||||||
|
|
||||||
Other Changes
|
Other Changes
|
||||||
---------------------
|
---------------------
|
||||||
|
|
||||||
|
|
|
@ -16,6 +16,16 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.solr.client.solrj.embedded;
|
package org.apache.solr.client.solrj.embedded;
|
||||||
|
|
||||||
|
import javax.servlet.DispatcherType;
|
||||||
|
import javax.servlet.Filter;
|
||||||
|
import javax.servlet.FilterChain;
|
||||||
|
import javax.servlet.FilterConfig;
|
||||||
|
import javax.servlet.ServletException;
|
||||||
|
import javax.servlet.ServletRequest;
|
||||||
|
import javax.servlet.ServletResponse;
|
||||||
|
import javax.servlet.http.HttpServlet;
|
||||||
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.lang.invoke.MethodHandles;
|
import java.lang.invoke.MethodHandles;
|
||||||
import java.net.BindException;
|
import java.net.BindException;
|
||||||
|
@ -34,17 +44,6 @@ import java.util.concurrent.TimeUnit;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
import java.util.concurrent.atomic.AtomicLong;
|
import java.util.concurrent.atomic.AtomicLong;
|
||||||
|
|
||||||
import javax.servlet.DispatcherType;
|
|
||||||
import javax.servlet.Filter;
|
|
||||||
import javax.servlet.FilterChain;
|
|
||||||
import javax.servlet.FilterConfig;
|
|
||||||
import javax.servlet.ServletException;
|
|
||||||
import javax.servlet.ServletRequest;
|
|
||||||
import javax.servlet.ServletResponse;
|
|
||||||
import javax.servlet.http.HttpServlet;
|
|
||||||
import javax.servlet.http.HttpServletRequest;
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
|
|
||||||
import org.apache.lucene.util.Constants;
|
import org.apache.lucene.util.Constants;
|
||||||
import org.apache.solr.client.solrj.SolrClient;
|
import org.apache.solr.client.solrj.SolrClient;
|
||||||
import org.apache.solr.client.solrj.cloud.SocketProxy;
|
import org.apache.solr.client.solrj.cloud.SocketProxy;
|
||||||
|
@ -112,7 +111,7 @@ public class JettySolrRunner {
|
||||||
|
|
||||||
private LinkedList<FilterHolder> extraFilters;
|
private LinkedList<FilterHolder> extraFilters;
|
||||||
|
|
||||||
private static final String excludePatterns = "/css/.+,/js/.+,/img/.+,/tpl/.+";
|
private static final String excludePatterns = "/partials/.+,/libs/.+,/css/.+,/js/.+,/img/.+,/templates/.+";
|
||||||
|
|
||||||
private int proxyPort = -1;
|
private int proxyPort = -1;
|
||||||
|
|
||||||
|
@ -369,7 +368,7 @@ public class JettySolrRunner {
|
||||||
|
|
||||||
log.info("Jetty properties: {}", nodeProperties);
|
log.info("Jetty properties: {}", nodeProperties);
|
||||||
|
|
||||||
debugFilter = root.addFilter(DebugFilter.class, "*", EnumSet.of(DispatcherType.REQUEST) );
|
debugFilter = root.addFilter(DebugFilter.class, "/*", EnumSet.of(DispatcherType.REQUEST) );
|
||||||
extraFilters = new LinkedList<>();
|
extraFilters = new LinkedList<>();
|
||||||
for (Map.Entry<Class<? extends Filter>, String> entry : config.extraFilters.entrySet()) {
|
for (Map.Entry<Class<? extends Filter>, String> entry : config.extraFilters.entrySet()) {
|
||||||
extraFilters.add(root.addFilter(entry.getKey(), entry.getValue(), EnumSet.of(DispatcherType.REQUEST)));
|
extraFilters.add(root.addFilter(entry.getKey(), entry.getValue(), EnumSet.of(DispatcherType.REQUEST)));
|
||||||
|
@ -381,7 +380,8 @@ public class JettySolrRunner {
|
||||||
dispatchFilter = root.getServletHandler().newFilterHolder(Source.EMBEDDED);
|
dispatchFilter = root.getServletHandler().newFilterHolder(Source.EMBEDDED);
|
||||||
dispatchFilter.setHeldClass(SolrDispatchFilter.class);
|
dispatchFilter.setHeldClass(SolrDispatchFilter.class);
|
||||||
dispatchFilter.setInitParameter("excludePatterns", excludePatterns);
|
dispatchFilter.setInitParameter("excludePatterns", excludePatterns);
|
||||||
root.addFilter(dispatchFilter, "*", EnumSet.of(DispatcherType.REQUEST));
|
// Map dispatchFilter in same path as in web.xml
|
||||||
|
root.addFilter(dispatchFilter, "/*", EnumSet.of(DispatcherType.REQUEST));
|
||||||
|
|
||||||
synchronized (JettySolrRunner.this) {
|
synchronized (JettySolrRunner.this) {
|
||||||
waitOnSolr = true;
|
waitOnSolr = true;
|
||||||
|
@ -394,8 +394,8 @@ public class JettySolrRunner {
|
||||||
System.clearProperty("hostPort");
|
System.clearProperty("hostPort");
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
// for some reason, there must be a servlet for this to get applied
|
// Default servlet as a fall-through
|
||||||
root.addServlet(Servlet404.class, "/*");
|
root.addServlet(Servlet404.class, "/");
|
||||||
chain = root;
|
chain = root;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -31,6 +31,7 @@ import java.util.stream.Collectors;
|
||||||
|
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
import org.apache.solr.common.cloud.ZkStateReader;
|
import org.apache.solr.common.cloud.ZkStateReader;
|
||||||
|
import org.apache.solr.servlet.ServletUtils;
|
||||||
import org.apache.solr.servlet.SolrRequestParsers;
|
import org.apache.solr.servlet.SolrRequestParsers;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
@ -130,7 +131,7 @@ public class AuditEvent {
|
||||||
this.solrPort = httpRequest.getLocalPort();
|
this.solrPort = httpRequest.getLocalPort();
|
||||||
this.solrIp = httpRequest.getLocalAddr();
|
this.solrIp = httpRequest.getLocalAddr();
|
||||||
this.clientIp = httpRequest.getRemoteAddr();
|
this.clientIp = httpRequest.getRemoteAddr();
|
||||||
this.resource = httpRequest.getPathInfo();
|
this.resource = ServletUtils.getPathAfterContext(httpRequest);
|
||||||
this.httpMethod = httpRequest.getMethod();
|
this.httpMethod = httpRequest.getMethod();
|
||||||
this.httpQueryString = httpRequest.getQueryString();
|
this.httpQueryString = httpRequest.getQueryString();
|
||||||
this.headers = getHeadersFromRequest(httpRequest);
|
this.headers = getHeadersFromRequest(httpRequest);
|
||||||
|
|
|
@ -192,11 +192,7 @@ public class HttpSolrCall {
|
||||||
req.setAttribute(SolrRequestParsers.REQUEST_TIMER_SERVLET_ATTRIBUTE, new RTimerTree());
|
req.setAttribute(SolrRequestParsers.REQUEST_TIMER_SERVLET_ATTRIBUTE, new RTimerTree());
|
||||||
// put the core container in request attribute
|
// put the core container in request attribute
|
||||||
req.setAttribute("org.apache.solr.CoreContainer", cores);
|
req.setAttribute("org.apache.solr.CoreContainer", cores);
|
||||||
path = req.getServletPath();
|
path = ServletUtils.getPathAfterContext(req);
|
||||||
if (req.getPathInfo() != null) {
|
|
||||||
// this lets you handle /update/commit when /update is a servlet
|
|
||||||
path += req.getPathInfo();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getPath() {
|
public String getPath() {
|
||||||
|
|
|
@ -0,0 +1,37 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.solr.servlet;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Various Util methods for interaction on servlet level, i.e. HttpServletRequest
|
||||||
|
*/
|
||||||
|
public abstract class ServletUtils {
|
||||||
|
private ServletUtils() { /* only static methods in this class */ }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Use this to get the full path after context path "/solr", which is a combination of
|
||||||
|
* servletPath and pathInfo.
|
||||||
|
* @param request the HttpServletRequest object
|
||||||
|
* @return String with path starting with a "/", or empty string if no path
|
||||||
|
*/
|
||||||
|
public static String getPathAfterContext(HttpServletRequest request) {
|
||||||
|
return request.getServletPath() + (request.getPathInfo() != null ? request.getPathInfo() : "");
|
||||||
|
}
|
||||||
|
}
|
|
@ -371,14 +371,9 @@ public class SolrDispatchFilter extends BaseSolrFilter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
String requestPath = request.getServletPath();
|
String requestPath = ServletUtils.getPathAfterContext(request);
|
||||||
// No need to even create the HttpSolrCall object if this path is excluded.
|
// No need to even create the HttpSolrCall object if this path is excluded.
|
||||||
if (excludePatterns != null) {
|
if (excludePatterns != null) {
|
||||||
String extraPath = request.getPathInfo();
|
|
||||||
if (extraPath != null) {
|
|
||||||
// In embedded mode, servlet path is empty - include all post-context path here for testing
|
|
||||||
requestPath += extraPath;
|
|
||||||
}
|
|
||||||
for (Pattern p : excludePatterns) {
|
for (Pattern p : excludePatterns) {
|
||||||
Matcher matcher = p.matcher(requestPath);
|
Matcher matcher = p.matcher(requestPath);
|
||||||
if (matcher.lookingAt()) {
|
if (matcher.lookingAt()) {
|
||||||
|
@ -468,11 +463,7 @@ public class SolrDispatchFilter extends BaseSolrFilter {
|
||||||
* want to add attributes to the request and send errors differently
|
* want to add attributes to the request and send errors differently
|
||||||
*/
|
*/
|
||||||
protected HttpSolrCall getHttpSolrCall(HttpServletRequest request, HttpServletResponse response, boolean retry) {
|
protected HttpSolrCall getHttpSolrCall(HttpServletRequest request, HttpServletResponse response, boolean retry) {
|
||||||
String path = request.getServletPath();
|
String path = ServletUtils.getPathAfterContext(request);
|
||||||
if (request.getPathInfo() != null) {
|
|
||||||
// this lets you handle /update/commit when /update is a servlet
|
|
||||||
path += request.getPathInfo();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isV2Enabled && (path.startsWith("/____v2/") || path.equals("/____v2"))) {
|
if (isV2Enabled && (path.startsWith("/____v2/") || path.equals("/____v2"))) {
|
||||||
return new V2HttpCall(this, cores, request, response, false);
|
return new V2HttpCall(this, cores, request, response, false);
|
||||||
|
@ -492,11 +483,7 @@ public class SolrDispatchFilter extends BaseSolrFilter {
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
// /admin/info/key must be always open. see SOLR-9188
|
// /admin/info/key must be always open. see SOLR-9188
|
||||||
// tests work only w/ getPathInfo
|
String requestPath = ServletUtils.getPathAfterContext(request);
|
||||||
//otherwise it's just enough to have getServletPath()
|
|
||||||
String requestPath = request.getPathInfo();
|
|
||||||
if (requestPath == null)
|
|
||||||
requestPath = request.getServletPath();
|
|
||||||
if (PublicKeyHandler.PATH.equals(requestPath)) {
|
if (PublicKeyHandler.PATH.equals(requestPath)) {
|
||||||
if (log.isDebugEnabled())
|
if (log.isDebugEnabled())
|
||||||
log.debug("Pass through PKI authentication endpoint");
|
log.debug("Pass through PKI authentication endpoint");
|
||||||
|
|
|
@ -346,7 +346,7 @@ public class CoreAdminHandlerTest extends SolrTestCaseJ4 {
|
||||||
runner.stop();
|
runner.stop();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
assertTrue(rse.getMessage().contains("Can not find: /solr/corex/select"));
|
assertTrue(rse.getMessage(), rse.getMessage().contains("Problem accessing /solr/corex/select"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
Loading…
Reference in New Issue