Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Search pipelines added #172

Merged
merged 9 commits into from
Mar 24, 2024
2 changes: 2 additions & 0 deletions model/opensearch.smithy
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,7 @@ service OpenSearch {
CreateUser,
Create_Post,
Create_Put,
CreateSearchPipeline,
DanglingIndicesDeleteDanglingIndex,
DanglingIndicesImportDanglingIndex,
DanglingIndicesListDanglingIndices,
Expand Down Expand Up @@ -143,6 +144,7 @@ service OpenSearch {
GetRoles,
GetRoleMapping,
GetRoleMappings,
GetSearchPipeline,
GetTenant,
GetTenants,
GetUser,
Expand Down
23 changes: 23 additions & 0 deletions model/search_pipeline/create/operations.smithy
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
// 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.

$version: "2"
namespace OpenSearch

@externalDocumentation(
"API Reference": "https://opensearch.org/docs/latest/search-plugins/search-pipelines/creating-search-pipeline/"
)

@xOperationGroup("search_pipeline.create")
@xVersionAdded("2.9")
@idempotent
@suppress(["HttpUriConflict"])
@http(method: "PUT", uri: "/_search/pipeline/{pipeline}")
@documentation("Creates or replaces the specified search pipeline.")
operation CreateSearchPipeline {
input: CreateSearchPipeline_Input,
output: CreateSearchPipeline_Output
}
24 changes: 24 additions & 0 deletions model/search_pipeline/create/structures.smithy
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
// 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.

$version: "2"
namespace OpenSearch


@input
structure CreateSearchPipeline_Input{
@required
@httpLabel
pipeline: String
@required
@httpPayload
content: SearchPipelineStructure
}

@output
structure CreateSearchPipeline_Output {
acknowledged: Boolean
}
34 changes: 34 additions & 0 deletions model/search_pipeline/get/operations.smithy
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
// 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.

$version: "2"
namespace OpenSearch

@externalDocumentation(
"API Reference": "https://opensearch.org/docs/latest/search-plugins/search-pipelines/index/"
)

@xOperationGroup("search_pipeline.get")
@xVersionAdded("2.9")
@readonly
@suppress(["HttpUriConflict"])
@http(method: "GET", uri: "/_search/pipeline")
@documentation("Retrieves information about search pipelines.")
operation GetSearchPipelines {
input: GetSearchPipelines_Input,
output: GetSearchPipelines_Output
}

@xOperationGroup("search_pipeline.get")
@xVersionAdded("2.9")
@readonly
@suppress(["HttpUriConflict"])
@http(method: "GET", uri: "/_search/pipeline/{pipeline}")
Tokesh marked this conversation as resolved.
Show resolved Hide resolved
@documentation("Retrieves information about a specified search pipeline.")
operation GetSearchPipeline {
input: GetSearchPipeline_Input,
output: GetSearchPipeline_Output
}
31 changes: 31 additions & 0 deletions model/search_pipeline/get/structures.smithy
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
// 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.

$version: "2"
namespace OpenSearch

@input
structure GetSearchPipelines_Input {
}

@output
structure GetSearchPipelines_Output {
@httpPayload
content: SearchPipelineMap
}

@input
structure GetSearchPipeline_Input {
@required
@httpLabel
pipeline: String,
}

@output
structure GetSearchPipeline_Output {
@httpPayload
content: SearchPipelineMap
}
110 changes: 110 additions & 0 deletions model/search_pipeline/search_pipeline.smithy
Original file line number Diff line number Diff line change
@@ -0,0 +1,110 @@
// 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.

$version: "2"
namespace OpenSearch

map SearchPipelineMap{
key: String,
value: SearchPipelineStructure
}

structure SearchPipelineStructure{
version: Integer,
request_processors: RequestProcessorsList,
response_processors: ResponseProcessorsList,
phase_results_processors: PhaseResultsProcessorsList
}

list RequestProcessorsList {
member: RequestProcessors
}

list ResponseProcessorsList {
member: RequestProcessors
}

list PhaseResultsProcessorsList {
member: PhaseResultsProcessors
}

structure RequestProcessors {
filter_query: FilterQuery,
neural_query_enricher: NeuralQueryEnricher,
script: SearchScript
}

structure ResponseProcessors {
personalize_search_ranking: PersonalizeSearchRanking,
rename_field: RenameField,
}
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Really these are more like unions rather than structures, but not sure how the OpenAPI conversion handles unions.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Union will become oneOf in OpenAPI

Copy link
Collaborator Author

@Tokesh Tokesh Feb 8, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I never used unions. Do i need to implement it here?


structure PhaseResultsProcessors {
normalization: ScoreNormalization,
combination: ScoreCombination,
tag: String,
description: String,
ignore_failure: Boolean
}

structure ScoreNormalization{
technique: String
}

structure ScoreCombination{
technique: String,
parameters: ScoreWeights
}

list ScoreWeights{
member: Float
}

structure FilterQuery {
query: UserDefinedObjectStructure,
tag: String,
description: String,
ignore_failure: Boolean
}

structure NeuralQueryEnricher {
default_model_id: String,
neural_field_default_id: NeuralFieldMap
tag: String,
description: String,
}

structure SearchScript {
source: String,
lang: String,
tag: String,
description: String,
ignore_failure: Boolean
}

structure PersonalizeSearchRanking {
campaign_arn: String,
recipe: String,
weight: Float,
item_id_field: String,
iam_role_arn: String,
tag: String,
description: String,
ignore_failure: Boolean
}

structure RenameField {
field: String,
target_field: String,
tag: String,
description: String,
ignore_failure: Boolean
}

map NeuralFieldMap {
key: String,
value: String
}
Tokesh marked this conversation as resolved.
Show resolved Hide resolved
Loading