From 27a6ec4b8104599ae937adc6106e461486d9ae10 Mon Sep 17 00:00:00 2001 From: Surya Sashank Nistala Date: Fri, 5 Jan 2024 10:59:01 -0800 Subject: [PATCH] change terms query clause on indices to list of should clauses as index is a text field in query index mapping Signed-off-by: Surya Sashank Nistala --- .../alerting/DocumentLevelMonitorRunner.kt | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/alerting/src/main/kotlin/org/opensearch/alerting/DocumentLevelMonitorRunner.kt b/alerting/src/main/kotlin/org/opensearch/alerting/DocumentLevelMonitorRunner.kt index 86fd18ff0..ab90d29ad 100644 --- a/alerting/src/main/kotlin/org/opensearch/alerting/DocumentLevelMonitorRunner.kt +++ b/alerting/src/main/kotlin/org/opensearch/alerting/DocumentLevelMonitorRunner.kt @@ -183,7 +183,6 @@ object DocumentLevelMonitorRunner : MonitorRunner() { } concreteIndicesSeenSoFar.addAll(concreteIndices) val updatedIndexName = indexName.replace("*", "_") -// lastUpdatedIndexName = updatedIndexName val conflictingFields = monitorCtx.docLevelMonitorQueries!!.getAllConflictingFields( monitorCtx.clusterService!!.state(), concreteIndices @@ -191,7 +190,6 @@ object DocumentLevelMonitorRunner : MonitorRunner() { concreteIndices.forEach { concreteIndexName -> // Prepare lastRunContext for each index -// lastConcreteIndexName = concreteIndexName val indexLastRunContext = lastRunContext.getOrPut(concreteIndexName) { val isIndexCreatedRecently = createdRecently( monitor, @@ -252,7 +250,7 @@ object DocumentLevelMonitorRunner : MonitorRunner() { } } /* if all indices are covered still in-memory docs size limit is not breached we would need to submit - the percolate query at the end*/ + the percolate query at the end */ if (transformedDocs.isNotEmpty()) { performPercolateQueryAndResetCounters( monitorCtx, @@ -772,7 +770,7 @@ object DocumentLevelMonitorRunner : MonitorRunner() { monitorInputIndices: List, ): SearchHits { val indices = docs.stream().map { it.second.indexName }.distinct().collect(Collectors.toList()) - val boolQueryBuilder = BoolQueryBuilder().must(QueryBuilders.termsQuery("index", indices)) + val boolQueryBuilder = BoolQueryBuilder().must(buildShouldClausesOverPerIndexMatchQueries(indices)) val percolateQueryBuilder = PercolateQueryBuilderExt("query", docs.map { it.second.docSource }, XContentType.JSON) if (monitor.id.isNotEmpty()) { @@ -823,6 +821,12 @@ object DocumentLevelMonitorRunner : MonitorRunner() { } return response.hits } + /** we cannot use terms query because `index` field's mapping is of type TEXT and not keyword. Refer doc-level-queries.json*/ + private fun buildShouldClausesOverPerIndexMatchQueries(indices: List): BoolQueryBuilder { + val boolQueryBuilder = QueryBuilders.boolQuery() + indices.forEach { boolQueryBuilder.should(QueryBuilders.matchQuery("index", it)) } + return boolQueryBuilder + } /** Transform field names and index names in all the search hits to format required to run percolate search against them. * Hits are transformed using method transformDocumentFieldNames() */