1// +build go1.13 2 3// Copyright (c) Microsoft Corporation. All rights reserved. 4// Licensed under the MIT License. See License.txt in the project root for license information. 5// Code generated by Microsoft (R) AutoRest Code Generator. 6// Changes may cause incorrect behavior and will be lost if the code is regenerated. 7 8package armnetwork 9 10import ( 11 "context" 12 "errors" 13 "fmt" 14 "github.com/Azure/azure-sdk-for-go/sdk/armcore" 15 "github.com/Azure/azure-sdk-for-go/sdk/azcore" 16 "net/http" 17 "net/url" 18 "strings" 19 "time" 20) 21 22// NetworkVirtualAppliancesClient contains the methods for the NetworkVirtualAppliances group. 23// Don't use this type directly, use NewNetworkVirtualAppliancesClient() instead. 24type NetworkVirtualAppliancesClient struct { 25 con *armcore.Connection 26 subscriptionID string 27} 28 29// NewNetworkVirtualAppliancesClient creates a new instance of NetworkVirtualAppliancesClient with the specified values. 30func NewNetworkVirtualAppliancesClient(con *armcore.Connection, subscriptionID string) *NetworkVirtualAppliancesClient { 31 return &NetworkVirtualAppliancesClient{con: con, subscriptionID: subscriptionID} 32} 33 34// BeginCreateOrUpdate - Creates or updates the specified Network Virtual Appliance. 35// If the operation fails it returns the *CloudError error type. 36func (client *NetworkVirtualAppliancesClient) BeginCreateOrUpdate(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, parameters NetworkVirtualAppliance, options *NetworkVirtualAppliancesBeginCreateOrUpdateOptions) (NetworkVirtualAppliancePollerResponse, error) { 37 resp, err := client.createOrUpdate(ctx, resourceGroupName, networkVirtualApplianceName, parameters, options) 38 if err != nil { 39 return NetworkVirtualAppliancePollerResponse{}, err 40 } 41 result := NetworkVirtualAppliancePollerResponse{ 42 RawResponse: resp.Response, 43 } 44 pt, err := armcore.NewLROPoller("NetworkVirtualAppliancesClient.CreateOrUpdate", "azure-async-operation", resp, client.con.Pipeline(), client.createOrUpdateHandleError) 45 if err != nil { 46 return NetworkVirtualAppliancePollerResponse{}, err 47 } 48 poller := &networkVirtualAppliancePoller{ 49 pt: pt, 50 } 51 result.Poller = poller 52 result.PollUntilDone = func(ctx context.Context, frequency time.Duration) (NetworkVirtualApplianceResponse, error) { 53 return poller.pollUntilDone(ctx, frequency) 54 } 55 return result, nil 56} 57 58// ResumeCreateOrUpdate creates a new NetworkVirtualAppliancePoller from the specified resume token. 59// token - The value must come from a previous call to NetworkVirtualAppliancePoller.ResumeToken(). 60func (client *NetworkVirtualAppliancesClient) ResumeCreateOrUpdate(ctx context.Context, token string) (NetworkVirtualAppliancePollerResponse, error) { 61 pt, err := armcore.NewLROPollerFromResumeToken("NetworkVirtualAppliancesClient.CreateOrUpdate", token, client.con.Pipeline(), client.createOrUpdateHandleError) 62 if err != nil { 63 return NetworkVirtualAppliancePollerResponse{}, err 64 } 65 poller := &networkVirtualAppliancePoller{ 66 pt: pt, 67 } 68 resp, err := poller.Poll(ctx) 69 if err != nil { 70 return NetworkVirtualAppliancePollerResponse{}, err 71 } 72 result := NetworkVirtualAppliancePollerResponse{ 73 RawResponse: resp, 74 } 75 result.Poller = poller 76 result.PollUntilDone = func(ctx context.Context, frequency time.Duration) (NetworkVirtualApplianceResponse, error) { 77 return poller.pollUntilDone(ctx, frequency) 78 } 79 return result, nil 80} 81 82// CreateOrUpdate - Creates or updates the specified Network Virtual Appliance. 83// If the operation fails it returns the *CloudError error type. 84func (client *NetworkVirtualAppliancesClient) createOrUpdate(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, parameters NetworkVirtualAppliance, options *NetworkVirtualAppliancesBeginCreateOrUpdateOptions) (*azcore.Response, error) { 85 req, err := client.createOrUpdateCreateRequest(ctx, resourceGroupName, networkVirtualApplianceName, parameters, options) 86 if err != nil { 87 return nil, err 88 } 89 resp, err := client.con.Pipeline().Do(req) 90 if err != nil { 91 return nil, err 92 } 93 if !resp.HasStatusCode(http.StatusOK, http.StatusCreated) { 94 return nil, client.createOrUpdateHandleError(resp) 95 } 96 return resp, nil 97} 98 99// createOrUpdateCreateRequest creates the CreateOrUpdate request. 100func (client *NetworkVirtualAppliancesClient) createOrUpdateCreateRequest(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, parameters NetworkVirtualAppliance, options *NetworkVirtualAppliancesBeginCreateOrUpdateOptions) (*azcore.Request, error) { 101 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}" 102 if resourceGroupName == "" { 103 return nil, errors.New("parameter resourceGroupName cannot be empty") 104 } 105 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 106 if networkVirtualApplianceName == "" { 107 return nil, errors.New("parameter networkVirtualApplianceName cannot be empty") 108 } 109 urlPath = strings.ReplaceAll(urlPath, "{networkVirtualApplianceName}", url.PathEscape(networkVirtualApplianceName)) 110 if client.subscriptionID == "" { 111 return nil, errors.New("parameter client.subscriptionID cannot be empty") 112 } 113 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 114 req, err := azcore.NewRequest(ctx, http.MethodPut, azcore.JoinPaths(client.con.Endpoint(), urlPath)) 115 if err != nil { 116 return nil, err 117 } 118 req.Telemetry(telemetryInfo) 119 reqQP := req.URL.Query() 120 reqQP.Set("api-version", "2021-02-01") 121 req.URL.RawQuery = reqQP.Encode() 122 req.Header.Set("Accept", "application/json") 123 return req, req.MarshalAsJSON(parameters) 124} 125 126// createOrUpdateHandleError handles the CreateOrUpdate error response. 127func (client *NetworkVirtualAppliancesClient) createOrUpdateHandleError(resp *azcore.Response) error { 128 body, err := resp.Payload() 129 if err != nil { 130 return azcore.NewResponseError(err, resp.Response) 131 } 132 errType := CloudError{raw: string(body)} 133 if err := resp.UnmarshalAsJSON(&errType); err != nil { 134 return azcore.NewResponseError(fmt.Errorf("%s\n%s", string(body), err), resp.Response) 135 } 136 return azcore.NewResponseError(&errType, resp.Response) 137} 138 139// BeginDelete - Deletes the specified Network Virtual Appliance. 140// If the operation fails it returns the *CloudError error type. 141func (client *NetworkVirtualAppliancesClient) BeginDelete(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, options *NetworkVirtualAppliancesBeginDeleteOptions) (HTTPPollerResponse, error) { 142 resp, err := client.deleteOperation(ctx, resourceGroupName, networkVirtualApplianceName, options) 143 if err != nil { 144 return HTTPPollerResponse{}, err 145 } 146 result := HTTPPollerResponse{ 147 RawResponse: resp.Response, 148 } 149 pt, err := armcore.NewLROPoller("NetworkVirtualAppliancesClient.Delete", "location", resp, client.con.Pipeline(), client.deleteHandleError) 150 if err != nil { 151 return HTTPPollerResponse{}, err 152 } 153 poller := &httpPoller{ 154 pt: pt, 155 } 156 result.Poller = poller 157 result.PollUntilDone = func(ctx context.Context, frequency time.Duration) (*http.Response, error) { 158 return poller.pollUntilDone(ctx, frequency) 159 } 160 return result, nil 161} 162 163// ResumeDelete creates a new HTTPPoller from the specified resume token. 164// token - The value must come from a previous call to HTTPPoller.ResumeToken(). 165func (client *NetworkVirtualAppliancesClient) ResumeDelete(ctx context.Context, token string) (HTTPPollerResponse, error) { 166 pt, err := armcore.NewLROPollerFromResumeToken("NetworkVirtualAppliancesClient.Delete", token, client.con.Pipeline(), client.deleteHandleError) 167 if err != nil { 168 return HTTPPollerResponse{}, err 169 } 170 poller := &httpPoller{ 171 pt: pt, 172 } 173 resp, err := poller.Poll(ctx) 174 if err != nil { 175 return HTTPPollerResponse{}, err 176 } 177 result := HTTPPollerResponse{ 178 RawResponse: resp, 179 } 180 result.Poller = poller 181 result.PollUntilDone = func(ctx context.Context, frequency time.Duration) (*http.Response, error) { 182 return poller.pollUntilDone(ctx, frequency) 183 } 184 return result, nil 185} 186 187// Delete - Deletes the specified Network Virtual Appliance. 188// If the operation fails it returns the *CloudError error type. 189func (client *NetworkVirtualAppliancesClient) deleteOperation(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, options *NetworkVirtualAppliancesBeginDeleteOptions) (*azcore.Response, error) { 190 req, err := client.deleteCreateRequest(ctx, resourceGroupName, networkVirtualApplianceName, options) 191 if err != nil { 192 return nil, err 193 } 194 resp, err := client.con.Pipeline().Do(req) 195 if err != nil { 196 return nil, err 197 } 198 if !resp.HasStatusCode(http.StatusOK, http.StatusAccepted, http.StatusNoContent) { 199 return nil, client.deleteHandleError(resp) 200 } 201 return resp, nil 202} 203 204// deleteCreateRequest creates the Delete request. 205func (client *NetworkVirtualAppliancesClient) deleteCreateRequest(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, options *NetworkVirtualAppliancesBeginDeleteOptions) (*azcore.Request, error) { 206 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}" 207 if resourceGroupName == "" { 208 return nil, errors.New("parameter resourceGroupName cannot be empty") 209 } 210 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 211 if networkVirtualApplianceName == "" { 212 return nil, errors.New("parameter networkVirtualApplianceName cannot be empty") 213 } 214 urlPath = strings.ReplaceAll(urlPath, "{networkVirtualApplianceName}", url.PathEscape(networkVirtualApplianceName)) 215 if client.subscriptionID == "" { 216 return nil, errors.New("parameter client.subscriptionID cannot be empty") 217 } 218 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 219 req, err := azcore.NewRequest(ctx, http.MethodDelete, azcore.JoinPaths(client.con.Endpoint(), urlPath)) 220 if err != nil { 221 return nil, err 222 } 223 req.Telemetry(telemetryInfo) 224 reqQP := req.URL.Query() 225 reqQP.Set("api-version", "2021-02-01") 226 req.URL.RawQuery = reqQP.Encode() 227 req.Header.Set("Accept", "application/json") 228 return req, nil 229} 230 231// deleteHandleError handles the Delete error response. 232func (client *NetworkVirtualAppliancesClient) deleteHandleError(resp *azcore.Response) error { 233 body, err := resp.Payload() 234 if err != nil { 235 return azcore.NewResponseError(err, resp.Response) 236 } 237 errType := CloudError{raw: string(body)} 238 if err := resp.UnmarshalAsJSON(&errType); err != nil { 239 return azcore.NewResponseError(fmt.Errorf("%s\n%s", string(body), err), resp.Response) 240 } 241 return azcore.NewResponseError(&errType, resp.Response) 242} 243 244// Get - Gets the specified Network Virtual Appliance. 245// If the operation fails it returns the *CloudError error type. 246func (client *NetworkVirtualAppliancesClient) Get(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, options *NetworkVirtualAppliancesGetOptions) (NetworkVirtualApplianceResponse, error) { 247 req, err := client.getCreateRequest(ctx, resourceGroupName, networkVirtualApplianceName, options) 248 if err != nil { 249 return NetworkVirtualApplianceResponse{}, err 250 } 251 resp, err := client.con.Pipeline().Do(req) 252 if err != nil { 253 return NetworkVirtualApplianceResponse{}, err 254 } 255 if !resp.HasStatusCode(http.StatusOK) { 256 return NetworkVirtualApplianceResponse{}, client.getHandleError(resp) 257 } 258 return client.getHandleResponse(resp) 259} 260 261// getCreateRequest creates the Get request. 262func (client *NetworkVirtualAppliancesClient) getCreateRequest(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, options *NetworkVirtualAppliancesGetOptions) (*azcore.Request, error) { 263 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}" 264 if resourceGroupName == "" { 265 return nil, errors.New("parameter resourceGroupName cannot be empty") 266 } 267 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 268 if networkVirtualApplianceName == "" { 269 return nil, errors.New("parameter networkVirtualApplianceName cannot be empty") 270 } 271 urlPath = strings.ReplaceAll(urlPath, "{networkVirtualApplianceName}", url.PathEscape(networkVirtualApplianceName)) 272 if client.subscriptionID == "" { 273 return nil, errors.New("parameter client.subscriptionID cannot be empty") 274 } 275 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 276 req, err := azcore.NewRequest(ctx, http.MethodGet, azcore.JoinPaths(client.con.Endpoint(), urlPath)) 277 if err != nil { 278 return nil, err 279 } 280 req.Telemetry(telemetryInfo) 281 reqQP := req.URL.Query() 282 reqQP.Set("api-version", "2021-02-01") 283 if options != nil && options.Expand != nil { 284 reqQP.Set("$expand", *options.Expand) 285 } 286 req.URL.RawQuery = reqQP.Encode() 287 req.Header.Set("Accept", "application/json") 288 return req, nil 289} 290 291// getHandleResponse handles the Get response. 292func (client *NetworkVirtualAppliancesClient) getHandleResponse(resp *azcore.Response) (NetworkVirtualApplianceResponse, error) { 293 var val *NetworkVirtualAppliance 294 if err := resp.UnmarshalAsJSON(&val); err != nil { 295 return NetworkVirtualApplianceResponse{}, err 296 } 297 return NetworkVirtualApplianceResponse{RawResponse: resp.Response, NetworkVirtualAppliance: val}, nil 298} 299 300// getHandleError handles the Get error response. 301func (client *NetworkVirtualAppliancesClient) getHandleError(resp *azcore.Response) error { 302 body, err := resp.Payload() 303 if err != nil { 304 return azcore.NewResponseError(err, resp.Response) 305 } 306 errType := CloudError{raw: string(body)} 307 if err := resp.UnmarshalAsJSON(&errType); err != nil { 308 return azcore.NewResponseError(fmt.Errorf("%s\n%s", string(body), err), resp.Response) 309 } 310 return azcore.NewResponseError(&errType, resp.Response) 311} 312 313// List - Gets all Network Virtual Appliances in a subscription. 314// If the operation fails it returns the *CloudError error type. 315func (client *NetworkVirtualAppliancesClient) List(options *NetworkVirtualAppliancesListOptions) NetworkVirtualApplianceListResultPager { 316 return &networkVirtualApplianceListResultPager{ 317 pipeline: client.con.Pipeline(), 318 requester: func(ctx context.Context) (*azcore.Request, error) { 319 return client.listCreateRequest(ctx, options) 320 }, 321 responder: client.listHandleResponse, 322 errorer: client.listHandleError, 323 advancer: func(ctx context.Context, resp NetworkVirtualApplianceListResultResponse) (*azcore.Request, error) { 324 return azcore.NewRequest(ctx, http.MethodGet, *resp.NetworkVirtualApplianceListResult.NextLink) 325 }, 326 statusCodes: []int{http.StatusOK}, 327 } 328} 329 330// listCreateRequest creates the List request. 331func (client *NetworkVirtualAppliancesClient) listCreateRequest(ctx context.Context, options *NetworkVirtualAppliancesListOptions) (*azcore.Request, error) { 332 urlPath := "/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkVirtualAppliances" 333 if client.subscriptionID == "" { 334 return nil, errors.New("parameter client.subscriptionID cannot be empty") 335 } 336 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 337 req, err := azcore.NewRequest(ctx, http.MethodGet, azcore.JoinPaths(client.con.Endpoint(), urlPath)) 338 if err != nil { 339 return nil, err 340 } 341 req.Telemetry(telemetryInfo) 342 reqQP := req.URL.Query() 343 reqQP.Set("api-version", "2021-02-01") 344 req.URL.RawQuery = reqQP.Encode() 345 req.Header.Set("Accept", "application/json") 346 return req, nil 347} 348 349// listHandleResponse handles the List response. 350func (client *NetworkVirtualAppliancesClient) listHandleResponse(resp *azcore.Response) (NetworkVirtualApplianceListResultResponse, error) { 351 var val *NetworkVirtualApplianceListResult 352 if err := resp.UnmarshalAsJSON(&val); err != nil { 353 return NetworkVirtualApplianceListResultResponse{}, err 354 } 355 return NetworkVirtualApplianceListResultResponse{RawResponse: resp.Response, NetworkVirtualApplianceListResult: val}, nil 356} 357 358// listHandleError handles the List error response. 359func (client *NetworkVirtualAppliancesClient) listHandleError(resp *azcore.Response) error { 360 body, err := resp.Payload() 361 if err != nil { 362 return azcore.NewResponseError(err, resp.Response) 363 } 364 errType := CloudError{raw: string(body)} 365 if err := resp.UnmarshalAsJSON(&errType); err != nil { 366 return azcore.NewResponseError(fmt.Errorf("%s\n%s", string(body), err), resp.Response) 367 } 368 return azcore.NewResponseError(&errType, resp.Response) 369} 370 371// ListByResourceGroup - Lists all Network Virtual Appliances in a resource group. 372// If the operation fails it returns the *CloudError error type. 373func (client *NetworkVirtualAppliancesClient) ListByResourceGroup(resourceGroupName string, options *NetworkVirtualAppliancesListByResourceGroupOptions) NetworkVirtualApplianceListResultPager { 374 return &networkVirtualApplianceListResultPager{ 375 pipeline: client.con.Pipeline(), 376 requester: func(ctx context.Context) (*azcore.Request, error) { 377 return client.listByResourceGroupCreateRequest(ctx, resourceGroupName, options) 378 }, 379 responder: client.listByResourceGroupHandleResponse, 380 errorer: client.listByResourceGroupHandleError, 381 advancer: func(ctx context.Context, resp NetworkVirtualApplianceListResultResponse) (*azcore.Request, error) { 382 return azcore.NewRequest(ctx, http.MethodGet, *resp.NetworkVirtualApplianceListResult.NextLink) 383 }, 384 statusCodes: []int{http.StatusOK}, 385 } 386} 387 388// listByResourceGroupCreateRequest creates the ListByResourceGroup request. 389func (client *NetworkVirtualAppliancesClient) listByResourceGroupCreateRequest(ctx context.Context, resourceGroupName string, options *NetworkVirtualAppliancesListByResourceGroupOptions) (*azcore.Request, error) { 390 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances" 391 if resourceGroupName == "" { 392 return nil, errors.New("parameter resourceGroupName cannot be empty") 393 } 394 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 395 if client.subscriptionID == "" { 396 return nil, errors.New("parameter client.subscriptionID cannot be empty") 397 } 398 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 399 req, err := azcore.NewRequest(ctx, http.MethodGet, azcore.JoinPaths(client.con.Endpoint(), urlPath)) 400 if err != nil { 401 return nil, err 402 } 403 req.Telemetry(telemetryInfo) 404 reqQP := req.URL.Query() 405 reqQP.Set("api-version", "2021-02-01") 406 req.URL.RawQuery = reqQP.Encode() 407 req.Header.Set("Accept", "application/json") 408 return req, nil 409} 410 411// listByResourceGroupHandleResponse handles the ListByResourceGroup response. 412func (client *NetworkVirtualAppliancesClient) listByResourceGroupHandleResponse(resp *azcore.Response) (NetworkVirtualApplianceListResultResponse, error) { 413 var val *NetworkVirtualApplianceListResult 414 if err := resp.UnmarshalAsJSON(&val); err != nil { 415 return NetworkVirtualApplianceListResultResponse{}, err 416 } 417 return NetworkVirtualApplianceListResultResponse{RawResponse: resp.Response, NetworkVirtualApplianceListResult: val}, nil 418} 419 420// listByResourceGroupHandleError handles the ListByResourceGroup error response. 421func (client *NetworkVirtualAppliancesClient) listByResourceGroupHandleError(resp *azcore.Response) error { 422 body, err := resp.Payload() 423 if err != nil { 424 return azcore.NewResponseError(err, resp.Response) 425 } 426 errType := CloudError{raw: string(body)} 427 if err := resp.UnmarshalAsJSON(&errType); err != nil { 428 return azcore.NewResponseError(fmt.Errorf("%s\n%s", string(body), err), resp.Response) 429 } 430 return azcore.NewResponseError(&errType, resp.Response) 431} 432 433// UpdateTags - Updates a Network Virtual Appliance. 434// If the operation fails it returns the *CloudError error type. 435func (client *NetworkVirtualAppliancesClient) UpdateTags(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, parameters TagsObject, options *NetworkVirtualAppliancesUpdateTagsOptions) (NetworkVirtualApplianceResponse, error) { 436 req, err := client.updateTagsCreateRequest(ctx, resourceGroupName, networkVirtualApplianceName, parameters, options) 437 if err != nil { 438 return NetworkVirtualApplianceResponse{}, err 439 } 440 resp, err := client.con.Pipeline().Do(req) 441 if err != nil { 442 return NetworkVirtualApplianceResponse{}, err 443 } 444 if !resp.HasStatusCode(http.StatusOK) { 445 return NetworkVirtualApplianceResponse{}, client.updateTagsHandleError(resp) 446 } 447 return client.updateTagsHandleResponse(resp) 448} 449 450// updateTagsCreateRequest creates the UpdateTags request. 451func (client *NetworkVirtualAppliancesClient) updateTagsCreateRequest(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, parameters TagsObject, options *NetworkVirtualAppliancesUpdateTagsOptions) (*azcore.Request, error) { 452 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}" 453 if client.subscriptionID == "" { 454 return nil, errors.New("parameter client.subscriptionID cannot be empty") 455 } 456 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 457 if resourceGroupName == "" { 458 return nil, errors.New("parameter resourceGroupName cannot be empty") 459 } 460 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 461 if networkVirtualApplianceName == "" { 462 return nil, errors.New("parameter networkVirtualApplianceName cannot be empty") 463 } 464 urlPath = strings.ReplaceAll(urlPath, "{networkVirtualApplianceName}", url.PathEscape(networkVirtualApplianceName)) 465 req, err := azcore.NewRequest(ctx, http.MethodPatch, azcore.JoinPaths(client.con.Endpoint(), urlPath)) 466 if err != nil { 467 return nil, err 468 } 469 req.Telemetry(telemetryInfo) 470 reqQP := req.URL.Query() 471 reqQP.Set("api-version", "2021-02-01") 472 req.URL.RawQuery = reqQP.Encode() 473 req.Header.Set("Accept", "application/json") 474 return req, req.MarshalAsJSON(parameters) 475} 476 477// updateTagsHandleResponse handles the UpdateTags response. 478func (client *NetworkVirtualAppliancesClient) updateTagsHandleResponse(resp *azcore.Response) (NetworkVirtualApplianceResponse, error) { 479 var val *NetworkVirtualAppliance 480 if err := resp.UnmarshalAsJSON(&val); err != nil { 481 return NetworkVirtualApplianceResponse{}, err 482 } 483 return NetworkVirtualApplianceResponse{RawResponse: resp.Response, NetworkVirtualAppliance: val}, nil 484} 485 486// updateTagsHandleError handles the UpdateTags error response. 487func (client *NetworkVirtualAppliancesClient) updateTagsHandleError(resp *azcore.Response) error { 488 body, err := resp.Payload() 489 if err != nil { 490 return azcore.NewResponseError(err, resp.Response) 491 } 492 errType := CloudError{raw: string(body)} 493 if err := resp.UnmarshalAsJSON(&errType); err != nil { 494 return azcore.NewResponseError(fmt.Errorf("%s\n%s", string(body), err), resp.Response) 495 } 496 return azcore.NewResponseError(&errType, resp.Response) 497} 498