From 75d631bf74c66f62dbadfeed877553f28005a320 Mon Sep 17 00:00:00 2001 From: Thomas Farr Date: Tue, 19 Sep 2023 10:11:03 +1200 Subject: [PATCH 1/4] Handle generating deprecation notices on high-level API methods Signed-off-by: Thomas Farr --- .../HighLevel/Methods/BoundFluentMethod.cs | 18 ++++---- .../Code/HighLevel/Methods/FluentMethod.cs | 6 +-- .../HighLevel/Methods/FluentSyntaxBase.cs | 24 +++++----- .../HighLevel/Methods/InitializerMethod.cs | 3 +- .../HighLevel/Methods/MethodSyntaxBase.cs | 8 +++- .../Domain/Specification/ApiEndpoint.cs | 24 +++++++--- .../Domain/Specification/Deprecation.cs | 44 +++++++++++++++++++ .../Domain/Specification/QueryParameters.cs | 31 +++---------- .../Generator/ApiEndpointFactory.cs | 4 +- .../HighLevel/Client/MethodXmlDocs.cshtml | 4 ++ 10 files changed, 104 insertions(+), 62 deletions(-) create mode 100644 src/ApiGenerator/Domain/Specification/Deprecation.cs diff --git a/src/ApiGenerator/Domain/Code/HighLevel/Methods/BoundFluentMethod.cs b/src/ApiGenerator/Domain/Code/HighLevel/Methods/BoundFluentMethod.cs index 7e005f027f..e7231c5523 100644 --- a/src/ApiGenerator/Domain/Code/HighLevel/Methods/BoundFluentMethod.cs +++ b/src/ApiGenerator/Domain/Code/HighLevel/Methods/BoundFluentMethod.cs @@ -31,16 +31,16 @@ using ApiGenerator.Configuration; using ApiGenerator.Domain.Specification; -namespace ApiGenerator.Domain.Code.HighLevel.Methods +namespace ApiGenerator.Domain.Code.HighLevel.Methods { public class BoundFluentMethod : FluentSyntaxBase { - public BoundFluentMethod(CsharpNames names, IReadOnlyCollection parts, bool selectorIsOptional, string link, string summary) - : base(names, parts, selectorIsOptional, link, summary) { } + public BoundFluentMethod(CsharpNames names, IReadOnlyCollection parts, bool selectorIsOptional, string link, string summary, Deprecation deprecated) + : base(names, parts, selectorIsOptional, link, summary, deprecated) { } private string DescriptorTypeParams => string.Join(", ", CsharpNames.DescriptorGenerics .Select(e => CsharpNames.DescriptorBoundDocumentGeneric)); - + private string RequestTypeParams => string.Join(", ", CsharpNames.SplitGeneric(CsharpNames.GenericsDeclaredOnRequest) .Select(e => CsharpNames.DescriptorBoundDocumentGeneric)); @@ -48,17 +48,17 @@ public BoundFluentMethod(CsharpNames names, IReadOnlyCollection parts, || !CodeConfiguration.GenericOnlyInterfaces.Contains(CsharpNames.RequestInterfaceName) ? CsharpNames.RequestInterfaceName : $"{CsharpNames.RequestInterfaceName}<{RequestTypeParams}>"; - + public override string DescriptorName => $"{CsharpNames.DescriptorName}<{DescriptorTypeParams}>"; public override string GenericWhereClause => $"where {CsharpNames.DescriptorBoundDocumentGeneric} : class"; public override string MethodGenerics => $"<{CsharpNames.DescriptorBoundDocumentGeneric}>"; - - public override string RequestMethodGenerics => !string.IsNullOrWhiteSpace(RequestTypeParams) + + public override string RequestMethodGenerics => !string.IsNullOrWhiteSpace(RequestTypeParams) ? $"<{RequestTypeParams}>" : base.RequestMethodGenerics; - + public override string Selector => $"Func<{DescriptorName}, {SelectorReturn}>"; - + } } diff --git a/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentMethod.cs b/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentMethod.cs index 07c5ccd5a9..62f138abda 100644 --- a/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentMethod.cs +++ b/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentMethod.cs @@ -30,12 +30,12 @@ using System.Linq; using ApiGenerator.Domain.Specification; -namespace ApiGenerator.Domain.Code.HighLevel.Methods +namespace ApiGenerator.Domain.Code.HighLevel.Methods { public class FluentMethod : FluentSyntaxBase { - public FluentMethod(CsharpNames names, IReadOnlyCollection parts, bool selectorIsOptional, string link, string summary) - : base(names, parts, selectorIsOptional, link, summary) { } + public FluentMethod(CsharpNames names, IReadOnlyCollection parts, bool selectorIsOptional, string link, string summary, Deprecation deprecated) + : base(names, parts, selectorIsOptional, link, summary, deprecated) { } public override string GenericWhereClause => string.Join(" ", CsharpNames.HighLevelDescriptorMethodGenerics diff --git a/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentSyntaxBase.cs b/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentSyntaxBase.cs index abff18c282..560fee547b 100644 --- a/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentSyntaxBase.cs +++ b/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentSyntaxBase.cs @@ -31,14 +31,14 @@ using ApiGenerator.Configuration; using ApiGenerator.Domain.Specification; -namespace ApiGenerator.Domain.Code.HighLevel.Methods +namespace ApiGenerator.Domain.Code.HighLevel.Methods { public abstract class FluentSyntaxBase : MethodSyntaxBase { private readonly bool _selectorIsOptional; - protected FluentSyntaxBase(CsharpNames names, IReadOnlyCollection parts, bool selectorIsOptional, string link, string summary) - : base(names, link, summary) => + protected FluentSyntaxBase(CsharpNames names, IReadOnlyCollection parts, bool selectorIsOptional, string link, string summary, Deprecation deprecated) + : base(names, link, summary, deprecated) => (UrlParts, _selectorIsOptional) = (CreateDescriptorArgs(parts), selectorIsOptional); private IReadOnlyCollection UrlParts { get; } @@ -61,7 +61,7 @@ protected FluentSyntaxBase(CsharpNames names, IReadOnlyCollection parts CodeConfiguration.GenericOnlyInterfaces.Contains(CsharpNames.RequestInterfaceName) ? CsharpNames.GenericsDeclaredOnRequest : DescriptorGenerics; - + public virtual string RequestMethodGenerics => CodeConfiguration.GenericOnlyInterfaces.Contains(CsharpNames.RequestInterfaceName) ? CsharpNames.GenericsDeclaredOnRequest @@ -74,11 +74,11 @@ protected FluentSyntaxBase(CsharpNames names, IReadOnlyCollection parts private List CreateDescriptorArgs(IReadOnlyCollection parts) { var requiredParts = parts.Where(p => p.Required).ToList(); - + //Many api's return ALOT of information by default e.g get_alias or get_mapping //the client methods that take a descriptor default to forcing a choice on the user. //except for cat api's where the amount of information returned is manageable - + var willInferFromDocument = CsharpNames.GenericsDeclaredOnDescriptor?.Contains("Document") ?? false; if (!requiredParts.Any() && CsharpNames.Namespace != "Cat") { @@ -113,15 +113,15 @@ private List CreateDescriptorArgs(IReadOnlyCollection parts) } private bool IsDocumentRequest => CodeConfiguration.DocumentRequests.Contains(CsharpNames.RequestInterfaceName); - private string GenericFirstArgument => + private string GenericFirstArgument => CsharpNames.GenericsDeclaredOnDescriptor.Replace("<", "").Replace(">", "").Split(",").First().Trim(); - + public string DescriptorArguments() { string codeArgs; if (CodeConfiguration.DescriptorConstructors.TryGetValue(CsharpNames.DescriptorName, out codeArgs)) codeArgs += ","; - + if (!UrlParts.Any()) return codeArgs; string Optional(UrlPart p) => !p.Required && SelectorIsOptional ? " = null" : string.Empty; @@ -136,17 +136,17 @@ public string SelectorArguments() codeArgs = string.Join(", ", codeArgs.Split(',').Select(a=>a.Split(' ').Last())); return codeArgs; } - + var parts = UrlParts.Where(p => p.Required).ToList(); if (!parts.Any()) return null; string ToArg(UrlPart p) { if (IsDocumentRequest) return "documentWithId: document"; - + if (p.HighLevelTypeName.StartsWith("DocumentPath")) return "documentWithId: id?.Document, index: id?.Self?.Index, id: id?.Self?.Id"; - + return $"{p.Name.ToCamelCase()}: {p.Name.ToCamelCase()}"; } diff --git a/src/ApiGenerator/Domain/Code/HighLevel/Methods/InitializerMethod.cs b/src/ApiGenerator/Domain/Code/HighLevel/Methods/InitializerMethod.cs index d47228b3ce..1520250e40 100644 --- a/src/ApiGenerator/Domain/Code/HighLevel/Methods/InitializerMethod.cs +++ b/src/ApiGenerator/Domain/Code/HighLevel/Methods/InitializerMethod.cs @@ -28,12 +28,13 @@ using System.Linq; using ApiGenerator.Configuration; +using ApiGenerator.Domain.Specification; namespace ApiGenerator.Domain.Code.HighLevel.Methods { public class InitializerMethod : MethodSyntaxBase { - public InitializerMethod(CsharpNames names, string link, string summary) : base(names, link, summary) { } + public InitializerMethod(CsharpNames names, string link, string summary, Deprecation deprecated) : base(names, link, summary, deprecated) { } public string MethodName => CsharpNames.MethodName; diff --git a/src/ApiGenerator/Domain/Code/HighLevel/Methods/MethodSyntaxBase.cs b/src/ApiGenerator/Domain/Code/HighLevel/Methods/MethodSyntaxBase.cs index 5e27c6d8e2..349c05e75d 100644 --- a/src/ApiGenerator/Domain/Code/HighLevel/Methods/MethodSyntaxBase.cs +++ b/src/ApiGenerator/Domain/Code/HighLevel/Methods/MethodSyntaxBase.cs @@ -26,17 +26,21 @@ * under the License. */ +using ApiGenerator.Domain.Specification; + namespace ApiGenerator.Domain.Code.HighLevel.Methods { public abstract class MethodSyntaxBase { - protected MethodSyntaxBase(CsharpNames names, string link, string summary) => - (CsharpNames, DocumentationLink, XmlDocSummary) = (names, link, summary); + protected MethodSyntaxBase(CsharpNames names, string link, string summary, Deprecation deprecated) => + (CsharpNames, DocumentationLink, XmlDocSummary, Deprecated) = (names, link, summary, deprecated); public string DocumentationLink { get; } public string XmlDocSummary { get; } + public Deprecation Deprecated { get; } + protected CsharpNames CsharpNames { get; } public bool InterfaceResponse => ResponseName.StartsWith("ISearchResponse<"); diff --git a/src/ApiGenerator/Domain/Specification/ApiEndpoint.cs b/src/ApiGenerator/Domain/Specification/ApiEndpoint.cs index 8ff2f8c41f..b07c2bca8f 100644 --- a/src/ApiGenerator/Domain/Specification/ApiEndpoint.cs +++ b/src/ApiGenerator/Domain/Specification/ApiEndpoint.cs @@ -117,24 +117,34 @@ public class ApiEndpoint public string HighLevelMethodXmlDocDescription => $"{PreferredHttpMethod} request to the {Name} API, read more about this API online:"; - public HighLevelModel HighLevelModel => new HighLevelModel - { + private bool BodyIsOptional => Body is not { Required: true } || HttpMethods.Contains("GET"); + + private Deprecation Deprecated => + Url.OriginalPaths.Count == 0 && Url.DeprecatedPaths.Count > 0 + ? Url.DeprecatedPaths.Select(p => new Deprecation { Description = p.Description, Version = p.Version }).FirstOrDefault() + : null; + + public HighLevelModel HighLevelModel => new() + { CsharpNames = CsharpNames, Fluent = new FluentMethod(CsharpNames, Url.Parts, - selectorIsOptional: Body == null || !Body.Required || HttpMethods.Contains("GET"), + selectorIsOptional: BodyIsOptional, link: OfficialDocumentationLink?.Url, - summary: HighLevelMethodXmlDocDescription + summary: HighLevelMethodXmlDocDescription, + deprecated: Deprecated ), FluentBound = !CsharpNames.DescriptorBindsOverMultipleDocuments ? null : new BoundFluentMethod(CsharpNames, Url.Parts, - selectorIsOptional: Body == null || !Body.Required || HttpMethods.Contains("GET"), + selectorIsOptional: BodyIsOptional, link: OfficialDocumentationLink?.Url, - summary: HighLevelMethodXmlDocDescription + summary: HighLevelMethodXmlDocDescription, + deprecated: Deprecated ), Initializer = new InitializerMethod(CsharpNames, link: OfficialDocumentationLink?.Url, - summary: HighLevelMethodXmlDocDescription + summary: HighLevelMethodXmlDocDescription, + deprecated: Deprecated ) }; diff --git a/src/ApiGenerator/Domain/Specification/Deprecation.cs b/src/ApiGenerator/Domain/Specification/Deprecation.cs new file mode 100644 index 0000000000..367a9741aa --- /dev/null +++ b/src/ApiGenerator/Domain/Specification/Deprecation.cs @@ -0,0 +1,44 @@ +// /* 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. +// */ + +namespace ApiGenerator.Domain.Specification; + +public class Deprecation +{ + public string Version { get; set; } + + public string Description { get; set; } + + public override string ToString() => + (!string.IsNullOrEmpty(Version), !string.IsNullOrEmpty(Description)) switch + { + (true, true) => $"Deprecated as of: {Version}, reason: {Description}", + (true, false) => $"Deprecated as of: {Version}", + (false, true) => $"reason: {Description}", + _ => "deprecated" + }; +} diff --git a/src/ApiGenerator/Domain/Specification/QueryParameters.cs b/src/ApiGenerator/Domain/Specification/QueryParameters.cs index f77b851068..da763df9a3 100644 --- a/src/ApiGenerator/Domain/Specification/QueryParameters.cs +++ b/src/ApiGenerator/Domain/Specification/QueryParameters.cs @@ -97,27 +97,13 @@ public IEnumerable DescriptionHighLevel public string Obsolete { - get - { - if (!string.IsNullOrEmpty(_obsolete)) return _obsolete; - if (Deprecated != null) - { - if (!string.IsNullOrEmpty(Deprecated.Version) && !string.IsNullOrEmpty(Deprecated.Description)) - return $"Deprecated as of: {Deprecated.Version}, reason: {Deprecated.Description}"; - if (!string.IsNullOrEmpty(Deprecated.Version)) - return $"Deprecated as of: {Deprecated.Version}"; - if (!string.IsNullOrEmpty(Deprecated.Description)) - return $"reason: {Deprecated.Description}"; - - return "deprecated"; - } - - return null; - } - set => _obsolete = value; + get => !string.IsNullOrEmpty(_obsolete) + ? _obsolete + : Deprecated?.ToString(); + set => _obsolete = value; } - public QueryParameterDeprecation Deprecated { get; set; } + public Deprecation Deprecated { get; set; } public IEnumerable Options { get; set; } public string QueryStringKey { get; set; } @@ -196,11 +182,4 @@ public string TypeLowLevel public string InitializerGenerator(string @namespace, string type, string name, string key, string setter, string versionAdded, params string[] doc) => CodeGenerator.Property(@namespace, type, name, key, setter, Obsolete, versionAdded, doc); } - - public class QueryParameterDeprecation - { - public string Version { get; set; } - - public string Description { get; set; } - } } diff --git a/src/ApiGenerator/Generator/ApiEndpointFactory.cs b/src/ApiGenerator/Generator/ApiEndpointFactory.cs index a8640adbe5..6b97f032fe 100644 --- a/src/ApiGenerator/Generator/ApiEndpointFactory.cs +++ b/src/ApiGenerator/Generator/ApiEndpointFactory.cs @@ -192,11 +192,11 @@ private static IEnumerable GetEnumOptions(JsonSchema schema) => ?? schema.ActualSchema.Enumeration?.Select(e => e.ToString()) ?? Enumerable.Empty(); - private static QueryParameterDeprecation GetDeprecation(IJsonExtensionObject schema) => + private static Deprecation GetDeprecation(IJsonExtensionObject schema) => (schema.XDeprecationMessage(), schema.XVersionDeprecated()) switch { (null, null) => null, - var (m, v) => new QueryParameterDeprecation { Description = m, Version = v } + var (m, v) => new Deprecation { Description = m, Version = v } }; private static string GetDescription(OpenApiRequestBody requestBody) diff --git a/src/ApiGenerator/Views/HighLevel/Client/MethodXmlDocs.cshtml b/src/ApiGenerator/Views/HighLevel/Client/MethodXmlDocs.cshtml index 26445d9ea9..723eb10db0 100644 --- a/src/ApiGenerator/Views/HighLevel/Client/MethodXmlDocs.cshtml +++ b/src/ApiGenerator/Views/HighLevel/Client/MethodXmlDocs.cshtml @@ -6,3 +6,7 @@ /// @Raw("") /// @Model.DocumentationLink /// +@if (Model.Deprecated is {} deprecation) +{ +@Raw($"[Obsolete(\"{deprecation}\")]") +} From bdc2059a5e9087290454ac32cfcfe50ed33d0d39 Mon Sep 17 00:00:00 2001 From: Thomas Farr Date: Wed, 20 Sep 2023 16:48:04 +1200 Subject: [PATCH 2/4] Improve formatting Signed-off-by: Thomas Farr --- .../Code/HighLevel/Requests/Constructor.cs | 2 +- .../DescriptorPartialImplementation.cs | 12 ++--- src/ApiGenerator/Domain/RestApiSpec.cs | 2 +- .../Domain/Specification/Deprecation.cs | 53 ++++++++++--------- .../Domain/Specification/UrlPath.cs | 4 +- src/ApiGenerator/Generator/CodeGenerator.cs | 6 +-- .../Client/FluentSyntax/FluentMethod.cshtml | 6 +-- .../OpenSearchClient.Namespace.cshtml | 6 +-- .../Implementation/OpenSearchClient.cshtml | 12 ++--- .../Client/Interface/IOpenSearchClient.cshtml | 10 ++-- .../HighLevel/Descriptors/XmlDocs.cshtml | 7 +-- .../Requests/RequestImplementations.cshtml | 6 +-- .../OpenSearchLowLevelClient.Namespace.cshtml | 12 ++--- .../OpenSearchLowLevelClient.cshtml | 12 ++--- .../IOpenSearchLowLevelClient.cshtml | 10 ++-- .../LowLevel/Client/Methods/MethodDocs.cshtml | 11 ++-- .../RequestParameters.cshtml | 4 +- 17 files changed, 89 insertions(+), 86 deletions(-) diff --git a/src/ApiGenerator/Domain/Code/HighLevel/Requests/Constructor.cs b/src/ApiGenerator/Domain/Code/HighLevel/Requests/Constructor.cs index a46a85660e..fcf1562b36 100644 --- a/src/ApiGenerator/Domain/Code/HighLevel/Requests/Constructor.cs +++ b/src/ApiGenerator/Domain/Code/HighLevel/Requests/Constructor.cs @@ -127,7 +127,7 @@ string generic Parameterless = true, Generated = $"protected {typeName}() : base()", Description = - $"///Used for serialization purposes, making sure we have a parameterless constructor{Indent}[SerializationConstructor]", + $"/// Used for serialization purposes, making sure we have a parameterless constructor{Indent}[SerializationConstructor]", }); return constructors; } diff --git a/src/ApiGenerator/Domain/Code/HighLevel/Requests/DescriptorPartialImplementation.cs b/src/ApiGenerator/Domain/Code/HighLevel/Requests/DescriptorPartialImplementation.cs index 3039482559..3f5a39882d 100644 --- a/src/ApiGenerator/Domain/Code/HighLevel/Requests/DescriptorPartialImplementation.cs +++ b/src/ApiGenerator/Domain/Code/HighLevel/Requests/DescriptorPartialImplementation.cs @@ -30,7 +30,7 @@ using System.Linq; using ApiGenerator.Domain.Specification; -namespace ApiGenerator.Domain.Code.HighLevel.Requests +namespace ApiGenerator.Domain.Code.HighLevel.Requests { public class DescriptorPartialImplementation { @@ -41,7 +41,7 @@ public class DescriptorPartialImplementation public IReadOnlyCollection Paths { get; set; } public IReadOnlyCollection Params { get; set; } public bool HasBody { get; set; } - + public IEnumerable GetFluentRouteSetters() { var setters = new List(); @@ -67,26 +67,26 @@ public IEnumerable GetFluentRouteSetters() var code = $"public {returnType} {p.InterfaceName}({p.HighLevelTypeName} {paramName}) => Assign({paramName}, (a,v)=>a.RouteValues.{routeSetter}(\"{p.Name}\", {routeValue}));"; - var xmlDoc = $"///{p.Description}"; + var xmlDoc = $"/// {p.Description}"; setters.Add(new FluentRouteSetter { Code = code, XmlDoc = xmlDoc }); if (paramName == "index") { code = $"public {returnType} {p.InterfaceName}() where TOther : class "; code += $"=> Assign(typeof(TOther), (a,v)=>a.RouteValues.{routeSetter}(\"{p.Name}\", ({p.HighLevelTypeName})v));"; - xmlDoc = $"///a shortcut into calling {p.InterfaceName}(typeof(TOther))"; + xmlDoc = $"/// a shortcut into calling {p.InterfaceName}(typeof(TOther))"; setters.Add(new FluentRouteSetter { Code = code, XmlDoc = xmlDoc }); } if (paramName == "index" && p.Type == "list") { code = $"public {returnType} AllIndices() => Index(Indices.All);"; - xmlDoc = $"///A shortcut into calling Index(Indices.All)"; + xmlDoc = $"/// A shortcut into calling Index(Indices.All)"; setters.Add(new FluentRouteSetter { Code = code, XmlDoc = xmlDoc }); } if (paramName == "fields" && p.Type == "list") { code = $"public {returnType} Fields(params Expression>[] fields) "; code += $"=> Assign(fields, (a,v)=>a.RouteValues.{routeSetter}(\"fields\", (Fields)v));"; - xmlDoc = $"///{p.Description}"; + xmlDoc = $"/// {p.Description}"; setters.Add(new FluentRouteSetter { Code = code, XmlDoc = xmlDoc }); } } diff --git a/src/ApiGenerator/Domain/RestApiSpec.cs b/src/ApiGenerator/Domain/RestApiSpec.cs index c474fa71d6..042910cefb 100644 --- a/src/ApiGenerator/Domain/RestApiSpec.cs +++ b/src/ApiGenerator/Domain/RestApiSpec.cs @@ -66,7 +66,7 @@ public IEnumerable EnumsInTheSpec var urlParameterEnums = Endpoints .Values .SelectMany(e => e.Url.Params.Values) - .Where(p => p.Options != null && p.Options.Any()) + .Where(p => !p.Skip && p.Options != null && p.Options.Any()) .Select(p => new EnumDescription { Name = p.ClsName, diff --git a/src/ApiGenerator/Domain/Specification/Deprecation.cs b/src/ApiGenerator/Domain/Specification/Deprecation.cs index 367a9741aa..c325e1e8ae 100644 --- a/src/ApiGenerator/Domain/Specification/Deprecation.cs +++ b/src/ApiGenerator/Domain/Specification/Deprecation.cs @@ -1,29 +1,30 @@ -// /* 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. -// */ +/* 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. + */ namespace ApiGenerator.Domain.Specification; diff --git a/src/ApiGenerator/Domain/Specification/UrlPath.cs b/src/ApiGenerator/Domain/Specification/UrlPath.cs index b1546f4f6e..37261eed00 100644 --- a/src/ApiGenerator/Domain/Specification/UrlPath.cs +++ b/src/ApiGenerator/Domain/Specification/UrlPath.cs @@ -95,7 +95,7 @@ public string DocumentPathConstructorArgument(string generic) => string.Join(", public string GetXmlDocs(string indent, bool skipResolvable = false, bool documentConstructor = false) { - var doc = $@"///{Path}"; + var doc = $@"/// {Path}"; var parts = Parts.Where(p => !skipResolvable || !ResolvabeFromT.Contains(p.Name)).ToList(); if (!parts.Any()) return doc; @@ -112,7 +112,7 @@ string GetDescription(UrlPart p) } } - private string P(string name, string description) => $"///{description}"; + private string P(string name, string description) => $"/// {description}"; private string LeadingBackslash(string p) => p.StartsWith("/") ? p : $"/{p}"; } diff --git a/src/ApiGenerator/Generator/CodeGenerator.cs b/src/ApiGenerator/Generator/CodeGenerator.cs index 0f9b35e627..b8165cc48c 100644 --- a/src/ApiGenerator/Generator/CodeGenerator.cs +++ b/src/ApiGenerator/Generator/CodeGenerator.cs @@ -89,15 +89,15 @@ private static IEnumerable RenderDocumentation(params string[] doc) { case 0: yield break; case 1: - yield return $"///{doc[0]}"; + yield return $"/// {doc[0]}"; yield break; default: - yield return "///"; + yield return "/// "; foreach (var d in doc) yield return $"/// {d}"; - yield return "///"; + yield return "/// "; yield break; } diff --git a/src/ApiGenerator/Views/HighLevel/Client/FluentSyntax/FluentMethod.cshtml b/src/ApiGenerator/Views/HighLevel/Client/FluentSyntax/FluentMethod.cshtml index 10b88e61eb..e748bf9fff 100644 --- a/src/ApiGenerator/Views/HighLevel/Client/FluentSyntax/FluentMethod.cshtml +++ b/src/ApiGenerator/Views/HighLevel/Client/FluentSyntax/FluentMethod.cshtml @@ -3,10 +3,10 @@ @inherits ApiGenerator.CodeTemplatePage @{ var method = !Model.Async ? Model.Syntax.MethodName : string.Format("{0}Async", Model.Syntax.MethodName); - var asyncKeyword = Model.Syntax.InterfaceResponse && Model.Async ? "async " : String.Empty; + var asyncKeyword = Model.Syntax.InterfaceResponse && Model.Async ? "async " : string.Empty; var awaitKeyWord = Model.Syntax.InterfaceResponse && Model.Async ? "await ": string.Empty; - var configureAwait = Model.Syntax.InterfaceResponse && Model.Async ? ".ConfigureAwait(false)" : String.Empty; - + var configureAwait = Model.Syntax.InterfaceResponse && Model.Async ? ".ConfigureAwait(false)" : string.Empty; + var requestMethodGenerics = Model.Syntax.RequestMethodGenerics; var descriptor = Model.Syntax.DescriptorName; var selectorArgs = Model.Syntax.SelectorArguments(); diff --git a/src/ApiGenerator/Views/HighLevel/Client/Implementation/OpenSearchClient.Namespace.cshtml b/src/ApiGenerator/Views/HighLevel/Client/Implementation/OpenSearchClient.Namespace.cshtml index 331099fb9b..c3c8e5d31b 100644 --- a/src/ApiGenerator/Views/HighLevel/Client/Implementation/OpenSearchClient.Namespace.cshtml +++ b/src/ApiGenerator/Views/HighLevel/Client/Implementation/OpenSearchClient.Namespace.cshtml @@ -18,12 +18,12 @@ using OpenSearch.Net.@(CsharpNames.ApiNamespace).@ns@(CsharpNames.ApiNamespaceSu // ReSharper disable RedundantTypeArgumentsOfMethod namespace OpenSearch.Client.@(CsharpNames.ApiNamespace).@ns@(CsharpNames.ApiNamespaceSuffix) { - /// + /// /// @ns.SplitPascalCase() APIs. /// Not intended to be instantiated directly. Use the property /// on . - /// - /// + /// + /// public partial class @(CsharpNames.HighLevelClientNamespacePrefix)@ns@(CsharpNames.ClientNamespaceSuffix) : NamespacedClientProxy { internal @(CsharpNames.HighLevelClientNamespacePrefix)@ns@(CsharpNames.ClientNamespaceSuffix)(OpenSearchClient client) : base(client) {} diff --git a/src/ApiGenerator/Views/HighLevel/Client/Implementation/OpenSearchClient.cshtml b/src/ApiGenerator/Views/HighLevel/Client/Implementation/OpenSearchClient.cshtml index 9ee1e2cd75..c57e3e1dfe 100644 --- a/src/ApiGenerator/Views/HighLevel/Client/Implementation/OpenSearchClient.cshtml +++ b/src/ApiGenerator/Views/HighLevel/Client/Implementation/OpenSearchClient.cshtml @@ -1,6 +1,6 @@ @using System.Linq @using ApiGenerator.Domain -@using ApiGenerator +@using ApiGenerator @using ApiGenerator.Domain.Code @inherits CodeTemplatePage @{ await IncludeGeneratorNotice(); } @@ -17,15 +17,15 @@ using OpenSearch.Client; // ReSharper disable RedundantTypeArgumentsOfMethod namespace OpenSearch.Client { - /// - ///OpenSearch high level client - /// + /// + /// OpenSearch high level client + /// public partial class OpenSearchClient : IOpenSearchClient { foreach (var ns in namespaces) { - ///@(ns.SplitPascalCase()) APIs + /// @(ns.SplitPascalCase()) APIs public @CsharpNames.HighLevelClientNamespacePrefix@(ns)@CsharpNames.ClientNamespaceSuffix @ns { get; private set; } } @@ -41,7 +41,7 @@ namespace OpenSearch.Client } - + foreach (var kv in Model.EndpointsPerNamespaceHighLevel) { diff --git a/src/ApiGenerator/Views/HighLevel/Client/Interface/IOpenSearchClient.cshtml b/src/ApiGenerator/Views/HighLevel/Client/Interface/IOpenSearchClient.cshtml index 2cef1f859e..3dd2c0ba9d 100644 --- a/src/ApiGenerator/Views/HighLevel/Client/Interface/IOpenSearchClient.cshtml +++ b/src/ApiGenerator/Views/HighLevel/Client/Interface/IOpenSearchClient.cshtml @@ -15,16 +15,16 @@ using OpenSearch.Client; namespace OpenSearch.Client { - /// - ///OpenSearch high level client - /// - public partial interface IOpenSearchClient + /// + /// OpenSearch high level client + /// + public partial interface IOpenSearchClient { @foreach(var (ns, endpoints) in Model.EndpointsPerNamespaceHighLevel) { if (ns != CsharpNames.RootNamespace) { - ///@ns.SplitPascalCase() APIs + /// @ns.SplitPascalCase() APIs @CsharpNames.HighLevelClientNamespacePrefix@(ns)@CsharpNames.ClientNamespaceSuffix @ns { get; } continue; diff --git a/src/ApiGenerator/Views/HighLevel/Descriptors/XmlDocs.cshtml b/src/ApiGenerator/Views/HighLevel/Descriptors/XmlDocs.cshtml index 5015387ffa..ebbe54683e 100644 --- a/src/ApiGenerator/Views/HighLevel/Descriptors/XmlDocs.cshtml +++ b/src/ApiGenerator/Views/HighLevel/Descriptors/XmlDocs.cshtml @@ -4,13 +4,14 @@ var description = Model.Count == 1 ? Model.First() : string.Join($"{Environment.NewLine}\t\t", Model.Select(d => "/// " + d)); if (Model.Count == 1) { - ///@Raw(description) + /// @Raw(description) + } else { - /// + /// @Raw(description) - /// + /// } } diff --git a/src/ApiGenerator/Views/HighLevel/Requests/RequestImplementations.cshtml b/src/ApiGenerator/Views/HighLevel/Requests/RequestImplementations.cshtml index b438e2feff..0be9404b61 100644 --- a/src/ApiGenerator/Views/HighLevel/Requests/RequestImplementations.cshtml +++ b/src/ApiGenerator/Views/HighLevel/Requests/RequestImplementations.cshtml @@ -7,7 +7,7 @@ @{ var apiLookup = $"ApiUrlsLookups.{Model.CsharpNames.Namespace}{Model.CsharpNames.MethodName}"; } -///Request for @Model.CsharpNames.MethodName@(Raw(Model.OfficialDocumentationLink.IsNullOrEmpty() ? "" : " " + Model.OfficialDocumentationLink + "")) +/// Request for @Model.CsharpNames.MethodName@(Raw(Model.OfficialDocumentationLink.IsNullOrEmpty() ? "" : " " + Model.OfficialDocumentationLink + "")) @if (Model.Stability != Stability.Stable) { string warningMessage = ""; @@ -20,8 +20,8 @@ warningMessage = "this functionality is in beta and is subject to change. The design and code is less mature than official GA features and is being provided as-is with no warranties. Beta features are not subject to the support SLA of official GA features."; break; } - -///@Raw("Note: " + Model.Stability + " within the OpenSearch server, " + warningMessage + "") + +/// @Raw("Note: " + Model.Stability + " within the OpenSearch server, " + warningMessage + "") } public partial class @Raw(Model.Name) @Raw(string.Format(": PlainRequestBase<{0}>, {1}", Model.CsharpNames.ParametersName, Model.InterfaceName)) diff --git a/src/ApiGenerator/Views/LowLevel/Client/Implementation/OpenSearchLowLevelClient.Namespace.cshtml b/src/ApiGenerator/Views/LowLevel/Client/Implementation/OpenSearchLowLevelClient.Namespace.cshtml index 87a06d99a4..7711359b87 100644 --- a/src/ApiGenerator/Views/LowLevel/Client/Implementation/OpenSearchLowLevelClient.Namespace.cshtml +++ b/src/ApiGenerator/Views/LowLevel/Client/Implementation/OpenSearchLowLevelClient.Namespace.cshtml @@ -1,6 +1,6 @@ @using System.Collections.ObjectModel @using System.Linq -@using ApiGenerator +@using ApiGenerator @using ApiGenerator.Domain.Code @using ApiGenerator.Domain.Specification @inherits CodeTemplatePage>> @@ -25,20 +25,20 @@ using static OpenSearch.Net.HttpMethod; // ReSharper disable RedundantExtendsListEntry namespace OpenSearch.Net.@(CsharpNames.ApiNamespace).@ns@(CsharpNames.ApiNamespaceSuffix) { - /// + /// /// @ns.SplitPascalCase() APIs. /// Not intended to be instantiated directly. Use the property /// on . - /// - /// + /// + /// public partial class @(CsharpNames.LowLevelClientNamespacePrefix)@ns@(CsharpNames.ClientNamespaceSuffix) : NamespacedClientProxy { internal @(CsharpNames.LowLevelClientNamespacePrefix)@ns@(CsharpNames.ClientNamespaceSuffix)(OpenSearchLowLevelClient client) : base(client) {} @if (ns == "Cat") { - protected override string ContentType { get; } = "text/plain"; + protected override string ContentType => "text/plain"; } - @{ + @{ var methods = endpoints.SelectMany(e=>e.LowLevelClientMethods).ToList(); foreach (var method in methods) { diff --git a/src/ApiGenerator/Views/LowLevel/Client/Implementation/OpenSearchLowLevelClient.cshtml b/src/ApiGenerator/Views/LowLevel/Client/Implementation/OpenSearchLowLevelClient.cshtml index 231413f7a1..2795157ec4 100644 --- a/src/ApiGenerator/Views/LowLevel/Client/Implementation/OpenSearchLowLevelClient.cshtml +++ b/src/ApiGenerator/Views/LowLevel/Client/Implementation/OpenSearchLowLevelClient.cshtml @@ -1,6 +1,6 @@ @using System.Linq @using ApiGenerator.Domain -@using ApiGenerator +@using ApiGenerator @using ApiGenerator.Domain.Code @inherits CodeTemplatePage @{ await IncludeGeneratorNotice(); } @@ -23,15 +23,15 @@ using static OpenSearch.Net.HttpMethod; // ReSharper disable RedundantExtendsListEntry namespace OpenSearch.Net { - /// - ///OpenSearch low level client - /// + /// + /// OpenSearch low level client + /// public partial class OpenSearchLowLevelClient : IOpenSearchLowLevelClient { foreach (var ns in namespaces) { - public @(CsharpNames.LowLevelClientNamespacePrefix)@(ns)@(CsharpNames.ClientNamespaceSuffix) @ns { get; private set; } + public @(CsharpNames.LowLevelClientNamespacePrefix)@(ns)@(CsharpNames.ClientNamespaceSuffix) @ns { get; private set; } } @@ -46,7 +46,7 @@ namespace OpenSearch.Net } - + foreach (var (ns, endpoints) in Model.EndpointsPerNamespaceLowLevel) { diff --git a/src/ApiGenerator/Views/LowLevel/Client/Interface/IOpenSearchLowLevelClient.cshtml b/src/ApiGenerator/Views/LowLevel/Client/Interface/IOpenSearchLowLevelClient.cshtml index c18cf883b8..4a90af2fb8 100644 --- a/src/ApiGenerator/Views/LowLevel/Client/Interface/IOpenSearchLowLevelClient.cshtml +++ b/src/ApiGenerator/Views/LowLevel/Client/Interface/IOpenSearchLowLevelClient.cshtml @@ -17,17 +17,17 @@ using OpenSearch.Net; namespace OpenSearch.Net { - /// - ///OpenSearch low level client - /// - public partial interface IOpenSearchLowLevelClient + /// + /// OpenSearch low level client + /// + public partial interface IOpenSearchLowLevelClient { @foreach(var (ns, endpoints) in Model.EndpointsPerNamespaceLowLevel) { if (ns != CsharpNames.RootNamespace) { - ///@ns.SplitPascalCase() APIs + /// @ns.SplitPascalCase() APIs @CsharpNames.LowLevelClientNamespacePrefix@(ns)@CsharpNames.ClientNamespaceSuffix @ns { get; } continue; diff --git a/src/ApiGenerator/Views/LowLevel/Client/Methods/MethodDocs.cshtml b/src/ApiGenerator/Views/LowLevel/Client/Methods/MethodDocs.cshtml index 46423d412d..e2b355e8b2 100644 --- a/src/ApiGenerator/Views/LowLevel/Client/Methods/MethodDocs.cshtml +++ b/src/ApiGenerator/Views/LowLevel/Client/Methods/MethodDocs.cshtml @@ -2,13 +2,13 @@ @using ApiGenerator.Domain.Code.LowLevel @using ApiGenerator.Domain.Specification @inherits ApiGenerator.CodeTemplatePage -///@Model.HttpMethod on @Model.Path@(Raw(Model.OfficialDocumentationLink.IsNullOrEmpty() ? "" : " " + Model.OfficialDocumentationLink + "")) +/// @Model.HttpMethod on @Model.Path@(Raw(Model.OfficialDocumentationLink.IsNullOrEmpty() ? "" : " " + Model.OfficialDocumentationLink + "")) @foreach (var part in Model.Parts) { - ///@Raw("")@part.Description@Raw("") + /// @Raw("")@part.Description@Raw("") } - ///@Raw(@"Request specific configuration such as querystring parameters & request specific connection settings.") + /// @Raw(@"Request specific configuration such as querystring parameters & request specific connection settings.") @if (Model.Stability != Stability.Stable) { string warningMessage = ""; @@ -23,9 +23,10 @@ } warningMessage += " This functionality is subject to potential breaking changes within a minor version, meaning that your referencing code may break when this library is upgraded."; - - ///@Raw("Note: " + Model.Stability + " within the OpenSearch server, " + warningMessage + "") + /// @Raw("Note: " + Model.Stability + " within the OpenSearch server, " + warningMessage + "") + +} } @if (Model.DeprecatedPath != null) { diff --git a/src/ApiGenerator/Views/LowLevel/RequestParameters/RequestParameters.cshtml b/src/ApiGenerator/Views/LowLevel/RequestParameters/RequestParameters.cshtml index 0295c09fd4..fd477d54ef 100644 --- a/src/ApiGenerator/Views/LowLevel/RequestParameters/RequestParameters.cshtml +++ b/src/ApiGenerator/Views/LowLevel/RequestParameters/RequestParameters.cshtml @@ -25,8 +25,8 @@ namespace OpenSearch.Net@(ns) var supportsBody = endpoint.Body != null; var names = r.CsharpNames; - ///Request options for @names.MethodName@Raw(r.OfficialDocumentationLink.IsNullOrEmpty() ? "" : " " + r.OfficialDocumentationLink + "") - public partial class @names.ParametersName : RequestParameters<@names.ParametersName> + /// Request options for @names.MethodName@Raw(r.OfficialDocumentationLink.IsNullOrEmpty() ? "" : " " + r.OfficialDocumentationLink + "") + public partial class @names.ParametersName : RequestParameters<@names.ParametersName> { public override HttpMethod DefaultHttpMethod => HttpMethod.@r.HttpMethod; public override bool SupportsBody => @(supportsBody ? "true" : "false"); From b0eac40601281a6dc193ab13be406e7ac6b0b891 Mon Sep 17 00:00:00 2001 From: Thomas Farr Date: Mon, 16 Oct 2023 17:21:08 +1300 Subject: [PATCH 3/4] Better URL path handling and support x-version-added on APIs Signed-off-by: Thomas Farr --- src/ApiGenerator/ApiGenerator.csproj | 1 + .../HighLevel/Methods/BoundFluentMethod.cs | 5 +- .../Code/HighLevel/Methods/FluentMethod.cs | 5 +- .../HighLevel/Methods/FluentSyntaxBase.cs | 5 +- .../HighLevel/Methods/InitializerMethod.cs | 3 +- .../HighLevel/Methods/MethodSyntaxBase.cs | 7 +- .../Code/LowLevel/LowLevelClientMethod.cs | 29 ++-- .../Domain/Specification/ApiEndpoint.cs | 33 ++-- .../Domain/Specification/Deprecation.cs | 50 +++--- .../Domain/Specification/QueryParameters.cs | 5 +- .../Domain/Specification/UrlInformation.cs | 84 +-------- .../Domain/Specification/UrlPart.cs | 41 ++--- .../Domain/Specification/UrlPath.cs | 44 ++--- src/ApiGenerator/Extensions.cs | 3 + .../Generator/ApiEndpointFactory.cs | 161 ++++++++++++------ src/ApiGenerator/Generator/CodeGenerator.cs | 5 +- .../HighLevel/Client/MethodXmlDocs.cshtml | 6 + .../HighLevel/Descriptors/Descriptor.cshtml | 27 +-- .../HighLevel/Descriptors/XmlDocs.cshtml | 13 +- .../HighLevel/Requests/ApiUrlsLookup.cshtml | 2 +- .../LowLevel/Client/Methods/MethodDocs.cshtml | 9 +- 21 files changed, 258 insertions(+), 280 deletions(-) diff --git a/src/ApiGenerator/ApiGenerator.csproj b/src/ApiGenerator/ApiGenerator.csproj index 5204b3a3d0..ea6d9cc7eb 100644 --- a/src/ApiGenerator/ApiGenerator.csproj +++ b/src/ApiGenerator/ApiGenerator.csproj @@ -13,6 +13,7 @@ + diff --git a/src/ApiGenerator/Domain/Code/HighLevel/Methods/BoundFluentMethod.cs b/src/ApiGenerator/Domain/Code/HighLevel/Methods/BoundFluentMethod.cs index e7231c5523..54e96d8645 100644 --- a/src/ApiGenerator/Domain/Code/HighLevel/Methods/BoundFluentMethod.cs +++ b/src/ApiGenerator/Domain/Code/HighLevel/Methods/BoundFluentMethod.cs @@ -30,13 +30,14 @@ using System.Linq; using ApiGenerator.Configuration; using ApiGenerator.Domain.Specification; +using SemanticVersioning; namespace ApiGenerator.Domain.Code.HighLevel.Methods { public class BoundFluentMethod : FluentSyntaxBase { - public BoundFluentMethod(CsharpNames names, IReadOnlyCollection parts, bool selectorIsOptional, string link, string summary, Deprecation deprecated) - : base(names, parts, selectorIsOptional, link, summary, deprecated) { } + public BoundFluentMethod(CsharpNames names, IReadOnlyCollection parts, bool selectorIsOptional, string link, string summary, Deprecation deprecated, Version versionAdded) + : base(names, parts, selectorIsOptional, link, summary, deprecated, versionAdded) { } private string DescriptorTypeParams => string.Join(", ", CsharpNames.DescriptorGenerics .Select(e => CsharpNames.DescriptorBoundDocumentGeneric)); diff --git a/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentMethod.cs b/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentMethod.cs index 62f138abda..fe7f3a3690 100644 --- a/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentMethod.cs +++ b/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentMethod.cs @@ -29,13 +29,14 @@ using System.Collections.Generic; using System.Linq; using ApiGenerator.Domain.Specification; +using SemanticVersioning; namespace ApiGenerator.Domain.Code.HighLevel.Methods { public class FluentMethod : FluentSyntaxBase { - public FluentMethod(CsharpNames names, IReadOnlyCollection parts, bool selectorIsOptional, string link, string summary, Deprecation deprecated) - : base(names, parts, selectorIsOptional, link, summary, deprecated) { } + public FluentMethod(CsharpNames names, IReadOnlyCollection parts, bool selectorIsOptional, string link, string summary, Deprecation deprecated, Version versionAdded) + : base(names, parts, selectorIsOptional, link, summary, deprecated, versionAdded) { } public override string GenericWhereClause => string.Join(" ", CsharpNames.HighLevelDescriptorMethodGenerics diff --git a/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentSyntaxBase.cs b/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentSyntaxBase.cs index 560fee547b..e3f9d02765 100644 --- a/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentSyntaxBase.cs +++ b/src/ApiGenerator/Domain/Code/HighLevel/Methods/FluentSyntaxBase.cs @@ -30,6 +30,7 @@ using System.Linq; using ApiGenerator.Configuration; using ApiGenerator.Domain.Specification; +using SemanticVersioning; namespace ApiGenerator.Domain.Code.HighLevel.Methods { @@ -37,8 +38,8 @@ public abstract class FluentSyntaxBase : MethodSyntaxBase { private readonly bool _selectorIsOptional; - protected FluentSyntaxBase(CsharpNames names, IReadOnlyCollection parts, bool selectorIsOptional, string link, string summary, Deprecation deprecated) - : base(names, link, summary, deprecated) => + protected FluentSyntaxBase(CsharpNames names, IReadOnlyCollection parts, bool selectorIsOptional, string link, string summary, Deprecation deprecated, Version versionAdded) + : base(names, link, summary, deprecated, versionAdded) => (UrlParts, _selectorIsOptional) = (CreateDescriptorArgs(parts), selectorIsOptional); private IReadOnlyCollection UrlParts { get; } diff --git a/src/ApiGenerator/Domain/Code/HighLevel/Methods/InitializerMethod.cs b/src/ApiGenerator/Domain/Code/HighLevel/Methods/InitializerMethod.cs index 1520250e40..f0f048e494 100644 --- a/src/ApiGenerator/Domain/Code/HighLevel/Methods/InitializerMethod.cs +++ b/src/ApiGenerator/Domain/Code/HighLevel/Methods/InitializerMethod.cs @@ -29,12 +29,13 @@ using System.Linq; using ApiGenerator.Configuration; using ApiGenerator.Domain.Specification; +using SemanticVersioning; namespace ApiGenerator.Domain.Code.HighLevel.Methods { public class InitializerMethod : MethodSyntaxBase { - public InitializerMethod(CsharpNames names, string link, string summary, Deprecation deprecated) : base(names, link, summary, deprecated) { } + public InitializerMethod(CsharpNames names, string link, string summary, Deprecation deprecated, Version versionAdded) : base(names, link, summary, deprecated, versionAdded) { } public string MethodName => CsharpNames.MethodName; diff --git a/src/ApiGenerator/Domain/Code/HighLevel/Methods/MethodSyntaxBase.cs b/src/ApiGenerator/Domain/Code/HighLevel/Methods/MethodSyntaxBase.cs index 349c05e75d..a0b1f329df 100644 --- a/src/ApiGenerator/Domain/Code/HighLevel/Methods/MethodSyntaxBase.cs +++ b/src/ApiGenerator/Domain/Code/HighLevel/Methods/MethodSyntaxBase.cs @@ -27,13 +27,14 @@ */ using ApiGenerator.Domain.Specification; +using SemanticVersioning; namespace ApiGenerator.Domain.Code.HighLevel.Methods { public abstract class MethodSyntaxBase { - protected MethodSyntaxBase(CsharpNames names, string link, string summary, Deprecation deprecated) => - (CsharpNames, DocumentationLink, XmlDocSummary, Deprecated) = (names, link, summary, deprecated); + protected MethodSyntaxBase(CsharpNames names, string link, string summary, Deprecation deprecated, Version versionAdded) => + (CsharpNames, DocumentationLink, XmlDocSummary, Deprecated, VersionAdded) = (names, link, summary, deprecated, versionAdded); public string DocumentationLink { get; } @@ -41,6 +42,8 @@ protected MethodSyntaxBase(CsharpNames names, string link, string summary, Depre public Deprecation Deprecated { get; } + public Version VersionAdded { get; set; } + protected CsharpNames CsharpNames { get; } public bool InterfaceResponse => ResponseName.StartsWith("ISearchResponse<"); diff --git a/src/ApiGenerator/Domain/Code/LowLevel/LowLevelClientMethod.cs b/src/ApiGenerator/Domain/Code/LowLevel/LowLevelClientMethod.cs index f00f74f9e5..a81e269163 100644 --- a/src/ApiGenerator/Domain/Code/LowLevel/LowLevelClientMethod.cs +++ b/src/ApiGenerator/Domain/Code/LowLevel/LowLevelClientMethod.cs @@ -30,6 +30,7 @@ using System.Linq; using System.Text.RegularExpressions; using ApiGenerator.Domain.Specification; +using SemanticVersioning; namespace ApiGenerator.Domain.Code.LowLevel { @@ -44,35 +45,31 @@ public class LowLevelClientMethod public string PerPathMethodName { get; set; } public string HttpMethod { get; set; } - public DeprecatedPath DeprecatedPath { get; set; } + public Deprecation Deprecation { get; set; } public UrlInformation Url { get; set; } public bool HasBody { get; set; } public IEnumerable Parts { get; set; } public string Path { get; set; } + public Version VersionAdded { get; set; } public string UrlInCode { get { - string Evaluator(Match m) - { - - var arg = m.Groups[^1].Value.ToCamelCase(); - return $"{{{arg}:{arg}}}"; - } - - var url = Path.TrimStart('/'); - var options = Url.OriginalParts?.Select(p => p.Key) ?? Enumerable.Empty(); + var url = Path.TrimStart('/'); + var options = Url.AllPaths.SelectMany(p => p.Parts).Select(p => p.Name).Distinct(); var pattern = string.Join("|", options); var urlCode = $"\"{url}\""; - if (Path.Contains("{")) - { - var patchedUrl = Regex.Replace(url, "{(" + pattern + ")}", Evaluator); - urlCode = $"Url($\"{patchedUrl}\")"; - } - return urlCode; + if (!Path.Contains('{')) return urlCode; + + var patchedUrl = Regex.Replace(url, "{(" + pattern + ")}", m => + { + var arg = m.Groups[^1].Value.ToCamelCase(); + return $"{{{arg}:{arg}}}"; + }); + return $"Url($\"{patchedUrl}\")"; } } diff --git a/src/ApiGenerator/Domain/Specification/ApiEndpoint.cs b/src/ApiGenerator/Domain/Specification/ApiEndpoint.cs index b07c2bca8f..f22c15731f 100644 --- a/src/ApiGenerator/Domain/Specification/ApiEndpoint.cs +++ b/src/ApiGenerator/Domain/Specification/ApiEndpoint.cs @@ -33,6 +33,7 @@ using ApiGenerator.Domain.Code.HighLevel.Methods; using ApiGenerator.Domain.Code.HighLevel.Requests; using ApiGenerator.Domain.Code.LowLevel; +using SemanticVersioning; namespace ApiGenerator.Domain.Specification { @@ -78,7 +79,7 @@ public class ApiEndpoint CsharpNames = CsharpNames, OfficialDocumentationLink = OfficialDocumentationLink?.Url, Stability = Stability, - Paths = Url.Paths, + Paths = Url.Paths.ToList(), Parts = Url.Parts, Params = ParamsToGenerate.ToList(), Constructors = Constructor.RequestConstructors(CsharpNames, Url, inheritsFromPlainRequestBase: true).ToList(), @@ -91,7 +92,7 @@ public class ApiEndpoint CsharpNames = CsharpNames, OfficialDocumentationLink = OfficialDocumentationLink?.Url, Constructors = Constructor.DescriptorConstructors(CsharpNames, Url).ToList(), - Paths = Url.Paths, + Paths = Url.Paths.ToList(), Parts = Url.Parts, Params = ParamsToGenerate.ToList(), HasBody = Body != null, @@ -120,10 +121,18 @@ public class ApiEndpoint private bool BodyIsOptional => Body is not { Required: true } || HttpMethods.Contains("GET"); private Deprecation Deprecated => - Url.OriginalPaths.Count == 0 && Url.DeprecatedPaths.Count > 0 - ? Url.DeprecatedPaths.Select(p => new Deprecation { Description = p.Description, Version = p.Version }).FirstOrDefault() + !Url.Paths.Any() && Url.AllPaths.Count > 0 + ? Url.DeprecatedPaths + .Select(p => p.Deprecation) + .MaxBy(d => d.Version) : null; + private Version VersionAdded => + Url.AllPaths + .Select(p => p.VersionAdded) + .Where(v => v != null) + .Min(); + public HighLevelModel HighLevelModel => new() { CsharpNames = CsharpNames, @@ -131,7 +140,8 @@ public class ApiEndpoint selectorIsOptional: BodyIsOptional, link: OfficialDocumentationLink?.Url, summary: HighLevelMethodXmlDocDescription, - deprecated: Deprecated + deprecated: Deprecated, + versionAdded: VersionAdded ), FluentBound = !CsharpNames.DescriptorBindsOverMultipleDocuments ? null @@ -139,12 +149,14 @@ public class ApiEndpoint selectorIsOptional: BodyIsOptional, link: OfficialDocumentationLink?.Url, summary: HighLevelMethodXmlDocDescription, - deprecated: Deprecated + deprecated: Deprecated, + versionAdded: VersionAdded ), Initializer = new InitializerMethod(CsharpNames, link: OfficialDocumentationLink?.Url, summary: HighLevelMethodXmlDocDescription, - deprecated: Deprecated + deprecated: Deprecated, + versionAdded: VersionAdded ) }; @@ -163,7 +175,7 @@ public IReadOnlyCollection LowLevelClientMethods Generator.ApiGenerator.Warnings.Add($"API '{Name}' has no documentation"); var httpMethod = PreferredHttpMethod; - foreach (var path in Url.PathsWithDeprecations) + foreach (var path in Url.AllPaths) { var methodName = CsharpNames.PerPathMethodName(path.Path); var parts = new List(path.Parts); @@ -193,11 +205,12 @@ public IReadOnlyCollection LowLevelClientMethods HttpMethod = httpMethod, OfficialDocumentationLink = OfficialDocumentationLink?.Url, Stability = Stability, - DeprecatedPath = path.Deprecation, + Deprecation = path.Deprecation, Path = path.Path, Parts = parts, Url = Url, - HasBody = Body != null + HasBody = Body != null, + VersionAdded = path.VersionAdded, }; _lowLevelClientMethods.Add(apiMethod); } diff --git a/src/ApiGenerator/Domain/Specification/Deprecation.cs b/src/ApiGenerator/Domain/Specification/Deprecation.cs index c325e1e8ae..96ac03c7d7 100644 --- a/src/ApiGenerator/Domain/Specification/Deprecation.cs +++ b/src/ApiGenerator/Domain/Specification/Deprecation.cs @@ -1,30 +1,30 @@ /* 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. - */ +* +* 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. - */ +* 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. +*/ namespace ApiGenerator.Domain.Specification; diff --git a/src/ApiGenerator/Domain/Specification/QueryParameters.cs b/src/ApiGenerator/Domain/Specification/QueryParameters.cs index da763df9a3..71fae53ebd 100644 --- a/src/ApiGenerator/Domain/Specification/QueryParameters.cs +++ b/src/ApiGenerator/Domain/Specification/QueryParameters.cs @@ -30,6 +30,7 @@ using System.Collections.Generic; using System.Linq; using ApiGenerator.Generator; +using Version = SemanticVersioning.Version; namespace ApiGenerator.Domain.Specification { @@ -45,7 +46,7 @@ public class QueryParameters public string Description { get; set; } - public string VersionAdded { get; set; } + public Version VersionAdded { get; set; } public IEnumerable DescriptionHighLevel { @@ -179,7 +180,7 @@ public string TypeLowLevel } - public string InitializerGenerator(string @namespace, string type, string name, string key, string setter, string versionAdded, params string[] doc) => + public string InitializerGenerator(string @namespace, string type, string name, string key, string setter, Version versionAdded, params string[] doc) => CodeGenerator.Property(@namespace, type, name, key, setter, Obsolete, versionAdded, doc); } } diff --git a/src/ApiGenerator/Domain/Specification/UrlInformation.cs b/src/ApiGenerator/Domain/Specification/UrlInformation.cs index e64e36d2ff..34f7c55591 100644 --- a/src/ApiGenerator/Domain/Specification/UrlInformation.cs +++ b/src/ApiGenerator/Domain/Specification/UrlInformation.cs @@ -26,9 +26,7 @@ * under the License. */ -using System; using System.Collections.Generic; -using System.Collections.Immutable; using System.Linq; namespace ApiGenerator.Domain.Specification @@ -39,80 +37,10 @@ public class UrlInformation { public IDictionary Params { get; set; } = new SortedDictionary(); - public IList OriginalPaths { get; set; } = new List(); - - public IDictionary OriginalParts { get; set; } - - public IList DeprecatedPaths { get; set; } = new List(); - - private List _paths; - public IReadOnlyCollection Paths - { - get - { - if (_paths != null && _paths.Count > 0) return _paths; - - _paths = OriginalPaths.Select(p => new UrlPath(p, OriginalParts)).ToList(); - return _paths; - } - } - - private List _pathsWithDeprecation; - public IReadOnlyCollection PathsWithDeprecations - { - get - { - if (_pathsWithDeprecation != null && _pathsWithDeprecation.Count > 0) return _pathsWithDeprecation; - - var paths = Paths ?? new UrlPath[] {}; - if (DeprecatedPaths == null || DeprecatedPaths.Count == 0) return Paths; - if (OriginalParts == null) return Paths; - - //some deprecated paths describe aliases to the canonical using the same path e.g - // PUT /{index}/_mapping/{type} - // PUT /{index}/{type}/_mappings - // - //The following routine dedups these occasions and prefers either the canonical path - //or the first duplicate deprecated path - - var canonicalPartNameLookup = paths.Select(path => new HashSet(path.Parts.Select(p => p.Name))).ToList(); - var withoutDeprecatedAliases = DeprecatedPaths - .Select(deprecatedPath => new - { - deprecatedPath, - parts = new HashSet(OriginalParts.Keys.Where(k => deprecatedPath.Path.Contains($"{{{k}}}"))) - }) - .GroupBy(t => t.parts, HashSet.CreateSetComparer()) - .Where(grouped => !canonicalPartNameLookup.Any(set => set.SetEquals(grouped.Key))) - .Select(grouped => grouped.First().deprecatedPath); - - _pathsWithDeprecation = paths - .Concat(withoutDeprecatedAliases.Select(p => new UrlPath(p, OriginalParts, Paths))) - .ToList(); - - // now, check for and prefer deprecated URLs - - var finalPathsWithDeprecations = new List(_pathsWithDeprecation.Count); - - foreach (var path in _pathsWithDeprecation) - { - if (path.Deprecation is null && - DeprecatedPaths.SingleOrDefault(p => p.Path.Equals(path.Path, StringComparison.OrdinalIgnoreCase)) is { } match) - { - finalPathsWithDeprecations.Add(new UrlPath(match, OriginalParts, Paths)); - } - else - { - finalPathsWithDeprecations.Add(path); - } - } - - _pathsWithDeprecation = finalPathsWithDeprecations; - - return _pathsWithDeprecation; - } - } + public IEnumerable Paths => AllPaths.Where(p => p.Deprecation == null); + public IEnumerable DeprecatedPaths => AllPaths.Where(p => p.Deprecation != null); + public IList AllPaths = new List(); public IReadOnlyCollection Parts => Paths .SelectMany(p => p.Parts) @@ -127,7 +55,7 @@ public IReadOnlyCollection PathsWithDeprecations public bool IsDocumentApi => IsADocumentRoute(Parts); public static bool IsADocumentRoute(IReadOnlyCollection parts) => - parts.Count() == DocumentApiParts.Length + parts.Count == DocumentApiParts.Length && parts.All(p => DocumentApiParts.Contains(p.Name)); @@ -136,8 +64,8 @@ public bool TryGetDocumentApiPath(out UrlPath path) path = null; if (!IsDocumentApi) return false; - var mostVerbosePath = _paths.OrderByDescending(p => p.Parts.Count()).First(); - path = new UrlPath(mostVerbosePath.Path, OriginalParts, mostVerbosePath.Parts); + var mostVerbosePath = Paths.OrderByDescending(p => p.Parts.Count).First(); + path = new UrlPath(mostVerbosePath.Path, mostVerbosePath.Parts, mostVerbosePath.Deprecation, mostVerbosePath.VersionAdded, mostVerbosePath.Parts); return true; } } diff --git a/src/ApiGenerator/Domain/Specification/UrlPart.cs b/src/ApiGenerator/Domain/Specification/UrlPart.cs index f0f0c27bbb..08a3d02089 100644 --- a/src/ApiGenerator/Domain/Specification/UrlPart.cs +++ b/src/ApiGenerator/Domain/Specification/UrlPart.cs @@ -30,16 +30,6 @@ namespace ApiGenerator.Domain.Specification { - - // Rename this type to Deprecation and remove Path duplication - public class DeprecatedPath - { - public string Version { get; set; } - public string Path { get; set; } - public string Description { get; set; } - } - - public class UrlPart { private string _description; @@ -146,30 +136,23 @@ public string Description set => _description = CleanUpDescription(value); } - public string InterfaceName - { - get - { - switch (Name) - { - case "repository": return "RepositoryName"; - default: return Name.ToPascalCase(); - } - } - } + public string InterfaceName => + Name switch + { + "repository" => "RepositoryName", + _ => Name.ToPascalCase() + }; - public string Name { get; set; } + public string Name { get; set; } public string NameAsArgument => Name.ToCamelCase(); public IEnumerable Options { get; set; } public bool Required { get; set; } public bool Deprecated { get; set; } public string Type { get; set; } - private string CleanUpDescription(string value) - { - if (string.IsNullOrWhiteSpace(value)) return value; - - return value.Replace("use `_all` or empty string", "use the special string `_all` or Indices.All"); - } - } + private static string CleanUpDescription(string value) => + string.IsNullOrWhiteSpace(value) + ? value + : value.Replace("use `_all` or empty string", "use the special string `_all` or Indices.All"); + } } diff --git a/src/ApiGenerator/Domain/Specification/UrlPath.cs b/src/ApiGenerator/Domain/Specification/UrlPath.cs index 37261eed00..63f215ea07 100644 --- a/src/ApiGenerator/Domain/Specification/UrlPath.cs +++ b/src/ApiGenerator/Domain/Specification/UrlPath.cs @@ -26,50 +26,28 @@ * under the License. */ -using System; using System.Collections.Generic; using System.Linq; +using SemanticVersioning; -namespace ApiGenerator.Domain.Specification +namespace ApiGenerator.Domain.Specification { public class UrlPath { - private readonly List _additionalPartsForConstructor; + private readonly IList _additionalPartsForConstructor; public string Path { get; } - public DeprecatedPath Deprecation { get; } + public Deprecation Deprecation { get; } + public Version VersionAdded { get; } + public IList Parts { get; } - - public List Parts { get; } - - //TODO mark the parts that are deprecated - public UrlPath(DeprecatedPath path, IDictionary originalParts, IReadOnlyCollection allNonDeprecatedPaths) - : this(path.Path, originalParts) - { - Deprecation = path; - foreach (var part in Parts) - { - if (!part.Deprecated && !allNonDeprecatedPaths.Any(p => p.Path.Contains($"{{{part.Name}}}"))) - part.Deprecated = true; - } - } - public UrlPath(string path, IDictionary allParts, List additionalPartsForConstructor = null) + public UrlPath(string path, IList parts, Deprecation deprecation, Version versionAdded, IList additionalPartsForConstructor = null) { _additionalPartsForConstructor = additionalPartsForConstructor ?? new List(); Path = LeadingBackslash(path); - if (allParts == null) - { - Parts = new List(); - return; - } - var parts = - from p in allParts - //so deliciously side effect-y but at least its more isolated then in ApiEndpoint.CsharpMethods - let name = p.Value.Name = p.Key - where path.Contains($"{{{name}}}") - orderby path.IndexOf($"{{{name}}}", StringComparison.Ordinal) - select p.Value; - Parts = parts.ToList(); - } + Parts = parts; + Deprecation = deprecation; + VersionAdded = versionAdded; + } public string ConstructorArguments => string.Join(", ", Parts.Select(p => $"{p.HighLevelTypeName} {p.NameAsArgument}")); public string RequestBaseArguments => diff --git a/src/ApiGenerator/Extensions.cs b/src/ApiGenerator/Extensions.cs index f61b107fe7..9484b5b428 100644 --- a/src/ApiGenerator/Extensions.cs +++ b/src/ApiGenerator/Extensions.cs @@ -71,5 +71,8 @@ public static string SplitPascalCase(this string s) => public static bool IsNullOrEmpty(this string s) => string.IsNullOrEmpty(s); + + public static void SortBy(this List list, Func selector) => + list.Sort((a, b) => Comparer.Default.Compare(selector(a), selector(b))); } } diff --git a/src/ApiGenerator/Generator/ApiEndpointFactory.cs b/src/ApiGenerator/Generator/ApiEndpointFactory.cs index 6b97f032fe..f7827792c5 100644 --- a/src/ApiGenerator/Generator/ApiEndpointFactory.cs +++ b/src/ApiGenerator/Generator/ApiEndpointFactory.cs @@ -31,6 +31,7 @@ using System.Collections.Immutable; using System.Linq; using System.Net.Mime; +using System.Text.RegularExpressions; using ApiGenerator.Configuration; using ApiGenerator.Configuration.Overrides; using ApiGenerator.Domain; @@ -39,6 +40,8 @@ using NJsonSchema; using NJsonSchema.References; using NSwag; +using SemanticVersioning; +using Version = SemanticVersioning.Version; namespace ApiGenerator.Generator { @@ -50,63 +53,103 @@ public static ApiEndpoint From(string name, List<(string HttpPath, OpenApiPathIt var methodName = tokens[^1]; var ns = tokens.Length > 1 ? tokens[0] : null; - var urlInfo = new UrlInformation(); - HashSet requiredPathParams = null; - var allPathParams = new List(); + HashSet requiredPathParts = null; + var allParts = new Dictionary(); + var canonicalPaths = new Dictionary, UrlPath>(HashSet.CreateSetComparer()); + var deprecatedPaths = new Dictionary, UrlPath>(HashSet.CreateSetComparer()); + var overloads = new List<(UrlPath Path, List<(string From, string To)> Renames)>(); foreach (var (httpPath, path, _, operation) in variants.DistinctBy(v => v.HttpPath)) - { - if (!operation.IsDeprecated) - urlInfo.OriginalPaths.Add(httpPath); - else - { - urlInfo.DeprecatedPaths.Add(new DeprecatedPath - { - Path = httpPath, - Version = operation.GetExtension("x-version-deprecated") as string, - Description = operation.GetExtension("x-deprecation-message") as string - }); - } - - var pathParams = path.Parameters - .Concat(operation.Parameters) - .Where(p => p.Kind == OpenApiParameterKind.Path) - .ToList(); - - foreach (var overloadedParam in pathParams.Where(p => p.Schema.XOverloadedParam() != null)) + { + var parts = new List(); + var partNames = new HashSet(); + var overloadedParts = new List<(string From, string To)>(); + + foreach (var param in path.Parameters + .Concat(operation.Parameters) + .Where(p => p.Kind == OpenApiParameterKind.Path)) { - urlInfo.OriginalPaths.Add(httpPath.Replace( - $"{{{overloadedParam.Name}}}", - $"{{{overloadedParam.Schema.XOverloadedParam()}}}" - )); + var partName = param.Name; + if (!allParts.TryGetValue(partName, out var part)) + { + part = allParts[partName] = new UrlPart + { + ClrTypeNameOverride = null, + Deprecated = param.IsDeprecated, + Description = param.Description, + Name = partName, + Type = GetOpenSearchType(param.Schema), + Options = GetEnumOptions(param.Schema) + }; + } + partNames.Add(partName); + parts.Add(part); + + if (param.Schema.XOverloadedParam() is {} overloadedParam) overloadedParts.Add((partName, overloadedParam)); } - var paramNames = pathParams.Select(p => p.Name); - if (requiredPathParams != null) - requiredPathParams.IntersectWith(paramNames); - else - requiredPathParams = new HashSet(paramNames); + parts.SortBy(p => httpPath.IndexOf($"{{{p.Name}}}", StringComparison.Ordinal)); - allPathParams.AddRange(pathParams); + var urlPath = new UrlPath(httpPath, parts, GetDeprecation(operation), operation.XVersionAdded()); + (urlPath.Deprecation == null ? canonicalPaths : deprecatedPaths).TryAdd(partNames, urlPath); + + if (overloadedParts.Count > 0) + overloads.Add((urlPath, overloadedParts)); + + if (requiredPathParts != null) + requiredPathParts.IntersectWith(partNames); + else + requiredPathParts = partNames; } - urlInfo.OriginalParts = allPathParams.DistinctBy(p => p.Name) - .Select(p => new UrlPart - { - ClrTypeNameOverride = null, - Deprecated = p.IsDeprecated, - Description = p.Description, - Name = p.Name, - Required = requiredPathParams?.Contains(p.Name) ?? false, - Type = GetOpenSearchType(p.Schema), - Options = GetEnumOptions(p.Schema) - }) - .ToImmutableSortedDictionary(p => p.Name, p => p); - - urlInfo.Params = variants.SelectMany(v => v.Path.Parameters.Concat(v.Operation.Parameters)) - .Where(p => p.Kind == OpenApiParameterKind.Query) - .DistinctBy(p => p.Name) - .ToImmutableSortedDictionary(p => p.Name, BuildQueryParam); + foreach (var (path, renames) in overloads) + { + foreach (var (from, to) in renames) + { + var newPath = path.Path.Replace($"{{{from}}}", $"{{{to}}}"); + var newParts = path.Parts.Select(p => p.Name == from ? allParts[to] : p).ToList(); + var newPartNames = newParts.Select(p => p.Name).ToHashSet(); + var newUrlPath = new UrlPath(newPath, newParts, path.Deprecation, path.VersionAdded); + (newUrlPath.Deprecation == null ? canonicalPaths : deprecatedPaths).TryAdd(newPartNames, newUrlPath); + } + } + + //some deprecated paths describe aliases to the canonical using the same path e.g + // PUT /{index}/_mapping/{type} + // PUT /{index}/{type}/_mappings + // + //The following routine dedups these occasions and prefers either the canonical path + //or the first duplicate deprecated path + + var paths = canonicalPaths.Values + .Concat(deprecatedPaths + .Where(p => !canonicalPaths.ContainsKey(p.Key)) + .Select(p => p.Value)) + .ToList(); + paths.Sort((p1, p2) => p1.Parts + .Zip(p2.Parts) + .Select(t => string.Compare(t.First.Name, t.Second.Name, StringComparison.Ordinal)) + .SkipWhile(c => c == 0) + .FirstOrDefault()); + + // // now, check for and prefer deprecated URLs + // + // var finalPathsWithDeprecations = new List(_pathsWithDeprecation.Count); + // + // foreach (var path in _pathsWithDeprecation) + // { + // if (path.Deprecation is null && + // DeprecatedPaths.SingleOrDefault(p => p.Path.Equals(path.Path, StringComparison.OrdinalIgnoreCase)) is { } match) + // { + // finalPathsWithDeprecations.Add(new UrlPath(match, OriginalParts, Paths)); + // } + // else + // { + // finalPathsWithDeprecations.Add(path); + // } + // } + + foreach (var partName in requiredPathParts ?? Enumerable.Empty()) allParts[partName].Required = true; var endpoint = new ApiEndpoint { @@ -120,7 +163,14 @@ public static ApiEndpoint From(string name, List<(string HttpPath, OpenApiPathIt Description = variants[0].Operation.Description, Url = variants[0].Operation.ExternalDocumentation?.Url }, - Url = urlInfo, + Url = new UrlInformation + { + AllPaths = paths, + Params = variants.SelectMany(v => v.Path.Parameters.Concat(v.Operation.Parameters)) + .Where(p => p.Kind == OpenApiParameterKind.Query) + .DistinctBy(p => p.Name) + .ToImmutableSortedDictionary(p => p.Name, BuildQueryParam) + }, Body = variants .Select(v => v.Operation.RequestBody) .FirstOrDefault(b => b != null) is { } reqBody @@ -215,8 +265,15 @@ private static string XDeprecationMessage(this IJsonExtensionObject schema) => private static string XVersionDeprecated(this IJsonExtensionObject schema) => schema.GetExtension("x-version-deprecated") as string; - private static string XVersionAdded(this IJsonExtensionObject schema) => - schema.GetExtension("x-version-added") as string; + private static Version XVersionAdded(this IJsonExtensionObject schema) => + schema.GetExtension("x-version-added") is string s + ? s.Split('.').Length switch + { + 1 => new Version($"{s}.0.0"), + 2 => new Version($"{s}.0"), + _ => new Version(s), + } + : null; private static string XDataType(this IJsonExtensionObject schema) => schema.GetExtension("x-data-type") as string; diff --git a/src/ApiGenerator/Generator/CodeGenerator.cs b/src/ApiGenerator/Generator/CodeGenerator.cs index b8165cc48c..9a0a5cb025 100644 --- a/src/ApiGenerator/Generator/CodeGenerator.cs +++ b/src/ApiGenerator/Generator/CodeGenerator.cs @@ -30,6 +30,7 @@ using System.Collections.Generic; using System.Linq; using ApiGenerator.Domain.Code.HighLevel.Requests; +using Version = SemanticVersioning.Version; namespace ApiGenerator.Generator { @@ -45,11 +46,11 @@ public static string CatFormatPropertyGenerator(string type, string name, string public static string PropertyGenerator(string type, string name, string key, string setter) => $"public {type} {name} {{ get => Q<{type}>(\"{key}\"); set => Q(\"{key}\", {setter}); }}"; - public static string Property(string @namespace, string type, string name, string key, string setter, string obsolete, string versionAdded, params string[] doc) + public static string Property(string @namespace, string type, string name, string key, string setter, string obsolete, Version versionAdded, params string[] doc) { var components = new List(); foreach (var d in RenderDocumentation(doc)) A(d); - if (!string.IsNullOrWhiteSpace(versionAdded)) A($"///Supported by OpenSearch servers of version {versionAdded} or greater."); + if (versionAdded != null) A($"/// Supported by OpenSearch servers of version {versionAdded} or greater."); if (!string.IsNullOrWhiteSpace(obsolete)) A($"[Obsolete(\"{obsolete}\")]"); var generated = @namespace != null && @namespace == "Cat" && name == "Format" diff --git a/src/ApiGenerator/Views/HighLevel/Client/MethodXmlDocs.cshtml b/src/ApiGenerator/Views/HighLevel/Client/MethodXmlDocs.cshtml index 723eb10db0..0a4ec9a61b 100644 --- a/src/ApiGenerator/Views/HighLevel/Client/MethodXmlDocs.cshtml +++ b/src/ApiGenerator/Views/HighLevel/Client/MethodXmlDocs.cshtml @@ -1,11 +1,17 @@ @using ApiGenerator @using ApiGenerator.Domain.Code.HighLevel.Methods; +@using Version = SemanticVersioning.Version; @inherits CodeTemplatePage /// /// @Raw(Model.XmlDocSummary) /// @Raw("") /// @Model.DocumentationLink /// +@if (Model.VersionAdded is {} versionAdded && versionAdded > new Version("1.0.0")) +{ +/// Supported by OpenSearch servers of version @(versionAdded) or greater. + +} @if (Model.Deprecated is {} deprecation) { @Raw($"[Obsolete(\"{deprecation}\")]") diff --git a/src/ApiGenerator/Views/HighLevel/Descriptors/Descriptor.cshtml b/src/ApiGenerator/Views/HighLevel/Descriptors/Descriptor.cshtml index f2ca53d42f..2e0626c3c1 100644 --- a/src/ApiGenerator/Views/HighLevel/Descriptors/Descriptor.cshtml +++ b/src/ApiGenerator/Views/HighLevel/Descriptors/Descriptor.cshtml @@ -10,9 +10,9 @@ var baseInterface = names.GenericOrNonGenericInterfacePreference; var apiLookup = $"ApiUrlsLookups.{Model.CsharpNames.Namespace}{Model.CsharpNames.MethodName}"; } - ///Descriptor for @names.MethodName@(Raw(Model.OfficialDocumentationLink.IsNullOrEmpty() ? "" : " " + Model.OfficialDocumentationLink + "")) + /// Descriptor for @names.MethodName@(Raw(Model.OfficialDocumentationLink.IsNullOrEmpty() ? "" : " " + Model.OfficialDocumentationLink + "")) public partial class @Raw(type) @(Raw(string.Format(" : RequestDescriptorBase<{0},{1}, {2}>, {2}", type,names.ParametersName, concreteInterface))) - { + { internal override ApiUrls ApiUrls => @apiLookup; @foreach (var c in Model.Constructors) { @@ -50,36 +50,27 @@ var tSuffix = (t == "bool" || t == "bool?") ? " = true" : ""; var typed = !string.IsNullOrEmpty(names.GenericsDeclaredOnDescriptor); var g = typed ? names.GenericsDeclaredOnDescriptor.Replace("<", "").Replace(">", "") : "T"; - var desc = param.DescriptionHighLevel.ToList(); - - await IncludeAsync("HighLevel/Descriptors/XmlDocs.cshtml", desc); - if (!string.IsNullOrWhiteSpace(param.VersionAdded)) - { - - ///Supported by OpenSearch servers of version @(param.VersionAdded) or greater. - } + await IncludeAsync("HighLevel/Descriptors/XmlDocs.cshtml", param); if(!string.IsNullOrWhiteSpace(param.Obsolete)) { - - [Obsolete("@Raw(param.Obsolete)")] - + [Obsolete("@Raw(param.Obsolete)")] + } - - public @Raw(type) @(param.ClsName)(@param.DescriptorArgumentType @param.ClsArgumentName@tSuffix) => Qs("@original", @(param.ClsArgumentName)); + public @Raw(type) @(param.ClsName)(@param.DescriptorArgumentType @param.ClsArgumentName@tSuffix) => Qs("@original", @(param.ClsArgumentName)); if (param.IsFieldsParam) { - ///@param.Description + /// @param.Description public @Raw(type) @param.ClsName@(Raw(typed ? "" : ""))(params @Raw("Expression>[]") fields) @Raw(typed ? "" : "where " + g + " : class") => Qs("@original", fields?@Raw(".Select(e=>(Field)e)")); } else if (param.IsFieldParam) { - ///@param.Description + /// @param.Description public @Raw(type) @param.ClsName@(Raw(typed ? "" : ""))(@Raw("Expression>") field) @Raw(typed ? "" : "where " + g + " : class") => Qs("@original", (Field)field); } @@ -90,6 +81,6 @@ public bool IsUnmapped => true; public bool UseIsUnmapped => IsUnmapped; - } + } } diff --git a/src/ApiGenerator/Views/HighLevel/Descriptors/XmlDocs.cshtml b/src/ApiGenerator/Views/HighLevel/Descriptors/XmlDocs.cshtml index ebbe54683e..5435af2bf5 100644 --- a/src/ApiGenerator/Views/HighLevel/Descriptors/XmlDocs.cshtml +++ b/src/ApiGenerator/Views/HighLevel/Descriptors/XmlDocs.cshtml @@ -1,8 +1,10 @@ @using System.Linq -@inherits ApiGenerator.CodeTemplatePage> +@using Version = SemanticVersioning.Version +@inherits ApiGenerator.CodeTemplatePage @{ - var description = Model.Count == 1 ? Model.First() : string.Join($"{Environment.NewLine}\t\t", Model.Select(d => "/// " + d)); - if (Model.Count == 1) + var docs = Model.DescriptionHighLevel.ToList(); + var description = docs.Count == 1 ? docs.First() : string.Join($"{Environment.NewLine}\t\t", docs.Select(d => "/// " + d)); + if (docs.Count == 1) { /// @Raw(description) @@ -14,4 +16,9 @@ /// } + if (Model.VersionAdded is {} versionAdded && versionAdded > new Version("1.0.0")) + { + /// Supported by OpenSearch servers of version @(versionAdded) or greater. + + } } diff --git a/src/ApiGenerator/Views/HighLevel/Requests/ApiUrlsLookup.cshtml b/src/ApiGenerator/Views/HighLevel/Requests/ApiUrlsLookup.cshtml index 68d92443e6..4cebf146e9 100644 --- a/src/ApiGenerator/Views/HighLevel/Requests/ApiUrlsLookup.cshtml +++ b/src/ApiGenerator/Views/HighLevel/Requests/ApiUrlsLookup.cshtml @@ -15,7 +15,7 @@ namespace OpenSearch.Client continue; } var propertyName = $"{endpoint.CsharpNames.Namespace}{endpoint.CsharpNames.MethodName}"; - var paths = endpoint.Url.Paths.Count == 0 ? endpoint.Url.PathsWithDeprecations : endpoint.Url.Paths; + var paths = !endpoint.Url.Paths.Any() ? endpoint.Url.AllPaths : endpoint.Url.Paths; internal static readonly ApiUrls @(Raw(propertyName)) = new(new [] {@Raw(string.Join(", ", paths.Select(p=>$"\"{p.Path.TrimStart('/')}\"")))}); diff --git a/src/ApiGenerator/Views/LowLevel/Client/Methods/MethodDocs.cshtml b/src/ApiGenerator/Views/LowLevel/Client/Methods/MethodDocs.cshtml index e2b355e8b2..2801001566 100644 --- a/src/ApiGenerator/Views/LowLevel/Client/Methods/MethodDocs.cshtml +++ b/src/ApiGenerator/Views/LowLevel/Client/Methods/MethodDocs.cshtml @@ -1,6 +1,8 @@ @using ApiGenerator @using ApiGenerator.Domain.Code.LowLevel @using ApiGenerator.Domain.Specification +@using SemanticVersioning +@using Version = SemanticVersioning.Version @inherits ApiGenerator.CodeTemplatePage /// @Model.HttpMethod on @Model.Path@(Raw(Model.OfficialDocumentationLink.IsNullOrEmpty() ? "" : " " + Model.OfficialDocumentationLink + "")) @foreach (var part in Model.Parts) @@ -27,8 +29,11 @@ /// @Raw("Note: " + Model.Stability + " within the OpenSearch server, " + warningMessage + "") } + @if (Model.VersionAdded is {} versionAdded && versionAdded > new Version("1.0.0")) + { + /// @Raw("Supported by OpenSearch servers of version " + versionAdded + " or greater.") } - @if (Model.DeprecatedPath != null) + @if (Model.Deprecation is {} deprecation) { - [Obsolete("Deprecated in version @Model.DeprecatedPath.Version: @Raw(Model.DeprecatedPath.Description)")] + [Obsolete("Deprecated in version @deprecation.Version: @Raw(deprecation.Description)")] } From 5642a9f66549d13455b53b0bd82eb5ded22e8d67 Mon Sep 17 00:00:00 2001 From: Thomas Farr Date: Mon, 16 Oct 2023 17:08:42 +1300 Subject: [PATCH 4/4] Re-generate Signed-off-by: Thomas Farr --- .../_Generated/ApiUrlsLookup.cs | 2 +- .../_Generated/Descriptors.Cluster.cs | 78 +++--- .../_Generated/Descriptors.DanglingIndices.cs | 38 +-- .../_Generated/Descriptors.Ingest.cs | 62 ++--- .../_Generated/Descriptors.Nodes.cs | 150 +++++----- .../_Generated/Descriptors.Snapshot.cs | 200 ++++++------- .../_Generated/Descriptors.Tasks.cs | 46 +-- .../_Generated/IOpenSearchClient.cs | 18 +- .../_Generated/OpenSearchClient.Cluster.cs | 6 +- .../OpenSearchClient.DanglingIndices.cs | 6 +- .../_Generated/OpenSearchClient.Ingest.cs | 6 +- .../_Generated/OpenSearchClient.Nodes.cs | 6 +- .../_Generated/OpenSearchClient.Snapshot.cs | 6 +- .../_Generated/OpenSearchClient.Tasks.cs | 6 +- .../_Generated/OpenSearchClient.cs | 18 +- .../_Generated/Requests.Cluster.cs | 72 ++--- .../_Generated/Requests.DanglingIndices.cs | 38 +-- .../_Generated/Requests.Ingest.cs | 58 ++-- .../_Generated/Requests.Nodes.cs | 126 ++++----- .../_Generated/Requests.Snapshot.cs | 194 ++++++------- .../_Generated/Requests.Tasks.cs | 48 ++-- .../RequestParameters.Cluster.cs | 92 +++--- .../RequestParameters.DanglingIndices.cs | 26 +- .../RequestParameters.Ingest.cs | 34 +-- .../RequestParameters.Nodes.cs | 46 +-- .../RequestParameters.Snapshot.cs | 110 ++++---- .../RequestParameters.Tasks.cs | 36 +-- .../_Generated/IOpenSearchLowLevelClient.cs | 18 +- .../OpenSearchLowLevelClient.Cluster.cs | 106 +++---- ...penSearchLowLevelClient.DanglingIndices.cs | 38 +-- .../OpenSearchLowLevelClient.Ingest.cs | 90 +++--- .../OpenSearchLowLevelClient.Nodes.cs | 262 +++++++++--------- .../OpenSearchLowLevelClient.Snapshot.cs | 210 +++++++------- .../OpenSearchLowLevelClient.Tasks.cs | 46 +-- .../_Generated/OpenSearchLowLevelClient.cs | 6 +- 35 files changed, 1152 insertions(+), 1152 deletions(-) diff --git a/src/OpenSearch.Client/_Generated/ApiUrlsLookup.cs b/src/OpenSearch.Client/_Generated/ApiUrlsLookup.cs index 322dd4a676..db47501d1f 100644 --- a/src/OpenSearch.Client/_Generated/ApiUrlsLookup.cs +++ b/src/OpenSearch.Client/_Generated/ApiUrlsLookup.cs @@ -89,8 +89,8 @@ internal static partial class ApiUrlsLookups new[] { "_nodes", - "_nodes/{node_id}", "_nodes/{metric}", + "_nodes/{node_id}", "_nodes/{node_id}/{metric}" } ); diff --git a/src/OpenSearch.Client/_Generated/Descriptors.Cluster.cs b/src/OpenSearch.Client/_Generated/Descriptors.Cluster.cs index 555c484199..234b1b72ae 100644 --- a/src/OpenSearch.Client/_Generated/Descriptors.Cluster.cs +++ b/src/OpenSearch.Client/_Generated/Descriptors.Cluster.cs @@ -58,7 +58,7 @@ // ReSharper disable RedundantNameQualifier namespace OpenSearch.Client.Specification.ClusterApi { - ///Descriptor for AllocationExplain https://opensearch.org/docs/latest/api-reference/cluster-api/cluster-allocation/ + /// Descriptor for AllocationExplain https://opensearch.org/docs/latest/api-reference/cluster-api/cluster-allocation/ public partial class ClusterAllocationExplainDescriptor : RequestDescriptorBase< ClusterAllocationExplainDescriptor, @@ -71,17 +71,17 @@ public partial class ClusterAllocationExplainDescriptor // values part of the url path // Request parameters - ///Return information about disk usage and shard sizes. + /// Return information about disk usage and shard sizes. public ClusterAllocationExplainDescriptor IncludeDiskInfo(bool? includediskinfo = true) => Qs("include_disk_info", includediskinfo); - ///Return 'YES' decisions in explanation. + /// Return 'YES' decisions in explanation. public ClusterAllocationExplainDescriptor IncludeYesDecisions( bool? includeyesdecisions = true ) => Qs("include_yes_decisions", includeyesdecisions); } - ///Descriptor for DeleteVotingConfigExclusions https://opensearch.org/docs/latest + /// Descriptor for DeleteVotingConfigExclusions https://opensearch.org/docs/latest public partial class DeleteVotingConfigExclusionsDescriptor : RequestDescriptorBase< DeleteVotingConfigExclusionsDescriptor, @@ -94,12 +94,12 @@ public partial class DeleteVotingConfigExclusionsDescriptor // values part of the url path // Request parameters - ///Specifies whether to wait for all excluded nodes to be removed from the cluster before clearing the voting configuration exclusions list. + /// Specifies whether to wait for all excluded nodes to be removed from the cluster before clearing the voting configuration exclusions list. public DeleteVotingConfigExclusionsDescriptor WaitForRemoval(bool? waitforremoval = true) => Qs("wait_for_removal", waitforremoval); } - ///Descriptor for GetSettings https://opensearch.org/docs/latest/api-reference/cluster-api/cluster-settings/ + /// Descriptor for GetSettings https://opensearch.org/docs/latest/api-reference/cluster-api/cluster-settings/ public partial class ClusterGetSettingsDescriptor : RequestDescriptorBase< ClusterGetSettingsDescriptor, @@ -112,31 +112,31 @@ public partial class ClusterGetSettingsDescriptor // values part of the url path // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public ClusterGetSettingsDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Return settings in flat format. + /// Return settings in flat format. public ClusterGetSettingsDescriptor FlatSettings(bool? flatsettings = true) => Qs("flat_settings", flatsettings); - ///Whether to return all default clusters setting. + /// Whether to return all default clusters setting. public ClusterGetSettingsDescriptor IncludeDefaults(bool? includedefaults = true) => Qs("include_defaults", includedefaults); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] public ClusterGetSettingsDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); - ///Operation timeout. + /// Operation timeout. public ClusterGetSettingsDescriptor Timeout(Time timeout) => Qs("timeout", timeout); } - ///Descriptor for Health https://opensearch.org/docs/latest/api-reference/cluster-api/cluster-health/ + /// Descriptor for Health https://opensearch.org/docs/latest/api-reference/cluster-api/cluster-health/ public partial class ClusterHealthDescriptor : RequestDescriptorBase< ClusterHealthDescriptor, @@ -147,94 +147,94 @@ public partial class ClusterHealthDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.ClusterHealth; - ////_cluster/health + /// /_cluster/health public ClusterHealthDescriptor() : base() { } - ////_cluster/health/{index} - ///Optional, accepts null + /// /_cluster/health/{index} + /// Optional, accepts null public ClusterHealthDescriptor(Indices index) : base(r => r.Optional("index", index)) { } // values part of the url path Indices IClusterHealthRequest.Index => Self.RouteValues.Get("index"); - ///Limit the information returned to specific indicies. + /// Limit the information returned to specific indicies. public ClusterHealthDescriptor Index(Indices index) => Assign(index, (a, v) => a.RouteValues.Optional("index", v)); - ///a shortcut into calling Index(typeof(TOther)) + /// a shortcut into calling Index(typeof(TOther)) public ClusterHealthDescriptor Index() where TOther : class => Assign(typeof(TOther), (a, v) => a.RouteValues.Optional("index", (Indices)v)); - ///A shortcut into calling Index(Indices.All) + /// A shortcut into calling Index(Indices.All) public ClusterHealthDescriptor AllIndices() => Index(Indices.All); // Request parameters - ///The awareness attribute for which the health is required. + /// The awareness attribute for which the health is required. public ClusterHealthDescriptor AwarenessAttribute(string awarenessattribute) => Qs("awareness_attribute", awarenessattribute); - ///Specify the level of detail for returned information. + /// Specify the level of detail for returned information. public ClusterHealthDescriptor ClusterHealthLevel(ClusterHealthLevel? clusterhealthlevel) => Qs("level", clusterhealthlevel); - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public ClusterHealthDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Checks whether local node is commissioned or not. If set to true on a local call it will throw exception if node is decommissioned. + /// Checks whether local node is commissioned or not. If set to true on a local call it will throw exception if node is decommissioned. public ClusterHealthDescriptor EnsureNodeCommissioned( bool? ensurenodecommissioned = true ) => Qs("ensure_node_commissioned", ensurenodecommissioned); - ///Whether to expand wildcard expression to concrete indices that are open, closed or both. + /// Whether to expand wildcard expression to concrete indices that are open, closed or both. public ClusterHealthDescriptor ExpandWildcards(ExpandWildcards? expandwildcards) => Qs("expand_wildcards", expandwildcards); - ///Return local information, do not retrieve the state from cluster-manager node. + /// Return local information, do not retrieve the state from cluster-manager node. public ClusterHealthDescriptor Local(bool? local = true) => Qs("local", local); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] public ClusterHealthDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); - ///Operation timeout. + /// Operation timeout. public ClusterHealthDescriptor Timeout(Time timeout) => Qs("timeout", timeout); - ///Wait until the specified number of shards is active. + /// Wait until the specified number of shards is active. public ClusterHealthDescriptor WaitForActiveShards(string waitforactiveshards) => Qs("wait_for_active_shards", waitforactiveshards); - ///Wait until all currently queued events with the given priority are processed. + /// Wait until all currently queued events with the given priority are processed. public ClusterHealthDescriptor WaitForEvents(WaitForEvents? waitforevents) => Qs("wait_for_events", waitforevents); - ///Wait until the specified number of nodes is available. + /// Wait until the specified number of nodes is available. public ClusterHealthDescriptor WaitForNodes(string waitfornodes) => Qs("wait_for_nodes", waitfornodes); - ///Whether to wait until there are no initializing shards in the cluster. + /// Whether to wait until there are no initializing shards in the cluster. public ClusterHealthDescriptor WaitForNoInitializingShards( bool? waitfornoinitializingshards = true ) => Qs("wait_for_no_initializing_shards", waitfornoinitializingshards); - ///Whether to wait until there are no relocating shards in the cluster. + /// Whether to wait until there are no relocating shards in the cluster. public ClusterHealthDescriptor WaitForNoRelocatingShards( bool? waitfornorelocatingshards = true ) => Qs("wait_for_no_relocating_shards", waitfornorelocatingshards); - ///Wait until cluster is in a specific state. + /// Wait until cluster is in a specific state. public ClusterHealthDescriptor WaitForStatus(WaitForStatus? waitforstatus) => Qs("wait_for_status", waitforstatus); } - ///Descriptor for PendingTasks https://opensearch.org/docs/latest + /// Descriptor for PendingTasks https://opensearch.org/docs/latest public partial class ClusterPendingTasksDescriptor : RequestDescriptorBase< ClusterPendingTasksDescriptor, @@ -247,15 +247,15 @@ public partial class ClusterPendingTasksDescriptor // values part of the url path // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public ClusterPendingTasksDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Return local information, do not retrieve the state from cluster-manager node. + /// Return local information, do not retrieve the state from cluster-manager node. public ClusterPendingTasksDescriptor Local(bool? local = true) => Qs("local", local); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] diff --git a/src/OpenSearch.Client/_Generated/Descriptors.DanglingIndices.cs b/src/OpenSearch.Client/_Generated/Descriptors.DanglingIndices.cs index bed0d17e70..9183697b4a 100644 --- a/src/OpenSearch.Client/_Generated/Descriptors.DanglingIndices.cs +++ b/src/OpenSearch.Client/_Generated/Descriptors.DanglingIndices.cs @@ -58,7 +58,7 @@ // ReSharper disable RedundantNameQualifier namespace OpenSearch.Client.Specification.DanglingIndicesApi { - ///Descriptor for DeleteDanglingIndex https://opensearch.org/docs/latest/api-reference/index-apis/dangling-index/ + /// Descriptor for DeleteDanglingIndex https://opensearch.org/docs/latest/api-reference/index-apis/dangling-index/ public partial class DeleteDanglingIndexDescriptor : RequestDescriptorBase< DeleteDanglingIndexDescriptor, @@ -69,12 +69,12 @@ public partial class DeleteDanglingIndexDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.DanglingIndicesDeleteDanglingIndex; - ////_dangling/{index_uuid} - ///this parameter is required + /// /_dangling/{index_uuid} + /// this parameter is required public DeleteDanglingIndexDescriptor(IndexUuid indexUuid) : base(r => r.Required("index_uuid", indexUuid)) { } - ///Used for serialization purposes, making sure we have a parameterless constructor + /// Used for serialization purposes, making sure we have a parameterless constructor [SerializationConstructor] protected DeleteDanglingIndexDescriptor() : base() { } @@ -84,27 +84,27 @@ protected DeleteDanglingIndexDescriptor() Self.RouteValues.Get("index_uuid"); // Request parameters - ///Must be set to true in order to delete the dangling index. + /// Must be set to true in order to delete the dangling index. public DeleteDanglingIndexDescriptor AcceptDataLoss(bool? acceptdataloss = true) => Qs("accept_data_loss", acceptdataloss); - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public DeleteDanglingIndexDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] public DeleteDanglingIndexDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); - ///Operation timeout. + /// Operation timeout. public DeleteDanglingIndexDescriptor Timeout(Time timeout) => Qs("timeout", timeout); } - ///Descriptor for ImportDanglingIndex https://opensearch.org/docs/latest/api-reference/index-apis/dangling-index/ + /// Descriptor for ImportDanglingIndex https://opensearch.org/docs/latest/api-reference/index-apis/dangling-index/ public partial class ImportDanglingIndexDescriptor : RequestDescriptorBase< ImportDanglingIndexDescriptor, @@ -115,12 +115,12 @@ public partial class ImportDanglingIndexDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.DanglingIndicesImportDanglingIndex; - ////_dangling/{index_uuid} - ///this parameter is required + /// /_dangling/{index_uuid} + /// this parameter is required public ImportDanglingIndexDescriptor(IndexUuid indexUuid) : base(r => r.Required("index_uuid", indexUuid)) { } - ///Used for serialization purposes, making sure we have a parameterless constructor + /// Used for serialization purposes, making sure we have a parameterless constructor [SerializationConstructor] protected ImportDanglingIndexDescriptor() : base() { } @@ -130,27 +130,27 @@ protected ImportDanglingIndexDescriptor() Self.RouteValues.Get("index_uuid"); // Request parameters - ///Must be set to true in order to import the dangling index. + /// Must be set to true in order to import the dangling index. public ImportDanglingIndexDescriptor AcceptDataLoss(bool? acceptdataloss = true) => Qs("accept_data_loss", acceptdataloss); - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public ImportDanglingIndexDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] public ImportDanglingIndexDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); - ///Operation timeout. + /// Operation timeout. public ImportDanglingIndexDescriptor Timeout(Time timeout) => Qs("timeout", timeout); } - ///Descriptor for List https://opensearch.org/docs/latest/api-reference/index-apis/dangling-index/ + /// Descriptor for List https://opensearch.org/docs/latest/api-reference/index-apis/dangling-index/ public partial class ListDanglingIndicesDescriptor : RequestDescriptorBase< ListDanglingIndicesDescriptor, diff --git a/src/OpenSearch.Client/_Generated/Descriptors.Ingest.cs b/src/OpenSearch.Client/_Generated/Descriptors.Ingest.cs index 6d90f2a038..74fe2de3b2 100644 --- a/src/OpenSearch.Client/_Generated/Descriptors.Ingest.cs +++ b/src/OpenSearch.Client/_Generated/Descriptors.Ingest.cs @@ -58,7 +58,7 @@ // ReSharper disable RedundantNameQualifier namespace OpenSearch.Client.Specification.IngestApi { - ///Descriptor for DeletePipeline https://opensearch.org/docs/latest/api-reference/ingest-apis/delete-ingest/ + /// Descriptor for DeletePipeline https://opensearch.org/docs/latest/api-reference/ingest-apis/delete-ingest/ public partial class DeletePipelineDescriptor : RequestDescriptorBase< DeletePipelineDescriptor, @@ -69,12 +69,12 @@ public partial class DeletePipelineDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.IngestDeletePipeline; - ////_ingest/pipeline/{id} - ///this parameter is required + /// /_ingest/pipeline/{id} + /// this parameter is required public DeletePipelineDescriptor(Id id) : base(r => r.Required("id", id)) { } - ///Used for serialization purposes, making sure we have a parameterless constructor + /// Used for serialization purposes, making sure we have a parameterless constructor [SerializationConstructor] protected DeletePipelineDescriptor() : base() { } @@ -83,23 +83,23 @@ protected DeletePipelineDescriptor() Id IDeletePipelineRequest.Id => Self.RouteValues.Get("id"); // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public DeletePipelineDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] public DeletePipelineDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); - ///Operation timeout. + /// Operation timeout. public DeletePipelineDescriptor Timeout(Time timeout) => Qs("timeout", timeout); } - ///Descriptor for GetPipeline https://opensearch.org/docs/latest/api-reference/ingest-apis/get-ingest/ + /// Descriptor for GetPipeline https://opensearch.org/docs/latest/api-reference/ingest-apis/get-ingest/ public partial class GetPipelineDescriptor : RequestDescriptorBase< GetPipelineDescriptor, @@ -110,29 +110,29 @@ public partial class GetPipelineDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.IngestGetPipeline; - ////_ingest/pipeline + /// /_ingest/pipeline public GetPipelineDescriptor() : base() { } - ////_ingest/pipeline/{id} - ///Optional, accepts null + /// /_ingest/pipeline/{id} + /// Optional, accepts null public GetPipelineDescriptor(Id id) : base(r => r.Optional("id", id)) { } // values part of the url path Id IGetPipelineRequest.Id => Self.RouteValues.Get("id"); - ///Comma-separated list of pipeline ids. Wildcards supported. + /// Comma-separated list of pipeline ids. Wildcards supported. public GetPipelineDescriptor Id(Id id) => Assign(id, (a, v) => a.RouteValues.Optional("id", v)); // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public GetPipelineDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] @@ -140,7 +140,7 @@ public GetPipelineDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); } - ///Descriptor for GrokProcessorPatterns https://opensearch.org/docs/latest + /// Descriptor for GrokProcessorPatterns https://opensearch.org/docs/latest public partial class GrokProcessorPatternsDescriptor : RequestDescriptorBase< GrokProcessorPatternsDescriptor, @@ -154,7 +154,7 @@ public partial class GrokProcessorPatternsDescriptor // Request parameters } - ///Descriptor for PutPipeline https://opensearch.org/docs/latest/api-reference/ingest-apis/create-update-ingest/ + /// Descriptor for PutPipeline https://opensearch.org/docs/latest/api-reference/ingest-apis/create-update-ingest/ public partial class PutPipelineDescriptor : RequestDescriptorBase< PutPipelineDescriptor, @@ -165,12 +165,12 @@ public partial class PutPipelineDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.IngestPutPipeline; - ////_ingest/pipeline/{id} - ///this parameter is required + /// /_ingest/pipeline/{id} + /// this parameter is required public PutPipelineDescriptor(Id id) : base(r => r.Required("id", id)) { } - ///Used for serialization purposes, making sure we have a parameterless constructor + /// Used for serialization purposes, making sure we have a parameterless constructor [SerializationConstructor] protected PutPipelineDescriptor() : base() { } @@ -179,23 +179,23 @@ protected PutPipelineDescriptor() Id IPutPipelineRequest.Id => Self.RouteValues.Get("id"); // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public PutPipelineDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] public PutPipelineDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); - ///Operation timeout. + /// Operation timeout. public PutPipelineDescriptor Timeout(Time timeout) => Qs("timeout", timeout); } - ///Descriptor for SimulatePipeline https://opensearch.org/docs/latest/api-reference/ingest-apis/simulate-ingest/ + /// Descriptor for SimulatePipeline https://opensearch.org/docs/latest/api-reference/ingest-apis/simulate-ingest/ public partial class SimulatePipelineDescriptor : RequestDescriptorBase< SimulatePipelineDescriptor, @@ -206,24 +206,24 @@ public partial class SimulatePipelineDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.IngestSimulatePipeline; - ////_ingest/pipeline/_simulate + /// /_ingest/pipeline/_simulate public SimulatePipelineDescriptor() : base() { } - ////_ingest/pipeline/{id}/_simulate - ///Optional, accepts null + /// /_ingest/pipeline/{id}/_simulate + /// Optional, accepts null public SimulatePipelineDescriptor(Id id) : base(r => r.Optional("id", id)) { } // values part of the url path Id ISimulatePipelineRequest.Id => Self.RouteValues.Get("id"); - ///Pipeline ID. + /// Pipeline ID. public SimulatePipelineDescriptor Id(Id id) => Assign(id, (a, v) => a.RouteValues.Optional("id", v)); // Request parameters - ///Verbose mode. Display data output for each processor in executed pipeline. + /// Verbose mode. Display data output for each processor in executed pipeline. public SimulatePipelineDescriptor Verbose(bool? verbose = true) => Qs("verbose", verbose); } } diff --git a/src/OpenSearch.Client/_Generated/Descriptors.Nodes.cs b/src/OpenSearch.Client/_Generated/Descriptors.Nodes.cs index 7a34b9e5d5..0cb44d5830 100644 --- a/src/OpenSearch.Client/_Generated/Descriptors.Nodes.cs +++ b/src/OpenSearch.Client/_Generated/Descriptors.Nodes.cs @@ -58,7 +58,7 @@ // ReSharper disable RedundantNameQualifier namespace OpenSearch.Client.Specification.NodesApi { - ///Descriptor for HotThreads https://opensearch.org/docs/latest/api-reference/nodes-apis/nodes-hot-threads/ + /// Descriptor for HotThreads https://opensearch.org/docs/latest/api-reference/nodes-apis/nodes-hot-threads/ public partial class NodesHotThreadsDescriptor : RequestDescriptorBase< NodesHotThreadsDescriptor, @@ -69,68 +69,68 @@ public partial class NodesHotThreadsDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.NodesHotThreads; - ////_nodes/hot_threads + /// /_nodes/hot_threads public NodesHotThreadsDescriptor() : base() { } - ////_nodes/{node_id}/hot_threads - ///Optional, accepts null + /// /_nodes/{node_id}/hot_threads + /// Optional, accepts null public NodesHotThreadsDescriptor(NodeIds nodeId) : base(r => r.Optional("node_id", nodeId)) { } // values part of the url path NodeIds INodesHotThreadsRequest.NodeId => Self.RouteValues.Get("node_id"); - ///Comma-separated list of node IDs or names to limit the returned information; use `_local` to return information from the node you're connecting to, leave empty to get information from all nodes. + /// Comma-separated list of node IDs or names to limit the returned information; use `_local` to return information from the node you're connecting to, leave empty to get information from all nodes. public NodesHotThreadsDescriptor NodeId(NodeIds nodeId) => Assign(nodeId, (a, v) => a.RouteValues.Optional("node_id", v)); // Request parameters - ///Don't show threads that are in known-idle places, such as waiting on a socket select or pulling from an empty task queue. + /// Don't show threads that are in known-idle places, such as waiting on a socket select or pulling from an empty task queue. public NodesHotThreadsDescriptor IgnoreIdleThreads(bool? ignoreidlethreads = true) => Qs("ignore_idle_threads", ignoreidlethreads); - ///The interval for the second sampling of threads. + /// The interval for the second sampling of threads. public NodesHotThreadsDescriptor Interval(Time interval) => Qs("interval", interval); - ///The type to sample. + /// The type to sample. public NodesHotThreadsDescriptor SampleType(SampleType? sampletype) => Qs("type", sampletype); - ///Number of samples of thread stacktrace. + /// Number of samples of thread stacktrace. public NodesHotThreadsDescriptor Snapshots(long? snapshots) => Qs("snapshots", snapshots); - ///Specify the number of threads to provide information for. + /// Specify the number of threads to provide information for. public NodesHotThreadsDescriptor Threads(long? threads) => Qs("threads", threads); - ///Operation timeout. + /// Operation timeout. public NodesHotThreadsDescriptor Timeout(Time timeout) => Qs("timeout", timeout); } - ///Descriptor for Info https://opensearch.org/docs/latest/api-reference/nodes-apis/nodes-info/ + /// Descriptor for Info https://opensearch.org/docs/latest/api-reference/nodes-apis/nodes-info/ public partial class NodesInfoDescriptor : RequestDescriptorBase, INodesInfoRequest { internal override ApiUrls ApiUrls => ApiUrlsLookups.NodesInfo; - ////_nodes + /// /_nodes public NodesInfoDescriptor() : base() { } - ////_nodes/{node_id} - ///Optional, accepts null - public NodesInfoDescriptor(NodeIds nodeId) - : base(r => r.Optional("node_id", nodeId)) { } - - ////_nodes/{metric} - ///Optional, accepts null + /// /_nodes/{metric} + /// Optional, accepts null public NodesInfoDescriptor(Metrics metric) : base(r => r.Optional("metric", metric)) { } - ////_nodes/{node_id}/{metric} - ///Optional, accepts null - ///Optional, accepts null + /// /_nodes/{node_id} + /// Optional, accepts null + public NodesInfoDescriptor(NodeIds nodeId) + : base(r => r.Optional("node_id", nodeId)) { } + + /// /_nodes/{node_id}/{metric} + /// Optional, accepts null + /// Optional, accepts null public NodesInfoDescriptor(NodeIds nodeId, Metrics metric) : base(r => r.Optional("node_id", nodeId).Optional("metric", metric)) { } @@ -138,24 +138,24 @@ public NodesInfoDescriptor(NodeIds nodeId, Metrics metric) Metrics INodesInfoRequest.Metric => Self.RouteValues.Get("metric"); NodeIds INodesInfoRequest.NodeId => Self.RouteValues.Get("node_id"); - ///Comma-separated list of metrics you wish returned. Leave empty to return all. + /// Comma-separated list of metrics you wish returned. Leave empty to return all. public NodesInfoDescriptor Metric(Metrics metric) => Assign(metric, (a, v) => a.RouteValues.Optional("metric", v)); - ///Comma-separated list of node IDs or names to limit the returned information; use `_local` to return information from the node you're connecting to, leave empty to get information from all nodes. + /// Comma-separated list of node IDs or names to limit the returned information; use `_local` to return information from the node you're connecting to, leave empty to get information from all nodes. public NodesInfoDescriptor NodeId(NodeIds nodeId) => Assign(nodeId, (a, v) => a.RouteValues.Optional("node_id", v)); // Request parameters - ///Return settings in flat format. + /// Return settings in flat format. public NodesInfoDescriptor FlatSettings(bool? flatsettings = true) => Qs("flat_settings", flatsettings); - ///Operation timeout. + /// Operation timeout. public NodesInfoDescriptor Timeout(Time timeout) => Qs("timeout", timeout); } - ///Descriptor for ReloadSecureSettings https://opensearch.org/docs/latest/api-reference/nodes-apis/nodes-reload-secure/ + /// Descriptor for ReloadSecureSettings https://opensearch.org/docs/latest/api-reference/nodes-apis/nodes-reload-secure/ public partial class ReloadSecureSettingsDescriptor : RequestDescriptorBase< ReloadSecureSettingsDescriptor, @@ -166,28 +166,28 @@ public partial class ReloadSecureSettingsDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.NodesReloadSecureSettings; - ////_nodes/reload_secure_settings + /// /_nodes/reload_secure_settings public ReloadSecureSettingsDescriptor() : base() { } - ////_nodes/{node_id}/reload_secure_settings - ///Optional, accepts null + /// /_nodes/{node_id}/reload_secure_settings + /// Optional, accepts null public ReloadSecureSettingsDescriptor(NodeIds nodeId) : base(r => r.Optional("node_id", nodeId)) { } // values part of the url path NodeIds IReloadSecureSettingsRequest.NodeId => Self.RouteValues.Get("node_id"); - ///Comma-separated list of node IDs to span the reload/reinit call. Should stay empty because reloading usually involves all cluster nodes. + /// Comma-separated list of node IDs to span the reload/reinit call. Should stay empty because reloading usually involves all cluster nodes. public ReloadSecureSettingsDescriptor NodeId(NodeIds nodeId) => Assign(nodeId, (a, v) => a.RouteValues.Optional("node_id", v)); // Request parameters - ///Operation timeout. + /// Operation timeout. public ReloadSecureSettingsDescriptor Timeout(Time timeout) => Qs("timeout", timeout); } - ///Descriptor for Stats https://opensearch.org/docs/latest/api-reference/nodes-apis/nodes-usage/ + /// Descriptor for Stats https://opensearch.org/docs/latest/api-reference/nodes-apis/nodes-usage/ public partial class NodesStatsDescriptor : RequestDescriptorBase< NodesStatsDescriptor, @@ -198,36 +198,36 @@ public partial class NodesStatsDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.NodesStats; - ////_nodes/stats + /// /_nodes/stats public NodesStatsDescriptor() : base() { } - ////_nodes/stats/{metric} - ///Optional, accepts null + /// /_nodes/stats/{metric} + /// Optional, accepts null public NodesStatsDescriptor(Metrics metric) : base(r => r.Optional("metric", metric)) { } - ////_nodes/stats/{metric}/{index_metric} - ///Optional, accepts null - ///Optional, accepts null + /// /_nodes/stats/{metric}/{index_metric} + /// Optional, accepts null + /// Optional, accepts null public NodesStatsDescriptor(Metrics metric, IndexMetrics indexMetric) : base(r => r.Optional("metric", metric).Optional("index_metric", indexMetric)) { } - ////_nodes/{node_id}/stats - ///Optional, accepts null + /// /_nodes/{node_id}/stats + /// Optional, accepts null public NodesStatsDescriptor(NodeIds nodeId) : base(r => r.Optional("node_id", nodeId)) { } - ////_nodes/{node_id}/stats/{metric} - ///Optional, accepts null - ///Optional, accepts null + /// /_nodes/{node_id}/stats/{metric} + /// Optional, accepts null + /// Optional, accepts null public NodesStatsDescriptor(NodeIds nodeId, Metrics metric) : base(r => r.Optional("node_id", nodeId).Optional("metric", metric)) { } - ////_nodes/{node_id}/stats/{metric}/{index_metric} - ///Optional, accepts null - ///Optional, accepts null - ///Optional, accepts null + /// /_nodes/{node_id}/stats/{metric}/{index_metric} + /// Optional, accepts null + /// Optional, accepts null + /// Optional, accepts null public NodesStatsDescriptor(NodeIds nodeId, Metrics metric, IndexMetrics indexMetric) : base( r => @@ -242,61 +242,61 @@ public NodesStatsDescriptor(NodeIds nodeId, Metrics metric, IndexMetrics indexMe Metrics INodesStatsRequest.Metric => Self.RouteValues.Get("metric"); NodeIds INodesStatsRequest.NodeId => Self.RouteValues.Get("node_id"); - ///Limit the information returned for `indices` metric to the specific index metrics. Isn't used if `indices` (or `all`) metric isn't specified. + /// Limit the information returned for `indices` metric to the specific index metrics. Isn't used if `indices` (or `all`) metric isn't specified. public NodesStatsDescriptor IndexMetric(IndexMetrics indexMetric) => Assign(indexMetric, (a, v) => a.RouteValues.Optional("index_metric", v)); - ///Limit the information returned to the specified metrics. + /// Limit the information returned to the specified metrics. public NodesStatsDescriptor Metric(Metrics metric) => Assign(metric, (a, v) => a.RouteValues.Optional("metric", v)); - ///Comma-separated list of node IDs or names to limit the returned information; use `_local` to return information from the node you're connecting to, leave empty to get information from all nodes. + /// Comma-separated list of node IDs or names to limit the returned information; use `_local` to return information from the node you're connecting to, leave empty to get information from all nodes. public NodesStatsDescriptor NodeId(NodeIds nodeId) => Assign(nodeId, (a, v) => a.RouteValues.Optional("node_id", v)); // Request parameters - ///Comma-separated list of fields for `fielddata` and `suggest` index metric (supports wildcards). + /// Comma-separated list of fields for `fielddata` and `suggest` index metric (supports wildcards). public NodesStatsDescriptor CompletionFields(Fields completionfields) => Qs("completion_fields", completionfields); - ///Comma-separated list of fields for `fielddata` and `suggest` index metric (supports wildcards). + /// Comma-separated list of fields for `fielddata` and `suggest` index metric (supports wildcards). public NodesStatsDescriptor CompletionFields(params Expression>[] fields) where T : class => Qs("completion_fields", fields?.Select(e => (Field)e)); - ///Comma-separated list of fields for `fielddata` index metric (supports wildcards). + /// Comma-separated list of fields for `fielddata` index metric (supports wildcards). public NodesStatsDescriptor FielddataFields(Fields fielddatafields) => Qs("fielddata_fields", fielddatafields); - ///Comma-separated list of fields for `fielddata` index metric (supports wildcards). + /// Comma-separated list of fields for `fielddata` index metric (supports wildcards). public NodesStatsDescriptor FielddataFields(params Expression>[] fields) where T : class => Qs("fielddata_fields", fields?.Select(e => (Field)e)); - ///Comma-separated list of fields for `fielddata` and `completion` index metric (supports wildcards). + /// Comma-separated list of fields for `fielddata` and `completion` index metric (supports wildcards). public NodesStatsDescriptor Fields(Fields fields) => Qs("fields", fields); - ///Comma-separated list of fields for `fielddata` and `completion` index metric (supports wildcards). + /// Comma-separated list of fields for `fielddata` and `completion` index metric (supports wildcards). public NodesStatsDescriptor Fields(params Expression>[] fields) where T : class => Qs("fields", fields?.Select(e => (Field)e)); - ///Comma-separated list of search groups for `search` index metric. + /// Comma-separated list of search groups for `search` index metric. public NodesStatsDescriptor Groups(params string[] groups) => Qs("groups", groups); - ///Whether to report the aggregated disk usage of each one of the Lucene index files (only applies if segment stats are requested). + /// Whether to report the aggregated disk usage of each one of the Lucene index files (only applies if segment stats are requested). public NodesStatsDescriptor IncludeSegmentFileSizes(bool? includesegmentfilesizes = true) => Qs("include_segment_file_sizes", includesegmentfilesizes); - ///Return indices stats aggregated at index, node or shard level. + /// Return indices stats aggregated at index, node or shard level. public NodesStatsDescriptor NodesStatLevel(NodesStatLevel? nodesstatlevel) => Qs("level", nodesstatlevel); - ///Operation timeout. + /// Operation timeout. public NodesStatsDescriptor Timeout(Time timeout) => Qs("timeout", timeout); - ///Comma-separated list of document types for the `indexing` index metric. + /// Comma-separated list of document types for the `indexing` index metric. public NodesStatsDescriptor Types(params string[] types) => Qs("types", types); } - ///Descriptor for Usage https://opensearch.org/docs/latest + /// Descriptor for Usage https://opensearch.org/docs/latest public partial class NodesUsageDescriptor : RequestDescriptorBase< NodesUsageDescriptor, @@ -307,23 +307,23 @@ public partial class NodesUsageDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.NodesUsage; - ////_nodes/usage + /// /_nodes/usage public NodesUsageDescriptor() : base() { } - ////_nodes/usage/{metric} - ///Optional, accepts null + /// /_nodes/usage/{metric} + /// Optional, accepts null public NodesUsageDescriptor(Metrics metric) : base(r => r.Optional("metric", metric)) { } - ////_nodes/{node_id}/usage - ///Optional, accepts null + /// /_nodes/{node_id}/usage + /// Optional, accepts null public NodesUsageDescriptor(NodeIds nodeId) : base(r => r.Optional("node_id", nodeId)) { } - ////_nodes/{node_id}/usage/{metric} - ///Optional, accepts null - ///Optional, accepts null + /// /_nodes/{node_id}/usage/{metric} + /// Optional, accepts null + /// Optional, accepts null public NodesUsageDescriptor(NodeIds nodeId, Metrics metric) : base(r => r.Optional("node_id", nodeId).Optional("metric", metric)) { } @@ -331,16 +331,16 @@ public NodesUsageDescriptor(NodeIds nodeId, Metrics metric) Metrics INodesUsageRequest.Metric => Self.RouteValues.Get("metric"); NodeIds INodesUsageRequest.NodeId => Self.RouteValues.Get("node_id"); - ///Limit the information returned to the specified metrics. + /// Limit the information returned to the specified metrics. public NodesUsageDescriptor Metric(Metrics metric) => Assign(metric, (a, v) => a.RouteValues.Optional("metric", v)); - ///Comma-separated list of node IDs or names to limit the returned information; use `_local` to return information from the node you're connecting to, leave empty to get information from all nodes. + /// Comma-separated list of node IDs or names to limit the returned information; use `_local` to return information from the node you're connecting to, leave empty to get information from all nodes. public NodesUsageDescriptor NodeId(NodeIds nodeId) => Assign(nodeId, (a, v) => a.RouteValues.Optional("node_id", v)); // Request parameters - ///Operation timeout. + /// Operation timeout. public NodesUsageDescriptor Timeout(Time timeout) => Qs("timeout", timeout); } } diff --git a/src/OpenSearch.Client/_Generated/Descriptors.Snapshot.cs b/src/OpenSearch.Client/_Generated/Descriptors.Snapshot.cs index ec355de773..22e7c2a7b3 100644 --- a/src/OpenSearch.Client/_Generated/Descriptors.Snapshot.cs +++ b/src/OpenSearch.Client/_Generated/Descriptors.Snapshot.cs @@ -58,7 +58,7 @@ // ReSharper disable RedundantNameQualifier namespace OpenSearch.Client.Specification.SnapshotApi { - ///Descriptor for CleanupRepository https://opensearch.org/docs/latest + /// Descriptor for CleanupRepository https://opensearch.org/docs/latest public partial class CleanupRepositoryDescriptor : RequestDescriptorBase< CleanupRepositoryDescriptor, @@ -69,12 +69,12 @@ public partial class CleanupRepositoryDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.SnapshotCleanupRepository; - ////_snapshot/{repository}/_cleanup - ///this parameter is required + /// /_snapshot/{repository}/_cleanup + /// this parameter is required public CleanupRepositoryDescriptor(Name repository) : base(r => r.Required("repository", repository)) { } - ///Used for serialization purposes, making sure we have a parameterless constructor + /// Used for serialization purposes, making sure we have a parameterless constructor [SerializationConstructor] protected CleanupRepositoryDescriptor() : base() { } @@ -83,23 +83,23 @@ protected CleanupRepositoryDescriptor() Name ICleanupRepositoryRequest.RepositoryName => Self.RouteValues.Get("repository"); // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public CleanupRepositoryDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] public CleanupRepositoryDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); - ///Operation timeout. + /// Operation timeout. public CleanupRepositoryDescriptor Timeout(Time timeout) => Qs("timeout", timeout); } - ///Descriptor for Clone https://opensearch.org/docs/latest + /// Descriptor for Clone https://opensearch.org/docs/latest public partial class CloneSnapshotDescriptor : RequestDescriptorBase< CloneSnapshotDescriptor, @@ -110,10 +110,10 @@ public partial class CloneSnapshotDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.SnapshotClone; - ////_snapshot/{repository}/{snapshot}/_clone/{target_snapshot} - ///this parameter is required - ///this parameter is required - ///this parameter is required + /// /_snapshot/{repository}/{snapshot}/_clone/{target_snapshot} + /// this parameter is required + /// this parameter is required + /// this parameter is required public CloneSnapshotDescriptor(Name repository, Name snapshot, Name targetSnapshot) : base( r => @@ -122,7 +122,7 @@ public CloneSnapshotDescriptor(Name repository, Name snapshot, Name targetSnapsh .Required("target_snapshot", targetSnapshot) ) { } - ///Used for serialization purposes, making sure we have a parameterless constructor + /// Used for serialization purposes, making sure we have a parameterless constructor [SerializationConstructor] protected CloneSnapshotDescriptor() : base() { } @@ -133,12 +133,12 @@ protected CloneSnapshotDescriptor() Name ICloneSnapshotRequest.TargetSnapshot => Self.RouteValues.Get("target_snapshot"); // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public CloneSnapshotDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] @@ -146,20 +146,20 @@ public CloneSnapshotDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); } - ///Descriptor for Snapshot + /// Descriptor for Snapshot public partial class SnapshotDescriptor : RequestDescriptorBase, ISnapshotRequest { internal override ApiUrls ApiUrls => ApiUrlsLookups.SnapshotSnapshot; - ////_snapshot/{repository}/{snapshot} - ///this parameter is required - ///this parameter is required + /// /_snapshot/{repository}/{snapshot} + /// this parameter is required + /// this parameter is required public SnapshotDescriptor(Name repository, Name snapshot) : base(r => r.Required("repository", repository).Required("snapshot", snapshot)) { } - ///Used for serialization purposes, making sure we have a parameterless constructor + /// Used for serialization purposes, making sure we have a parameterless constructor [SerializationConstructor] protected SnapshotDescriptor() : base() { } @@ -169,24 +169,24 @@ protected SnapshotDescriptor() Name ISnapshotRequest.Snapshot => Self.RouteValues.Get("snapshot"); // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public SnapshotDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] public SnapshotDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); - ///Should this request wait until the operation has completed before returning. + /// Should this request wait until the operation has completed before returning. public SnapshotDescriptor WaitForCompletion(bool? waitforcompletion = true) => Qs("wait_for_completion", waitforcompletion); } - ///Descriptor for CreateRepository + /// Descriptor for CreateRepository public partial class CreateRepositoryDescriptor : RequestDescriptorBase< CreateRepositoryDescriptor, @@ -197,12 +197,12 @@ public partial class CreateRepositoryDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.SnapshotCreateRepository; - ////_snapshot/{repository} - ///this parameter is required + /// /_snapshot/{repository} + /// this parameter is required public CreateRepositoryDescriptor(Name repository) : base(r => r.Required("repository", repository)) { } - ///Used for serialization purposes, making sure we have a parameterless constructor + /// Used for serialization purposes, making sure we have a parameterless constructor [SerializationConstructor] protected CreateRepositoryDescriptor() : base() { } @@ -211,26 +211,26 @@ protected CreateRepositoryDescriptor() Name ICreateRepositoryRequest.RepositoryName => Self.RouteValues.Get("repository"); // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public CreateRepositoryDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] public CreateRepositoryDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); - ///Operation timeout. + /// Operation timeout. public CreateRepositoryDescriptor Timeout(Time timeout) => Qs("timeout", timeout); - ///Whether to verify the repository after creation. + /// Whether to verify the repository after creation. public CreateRepositoryDescriptor Verify(bool? verify = true) => Qs("verify", verify); } - ///Descriptor for Delete https://opensearch.org/docs/latest/api-reference/snapshots/delete-snapshot/ + /// Descriptor for Delete https://opensearch.org/docs/latest/api-reference/snapshots/delete-snapshot/ public partial class DeleteSnapshotDescriptor : RequestDescriptorBase< DeleteSnapshotDescriptor, @@ -241,13 +241,13 @@ public partial class DeleteSnapshotDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.SnapshotDelete; - ////_snapshot/{repository}/{snapshot} - ///this parameter is required - ///this parameter is required + /// /_snapshot/{repository}/{snapshot} + /// this parameter is required + /// this parameter is required public DeleteSnapshotDescriptor(Name repository, Name snapshot) : base(r => r.Required("repository", repository).Required("snapshot", snapshot)) { } - ///Used for serialization purposes, making sure we have a parameterless constructor + /// Used for serialization purposes, making sure we have a parameterless constructor [SerializationConstructor] protected DeleteSnapshotDescriptor() : base() { } @@ -257,12 +257,12 @@ protected DeleteSnapshotDescriptor() Name IDeleteSnapshotRequest.Snapshot => Self.RouteValues.Get("snapshot"); // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public DeleteSnapshotDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] @@ -270,7 +270,7 @@ public DeleteSnapshotDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); } - ///Descriptor for DeleteRepository https://opensearch.org/docs/latest/api-reference/snapshots/delete-snapshot-repository/ + /// Descriptor for DeleteRepository https://opensearch.org/docs/latest/api-reference/snapshots/delete-snapshot-repository/ public partial class DeleteRepositoryDescriptor : RequestDescriptorBase< DeleteRepositoryDescriptor, @@ -281,12 +281,12 @@ public partial class DeleteRepositoryDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.SnapshotDeleteRepository; - ////_snapshot/{repository} - ///this parameter is required + /// /_snapshot/{repository} + /// this parameter is required public DeleteRepositoryDescriptor(Names repository) : base(r => r.Required("repository", repository)) { } - ///Used for serialization purposes, making sure we have a parameterless constructor + /// Used for serialization purposes, making sure we have a parameterless constructor [SerializationConstructor] protected DeleteRepositoryDescriptor() : base() { } @@ -295,23 +295,23 @@ protected DeleteRepositoryDescriptor() Names IDeleteRepositoryRequest.RepositoryName => Self.RouteValues.Get("repository"); // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public DeleteRepositoryDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] public DeleteRepositoryDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); - ///Operation timeout. + /// Operation timeout. public DeleteRepositoryDescriptor Timeout(Time timeout) => Qs("timeout", timeout); } - ///Descriptor for Get https://opensearch.org/docs/latest + /// Descriptor for Get https://opensearch.org/docs/latest public partial class GetSnapshotDescriptor : RequestDescriptorBase< GetSnapshotDescriptor, @@ -322,13 +322,13 @@ public partial class GetSnapshotDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.SnapshotGet; - ////_snapshot/{repository}/{snapshot} - ///this parameter is required - ///this parameter is required + /// /_snapshot/{repository}/{snapshot} + /// this parameter is required + /// this parameter is required public GetSnapshotDescriptor(Name repository, Names snapshot) : base(r => r.Required("repository", repository).Required("snapshot", snapshot)) { } - ///Used for serialization purposes, making sure we have a parameterless constructor + /// Used for serialization purposes, making sure we have a parameterless constructor [SerializationConstructor] protected GetSnapshotDescriptor() : base() { } @@ -338,27 +338,27 @@ protected GetSnapshotDescriptor() Names IGetSnapshotRequest.Snapshot => Self.RouteValues.Get("snapshot"); // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public GetSnapshotDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Whether to ignore unavailable snapshots, defaults to false which means a SnapshotMissingException is thrown. + /// Whether to ignore unavailable snapshots, defaults to false which means a SnapshotMissingException is thrown. public GetSnapshotDescriptor IgnoreUnavailable(bool? ignoreunavailable = true) => Qs("ignore_unavailable", ignoreunavailable); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] public GetSnapshotDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); - ///Whether to show verbose snapshot info or only show the basic info found in the repository index blob. + /// Whether to show verbose snapshot info or only show the basic info found in the repository index blob. public GetSnapshotDescriptor Verbose(bool? verbose = true) => Qs("verbose", verbose); } - ///Descriptor for GetRepository https://opensearch.org/docs/latest/api-reference/snapshots/get-snapshot-repository/ + /// Descriptor for GetRepository https://opensearch.org/docs/latest/api-reference/snapshots/get-snapshot-repository/ public partial class GetRepositoryDescriptor : RequestDescriptorBase< GetRepositoryDescriptor, @@ -369,32 +369,32 @@ public partial class GetRepositoryDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.SnapshotGetRepository; - ////_snapshot + /// /_snapshot public GetRepositoryDescriptor() : base() { } - ////_snapshot/{repository} - ///Optional, accepts null + /// /_snapshot/{repository} + /// Optional, accepts null public GetRepositoryDescriptor(Names repository) : base(r => r.Optional("repository", repository)) { } // values part of the url path Names IGetRepositoryRequest.RepositoryName => Self.RouteValues.Get("repository"); - ///Comma-separated list of repository names. + /// Comma-separated list of repository names. public GetRepositoryDescriptor RepositoryName(Names repository) => Assign(repository, (a, v) => a.RouteValues.Optional("repository", v)); // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public GetRepositoryDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Return local information, do not retrieve the state from cluster-manager node. + /// Return local information, do not retrieve the state from cluster-manager node. public GetRepositoryDescriptor Local(bool? local = true) => Qs("local", local); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] @@ -402,20 +402,20 @@ public GetRepositoryDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); } - ///Descriptor for Restore https://opensearch.org/docs/latest/api-reference/snapshots/restore-snapshot/ + /// Descriptor for Restore https://opensearch.org/docs/latest/api-reference/snapshots/restore-snapshot/ public partial class RestoreDescriptor : RequestDescriptorBase, IRestoreRequest { internal override ApiUrls ApiUrls => ApiUrlsLookups.SnapshotRestore; - ////_snapshot/{repository}/{snapshot}/_restore - ///this parameter is required - ///this parameter is required + /// /_snapshot/{repository}/{snapshot}/_restore + /// this parameter is required + /// this parameter is required public RestoreDescriptor(Name repository, Name snapshot) : base(r => r.Required("repository", repository).Required("snapshot", snapshot)) { } - ///Used for serialization purposes, making sure we have a parameterless constructor + /// Used for serialization purposes, making sure we have a parameterless constructor [SerializationConstructor] protected RestoreDescriptor() : base() { } @@ -425,24 +425,24 @@ protected RestoreDescriptor() Name IRestoreRequest.Snapshot => Self.RouteValues.Get("snapshot"); // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public RestoreDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] public RestoreDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); - ///Should this request wait until the operation has completed before returning. + /// Should this request wait until the operation has completed before returning. public RestoreDescriptor WaitForCompletion(bool? waitforcompletion = true) => Qs("wait_for_completion", waitforcompletion); } - ///Descriptor for Status https://opensearch.org/docs/latest/api-reference/snapshots/get-snapshot-status/ + /// Descriptor for Status https://opensearch.org/docs/latest/api-reference/snapshots/get-snapshot-status/ public partial class SnapshotStatusDescriptor : RequestDescriptorBase< SnapshotStatusDescriptor, @@ -453,18 +453,18 @@ public partial class SnapshotStatusDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.SnapshotStatus; - ////_snapshot/_status + /// /_snapshot/_status public SnapshotStatusDescriptor() : base() { } - ////_snapshot/{repository}/_status - ///Optional, accepts null + /// /_snapshot/{repository}/_status + /// Optional, accepts null public SnapshotStatusDescriptor(Name repository) : base(r => r.Optional("repository", repository)) { } - ////_snapshot/{repository}/{snapshot}/_status - ///Optional, accepts null - ///Optional, accepts null + /// /_snapshot/{repository}/{snapshot}/_status + /// Optional, accepts null + /// Optional, accepts null public SnapshotStatusDescriptor(Name repository, Names snapshot) : base(r => r.Optional("repository", repository).Optional("snapshot", snapshot)) { } @@ -472,25 +472,25 @@ public SnapshotStatusDescriptor(Name repository, Names snapshot) Name ISnapshotStatusRequest.RepositoryName => Self.RouteValues.Get("repository"); Names ISnapshotStatusRequest.Snapshot => Self.RouteValues.Get("snapshot"); - ///Repository name. + /// Repository name. public SnapshotStatusDescriptor RepositoryName(Name repository) => Assign(repository, (a, v) => a.RouteValues.Optional("repository", v)); - ///Comma-separated list of snapshot names. + /// Comma-separated list of snapshot names. public SnapshotStatusDescriptor Snapshot(Names snapshot) => Assign(snapshot, (a, v) => a.RouteValues.Optional("snapshot", v)); // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public SnapshotStatusDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Whether to ignore unavailable snapshots, defaults to false which means a SnapshotMissingException is thrown. + /// Whether to ignore unavailable snapshots, defaults to false which means a SnapshotMissingException is thrown. public SnapshotStatusDescriptor IgnoreUnavailable(bool? ignoreunavailable = true) => Qs("ignore_unavailable", ignoreunavailable); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] @@ -498,7 +498,7 @@ public SnapshotStatusDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); } - ///Descriptor for VerifyRepository https://opensearch.org/docs/latest/api-reference/snapshots/verify-snapshot-repository/ + /// Descriptor for VerifyRepository https://opensearch.org/docs/latest/api-reference/snapshots/verify-snapshot-repository/ public partial class VerifyRepositoryDescriptor : RequestDescriptorBase< VerifyRepositoryDescriptor, @@ -509,12 +509,12 @@ public partial class VerifyRepositoryDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.SnapshotVerifyRepository; - ////_snapshot/{repository}/_verify - ///this parameter is required + /// /_snapshot/{repository}/_verify + /// this parameter is required public VerifyRepositoryDescriptor(Name repository) : base(r => r.Required("repository", repository)) { } - ///Used for serialization purposes, making sure we have a parameterless constructor + /// Used for serialization purposes, making sure we have a parameterless constructor [SerializationConstructor] protected VerifyRepositoryDescriptor() : base() { } @@ -523,19 +523,19 @@ protected VerifyRepositoryDescriptor() Name IVerifyRepositoryRequest.RepositoryName => Self.RouteValues.Get("repository"); // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public VerifyRepositoryDescriptor ClusterManagerTimeout(Time clustermanagertimeout) => Qs("cluster_manager_timeout", clustermanagertimeout); - ///Operation timeout for connection to master node. + /// Operation timeout for connection to master node. [Obsolete( "Deprecated as of: 2.0.0, reason: To promote inclusive language, use 'cluster_manager_timeout' instead." )] public VerifyRepositoryDescriptor MasterTimeout(Time mastertimeout) => Qs("master_timeout", mastertimeout); - ///Operation timeout. + /// Operation timeout. public VerifyRepositoryDescriptor Timeout(Time timeout) => Qs("timeout", timeout); } } diff --git a/src/OpenSearch.Client/_Generated/Descriptors.Tasks.cs b/src/OpenSearch.Client/_Generated/Descriptors.Tasks.cs index 2d1ece1f1b..f2b61bf073 100644 --- a/src/OpenSearch.Client/_Generated/Descriptors.Tasks.cs +++ b/src/OpenSearch.Client/_Generated/Descriptors.Tasks.cs @@ -58,7 +58,7 @@ // ReSharper disable RedundantNameQualifier namespace OpenSearch.Client.Specification.TasksApi { - ///Descriptor for Cancel https://opensearch.org/docs/latest/api-reference/tasks/#task-canceling + /// Descriptor for Cancel https://opensearch.org/docs/latest/api-reference/tasks/#task-canceling public partial class CancelTasksDescriptor : RequestDescriptorBase< CancelTasksDescriptor, @@ -69,51 +69,51 @@ public partial class CancelTasksDescriptor { internal override ApiUrls ApiUrls => ApiUrlsLookups.TasksCancel; - ////_tasks/_cancel + /// /_tasks/_cancel public CancelTasksDescriptor() : base() { } - ////_tasks/{task_id}/_cancel - ///Optional, accepts null + /// /_tasks/{task_id}/_cancel + /// Optional, accepts null public CancelTasksDescriptor(TaskId taskId) : base(r => r.Optional("task_id", taskId)) { } // values part of the url path TaskId ICancelTasksRequest.TaskId => Self.RouteValues.Get("task_id"); - ///Cancel the task with specified task id (node_id:task_number). + /// Cancel the task with specified task id (node_id:task_number). public CancelTasksDescriptor TaskId(TaskId taskId) => Assign(taskId, (a, v) => a.RouteValues.Optional("task_id", v)); // Request parameters - ///Comma-separated list of actions that should be cancelled. Leave empty to cancel all. + /// Comma-separated list of actions that should be cancelled. Leave empty to cancel all. public CancelTasksDescriptor Actions(params string[] actions) => Qs("actions", actions); - ///Comma-separated list of node IDs or names to limit the returned information; use `_local` to return information from the node you're connecting to, leave empty to get information from all nodes. + /// Comma-separated list of node IDs or names to limit the returned information; use `_local` to return information from the node you're connecting to, leave empty to get information from all nodes. public CancelTasksDescriptor Nodes(params string[] nodes) => Qs("nodes", nodes); - ///Cancel tasks with specified parent task id (node_id:task_number). Set to -1 to cancel all. + /// Cancel tasks with specified parent task id (node_id:task_number). Set to -1 to cancel all. public CancelTasksDescriptor ParentTaskId(string parenttaskid) => Qs("parent_task_id", parenttaskid); - ///Should this request wait until the operation has completed before returning. + /// Should this request wait until the operation has completed before returning. public CancelTasksDescriptor WaitForCompletion(bool? waitforcompletion = true) => Qs("wait_for_completion", waitforcompletion); } - ///Descriptor for GetTask https://opensearch.org/docs/latest/api-reference/tasks/ + /// Descriptor for GetTask https://opensearch.org/docs/latest/api-reference/tasks/ public partial class GetTaskDescriptor : RequestDescriptorBase, IGetTaskRequest { internal override ApiUrls ApiUrls => ApiUrlsLookups.TasksGetTask; - ////_tasks/{task_id} - ///this parameter is required + /// /_tasks/{task_id} + /// this parameter is required public GetTaskDescriptor(TaskId taskId) : base(r => r.Required("task_id", taskId)) { } - ///Used for serialization purposes, making sure we have a parameterless constructor + /// Used for serialization purposes, making sure we have a parameterless constructor [SerializationConstructor] protected GetTaskDescriptor() : base() { } @@ -122,15 +122,15 @@ protected GetTaskDescriptor() TaskId IGetTaskRequest.TaskId => Self.RouteValues.Get("task_id"); // Request parameters - ///Operation timeout. + /// Operation timeout. public GetTaskDescriptor Timeout(Time timeout) => Qs("timeout", timeout); - ///Should this request wait until the operation has completed before returning. + /// Should this request wait until the operation has completed before returning. public GetTaskDescriptor WaitForCompletion(bool? waitforcompletion = true) => Qs("wait_for_completion", waitforcompletion); } - ///Descriptor for List https://opensearch.org/docs/latest/api-reference/tasks/ + /// Descriptor for List https://opensearch.org/docs/latest/api-reference/tasks/ public partial class ListTasksDescriptor : RequestDescriptorBase, IListTasksRequest @@ -139,26 +139,26 @@ public partial class ListTasksDescriptor // values part of the url path // Request parameters - ///Comma-separated list of actions that should be returned. Leave empty to return all. + /// Comma-separated list of actions that should be returned. Leave empty to return all. public ListTasksDescriptor Actions(params string[] actions) => Qs("actions", actions); - ///Return detailed task information. + /// Return detailed task information. public ListTasksDescriptor Detailed(bool? detailed = true) => Qs("detailed", detailed); - ///Group tasks by nodes or parent/child relationships. + /// Group tasks by nodes or parent/child relationships. public ListTasksDescriptor GroupBy(GroupBy? groupby) => Qs("group_by", groupby); - ///Comma-separated list of node IDs or names to limit the returned information; use `_local` to return information from the node you're connecting to, leave empty to get information from all nodes. + /// Comma-separated list of node IDs or names to limit the returned information; use `_local` to return information from the node you're connecting to, leave empty to get information from all nodes. public ListTasksDescriptor Nodes(params string[] nodes) => Qs("nodes", nodes); - ///Return tasks with specified parent task id (node_id:task_number). Set to -1 to return all. + /// Return tasks with specified parent task id (node_id:task_number). Set to -1 to return all. public ListTasksDescriptor ParentTaskId(string parenttaskid) => Qs("parent_task_id", parenttaskid); - ///Operation timeout. + /// Operation timeout. public ListTasksDescriptor Timeout(Time timeout) => Qs("timeout", timeout); - ///Should this request wait until the operation has completed before returning. + /// Should this request wait until the operation has completed before returning. public ListTasksDescriptor WaitForCompletion(bool? waitforcompletion = true) => Qs("wait_for_completion", waitforcompletion); } diff --git a/src/OpenSearch.Client/_Generated/IOpenSearchClient.cs b/src/OpenSearch.Client/_Generated/IOpenSearchClient.cs index 62f5947fb3..a6fbe1df5b 100644 --- a/src/OpenSearch.Client/_Generated/IOpenSearchClient.cs +++ b/src/OpenSearch.Client/_Generated/IOpenSearchClient.cs @@ -57,27 +57,27 @@ namespace OpenSearch.Client { - /// - ///OpenSearch high level client - /// + /// + /// OpenSearch high level client + /// public partial interface IOpenSearchClient { - ///Cluster APIs + /// Cluster APIs ClusterNamespace Cluster { get; } - ///Dangling Indices APIs + /// Dangling Indices APIs DanglingIndicesNamespace DanglingIndices { get; } - ///Ingest APIs + /// Ingest APIs IngestNamespace Ingest { get; } - ///Nodes APIs + /// Nodes APIs NodesNamespace Nodes { get; } - ///Snapshot APIs + /// Snapshot APIs SnapshotNamespace Snapshot { get; } - ///Tasks APIs + /// Tasks APIs TasksNamespace Tasks { get; } } } diff --git a/src/OpenSearch.Client/_Generated/OpenSearchClient.Cluster.cs b/src/OpenSearch.Client/_Generated/OpenSearchClient.Cluster.cs index 0f551bcb3c..c2ddd0c528 100644 --- a/src/OpenSearch.Client/_Generated/OpenSearchClient.Cluster.cs +++ b/src/OpenSearch.Client/_Generated/OpenSearchClient.Cluster.cs @@ -51,12 +51,12 @@ // ReSharper disable RedundantTypeArgumentsOfMethod namespace OpenSearch.Client.Specification.ClusterApi { - /// + /// /// Cluster APIs. /// Not intended to be instantiated directly. Use the property /// on . - /// - /// + /// + /// public partial class ClusterNamespace : NamespacedClientProxy { internal ClusterNamespace(OpenSearchClient client) diff --git a/src/OpenSearch.Client/_Generated/OpenSearchClient.DanglingIndices.cs b/src/OpenSearch.Client/_Generated/OpenSearchClient.DanglingIndices.cs index 435991460c..8ad5717c77 100644 --- a/src/OpenSearch.Client/_Generated/OpenSearchClient.DanglingIndices.cs +++ b/src/OpenSearch.Client/_Generated/OpenSearchClient.DanglingIndices.cs @@ -51,12 +51,12 @@ // ReSharper disable RedundantTypeArgumentsOfMethod namespace OpenSearch.Client.Specification.DanglingIndicesApi { - /// + /// /// Dangling Indices APIs. /// Not intended to be instantiated directly. Use the property /// on . - /// - /// + /// + /// public partial class DanglingIndicesNamespace : NamespacedClientProxy { internal DanglingIndicesNamespace(OpenSearchClient client) diff --git a/src/OpenSearch.Client/_Generated/OpenSearchClient.Ingest.cs b/src/OpenSearch.Client/_Generated/OpenSearchClient.Ingest.cs index 1a108f219a..fa0ed81142 100644 --- a/src/OpenSearch.Client/_Generated/OpenSearchClient.Ingest.cs +++ b/src/OpenSearch.Client/_Generated/OpenSearchClient.Ingest.cs @@ -51,12 +51,12 @@ // ReSharper disable RedundantTypeArgumentsOfMethod namespace OpenSearch.Client.Specification.IngestApi { - /// + /// /// Ingest APIs. /// Not intended to be instantiated directly. Use the property /// on . - /// - /// + /// + /// public partial class IngestNamespace : NamespacedClientProxy { internal IngestNamespace(OpenSearchClient client) diff --git a/src/OpenSearch.Client/_Generated/OpenSearchClient.Nodes.cs b/src/OpenSearch.Client/_Generated/OpenSearchClient.Nodes.cs index 95faeaae8c..dd56c31a52 100644 --- a/src/OpenSearch.Client/_Generated/OpenSearchClient.Nodes.cs +++ b/src/OpenSearch.Client/_Generated/OpenSearchClient.Nodes.cs @@ -51,12 +51,12 @@ // ReSharper disable RedundantTypeArgumentsOfMethod namespace OpenSearch.Client.Specification.NodesApi { - /// + /// /// Nodes APIs. /// Not intended to be instantiated directly. Use the property /// on . - /// - /// + /// + /// public partial class NodesNamespace : NamespacedClientProxy { internal NodesNamespace(OpenSearchClient client) diff --git a/src/OpenSearch.Client/_Generated/OpenSearchClient.Snapshot.cs b/src/OpenSearch.Client/_Generated/OpenSearchClient.Snapshot.cs index fb4215bd91..b4895616b0 100644 --- a/src/OpenSearch.Client/_Generated/OpenSearchClient.Snapshot.cs +++ b/src/OpenSearch.Client/_Generated/OpenSearchClient.Snapshot.cs @@ -51,12 +51,12 @@ // ReSharper disable RedundantTypeArgumentsOfMethod namespace OpenSearch.Client.Specification.SnapshotApi { - /// + /// /// Snapshot APIs. /// Not intended to be instantiated directly. Use the property /// on . - /// - /// + /// + /// public partial class SnapshotNamespace : NamespacedClientProxy { internal SnapshotNamespace(OpenSearchClient client) diff --git a/src/OpenSearch.Client/_Generated/OpenSearchClient.Tasks.cs b/src/OpenSearch.Client/_Generated/OpenSearchClient.Tasks.cs index afd5018715..e1b00503d2 100644 --- a/src/OpenSearch.Client/_Generated/OpenSearchClient.Tasks.cs +++ b/src/OpenSearch.Client/_Generated/OpenSearchClient.Tasks.cs @@ -51,12 +51,12 @@ // ReSharper disable RedundantTypeArgumentsOfMethod namespace OpenSearch.Client.Specification.TasksApi { - /// + /// /// Tasks APIs. /// Not intended to be instantiated directly. Use the property /// on . - /// - /// + /// + /// public partial class TasksNamespace : NamespacedClientProxy { internal TasksNamespace(OpenSearchClient client) diff --git a/src/OpenSearch.Client/_Generated/OpenSearchClient.cs b/src/OpenSearch.Client/_Generated/OpenSearchClient.cs index e1947d5d8f..fa5f242a9e 100644 --- a/src/OpenSearch.Client/_Generated/OpenSearchClient.cs +++ b/src/OpenSearch.Client/_Generated/OpenSearchClient.cs @@ -56,27 +56,27 @@ // ReSharper disable RedundantTypeArgumentsOfMethod namespace OpenSearch.Client { - /// - ///OpenSearch high level client - /// + /// + /// OpenSearch high level client + /// public partial class OpenSearchClient : IOpenSearchClient { - ///Cluster APIs + /// Cluster APIs public ClusterNamespace Cluster { get; private set; } - ///Dangling Indices APIs + /// Dangling Indices APIs public DanglingIndicesNamespace DanglingIndices { get; private set; } - ///Ingest APIs + /// Ingest APIs public IngestNamespace Ingest { get; private set; } - ///Nodes APIs + /// Nodes APIs public NodesNamespace Nodes { get; private set; } - ///Snapshot APIs + /// Snapshot APIs public SnapshotNamespace Snapshot { get; private set; } - ///Tasks APIs + /// Tasks APIs public TasksNamespace Tasks { get; private set; } partial void SetupGeneratedNamespaces() diff --git a/src/OpenSearch.Client/_Generated/Requests.Cluster.cs b/src/OpenSearch.Client/_Generated/Requests.Cluster.cs index cbf2b0ea8a..fe5fb86e91 100644 --- a/src/OpenSearch.Client/_Generated/Requests.Cluster.cs +++ b/src/OpenSearch.Client/_Generated/Requests.Cluster.cs @@ -62,7 +62,7 @@ namespace OpenSearch.Client.Specification.ClusterApi public partial interface IClusterAllocationExplainRequest : IRequest { } - ///Request for AllocationExplain https://opensearch.org/docs/latest/api-reference/cluster-api/cluster-allocation/ + /// Request for AllocationExplain https://opensearch.org/docs/latest/api-reference/cluster-api/cluster-allocation/ public partial class ClusterAllocationExplainRequest : PlainRequestBase, IClusterAllocationExplainRequest @@ -73,14 +73,14 @@ public partial class ClusterAllocationExplainRequest // values part of the url path // Request parameters - ///Return information about disk usage and shard sizes. + /// Return information about disk usage and shard sizes. public bool? IncludeDiskInfo { get => Q("include_disk_info"); set => Q("include_disk_info", value); } - ///Return 'YES' decisions in explanation. + /// Return 'YES' decisions in explanation. public bool? IncludeYesDecisions { get => Q("include_yes_decisions"); @@ -92,7 +92,7 @@ public bool? IncludeYesDecisions public partial interface IDeleteVotingConfigExclusionsRequest : IRequest { } - ///Request for DeleteVotingConfigExclusions https://opensearch.org/docs/latest + /// Request for DeleteVotingConfigExclusions https://opensearch.org/docs/latest public partial class DeleteVotingConfigExclusionsRequest : PlainRequestBase, IDeleteVotingConfigExclusionsRequest @@ -103,7 +103,7 @@ public partial class DeleteVotingConfigExclusionsRequest // values part of the url path // Request parameters - ///Specifies whether to wait for all excluded nodes to be removed from the cluster before clearing the voting configuration exclusions list. + /// Specifies whether to wait for all excluded nodes to be removed from the cluster before clearing the voting configuration exclusions list. public bool? WaitForRemoval { get => Q("wait_for_removal"); @@ -115,7 +115,7 @@ public bool? WaitForRemoval public partial interface IClusterGetSettingsRequest : IRequest { } - ///Request for GetSettings https://opensearch.org/docs/latest/api-reference/cluster-api/cluster-settings/ + /// Request for GetSettings https://opensearch.org/docs/latest/api-reference/cluster-api/cluster-settings/ public partial class ClusterGetSettingsRequest : PlainRequestBase, IClusterGetSettingsRequest @@ -126,29 +126,29 @@ public partial class ClusterGetSettingsRequest // values part of the url path // Request parameters - ///Operation timeout for connection to cluster-manager node. - ///Supported by OpenSearch servers of version 2.0.0 or greater. + /// Operation timeout for connection to cluster-manager node. + /// Supported by OpenSearch servers of version 2.0.0 or greater. public Time ClusterManagerTimeout { get => Q