mirror of https://github.com/apache/lucene.git
SOLR-9662: New parameter -u <user:pass> in bin/post to pass basicauth credentials
This commit is contained in:
parent
c9cf0eff03
commit
e3a8a0fe5f
|
@ -152,6 +152,8 @@ New Features
|
||||||
* SOLR-9326: Ability to create/delete/list snapshots at collection level.
|
* SOLR-9326: Ability to create/delete/list snapshots at collection level.
|
||||||
(Hrishikesh Gadre via yonik)
|
(Hrishikesh Gadre via yonik)
|
||||||
|
|
||||||
|
* SOLR-9662: New parameter -u <user:pass> in bin/post to pass basicauth credentials (janhoy)
|
||||||
|
|
||||||
Bug Fixes
|
Bug Fixes
|
||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
|
|
|
@ -68,6 +68,7 @@ function print_usage() {
|
||||||
echo " -host <host> (default: localhost)"
|
echo " -host <host> (default: localhost)"
|
||||||
echo " -p or -port <port> (default: 8983)"
|
echo " -p or -port <port> (default: 8983)"
|
||||||
echo " -commit yes|no (default: yes)"
|
echo " -commit yes|no (default: yes)"
|
||||||
|
echo " -u or -user <user:pass> (sets BasicAuth credentials)"
|
||||||
# optimize intentionally omitted, but can be used as '-optimize yes' (default: no)
|
# optimize intentionally omitted, but can be used as '-optimize yes' (default: no)
|
||||||
echo ""
|
echo ""
|
||||||
echo " Web crawl options:"
|
echo " Web crawl options:"
|
||||||
|
@ -155,6 +156,15 @@ while [ $# -gt 0 ]; do
|
||||||
ARGS+=("<add/>")
|
ARGS+=("<add/>")
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
elif [[ ("$1" == "-u" || "$1" == "-user") ]]; then
|
||||||
|
shift
|
||||||
|
PROPS+=("-Dbasicauth=$1")
|
||||||
|
else
|
||||||
|
if [[ "$1" == -D* ]] ; then
|
||||||
|
PROPS+=("$1")
|
||||||
|
if [[ "${1:2:4}" == "url=" ]]; then
|
||||||
|
SOLR_URL=${1:6}
|
||||||
|
fi
|
||||||
else
|
else
|
||||||
key="${1:1}"
|
key="${1:1}"
|
||||||
shift
|
shift
|
||||||
|
@ -164,6 +174,7 @@ while [ $# -gt 0 ]; do
|
||||||
SOLR_URL=$1
|
SOLR_URL=$1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
else
|
else
|
||||||
echo -e "\nUnrecognized argument: $1\n"
|
echo -e "\nUnrecognized argument: $1\n"
|
||||||
echo -e "If this was intended to be a data file, it does not exist relative to $PWD\n"
|
echo -e "If this was intended to be a data file, it does not exist relative to $PWD\n"
|
||||||
|
|
|
@ -42,6 +42,7 @@ import java.nio.BufferOverflowException;
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
import java.nio.charset.Charset;
|
import java.nio.charset.Charset;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.security.GeneralSecurityException;
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Base64;
|
import java.util.Base64;
|
||||||
|
@ -65,6 +66,9 @@ import org.w3c.dom.Node;
|
||||||
import org.w3c.dom.NodeList;
|
import org.w3c.dom.NodeList;
|
||||||
import org.xml.sax.SAXException;
|
import org.xml.sax.SAXException;
|
||||||
|
|
||||||
|
import static java.nio.charset.StandardCharsets.US_ASCII;
|
||||||
|
import static java.nio.charset.StandardCharsets.UTF_8;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A simple utility class for posting raw updates to a Solr server,
|
* A simple utility class for posting raw updates to a Solr server,
|
||||||
* has a main method so it can be run on the command line.
|
* has a main method so it can be run on the command line.
|
||||||
|
@ -86,6 +90,7 @@ public class SimplePostTool {
|
||||||
private static final int MAX_WEB_DEPTH = 10;
|
private static final int MAX_WEB_DEPTH = 10;
|
||||||
private static final String DEFAULT_CONTENT_TYPE = "application/xml";
|
private static final String DEFAULT_CONTENT_TYPE = "application/xml";
|
||||||
private static final String DEFAULT_FILE_TYPES = "xml,json,jsonl,csv,pdf,doc,docx,ppt,pptx,xls,xlsx,odt,odp,ods,ott,otp,ots,rtf,htm,html,txt,log";
|
private static final String DEFAULT_FILE_TYPES = "xml,json,jsonl,csv,pdf,doc,docx,ppt,pptx,xls,xlsx,odt,odp,ods,ott,otp,ots,rtf,htm,html,txt,log";
|
||||||
|
private static final String BASIC_AUTH = "basicauth";
|
||||||
|
|
||||||
static final String DATA_MODE_FILES = "files";
|
static final String DATA_MODE_FILES = "files";
|
||||||
static final String DATA_MODE_ARGS = "args";
|
static final String DATA_MODE_ARGS = "args";
|
||||||
|
@ -233,6 +238,15 @@ public class SimplePostTool {
|
||||||
}
|
}
|
||||||
urlStr = SimplePostTool.appendParam(urlStr, params);
|
urlStr = SimplePostTool.appendParam(urlStr, params);
|
||||||
URL url = new URL(urlStr);
|
URL url = new URL(urlStr);
|
||||||
|
String user = null;
|
||||||
|
if (url.getUserInfo() != null && url.getUserInfo().trim().length() > 0) {
|
||||||
|
user = url.getUserInfo().split(":")[0];
|
||||||
|
} else if (System.getProperty(BASIC_AUTH) != null) {
|
||||||
|
user = System.getProperty(BASIC_AUTH).trim().split(":")[0];
|
||||||
|
}
|
||||||
|
if (user != null)
|
||||||
|
info("Basic Authentication enabled, user=" + user);
|
||||||
|
|
||||||
boolean auto = isOn(System.getProperty("auto", DEFAULT_AUTO));
|
boolean auto = isOn(System.getProperty("auto", DEFAULT_AUTO));
|
||||||
String type = System.getProperty("type");
|
String type = System.getProperty("type");
|
||||||
String format = System.getProperty("format");
|
String format = System.getProperty("format");
|
||||||
|
@ -385,6 +399,7 @@ public class SimplePostTool {
|
||||||
" -Dtype=<content-type> (default=" + DEFAULT_CONTENT_TYPE + ")\n"+
|
" -Dtype=<content-type> (default=" + DEFAULT_CONTENT_TYPE + ")\n"+
|
||||||
" -Dhost=<host> (default: " + DEFAULT_POST_HOST+ ")\n"+
|
" -Dhost=<host> (default: " + DEFAULT_POST_HOST+ ")\n"+
|
||||||
" -Dport=<port> (default: " + DEFAULT_POST_PORT+ ")\n"+
|
" -Dport=<port> (default: " + DEFAULT_POST_PORT+ ")\n"+
|
||||||
|
" -Dbasicauth=<user:pass> (sets Basic Authentication credentials)\n"+
|
||||||
" -Dauto=yes|no (default=" + DEFAULT_AUTO + ")\n"+
|
" -Dauto=yes|no (default=" + DEFAULT_AUTO + ")\n"+
|
||||||
" -Drecursive=yes|no|<depth> (default=" + DEFAULT_RECURSIVE + ")\n"+
|
" -Drecursive=yes|no|<depth> (default=" + DEFAULT_RECURSIVE + ")\n"+
|
||||||
" -Ddelay=<seconds> (default=0 for files, 10 for web)\n"+
|
" -Ddelay=<seconds> (default=0 for files, 10 for web)\n"+
|
||||||
|
@ -851,14 +866,13 @@ public class SimplePostTool {
|
||||||
try {
|
try {
|
||||||
if(mockMode) return;
|
if(mockMode) return;
|
||||||
HttpURLConnection urlc = (HttpURLConnection) url.openConnection();
|
HttpURLConnection urlc = (HttpURLConnection) url.openConnection();
|
||||||
if (url.getUserInfo() != null) {
|
basicAuth(urlc);
|
||||||
String encoding = Base64.getEncoder().encodeToString(url.getUserInfo().getBytes(StandardCharsets.US_ASCII));
|
|
||||||
urlc.setRequestProperty("Authorization", "Basic " + encoding);
|
|
||||||
}
|
|
||||||
urlc.connect();
|
urlc.connect();
|
||||||
checkResponseCode(urlc);
|
checkResponseCode(urlc);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
warn("An error occurred posting data to "+url+". Please check that Solr is running.");
|
warn("An error occurred getting data from "+url+". Please check that Solr is running.");
|
||||||
|
} catch (Exception e) {
|
||||||
|
warn("An error occurred getting data from "+url+". Message: " + e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -886,10 +900,7 @@ public class SimplePostTool {
|
||||||
urlc.setUseCaches(false);
|
urlc.setUseCaches(false);
|
||||||
urlc.setAllowUserInteraction(false);
|
urlc.setAllowUserInteraction(false);
|
||||||
urlc.setRequestProperty("Content-type", type);
|
urlc.setRequestProperty("Content-type", type);
|
||||||
if (url.getUserInfo() != null) {
|
basicAuth(urlc);
|
||||||
String encoding = Base64.getEncoder().encodeToString(url.getUserInfo().getBytes(StandardCharsets.US_ASCII));
|
|
||||||
urlc.setRequestProperty("Authorization", "Basic " + encoding);
|
|
||||||
}
|
|
||||||
if (null != length) {
|
if (null != length) {
|
||||||
urlc.setFixedLengthStreamingMode(length);
|
urlc.setFixedLengthStreamingMode(length);
|
||||||
} else {
|
} else {
|
||||||
|
@ -899,13 +910,14 @@ public class SimplePostTool {
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
fatal("Connection error (is Solr running at " + solrUrl + " ?): " + e);
|
fatal("Connection error (is Solr running at " + solrUrl + " ?): " + e);
|
||||||
success = false;
|
success = false;
|
||||||
|
} catch (Exception e) {
|
||||||
|
fatal("POST failed with error " + e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
try (final OutputStream out = urlc.getOutputStream()) {
|
try (final OutputStream out = urlc.getOutputStream()) {
|
||||||
pipe(data, out);
|
pipe(data, out);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
fatal("IOException while posting data: " + e);
|
fatal("IOException while posting data: " + e);
|
||||||
success = false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
@ -916,6 +928,8 @@ public class SimplePostTool {
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
warn("IOException while reading response: " + e);
|
warn("IOException while reading response: " + e);
|
||||||
success = false;
|
success = false;
|
||||||
|
} catch (GeneralSecurityException e) {
|
||||||
|
fatal("Looks like Solr is secured and would not let us in. Try with another user in '-u' parameter");
|
||||||
}
|
}
|
||||||
} finally {
|
} finally {
|
||||||
if (urlc!=null) urlc.disconnect();
|
if (urlc!=null) urlc.disconnect();
|
||||||
|
@ -923,7 +937,20 @@ public class SimplePostTool {
|
||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static boolean checkResponseCode(HttpURLConnection urlc) throws IOException {
|
private static void basicAuth(HttpURLConnection urlc) throws Exception {
|
||||||
|
if (urlc.getURL().getUserInfo() != null) {
|
||||||
|
String encoding = Base64.getEncoder().encodeToString(urlc.getURL().getUserInfo().getBytes(US_ASCII));
|
||||||
|
urlc.setRequestProperty("Authorization", "Basic " + encoding);
|
||||||
|
} else if (System.getProperty(BASIC_AUTH) != null) {
|
||||||
|
String basicauth = System.getProperty(BASIC_AUTH).trim();
|
||||||
|
if (!basicauth.contains(":")) {
|
||||||
|
throw new Exception("System property '"+BASIC_AUTH+"' must be of format user:pass");
|
||||||
|
}
|
||||||
|
urlc.setRequestProperty("Authorization", "Basic " + Base64.getEncoder().encodeToString(basicauth.getBytes(UTF_8)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static boolean checkResponseCode(HttpURLConnection urlc) throws IOException, GeneralSecurityException {
|
||||||
if (urlc.getResponseCode() >= 400) {
|
if (urlc.getResponseCode() >= 400) {
|
||||||
warn("Solr returned an error #" + urlc.getResponseCode() +
|
warn("Solr returned an error #" + urlc.getResponseCode() +
|
||||||
" (" + urlc.getResponseMessage() + ") for url: " + urlc.getURL());
|
" (" + urlc.getResponseMessage() + ") for url: " + urlc.getURL());
|
||||||
|
@ -948,6 +975,12 @@ public class SimplePostTool {
|
||||||
warn(response.toString().trim());
|
warn(response.toString().trim());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (urlc.getResponseCode() == 401) {
|
||||||
|
throw new GeneralSecurityException("Solr requires authentication (response 401). Please try again with '-u' option");
|
||||||
|
}
|
||||||
|
if (urlc.getResponseCode() == 403) {
|
||||||
|
throw new GeneralSecurityException("You are not authorized to perform this action against Solr. (response 403)");
|
||||||
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
|
Loading…
Reference in New Issue