/* 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. * * Licensed to Elasticsearch B.V. under one or more contributor * license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright * ownership. Elasticsearch B.V. licenses this file to you under * the Apache License, Version 2.0 (the "License"); you may * not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License 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. */ using System; using System.Linq.Expressions; using System.Runtime.Serialization; using OpenSearch.Net.Utf8Json; namespace OpenSearch.Client.Specification.IngestApi { /// /// Converts a string field by applying a regular expression and a replacement. /// If the field is not a string, the processor will throw an exception. /// [InterfaceDataContract] public interface IGsubProcessor : IProcessor { /// /// The field to apply the replacement to /// [DataMember(Name ="field")] Field Field { get; set; } /// /// The field to assign the converted value to, by default field is updated in-place /// [DataMember(Name = "target_field")] Field TargetField { get; set; } /// /// The pattern to be replaced /// [DataMember(Name ="pattern")] string Pattern { get; set; } /// /// The string to replace the matching patterns with /// [DataMember(Name ="replacement")] string Replacement { get; set; } /// /// If true and does not exist or is null, /// the processor quietly exits without modifying the document. Default is false /// [DataMember(Name = "ignore_missing")] bool? IgnoreMissing { get; set; } } /// public class GsubProcessor : ProcessorBase, IGsubProcessor { /// public Field Field { get; set; } /// public Field TargetField { get; set; } /// public string Pattern { get; set; } /// public string Replacement { get; set; } /// public bool? IgnoreMissing { get; set; } protected override string Name => "gsub"; } /// public class GsubProcessorDescriptor : ProcessorDescriptorBase, IGsubProcessor>, IGsubProcessor where T : class { protected override string Name => "gsub"; Field IGsubProcessor.Field { get; set; } Field IGsubProcessor.TargetField { get; set; } string IGsubProcessor.Pattern { get; set; } string IGsubProcessor.Replacement { get; set; } bool? IGsubProcessor.IgnoreMissing { get; set; } /// public GsubProcessorDescriptor Field(Field field) => Assign(field, (a, v) => a.Field = v); /// public GsubProcessorDescriptor Field(Expression> objectPath) => Assign(objectPath, (a, v) => a.Field = v); /// public GsubProcessorDescriptor TargetField(Field field) => Assign(field, (a, v) => a.TargetField = v); /// public GsubProcessorDescriptor TargetField(Expression> objectPath) => Assign(objectPath, (a, v) => a.TargetField = v); /// public GsubProcessorDescriptor Pattern(string pattern) => Assign(pattern, (a, v) => a.Pattern = v); /// public GsubProcessorDescriptor Replacement(string replacement) => Assign(replacement, (a, v) => a.Replacement = v); /// public GsubProcessorDescriptor IgnoreMissing(bool? ignoreMissing = true) => Assign(ignoreMissing, (a, v) => a.IgnoreMissing = v); } }