/* 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 OpenSearch.Net; using OpenSearch.Net.Utf8Json; using OpenSearch.Net.Utf8Json.Internal; namespace OpenSearch.Client { internal class MovingAverageAggregationFormatter : IJsonFormatter { private static readonly AutomataDictionary AutomataDictionary = new AutomataDictionary { { "format", 0 }, { "gap_policy", 1 }, { "minimize", 2 }, { "predict", 3 }, { "window", 4 }, { "settings", 5 }, { "model", 6 }, { "buckets_path", 7 } }; private static readonly AutomataDictionary ModelDictionary = new AutomataDictionary { { "linear", 0 }, { "simple", 1 }, { "ewma", 2 }, { "holt", 3 }, { "holt_winters", 4 } }; public IMovingAverageAggregation Deserialize(ref JsonReader reader, IJsonFormatterResolver formatterResolver) { if (reader.GetCurrentJsonToken() != JsonToken.BeginObject) { reader.ReadNextBlock(); return null; } var count = 0; var aggregation = new MovingAverageAggregation(); ArraySegment model = default; ArraySegment modelSegment = default; while (reader.ReadIsInObject(ref count)) { var propertyName = reader.ReadPropertyNameSegmentRaw(); if (AutomataDictionary.TryGetValue(propertyName, out var value)) { switch (value) { case 0: aggregation.Format = reader.ReadString(); break; case 1: aggregation.GapPolicy = formatterResolver.GetFormatter() .Deserialize(ref reader, formatterResolver); break; case 2: aggregation.Minimize = reader.ReadBoolean(); break; case 3: aggregation.Predict = reader.ReadInt32(); break; case 4: aggregation.Window = reader.ReadInt32(); break; case 5: modelSegment = reader.ReadNextBlockSegment(); break; case 6: model = reader.ReadStringSegmentUnsafe(); break; case 7: var path = reader.ReadString(); if (!string.IsNullOrEmpty(path)) aggregation.BucketsPath = new SingleBucketsPath(path); break; } } } if (model != default && ModelDictionary.TryGetValue(model, out var modelValue)) { var modelReader = new JsonReader(modelSegment.Array, modelSegment.Offset); switch (modelValue) { case 0: aggregation.Model = formatterResolver.GetFormatter() .Deserialize(ref modelReader, formatterResolver); break; case 1: aggregation.Model = formatterResolver.GetFormatter() .Deserialize(ref modelReader, formatterResolver); break; case 2: aggregation.Model = formatterResolver.GetFormatter() .Deserialize(ref modelReader, formatterResolver); break; case 3: aggregation.Model = formatterResolver.GetFormatter() .Deserialize(ref modelReader, formatterResolver); break; case 4: aggregation.Model = formatterResolver.GetFormatter() .Deserialize(ref modelReader, formatterResolver); break; } } return aggregation; } public void Serialize(ref JsonWriter writer, IMovingAverageAggregation value, IJsonFormatterResolver formatterResolver) { if (value == null) { writer.WriteNull(); return; } writer.WriteBeginObject(); var propertyWritten = false; if (value.BucketsPath != null) { writer.WritePropertyName("buckets_path"); var formatter = formatterResolver.GetFormatter(); formatter.Serialize(ref writer, value.BucketsPath, formatterResolver); propertyWritten = true; } if (value.GapPolicy != null) { if (propertyWritten) writer.WriteValueSeparator(); writer.WritePropertyName("gap_policy"); writer.WriteString(value.GapPolicy.GetStringValue()); propertyWritten = true; } if (!value.Format.IsNullOrEmpty()) { if (propertyWritten) writer.WriteValueSeparator(); writer.WritePropertyName("format"); writer.WriteString(value.Format); propertyWritten = true; } if (value.Window != null) { if (propertyWritten) writer.WriteValueSeparator(); writer.WritePropertyName("window"); writer.WriteInt32(value.Window.Value); propertyWritten = true; } if (value.Minimize != null) { if (propertyWritten) writer.WriteValueSeparator(); writer.WritePropertyName("minimize"); writer.WriteBoolean(value.Minimize.Value); propertyWritten = true; } if (value.Predict != null) { if (propertyWritten) writer.WriteValueSeparator(); writer.WritePropertyName("predict"); writer.WriteInt32(value.Predict.Value); propertyWritten = true; } if (value.Model != null) { if (propertyWritten) writer.WriteValueSeparator(); writer.WritePropertyName("model"); writer.WriteString(value.Model.Name); writer.WriteValueSeparator(); writer.WritePropertyName("settings"); switch (value.Model.Name) { case "ewma": Serialize(ref writer, (IEwmaModel)value.Model, formatterResolver); break; case "linear": Serialize(ref writer, (ILinearModel)value.Model, formatterResolver); break; case "simple": Serialize(ref writer, (ISimpleModel)value.Model, formatterResolver); break; case "holt": Serialize(ref writer, (IHoltLinearModel)value.Model, formatterResolver); break; case "holt_winters": Serialize(ref writer, (IHoltWintersModel)value.Model, formatterResolver); break; default: Serialize(ref writer, value.Model, formatterResolver); break; } } writer.WriteEndObject(); } private static void Serialize(ref JsonWriter writer, TModel model, IJsonFormatterResolver formatterResolver) where TModel : IMovingAverageModel { var formatter = formatterResolver.GetFormatter(); formatter.Serialize(ref writer, model, formatterResolver); } } }