mirror of
https://github.com/eliasstepanik/IonosDDNSUpdater.git
synced 2026-01-11 19:48:26 +00:00
118 lines
6.4 KiB
C#
118 lines
6.4 KiB
C#
using DDNSUpdater.APIs.Ionos.ApiClient.Models;
|
|
using DDNSUpdater.APIs.Ionos.ApiClient.V1.Zones.Item;
|
|
using Microsoft.Kiota.Abstractions;
|
|
using Microsoft.Kiota.Abstractions.Serialization;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.IO;
|
|
using System.Linq;
|
|
using System.Threading;
|
|
using System.Threading.Tasks;
|
|
namespace DDNSUpdater.APIs.Ionos.ApiClient.V1.Zones {
|
|
/// <summary>
|
|
/// Builds and executes requests for operations under \v1\zones
|
|
/// </summary>
|
|
public class ZonesRequestBuilder {
|
|
/// <summary>Path parameters for the request</summary>
|
|
private Dictionary<string, object> PathParameters { get; set; }
|
|
/// <summary>The request adapter to use to execute the requests.</summary>
|
|
private IRequestAdapter RequestAdapter { get; set; }
|
|
/// <summary>Url template to use to build the URL for the current request builder</summary>
|
|
private string UrlTemplate { get; set; }
|
|
/// <summary>Gets an item from the DDNSUpdater.APIs.Ionos.ApiClient.v1.zones.item collection</summary>
|
|
public WithZoneItemRequestBuilder this[string position] { get {
|
|
var urlTplParams = new Dictionary<string, object>(PathParameters);
|
|
if (!string.IsNullOrWhiteSpace(position)) urlTplParams.Add("zoneId", position);
|
|
return new WithZoneItemRequestBuilder(urlTplParams, RequestAdapter);
|
|
} }
|
|
/// <summary>
|
|
/// Instantiates a new ZonesRequestBuilder and sets the default values.
|
|
/// </summary>
|
|
/// <param name="pathParameters">Path parameters for the request</param>
|
|
/// <param name="requestAdapter">The request adapter to use to execute the requests.</param>
|
|
public ZonesRequestBuilder(Dictionary<string, object> pathParameters, IRequestAdapter requestAdapter) {
|
|
_ = pathParameters ?? throw new ArgumentNullException(nameof(pathParameters));
|
|
_ = requestAdapter ?? throw new ArgumentNullException(nameof(requestAdapter));
|
|
UrlTemplate = "{+baseurl}/v1/zones";
|
|
var urlTplParams = new Dictionary<string, object>(pathParameters);
|
|
PathParameters = urlTplParams;
|
|
RequestAdapter = requestAdapter;
|
|
}
|
|
/// <summary>
|
|
/// Instantiates a new ZonesRequestBuilder and sets the default values.
|
|
/// </summary>
|
|
/// <param name="rawUrl">The raw URL to use for the request builder.</param>
|
|
/// <param name="requestAdapter">The request adapter to use to execute the requests.</param>
|
|
public ZonesRequestBuilder(string rawUrl, IRequestAdapter requestAdapter) {
|
|
if(string.IsNullOrEmpty(rawUrl)) throw new ArgumentNullException(nameof(rawUrl));
|
|
_ = requestAdapter ?? throw new ArgumentNullException(nameof(requestAdapter));
|
|
UrlTemplate = "{+baseurl}/v1/zones";
|
|
var urlTplParams = new Dictionary<string, object>();
|
|
if (!string.IsNullOrWhiteSpace(rawUrl)) urlTplParams.Add("request-raw-url", rawUrl);
|
|
PathParameters = urlTplParams;
|
|
RequestAdapter = requestAdapter;
|
|
}
|
|
/// <summary>
|
|
/// Returns list of customer zones.
|
|
/// </summary>
|
|
/// <param name="cancellationToken">Cancellation token to use when cancelling requests</param>
|
|
/// <param name="requestConfiguration">Configuration for the request such as headers, query parameters, and middleware options.</param>
|
|
#if NETSTANDARD2_1_OR_GREATER || NETCOREAPP3_1_OR_GREATER
|
|
#nullable enable
|
|
public async Task<List<Zone>?> GetAsync(Action<ZonesRequestBuilderGetRequestConfiguration>? requestConfiguration = default, CancellationToken cancellationToken = default) {
|
|
#nullable restore
|
|
#else
|
|
public async Task<List<Zone>> GetAsync(Action<ZonesRequestBuilderGetRequestConfiguration> requestConfiguration = default, CancellationToken cancellationToken = default) {
|
|
#endif
|
|
var requestInfo = ToGetRequestInformation(requestConfiguration);
|
|
var errorMapping = new Dictionary<string, ParsableFactory<IParsable>> {
|
|
{"401", Error.CreateFromDiscriminatorValue},
|
|
{"500", Error.CreateFromDiscriminatorValue},
|
|
};
|
|
var collectionResult = await RequestAdapter.SendCollectionAsync<Zone>(requestInfo, Zone.CreateFromDiscriminatorValue, errorMapping, cancellationToken);
|
|
return collectionResult?.ToList();
|
|
}
|
|
/// <summary>
|
|
/// Returns list of customer zones.
|
|
/// </summary>
|
|
/// <param name="requestConfiguration">Configuration for the request such as headers, query parameters, and middleware options.</param>
|
|
#if NETSTANDARD2_1_OR_GREATER || NETCOREAPP3_1_OR_GREATER
|
|
#nullable enable
|
|
public RequestInformation ToGetRequestInformation(Action<ZonesRequestBuilderGetRequestConfiguration>? requestConfiguration = default) {
|
|
#nullable restore
|
|
#else
|
|
public RequestInformation ToGetRequestInformation(Action<ZonesRequestBuilderGetRequestConfiguration> requestConfiguration = default) {
|
|
#endif
|
|
var requestInfo = new RequestInformation {
|
|
HttpMethod = Method.GET,
|
|
UrlTemplate = UrlTemplate,
|
|
PathParameters = PathParameters,
|
|
};
|
|
requestInfo.Headers.Add("Accept", "application/json");
|
|
if (requestConfiguration != null) {
|
|
var requestConfig = new ZonesRequestBuilderGetRequestConfiguration();
|
|
requestConfiguration.Invoke(requestConfig);
|
|
requestInfo.AddRequestOptions(requestConfig.Options);
|
|
requestInfo.AddHeaders(requestConfig.Headers);
|
|
}
|
|
return requestInfo;
|
|
}
|
|
/// <summary>
|
|
/// Configuration for the request such as headers, query parameters, and middleware options.
|
|
/// </summary>
|
|
public class ZonesRequestBuilderGetRequestConfiguration {
|
|
/// <summary>Request headers</summary>
|
|
public RequestHeaders Headers { get; set; }
|
|
/// <summary>Request options</summary>
|
|
public IList<IRequestOption> Options { get; set; }
|
|
/// <summary>
|
|
/// Instantiates a new zonesRequestBuilderGetRequestConfiguration and sets the default values.
|
|
/// </summary>
|
|
public ZonesRequestBuilderGetRequestConfiguration() {
|
|
Options = new List<IRequestOption>();
|
|
Headers = new RequestHeaders();
|
|
}
|
|
}
|
|
}
|
|
}
|