From 8274f38f758ba781f95583b1103939683b85b8aa Mon Sep 17 00:00:00 2001 From: Ashish Agrawal Date: Thu, 9 Feb 2023 13:53:44 -0800 Subject: [PATCH] Fix setting default title only when no subject has been set (#750) Signed-off-by: Ashish Agrawal (cherry picked from commit 830dff1d17c9a002efe417b55b84219b14c0c2fe) --- .../org/opensearch/alerting/MonitorRunner.kt | 3 +- .../NotificationApiUtils.kt | 28 ++----------------- 2 files changed, 3 insertions(+), 28 deletions(-) diff --git a/alerting/src/main/kotlin/org/opensearch/alerting/MonitorRunner.kt b/alerting/src/main/kotlin/org/opensearch/alerting/MonitorRunner.kt index 7ca0e4800..de8c57993 100644 --- a/alerting/src/main/kotlin/org/opensearch/alerting/MonitorRunner.kt +++ b/alerting/src/main/kotlin/org/opensearch/alerting/MonitorRunner.kt @@ -23,7 +23,6 @@ import org.opensearch.alerting.script.QueryLevelTriggerExecutionContext import org.opensearch.alerting.script.TriggerExecutionContext import org.opensearch.alerting.util.destinationmigration.NotificationActionConfigs import org.opensearch.alerting.util.destinationmigration.NotificationApiUtils.Companion.getNotificationConfigInfo -import org.opensearch.alerting.util.destinationmigration.createMessageContent import org.opensearch.alerting.util.destinationmigration.getTitle import org.opensearch.alerting.util.destinationmigration.publishLegacyNotification import org.opensearch.alerting.util.destinationmigration.sendNotification @@ -110,7 +109,7 @@ abstract class MonitorRunner { ?.sendNotification( monitorCtx.client!!, config.channel.getTitle(subject), - config.channel.createMessageContent(subject, message) + message ) ?: actionResponseContent actionResponseContent = config.destination diff --git a/alerting/src/main/kotlin/org/opensearch/alerting/util/destinationmigration/NotificationApiUtils.kt b/alerting/src/main/kotlin/org/opensearch/alerting/util/destinationmigration/NotificationApiUtils.kt index 7b4dc8abf..489aa59d6 100644 --- a/alerting/src/main/kotlin/org/opensearch/alerting/util/destinationmigration/NotificationApiUtils.kt +++ b/alerting/src/main/kotlin/org/opensearch/alerting/util/destinationmigration/NotificationApiUtils.kt @@ -14,7 +14,6 @@ import org.opensearch.alerting.opensearchapi.retryForNotification import org.opensearch.alerting.opensearchapi.suspendUntil import org.opensearch.client.Client import org.opensearch.client.node.NodeClient -import org.opensearch.common.Strings import org.opensearch.common.unit.TimeValue import org.opensearch.commons.ConfigConstants import org.opensearch.commons.destination.message.LegacyBaseMessage @@ -27,7 +26,6 @@ import org.opensearch.commons.notifications.action.LegacyPublishNotificationRequ import org.opensearch.commons.notifications.action.LegacyPublishNotificationResponse import org.opensearch.commons.notifications.action.SendNotificationResponse import org.opensearch.commons.notifications.model.ChannelMessage -import org.opensearch.commons.notifications.model.ConfigType import org.opensearch.commons.notifications.model.EventSource import org.opensearch.commons.notifications.model.NotificationConfigInfo import org.opensearch.commons.notifications.model.SeverityType @@ -138,33 +136,11 @@ suspend fun NotificationConfigInfo.sendNotification(client: Client, title: Strin } /** - * For most channel types, a placeholder Alerting title will be used but the email channel/SNS notification will - * use the subject, so it appears as the actual subject of the email/SNS notification. + * A placeholder Alerting title will be used if no subject is passed in. */ fun NotificationConfigInfo.getTitle(subject: String?): String { val defaultTitle = "Alerting-Notification Action" - if (this.notificationConfig.configType == ConfigType.EMAIL || this.notificationConfig.configType == ConfigType.SNS) { - return if (subject.isNullOrEmpty()) defaultTitle else subject - } - - return defaultTitle -} - -fun NotificationConfigInfo.createMessageContent(subject: String?, message: String): String { - // For Email Channels, the subject is not passed in the main message since it's used as the title - if (this.notificationConfig.configType == ConfigType.EMAIL) { - return constructMessageContent("", message) - } - - return constructMessageContent(subject, message) -} - -/** - * Similar to Destinations, this is a generic utility method for constructing message content from - * a subject and message body when sending through Notifications since the Action definition in Monitors can have both. - */ -private fun constructMessageContent(subject: String?, message: String): String { - return if (Strings.isNullOrEmpty(subject)) message else "$subject \n\n $message" + return if (subject.isNullOrEmpty()) defaultTitle else subject } /**