1package network
2
3// Copyright (c) Microsoft and contributors.  All rights reserved.
4//
5// Licensed under the Apache License, Version 2.0 (the "License");
6// you may not use this file except in compliance with the License.
7// You may obtain a copy of the License at
8// http://www.apache.org/licenses/LICENSE-2.0
9//
10// Unless required by applicable law or agreed to in writing, software
11// distributed under the License is distributed on an "AS IS" BASIS,
12// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13//
14// See the License for the specific language governing permissions and
15// limitations under the License.
16//
17// Code generated by Microsoft (R) AutoRest Code Generator.
18// Changes may cause incorrect behavior and will be lost if the code is regenerated.
19
20import (
21	"context"
22	"github.com/Azure/go-autorest/autorest"
23	"github.com/Azure/go-autorest/autorest/azure"
24	"github.com/Azure/go-autorest/tracing"
25	"net/http"
26)
27
28// AvailableServiceAliasesClient is the network Client
29type AvailableServiceAliasesClient struct {
30	BaseClient
31}
32
33// NewAvailableServiceAliasesClient creates an instance of the AvailableServiceAliasesClient client.
34func NewAvailableServiceAliasesClient(subscriptionID string) AvailableServiceAliasesClient {
35	return NewAvailableServiceAliasesClientWithBaseURI(DefaultBaseURI, subscriptionID)
36}
37
38// NewAvailableServiceAliasesClientWithBaseURI creates an instance of the AvailableServiceAliasesClient client using a
39// custom endpoint.  Use this when interacting with an Azure cloud that uses a non-standard base URI (sovereign clouds,
40// Azure stack).
41func NewAvailableServiceAliasesClientWithBaseURI(baseURI string, subscriptionID string) AvailableServiceAliasesClient {
42	return AvailableServiceAliasesClient{NewWithBaseURI(baseURI, subscriptionID)}
43}
44
45// List gets all available service aliases for this subscription in this region.
46// Parameters:
47// location - the location.
48func (client AvailableServiceAliasesClient) List(ctx context.Context, location string) (result AvailableServiceAliasesResultPage, err error) {
49	if tracing.IsEnabled() {
50		ctx = tracing.StartSpan(ctx, fqdn+"/AvailableServiceAliasesClient.List")
51		defer func() {
52			sc := -1
53			if result.asar.Response.Response != nil {
54				sc = result.asar.Response.Response.StatusCode
55			}
56			tracing.EndSpan(ctx, sc, err)
57		}()
58	}
59	result.fn = client.listNextResults
60	req, err := client.ListPreparer(ctx, location)
61	if err != nil {
62		err = autorest.NewErrorWithError(err, "network.AvailableServiceAliasesClient", "List", nil, "Failure preparing request")
63		return
64	}
65
66	resp, err := client.ListSender(req)
67	if err != nil {
68		result.asar.Response = autorest.Response{Response: resp}
69		err = autorest.NewErrorWithError(err, "network.AvailableServiceAliasesClient", "List", resp, "Failure sending request")
70		return
71	}
72
73	result.asar, err = client.ListResponder(resp)
74	if err != nil {
75		err = autorest.NewErrorWithError(err, "network.AvailableServiceAliasesClient", "List", resp, "Failure responding to request")
76	}
77
78	return
79}
80
81// ListPreparer prepares the List request.
82func (client AvailableServiceAliasesClient) ListPreparer(ctx context.Context, location string) (*http.Request, error) {
83	pathParameters := map[string]interface{}{
84		"location":       autorest.Encode("path", location),
85		"subscriptionId": autorest.Encode("path", client.SubscriptionID),
86	}
87
88	const APIVersion = "2019-11-01"
89	queryParameters := map[string]interface{}{
90		"api-version": APIVersion,
91	}
92
93	preparer := autorest.CreatePreparer(
94		autorest.AsGet(),
95		autorest.WithBaseURL(client.BaseURI),
96		autorest.WithPathParameters("/subscriptions/{subscriptionId}/providers/Microsoft.Network/locations/{location}/availableServiceAliases", pathParameters),
97		autorest.WithQueryParameters(queryParameters))
98	return preparer.Prepare((&http.Request{}).WithContext(ctx))
99}
100
101// ListSender sends the List request. The method will close the
102// http.Response Body if it receives an error.
103func (client AvailableServiceAliasesClient) ListSender(req *http.Request) (*http.Response, error) {
104	return client.Send(req, azure.DoRetryWithRegistration(client.Client))
105}
106
107// ListResponder handles the response to the List request. The method always
108// closes the http.Response Body.
109func (client AvailableServiceAliasesClient) ListResponder(resp *http.Response) (result AvailableServiceAliasesResult, err error) {
110	err = autorest.Respond(
111		resp,
112		client.ByInspecting(),
113		azure.WithErrorUnlessStatusCode(http.StatusOK),
114		autorest.ByUnmarshallingJSON(&result),
115		autorest.ByClosing())
116	result.Response = autorest.Response{Response: resp}
117	return
118}
119
120// listNextResults retrieves the next set of results, if any.
121func (client AvailableServiceAliasesClient) listNextResults(ctx context.Context, lastResults AvailableServiceAliasesResult) (result AvailableServiceAliasesResult, err error) {
122	req, err := lastResults.availableServiceAliasesResultPreparer(ctx)
123	if err != nil {
124		return result, autorest.NewErrorWithError(err, "network.AvailableServiceAliasesClient", "listNextResults", nil, "Failure preparing next results request")
125	}
126	if req == nil {
127		return
128	}
129	resp, err := client.ListSender(req)
130	if err != nil {
131		result.Response = autorest.Response{Response: resp}
132		return result, autorest.NewErrorWithError(err, "network.AvailableServiceAliasesClient", "listNextResults", resp, "Failure sending next results request")
133	}
134	result, err = client.ListResponder(resp)
135	if err != nil {
136		err = autorest.NewErrorWithError(err, "network.AvailableServiceAliasesClient", "listNextResults", resp, "Failure responding to next results request")
137	}
138	return
139}
140
141// ListComplete enumerates all values, automatically crossing page boundaries as required.
142func (client AvailableServiceAliasesClient) ListComplete(ctx context.Context, location string) (result AvailableServiceAliasesResultIterator, err error) {
143	if tracing.IsEnabled() {
144		ctx = tracing.StartSpan(ctx, fqdn+"/AvailableServiceAliasesClient.List")
145		defer func() {
146			sc := -1
147			if result.Response().Response.Response != nil {
148				sc = result.page.Response().Response.Response.StatusCode
149			}
150			tracing.EndSpan(ctx, sc, err)
151		}()
152	}
153	result.page, err = client.List(ctx, location)
154	return
155}
156
157// ListByResourceGroup gets all available service aliases for this resource group in this region.
158// Parameters:
159// resourceGroupName - the name of the resource group.
160// location - the location.
161func (client AvailableServiceAliasesClient) ListByResourceGroup(ctx context.Context, resourceGroupName string, location string) (result AvailableServiceAliasesResultPage, err error) {
162	if tracing.IsEnabled() {
163		ctx = tracing.StartSpan(ctx, fqdn+"/AvailableServiceAliasesClient.ListByResourceGroup")
164		defer func() {
165			sc := -1
166			if result.asar.Response.Response != nil {
167				sc = result.asar.Response.Response.StatusCode
168			}
169			tracing.EndSpan(ctx, sc, err)
170		}()
171	}
172	result.fn = client.listByResourceGroupNextResults
173	req, err := client.ListByResourceGroupPreparer(ctx, resourceGroupName, location)
174	if err != nil {
175		err = autorest.NewErrorWithError(err, "network.AvailableServiceAliasesClient", "ListByResourceGroup", nil, "Failure preparing request")
176		return
177	}
178
179	resp, err := client.ListByResourceGroupSender(req)
180	if err != nil {
181		result.asar.Response = autorest.Response{Response: resp}
182		err = autorest.NewErrorWithError(err, "network.AvailableServiceAliasesClient", "ListByResourceGroup", resp, "Failure sending request")
183		return
184	}
185
186	result.asar, err = client.ListByResourceGroupResponder(resp)
187	if err != nil {
188		err = autorest.NewErrorWithError(err, "network.AvailableServiceAliasesClient", "ListByResourceGroup", resp, "Failure responding to request")
189	}
190
191	return
192}
193
194// ListByResourceGroupPreparer prepares the ListByResourceGroup request.
195func (client AvailableServiceAliasesClient) ListByResourceGroupPreparer(ctx context.Context, resourceGroupName string, location string) (*http.Request, error) {
196	pathParameters := map[string]interface{}{
197		"location":          autorest.Encode("path", location),
198		"resourceGroupName": autorest.Encode("path", resourceGroupName),
199		"subscriptionId":    autorest.Encode("path", client.SubscriptionID),
200	}
201
202	const APIVersion = "2019-11-01"
203	queryParameters := map[string]interface{}{
204		"api-version": APIVersion,
205	}
206
207	preparer := autorest.CreatePreparer(
208		autorest.AsGet(),
209		autorest.WithBaseURL(client.BaseURI),
210		autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/locations/{location}/availableServiceAliases", pathParameters),
211		autorest.WithQueryParameters(queryParameters))
212	return preparer.Prepare((&http.Request{}).WithContext(ctx))
213}
214
215// ListByResourceGroupSender sends the ListByResourceGroup request. The method will close the
216// http.Response Body if it receives an error.
217func (client AvailableServiceAliasesClient) ListByResourceGroupSender(req *http.Request) (*http.Response, error) {
218	return client.Send(req, azure.DoRetryWithRegistration(client.Client))
219}
220
221// ListByResourceGroupResponder handles the response to the ListByResourceGroup request. The method always
222// closes the http.Response Body.
223func (client AvailableServiceAliasesClient) ListByResourceGroupResponder(resp *http.Response) (result AvailableServiceAliasesResult, err error) {
224	err = autorest.Respond(
225		resp,
226		client.ByInspecting(),
227		azure.WithErrorUnlessStatusCode(http.StatusOK),
228		autorest.ByUnmarshallingJSON(&result),
229		autorest.ByClosing())
230	result.Response = autorest.Response{Response: resp}
231	return
232}
233
234// listByResourceGroupNextResults retrieves the next set of results, if any.
235func (client AvailableServiceAliasesClient) listByResourceGroupNextResults(ctx context.Context, lastResults AvailableServiceAliasesResult) (result AvailableServiceAliasesResult, err error) {
236	req, err := lastResults.availableServiceAliasesResultPreparer(ctx)
237	if err != nil {
238		return result, autorest.NewErrorWithError(err, "network.AvailableServiceAliasesClient", "listByResourceGroupNextResults", nil, "Failure preparing next results request")
239	}
240	if req == nil {
241		return
242	}
243	resp, err := client.ListByResourceGroupSender(req)
244	if err != nil {
245		result.Response = autorest.Response{Response: resp}
246		return result, autorest.NewErrorWithError(err, "network.AvailableServiceAliasesClient", "listByResourceGroupNextResults", resp, "Failure sending next results request")
247	}
248	result, err = client.ListByResourceGroupResponder(resp)
249	if err != nil {
250		err = autorest.NewErrorWithError(err, "network.AvailableServiceAliasesClient", "listByResourceGroupNextResults", resp, "Failure responding to next results request")
251	}
252	return
253}
254
255// ListByResourceGroupComplete enumerates all values, automatically crossing page boundaries as required.
256func (client AvailableServiceAliasesClient) ListByResourceGroupComplete(ctx context.Context, resourceGroupName string, location string) (result AvailableServiceAliasesResultIterator, err error) {
257	if tracing.IsEnabled() {
258		ctx = tracing.StartSpan(ctx, fqdn+"/AvailableServiceAliasesClient.ListByResourceGroup")
259		defer func() {
260			sc := -1
261			if result.Response().Response.Response != nil {
262				sc = result.page.Response().Response.Response.StatusCode
263			}
264			tracing.EndSpan(ctx, sc, err)
265		}()
266	}
267	result.page, err = client.ListByResourceGroup(ctx, resourceGroupName, location)
268	return
269}
270