-
Notifications
You must be signed in to change notification settings - Fork 95
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Notification plugin interface and models
[Tests] Contains unit test for all model classes Signed-off-by: @akbhatta
- Loading branch information
Showing
93 changed files
with
13,734 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
67 changes: 67 additions & 0 deletions
67
src/main/kotlin/org/opensearch/commons/notifications/NotificationConstants.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
package org.opensearch.commons.notifications | ||
|
||
/** | ||
* Class containing Internal constants like JSON tags and defaults. | ||
*/ | ||
internal object NotificationConstants { | ||
internal const val CONFIG_ID_TAG = "config_id" | ||
internal const val CONFIG_ID_LIST_TAG = "config_id_list" | ||
internal const val EVENT_ID_TAG = "event_id" | ||
internal const val EVENT_ID_LIST_TAG = "event_id_list" | ||
internal const val EMAIL_ACCOUNT_ID_TAG = "email_account_id" | ||
internal const val REFERENCE_ID_TAG = "reference_id" | ||
internal const val CHANNEL_ID_LIST_TAG = "channel_id_list" | ||
internal const val CONFIG_NAME_TAG = "config_name" | ||
internal const val CONFIG_TYPE_TAG = "config_type" | ||
internal const val CONFIG_TAG = "config" | ||
internal const val EVENT_TAG = "event" | ||
internal const val EVENT_SOURCE_TAG = "event_source" | ||
internal const val FEATURE_TAG = "feature" | ||
internal const val THREAD_CONTEXT_TAG = "context" | ||
internal const val CHANNEL_MESSAGE_TAG = "channel_message" | ||
internal const val TEXT_DESCRIPTION_TAG = "text_description" | ||
internal const val HTML_DESCRIPTION_TAG = "html_description" | ||
internal const val ATTACHMENT_TAG = "attachment" | ||
internal const val RECIPIENT_TAG = "recipient" | ||
internal const val RECIPIENT_LIST_TAG = "recipient_list" | ||
internal const val EMAIL_RECIPIENT_STATUS_TAG = "email_recipient_status" | ||
internal const val EMAIL_GROUP_ID_LIST_TAG = "email_group_id_list" | ||
internal const val STATUS_CODE_TAG = "status_code" | ||
internal const val STATUS_TEXT_TAG = "status_text" | ||
internal const val DELIVERY_STATUS_TAG = "delivery_status" | ||
internal const val NAME_TAG = "name" | ||
internal const val DESCRIPTION_TAG = "description" | ||
internal const val IS_ENABLED_TAG = "is_enabled" | ||
internal const val FEATURE_LIST_TAG = "feature_list" | ||
internal const val TITLE_TAG = "title" | ||
internal const val SEVERITY_TAG = "severity" | ||
internal const val TAGS_TAG = "tags" | ||
internal const val URL_TAG = "url" | ||
internal const val HEADER_PARAMS_TAG = "header_params" | ||
internal const val HOST_TAG = "host" | ||
internal const val PORT_TAG = "port" | ||
internal const val METHOD_TAG = "method" | ||
internal const val FROM_ADDRESS_TAG = "from_address" | ||
internal const val UPDATED_TIME_TAG = "last_updated_time_ms" | ||
internal const val CREATED_TIME_TAG = "created_time_ms" | ||
internal const val TENANT_TAG = "tenant" | ||
internal const val CONFIG_LIST_TAG = "config_list" | ||
internal const val EVENT_LIST_TAG = "event_list" | ||
internal const val FEATURE_CONFIG_LIST_TAG = "feature_channel_list" | ||
internal const val DELETE_RESPONSE_LIST_TAG = "delete_response_list" | ||
internal const val FROM_INDEX_TAG = "from_index" | ||
internal const val MAX_ITEMS_TAG = "max_items" | ||
internal const val SORT_FIELD_TAG = "sort_field" | ||
internal const val SORT_ORDER_TAG = "sort_order" | ||
internal const val FILTER_PARAM_LIST_TAG = "filter_param_list" | ||
internal const val STATUS_LIST_TAG = "status_list" | ||
internal const val START_INDEX_TAG = "start_index" | ||
internal const val TOTAL_HITS_TAG = "total_hits" | ||
internal const val TOTAL_HIT_RELATION_TAG = "total_hit_relation" | ||
internal const val QUERY_TAG = "query" | ||
internal const val COMPACT_TAG = "compact" | ||
internal const val CONFIG_TYPE_LIST_TAG = "config_type_list" | ||
internal const val PLUGIN_FEATURES_TAG = "plugin_features" | ||
|
||
internal const val DEFAULT_MAX_ITEMS = 1000 | ||
} |
215 changes: 215 additions & 0 deletions
215
src/main/kotlin/org/opensearch/commons/notifications/NotificationsPluginInterface.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,215 @@ | ||
/* | ||
* SPDX-License-Identifier: Apache-2.0 | ||
* | ||
* The OpenSearch Contributors require contributions made to | ||
* this file be licensed under the Apache-2.0 license or a | ||
* compatible open source license. | ||
* | ||
* Modifications Copyright OpenSearch Contributors. See | ||
* GitHub history for details. | ||
*/ | ||
|
||
/* | ||
* Copyright 2021 Amazon.com, Inc. or its affiliates. All Rights Reserved. | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"). | ||
* You may not use this file except in compliance with the License. | ||
* A copy of the License is located at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* or in the "license" file accompanying this file. This file is distributed | ||
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either | ||
* express or implied. See the License for the specific language governing | ||
* permissions and limitations under the License. | ||
* | ||
*/ | ||
package org.opensearch.commons.notifications | ||
|
||
import org.opensearch.action.ActionListener | ||
import org.opensearch.client.node.NodeClient | ||
import org.opensearch.commons.ConfigConstants.OPENSEARCH_SECURITY_USER_INFO_THREAD_CONTEXT | ||
import org.opensearch.commons.notifications.action.CreateNotificationConfigRequest | ||
import org.opensearch.commons.notifications.action.CreateNotificationConfigResponse | ||
import org.opensearch.commons.notifications.action.DeleteNotificationConfigRequest | ||
import org.opensearch.commons.notifications.action.DeleteNotificationConfigResponse | ||
import org.opensearch.commons.notifications.action.GetFeatureChannelListRequest | ||
import org.opensearch.commons.notifications.action.GetFeatureChannelListResponse | ||
import org.opensearch.commons.notifications.action.GetNotificationConfigRequest | ||
import org.opensearch.commons.notifications.action.GetNotificationConfigResponse | ||
import org.opensearch.commons.notifications.action.GetNotificationEventRequest | ||
import org.opensearch.commons.notifications.action.GetNotificationEventResponse | ||
import org.opensearch.commons.notifications.action.GetPluginFeaturesRequest | ||
import org.opensearch.commons.notifications.action.GetPluginFeaturesResponse | ||
import org.opensearch.commons.notifications.action.NotificationsActions.CREATE_NOTIFICATION_CONFIG_ACTION_TYPE | ||
import org.opensearch.commons.notifications.action.NotificationsActions.DELETE_NOTIFICATION_CONFIG_ACTION_TYPE | ||
import org.opensearch.commons.notifications.action.NotificationsActions.GET_FEATURE_CHANNEL_LIST_ACTION_TYPE | ||
import org.opensearch.commons.notifications.action.NotificationsActions.GET_NOTIFICATION_CONFIG_ACTION_TYPE | ||
import org.opensearch.commons.notifications.action.NotificationsActions.GET_NOTIFICATION_EVENT_ACTION_TYPE | ||
import org.opensearch.commons.notifications.action.NotificationsActions.GET_PLUGIN_FEATURES_ACTION_TYPE | ||
import org.opensearch.commons.notifications.action.NotificationsActions.SEND_NOTIFICATION_ACTION_TYPE | ||
import org.opensearch.commons.notifications.action.NotificationsActions.UPDATE_NOTIFICATION_CONFIG_ACTION_TYPE | ||
import org.opensearch.commons.notifications.action.SendNotificationRequest | ||
import org.opensearch.commons.notifications.action.SendNotificationResponse | ||
import org.opensearch.commons.notifications.action.UpdateNotificationConfigRequest | ||
import org.opensearch.commons.notifications.action.UpdateNotificationConfigResponse | ||
import org.opensearch.commons.notifications.model.ChannelMessage | ||
import org.opensearch.commons.notifications.model.EventSource | ||
import org.opensearch.commons.utils.SecureClientWrapper | ||
|
||
/** | ||
* All the transport action plugin interfaces for the Notification plugin | ||
*/ | ||
object NotificationsPluginInterface { | ||
|
||
/** | ||
* Create notification configuration. | ||
* @param client Node client for making transport action | ||
* @param request The request object | ||
* @param listener The listener for getting response | ||
*/ | ||
fun createNotificationConfig( | ||
client: NodeClient, | ||
request: CreateNotificationConfigRequest, | ||
listener: ActionListener<CreateNotificationConfigResponse> | ||
) { | ||
client.execute( | ||
CREATE_NOTIFICATION_CONFIG_ACTION_TYPE, | ||
request, | ||
listener | ||
) | ||
} | ||
|
||
/** | ||
* Update notification configuration. | ||
* @param client Node client for making transport action | ||
* @param request The request object | ||
* @param listener The listener for getting response | ||
*/ | ||
fun updateNotificationConfig( | ||
client: NodeClient, | ||
request: UpdateNotificationConfigRequest, | ||
listener: ActionListener<UpdateNotificationConfigResponse> | ||
) { | ||
client.execute( | ||
UPDATE_NOTIFICATION_CONFIG_ACTION_TYPE, | ||
request, | ||
listener | ||
) | ||
} | ||
|
||
/** | ||
* Delete notification configuration. | ||
* @param client Node client for making transport action | ||
* @param request The request object | ||
* @param listener The listener for getting response | ||
*/ | ||
fun deleteNotificationConfig( | ||
client: NodeClient, | ||
request: DeleteNotificationConfigRequest, | ||
listener: ActionListener<DeleteNotificationConfigResponse> | ||
) { | ||
client.execute( | ||
DELETE_NOTIFICATION_CONFIG_ACTION_TYPE, | ||
request, | ||
listener | ||
) | ||
} | ||
|
||
/** | ||
* Get notification configuration. | ||
* @param client Node client for making transport action | ||
* @param request The request object | ||
* @param listener The listener for getting response | ||
*/ | ||
fun getNotificationConfig( | ||
client: NodeClient, | ||
request: GetNotificationConfigRequest, | ||
listener: ActionListener<GetNotificationConfigResponse> | ||
) { | ||
client.execute( | ||
GET_NOTIFICATION_CONFIG_ACTION_TYPE, | ||
request, | ||
listener | ||
) | ||
} | ||
|
||
/** | ||
* Get notification events. | ||
* @param client Node client for making transport action | ||
* @param request The request object | ||
* @param listener The listener for getting response | ||
*/ | ||
fun getNotificationEvent( | ||
client: NodeClient, | ||
request: GetNotificationEventRequest, | ||
listener: ActionListener<GetNotificationEventResponse> | ||
) { | ||
client.execute( | ||
GET_NOTIFICATION_EVENT_ACTION_TYPE, | ||
request, | ||
listener | ||
) | ||
} | ||
|
||
/** | ||
* Get notification plugin features. | ||
* @param client Node client for making transport action | ||
* @param request The request object | ||
* @param listener The listener for getting response | ||
*/ | ||
fun getPluginFeatures( | ||
client: NodeClient, | ||
request: GetPluginFeaturesRequest, | ||
listener: ActionListener<GetPluginFeaturesResponse> | ||
) { | ||
client.execute( | ||
GET_PLUGIN_FEATURES_ACTION_TYPE, | ||
request, | ||
listener | ||
) | ||
} | ||
|
||
/** | ||
* Get notification channel configuration enabled for a feature. | ||
* @param client Node client for making transport action | ||
* @param request The request object | ||
* @param listener The listener for getting response | ||
*/ | ||
fun getFeatureChannelList( | ||
client: NodeClient, | ||
request: GetFeatureChannelListRequest, | ||
listener: ActionListener<GetFeatureChannelListResponse> | ||
) { | ||
client.execute( | ||
GET_FEATURE_CHANNEL_LIST_ACTION_TYPE, | ||
request, | ||
listener | ||
) | ||
} | ||
|
||
/** | ||
* Send notification API enabled for a feature. No REST API. Internal API only for Inter plugin communication. | ||
* @param client Node client for making transport action | ||
* @param eventSource The notification event information | ||
* @param channelMessage The notification message | ||
* @param channelIds The list of channel ids to send message to. | ||
* @param listener The listener for getting response | ||
*/ | ||
fun sendNotification( | ||
client: NodeClient, | ||
eventSource: EventSource, | ||
channelMessage: ChannelMessage, | ||
channelIds: List<String>, | ||
listener: ActionListener<SendNotificationResponse> | ||
) { | ||
val threadContext: String? = | ||
client.threadPool().threadContext.getTransient<String>(OPENSEARCH_SECURITY_USER_INFO_THREAD_CONTEXT) | ||
val wrapper = SecureClientWrapper(client) // Executing request in privileged mode | ||
wrapper.execute( | ||
SEND_NOTIFICATION_ACTION_TYPE, | ||
SendNotificationRequest(eventSource, channelMessage, channelIds, threadContext), | ||
listener | ||
) | ||
} | ||
} |
59 changes: 59 additions & 0 deletions
59
src/main/kotlin/org/opensearch/commons/notifications/action/BaseResponse.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
/* | ||
* SPDX-License-Identifier: Apache-2.0 | ||
* | ||
* The OpenSearch Contributors require contributions made to | ||
* this file be licensed under the Apache-2.0 license or a | ||
* compatible open source license. | ||
* | ||
* Modifications Copyright OpenSearch Contributors. See | ||
* GitHub history for details. | ||
*/ | ||
|
||
/* | ||
* Copyright 2021 Amazon.com, Inc. or its affiliates. All Rights Reserved. | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"). | ||
* You may not use this file except in compliance with the License. | ||
* A copy of the License is located at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* or in the "license" file accompanying this file. This file is distributed | ||
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either | ||
* express or implied. See the License for the specific language governing | ||
* permissions and limitations under the License. | ||
* | ||
*/ | ||
|
||
package org.opensearch.commons.notifications.action | ||
|
||
import org.opensearch.action.ActionResponse | ||
import org.opensearch.common.io.stream.StreamInput | ||
import org.opensearch.common.xcontent.ToXContentObject | ||
import org.opensearch.rest.RestStatus | ||
import java.io.IOException | ||
|
||
/** | ||
* Base response which give REST status. | ||
*/ | ||
abstract class BaseResponse : ActionResponse, ToXContentObject { | ||
|
||
/** | ||
* constructor for creating the class | ||
*/ | ||
constructor() | ||
|
||
/** | ||
* {@inheritDoc} | ||
*/ | ||
@Throws(IOException::class) | ||
constructor(input: StreamInput) : super(input) | ||
|
||
/** | ||
* get rest status for the response. Useful override for multi-status response. | ||
* @return RestStatus for the response | ||
*/ | ||
open fun getStatus(): RestStatus { | ||
return RestStatus.OK | ||
} | ||
} |
Oops, something went wrong.