From 9f502b01290897f4628a6b94aca6a1ab6efc9bf4 Mon Sep 17 00:00:00 2001 From: javanna Date: Mon, 3 Mar 2014 14:52:43 +0100 Subject: [PATCH] Improved how aliases get parsed in create index Added also CreateIndexRequest#aliases(BytesReference) method --- .../indices/create/CreateIndexRequest.java | 17 ++++++++++------- .../create/CreateIndexRequestBuilder.java | 8 ++++++++ 2 files changed, 18 insertions(+), 7 deletions(-) diff --git a/src/main/java/org/elasticsearch/action/admin/indices/create/CreateIndexRequest.java b/src/main/java/org/elasticsearch/action/admin/indices/create/CreateIndexRequest.java index aae996b7fca..3f66ebd910b 100644 --- a/src/main/java/org/elasticsearch/action/admin/indices/create/CreateIndexRequest.java +++ b/src/main/java/org/elasticsearch/action/admin/indices/create/CreateIndexRequest.java @@ -256,7 +256,7 @@ public class CreateIndexRequest extends AcknowledgedRequest try { XContentBuilder builder = XContentFactory.jsonBuilder(); builder.map(source); - return aliases(builder.string()); + return aliases(builder.bytes()); } catch (IOException e) { throw new ElasticsearchGenerationException("Failed to generate [" + source + "]", e); } @@ -266,19 +266,22 @@ public class CreateIndexRequest extends AcknowledgedRequest * Sets the aliases that will be associated with the index when it gets created */ public CreateIndexRequest aliases(XContentBuilder source) { - try { - return aliases(source.string()); - } catch (IOException e) { - throw new ElasticsearchIllegalArgumentException("Failed to build json for aliases", e); - } + return aliases(source.bytes()); } /** * Sets the aliases that will be associated with the index when it gets created */ public CreateIndexRequest aliases(String source) { + return aliases(new BytesArray(source)); + } + + /** + * Sets the aliases that will be associated with the index when it gets created + */ + public CreateIndexRequest aliases(BytesReference source) { try { - XContentParser parser = XContentHelper.createParser(new BytesArray(source)); + XContentParser parser = XContentHelper.createParser(source); //move to the first alias parser.nextToken(); while ((parser.nextToken()) != XContentParser.Token.END_OBJECT) { diff --git a/src/main/java/org/elasticsearch/action/admin/indices/create/CreateIndexRequestBuilder.java b/src/main/java/org/elasticsearch/action/admin/indices/create/CreateIndexRequestBuilder.java index e738ec3c855..9baca73b653 100644 --- a/src/main/java/org/elasticsearch/action/admin/indices/create/CreateIndexRequestBuilder.java +++ b/src/main/java/org/elasticsearch/action/admin/indices/create/CreateIndexRequestBuilder.java @@ -174,6 +174,14 @@ public class CreateIndexRequestBuilder extends AcknowledgedRequestBuilder