From 6386f1760feb9901eea1bc8e5cd9e22ce6475f91 Mon Sep 17 00:00:00 2001 From: Noble Paul Date: Fri, 5 Sep 2014 19:44:45 +0000 Subject: [PATCH] SOLR-6471 git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1622773 13f79535-47bb-0310-9956-ffa450edef68 --- .../solr/handler/UpdateRequestHandler.java | 39 +++++++++---------- .../solr/handler/loader/JsonLoader.java | 2 +- .../solr/collection1/conf/schema.xml | 5 ++- 3 files changed, 24 insertions(+), 22 deletions(-) diff --git a/solr/core/src/java/org/apache/solr/handler/UpdateRequestHandler.java b/solr/core/src/java/org/apache/solr/handler/UpdateRequestHandler.java index 4caaea2169a..4519a2a25ab 100644 --- a/solr/core/src/java/org/apache/solr/handler/UpdateRequestHandler.java +++ b/solr/core/src/java/org/apache/solr/handler/UpdateRequestHandler.java @@ -77,28 +77,27 @@ public class UpdateRequestHandler extends ContentStreamHandlerBase { public void load(SolrQueryRequest req, SolrQueryResponse rsp, ContentStream stream, UpdateRequestProcessor processor) throws Exception { - ContentStreamLoader ldr = pathVsLoaders.get(req.getContext().get("path")); - if(ldr != null){ - ldr.load(req,rsp,stream,processor); - return; + ContentStreamLoader loader = pathVsLoaders.get(req.getContext().get("path")); + log.info("$$$$$$$ used the pathVsLoaders {} ",req.getContext().get("path")); + if(loader == null) { + String type = req.getParams().get(UpdateParams.ASSUME_CONTENT_TYPE); + if (type == null) { + type = stream.getContentType(); + } + if (type == null) { // Normal requests will not get here. + throw new SolrException(ErrorCode.UNSUPPORTED_MEDIA_TYPE, "Missing ContentType"); + } + int idx = type.indexOf(';'); + if (idx > 0) { + type = type.substring(0, idx); + } + loader = loaders.get(type); + if (loader == null) { + throw new SolrException(ErrorCode.UNSUPPORTED_MEDIA_TYPE, "Unsupported ContentType: " + + type + " Not in: " + loaders.keySet()); + } } - String type = req.getParams().get(UpdateParams.ASSUME_CONTENT_TYPE); - if(type == null) { - type = stream.getContentType(); - } - if( type == null ) { // Normal requests will not get here. - throw new SolrException(ErrorCode.UNSUPPORTED_MEDIA_TYPE, "Missing ContentType"); - } - int idx = type.indexOf(';'); - if(idx>0) { - type = type.substring(0,idx); - } - ContentStreamLoader loader = loaders.get(type); - if(loader==null) { - throw new SolrException(ErrorCode.UNSUPPORTED_MEDIA_TYPE, "Unsupported ContentType: " - +type+ " Not in: "+loaders.keySet()); - } if(loader.getDefaultWT()!=null) { setDefaultWT(req,loader); } diff --git a/solr/core/src/java/org/apache/solr/handler/loader/JsonLoader.java b/solr/core/src/java/org/apache/solr/handler/loader/JsonLoader.java index 5e428ef1ab2..177fe1afb2b 100644 --- a/solr/core/src/java/org/apache/solr/handler/loader/JsonLoader.java +++ b/solr/core/src/java/org/apache/solr/handler/loader/JsonLoader.java @@ -191,7 +191,7 @@ public class JsonLoader extends ContentStreamLoader { private void handleSplitMode(String split, String[] fields) throws IOException { if(split == null) split = "/"; - if(fields == null || fields.length ==0) fields = new String[]{"/*"}; + if(fields == null || fields.length ==0) fields = new String[]{"/**"}; final boolean echo = "true".equals( req.getParams().get("echo")); JsonRecordReader jsonRecordReader = JsonRecordReader.getInst(split, Arrays.asList(fields)); jsonRecordReader.streamRecords(parser,new JsonRecordReader.Handler() { diff --git a/solr/example/example-schemaless/solr/collection1/conf/schema.xml b/solr/example/example-schemaless/solr/collection1/conf/schema.xml index 88cc79bdddf..432c735b896 100755 --- a/solr/example/example-schemaless/solr/collection1/conf/schema.xml +++ b/solr/example/example-schemaless/solr/collection1/conf/schema.xml @@ -1038,7 +1038,10 @@ - + + +