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