From 977cb4a72951a5e6c8ee5b74f378932d3d9c9b45 Mon Sep 17 00:00:00 2001 From: Boaz Leskes Date: Fri, 11 Oct 2013 12:25:21 +0200 Subject: [PATCH] Make the get source REST API source fetching query parameters consistent with other API The get source rest endpoint now uses _source_* parameters. Also it will now throw a validation error if you turn off source fetching. Closes #3886 --- .../rest/action/get/RestGetSourceAction.java | 25 ++++++++----------- 1 file changed, 10 insertions(+), 15 deletions(-) diff --git a/src/main/java/org/elasticsearch/rest/action/get/RestGetSourceAction.java b/src/main/java/org/elasticsearch/rest/action/get/RestGetSourceAction.java index 32827b45c12..21caf1d5624 100644 --- a/src/main/java/org/elasticsearch/rest/action/get/RestGetSourceAction.java +++ b/src/main/java/org/elasticsearch/rest/action/get/RestGetSourceAction.java @@ -20,10 +20,10 @@ package org.elasticsearch.rest.action.get; import org.elasticsearch.action.ActionListener; +import org.elasticsearch.action.ActionRequestValidationException; import org.elasticsearch.action.get.GetRequest; import org.elasticsearch.action.get.GetResponse; import org.elasticsearch.client.Client; -import org.elasticsearch.common.Strings; import org.elasticsearch.common.inject.Inject; import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.xcontent.XContentBuilder; @@ -60,21 +60,16 @@ public class RestGetSourceAction extends BaseRestHandler { getRequest.preference(request.param("preference")); getRequest.realtime(request.paramAsBooleanOptional("realtime", null)); - String[] includes = null, excludes = null; - String sIncludes = request.param("include"); - sIncludes = request.param("includes", sIncludes); - if (sIncludes != null) { - includes = Strings.splitStringByCommaToArray(sIncludes); - } + getRequest.fetchSourceContext(FetchSourceContext.parseFromRestRequest(request)); - String sExcludes = request.param("exclude"); - sExcludes = request.param("excludes", sExcludes); - if (sExcludes != null) { - excludes = Strings.splitStringByCommaToArray(sExcludes); - } - - if (includes != null || excludes != null) { - getRequest.fetchSourceContext(new FetchSourceContext(includes, excludes)); + if (getRequest.fetchSourceContext() != null && !getRequest.fetchSourceContext().fetchSource()) { + try { + ActionRequestValidationException validationError = new ActionRequestValidationException(); + validationError.addValidationError("fetching source can not be disabled"); + channel.sendResponse(new XContentThrowableRestResponse(request, validationError)); + } catch (IOException e) { + logger.error("Failed to send failure response", e); + } } client.get(getRequest, new ActionListener() {