[7.x] Move internal index templates to composable templates (#61457) (#61661)

This change moves watcher, ILM history and SLM history templates to composable templates.
Versions are updated to reflect the switch. Only change to the templates themselves is added `_meta` to mark them as managed
This commit is contained in:
Przemko Robakowski 2020-09-08 11:26:06 +02:00 committed by GitHub
parent ebd1569028
commit bb357f6aae
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
20 changed files with 2103 additions and 587 deletions

View File

@ -36,7 +36,8 @@ public class SnapshotLifecycleTemplateRegistry extends IndexTemplateRegistry {
// history (please add a comment why you increased the version here) // history (please add a comment why you increased the version here)
// version 1: initial // version 1: initial
// version 2: converted to hidden index // version 2: converted to hidden index
public static final int INDEX_TEMPLATE_VERSION = 2; // version 3: templates moved to composable templates
public static final int INDEX_TEMPLATE_VERSION = 3;
public static final String SLM_TEMPLATE_VERSION_VARIABLE = "xpack.slm.template.version"; public static final String SLM_TEMPLATE_VERSION_VARIABLE = "xpack.slm.template.version";
public static final String SLM_TEMPLATE_NAME = ".slm-history"; public static final String SLM_TEMPLATE_NAME = ".slm-history";
@ -69,7 +70,7 @@ public class SnapshotLifecycleTemplateRegistry extends IndexTemplateRegistry {
} }
@Override @Override
protected List<IndexTemplateConfig> getLegacyTemplateConfigs() { protected List<IndexTemplateConfig> getComposableTemplateConfigs() {
if (slmHistoryEnabled == false) { if (slmHistoryEnabled == false) {
return Collections.emptyList(); return Collections.emptyList();
} }
@ -90,9 +91,9 @@ public class SnapshotLifecycleTemplateRegistry extends IndexTemplateRegistry {
} }
public boolean validate(ClusterState state) { public boolean validate(ClusterState state) {
boolean allTemplatesPresent = getLegacyTemplateConfigs().stream() boolean allTemplatesPresent = getComposableTemplateConfigs().stream()
.map(IndexTemplateConfig::getTemplateName) .map(IndexTemplateConfig::getTemplateName)
.allMatch(name -> state.metadata().getTemplates().containsKey(name)); .allMatch(name -> state.metadata().templatesV2().containsKey(name));
Optional<Map<String, LifecyclePolicy>> maybePolicies = Optional Optional<Map<String, LifecyclePolicy>> maybePolicies = Optional
.<IndexLifecycleMetadata>ofNullable(state.metadata().custom(IndexLifecycleMetadata.TYPE)) .<IndexLifecycleMetadata>ofNullable(state.metadata().custom(IndexLifecycleMetadata.TYPE))

View File

@ -16,15 +16,21 @@ public final class WatcherIndexTemplateRegistryField {
// version 9: add a user field defining which user executed the watch // version 9: add a user field defining which user executed the watch
// version 10: add support for foreach path in actions // version 10: add support for foreach path in actions
// version 11: watch history indices are hidden // version 11: watch history indices are hidden
// version 12: templates changed to composable templates
// Note: if you change this, also inform the kibana team around the watcher-ui // Note: if you change this, also inform the kibana team around the watcher-ui
public static final int INDEX_TEMPLATE_VERSION = 11; public static final int INDEX_TEMPLATE_VERSION = 12;
public static final int INDEX_TEMPLATE_VERSION_10 = 10; public static final int INDEX_TEMPLATE_VERSION_10 = 10;
public static final int INDEX_TEMPLATE_VERSION_11 = 11;
public static final String HISTORY_TEMPLATE_NAME = ".watch-history-" + INDEX_TEMPLATE_VERSION; public static final String HISTORY_TEMPLATE_NAME = ".watch-history-" + INDEX_TEMPLATE_VERSION;
public static final String HISTORY_TEMPLATE_NAME_10 = ".watch-history-" + INDEX_TEMPLATE_VERSION_10; public static final String HISTORY_TEMPLATE_NAME_10 = ".watch-history-" + INDEX_TEMPLATE_VERSION_10;
public static final String HISTORY_TEMPLATE_NAME_11 = ".watch-history-" + INDEX_TEMPLATE_VERSION_11;
public static final String HISTORY_TEMPLATE_NAME_NO_ILM = ".watch-history-no-ilm-" + INDEX_TEMPLATE_VERSION; public static final String HISTORY_TEMPLATE_NAME_NO_ILM = ".watch-history-no-ilm-" + INDEX_TEMPLATE_VERSION;
public static final String HISTORY_TEMPLATE_NAME_NO_ILM_10 = ".watch-history-no-ilm-10"; public static final String HISTORY_TEMPLATE_NAME_NO_ILM_10 = ".watch-history-no-ilm-10";
public static final String HISTORY_TEMPLATE_NAME_NO_ILM_11 = ".watch-history-no-ilm-" + INDEX_TEMPLATE_VERSION_11;
public static final String TRIGGERED_TEMPLATE_NAME = ".triggered_watches"; public static final String TRIGGERED_TEMPLATE_NAME = ".triggered_watches";
public static final String TRIGGERED_TEMPLATE_NAME_11 = ".triggered_watches-11";
public static final String WATCHES_TEMPLATE_NAME = ".watches"; public static final String WATCHES_TEMPLATE_NAME = ".watches";
public static final String WATCHES_TEMPLATE_NAME_11 = ".watches-11";
public static final String[] TEMPLATE_NAMES = new String[] { public static final String[] TEMPLATE_NAMES = new String[] {
HISTORY_TEMPLATE_NAME, TRIGGERED_TEMPLATE_NAME, WATCHES_TEMPLATE_NAME HISTORY_TEMPLATE_NAME, TRIGGERED_TEMPLATE_NAME, WATCHES_TEMPLATE_NAME
}; };

View File

@ -2,84 +2,88 @@
"index_patterns": [ "index_patterns": [
"ilm-history-${xpack.ilm_history.template.version}*" "ilm-history-${xpack.ilm_history.template.version}*"
], ],
"order": 2147483647, "template": {
"settings": { "settings": {
"index.number_of_shards": 1, "index.number_of_shards": 1,
"index.number_of_replicas": 0, "index.number_of_replicas": 0,
"index.auto_expand_replicas": "0-1", "index.auto_expand_replicas": "0-1",
"index.lifecycle.name": "ilm-history-ilm-policy", "index.lifecycle.name": "ilm-history-ilm-policy",
"index.lifecycle.rollover_alias": "ilm-history-${xpack.ilm_history.template.version}", "index.lifecycle.rollover_alias": "ilm-history-${xpack.ilm_history.template.version}",
"index.hidden": true, "index.hidden": true,
"index.format": 1 "index.format": 1
}, },
"mappings": { "mappings": {
"_doc": { "dynamic": false,
"dynamic": false, "properties": {
"properties": { "@timestamp": {
"@timestamp": { "type": "date",
"type": "date", "format": "epoch_millis"
"format": "epoch_millis" },
}, "policy": {
"policy": { "type": "keyword"
"type": "keyword" },
}, "index": {
"index": { "type": "keyword"
"type": "keyword" },
}, "index_age": {
"index_age":{ "type": "long"
"type": "long" },
}, "success": {
"success": { "type": "boolean"
"type": "boolean" },
}, "state": {
"state": { "type": "object",
"type": "object", "dynamic": true,
"dynamic": true, "properties": {
"properties": { "phase": {
"phase": { "type": "keyword"
"type": "keyword" },
}, "action": {
"action": { "type": "keyword"
"type": "keyword" },
}, "step": {
"step": { "type": "keyword"
"type": "keyword" },
}, "failed_step": {
"failed_step": { "type": "keyword"
"type": "keyword" },
}, "is_auto-retryable_error": {
"is_auto-retryable_error": { "type": "keyword"
"type": "keyword" },
}, "creation_date": {
"creation_date": { "type": "date",
"type": "date", "format": "epoch_millis"
"format": "epoch_millis" },
}, "phase_time": {
"phase_time": { "type": "date",
"type": "date", "format": "epoch_millis"
"format": "epoch_millis" },
}, "action_time": {
"action_time": { "type": "date",
"type": "date", "format": "epoch_millis"
"format": "epoch_millis" },
}, "step_time": {
"step_time": { "type": "date",
"type": "date", "format": "epoch_millis"
"format": "epoch_millis" },
}, "phase_definition": {
"phase_definition": { "type": "text"
"type": "text" },
}, "step_info": {
"step_info": { "type": "text"
"type": "text" }
} }
},
"error_details": {
"type": "text"
} }
},
"error_details": {
"type": "text"
} }
} }
}
}, },
"_meta": {
"description": "index template for ILM history indices",
"managed": true
},
"priority": 2147483647,
"version": ${xpack.ilm_history.template.version} "version": ${xpack.ilm_history.template.version}
} }

View File

@ -2,18 +2,18 @@
"index_patterns": [ "index_patterns": [
".slm-history-${xpack.slm.template.version}*" ".slm-history-${xpack.slm.template.version}*"
], ],
"order": 2147483647, "priority": 2147483647,
"settings": { "template": {
"index.number_of_shards": 1, "settings": {
"index.number_of_replicas": 0, "index.number_of_shards": 1,
"index.auto_expand_replicas": "0-1", "index.number_of_replicas": 0,
"index.lifecycle.name": "slm-history-ilm-policy", "index.auto_expand_replicas": "0-1",
"index.lifecycle.rollover_alias": ".slm-history-${xpack.slm.template.version}", "index.lifecycle.name": "slm-history-ilm-policy",
"index.hidden": true, "index.lifecycle.rollover_alias": ".slm-history-${xpack.slm.template.version}",
"index.format": 1 "index.hidden": true,
}, "index.format": 1
"mappings": { },
"_doc": { "mappings": {
"dynamic": false, "dynamic": false,
"properties": { "properties": {
"@timestamp": { "@timestamp": {
@ -26,7 +26,7 @@
"repository": { "repository": {
"type": "keyword" "type": "keyword"
}, },
"snapshot_name":{ "snapshot_name": {
"type": "keyword" "type": "keyword"
}, },
"operation": { "operation": {
@ -57,5 +57,9 @@
} }
} }
}, },
"_meta": {
"description": "index template for SLM history indices",
"managed": true
},
"version": ${xpack.slm.template.version} "version": ${xpack.slm.template.version}
} }

View File

@ -0,0 +1,41 @@
{
"index_patterns": [ ".triggered_watches*" ],
"order": 2147483647,
"settings": {
"index.number_of_shards": 1,
"index.auto_expand_replicas": "0-1",
"index.refresh_interval" : "-1",
"index.format": 6,
"index.priority": 900
},
"mappings": {
"_doc": {
"dynamic" : "strict",
"properties": {
"trigger_event": {
"type": "object",
"dynamic": true,
"enabled" : false,
"properties": {
"schedule": {
"type": "object",
"dynamic": true,
"properties": {
"triggered_time": {
"type": "date"
},
"scheduled_time": {
"type": "date"
}
}
}
}
},
"state": {
"type": "keyword"
}
}
}
},
"version": 11
}

View File

@ -1,21 +1,21 @@
{ {
"index_patterns": [ ".triggered_watches*" ], "index_patterns": [ ".triggered_watches*" ],
"order": 2147483647, "priority": 2147483647,
"settings": { "template": {
"index.number_of_shards": 1, "settings": {
"index.auto_expand_replicas": "0-1", "index.number_of_shards": 1,
"index.refresh_interval" : "-1", "index.auto_expand_replicas": "0-1",
"index.format": 6, "index.refresh_interval": "-1",
"index.priority": 900 "index.format": 6,
}, "index.priority": 900
"mappings": { },
"_doc": { "mappings": {
"dynamic" : "strict", "dynamic": "strict",
"properties": { "properties": {
"trigger_event": { "trigger_event": {
"type": "object", "type": "object",
"dynamic": true, "dynamic": true,
"enabled" : false, "enabled": false,
"properties": { "properties": {
"schedule": { "schedule": {
"type": "object", "type": "object",
@ -37,5 +37,9 @@
} }
} }
}, },
"_meta": {
"description": "index template for triggered watches indices",
"managed": true
},
"version": ${xpack.watcher.template.version} "version": ${xpack.watcher.template.version}
} }

View File

@ -0,0 +1,568 @@
{
"index_patterns": [ ".watcher-history-11*" ],
"order": 2147483647,
"settings": {
"index.number_of_shards": 1,
"index.number_of_replicas": 0,
"index.auto_expand_replicas": "0-1",
"index.lifecycle.name": "watch-history-ilm-policy",
"index.hidden": true,
"index.format": 6
},
"mappings": {
"_doc": {
"_meta": {
"watcher-history-version": "11"
},
"dynamic_templates": [
{
"disabled_payload_fields": {
"path_match": "result\\.(input(\\..+)*|(transform(\\..+)*)|(actions\\.transform(\\..+)*))\\.payload",
"match_pattern": "regex",
"mapping": {
"type": "object",
"enabled": false
}
}
},
{
"disabled_search_request_body_fields": {
"path_match": "result\\.(input(\\..+)*|(transform(\\..+)*)|(actions\\.transform(\\..+)*))\\.search\\.request\\.(body|template)",
"match_pattern": "regex",
"mapping": {
"type": "object",
"enabled": false
}
}
},
{
"disabled_exception_fields": {
"path_match": "result\\.(input(\\..+)*|(transform(\\..+)*)|(actions\\.transform(\\..+)*)|actions)\\.error",
"match_pattern": "regex",
"mapping": {
"type": "object",
"enabled": false
}
}
},
{
"disabled_jira_custom_fields": {
"path_match": "result.actions.jira.fields.customfield_*",
"mapping": {
"type": "object",
"enabled": false
}
}
}
],
"dynamic": false,
"properties": {
"watch_id": {
"type": "keyword"
},
"node": {
"type": "keyword"
},
"trigger_event": {
"type": "object",
"dynamic": true,
"properties": {
"type" : {
"type" : "keyword"
},
"triggered_time": {
"type": "date"
},
"manual": {
"type": "object",
"dynamic": true,
"properties": {
"schedule": {
"type": "object",
"dynamic": true,
"properties": {
"scheduled_time": {
"type": "date"
}
}
}
}
},
"schedule": {
"type": "object",
"dynamic": true,
"properties": {
"scheduled_time": {
"type": "date"
}
}
}
}
},
"vars" : {
"type" : "object",
"enabled" : false
},
"input": {
"type": "object",
"enabled": false
},
"condition": {
"type": "object",
"enabled": false
},
"state": {
"type": "keyword"
},
"status": {
"type": "object",
"enabled" : false,
"dynamic" : true
},
"messages": {
"type": "text"
},
"user": {
"type": "text"
},
"exception" : {
"type" : "object",
"enabled" : false
},
"result": {
"type": "object",
"dynamic": true,
"properties": {
"execution_time": {
"type": "date"
},
"execution_duration": {
"type": "long"
},
"input": {
"type": "object",
"dynamic": true,
"properties": {
"type" : {
"type" : "keyword"
},
"status" : {
"type" : "keyword"
},
"payload" : {
"type" : "object",
"enabled" : false
},
"search": {
"type": "object",
"dynamic": true,
"properties": {
"request": {
"type": "object",
"dynamic": true,
"properties": {
"search_type": {
"type": "keyword"
},
"indices": {
"type": "keyword"
},
"types": {
"type": "keyword"
}
}
}
}
},
"http": {
"type": "object",
"dynamic": true,
"properties": {
"request": {
"type": "object",
"dynamic": true,
"properties": {
"path": {
"type": "keyword"
},
"host": {
"type": "keyword"
}
}
}
}
}
}
},
"condition" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"type" : {
"type" : "keyword"
},
"status" : {
"type" : "keyword"
},
"met" : {
"type" : "boolean"
},
"compare" : {
"type" : "object",
"enabled" : false
},
"array_compare" : {
"type" : "object",
"enabled" : false
},
"script" : {
"type" : "object",
"enabled" : false
}
}
},
"transform" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"type" : {
"type" : "keyword"
},
"search" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"request" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"indices" : {
"type" : "keyword"
},
"types" : {
"type" : "keyword"
}
}
}
}
}
}
},
"actions": {
"type": "nested",
"include_in_parent": true,
"dynamic": true,
"properties": {
"id" : {
"type" : "keyword"
},
"type" : {
"type" : "keyword"
},
"status" : {
"type" : "keyword"
},
"reason" : {
"type" : "keyword"
},
"number_of_actions_executed": {
"type": "integer"
},
"foreach" : {
"type": "object",
"enabled" : false
},
"email": {
"type": "object",
"dynamic": true,
"properties": {
"message": {
"type": "object",
"dynamic": true,
"properties": {
"id": {
"type": "keyword"
},
"from": {
"type": "keyword"
},
"reply_to": {
"type": "keyword"
},
"to": {
"type": "keyword"
},
"cc": {
"type": "keyword"
},
"bcc": {
"type": "keyword"
}
}
}
}
},
"webhook": {
"type": "object",
"dynamic": true,
"properties": {
"request": {
"type": "object",
"dynamic": true,
"properties": {
"path": {
"type": "keyword"
},
"host": {
"type": "keyword"
}
}
}
}
},
"index": {
"type": "object",
"dynamic": true,
"properties": {
"response": {
"type": "object",
"dynamic": true,
"properties": {
"index": {
"type": "keyword"
},
"type": {
"type": "keyword"
},
"id": {
"type": "keyword"
}
}
}
}
},
"jira" : {
"type": "object",
"dynamic": true,
"properties": {
"account": {
"type": "keyword"
},
"reason": {
"type": "text"
},
"request" : {
"type" : "object",
"enabled" : false
},
"response" : {
"type" : "object",
"enabled" : false
},
"fields": {
"type": "object",
"dynamic": true,
"properties": {
"summary": {
"type": "text"
},
"description": {
"type": "text"
},
"labels" : {
"type": "text"
},
"project" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"key" : {
"type" : "keyword"
},
"id" : {
"type" : "keyword"
}
}
},
"issuetype" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"name" : {
"type": "keyword"
},
"id" : {
"type" : "keyword"
}
}
}
}
},
"result": {
"type": "object",
"dynamic": true,
"properties" : {
"id" : {
"type" : "keyword"
},
"key" : {
"type" : "keyword"
},
"self" : {
"type" : "keyword"
}
}
}
}
},
"slack" : {
"type": "object",
"dynamic": true,
"properties": {
"account": {
"type": "keyword"
},
"sent_messages": {
"type": "nested",
"include_in_parent": true,
"dynamic": true,
"properties": {
"status": {
"type": "keyword"
},
"reason": {
"type": "text"
},
"request" : {
"type" : "object",
"enabled" : false
},
"response" : {
"type" : "object",
"enabled" : false
},
"to" : {
"type": "keyword"
},
"message" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"from" : {
"type" : "text"
},
"icon" : {
"type" : "keyword"
},
"text" : {
"type" : "text"
},
"attachments" : {
"type" : "nested",
"include_in_parent": true,
"dynamic" : true,
"properties" : {
"color" : {
"type" : "keyword"
},
"fields" : {
"properties" : {
"value" : {
"type" : "text"
}
}
}
}
}
}
}
}
}
}
},
"pagerduty" : {
"type": "object",
"dynamic": true,
"properties": {
"account": {
"type": "keyword"
},
"sent_event": {
"type": "nested",
"include_in_parent": true,
"dynamic": true,
"properties": {
"reason": {
"type": "text"
},
"request" : {
"type" : "object",
"enabled" : false
},
"response" : {
"type" : "object",
"enabled" : false
},
"event" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"type" : {
"type" : "keyword"
},
"client" : {
"type" : "text"
},
"client_url" : {
"type" : "keyword"
},
"account" : {
"type" : "keyword"
},
"attach_payload" : {
"type" : "boolean"
},
"incident_key" : {
"type" : "keyword"
},
"description" : {
"type" : "text"
},
"context" : {
"type" : "nested",
"include_in_parent": true,
"dynamic" : true,
"properties" : {
"type" : {
"type" : "keyword"
},
"href" : {
"type" : "keyword"
},
"src" : {
"type" : "keyword"
},
"alt" : {
"type" : "text"
}
}
}
}
}
}
}
}
}
}
}
}
},
"metadata": {
"type": "object",
"dynamic": true
}
}
}
},
"version": 11
}

View File

@ -0,0 +1,617 @@
{
"index_patterns": [ ".watcher-history-11*" ],
"order": 2147483646,
"settings": {
"index.number_of_shards": 1,
"index.number_of_replicas": 0,
"index.auto_expand_replicas": "0-1",
"index.hidden": true,
"index.format": 6
},
"mappings": {
"doc": {
"_meta": {
"watcher-history-version": "11"
},
"dynamic_templates": [
{
"disabled_payload_fields": {
"path_match": "result\\.(input(\\..+)*|(transform(\\..+)*)|(actions\\.transform(\\..+)*))\\.payload",
"match_pattern": "regex",
"mapping": {
"type": "object",
"enabled": false
}
}
},
{
"disabled_search_request_body_fields": {
"path_match": "result\\.(input(\\..+)*|(transform(\\..+)*)|(actions\\.transform(\\..+)*))\\.search\\.request\\.(body|template)",
"match_pattern": "regex",
"mapping": {
"type": "object",
"enabled": false
}
}
},
{
"disabled_exception_fields": {
"path_match": "result\\.(input(\\..+)*|(transform(\\..+)*)|(actions\\.transform(\\..+)*)|actions)\\.error",
"match_pattern": "regex",
"mapping": {
"type": "object",
"enabled": false
}
}
},
{
"disabled_jira_custom_fields": {
"path_match": "result.actions.jira.fields.customfield_*",
"mapping": {
"type": "object",
"enabled": false
}
}
}
],
"dynamic": false,
"properties": {
"watch_id": {
"type": "keyword"
},
"node": {
"type": "keyword"
},
"trigger_event": {
"type": "object",
"dynamic": true,
"properties": {
"type" : {
"type" : "keyword"
},
"triggered_time": {
"type": "date"
},
"manual": {
"type": "object",
"dynamic": true,
"properties": {
"schedule": {
"type": "object",
"dynamic": true,
"properties": {
"scheduled_time": {
"type": "date"
}
}
}
}
},
"schedule": {
"type": "object",
"dynamic": true,
"properties": {
"scheduled_time": {
"type": "date"
}
}
}
}
},
"vars" : {
"type" : "object",
"enabled" : false
},
"input": {
"type": "object",
"enabled": false
},
"condition": {
"type": "object",
"enabled": false
},
"state": {
"type": "keyword"
},
"status": {
"type": "object",
"enabled" : false,
"dynamic" : true
},
"messages": {
"type": "text"
},
"user": {
"type": "text"
},
"exception" : {
"type" : "object",
"enabled" : false
},
"result": {
"type": "object",
"dynamic": true,
"properties": {
"execution_time": {
"type": "date"
},
"execution_duration": {
"type": "long"
},
"input": {
"type": "object",
"dynamic": true,
"properties": {
"type" : {
"type" : "keyword"
},
"status" : {
"type" : "keyword"
},
"payload" : {
"type" : "object",
"enabled" : false
},
"search": {
"type": "object",
"dynamic": true,
"properties": {
"request": {
"type": "object",
"dynamic": true,
"properties": {
"search_type": {
"type": "keyword"
},
"indices": {
"type": "keyword"
},
"types": {
"type": "keyword"
}
}
}
}
},
"http": {
"type": "object",
"dynamic": true,
"properties": {
"request": {
"type": "object",
"dynamic": true,
"properties": {
"path": {
"type": "keyword"
},
"host": {
"type": "keyword"
}
}
}
}
}
}
},
"condition" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"type" : {
"type" : "keyword"
},
"status" : {
"type" : "keyword"
},
"met" : {
"type" : "boolean"
},
"compare" : {
"type" : "object",
"enabled" : false
},
"array_compare" : {
"type" : "object",
"enabled" : false
},
"script" : {
"type" : "object",
"enabled" : false
}
}
},
"transform" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"type" : {
"type" : "keyword"
},
"search" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"request" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"indices" : {
"type" : "keyword"
},
"types" : {
"type" : "keyword"
}
}
}
}
}
}
},
"actions": {
"type": "nested",
"include_in_parent": true,
"dynamic": true,
"properties": {
"id" : {
"type" : "keyword"
},
"type" : {
"type" : "keyword"
},
"status" : {
"type" : "keyword"
},
"reason" : {
"type" : "keyword"
},
"email": {
"type": "object",
"dynamic": true,
"properties": {
"message": {
"type": "object",
"dynamic": true,
"properties": {
"id": {
"type": "keyword"
},
"from": {
"type": "keyword"
},
"reply_to": {
"type": "keyword"
},
"to": {
"type": "keyword"
},
"cc": {
"type": "keyword"
},
"bcc": {
"type": "keyword"
}
}
}
}
},
"webhook": {
"type": "object",
"dynamic": true,
"properties": {
"request": {
"type": "object",
"dynamic": true,
"properties": {
"path": {
"type": "keyword"
},
"host": {
"type": "keyword"
}
}
}
}
},
"index": {
"type": "object",
"dynamic": true,
"properties": {
"response": {
"type": "object",
"dynamic": true,
"properties": {
"index": {
"type": "keyword"
},
"type": {
"type": "keyword"
},
"id": {
"type": "keyword"
}
}
}
}
},
"hipchat" : {
"type": "object",
"dynamic": true,
"properties": {
"account": {
"type": "keyword"
},
"sent_messages": {
"type": "nested",
"include_in_parent": true,
"dynamic": true,
"properties": {
"status": {
"type": "keyword"
},
"reason": {
"type": "text"
},
"request" : {
"type" : "object",
"enabled" : false
},
"response" : {
"type" : "object",
"enabled" : false
},
"room" : {
"type": "keyword"
},
"user" : {
"type": "keyword"
},
"message" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"message_format" : {
"type" : "keyword"
},
"color" : {
"type" : "keyword"
},
"notify" : {
"type" : "boolean"
},
"message" : {
"type" : "text"
},
"from" : {
"type" : "text"
}
}
}
}
}
}
},
"jira" : {
"type": "object",
"dynamic": true,
"properties": {
"account": {
"type": "keyword"
},
"reason": {
"type": "text"
},
"request" : {
"type" : "object",
"enabled" : false
},
"response" : {
"type" : "object",
"enabled" : false
},
"fields": {
"type": "object",
"dynamic": true,
"properties": {
"summary": {
"type": "text"
},
"description": {
"type": "text"
},
"labels" : {
"type": "text"
},
"project" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"key" : {
"type" : "keyword"
},
"id" : {
"type" : "keyword"
}
}
},
"issuetype" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"name" : {
"type": "keyword"
},
"id" : {
"type" : "keyword"
}
}
}
}
},
"result": {
"type": "object",
"dynamic": true,
"properties" : {
"id" : {
"type" : "keyword"
},
"key" : {
"type" : "keyword"
},
"self" : {
"type" : "keyword"
}
}
}
}
},
"slack" : {
"type": "object",
"dynamic": true,
"properties": {
"account": {
"type": "keyword"
},
"sent_messages": {
"type": "nested",
"include_in_parent": true,
"dynamic": true,
"properties": {
"status": {
"type": "keyword"
},
"reason": {
"type": "text"
},
"request" : {
"type" : "object",
"enabled" : false
},
"response" : {
"type" : "object",
"enabled" : false
},
"to" : {
"type": "keyword"
},
"message" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"from" : {
"type" : "text"
},
"icon" : {
"type" : "keyword"
},
"text" : {
"type" : "text"
},
"attachments" : {
"type" : "nested",
"include_in_parent": true,
"dynamic" : true,
"properties" : {
"color" : {
"type" : "keyword"
},
"fields" : {
"properties" : {
"value" : {
"type" : "text"
}
}
}
}
}
}
}
}
}
}
},
"pagerduty" : {
"type": "object",
"dynamic": true,
"properties": {
"account": {
"type": "keyword"
},
"sent_event": {
"type": "nested",
"include_in_parent": true,
"dynamic": true,
"properties": {
"reason": {
"type": "text"
},
"request" : {
"type" : "object",
"enabled" : false
},
"response" : {
"type" : "object",
"enabled" : false
},
"event" : {
"type" : "object",
"dynamic" : true,
"properties" : {
"type" : {
"type" : "keyword"
},
"client" : {
"type" : "text"
},
"client_url" : {
"type" : "keyword"
},
"account" : {
"type" : "keyword"
},
"attach_payload" : {
"type" : "boolean"
},
"incident_key" : {
"type" : "keyword"
},
"description" : {
"type" : "text"
},
"context" : {
"type" : "nested",
"include_in_parent": true,
"dynamic" : true,
"properties" : {
"type" : {
"type" : "keyword"
},
"href" : {
"type" : "keyword"
},
"src" : {
"type" : "keyword"
},
"alt" : {
"type" : "text"
}
}
}
}
}
}
}
}
}
}
}
}
},
"metadata": {
"type": "object",
"dynamic": true
}
}
}
},
"version": 11
}

View File

@ -1,15 +1,15 @@
{ {
"index_patterns": [ ".watcher-history-${xpack.watcher.template.version}*" ], "index_patterns": [ ".watcher-history-${xpack.watcher.template.version}*" ],
"order": 2147483646, "priority": 2147483646,
"settings": { "template": {
"index.number_of_shards": 1, "settings": {
"index.number_of_replicas": 0, "index.number_of_shards": 1,
"index.auto_expand_replicas": "0-1", "index.number_of_replicas": 0,
"index.hidden": true, "index.auto_expand_replicas": "0-1",
"index.format": 6 "index.hidden": true,
}, "index.format": 6
"mappings": { },
"doc": { "mappings": {
"_meta": { "_meta": {
"watcher-history-version": "${xpack.watcher.template.version}" "watcher-history-version": "${xpack.watcher.template.version}"
}, },
@ -46,7 +46,7 @@
}, },
{ {
"disabled_jira_custom_fields": { "disabled_jira_custom_fields": {
"path_match": "result.actions.jira.fields.customfield_*", "path_match": "result.actions.jira.fields.customfield_*",
"mapping": { "mapping": {
"type": "object", "type": "object",
"enabled": false "enabled": false
@ -66,8 +66,8 @@
"type": "object", "type": "object",
"dynamic": true, "dynamic": true,
"properties": { "properties": {
"type" : { "type": {
"type" : "keyword" "type": "keyword"
}, },
"triggered_time": { "triggered_time": {
"type": "date" "type": "date"
@ -98,9 +98,9 @@
} }
} }
}, },
"vars" : { "vars": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"input": { "input": {
"type": "object", "type": "object",
@ -115,8 +115,8 @@
}, },
"status": { "status": {
"type": "object", "type": "object",
"enabled" : false, "enabled": false,
"dynamic" : true "dynamic": true
}, },
"messages": { "messages": {
"type": "text" "type": "text"
@ -124,9 +124,9 @@
"user": { "user": {
"type": "text" "type": "text"
}, },
"exception" : { "exception": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"result": { "result": {
"type": "object", "type": "object",
@ -142,15 +142,15 @@
"type": "object", "type": "object",
"dynamic": true, "dynamic": true,
"properties": { "properties": {
"type" : { "type": {
"type" : "keyword" "type": "keyword"
}, },
"status" : { "status": {
"type" : "keyword" "type": "keyword"
}, },
"payload" : { "payload": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"search": { "search": {
"type": "object", "type": "object",
@ -193,53 +193,53 @@
} }
} }
}, },
"condition" : { "condition": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"type" : { "type": {
"type" : "keyword" "type": "keyword"
}, },
"status" : { "status": {
"type" : "keyword" "type": "keyword"
}, },
"met" : { "met": {
"type" : "boolean" "type": "boolean"
}, },
"compare" : { "compare": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"array_compare" : { "array_compare": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"script" : { "script": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
} }
} }
}, },
"transform" : { "transform": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"type" : { "type": {
"type" : "keyword" "type": "keyword"
}, },
"search" : { "search": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"request" : { "request": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"indices" : { "indices": {
"type" : "keyword" "type": "keyword"
}, },
"types" : { "types": {
"type" : "keyword" "type": "keyword"
} }
} }
} }
@ -252,17 +252,17 @@
"include_in_parent": true, "include_in_parent": true,
"dynamic": true, "dynamic": true,
"properties": { "properties": {
"id" : { "id": {
"type" : "keyword" "type": "keyword"
}, },
"type" : { "type": {
"type" : "keyword" "type": "keyword"
}, },
"status" : { "status": {
"type" : "keyword" "type": "keyword"
}, },
"reason" : { "reason": {
"type" : "keyword" "type": "keyword"
}, },
"email": { "email": {
"type": "object", "type": "object",
@ -333,7 +333,7 @@
} }
} }
}, },
"hipchat" : { "hipchat": {
"type": "object", "type": "object",
"dynamic": true, "dynamic": true,
"properties": { "properties": {
@ -351,38 +351,38 @@
"reason": { "reason": {
"type": "text" "type": "text"
}, },
"request" : { "request": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"response" : { "response": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"room" : { "room": {
"type": "keyword" "type": "keyword"
}, },
"user" : { "user": {
"type": "keyword" "type": "keyword"
}, },
"message" : { "message": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"message_format" : { "message_format": {
"type" : "keyword" "type": "keyword"
}, },
"color" : { "color": {
"type" : "keyword" "type": "keyword"
}, },
"notify" : { "notify": {
"type" : "boolean" "type": "boolean"
}, },
"message" : { "message": {
"type" : "text" "type": "text"
}, },
"from" : { "from": {
"type" : "text" "type": "text"
} }
} }
} }
@ -390,7 +390,7 @@
} }
} }
}, },
"jira" : { "jira": {
"type": "object", "type": "object",
"dynamic": true, "dynamic": true,
"properties": { "properties": {
@ -400,13 +400,13 @@
"reason": { "reason": {
"type": "text" "type": "text"
}, },
"request" : { "request": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"response" : { "response": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"fields": { "fields": {
"type": "object", "type": "object",
@ -418,30 +418,30 @@
"description": { "description": {
"type": "text" "type": "text"
}, },
"labels" : { "labels": {
"type": "text" "type": "text"
}, },
"project" : { "project": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"key" : { "key": {
"type" : "keyword" "type": "keyword"
}, },
"id" : { "id": {
"type" : "keyword" "type": "keyword"
} }
} }
}, },
"issuetype" : { "issuetype": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"name" : { "name": {
"type": "keyword" "type": "keyword"
}, },
"id" : { "id": {
"type" : "keyword" "type": "keyword"
} }
} }
} }
@ -450,21 +450,21 @@
"result": { "result": {
"type": "object", "type": "object",
"dynamic": true, "dynamic": true,
"properties" : { "properties": {
"id" : { "id": {
"type" : "keyword" "type": "keyword"
}, },
"key" : { "key": {
"type" : "keyword" "type": "keyword"
}, },
"self" : { "self": {
"type" : "keyword" "type": "keyword"
} }
} }
} }
} }
}, },
"slack" : { "slack": {
"type": "object", "type": "object",
"dynamic": true, "dynamic": true,
"properties": { "properties": {
@ -482,42 +482,42 @@
"reason": { "reason": {
"type": "text" "type": "text"
}, },
"request" : { "request": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"response" : { "response": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"to" : { "to": {
"type": "keyword" "type": "keyword"
}, },
"message" : { "message": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"from" : { "from": {
"type" : "text" "type": "text"
}, },
"icon" : { "icon": {
"type" : "keyword" "type": "keyword"
}, },
"text" : { "text": {
"type" : "text" "type": "text"
}, },
"attachments" : { "attachments": {
"type" : "nested", "type": "nested",
"include_in_parent": true, "include_in_parent": true,
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"color" : { "color": {
"type" : "keyword" "type": "keyword"
}, },
"fields" : { "fields": {
"properties" : { "properties": {
"value" : { "value": {
"type" : "text" "type": "text"
} }
} }
} }
@ -529,7 +529,7 @@
} }
} }
}, },
"pagerduty" : { "pagerduty": {
"type": "object", "type": "object",
"dynamic": true, "dynamic": true,
"properties": { "properties": {
@ -544,55 +544,55 @@
"reason": { "reason": {
"type": "text" "type": "text"
}, },
"request" : { "request": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"response" : { "response": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"event" : { "event": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"type" : { "type": {
"type" : "keyword" "type": "keyword"
}, },
"client" : { "client": {
"type" : "text" "type": "text"
}, },
"client_url" : { "client_url": {
"type" : "keyword" "type": "keyword"
}, },
"account" : { "account": {
"type" : "keyword" "type": "keyword"
}, },
"attach_payload" : { "attach_payload": {
"type" : "boolean" "type": "boolean"
}, },
"incident_key" : { "incident_key": {
"type" : "keyword" "type": "keyword"
}, },
"description" : { "description": {
"type" : "text" "type": "text"
}, },
"context" : { "context": {
"type" : "nested", "type": "nested",
"include_in_parent": true, "include_in_parent": true,
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"type" : { "type": {
"type" : "keyword" "type": "keyword"
}, },
"href" : { "href": {
"type" : "keyword" "type": "keyword"
}, },
"src" : { "src": {
"type" : "keyword" "type": "keyword"
}, },
"alt" : { "alt": {
"type" : "text" "type": "text"
} }
} }
} }
@ -613,5 +613,9 @@
} }
} }
}, },
"_meta": {
"description": "index template for watcher history indices",
"managed": true
},
"version": ${xpack.watcher.template.version} "version": ${xpack.watcher.template.version}
} }

View File

@ -1,16 +1,16 @@
{ {
"index_patterns": [ ".watcher-history-${xpack.watcher.template.version}*" ], "index_patterns": [ ".watcher-history-${xpack.watcher.template.version}*" ],
"order": 2147483647, "priority": 2147483647,
"settings": { "template": {
"index.number_of_shards": 1, "settings": {
"index.number_of_replicas": 0, "index.number_of_shards": 1,
"index.auto_expand_replicas": "0-1", "index.number_of_replicas": 0,
"index.lifecycle.name": "watch-history-ilm-policy", "index.auto_expand_replicas": "0-1",
"index.hidden": true, "index.lifecycle.name": "watch-history-ilm-policy",
"index.format": 6 "index.hidden": true,
}, "index.format": 6
"mappings": { },
"_doc": { "mappings": {
"_meta": { "_meta": {
"watcher-history-version": "${xpack.watcher.template.version}" "watcher-history-version": "${xpack.watcher.template.version}"
}, },
@ -47,7 +47,7 @@
}, },
{ {
"disabled_jira_custom_fields": { "disabled_jira_custom_fields": {
"path_match": "result.actions.jira.fields.customfield_*", "path_match": "result.actions.jira.fields.customfield_*",
"mapping": { "mapping": {
"type": "object", "type": "object",
"enabled": false "enabled": false
@ -67,8 +67,8 @@
"type": "object", "type": "object",
"dynamic": true, "dynamic": true,
"properties": { "properties": {
"type" : { "type": {
"type" : "keyword" "type": "keyword"
}, },
"triggered_time": { "triggered_time": {
"type": "date" "type": "date"
@ -99,9 +99,9 @@
} }
} }
}, },
"vars" : { "vars": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"input": { "input": {
"type": "object", "type": "object",
@ -116,8 +116,8 @@
}, },
"status": { "status": {
"type": "object", "type": "object",
"enabled" : false, "enabled": false,
"dynamic" : true "dynamic": true
}, },
"messages": { "messages": {
"type": "text" "type": "text"
@ -125,9 +125,9 @@
"user": { "user": {
"type": "text" "type": "text"
}, },
"exception" : { "exception": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"result": { "result": {
"type": "object", "type": "object",
@ -143,15 +143,15 @@
"type": "object", "type": "object",
"dynamic": true, "dynamic": true,
"properties": { "properties": {
"type" : { "type": {
"type" : "keyword" "type": "keyword"
}, },
"status" : { "status": {
"type" : "keyword" "type": "keyword"
}, },
"payload" : { "payload": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"search": { "search": {
"type": "object", "type": "object",
@ -194,53 +194,53 @@
} }
} }
}, },
"condition" : { "condition": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"type" : { "type": {
"type" : "keyword" "type": "keyword"
}, },
"status" : { "status": {
"type" : "keyword" "type": "keyword"
}, },
"met" : { "met": {
"type" : "boolean" "type": "boolean"
}, },
"compare" : { "compare": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"array_compare" : { "array_compare": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"script" : { "script": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
} }
} }
}, },
"transform" : { "transform": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"type" : { "type": {
"type" : "keyword" "type": "keyword"
}, },
"search" : { "search": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"request" : { "request": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"indices" : { "indices": {
"type" : "keyword" "type": "keyword"
}, },
"types" : { "types": {
"type" : "keyword" "type": "keyword"
} }
} }
} }
@ -253,24 +253,24 @@
"include_in_parent": true, "include_in_parent": true,
"dynamic": true, "dynamic": true,
"properties": { "properties": {
"id" : { "id": {
"type" : "keyword" "type": "keyword"
}, },
"type" : { "type": {
"type" : "keyword" "type": "keyword"
}, },
"status" : { "status": {
"type" : "keyword" "type": "keyword"
}, },
"reason" : { "reason": {
"type" : "keyword" "type": "keyword"
}, },
"number_of_actions_executed": { "number_of_actions_executed": {
"type": "integer" "type": "integer"
}, },
"foreach" : { "foreach": {
"type": "object", "type": "object",
"enabled" : false "enabled": false
}, },
"email": { "email": {
"type": "object", "type": "object",
@ -341,7 +341,7 @@
} }
} }
}, },
"jira" : { "jira": {
"type": "object", "type": "object",
"dynamic": true, "dynamic": true,
"properties": { "properties": {
@ -351,13 +351,13 @@
"reason": { "reason": {
"type": "text" "type": "text"
}, },
"request" : { "request": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"response" : { "response": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"fields": { "fields": {
"type": "object", "type": "object",
@ -369,30 +369,30 @@
"description": { "description": {
"type": "text" "type": "text"
}, },
"labels" : { "labels": {
"type": "text" "type": "text"
}, },
"project" : { "project": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"key" : { "key": {
"type" : "keyword" "type": "keyword"
}, },
"id" : { "id": {
"type" : "keyword" "type": "keyword"
} }
} }
}, },
"issuetype" : { "issuetype": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"name" : { "name": {
"type": "keyword" "type": "keyword"
}, },
"id" : { "id": {
"type" : "keyword" "type": "keyword"
} }
} }
} }
@ -401,21 +401,21 @@
"result": { "result": {
"type": "object", "type": "object",
"dynamic": true, "dynamic": true,
"properties" : { "properties": {
"id" : { "id": {
"type" : "keyword" "type": "keyword"
}, },
"key" : { "key": {
"type" : "keyword" "type": "keyword"
}, },
"self" : { "self": {
"type" : "keyword" "type": "keyword"
} }
} }
} }
} }
}, },
"slack" : { "slack": {
"type": "object", "type": "object",
"dynamic": true, "dynamic": true,
"properties": { "properties": {
@ -433,42 +433,42 @@
"reason": { "reason": {
"type": "text" "type": "text"
}, },
"request" : { "request": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"response" : { "response": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"to" : { "to": {
"type": "keyword" "type": "keyword"
}, },
"message" : { "message": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"from" : { "from": {
"type" : "text" "type": "text"
}, },
"icon" : { "icon": {
"type" : "keyword" "type": "keyword"
}, },
"text" : { "text": {
"type" : "text" "type": "text"
}, },
"attachments" : { "attachments": {
"type" : "nested", "type": "nested",
"include_in_parent": true, "include_in_parent": true,
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"color" : { "color": {
"type" : "keyword" "type": "keyword"
}, },
"fields" : { "fields": {
"properties" : { "properties": {
"value" : { "value": {
"type" : "text" "type": "text"
} }
} }
} }
@ -480,7 +480,7 @@
} }
} }
}, },
"pagerduty" : { "pagerduty": {
"type": "object", "type": "object",
"dynamic": true, "dynamic": true,
"properties": { "properties": {
@ -495,55 +495,55 @@
"reason": { "reason": {
"type": "text" "type": "text"
}, },
"request" : { "request": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"response" : { "response": {
"type" : "object", "type": "object",
"enabled" : false "enabled": false
}, },
"event" : { "event": {
"type" : "object", "type": "object",
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"type" : { "type": {
"type" : "keyword" "type": "keyword"
}, },
"client" : { "client": {
"type" : "text" "type": "text"
}, },
"client_url" : { "client_url": {
"type" : "keyword" "type": "keyword"
}, },
"account" : { "account": {
"type" : "keyword" "type": "keyword"
}, },
"attach_payload" : { "attach_payload": {
"type" : "boolean" "type": "boolean"
}, },
"incident_key" : { "incident_key": {
"type" : "keyword" "type": "keyword"
}, },
"description" : { "description": {
"type" : "text" "type": "text"
}, },
"context" : { "context": {
"type" : "nested", "type": "nested",
"include_in_parent": true, "include_in_parent": true,
"dynamic" : true, "dynamic": true,
"properties" : { "properties": {
"type" : { "type": {
"type" : "keyword" "type": "keyword"
}, },
"href" : { "href": {
"type" : "keyword" "type": "keyword"
}, },
"src" : { "src": {
"type" : "keyword" "type": "keyword"
}, },
"alt" : { "alt": {
"type" : "text" "type": "text"
} }
} }
} }
@ -564,5 +564,9 @@
} }
} }
}, },
"_meta": {
"description": "index template for watcher history indices",
"managed": true
},
"version": ${xpack.watcher.template.version} "version": ${xpack.watcher.template.version}
} }

View File

@ -0,0 +1,63 @@
{
"index_patterns": [ ".watches*" ],
"order": 2147483647,
"settings": {
"index.number_of_shards": 1,
"index.number_of_replicas": 0,
"index.auto_expand_replicas": "0-1",
"index.format": 6,
"index.priority": 800
},
"mappings": {
"_doc": {
"dynamic" : "strict",
"properties": {
"status": {
"type": "object",
"enabled" : false,
"dynamic" : true
},
"trigger" : {
"type": "object",
"enabled" : false,
"dynamic" : true
},
"input": {
"type": "object",
"enabled" : false,
"dynamic" : true
},
"condition": {
"type": "object",
"enabled" : false,
"dynamic" : true
},
"throttle_period": {
"type" : "keyword",
"index" : false,
"doc_values" : false
},
"throttle_period_in_millis": {
"type" : "long",
"index" : false,
"doc_values" : false
},
"transform": {
"type" : "object",
"enabled" : false,
"dynamic" : true
},
"actions": {
"type" : "object",
"enabled" : false,
"dynamic" : true
},
"metadata" : {
"type" : "object",
"dynamic": true
}
}
}
},
"version": 11
}

View File

@ -1,63 +1,67 @@
{ {
"index_patterns": [ ".watches*" ], "index_patterns": [ ".watches*" ],
"order": 2147483647, "priority": 2147483647,
"settings": { "template": {
"index.number_of_shards": 1, "settings": {
"index.number_of_replicas": 0, "index.number_of_shards": 1,
"index.auto_expand_replicas": "0-1", "index.number_of_replicas": 0,
"index.format": 6, "index.auto_expand_replicas": "0-1",
"index.priority": 800 "index.format": 6,
}, "index.priority": 800
"mappings": { },
"_doc": { "mappings": {
"dynamic" : "strict", "dynamic": "strict",
"properties": { "properties": {
"status": { "status": {
"type": "object", "type": "object",
"enabled" : false, "enabled": false,
"dynamic" : true "dynamic": true
}, },
"trigger" : { "trigger": {
"type": "object", "type": "object",
"enabled" : false, "enabled": false,
"dynamic" : true "dynamic": true
}, },
"input": { "input": {
"type": "object", "type": "object",
"enabled" : false, "enabled": false,
"dynamic" : true "dynamic": true
}, },
"condition": { "condition": {
"type": "object", "type": "object",
"enabled" : false, "enabled": false,
"dynamic" : true "dynamic": true
}, },
"throttle_period": { "throttle_period": {
"type" : "keyword", "type": "keyword",
"index" : false, "index": false,
"doc_values" : false "doc_values": false
}, },
"throttle_period_in_millis": { "throttle_period_in_millis": {
"type" : "long", "type": "long",
"index" : false, "index": false,
"doc_values" : false "doc_values": false
}, },
"transform": { "transform": {
"type" : "object", "type": "object",
"enabled" : false, "enabled": false,
"dynamic" : true "dynamic": true
}, },
"actions": { "actions": {
"type" : "object", "type": "object",
"enabled" : false, "enabled": false,
"dynamic" : true "dynamic": true
}, },
"metadata" : { "metadata": {
"type" : "object", "type": "object",
"dynamic": true "dynamic": true
}
} }
}
} }
}, },
"_meta": {
"description": "index template for watches indices",
"managed": true
},
"version": ${xpack.watcher.template.version} "version": ${xpack.watcher.template.version}
} }

View File

@ -11,22 +11,20 @@ import org.elasticsearch.action.ActionListener;
import org.elasticsearch.action.ActionRequest; import org.elasticsearch.action.ActionRequest;
import org.elasticsearch.action.ActionResponse; import org.elasticsearch.action.ActionResponse;
import org.elasticsearch.action.ActionType; import org.elasticsearch.action.ActionType;
import org.elasticsearch.action.admin.indices.template.put.PutIndexTemplateAction; import org.elasticsearch.action.admin.indices.template.put.PutComposableIndexTemplateAction;
import org.elasticsearch.action.admin.indices.template.put.PutIndexTemplateRequest;
import org.elasticsearch.action.support.master.AcknowledgedResponse; import org.elasticsearch.action.support.master.AcknowledgedResponse;
import org.elasticsearch.cluster.ClusterChangedEvent; import org.elasticsearch.cluster.ClusterChangedEvent;
import org.elasticsearch.cluster.ClusterModule; import org.elasticsearch.cluster.ClusterModule;
import org.elasticsearch.cluster.ClusterName; import org.elasticsearch.cluster.ClusterName;
import org.elasticsearch.cluster.ClusterState; import org.elasticsearch.cluster.ClusterState;
import org.elasticsearch.cluster.block.ClusterBlocks; import org.elasticsearch.cluster.block.ClusterBlocks;
import org.elasticsearch.cluster.metadata.IndexTemplateMetadata; import org.elasticsearch.cluster.metadata.ComposableIndexTemplate;
import org.elasticsearch.cluster.metadata.Metadata; import org.elasticsearch.cluster.metadata.Metadata;
import org.elasticsearch.cluster.node.DiscoveryNode; import org.elasticsearch.cluster.node.DiscoveryNode;
import org.elasticsearch.cluster.node.DiscoveryNodes; import org.elasticsearch.cluster.node.DiscoveryNodes;
import org.elasticsearch.cluster.service.ClusterService; import org.elasticsearch.cluster.service.ClusterService;
import org.elasticsearch.common.ParseField; import org.elasticsearch.common.ParseField;
import org.elasticsearch.common.TriFunction; import org.elasticsearch.common.TriFunction;
import org.elasticsearch.common.collect.ImmutableOpenMap;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.xcontent.LoggingDeprecationHandler; import org.elasticsearch.common.xcontent.LoggingDeprecationHandler;
import org.elasticsearch.common.xcontent.NamedXContentRegistry; import org.elasticsearch.common.xcontent.NamedXContentRegistry;
@ -105,7 +103,7 @@ public class SnapshotLifecycleTemplateRegistryTests extends ESTestCase {
Settings settings = Settings.builder().put(SLM_HISTORY_INDEX_ENABLED_SETTING.getKey(), false).build(); Settings settings = Settings.builder().put(SLM_HISTORY_INDEX_ENABLED_SETTING.getKey(), false).build();
SnapshotLifecycleTemplateRegistry disabledRegistry = new SnapshotLifecycleTemplateRegistry(settings, clusterService, threadPool, SnapshotLifecycleTemplateRegistry disabledRegistry = new SnapshotLifecycleTemplateRegistry(settings, clusterService, threadPool,
client, xContentRegistry); client, xContentRegistry);
assertThat(disabledRegistry.getLegacyTemplateConfigs(), hasSize(0)); assertThat(disabledRegistry.getComposableTemplateConfigs(), hasSize(0));
assertThat(disabledRegistry.getPolicyConfigs(), hasSize(0)); assertThat(disabledRegistry.getPolicyConfigs(), hasSize(0));
} }
@ -119,7 +117,7 @@ public class SnapshotLifecycleTemplateRegistryTests extends ESTestCase {
AtomicInteger calledTimes = new AtomicInteger(0); AtomicInteger calledTimes = new AtomicInteger(0);
client.setVerifier((action, request, listener) -> verifyTemplateInstalled(calledTimes, action, request, listener)); client.setVerifier((action, request, listener) -> verifyTemplateInstalled(calledTimes, action, request, listener));
registry.clusterChanged(event); registry.clusterChanged(event);
assertBusy(() -> assertThat(calledTimes.get(), equalTo(registry.getLegacyTemplateConfigs().size()))); assertBusy(() -> assertThat(calledTimes.get(), equalTo(registry.getComposableTemplateConfigs().size())));
calledTimes.set(0); calledTimes.set(0);
@ -149,7 +147,7 @@ public class SnapshotLifecycleTemplateRegistryTests extends ESTestCase {
assertThat(putRequest.getPolicy().getName(), equalTo(SLM_POLICY_NAME)); assertThat(putRequest.getPolicy().getName(), equalTo(SLM_POLICY_NAME));
assertNotNull(listener); assertNotNull(listener);
return new PutLifecycleAction.Response(true); return new PutLifecycleAction.Response(true);
} else if (action instanceof PutIndexTemplateAction) { } else if (action instanceof PutComposableIndexTemplateAction) {
// Ignore this, it's verified in another test // Ignore this, it's verified in another test
return new TestPutIndexTemplateResponse(true); return new TestPutIndexTemplateResponse(true);
} else { } else {
@ -176,7 +174,7 @@ public class SnapshotLifecycleTemplateRegistryTests extends ESTestCase {
policyMap.put(policy.getName(), policy); policyMap.put(policy.getName(), policy);
client.setVerifier((action, request, listener) -> { client.setVerifier((action, request, listener) -> {
if (action instanceof PutIndexTemplateAction) { if (action instanceof PutComposableIndexTemplateAction) {
// Ignore this, it's verified in another test // Ignore this, it's verified in another test
return new TestPutIndexTemplateResponse(true); return new TestPutIndexTemplateResponse(true);
} else if (action instanceof PutLifecycleAction) { } else if (action instanceof PutLifecycleAction) {
@ -204,7 +202,7 @@ public class SnapshotLifecycleTemplateRegistryTests extends ESTestCase {
LifecyclePolicy policy = policies.get(0); LifecyclePolicy policy = policies.get(0);
client.setVerifier((action, request, listener) -> { client.setVerifier((action, request, listener) -> {
if (action instanceof PutIndexTemplateAction) { if (action instanceof PutComposableIndexTemplateAction) {
// Ignore this, it's verified in another test // Ignore this, it's verified in another test
return new TestPutIndexTemplateResponse(true); return new TestPutIndexTemplateResponse(true);
} else if (action instanceof PutLifecycleAction) { } else if (action instanceof PutLifecycleAction) {
@ -233,7 +231,7 @@ public class SnapshotLifecycleTemplateRegistryTests extends ESTestCase {
AtomicInteger calledTimes = new AtomicInteger(0); AtomicInteger calledTimes = new AtomicInteger(0);
client.setVerifier((action, request, listener) -> verifyTemplateInstalled(calledTimes, action, request, listener)); client.setVerifier((action, request, listener) -> verifyTemplateInstalled(calledTimes, action, request, listener));
registry.clusterChanged(event); registry.clusterChanged(event);
assertBusy(() -> assertThat(calledTimes.get(), equalTo(registry.getLegacyTemplateConfigs().size()))); assertBusy(() -> assertThat(calledTimes.get(), equalTo(registry.getComposableTemplateConfigs().size())));
} }
public void testThatUnversionedOldTemplatesAreUpgraded() throws Exception { public void testThatUnversionedOldTemplatesAreUpgraded() throws Exception {
@ -244,7 +242,7 @@ public class SnapshotLifecycleTemplateRegistryTests extends ESTestCase {
AtomicInteger calledTimes = new AtomicInteger(0); AtomicInteger calledTimes = new AtomicInteger(0);
client.setVerifier((action, request, listener) -> verifyTemplateInstalled(calledTimes, action, request, listener)); client.setVerifier((action, request, listener) -> verifyTemplateInstalled(calledTimes, action, request, listener));
registry.clusterChanged(event); registry.clusterChanged(event);
assertBusy(() -> assertThat(calledTimes.get(), equalTo(registry.getLegacyTemplateConfigs().size()))); assertBusy(() -> assertThat(calledTimes.get(), equalTo(registry.getComposableTemplateConfigs().size())));
} }
@ -256,7 +254,7 @@ public class SnapshotLifecycleTemplateRegistryTests extends ESTestCase {
Collections.singletonMap(SLM_TEMPLATE_NAME, INDEX_TEMPLATE_VERSION), nodes); Collections.singletonMap(SLM_TEMPLATE_NAME, INDEX_TEMPLATE_VERSION), nodes);
AtomicInteger calledTimes = new AtomicInteger(0); AtomicInteger calledTimes = new AtomicInteger(0);
client.setVerifier((action, request, listener) -> { client.setVerifier((action, request, listener) -> {
if (action instanceof PutIndexTemplateAction) { if (action instanceof PutComposableIndexTemplateAction) {
fail("template should not have been re-installed"); fail("template should not have been re-installed");
return null; return null;
} else if (action instanceof PutLifecycleAction) { } else if (action instanceof PutLifecycleAction) {
@ -340,14 +338,14 @@ public class SnapshotLifecycleTemplateRegistryTests extends ESTestCase {
private ActionResponse verifyTemplateInstalled( private ActionResponse verifyTemplateInstalled(
AtomicInteger calledTimes, ActionType<?> action, ActionRequest request, ActionListener<?> listener) { AtomicInteger calledTimes, ActionType<?> action, ActionRequest request, ActionListener<?> listener) {
if (action instanceof PutIndexTemplateAction) { if (action instanceof PutComposableIndexTemplateAction) {
calledTimes.incrementAndGet(); calledTimes.incrementAndGet();
assertThat(action, instanceOf(PutIndexTemplateAction.class)); assertThat(action, instanceOf(PutComposableIndexTemplateAction.class));
assertThat(request, instanceOf(PutIndexTemplateRequest.class)); assertThat(request, instanceOf(PutComposableIndexTemplateAction.Request.class));
final PutIndexTemplateRequest putRequest = (PutIndexTemplateRequest) request; final PutComposableIndexTemplateAction.Request putRequest = (PutComposableIndexTemplateAction.Request) request;
assertThat(putRequest.name(), equalTo(SLM_TEMPLATE_NAME)); assertThat(putRequest.name(), equalTo(SLM_TEMPLATE_NAME));
assertThat(putRequest.settings().get("index.lifecycle.name"), equalTo(SLM_POLICY_NAME)); assertThat(putRequest.indexTemplate().template().settings().get("index.lifecycle.name"), equalTo(SLM_POLICY_NAME));
assertThat(putRequest.version(), equalTo(INDEX_TEMPLATE_VERSION)); assertThat(putRequest.indexTemplate().version(), equalTo((long) INDEX_TEMPLATE_VERSION));
assertNotNull(listener); assertNotNull(listener);
return new TestPutIndexTemplateResponse(true); return new TestPutIndexTemplateResponse(true);
} else if (action instanceof PutLifecycleAction) { } else if (action instanceof PutLifecycleAction) {
@ -377,11 +375,11 @@ public class SnapshotLifecycleTemplateRegistryTests extends ESTestCase {
private ClusterState createClusterState(Settings nodeSettings, Map<String, Integer> existingTemplates, private ClusterState createClusterState(Settings nodeSettings, Map<String, Integer> existingTemplates,
Map<String, LifecyclePolicy> existingPolicies, DiscoveryNodes nodes) { Map<String, LifecyclePolicy> existingPolicies, DiscoveryNodes nodes) {
ImmutableOpenMap.Builder<String, IndexTemplateMetadata> indexTemplates = ImmutableOpenMap.builder(); Map<String, ComposableIndexTemplate> indexTemplates = new HashMap<>();
for (Map.Entry<String, Integer> template : existingTemplates.entrySet()) { for (Map.Entry<String, Integer> template : existingTemplates.entrySet()) {
final IndexTemplateMetadata mockTemplate = mock(IndexTemplateMetadata.class); final ComposableIndexTemplate mockTemplate = mock(ComposableIndexTemplate.class);
when(mockTemplate.version()).thenReturn(template.getValue()); Long version = template.getValue() == null ? null : (long) template.getValue();
when(mockTemplate.getVersion()).thenReturn(template.getValue()); when(mockTemplate.version()).thenReturn(version);
indexTemplates.put(template.getKey(), mockTemplate); indexTemplates.put(template.getKey(), mockTemplate);
} }
@ -392,7 +390,7 @@ public class SnapshotLifecycleTemplateRegistryTests extends ESTestCase {
return ClusterState.builder(new ClusterName("test")) return ClusterState.builder(new ClusterName("test"))
.metadata(Metadata.builder() .metadata(Metadata.builder()
.templates(indexTemplates.build()) .indexTemplates(indexTemplates)
.transientSettings(nodeSettings) .transientSettings(nodeSettings)
.putCustom(IndexLifecycleMetadata.TYPE, ilmMeta) .putCustom(IndexLifecycleMetadata.TYPE, ilmMeta)
.build()) .build())

View File

@ -0,0 +1,135 @@
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License;
* you may not use this file except in compliance with the Elastic License.
*/
package org.elasticsearch.xpack.ilm;
import org.elasticsearch.action.admin.indices.create.CreateIndexResponse;
import org.elasticsearch.action.admin.indices.get.GetIndexResponse;
import org.elasticsearch.action.admin.indices.rollover.RolloverResponse;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.unit.TimeValue;
import org.elasticsearch.plugins.Plugin;
import org.elasticsearch.test.ESIntegTestCase;
import org.elasticsearch.xpack.core.LocalStateCompositeXPackPlugin;
import org.elasticsearch.xpack.core.XPackSettings;
import org.elasticsearch.xpack.core.ilm.LifecyclePolicy;
import org.elasticsearch.xpack.core.ilm.LifecycleSettings;
import org.elasticsearch.xpack.core.ilm.OperationMode;
import org.elasticsearch.xpack.core.ilm.Phase;
import org.elasticsearch.xpack.core.ilm.StopILMRequest;
import org.elasticsearch.xpack.core.ilm.action.GetStatusAction;
import org.elasticsearch.xpack.core.ilm.action.PutLifecycleAction;
import org.elasticsearch.xpack.core.ilm.action.StopILMAction;
import org.elasticsearch.xpack.ilm.history.ILMHistoryStore;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import static org.elasticsearch.cluster.metadata.IndexMetadata.SETTING_NUMBER_OF_REPLICAS;
import static org.elasticsearch.cluster.metadata.IndexMetadata.SETTING_NUMBER_OF_SHARDS;
import static org.elasticsearch.index.query.QueryBuilders.matchQuery;
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertHitCount;
import static org.hamcrest.Matchers.arrayContaining;
import static org.hamcrest.Matchers.is;
@ESIntegTestCase.ClusterScope(scope = ESIntegTestCase.Scope.TEST, numDataNodes = 0)
public class ILMHistoryTests extends ESIntegTestCase {
@Override
protected Settings nodeSettings(int nodeOrdinal) {
Settings.Builder settings = Settings.builder().put(super.nodeSettings(nodeOrdinal));
settings.put(XPackSettings.MACHINE_LEARNING_ENABLED.getKey(), false);
settings.put(XPackSettings.SECURITY_ENABLED.getKey(), false);
settings.put(XPackSettings.WATCHER_ENABLED.getKey(), false);
settings.put(XPackSettings.GRAPH_ENABLED.getKey(), false);
settings.put(LifecycleSettings.LIFECYCLE_POLL_INTERVAL, "1s");
settings.put(LifecycleSettings.SLM_HISTORY_INDEX_ENABLED_SETTING.getKey(), false);
return settings.build();
}
@Override
protected boolean ignoreExternalCluster() {
return true;
}
@Override
protected Collection<Class<? extends Plugin>> nodePlugins() {
return Arrays.asList(LocalStateCompositeXPackPlugin.class, IndexLifecycle.class);
}
@Override
protected Settings transportClientSettings() {
Settings.Builder settings = Settings.builder().put(super.transportClientSettings());
settings.put(XPackSettings.MACHINE_LEARNING_ENABLED.getKey(), false);
settings.put(XPackSettings.SECURITY_ENABLED.getKey(), false);
settings.put(XPackSettings.WATCHER_ENABLED.getKey(), false);
settings.put(XPackSettings.GRAPH_ENABLED.getKey(), false);
return settings.build();
}
@Override
protected Collection<Class<? extends Plugin>> transportClientPlugins() {
return nodePlugins();
}
private void putTestPolicy() throws InterruptedException, java.util.concurrent.ExecutionException {
Phase phase = new Phase("hot", TimeValue.ZERO, Collections.emptyMap());
LifecyclePolicy lifecyclePolicy = new LifecyclePolicy("test", Collections.singletonMap("hot", phase));
PutLifecycleAction.Request putLifecycleRequest = new PutLifecycleAction.Request(lifecyclePolicy);
PutLifecycleAction.Response putLifecycleResponse = client().execute(PutLifecycleAction.INSTANCE, putLifecycleRequest).get();
assertAcked(putLifecycleResponse);
}
public void testIlmHistoryIndexCanRollover() throws Exception {
putTestPolicy();
Settings settings = Settings.builder().put(indexSettings()).put(SETTING_NUMBER_OF_SHARDS, 1)
.put(SETTING_NUMBER_OF_REPLICAS, 0).put(LifecycleSettings.LIFECYCLE_NAME, "test").build();
CreateIndexResponse res = client().admin().indices().prepareCreate("test").setSettings(settings).get();
assertTrue(res.isAcknowledged());
String firstIndex = ILMHistoryStore.ILM_HISTORY_INDEX_PREFIX + "000001";
String secondIndex = ILMHistoryStore.ILM_HISTORY_INDEX_PREFIX + "000002";
assertBusy(() -> {
try {
GetIndexResponse getIndexResponse = client().admin().indices().prepareGetIndex().setIndices(firstIndex).get();
assertThat(getIndexResponse.getIndices(), arrayContaining(firstIndex));
} catch (Exception e) {
fail(e.getMessage());
}
});
//wait for all history items to index to avoid waiting for timeout in ILMHistoryStore beforeBulk
assertBusy(() -> {
try {
SearchResponse search = client().prepareSearch(firstIndex).setQuery(matchQuery("index", firstIndex)).setSize(0).get();
assertHitCount(search, 9);
} catch (Exception e) {
//assertBusy will stop on first non-assertion error and it can happen when we try to search too early
//instead of failing the whole test change it to assertion error and wait some more time
fail(e.getMessage());
}
});
//make sure ILM is stopped so no new items will be queued in ILM history
assertTrue(client().execute(StopILMAction.INSTANCE, new StopILMRequest()).actionGet().isAcknowledged());
assertBusy(() -> {
GetStatusAction.Response status = client().execute(GetStatusAction.INSTANCE, new GetStatusAction.Request()).actionGet();
assertThat(status.getMode(), is(OperationMode.STOPPED));
});
RolloverResponse rolloverResponse = client().admin().indices().prepareRolloverIndex(ILMHistoryStore.ILM_HISTORY_ALIAS).get();
assertTrue(rolloverResponse.isAcknowledged());
assertThat(rolloverResponse.getNewIndex(), is(secondIndex));
GetIndexResponse getIndexResponse = client().admin().indices().prepareGetIndex().setIndices(secondIndex).get();
assertThat(getIndexResponse.getIndices(), arrayContaining(secondIndex));
}
}

View File

@ -182,6 +182,8 @@ public class ILMHistoryStore implements Closeable {
byte[] templateBytes = TEMPLATE_ILM_HISTORY.loadBytes(); byte[] templateBytes = TEMPLATE_ILM_HISTORY.loadBytes();
Map<String, Object> templateAsMap = XContentHelper.convertToMap(new BytesArray(templateBytes, 0, templateBytes.length), Map<String, Object> templateAsMap = XContentHelper.convertToMap(new BytesArray(templateBytes, 0, templateBytes.length),
false, XContentType.JSON).v2(); false, XContentType.JSON).v2();
templateAsMap = (Map<String, Object>) templateAsMap.get("template");
client.admin().indices().prepareCreate(initialHistoryIndexName) client.admin().indices().prepareCreate(initialHistoryIndexName)
.setSettings((Map<String, ?>) templateAsMap.get("settings")) .setSettings((Map<String, ?>) templateAsMap.get("settings"))

View File

@ -28,7 +28,8 @@ public class ILMHistoryTemplateRegistry extends IndexTemplateRegistry {
// history (please add a comment why you increased the version here) // history (please add a comment why you increased the version here)
// version 1: initial // version 1: initial
// version 2: convert to hidden index // version 2: convert to hidden index
public static final int INDEX_TEMPLATE_VERSION = 2; // version 3: templates moved to composable templates
public static final int INDEX_TEMPLATE_VERSION = 3;
public static final String ILM_TEMPLATE_VERSION_VARIABLE = "xpack.ilm_history.template.version"; public static final String ILM_TEMPLATE_VERSION_VARIABLE = "xpack.ilm_history.template.version";
public static final String ILM_TEMPLATE_NAME = "ilm-history"; public static final String ILM_TEMPLATE_NAME = "ilm-history";
@ -62,7 +63,7 @@ public class ILMHistoryTemplateRegistry extends IndexTemplateRegistry {
} }
@Override @Override
protected List<IndexTemplateConfig> getLegacyTemplateConfigs() { protected List<IndexTemplateConfig> getComposableTemplateConfigs() {
if (this.ilmHistoryEnabled) { if (this.ilmHistoryEnabled) {
return Collections.singletonList(TEMPLATE_ILM_HISTORY); return Collections.singletonList(TEMPLATE_ILM_HISTORY);
} else { } else {

View File

@ -11,7 +11,7 @@ import org.elasticsearch.action.admin.indices.alias.Alias;
import org.elasticsearch.action.admin.indices.alias.get.GetAliasesResponse; import org.elasticsearch.action.admin.indices.alias.get.GetAliasesResponse;
import org.elasticsearch.action.admin.indices.create.CreateIndexResponse; import org.elasticsearch.action.admin.indices.create.CreateIndexResponse;
import org.elasticsearch.action.admin.indices.get.GetIndexResponse; import org.elasticsearch.action.admin.indices.get.GetIndexResponse;
import org.elasticsearch.action.admin.indices.template.get.GetIndexTemplatesResponse; import org.elasticsearch.action.admin.indices.template.get.GetComposableIndexTemplateAction;
import org.elasticsearch.action.search.SearchRequestBuilder; import org.elasticsearch.action.search.SearchRequestBuilder;
import org.elasticsearch.action.search.SearchResponse; import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.action.support.IndicesOptions; import org.elasticsearch.action.support.IndicesOptions;
@ -486,12 +486,15 @@ public abstract class AbstractWatcherIntegrationTestCase extends ESIntegTestCase
private void ensureWatcherTemplatesAdded() throws Exception { private void ensureWatcherTemplatesAdded() throws Exception {
// Verify that the index templates exist: // Verify that the index templates exist:
assertBusy(() -> { assertBusy(() -> {
GetIndexTemplatesResponse response = client().admin().indices().prepareGetTemplates(HISTORY_TEMPLATE_NAME).get(); GetComposableIndexTemplateAction.Response response = client().execute(GetComposableIndexTemplateAction.INSTANCE,
assertThat("[" + HISTORY_TEMPLATE_NAME + "] is missing", response.getIndexTemplates().size(), equalTo(1)); new GetComposableIndexTemplateAction.Request(HISTORY_TEMPLATE_NAME)).get();
response = client().admin().indices().prepareGetTemplates(TRIGGERED_TEMPLATE_NAME).get(); assertThat("[" + HISTORY_TEMPLATE_NAME + "] is missing", response.indexTemplates().size(), equalTo(1));
assertThat("[" + TRIGGERED_TEMPLATE_NAME + "] is missing", response.getIndexTemplates().size(), equalTo(1)); response = client().execute(GetComposableIndexTemplateAction.INSTANCE,
response = client().admin().indices().prepareGetTemplates(WATCHES_TEMPLATE_NAME).get(); new GetComposableIndexTemplateAction.Request(TRIGGERED_TEMPLATE_NAME)).get();
assertThat("[" + WATCHES_TEMPLATE_NAME + "] is missing", response.getIndexTemplates().size(), equalTo(1)); assertThat("[" + TRIGGERED_TEMPLATE_NAME + "] is missing", response.indexTemplates().size(), equalTo(1));
response = client().execute(GetComposableIndexTemplateAction.INSTANCE,
new GetComposableIndexTemplateAction.Request(WATCHES_TEMPLATE_NAME)).get();
assertThat("[" + WATCHES_TEMPLATE_NAME + "] is missing", response.indexTemplates().size(), equalTo(1));
}); });
} }

View File

@ -32,6 +32,11 @@ public class WatcherIndexTemplateRegistry extends IndexTemplateRegistry {
"/triggered-watches.json", "/triggered-watches.json",
WatcherIndexTemplateRegistryField.INDEX_TEMPLATE_VERSION, WatcherIndexTemplateRegistryField.INDEX_TEMPLATE_VERSION,
WATCHER_TEMPLATE_VERSION_VARIABLE); WATCHER_TEMPLATE_VERSION_VARIABLE);
public static final IndexTemplateConfig TEMPLATE_CONFIG_TRIGGERED_WATCHES_11 = new IndexTemplateConfig(
WatcherIndexTemplateRegistryField.TRIGGERED_TEMPLATE_NAME_11,
"/triggered-watches-11.json",
11,
WATCHER_TEMPLATE_VERSION_VARIABLE);
public static final IndexTemplateConfig TEMPLATE_CONFIG_WATCH_HISTORY = new IndexTemplateConfig( public static final IndexTemplateConfig TEMPLATE_CONFIG_WATCH_HISTORY = new IndexTemplateConfig(
WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME, WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME,
"/watch-history.json", "/watch-history.json",
@ -42,6 +47,11 @@ public class WatcherIndexTemplateRegistry extends IndexTemplateRegistry {
"/watch-history-10.json", "/watch-history-10.json",
10, 10,
WATCHER_TEMPLATE_VERSION_VARIABLE); WATCHER_TEMPLATE_VERSION_VARIABLE);
public static final IndexTemplateConfig TEMPLATE_CONFIG_WATCH_HISTORY_11 = new IndexTemplateConfig(
WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_11,
"/watch-history-11.json",
11,
WATCHER_TEMPLATE_VERSION_VARIABLE);
public static final IndexTemplateConfig TEMPLATE_CONFIG_WATCH_HISTORY_NO_ILM = new IndexTemplateConfig( public static final IndexTemplateConfig TEMPLATE_CONFIG_WATCH_HISTORY_NO_ILM = new IndexTemplateConfig(
WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_NO_ILM, WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_NO_ILM,
"/watch-history-no-ilm.json", "/watch-history-no-ilm.json",
@ -52,11 +62,21 @@ public class WatcherIndexTemplateRegistry extends IndexTemplateRegistry {
"/watch-history-no-ilm-10.json", "/watch-history-no-ilm-10.json",
10, 10,
WATCHER_TEMPLATE_VERSION_VARIABLE); WATCHER_TEMPLATE_VERSION_VARIABLE);
public static final IndexTemplateConfig TEMPLATE_CONFIG_WATCH_HISTORY_NO_ILM_11 = new IndexTemplateConfig(
WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_NO_ILM_11,
"/watch-history-no-ilm-11.json",
11,
WATCHER_TEMPLATE_VERSION_VARIABLE);
public static final IndexTemplateConfig TEMPLATE_CONFIG_WATCHES = new IndexTemplateConfig( public static final IndexTemplateConfig TEMPLATE_CONFIG_WATCHES = new IndexTemplateConfig(
WatcherIndexTemplateRegistryField.WATCHES_TEMPLATE_NAME, WatcherIndexTemplateRegistryField.WATCHES_TEMPLATE_NAME,
"/watches.json", "/watches.json",
WatcherIndexTemplateRegistryField.INDEX_TEMPLATE_VERSION, WatcherIndexTemplateRegistryField.INDEX_TEMPLATE_VERSION,
WATCHER_TEMPLATE_VERSION_VARIABLE); WATCHER_TEMPLATE_VERSION_VARIABLE);
public static final IndexTemplateConfig TEMPLATE_CONFIG_WATCHES_11 = new IndexTemplateConfig(
WatcherIndexTemplateRegistryField.WATCHES_TEMPLATE_NAME_11,
"/watches-11.json",
11,
WATCHER_TEMPLATE_VERSION_VARIABLE);
public static final LifecyclePolicyConfig POLICY_WATCH_HISTORY = new LifecyclePolicyConfig("watch-history-ilm-policy", public static final LifecyclePolicyConfig POLICY_WATCH_HISTORY = new LifecyclePolicyConfig("watch-history-ilm-policy",
"/watch-history-ilm-policy.json"); "/watch-history-ilm-policy.json");
@ -71,21 +91,32 @@ public class WatcherIndexTemplateRegistry extends IndexTemplateRegistry {
@Override @Override
protected List<IndexTemplateConfig> getLegacyTemplateConfigs() { protected List<IndexTemplateConfig> getLegacyTemplateConfigs() {
if (clusterService.state().nodes().getMinNodeVersion().onOrAfter(Version.V_7_7_0)) { if (clusterService.state().nodes().getMinNodeVersion().onOrAfter(Version.V_7_9_0)) {
return Collections.emptyList();
} else if (clusterService.state().nodes().getMinNodeVersion().onOrAfter(Version.V_7_7_0)) {
return Arrays.asList( return Arrays.asList(
ilmManagementEnabled ? TEMPLATE_CONFIG_WATCH_HISTORY : TEMPLATE_CONFIG_WATCH_HISTORY_NO_ILM, ilmManagementEnabled ? TEMPLATE_CONFIG_WATCH_HISTORY_11 : TEMPLATE_CONFIG_WATCH_HISTORY_NO_ILM_11,
TEMPLATE_CONFIG_TRIGGERED_WATCHES, TEMPLATE_CONFIG_TRIGGERED_WATCHES_11,
TEMPLATE_CONFIG_WATCHES TEMPLATE_CONFIG_WATCHES_11
); );
} else { } else {
return Arrays.asList( return Arrays.asList(
ilmManagementEnabled ? TEMPLATE_CONFIG_WATCH_HISTORY_10 : TEMPLATE_CONFIG_WATCH_HISTORY_NO_ILM_10, ilmManagementEnabled ? TEMPLATE_CONFIG_WATCH_HISTORY_10 : TEMPLATE_CONFIG_WATCH_HISTORY_NO_ILM_10,
TEMPLATE_CONFIG_TRIGGERED_WATCHES, TEMPLATE_CONFIG_TRIGGERED_WATCHES_11,
TEMPLATE_CONFIG_WATCHES TEMPLATE_CONFIG_WATCHES_11
); );
} }
} }
@Override
protected List<IndexTemplateConfig> getComposableTemplateConfigs() {
return Arrays.asList(
ilmManagementEnabled ? TEMPLATE_CONFIG_WATCH_HISTORY : TEMPLATE_CONFIG_WATCH_HISTORY_NO_ILM,
TEMPLATE_CONFIG_TRIGGERED_WATCHES,
TEMPLATE_CONFIG_WATCHES
);
}
/** /**
* If Watcher is configured not to use ILM, we don't return a policy. * If Watcher is configured not to use ILM, we don't return a policy.
*/ */
@ -103,16 +134,21 @@ public class WatcherIndexTemplateRegistry extends IndexTemplateRegistry {
} }
public static boolean validate(ClusterState state) { public static boolean validate(ClusterState state) {
if (state.nodes().getMinNodeVersion().onOrAfter(Version.V_7_7_0)) { if(state.nodes().getMinNodeVersion().onOrAfter(Version.V_7_9_0)){
return (state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME) || return (state.getMetadata().templatesV2().containsKey(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME) ||
state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_NO_ILM)) && state.getMetadata().templatesV2().containsKey(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_NO_ILM)) &&
state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.TRIGGERED_TEMPLATE_NAME) && state.getMetadata().templatesV2().containsKey(WatcherIndexTemplateRegistryField.TRIGGERED_TEMPLATE_NAME) &&
state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.WATCHES_TEMPLATE_NAME); state.getMetadata().templatesV2().containsKey(WatcherIndexTemplateRegistryField.WATCHES_TEMPLATE_NAME);
} else if (state.nodes().getMinNodeVersion().onOrAfter(Version.V_7_7_0)) {
return (state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_11) ||
state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_NO_ILM_11)) &&
state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.TRIGGERED_TEMPLATE_NAME_11) &&
state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.WATCHES_TEMPLATE_NAME_11);
} else { } else {
return (state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_10) || return (state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_10) ||
state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_NO_ILM_10)) && state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_NO_ILM_10)) &&
state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.TRIGGERED_TEMPLATE_NAME) && state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.TRIGGERED_TEMPLATE_NAME_11) &&
state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.WATCHES_TEMPLATE_NAME); state.getMetadata().getTemplates().containsKey(WatcherIndexTemplateRegistryField.WATCHES_TEMPLATE_NAME_11);
} }
} }

View File

@ -7,6 +7,7 @@ package org.elasticsearch.xpack.watcher.support;
import org.elasticsearch.Version; import org.elasticsearch.Version;
import org.elasticsearch.action.ActionListener; import org.elasticsearch.action.ActionListener;
import org.elasticsearch.action.admin.indices.template.put.PutComposableIndexTemplateAction;
import org.elasticsearch.action.admin.indices.template.put.PutIndexTemplateRequest; import org.elasticsearch.action.admin.indices.template.put.PutIndexTemplateRequest;
import org.elasticsearch.action.support.master.AcknowledgedResponse; import org.elasticsearch.action.support.master.AcknowledgedResponse;
import org.elasticsearch.client.AdminClient; import org.elasticsearch.client.AdminClient;
@ -17,6 +18,7 @@ import org.elasticsearch.cluster.ClusterModule;
import org.elasticsearch.cluster.ClusterName; import org.elasticsearch.cluster.ClusterName;
import org.elasticsearch.cluster.ClusterState; import org.elasticsearch.cluster.ClusterState;
import org.elasticsearch.cluster.block.ClusterBlocks; import org.elasticsearch.cluster.block.ClusterBlocks;
import org.elasticsearch.cluster.metadata.ComposableIndexTemplate;
import org.elasticsearch.cluster.metadata.IndexTemplateMetadata; import org.elasticsearch.cluster.metadata.IndexTemplateMetadata;
import org.elasticsearch.cluster.metadata.Metadata; import org.elasticsearch.cluster.metadata.Metadata;
import org.elasticsearch.cluster.node.DiscoveryNode; import org.elasticsearch.cluster.node.DiscoveryNode;
@ -54,6 +56,7 @@ import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import static org.elasticsearch.mock.orig.Mockito.verify; import static org.elasticsearch.mock.orig.Mockito.verify;
@ -65,6 +68,8 @@ import static org.hamcrest.Matchers.is;
import static org.mockito.Matchers.any; import static org.mockito.Matchers.any;
import static org.mockito.Matchers.anyObject; import static org.mockito.Matchers.anyObject;
import static org.mockito.Matchers.eq; import static org.mockito.Matchers.eq;
import static org.mockito.Matchers.same;
import static org.mockito.Mockito.atLeastOnce;
import static org.mockito.Mockito.doAnswer; import static org.mockito.Mockito.doAnswer;
import static org.mockito.Mockito.mock; import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.spy; import static org.mockito.Mockito.spy;
@ -114,8 +119,9 @@ public class WatcherIndexTemplateRegistryTests extends ESTestCase {
ClusterChangedEvent event = createClusterChangedEvent(Collections.emptyMap(), nodes); ClusterChangedEvent event = createClusterChangedEvent(Collections.emptyMap(), nodes);
registry.clusterChanged(event); registry.clusterChanged(event);
ArgumentCaptor<PutIndexTemplateRequest> argumentCaptor = ArgumentCaptor.forClass(PutIndexTemplateRequest.class); ArgumentCaptor<PutComposableIndexTemplateAction.Request> argumentCaptor =
verify(client.admin().indices(), times(3)).putTemplate(argumentCaptor.capture(), anyObject()); ArgumentCaptor.forClass(PutComposableIndexTemplateAction.Request.class);
verify(client, times(3)).execute(same(PutComposableIndexTemplateAction.INSTANCE), argumentCaptor.capture(), anyObject());
// now delete one template from the cluster state and lets retry // now delete one template from the cluster state and lets retry
Map<String, Integer> existingTemplates = new HashMap<>(); Map<String, Integer> existingTemplates = new HashMap<>();
@ -123,13 +129,13 @@ public class WatcherIndexTemplateRegistryTests extends ESTestCase {
existingTemplates.put(WatcherIndexTemplateRegistryField.TRIGGERED_TEMPLATE_NAME, INDEX_TEMPLATE_VERSION); existingTemplates.put(WatcherIndexTemplateRegistryField.TRIGGERED_TEMPLATE_NAME, INDEX_TEMPLATE_VERSION);
ClusterChangedEvent newEvent = createClusterChangedEvent(existingTemplates, nodes); ClusterChangedEvent newEvent = createClusterChangedEvent(existingTemplates, nodes);
registry.clusterChanged(newEvent); registry.clusterChanged(newEvent);
ArgumentCaptor<PutIndexTemplateRequest> captor = ArgumentCaptor.forClass(PutIndexTemplateRequest.class); argumentCaptor = ArgumentCaptor.forClass(PutComposableIndexTemplateAction.Request.class);
verify(client.admin().indices(), times(4)).putTemplate(captor.capture(), anyObject()); verify(client, times(3)).execute(same(PutComposableIndexTemplateAction.INSTANCE), argumentCaptor.capture(), anyObject());
PutIndexTemplateRequest req = captor.getAllValues().stream() PutComposableIndexTemplateAction.Request req = argumentCaptor.getAllValues().stream()
.filter(r -> r.name().equals(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME)) .filter(r -> r.name().equals(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME))
.findFirst() .findFirst()
.orElseThrow(() -> new AssertionError("expected the watch history template to be put")); .orElseThrow(() -> new AssertionError("expected the watch history template to be put"));
assertThat(req.settings().get("index.lifecycle.name"), equalTo("watch-history-ilm-policy")); assertThat(req.indexTemplate().template().settings().get("index.lifecycle.name"), equalTo("watch-history-ilm-policy"));
} }
public void testThatNonExistingTemplatesAreAddedEvenWithILMUsageDisabled() { public void testThatNonExistingTemplatesAreAddedEvenWithILMUsageDisabled() {
@ -141,8 +147,9 @@ public class WatcherIndexTemplateRegistryTests extends ESTestCase {
clusterService, threadPool, client, xContentRegistry); clusterService, threadPool, client, xContentRegistry);
ClusterChangedEvent event = createClusterChangedEvent(Settings.EMPTY, Collections.emptyMap(), Collections.emptyMap(), nodes); ClusterChangedEvent event = createClusterChangedEvent(Settings.EMPTY, Collections.emptyMap(), Collections.emptyMap(), nodes);
registry.clusterChanged(event); registry.clusterChanged(event);
ArgumentCaptor<PutIndexTemplateRequest> argumentCaptor = ArgumentCaptor.forClass(PutIndexTemplateRequest.class); ArgumentCaptor<PutComposableIndexTemplateAction.Request> argumentCaptor =
verify(client.admin().indices(), times(3)).putTemplate(argumentCaptor.capture(), anyObject()); ArgumentCaptor.forClass(PutComposableIndexTemplateAction.Request.class);
verify(client, times(3)).execute(same(PutComposableIndexTemplateAction.INSTANCE), argumentCaptor.capture(), anyObject());
// now delete one template from the cluster state and lets retry // now delete one template from the cluster state and lets retry
Map<String, Integer> existingTemplates = new HashMap<>(); Map<String, Integer> existingTemplates = new HashMap<>();
@ -151,7 +158,7 @@ public class WatcherIndexTemplateRegistryTests extends ESTestCase {
ClusterChangedEvent newEvent = createClusterChangedEvent(existingTemplates, nodes); ClusterChangedEvent newEvent = createClusterChangedEvent(existingTemplates, nodes);
registry.clusterChanged(newEvent); registry.clusterChanged(newEvent);
ArgumentCaptor<PutIndexTemplateRequest> captor = ArgumentCaptor.forClass(PutIndexTemplateRequest.class); ArgumentCaptor<PutIndexTemplateRequest> captor = ArgumentCaptor.forClass(PutIndexTemplateRequest.class);
verify(client.admin().indices(), times(5)).putTemplate(captor.capture(), anyObject()); verify(client, times(3)).execute(same(PutComposableIndexTemplateAction.INSTANCE), argumentCaptor.capture(), anyObject());
captor.getAllValues().forEach(req -> assertNull(req.settings().get("index.lifecycle.name"))); captor.getAllValues().forEach(req -> assertNull(req.settings().get("index.lifecycle.name")));
verify(client, times(0)).execute(eq(PutLifecycleAction.INSTANCE), anyObject(), anyObject()); verify(client, times(0)).execute(eq(PutLifecycleAction.INSTANCE), anyObject(), anyObject());
} }
@ -262,9 +269,11 @@ public class WatcherIndexTemplateRegistryTests extends ESTestCase {
ClusterChangedEvent event = createClusterChangedEvent(existingTemplates, nodes); ClusterChangedEvent event = createClusterChangedEvent(existingTemplates, nodes);
registry.clusterChanged(event); registry.clusterChanged(event);
ArgumentCaptor<PutIndexTemplateRequest> argumentCaptor = ArgumentCaptor.forClass(PutIndexTemplateRequest.class); ArgumentCaptor<PutComposableIndexTemplateAction.Request> argumentCaptor =
verify(client.admin().indices(), times(1)).putTemplate(argumentCaptor.capture(), anyObject()); ArgumentCaptor.forClass(PutComposableIndexTemplateAction.Request.class);
assertThat(argumentCaptor.getValue().name(), is(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_10)); verify(client, times(3)).execute(same(PutComposableIndexTemplateAction.INSTANCE), argumentCaptor.capture(), anyObject());
assertTrue(argumentCaptor.getAllValues().stream()
.anyMatch(r -> r.name().equals(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME)));
} }
public void testThatTemplatesWithHiddenAreAppliedOnNewerNodes() { public void testThatTemplatesWithHiddenAreAppliedOnNewerNodes() {
@ -280,8 +289,9 @@ public class WatcherIndexTemplateRegistryTests extends ESTestCase {
registry.clusterChanged(event); registry.clusterChanged(event);
ArgumentCaptor<PutIndexTemplateRequest> argumentCaptor = ArgumentCaptor.forClass(PutIndexTemplateRequest.class); ArgumentCaptor<PutIndexTemplateRequest> argumentCaptor = ArgumentCaptor.forClass(PutIndexTemplateRequest.class);
verify(client.admin().indices(), times(1)).putTemplate(argumentCaptor.capture(), anyObject()); verify(client.admin().indices(), atLeastOnce()).putTemplate(argumentCaptor.capture(), anyObject());
assertThat(argumentCaptor.getValue().name(), is(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_10)); assertTrue(argumentCaptor.getAllValues().stream()
.anyMatch(i -> i.name().equals(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_10)));
existingTemplates.remove(".watch-history-6"); existingTemplates.remove(".watch-history-6");
existingTemplates.put(".watch-history-10", 10); existingTemplates.put(".watch-history-10", 10);
@ -291,8 +301,16 @@ public class WatcherIndexTemplateRegistryTests extends ESTestCase {
registry.clusterChanged(event); registry.clusterChanged(event);
argumentCaptor = ArgumentCaptor.forClass(PutIndexTemplateRequest.class); argumentCaptor = ArgumentCaptor.forClass(PutIndexTemplateRequest.class);
verify(client.admin().indices(), times(2)).putTemplate(argumentCaptor.capture(), anyObject()); verify(client.admin().indices(), atLeastOnce()).putTemplate(argumentCaptor.capture(), anyObject());
assertThat(argumentCaptor.getValue().name(), is(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME)); assertTrue(argumentCaptor.getAllValues().stream()
.anyMatch(i -> i.name().equals(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_10)));
ArgumentCaptor<PutComposableIndexTemplateAction.Request> captor =
ArgumentCaptor.forClass(PutComposableIndexTemplateAction.Request.class);
verify(client, atLeastOnce()).execute(same(PutComposableIndexTemplateAction.INSTANCE), captor.capture(), anyObject());
Set<String> templateNames =
captor.getAllValues().stream().map(PutComposableIndexTemplateAction.Request::name).collect(Collectors.toSet());
assertTrue(templateNames.contains(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME));
assertFalse(templateNames.contains(WatcherIndexTemplateRegistryField.HISTORY_TEMPLATE_NAME_10));
} }
public void testThatTemplatesAreNotAppliedOnSameVersionNodes() { public void testThatTemplatesAreNotAppliedOnSameVersionNodes() {
@ -376,11 +394,14 @@ public class WatcherIndexTemplateRegistryTests extends ESTestCase {
private ClusterState createClusterState(Map<String, Integer> existingTemplates) { private ClusterState createClusterState(Map<String, Integer> existingTemplates) {
Metadata.Builder metadataBuilder = Metadata.builder(); Metadata.Builder metadataBuilder = Metadata.builder();
HashMap<String, ComposableIndexTemplate> templates = new HashMap<>();
for (Map.Entry<String, Integer> template : existingTemplates.entrySet()) { for (Map.Entry<String, Integer> template : existingTemplates.entrySet()) {
metadataBuilder.put(IndexTemplateMetadata.builder(template.getKey()) ComposableIndexTemplate indexTemplate = mock(ComposableIndexTemplate.class);
.version(template.getValue()) when(indexTemplate.version()).thenReturn(template.getValue() == null ? null : (long) template.getValue());
.patterns(Arrays.asList(generateRandomStringArray(10, 100, false, false)))); when(indexTemplate.indexPatterns()).thenReturn(Arrays.asList(generateRandomStringArray(10, 100, false, false)));
templates.put(template.getKey(), indexTemplate);
} }
metadataBuilder.indexTemplates(templates);
return ClusterState.builder(new ClusterName("foo")).metadata(metadataBuilder.build()).build(); return ClusterState.builder(new ClusterName("foo")).metadata(metadataBuilder.build()).build();
} }

View File

@ -39,7 +39,7 @@ public class WatcherRestartIT extends AbstractUpgradeTestCase {
// in a mixed cluster with some nodes <7.7.0 it will install template version 10, but if all nodes are <=7.7.0 template v11 // in a mixed cluster with some nodes <7.7.0 it will install template version 10, but if all nodes are <=7.7.0 template v11
// is used. // is used.
final String expectedMixedClusterTemplate = templatePrefix + (UPGRADE_FROM_VERSION.before(Version.V_7_7_0) ? "10" : "11"); final String expectedMixedClusterTemplate = templatePrefix + (UPGRADE_FROM_VERSION.before(Version.V_7_7_0) ? "10" : "11");
final String expectedFinalTemplate = templatePrefix + "11"; final String expectedFinalTemplate = templatePrefix + "12";
if (ClusterType.MIXED == CLUSTER_TYPE) { if (ClusterType.MIXED == CLUSTER_TYPE) {
final Request request = new Request("HEAD", "/_template/" + expectedMixedClusterTemplate); final Request request = new Request("HEAD", "/_template/" + expectedMixedClusterTemplate);
@ -50,7 +50,7 @@ public class WatcherRestartIT extends AbstractUpgradeTestCase {
Response response = client().performRequest(request); Response response = client().performRequest(request);
assertThat(response.getStatusLine().getStatusCode(), is(200)); assertThat(response.getStatusLine().getStatusCode(), is(200));
} else if (ClusterType.UPGRADED == CLUSTER_TYPE) { } else if (ClusterType.UPGRADED == CLUSTER_TYPE) {
Response response = client().performRequest(new Request("HEAD", "/_template/" + expectedFinalTemplate)); Response response = client().performRequest(new Request("HEAD", "/_index_template/" + expectedFinalTemplate));
assertThat(response.getStatusLine().getStatusCode(), is(200)); assertThat(response.getStatusLine().getStatusCode(), is(200));
} }
} }