mirror of https://github.com/apache/lucene.git
SOLR-8992: Restore Schema API GET method functionality removed in 6.0
This commit is contained in:
parent
9e34d3137f
commit
7fefc35dcf
|
@ -185,7 +185,7 @@ public class SchemaHandler extends RequestHandlerBase implements SolrCoreAware,
|
||||||
if (parts.get(0).isEmpty()) parts.remove(0);
|
if (parts.get(0).isEmpty()) parts.remove(0);
|
||||||
if (parts.size() > 1 && level2.containsKey(parts.get(1))) {
|
if (parts.size() > 1 && level2.containsKey(parts.get(1))) {
|
||||||
String realName = level2.get(parts.get(1));
|
String realName = level2.get(parts.get(1));
|
||||||
SimpleOrderedMap<Object> propertyValues = req.getSchema().getNamedPropertyValues(req.getParams());
|
Map propertyValues = req.getSchema().getNamedPropertyValues(realName, req.getParams());
|
||||||
Object o = propertyValues.get(realName);
|
Object o = propertyValues.get(realName);
|
||||||
if(parts.size()> 2) {
|
if(parts.size()> 2) {
|
||||||
String name = parts.get(2);
|
String name = parts.get(2);
|
||||||
|
|
|
@ -78,8 +78,8 @@ public class SchemaXmlWriter extends TextResponseWriter {
|
||||||
writer.write(MANAGED_SCHEMA_DO_NOT_EDIT_WARNING);
|
writer.write(MANAGED_SCHEMA_DO_NOT_EDIT_WARNING);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("unchecked") SimpleOrderedMap<Object> schemaProperties
|
@SuppressWarnings("unchecked") Map<String,Object> schemaProperties
|
||||||
= (SimpleOrderedMap<Object>)rsp.getValues().get(IndexSchema.SCHEMA);
|
= (Map<String , Object>)rsp.getValues().get(IndexSchema.SCHEMA);
|
||||||
|
|
||||||
openStartTag(IndexSchema.SCHEMA);
|
openStartTag(IndexSchema.SCHEMA);
|
||||||
writeAttr(IndexSchema.NAME, schemaProperties.get(IndexSchema.NAME).toString());
|
writeAttr(IndexSchema.NAME, schemaProperties.get(IndexSchema.NAME).toString());
|
||||||
|
@ -87,34 +87,33 @@ public class SchemaXmlWriter extends TextResponseWriter {
|
||||||
closeStartTag(false);
|
closeStartTag(false);
|
||||||
incLevel();
|
incLevel();
|
||||||
|
|
||||||
for (int schemaPropNum = 0 ; schemaPropNum < schemaProperties.size() ; ++schemaPropNum) {
|
for (Map.Entry<String, Object> entry : schemaProperties.entrySet()) {
|
||||||
String schemaPropName = schemaProperties.getName(schemaPropNum);
|
String schemaPropName = entry.getKey();
|
||||||
|
Object val = entry.getValue();
|
||||||
if (schemaPropName.equals(IndexSchema.NAME) || schemaPropName.equals(IndexSchema.VERSION)) {
|
if (schemaPropName.equals(IndexSchema.NAME) || schemaPropName.equals(IndexSchema.VERSION)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (schemaPropName.equals(IndexSchema.UNIQUE_KEY)) {
|
if (schemaPropName.equals(IndexSchema.UNIQUE_KEY)) {
|
||||||
openStartTag(IndexSchema.UNIQUE_KEY);
|
openStartTag(IndexSchema.UNIQUE_KEY);
|
||||||
closeStartTag(false);
|
closeStartTag(false);
|
||||||
writer.write(schemaProperties.getVal(schemaPropNum).toString());
|
writer.write(val.toString());
|
||||||
endTag(IndexSchema.UNIQUE_KEY, false);
|
endTag(IndexSchema.UNIQUE_KEY, false);
|
||||||
} else if (schemaPropName.equals(IndexSchema.DEFAULT_SEARCH_FIELD)) {
|
} else if (schemaPropName.equals(IndexSchema.DEFAULT_SEARCH_FIELD)) {
|
||||||
openStartTag(IndexSchema.DEFAULT_SEARCH_FIELD);
|
openStartTag(IndexSchema.DEFAULT_SEARCH_FIELD);
|
||||||
closeStartTag(false);
|
closeStartTag(false);
|
||||||
writer.write(schemaProperties.getVal(schemaPropNum).toString());
|
writer.write(val.toString());
|
||||||
endTag(IndexSchema.DEFAULT_SEARCH_FIELD, false);
|
endTag(IndexSchema.DEFAULT_SEARCH_FIELD, false);
|
||||||
} else if (schemaPropName.equals(IndexSchema.SOLR_QUERY_PARSER)) {
|
} else if (schemaPropName.equals(IndexSchema.SOLR_QUERY_PARSER)) {
|
||||||
openStartTag(IndexSchema.SOLR_QUERY_PARSER);
|
openStartTag(IndexSchema.SOLR_QUERY_PARSER);
|
||||||
@SuppressWarnings("unchecked") SimpleOrderedMap<Object> solrQueryParserProperties
|
writeAttr(IndexSchema.DEFAULT_OPERATOR, ((Map<String ,Object>) val).get(IndexSchema.DEFAULT_OPERATOR).toString());
|
||||||
= (SimpleOrderedMap<Object>)schemaProperties.getVal(schemaPropNum);
|
|
||||||
writeAttr(IndexSchema.DEFAULT_OPERATOR, solrQueryParserProperties.get(IndexSchema.DEFAULT_OPERATOR).toString());
|
|
||||||
closeStartTag(true);
|
closeStartTag(true);
|
||||||
} else if (schemaPropName.equals(IndexSchema.SIMILARITY)) {
|
} else if (schemaPropName.equals(IndexSchema.SIMILARITY)) {
|
||||||
writeSimilarity((SimpleOrderedMap<Object>) schemaProperties.getVal(schemaPropNum));
|
writeSimilarity((SimpleOrderedMap<Object>) val);
|
||||||
} else if (schemaPropName.equals(IndexSchema.FIELD_TYPES)) {
|
} else if (schemaPropName.equals(IndexSchema.FIELD_TYPES)) {
|
||||||
writeFieldTypes((List<SimpleOrderedMap<Object>>)schemaProperties.getVal(schemaPropNum));
|
writeFieldTypes((List<SimpleOrderedMap<Object>>) val);
|
||||||
} else if (schemaPropName.equals(IndexSchema.FIELDS)) {
|
} else if (schemaPropName.equals(IndexSchema.FIELDS)) {
|
||||||
@SuppressWarnings("unchecked") List<SimpleOrderedMap<Object>> fieldPropertiesList
|
@SuppressWarnings("unchecked") List<SimpleOrderedMap<Object>> fieldPropertiesList
|
||||||
= (List<SimpleOrderedMap<Object>>)schemaProperties.getVal(schemaPropNum);
|
= (List<SimpleOrderedMap<Object>>) val;
|
||||||
for (SimpleOrderedMap<Object> fieldProperties : fieldPropertiesList) {
|
for (SimpleOrderedMap<Object> fieldProperties : fieldPropertiesList) {
|
||||||
openStartTag(IndexSchema.FIELD);
|
openStartTag(IndexSchema.FIELD);
|
||||||
for (int fieldPropNum = 0 ; fieldPropNum < fieldProperties.size() ; ++fieldPropNum) {
|
for (int fieldPropNum = 0 ; fieldPropNum < fieldProperties.size() ; ++fieldPropNum) {
|
||||||
|
@ -124,7 +123,7 @@ public class SchemaXmlWriter extends TextResponseWriter {
|
||||||
}
|
}
|
||||||
} else if (schemaPropName.equals(IndexSchema.DYNAMIC_FIELDS)) {
|
} else if (schemaPropName.equals(IndexSchema.DYNAMIC_FIELDS)) {
|
||||||
@SuppressWarnings("unchecked") List<SimpleOrderedMap<Object>> dynamicFieldPropertiesList
|
@SuppressWarnings("unchecked") List<SimpleOrderedMap<Object>> dynamicFieldPropertiesList
|
||||||
= (List<SimpleOrderedMap<Object>>)schemaProperties.getVal(schemaPropNum);
|
= (List<SimpleOrderedMap<Object>>) val;
|
||||||
for (SimpleOrderedMap<Object> dynamicFieldProperties : dynamicFieldPropertiesList) {
|
for (SimpleOrderedMap<Object> dynamicFieldProperties : dynamicFieldPropertiesList) {
|
||||||
openStartTag(IndexSchema.DYNAMIC_FIELD);
|
openStartTag(IndexSchema.DYNAMIC_FIELD);
|
||||||
for (int dynamicFieldPropNum = 0 ; dynamicFieldPropNum < dynamicFieldProperties.size() ; ++dynamicFieldPropNum) {
|
for (int dynamicFieldPropNum = 0 ; dynamicFieldPropNum < dynamicFieldProperties.size() ; ++dynamicFieldPropNum) {
|
||||||
|
@ -135,7 +134,7 @@ public class SchemaXmlWriter extends TextResponseWriter {
|
||||||
}
|
}
|
||||||
} else if (schemaPropName.equals(IndexSchema.COPY_FIELDS)) {
|
} else if (schemaPropName.equals(IndexSchema.COPY_FIELDS)) {
|
||||||
@SuppressWarnings("unchecked") List<SimpleOrderedMap<Object>> copyFieldPropertiesList
|
@SuppressWarnings("unchecked") List<SimpleOrderedMap<Object>> copyFieldPropertiesList
|
||||||
= (List<SimpleOrderedMap<Object>>)schemaProperties.getVal(schemaPropNum);
|
= (List<SimpleOrderedMap<Object>>) val;
|
||||||
for (SimpleOrderedMap<Object> copyFieldProperties : copyFieldPropertiesList) {
|
for (SimpleOrderedMap<Object> copyFieldProperties : copyFieldPropertiesList) {
|
||||||
openStartTag(IndexSchema.COPY_FIELD);
|
openStartTag(IndexSchema.COPY_FIELD);
|
||||||
for (int copyFieldPropNum = 0 ; copyFieldPropNum < copyFieldProperties.size() ; ++ copyFieldPropNum) {
|
for (int copyFieldPropNum = 0 ; copyFieldPropNum < copyFieldProperties.size() ; ++ copyFieldPropNum) {
|
||||||
|
|
|
@ -20,11 +20,15 @@ import java.io.IOException;
|
||||||
import java.io.Writer;
|
import java.io.Writer;
|
||||||
import java.lang.invoke.MethodHandles;
|
import java.lang.invoke.MethodHandles;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
import java.util.function.Function;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
import java.util.stream.Stream;
|
||||||
import javax.xml.xpath.XPath;
|
import javax.xml.xpath.XPath;
|
||||||
import javax.xml.xpath.XPathConstants;
|
import javax.xml.xpath.XPathConstants;
|
||||||
import javax.xml.xpath.XPathExpressionException;
|
import javax.xml.xpath.XPathExpressionException;
|
||||||
|
|
||||||
|
import com.google.common.base.Functions;
|
||||||
import org.apache.lucene.analysis.Analyzer;
|
import org.apache.lucene.analysis.Analyzer;
|
||||||
import org.apache.lucene.analysis.DelegatingAnalyzerWrapper;
|
import org.apache.lucene.analysis.DelegatingAnalyzerWrapper;
|
||||||
import org.apache.lucene.index.DocValuesType;
|
import org.apache.lucene.index.DocValuesType;
|
||||||
|
@ -32,19 +36,21 @@ import org.apache.lucene.index.FieldInfo;
|
||||||
import org.apache.lucene.index.IndexOptions;
|
import org.apache.lucene.index.IndexOptions;
|
||||||
import org.apache.lucene.index.IndexReader;
|
import org.apache.lucene.index.IndexReader;
|
||||||
import org.apache.lucene.index.IndexableField;
|
import org.apache.lucene.index.IndexableField;
|
||||||
import org.apache.lucene.index.IndexableField;
|
|
||||||
import org.apache.lucene.index.MultiFields;
|
import org.apache.lucene.index.MultiFields;
|
||||||
import org.apache.lucene.search.similarities.Similarity;
|
import org.apache.lucene.search.similarities.Similarity;
|
||||||
import org.apache.lucene.uninverting.UninvertingReader;
|
import org.apache.lucene.uninverting.UninvertingReader;
|
||||||
import org.apache.lucene.util.Version;
|
import org.apache.lucene.util.Version;
|
||||||
import org.apache.solr.common.SolrException.ErrorCode;
|
import org.apache.solr.common.SolrException.ErrorCode;
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
|
import org.apache.solr.common.params.CommonParams;
|
||||||
import org.apache.solr.common.params.MapSolrParams;
|
import org.apache.solr.common.params.MapSolrParams;
|
||||||
import org.apache.solr.common.params.ModifiableSolrParams;
|
import org.apache.solr.common.params.ModifiableSolrParams;
|
||||||
import org.apache.solr.common.params.SolrParams;
|
import org.apache.solr.common.params.SolrParams;
|
||||||
import org.apache.solr.common.util.NamedList;
|
import org.apache.solr.common.util.NamedList;
|
||||||
|
import org.apache.solr.common.util.Pair;
|
||||||
import org.apache.solr.common.util.SimpleOrderedMap;
|
import org.apache.solr.common.util.SimpleOrderedMap;
|
||||||
import org.apache.solr.core.Config;
|
import org.apache.solr.core.Config;
|
||||||
|
import org.apache.solr.core.MapSerializable;
|
||||||
import org.apache.solr.core.SolrConfig;
|
import org.apache.solr.core.SolrConfig;
|
||||||
import org.apache.solr.core.SolrResourceLoader;
|
import org.apache.solr.core.SolrResourceLoader;
|
||||||
import org.apache.solr.request.LocalSolrQueryRequest;
|
import org.apache.solr.request.LocalSolrQueryRequest;
|
||||||
|
@ -63,6 +69,7 @@ import org.w3c.dom.Node;
|
||||||
import org.w3c.dom.NodeList;
|
import org.w3c.dom.NodeList;
|
||||||
import org.xml.sax.InputSource;
|
import org.xml.sax.InputSource;
|
||||||
|
|
||||||
|
import static java.util.Arrays.asList;
|
||||||
import static java.util.Collections.singletonList;
|
import static java.util.Collections.singletonList;
|
||||||
import static java.util.Collections.singletonMap;
|
import static java.util.Collections.singletonMap;
|
||||||
|
|
||||||
|
@ -780,7 +787,7 @@ public class IndexSchema {
|
||||||
* @param fields The sequence of {@link org.apache.solr.schema.SchemaField}
|
* @param fields The sequence of {@link org.apache.solr.schema.SchemaField}
|
||||||
*/
|
*/
|
||||||
public void registerDynamicFields(SchemaField... fields) {
|
public void registerDynamicFields(SchemaField... fields) {
|
||||||
List<DynamicField> dynFields = new ArrayList<>(Arrays.asList(dynamicFields));
|
List<DynamicField> dynFields = new ArrayList<>(asList(dynamicFields));
|
||||||
for (SchemaField field : fields) {
|
for (SchemaField field : fields) {
|
||||||
if (isDuplicateDynField(dynFields, field)) {
|
if (isDuplicateDynField(dynFields, field)) {
|
||||||
log.debug("dynamic field already exists: dynamic field: [" + field.getName() + "]");
|
log.debug("dynamic field already exists: dynamic field: [" + field.getName() + "]");
|
||||||
|
@ -1352,58 +1359,138 @@ public class IndexSchema {
|
||||||
/**
|
/**
|
||||||
* Get a map of property name -> value for the whole schema.
|
* Get a map of property name -> value for the whole schema.
|
||||||
*/
|
*/
|
||||||
public SimpleOrderedMap<Object> getNamedPropertyValues() {
|
public Map getNamedPropertyValues() {
|
||||||
return getNamedPropertyValues(new MapSolrParams(Collections.EMPTY_MAP));
|
return getNamedPropertyValues(null, new MapSolrParams(Collections.EMPTY_MAP));
|
||||||
|
|
||||||
}
|
|
||||||
public SimpleOrderedMap<Object> getNamedPropertyValues(SolrParams params) {
|
|
||||||
SimpleOrderedMap<Object> topLevel = new SimpleOrderedMap<>();
|
|
||||||
topLevel.add(NAME, getSchemaName());
|
|
||||||
topLevel.add(VERSION, getVersion());
|
|
||||||
if (null != uniqueKeyFieldName) {
|
|
||||||
topLevel.add(UNIQUE_KEY, uniqueKeyFieldName);
|
|
||||||
}
|
|
||||||
if (null != defaultSearchFieldName) {
|
|
||||||
topLevel.add(DEFAULT_SEARCH_FIELD, defaultSearchFieldName);
|
|
||||||
}
|
|
||||||
if (isExplicitQueryParserDefaultOperator) {
|
|
||||||
SimpleOrderedMap<Object> solrQueryParserProperties = new SimpleOrderedMap<>();
|
|
||||||
solrQueryParserProperties.add(DEFAULT_OPERATOR, queryParserDefaultOperator);
|
|
||||||
topLevel.add(SOLR_QUERY_PARSER, solrQueryParserProperties);
|
|
||||||
}
|
|
||||||
if (isExplicitSimilarity) {
|
|
||||||
topLevel.add(SIMILARITY, similarityFactory.getNamedPropertyValues());
|
|
||||||
}
|
|
||||||
List<SimpleOrderedMap<Object>> fieldTypeProperties = new ArrayList<>();
|
|
||||||
SortedMap<String,FieldType> sortedFieldTypes = new TreeMap<>(fieldTypes);
|
|
||||||
for (FieldType fieldType : sortedFieldTypes.values()) {
|
|
||||||
fieldTypeProperties.add(fieldType.getNamedPropertyValues(params.getBool("showDefaults", false)));
|
|
||||||
}
|
|
||||||
topLevel.add(FIELD_TYPES, fieldTypeProperties);
|
|
||||||
List<SimpleOrderedMap<Object>> fieldProperties = new ArrayList<>();
|
|
||||||
SortedSet<String> fieldNames = new TreeSet<>(fields.keySet());
|
|
||||||
for (String fieldName : fieldNames) {
|
|
||||||
fieldProperties.add(fields.get(fieldName).getNamedPropertyValues(params.getBool("showDefaults", false)));
|
|
||||||
}
|
|
||||||
if (params.getBool("includeDynamic", false)) {
|
|
||||||
fieldProperties.addAll(getDynamicFields(params));
|
|
||||||
}
|
|
||||||
topLevel.add(FIELDS, fieldProperties);
|
|
||||||
topLevel.add(DYNAMIC_FIELDS, getDynamicFields(params));
|
|
||||||
topLevel.add(COPY_FIELDS, getCopyFieldProperties(false, null, null));
|
|
||||||
return topLevel;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<SimpleOrderedMap<Object>> getDynamicFields(SolrParams params) {
|
static class SchemaProps implements MapSerializable {
|
||||||
List<SimpleOrderedMap<Object>> dynamicFieldProperties = new ArrayList<>();
|
private static final String SOURCE_FIELD_LIST = IndexSchema.SOURCE + "." + CommonParams.FL;
|
||||||
for (DynamicField dynamicField : dynamicFields) {
|
private static final String DESTINATION_FIELD_LIST = IndexSchema.DESTINATION + "." + CommonParams.FL;
|
||||||
if ( ! dynamicField.getRegex().startsWith(INTERNAL_POLY_FIELD_PREFIX)) { // omit internal polyfields
|
private final String name;
|
||||||
dynamicFieldProperties.add(dynamicField.getPrototype().getNamedPropertyValues(params.getBool("showDefaults", false)));
|
private final SolrParams params;
|
||||||
|
private final IndexSchema schema;
|
||||||
|
boolean showDefaults, includeDynamic;
|
||||||
|
Set<String> requestedFields;
|
||||||
|
private Set<String> requestedSourceFields;
|
||||||
|
private Set<String> requestedDestinationFields;
|
||||||
|
|
||||||
|
|
||||||
|
enum Handler {
|
||||||
|
NAME(IndexSchema.NAME, sp -> sp.schema.getSchemaName()),
|
||||||
|
VERSION(IndexSchema.VERSION, sp -> sp.schema.getVersion()),
|
||||||
|
UNIQUE_KEY(IndexSchema.UNIQUE_KEY, sp -> sp.schema.uniqueKeyFieldName),
|
||||||
|
DEFAULT_SEARCH_FIELD(IndexSchema.DEFAULT_SEARCH_FIELD, sp -> sp.schema.defaultSearchFieldName),
|
||||||
|
SOLR_QUERY_PARSER(IndexSchema.SOLR_QUERY_PARSER, sp -> sp.schema.isExplicitQueryParserDefaultOperator ?
|
||||||
|
singletonMap(DEFAULT_OPERATOR, sp.schema.queryParserDefaultOperator) :
|
||||||
|
null),
|
||||||
|
SIMILARITY(IndexSchema.SIMILARITY, sp -> sp.schema.isExplicitSimilarity ?
|
||||||
|
sp.schema.similarityFactory.getNamedPropertyValues() :
|
||||||
|
null),
|
||||||
|
FIELD_TYPES(IndexSchema.FIELD_TYPES, sp -> new TreeMap<>(sp.schema.fieldTypes)
|
||||||
|
.values().stream()
|
||||||
|
.map(it -> it.getNamedPropertyValues(sp.showDefaults))
|
||||||
|
.collect(Collectors.toList())),
|
||||||
|
|
||||||
|
DYNAMIC_FIELDS(IndexSchema.DYNAMIC_FIELDS, sp -> Stream.of(sp.schema.dynamicFields)
|
||||||
|
.filter(it -> !it.getRegex().startsWith(INTERNAL_POLY_FIELD_PREFIX))
|
||||||
|
.filter(it -> sp.requestedFields == null || sp.requestedFields.contains(it.getPrototype().getName()))
|
||||||
|
.map(it -> sp.getProperties(it.getPrototype()))
|
||||||
|
.collect(Collectors.toList())),
|
||||||
|
FIELDS(IndexSchema.FIELDS, sp -> {
|
||||||
|
List<SimpleOrderedMap> result = (sp.requestedFields != null ? sp.requestedFields : new TreeSet<>(sp.schema.fields.keySet()))
|
||||||
|
.stream()
|
||||||
|
.map(sp.schema::getFieldOrNull)
|
||||||
|
.filter(it -> it != null)
|
||||||
|
.filter(it -> sp.includeDynamic || !sp.schema.isDynamicField(it.name))
|
||||||
|
.map(sp::getProperties)
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
if (sp.includeDynamic && sp.requestedFields == null) {
|
||||||
|
result.addAll((Collection) Handler.DYNAMIC_FIELDS.fun.apply(sp));
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}),
|
||||||
|
|
||||||
|
|
||||||
|
COPY_FIELDS(IndexSchema.COPY_FIELDS, sp -> sp.schema.getCopyFieldProperties(false,
|
||||||
|
sp.requestedSourceFields, sp.requestedDestinationFields));
|
||||||
|
|
||||||
|
final Function<SchemaProps, Object> fun;
|
||||||
|
final String name;
|
||||||
|
Handler(String name, Function<SchemaProps, Object> fun) {
|
||||||
|
this.fun = fun;
|
||||||
|
this.name = name;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return dynamicFieldProperties;
|
|
||||||
|
SchemaProps(String name, SolrParams params, IndexSchema schema) {
|
||||||
|
this.name = name;
|
||||||
|
this.params = params;
|
||||||
|
this.schema = schema;
|
||||||
|
showDefaults = params.getBool("showDefaults", false);
|
||||||
|
includeDynamic = params.getBool("includeDynamic", false);
|
||||||
|
|
||||||
|
String sourceFieldListParam = params.get(SOURCE_FIELD_LIST);
|
||||||
|
if (null != sourceFieldListParam) {
|
||||||
|
String[] fields = sourceFieldListParam.trim().split("[,\\s]+");
|
||||||
|
if (fields.length > 0) {
|
||||||
|
requestedSourceFields = new HashSet<>(Arrays.asList(fields));
|
||||||
|
requestedSourceFields.remove(""); // Remove empty values, if any
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String destinationFieldListParam = params.get(DESTINATION_FIELD_LIST);
|
||||||
|
if (null != destinationFieldListParam) {
|
||||||
|
String[] fields = destinationFieldListParam.trim().split("[,\\s]+");
|
||||||
|
if (fields.length > 0) {
|
||||||
|
requestedDestinationFields = new HashSet<>(Arrays.asList(fields));
|
||||||
|
requestedDestinationFields.remove(""); // Remove empty values, if any
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
String flParam = params.get(CommonParams.FL);
|
||||||
|
if (null != flParam) {
|
||||||
|
String[] fields = flParam.trim().split("[,\\s]+");
|
||||||
|
if (fields.length > 0)
|
||||||
|
requestedFields = new LinkedHashSet<>(Stream.of(fields)
|
||||||
|
.filter(it -> !it.trim().isEmpty())
|
||||||
|
.collect(Collectors.toList()));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
SimpleOrderedMap getProperties(SchemaField sf) {
|
||||||
|
SimpleOrderedMap<Object> result = sf.getNamedPropertyValues(showDefaults);
|
||||||
|
if (schema.isDynamicField(sf.name)) {
|
||||||
|
String dynamicBase = schema.getDynamicPattern(sf.getName());
|
||||||
|
// Add dynamicBase property if it's different from the field name.
|
||||||
|
if (!sf.getName().equals(dynamicBase)) {
|
||||||
|
result.add("dynamicBase", dynamicBase);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Map<String, Object> toMap() {
|
||||||
|
Map<String, Object> topLevel = new LinkedHashMap<>();
|
||||||
|
Stream.of(Handler.values())
|
||||||
|
.filter(it -> name == null || it.name.equals(name))
|
||||||
|
.forEach(it -> {
|
||||||
|
Object val = it.fun.apply(this);
|
||||||
|
if (val != null) topLevel.put(it.name, val);
|
||||||
|
});
|
||||||
|
return topLevel;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Map<String, Object> getNamedPropertyValues(String name, SolrParams params) {
|
||||||
|
return new SchemaProps(name, params, this).toMap();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a list of copyField directives, with optional details and optionally restricting to those
|
* Returns a list of copyField directives, with optional details and optionally restricting to those
|
||||||
* directives that contain the requested source and/or destination field names.
|
* directives that contain the requested source and/or destination field names.
|
||||||
|
|
|
@ -100,4 +100,38 @@ public class TestCopyFieldCollectionResource extends SolrRestletTestBase {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testRestrictSource() throws Exception {
|
||||||
|
assertQ("/schema/copyfields/?indent=on&wt=xml&source.fl=title,*_i,*_src_sub_i,src_sub_no_ast_i",
|
||||||
|
"count(/response/arr[@name='copyFields']/lst) = 16", // 4 + 4 + 4 + 4
|
||||||
|
"count(/response/arr[@name='copyFields']/lst/str[@name='source'][.='title']) = 4",
|
||||||
|
"count(/response/arr[@name='copyFields']/lst/str[@name='source'][.='*_i']) = 4",
|
||||||
|
"count(/response/arr[@name='copyFields']/lst/str[@name='source'][.='*_src_sub_i']) = 4",
|
||||||
|
"count(/response/arr[@name='copyFields']/lst/str[@name='source'][.='src_sub_no_ast_i']) = 4");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testRestrictDest() throws Exception {
|
||||||
|
assertQ("/schema/copyfields/?indent=on&wt=xml&dest.fl=title,*_s,*_dest_sub_s,dest_sub_no_ast_s",
|
||||||
|
"count(/response/arr[@name='copyFields']/lst) = 16", // 3 + 4 + 4 + 5
|
||||||
|
"count(/response/arr[@name='copyFields']/lst/str[@name='dest'][.='title']) = 3",
|
||||||
|
"count(/response/arr[@name='copyFields']/lst/str[@name='dest'][.='*_s']) = 4",
|
||||||
|
"count(/response/arr[@name='copyFields']/lst/str[@name='dest'][.='*_dest_sub_s']) = 4",
|
||||||
|
"count(/response/arr[@name='copyFields']/lst/str[@name='dest'][.='dest_sub_no_ast_s']) = 5");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testRestrictSourceAndDest() throws Exception {
|
||||||
|
assertQ("/schema/copyfields/?indent=on&wt=xml&source.fl=title,*_i&dest.fl=title,dest_sub_no_ast_s",
|
||||||
|
"count(/response/arr[@name='copyFields']/lst) = 3",
|
||||||
|
|
||||||
|
"/response/arr[@name='copyFields']/lst[ str[@name='source'][.='title']"
|
||||||
|
+ " and str[@name='dest'][.='dest_sub_no_ast_s']]",
|
||||||
|
|
||||||
|
"/response/arr[@name='copyFields']/lst[ str[@name='source'][.='*_i']"
|
||||||
|
+ " and str[@name='dest'][.='title']]",
|
||||||
|
|
||||||
|
"/response/arr[@name='copyFields']/lst[ str[@name='source'][.='*_i']"
|
||||||
|
+ " and str[@name='dest'][.='dest_sub_no_ast_s']]");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,6 +29,21 @@ public class TestDynamicFieldCollectionResource extends SolrRestletTestBase {
|
||||||
"(/response/arr[@name='dynamicFields']/lst/str[@name='name'])[3] = '*_mfacet'");
|
"(/response/arr[@name='dynamicFields']/lst/str[@name='name'])[3] = '*_mfacet'");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetTwoDynamicFields() throws IOException {
|
||||||
|
assertQ("/schema/dynamicfields?indent=on&wt=xml&fl=*_i,*_s",
|
||||||
|
"count(/response/arr[@name='dynamicFields']/lst/str[@name='name']) = 2",
|
||||||
|
"(/response/arr[@name='dynamicFields']/lst/str[@name='name'])[1] = '*_i'",
|
||||||
|
"(/response/arr[@name='dynamicFields']/lst/str[@name='name'])[2] = '*_s'");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testNotFoundDynamicFields() throws IOException {
|
||||||
|
assertQ("/schema/dynamicfields?indent=on&wt=xml&fl=*_not_in_there,this_one_isnt_either_*",
|
||||||
|
"count(/response/arr[@name='dynamicFields']) = 1",
|
||||||
|
"count(/response/arr[@name='dynamicfields']/lst/str[@name='name']) = 0");
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testJsonGetAllDynamicFields() throws Exception {
|
public void testJsonGetAllDynamicFields() throws Exception {
|
||||||
assertJQ("/schema/dynamicfields?indent=on",
|
assertJQ("/schema/dynamicfields?indent=on",
|
||||||
|
@ -36,4 +51,13 @@ public class TestDynamicFieldCollectionResource extends SolrRestletTestBase {
|
||||||
"/dynamicFields/[1]/name=='ignored_*'",
|
"/dynamicFields/[1]/name=='ignored_*'",
|
||||||
"/dynamicFields/[2]/name=='*_mfacet'");
|
"/dynamicFields/[2]/name=='*_mfacet'");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testJsonGetTwoDynamicFields() throws Exception {
|
||||||
|
assertJQ("/schema/dynamicfields?indent=on&fl=*_i,*_s&wt=xml", // assertJQ will fix the wt param to be json
|
||||||
|
"/dynamicFields/[0]/name=='*_i'",
|
||||||
|
"/dynamicFields/[1]/name=='*_s'");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,6 +15,8 @@
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.solr.rest.schema;
|
package org.apache.solr.rest.schema;
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
import org.apache.solr.rest.SolrRestletTestBase;
|
import org.apache.solr.rest.SolrRestletTestBase;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
@ -37,6 +39,37 @@ public class TestFieldCollectionResource extends SolrRestletTestBase {
|
||||||
"/fields/[2]/name=='_version_'");
|
"/fields/[2]/name=='_version_'");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetThreeFieldsDontIncludeDynamic() throws IOException {
|
||||||
|
//
|
||||||
|
assertQ("/schema/fields?indent=on&wt=xml&fl=id,_version_,price_i",
|
||||||
|
"count(/response/arr[@name='fields']/lst/str[@name='name']) = 2",
|
||||||
|
"(/response/arr[@name='fields']/lst/str[@name='name'])[1] = 'id'",
|
||||||
|
"(/response/arr[@name='fields']/lst/str[@name='name'])[2] = '_version_'");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetThreeFieldsIncludeDynamic() throws IOException {
|
||||||
|
assertQ("/schema/fields?indent=on&wt=xml&fl=id,_version_,price_i&includeDynamic=on",
|
||||||
|
|
||||||
|
"count(/response/arr[@name='fields']/lst/str[@name='name']) = 3",
|
||||||
|
|
||||||
|
"(/response/arr[@name='fields']/lst/str[@name='name'])[1] = 'id'",
|
||||||
|
|
||||||
|
"(/response/arr[@name='fields']/lst/str[@name='name'])[2] = '_version_'",
|
||||||
|
|
||||||
|
"(/response/arr[@name='fields']/lst/str[@name='name'])[3] = 'price_i'",
|
||||||
|
|
||||||
|
"/response/arr[@name='fields']/lst[ str[@name='name']='price_i' "
|
||||||
|
+" and str[@name='dynamicBase']='*_i']");
|
||||||
|
}
|
||||||
|
@Test
|
||||||
|
public void testNotFoundFields() throws IOException {
|
||||||
|
assertQ("/schema/fields?indent=on&wt=xml&fl=not_in_there,this_one_either",
|
||||||
|
"count(/response/arr[@name='fields']) = 1",
|
||||||
|
"count(/response/arr[@name='fields']/lst/str[@name='name']) = 0");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testJsonGetAllFieldsIncludeDynamic() throws Exception {
|
public void testJsonGetAllFieldsIncludeDynamic() throws Exception {
|
||||||
|
|
Loading…
Reference in New Issue