Put index template api: unified PUT/POST behaviour in relation to create parameter

The put index template api supports the create parameter (defaults to false), which tells whether the template can replace an existing one with same name or not. Unified its behaviour between PUT and POST method, whereas the POST would previously force create to true.

Added create parameter to the rest spec (was missing before) and a REST test for create true scenario.
This commit is contained in:
javanna 2014-06-06 15:29:20 +02:00 committed by Luca Cavanna
parent 797a9b07ef
commit 11f7c31852
3 changed files with 40 additions and 15 deletions

View File

@ -17,6 +17,11 @@
"type" : "number", "type" : "number",
"description" : "The order for this template when merging multiple matching ones (higher numbers are merged later, overriding the lower numbers)" "description" : "The order for this template when merging multiple matching ones (higher numbers are merged later, overriding the lower numbers)"
}, },
"create" : {
"type" : "boolean",
"description" : "Whether the index template should only be added if new or can also replace an existing one",
"default" : false
},
"timeout": { "timeout": {
"type" : "time", "type" : "time",
"description" : "Explicit operation timeout" "description" : "Explicit operation timeout"
@ -25,10 +30,10 @@
"type" : "time", "type" : "time",
"description" : "Specify timeout for connection to master" "description" : "Specify timeout for connection to master"
}, },
"flat_settings": { "flat_settings": {
"type": "boolean", "type": "boolean",
"description": "Return settings in flat format (default: false)" "description": "Return settings in flat format (default: false)"
} }
} }
}, },
"body": { "body": {

View File

@ -39,3 +39,33 @@
- match: { test.aliases.test_blias.search_routing: "b" } - match: { test.aliases.test_blias.search_routing: "b" }
- match: { test.aliases.test_clias.filter.term.user: "kimchy" } - match: { test.aliases.test_clias.filter.term.user: "kimchy" }
---
"Put template create":
- do:
indices.put_template:
name: test
create: true
body:
template: test-*
settings:
number_of_shards: 1
number_of_replicas: 0
- do:
indices.get_template:
name: test
- match: {test.template: "test-*"}
- match: {test.settings: {index.number_of_shards: '1', index.number_of_replicas: '0'}}
- do:
catch: request
indices.put_template:
name: test
create: true
body:
template: test-*
settings:
number_of_shards: 1
number_of_replicas: 0

View File

@ -26,8 +26,6 @@ import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.rest.*; import org.elasticsearch.rest.*;
import org.elasticsearch.rest.action.support.AcknowledgedRestListener; import org.elasticsearch.rest.action.support.AcknowledgedRestListener;
import java.io.IOException;
/** /**
* *
*/ */
@ -37,15 +35,7 @@ public class RestPutIndexTemplateAction extends BaseRestHandler {
public RestPutIndexTemplateAction(Settings settings, Client client, RestController controller) { public RestPutIndexTemplateAction(Settings settings, Client client, RestController controller) {
super(settings, client); super(settings, client);
controller.registerHandler(RestRequest.Method.PUT, "/_template/{name}", this); controller.registerHandler(RestRequest.Method.PUT, "/_template/{name}", this);
controller.registerHandler(RestRequest.Method.POST, "/_template/{name}", new CreateHandler()); controller.registerHandler(RestRequest.Method.POST, "/_template/{name}", this);
}
final class CreateHandler implements RestHandler {
@Override
public void handleRequest(RestRequest request, RestChannel channel) {
request.params().put("create", "true");
RestPutIndexTemplateAction.this.handleRequest(request, channel);
}
} }
@SuppressWarnings({"unchecked"}) @SuppressWarnings({"unchecked"})