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// VirtualApplianceSkusClient is the network Client 29type VirtualApplianceSkusClient struct { 30 BaseClient 31} 32 33// NewVirtualApplianceSkusClient creates an instance of the VirtualApplianceSkusClient client. 34func NewVirtualApplianceSkusClient(subscriptionID string) VirtualApplianceSkusClient { 35 return NewVirtualApplianceSkusClientWithBaseURI(DefaultBaseURI, subscriptionID) 36} 37 38// NewVirtualApplianceSkusClientWithBaseURI creates an instance of the VirtualApplianceSkusClient client using a custom 39// endpoint. Use this when interacting with an Azure cloud that uses a non-standard base URI (sovereign clouds, Azure 40// stack). 41func NewVirtualApplianceSkusClientWithBaseURI(baseURI string, subscriptionID string) VirtualApplianceSkusClient { 42 return VirtualApplianceSkusClient{NewWithBaseURI(baseURI, subscriptionID)} 43} 44 45// Get retrieves a single available sku for network virtual appliance. 46// Parameters: 47// skuName - name of the Sku. 48func (client VirtualApplianceSkusClient) Get(ctx context.Context, skuName string) (result VirtualApplianceSku, err error) { 49 if tracing.IsEnabled() { 50 ctx = tracing.StartSpan(ctx, fqdn+"/VirtualApplianceSkusClient.Get") 51 defer func() { 52 sc := -1 53 if result.Response.Response != nil { 54 sc = result.Response.Response.StatusCode 55 } 56 tracing.EndSpan(ctx, sc, err) 57 }() 58 } 59 req, err := client.GetPreparer(ctx, skuName) 60 if err != nil { 61 err = autorest.NewErrorWithError(err, "network.VirtualApplianceSkusClient", "Get", nil, "Failure preparing request") 62 return 63 } 64 65 resp, err := client.GetSender(req) 66 if err != nil { 67 result.Response = autorest.Response{Response: resp} 68 err = autorest.NewErrorWithError(err, "network.VirtualApplianceSkusClient", "Get", resp, "Failure sending request") 69 return 70 } 71 72 result, err = client.GetResponder(resp) 73 if err != nil { 74 err = autorest.NewErrorWithError(err, "network.VirtualApplianceSkusClient", "Get", resp, "Failure responding to request") 75 } 76 77 return 78} 79 80// GetPreparer prepares the Get request. 81func (client VirtualApplianceSkusClient) GetPreparer(ctx context.Context, skuName string) (*http.Request, error) { 82 pathParameters := map[string]interface{}{ 83 "skuName": autorest.Encode("path", skuName), 84 "subscriptionId": autorest.Encode("path", client.SubscriptionID), 85 } 86 87 const APIVersion = "2020-05-01" 88 queryParameters := map[string]interface{}{ 89 "api-version": APIVersion, 90 } 91 92 preparer := autorest.CreatePreparer( 93 autorest.AsGet(), 94 autorest.WithBaseURL(client.BaseURI), 95 autorest.WithPathParameters("/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkVirtualApplianceSkus/{skuName}", pathParameters), 96 autorest.WithQueryParameters(queryParameters)) 97 return preparer.Prepare((&http.Request{}).WithContext(ctx)) 98} 99 100// GetSender sends the Get request. The method will close the 101// http.Response Body if it receives an error. 102func (client VirtualApplianceSkusClient) GetSender(req *http.Request) (*http.Response, error) { 103 return client.Send(req, azure.DoRetryWithRegistration(client.Client)) 104} 105 106// GetResponder handles the response to the Get request. The method always 107// closes the http.Response Body. 108func (client VirtualApplianceSkusClient) GetResponder(resp *http.Response) (result VirtualApplianceSku, err error) { 109 err = autorest.Respond( 110 resp, 111 client.ByInspecting(), 112 azure.WithErrorUnlessStatusCode(http.StatusOK), 113 autorest.ByUnmarshallingJSON(&result), 114 autorest.ByClosing()) 115 result.Response = autorest.Response{Response: resp} 116 return 117} 118 119// List list all SKUs available for a virtual appliance. 120func (client VirtualApplianceSkusClient) List(ctx context.Context) (result VirtualApplianceSkuListResultPage, err error) { 121 if tracing.IsEnabled() { 122 ctx = tracing.StartSpan(ctx, fqdn+"/VirtualApplianceSkusClient.List") 123 defer func() { 124 sc := -1 125 if result.vaslr.Response.Response != nil { 126 sc = result.vaslr.Response.Response.StatusCode 127 } 128 tracing.EndSpan(ctx, sc, err) 129 }() 130 } 131 result.fn = client.listNextResults 132 req, err := client.ListPreparer(ctx) 133 if err != nil { 134 err = autorest.NewErrorWithError(err, "network.VirtualApplianceSkusClient", "List", nil, "Failure preparing request") 135 return 136 } 137 138 resp, err := client.ListSender(req) 139 if err != nil { 140 result.vaslr.Response = autorest.Response{Response: resp} 141 err = autorest.NewErrorWithError(err, "network.VirtualApplianceSkusClient", "List", resp, "Failure sending request") 142 return 143 } 144 145 result.vaslr, err = client.ListResponder(resp) 146 if err != nil { 147 err = autorest.NewErrorWithError(err, "network.VirtualApplianceSkusClient", "List", resp, "Failure responding to request") 148 } 149 150 return 151} 152 153// ListPreparer prepares the List request. 154func (client VirtualApplianceSkusClient) ListPreparer(ctx context.Context) (*http.Request, error) { 155 pathParameters := map[string]interface{}{ 156 "subscriptionId": autorest.Encode("path", client.SubscriptionID), 157 } 158 159 const APIVersion = "2020-05-01" 160 queryParameters := map[string]interface{}{ 161 "api-version": APIVersion, 162 } 163 164 preparer := autorest.CreatePreparer( 165 autorest.AsGet(), 166 autorest.WithBaseURL(client.BaseURI), 167 autorest.WithPathParameters("/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkVirtualApplianceSkus", pathParameters), 168 autorest.WithQueryParameters(queryParameters)) 169 return preparer.Prepare((&http.Request{}).WithContext(ctx)) 170} 171 172// ListSender sends the List request. The method will close the 173// http.Response Body if it receives an error. 174func (client VirtualApplianceSkusClient) ListSender(req *http.Request) (*http.Response, error) { 175 return client.Send(req, azure.DoRetryWithRegistration(client.Client)) 176} 177 178// ListResponder handles the response to the List request. The method always 179// closes the http.Response Body. 180func (client VirtualApplianceSkusClient) ListResponder(resp *http.Response) (result VirtualApplianceSkuListResult, err error) { 181 err = autorest.Respond( 182 resp, 183 client.ByInspecting(), 184 azure.WithErrorUnlessStatusCode(http.StatusOK), 185 autorest.ByUnmarshallingJSON(&result), 186 autorest.ByClosing()) 187 result.Response = autorest.Response{Response: resp} 188 return 189} 190 191// listNextResults retrieves the next set of results, if any. 192func (client VirtualApplianceSkusClient) listNextResults(ctx context.Context, lastResults VirtualApplianceSkuListResult) (result VirtualApplianceSkuListResult, err error) { 193 req, err := lastResults.virtualApplianceSkuListResultPreparer(ctx) 194 if err != nil { 195 return result, autorest.NewErrorWithError(err, "network.VirtualApplianceSkusClient", "listNextResults", nil, "Failure preparing next results request") 196 } 197 if req == nil { 198 return 199 } 200 resp, err := client.ListSender(req) 201 if err != nil { 202 result.Response = autorest.Response{Response: resp} 203 return result, autorest.NewErrorWithError(err, "network.VirtualApplianceSkusClient", "listNextResults", resp, "Failure sending next results request") 204 } 205 result, err = client.ListResponder(resp) 206 if err != nil { 207 err = autorest.NewErrorWithError(err, "network.VirtualApplianceSkusClient", "listNextResults", resp, "Failure responding to next results request") 208 } 209 return 210} 211 212// ListComplete enumerates all values, automatically crossing page boundaries as required. 213func (client VirtualApplianceSkusClient) ListComplete(ctx context.Context) (result VirtualApplianceSkuListResultIterator, err error) { 214 if tracing.IsEnabled() { 215 ctx = tracing.StartSpan(ctx, fqdn+"/VirtualApplianceSkusClient.List") 216 defer func() { 217 sc := -1 218 if result.Response().Response.Response != nil { 219 sc = result.page.Response().Response.Response.StatusCode 220 } 221 tracing.EndSpan(ctx, sc, err) 222 }() 223 } 224 result.page, err = client.List(ctx) 225 return 226} 227