mirror of https://github.com/apache/lucene.git
SOLR-8765: Fix CollectionAdminRequest.SplitShard to accept requests without the 'shard' parameter
This commit is contained in:
parent
8fe11a06ce
commit
bc41158648
|
@ -454,7 +454,7 @@ public class CollectionsHandler extends RequestHandlerBase {
|
|||
String splitKey = req.getParams().get("split.key");
|
||||
|
||||
if (splitKey == null && shard == null) {
|
||||
throw new SolrException(ErrorCode.BAD_REQUEST, "Missing required parameter: shard");
|
||||
throw new SolrException(ErrorCode.BAD_REQUEST, "At least one of shard, or split.key should be specified.");
|
||||
}
|
||||
if (splitKey != null && shard != null) {
|
||||
throw new SolrException(ErrorCode.BAD_REQUEST,
|
||||
|
|
|
@ -616,27 +616,30 @@ public abstract class CollectionAdminRequest<T extends CollectionAdminResponse>
|
|||
/**
|
||||
* Returns a SolrRequest to split a shard in a collection
|
||||
*/
|
||||
public static SplitShard splitShard(String collection, String shard) {
|
||||
return new SplitShard(collection, shard);
|
||||
public static SplitShard splitShard(String collection) {
|
||||
return new SplitShard(collection);
|
||||
}
|
||||
|
||||
// SPLITSHARD request
|
||||
public static class SplitShard extends AsyncShardSpecificAdminRequest {
|
||||
public static class SplitShard extends AsyncCollectionAdminRequest {
|
||||
protected String collection;
|
||||
protected String ranges;
|
||||
protected String splitKey;
|
||||
protected String shard;
|
||||
|
||||
private Properties properties;
|
||||
|
||||
private SplitShard(String collection, String shard) {
|
||||
super(CollectionAction.SPLITSHARD, collection, shard);
|
||||
private SplitShard(String collection) {
|
||||
super(CollectionAction.SPLITSHARD);
|
||||
this.collection = collection;
|
||||
}
|
||||
|
||||
/**
|
||||
* @deprecated Use {@link #splitShard(String, String)}
|
||||
* @deprecated Use {@link #splitShard(String)}
|
||||
*/
|
||||
@Deprecated
|
||||
public SplitShard() {
|
||||
super(CollectionAction.SPLITSHARD, null, null);
|
||||
super(CollectionAction.SPLITSHARD);
|
||||
}
|
||||
|
||||
public SplitShard setRanges(String ranges) { this.ranges = ranges; return this; }
|
||||
|
@ -660,15 +663,12 @@ public abstract class CollectionAdminRequest<T extends CollectionAdminResponse>
|
|||
return this;
|
||||
}
|
||||
|
||||
@Override
|
||||
@Deprecated
|
||||
public SplitShard setCollectionName(String collection) {
|
||||
this.collection = collection;
|
||||
return this;
|
||||
}
|
||||
|
||||
@Override
|
||||
@Deprecated
|
||||
public SplitShard setShardName(String shard) {
|
||||
this.shard = shard;
|
||||
return this;
|
||||
|
@ -684,10 +684,20 @@ public abstract class CollectionAdminRequest<T extends CollectionAdminResponse>
|
|||
@Override
|
||||
public SolrParams getParams() {
|
||||
ModifiableSolrParams params = (ModifiableSolrParams) super.getParams();
|
||||
params.set( "ranges", ranges);
|
||||
|
||||
if(splitKey != null)
|
||||
params.set("split.key", this.splitKey);
|
||||
if(this.collection == null) {
|
||||
throw new IllegalArgumentException("You must set collection name for this request.");
|
||||
}
|
||||
|
||||
params.set(CollectionAdminParams.COLLECTION, collection);
|
||||
|
||||
if (this.shard == null && this.splitKey == null) {
|
||||
throw new IllegalArgumentException("You must set shardname OR splitkey for this request.");
|
||||
}
|
||||
|
||||
params.set("shard", shard);
|
||||
params.set("split.key", this.splitKey);
|
||||
params.set( "ranges", ranges);
|
||||
|
||||
if(properties != null) {
|
||||
addProperties(params, properties);
|
||||
|
|
|
@ -21,4 +21,6 @@ public abstract class CollectionAdminParams {
|
|||
/* Param used by DELETESTATUS call to clear all stored responses */
|
||||
public static final String FLUSH = "flush";
|
||||
|
||||
public static final String COLLECTION = "collection";
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue