From 8720ec76e120209d7febabe37f59aae193f5595b Mon Sep 17 00:00:00 2001 From: Piumal1999 Date: Mon, 23 Sep 2024 02:14:36 +0530 Subject: [PATCH] Update AnalyticsDataPublisher to Handle Multiple Reporter Types --- .../apimgt/common/analytics/Constants.java | 2 + .../impl/AnalyticsDataPublisher.java | 38 +++++++++++++++++-- 2 files changed, 36 insertions(+), 4 deletions(-) diff --git a/components/apimgt/org.wso2.carbon.apimgt.common.analytics/src/main/java/org/wso2/carbon/apimgt/common/analytics/Constants.java b/components/apimgt/org.wso2.carbon.apimgt.common.analytics/src/main/java/org/wso2/carbon/apimgt/common/analytics/Constants.java index 3d75425bfe6f..e28291095550 100644 --- a/components/apimgt/org.wso2.carbon.apimgt.common.analytics/src/main/java/org/wso2/carbon/apimgt/common/analytics/Constants.java +++ b/components/apimgt/org.wso2.carbon.apimgt.common.analytics/src/main/java/org/wso2/carbon/apimgt/common/analytics/Constants.java @@ -39,4 +39,6 @@ public class Constants { public static final String USERNAME_MASK_VALUE = "*****"; public static final String AUTH_API_URL = "auth.api.url"; + + public static final String CHOREO_REPORTER_NAME = "choreo"; } diff --git a/components/apimgt/org.wso2.carbon.apimgt.common.analytics/src/main/java/org/wso2/carbon/apimgt/common/analytics/publishers/impl/AnalyticsDataPublisher.java b/components/apimgt/org.wso2.carbon.apimgt.common.analytics/src/main/java/org/wso2/carbon/apimgt/common/analytics/publishers/impl/AnalyticsDataPublisher.java index d5de8f5469b0..5dc06ebefd56 100644 --- a/components/apimgt/org.wso2.carbon.apimgt.common.analytics/src/main/java/org/wso2/carbon/apimgt/common/analytics/publishers/impl/AnalyticsDataPublisher.java +++ b/components/apimgt/org.wso2.carbon.apimgt.common.analytics/src/main/java/org/wso2/carbon/apimgt/common/analytics/publishers/impl/AnalyticsDataPublisher.java @@ -29,10 +29,14 @@ import org.wso2.carbon.apimgt.common.analytics.Constants; import java.util.ArrayList; +import java.util.Arrays; +import java.util.Collections; import java.util.List; import java.util.Map; import java.util.stream.Collectors; +import static org.wso2.carbon.apimgt.common.analytics.Constants.CHOREO_REPORTER_NAME; + /** * Analytics event publisher for APIM. */ @@ -53,6 +57,20 @@ public static AnalyticsDataPublisher getInstance() { return instance; } + private List getReporterTypesOrNull(String typeConfig) { + if (typeConfig == null) { + return null; + } + if (typeConfig.startsWith("[") && typeConfig.endsWith("]")) { + return Arrays.stream(typeConfig.substring(1, typeConfig.length() - 1).split(",")) + .map(String::trim) + .filter(s -> !s.isEmpty()) + .collect(Collectors.toList()); + } else { + return Collections.singletonList(typeConfig); + } + } + private List getReportersClassesOrNull(Map configs) { List reporterClasses = new ArrayList<>(); List reporterKeys = configs.keySet() @@ -93,7 +111,7 @@ private List getSuccessOrFaultyCounterMetrics(List configs = commonConfig.getConfigurations(); String reporterClass = configs.get("publisher.reporter.class"); - String reporterType = configs.get("type"); + List reporterTypes = getReporterTypesOrNull(configs.get("type")); List reporterClasses = getReportersClassesOrNull(configs); try { List metricReporters = new ArrayList<>(); @@ -113,9 +131,21 @@ public void initialize(AnalyticsCommonConfiguration commonConfig) { " out of multiple metric reporters.", e); } } - } else if (reporterType != null && !reporterType.equals("")) { - metricReporter = MetricReporterFactory.getInstance().createLogMetricReporter(configs); - metricReporters.add(metricReporter); + } else if (reporterTypes != null && !reporterTypes.isEmpty()) { + for (String type : reporterTypes) { + if (type.equals(CHOREO_REPORTER_NAME)) { + String authEndpoint = configs.get(Constants.AUTH_API_URL); + if (authEndpoint == null || authEndpoint.isEmpty()) { + throw new MetricCreationException("Analytics Config Endpoint is not provided."); + } + metricReporter = MetricReporterFactory.getInstance().createMetricReporter(configs); + metricReporters.add(metricReporter); + } else { + metricReporter = MetricReporterFactory.getInstance().createLogMetricReporter(configs); + metricReporters.add(metricReporter); + } + + } } else { String authEndpoint = configs.get(Constants.AUTH_API_URL);