-
Notifications
You must be signed in to change notification settings - Fork 114
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch '2.x' of github.com:bowenlan-amzn/index-management into 2.x
- Loading branch information
Showing
34 changed files
with
2,363 additions
and
4 deletions.
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
70 changes: 70 additions & 0 deletions
70
.../kotlin/org/opensearch/indexmanagement/controlcenter/notification/ControlCenterIndices.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,70 @@ | ||
/* | ||
* Copyright OpenSearch Contributors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package org.opensearch.indexmanagement.controlcenter.notification | ||
|
||
import org.opensearch.ResourceAlreadyExistsException | ||
import org.opensearch.action.ActionListener | ||
import org.opensearch.action.admin.indices.create.CreateIndexRequest | ||
import org.opensearch.action.admin.indices.create.CreateIndexResponse | ||
import org.opensearch.action.support.master.AcknowledgedResponse | ||
import org.opensearch.client.IndicesAdminClient | ||
import org.opensearch.cluster.service.ClusterService | ||
import org.opensearch.common.settings.Settings | ||
import org.opensearch.indexmanagement.IndexManagementPlugin | ||
import org.opensearch.indexmanagement.indexstatemanagement.util.INDEX_HIDDEN | ||
import org.opensearch.indexmanagement.util.IndexUtils | ||
|
||
class ControlCenterIndices( | ||
private val client: IndicesAdminClient, | ||
private val clusterService: ClusterService, | ||
) { | ||
|
||
fun checkAndUpdateControlCenterIndex(actionListener: ActionListener<AcknowledgedResponse>) { | ||
if (!controlCenterIndexExists()) { | ||
val indexRequest = CreateIndexRequest(IndexManagementPlugin.CONTROL_CENTER_INDEX) | ||
.mapping(controlCenterMappings) | ||
.settings(Settings.builder().put(INDEX_HIDDEN, true).build()) | ||
client.create( | ||
indexRequest, | ||
object : ActionListener<CreateIndexResponse> { | ||
override fun onFailure(e: Exception) { | ||
if (e is ResourceAlreadyExistsException) { | ||
/* if two request create the control center index at the same time, may raise this exception */ | ||
/* but we don't take it as error */ | ||
actionListener.onResponse( | ||
CreateIndexResponse( | ||
true, | ||
true, | ||
IndexManagementPlugin.CONTROL_CENTER_INDEX | ||
) | ||
) | ||
} else actionListener.onFailure(e) | ||
} | ||
|
||
override fun onResponse(response: CreateIndexResponse) { | ||
actionListener.onResponse(response) | ||
} | ||
} | ||
) | ||
} else { | ||
IndexUtils.checkAndUpdateIndexMapping( | ||
IndexManagementPlugin.CONTROL_CENTER_INDEX, | ||
IndexUtils.getSchemaVersion(controlCenterMappings), | ||
controlCenterMappings, | ||
clusterService.state(), | ||
client, | ||
actionListener | ||
) | ||
} | ||
} | ||
|
||
private fun controlCenterIndexExists(): Boolean = clusterService.state().routingTable.hasIndex(IndexManagementPlugin.CONTROL_CENTER_INDEX) | ||
|
||
companion object { | ||
val controlCenterMappings = ControlCenterIndices::class.java.classLoader | ||
.getResource("mappings/opensearch-control-center.json")!!.readText() | ||
} | ||
} |
46 changes: 46 additions & 0 deletions
46
...in/kotlin/org/opensearch/indexmanagement/controlcenter/notification/LRONConfigResponse.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,46 @@ | ||
/* | ||
* Copyright OpenSearch Contributors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package org.opensearch.indexmanagement.controlcenter.notification | ||
|
||
import org.opensearch.action.ActionResponse | ||
import org.opensearch.common.io.stream.StreamInput | ||
import org.opensearch.common.io.stream.StreamOutput | ||
import org.opensearch.core.xcontent.ToXContent | ||
import org.opensearch.core.xcontent.ToXContentObject | ||
import org.opensearch.core.xcontent.XContentBuilder | ||
import org.opensearch.indexmanagement.controlcenter.notification.model.LRONConfig | ||
import org.opensearch.indexmanagement.controlcenter.notification.util.WITH_PRIORITY | ||
import org.opensearch.indexmanagement.indexstatemanagement.util.WITH_TYPE | ||
import org.opensearch.indexmanagement.indexstatemanagement.util.WITH_USER | ||
import org.opensearch.indexmanagement.util._ID | ||
import java.io.IOException | ||
|
||
class LRONConfigResponse( | ||
val id: String, | ||
val lronConfig: LRONConfig | ||
) : ActionResponse(), ToXContentObject { | ||
@Throws(IOException::class) | ||
constructor(sin: StreamInput) : this( | ||
id = sin.readString(), | ||
lronConfig = LRONConfig(sin) | ||
) | ||
|
||
override fun writeTo(out: StreamOutput) { | ||
out.writeString(id) | ||
lronConfig.writeTo(out) | ||
} | ||
|
||
override fun toXContent(builder: XContentBuilder, params: ToXContent.Params): XContentBuilder { | ||
builder.startObject() | ||
.field(_ID, id) | ||
|
||
/* drop user info in rest layer. only keep user info in transport layer */ | ||
val lronConfigParams = ToXContent.MapParams(mapOf(WITH_TYPE to "false", WITH_USER to "false", WITH_PRIORITY to "false")) | ||
builder.field(LRONConfig.LRON_CONFIG_FIELD, lronConfig, lronConfigParams) | ||
|
||
return builder.endObject() | ||
} | ||
} |
16 changes: 16 additions & 0 deletions
16
...search/indexmanagement/controlcenter/notification/action/delete/DeleteLRONConfigAction.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,16 @@ | ||
/* | ||
* Copyright OpenSearch Contributors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package org.opensearch.indexmanagement.controlcenter.notification.action.delete | ||
|
||
import org.opensearch.action.ActionType | ||
import org.opensearch.action.delete.DeleteResponse | ||
|
||
class DeleteLRONConfigAction private constructor() : ActionType<DeleteResponse>(NAME, ::DeleteResponse) { | ||
companion object { | ||
val INSTANCE = DeleteLRONConfigAction() | ||
const val NAME = "cluster:admin/opensearch/controlcenter/lron/delete" | ||
} | ||
} |
39 changes: 39 additions & 0 deletions
39
...earch/indexmanagement/controlcenter/notification/action/delete/DeleteLRONConfigRequest.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,39 @@ | ||
/* | ||
* Copyright OpenSearch Contributors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package org.opensearch.indexmanagement.controlcenter.notification.action.delete | ||
|
||
import org.opensearch.action.ActionRequest | ||
import org.opensearch.action.ActionRequestValidationException | ||
import org.opensearch.action.ValidateActions | ||
import org.opensearch.common.io.stream.StreamInput | ||
import org.opensearch.common.io.stream.StreamOutput | ||
import org.opensearch.indexmanagement.controlcenter.notification.util.LRON_DOC_ID_PREFIX | ||
import java.io.IOException | ||
|
||
class DeleteLRONConfigRequest( | ||
val docId: String | ||
) : ActionRequest() { | ||
@Throws(IOException::class) | ||
constructor(sin: StreamInput) : this( | ||
docId = sin.readString() | ||
) | ||
|
||
override fun validate(): ActionRequestValidationException? { | ||
var validationException: ActionRequestValidationException? = null | ||
if (!(docId.startsWith(LRON_DOC_ID_PREFIX))) { | ||
validationException = ValidateActions.addValidationError( | ||
"Invalid LRONConfig ID", | ||
validationException | ||
) | ||
} | ||
return validationException | ||
} | ||
|
||
@Throws(IOException::class) | ||
override fun writeTo(out: StreamOutput) { | ||
out.writeString(docId) | ||
} | ||
} |
58 changes: 58 additions & 0 deletions
58
...dexmanagement/controlcenter/notification/action/delete/TransportDeleteLRONConfigAction.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,58 @@ | ||
/* | ||
* Copyright OpenSearch Contributors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package org.opensearch.indexmanagement.controlcenter.notification.action.delete | ||
|
||
import org.apache.logging.log4j.LogManager | ||
import org.opensearch.action.ActionListener | ||
import org.opensearch.action.delete.DeleteRequest | ||
import org.opensearch.action.delete.DeleteResponse | ||
import org.opensearch.action.support.ActionFilters | ||
import org.opensearch.action.support.HandledTransportAction | ||
import org.opensearch.action.support.WriteRequest | ||
import org.opensearch.client.node.NodeClient | ||
import org.opensearch.common.inject.Inject | ||
import org.opensearch.commons.ConfigConstants | ||
import org.opensearch.indexmanagement.IndexManagementPlugin | ||
import org.opensearch.tasks.Task | ||
import org.opensearch.transport.TransportService | ||
|
||
class TransportDeleteLRONConfigAction @Inject constructor( | ||
val client: NodeClient, | ||
transportService: TransportService, | ||
actionFilters: ActionFilters | ||
) : HandledTransportAction<DeleteLRONConfigRequest, DeleteResponse>( | ||
DeleteLRONConfigAction.NAME, transportService, actionFilters, ::DeleteLRONConfigRequest | ||
) { | ||
private val log = LogManager.getLogger(javaClass) | ||
|
||
override fun doExecute(task: Task, request: DeleteLRONConfigRequest, listener: ActionListener<DeleteResponse>) { | ||
DeleteLRONConfigHandler(client, listener, request).start() | ||
} | ||
|
||
inner class DeleteLRONConfigHandler( | ||
private val client: NodeClient, | ||
private val actionListener: ActionListener<DeleteResponse>, | ||
private val request: DeleteLRONConfigRequest, | ||
private val docId: String = request.docId | ||
) { | ||
fun start() { | ||
log.debug( | ||
"User and roles string from thread context: ${ | ||
client.threadPool().threadContext.getTransient<String>( | ||
ConfigConstants.OPENSEARCH_SECURITY_USER_INFO_THREAD_CONTEXT | ||
) | ||
}" | ||
) | ||
|
||
client.threadPool().threadContext.stashContext().use { | ||
val deleteRequest = DeleteRequest(IndexManagementPlugin.CONTROL_CENTER_INDEX, docId) | ||
.setRefreshPolicy(WriteRequest.RefreshPolicy.IMMEDIATE) | ||
|
||
client.delete(deleteRequest, actionListener) | ||
} | ||
} | ||
} | ||
} |
15 changes: 15 additions & 0 deletions
15
...g/opensearch/indexmanagement/controlcenter/notification/action/get/GetLRONConfigAction.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,15 @@ | ||
/* | ||
* Copyright OpenSearch Contributors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package org.opensearch.indexmanagement.controlcenter.notification.action.get | ||
|
||
import org.opensearch.action.ActionType | ||
|
||
class GetLRONConfigAction private constructor() : ActionType<GetLRONConfigResponse>(NAME, ::GetLRONConfigResponse) { | ||
companion object { | ||
val INSTANCE = GetLRONConfigAction() | ||
const val NAME = "cluster:admin/opensearch/controlcenter/lron/get" | ||
} | ||
} |
55 changes: 55 additions & 0 deletions
55
.../opensearch/indexmanagement/controlcenter/notification/action/get/GetLRONConfigRequest.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,55 @@ | ||
/* | ||
* Copyright OpenSearch Contributors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package org.opensearch.indexmanagement.controlcenter.notification.action.get | ||
|
||
import org.opensearch.action.ActionRequest | ||
import org.opensearch.action.ActionRequestValidationException | ||
import org.opensearch.action.ValidateActions | ||
import org.opensearch.common.io.stream.StreamInput | ||
import org.opensearch.common.io.stream.StreamOutput | ||
import org.opensearch.indexmanagement.common.model.rest.SearchParams | ||
import org.opensearch.indexmanagement.controlcenter.notification.util.LRON_DOC_ID_PREFIX | ||
import java.io.IOException | ||
|
||
class GetLRONConfigRequest( | ||
val docId: String? = null, | ||
val searchParams: SearchParams? = null | ||
) : ActionRequest() { | ||
@Throws(IOException::class) | ||
constructor(sin: StreamInput) : this( | ||
docId = sin.readOptionalString(), | ||
searchParams = sin.readOptionalWriteable(::SearchParams) | ||
) | ||
|
||
override fun validate(): ActionRequestValidationException? { | ||
var validationException: ActionRequestValidationException? = null | ||
if (null == docId && null == searchParams) { | ||
validationException = ValidateActions.addValidationError( | ||
"GetLRONConfigRequest must contain docId or searchParams", | ||
validationException | ||
) | ||
} | ||
if (null != docId && null != searchParams) { | ||
validationException = ValidateActions.addValidationError( | ||
"Get LRONConfig requires either docId or searchParams to be specified", | ||
validationException | ||
) | ||
} | ||
if (null != docId && !docId.startsWith(LRON_DOC_ID_PREFIX)) { | ||
validationException = ValidateActions.addValidationError( | ||
"Invalid LRONConfig ID", | ||
validationException | ||
) | ||
} | ||
return validationException | ||
} | ||
|
||
@Throws(IOException::class) | ||
override fun writeTo(out: StreamOutput) { | ||
out.writeOptionalString(docId) | ||
out.writeOptionalWriteable(searchParams) | ||
} | ||
} |
Oops, something went wrong.