From 7066923d085708a1a2326c53f12fcc8f208c7b59 Mon Sep 17 00:00:00 2001 From: Joanne Wang Date: Fri, 8 Dec 2023 09:18:25 -0800 Subject: [PATCH] Use a common constant to specify the version for log type mappings #708 (#734) * json parser Signed-off-by: Joanne Wang * update gradle json dependency Signed-off-by: Joanne Wang * use xcontenthelper to parse json file Signed-off-by: Joanne Wang --------- Signed-off-by: Joanne Wang --- .../logtype/LogTypeService.java | 16 ++++++++++++---- .../securityanalytics/LogTypeServiceTests.java | 6 +++++- 2 files changed, 17 insertions(+), 5 deletions(-) diff --git a/src/main/java/org/opensearch/securityanalytics/logtype/LogTypeService.java b/src/main/java/org/opensearch/securityanalytics/logtype/LogTypeService.java index bec6ef8ae..9036f514d 100644 --- a/src/main/java/org/opensearch/securityanalytics/logtype/LogTypeService.java +++ b/src/main/java/org/opensearch/securityanalytics/logtype/LogTypeService.java @@ -25,6 +25,8 @@ import org.opensearch.OpenSearchStatusException; import org.opensearch.ResourceAlreadyExistsException; import org.opensearch.cluster.routing.Preference; +import org.opensearch.common.xcontent.XContentHelper; +import org.opensearch.common.xcontent.json.JsonXContent; import org.opensearch.core.action.ActionListener; import org.opensearch.action.DocWriteRequest; import org.opensearch.action.admin.indices.create.CreateIndexRequest; @@ -76,8 +78,6 @@ public class LogTypeService { public static final String LOG_TYPE_MAPPING_VERSION_META_FIELD = "schema_version"; - public static final int LOG_TYPE_MAPPING_VERSION = 1; // must match version in log_type_config_mapping.json - public static final int MAX_LOG_TYPE_COUNT = 100; private static volatile boolean isConfigIndexInitialized; @@ -92,6 +92,8 @@ public class LogTypeService { private String defaultSchemaField; + public int logTypeMappingVersion; + @Inject public LogTypeService(Client client, ClusterService clusterService, NamedXContentRegistry xContentRegistry, BuiltinLogTypeLoader builtinLogTypeLoader) { this.client = client; @@ -104,6 +106,7 @@ public LogTypeService(Client client, ClusterService clusterService, NamedXConten DEFAULT_MAPPING_SCHEMA, newDefaultSchema -> this.defaultSchemaField = newDefaultSchema ); + setLogTypeMappingVersion(); } public void getAllLogTypes(ActionListener> listener) { @@ -482,7 +485,7 @@ public void onFailure(Exception e) { }); } else { IndexMetadata metadata = state.getMetadata().index(LOG_TYPE_INDEX); - if (getConfigIndexMappingVersion(metadata) < LOG_TYPE_MAPPING_VERSION) { + if (getConfigIndexMappingVersion(metadata) < logTypeMappingVersion) { // The index already exists but doesn't have our mapping client.admin() .indices() @@ -777,8 +780,13 @@ public Map getRuleFieldMappingsForBuiltinLogType(String builtinL } } - public String getDefaultSchemaField() { return defaultSchemaField; } + + public void setLogTypeMappingVersion() { + Map logTypeConfigAsMap = + XContentHelper.convertToMap(JsonXContent.jsonXContent, logTypeIndexMapping(), false); + this.logTypeMappingVersion = (int)((Map)logTypeConfigAsMap.get("_meta")).get("schema_version"); + } } \ No newline at end of file diff --git a/src/test/java/org/opensearch/securityanalytics/LogTypeServiceTests.java b/src/test/java/org/opensearch/securityanalytics/LogTypeServiceTests.java index 64288f669..217fa0a03 100644 --- a/src/test/java/org/opensearch/securityanalytics/LogTypeServiceTests.java +++ b/src/test/java/org/opensearch/securityanalytics/LogTypeServiceTests.java @@ -107,7 +107,11 @@ public void testIndexMappings() throws ExecutionException, InterruptedException } - + public void testSetLogTypeMappingSchema() { + int expectedVersion = 2; + int version = logTypeService.logTypeMappingVersion; + assertEquals(expectedVersion, version); + } private void indexFieldMappings(List fieldMappingDocs) { PlainActionFuture fut = new PlainActionFuture<>();