github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/network/armnetwork/v6@v6.2.0/virtualappliances_client.go (about) 1 //go:build go1.18 2 // +build go1.18 3 4 // Copyright (c) Microsoft Corporation. All rights reserved. 5 // Licensed under the MIT License. See License.txt in the project root for license information. 6 // Code generated by Microsoft (R) AutoRest Code Generator. DO NOT EDIT. 7 // Changes may cause incorrect behavior and will be lost if the code is regenerated. 8 9 package armnetwork 10 11 import ( 12 "context" 13 "errors" 14 "github.com/Azure/azure-sdk-for-go/sdk/azcore" 15 "github.com/Azure/azure-sdk-for-go/sdk/azcore/arm" 16 "github.com/Azure/azure-sdk-for-go/sdk/azcore/policy" 17 "github.com/Azure/azure-sdk-for-go/sdk/azcore/runtime" 18 "net/http" 19 "net/url" 20 "strings" 21 ) 22 23 // VirtualAppliancesClient contains the methods for the NetworkVirtualAppliances group. 24 // Don't use this type directly, use NewVirtualAppliancesClient() instead. 25 type VirtualAppliancesClient struct { 26 internal *arm.Client 27 subscriptionID string 28 } 29 30 // NewVirtualAppliancesClient creates a new instance of VirtualAppliancesClient with the specified values. 31 // - subscriptionID - The subscription credentials which uniquely identify the Microsoft Azure subscription. The subscription 32 // ID forms part of the URI for every service call. 33 // - credential - used to authorize requests. Usually a credential from azidentity. 34 // - options - pass nil to accept the default values. 35 func NewVirtualAppliancesClient(subscriptionID string, credential azcore.TokenCredential, options *arm.ClientOptions) (*VirtualAppliancesClient, error) { 36 cl, err := arm.NewClient(moduleName, moduleVersion, credential, options) 37 if err != nil { 38 return nil, err 39 } 40 client := &VirtualAppliancesClient{ 41 subscriptionID: subscriptionID, 42 internal: cl, 43 } 44 return client, nil 45 } 46 47 // BeginCreateOrUpdate - Creates or updates the specified Network Virtual Appliance. 48 // If the operation fails it returns an *azcore.ResponseError type. 49 // 50 // Generated from API version 2024-05-01 51 // - resourceGroupName - The name of the resource group. 52 // - networkVirtualApplianceName - The name of Network Virtual Appliance. 53 // - parameters - Parameters supplied to the create or update Network Virtual Appliance. 54 // - options - VirtualAppliancesClientBeginCreateOrUpdateOptions contains the optional parameters for the VirtualAppliancesClient.BeginCreateOrUpdate 55 // method. 56 func (client *VirtualAppliancesClient) BeginCreateOrUpdate(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, parameters VirtualAppliance, options *VirtualAppliancesClientBeginCreateOrUpdateOptions) (*runtime.Poller[VirtualAppliancesClientCreateOrUpdateResponse], error) { 57 if options == nil || options.ResumeToken == "" { 58 resp, err := client.createOrUpdate(ctx, resourceGroupName, networkVirtualApplianceName, parameters, options) 59 if err != nil { 60 return nil, err 61 } 62 poller, err := runtime.NewPoller(resp, client.internal.Pipeline(), &runtime.NewPollerOptions[VirtualAppliancesClientCreateOrUpdateResponse]{ 63 FinalStateVia: runtime.FinalStateViaAzureAsyncOp, 64 Tracer: client.internal.Tracer(), 65 }) 66 return poller, err 67 } else { 68 return runtime.NewPollerFromResumeToken(options.ResumeToken, client.internal.Pipeline(), &runtime.NewPollerFromResumeTokenOptions[VirtualAppliancesClientCreateOrUpdateResponse]{ 69 Tracer: client.internal.Tracer(), 70 }) 71 } 72 } 73 74 // CreateOrUpdate - Creates or updates the specified Network Virtual Appliance. 75 // If the operation fails it returns an *azcore.ResponseError type. 76 // 77 // Generated from API version 2024-05-01 78 func (client *VirtualAppliancesClient) createOrUpdate(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, parameters VirtualAppliance, options *VirtualAppliancesClientBeginCreateOrUpdateOptions) (*http.Response, error) { 79 var err error 80 const operationName = "VirtualAppliancesClient.BeginCreateOrUpdate" 81 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, operationName) 82 ctx, endSpan := runtime.StartSpan(ctx, operationName, client.internal.Tracer(), nil) 83 defer func() { endSpan(err) }() 84 req, err := client.createOrUpdateCreateRequest(ctx, resourceGroupName, networkVirtualApplianceName, parameters, options) 85 if err != nil { 86 return nil, err 87 } 88 httpResp, err := client.internal.Pipeline().Do(req) 89 if err != nil { 90 return nil, err 91 } 92 if !runtime.HasStatusCode(httpResp, http.StatusOK, http.StatusCreated) { 93 err = runtime.NewResponseError(httpResp) 94 return nil, err 95 } 96 return httpResp, nil 97 } 98 99 // createOrUpdateCreateRequest creates the CreateOrUpdate request. 100 func (client *VirtualAppliancesClient) createOrUpdateCreateRequest(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, parameters VirtualAppliance, options *VirtualAppliancesClientBeginCreateOrUpdateOptions) (*policy.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 := runtime.NewRequest(ctx, http.MethodPut, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 115 if err != nil { 116 return nil, err 117 } 118 reqQP := req.Raw().URL.Query() 119 reqQP.Set("api-version", "2024-05-01") 120 req.Raw().URL.RawQuery = reqQP.Encode() 121 req.Raw().Header["Accept"] = []string{"application/json"} 122 if err := runtime.MarshalAsJSON(req, parameters); err != nil { 123 return nil, err 124 } 125 return req, nil 126 } 127 128 // BeginDelete - Deletes the specified Network Virtual Appliance. 129 // If the operation fails it returns an *azcore.ResponseError type. 130 // 131 // Generated from API version 2024-05-01 132 // - resourceGroupName - The name of the resource group. 133 // - networkVirtualApplianceName - The name of Network Virtual Appliance. 134 // - options - VirtualAppliancesClientBeginDeleteOptions contains the optional parameters for the VirtualAppliancesClient.BeginDelete 135 // method. 136 func (client *VirtualAppliancesClient) BeginDelete(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, options *VirtualAppliancesClientBeginDeleteOptions) (*runtime.Poller[VirtualAppliancesClientDeleteResponse], error) { 137 if options == nil || options.ResumeToken == "" { 138 resp, err := client.deleteOperation(ctx, resourceGroupName, networkVirtualApplianceName, options) 139 if err != nil { 140 return nil, err 141 } 142 poller, err := runtime.NewPoller(resp, client.internal.Pipeline(), &runtime.NewPollerOptions[VirtualAppliancesClientDeleteResponse]{ 143 FinalStateVia: runtime.FinalStateViaLocation, 144 Tracer: client.internal.Tracer(), 145 }) 146 return poller, err 147 } else { 148 return runtime.NewPollerFromResumeToken(options.ResumeToken, client.internal.Pipeline(), &runtime.NewPollerFromResumeTokenOptions[VirtualAppliancesClientDeleteResponse]{ 149 Tracer: client.internal.Tracer(), 150 }) 151 } 152 } 153 154 // Delete - Deletes the specified Network Virtual Appliance. 155 // If the operation fails it returns an *azcore.ResponseError type. 156 // 157 // Generated from API version 2024-05-01 158 func (client *VirtualAppliancesClient) deleteOperation(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, options *VirtualAppliancesClientBeginDeleteOptions) (*http.Response, error) { 159 var err error 160 const operationName = "VirtualAppliancesClient.BeginDelete" 161 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, operationName) 162 ctx, endSpan := runtime.StartSpan(ctx, operationName, client.internal.Tracer(), nil) 163 defer func() { endSpan(err) }() 164 req, err := client.deleteCreateRequest(ctx, resourceGroupName, networkVirtualApplianceName, options) 165 if err != nil { 166 return nil, err 167 } 168 httpResp, err := client.internal.Pipeline().Do(req) 169 if err != nil { 170 return nil, err 171 } 172 if !runtime.HasStatusCode(httpResp, http.StatusOK, http.StatusAccepted, http.StatusNoContent) { 173 err = runtime.NewResponseError(httpResp) 174 return nil, err 175 } 176 return httpResp, nil 177 } 178 179 // deleteCreateRequest creates the Delete request. 180 func (client *VirtualAppliancesClient) deleteCreateRequest(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, options *VirtualAppliancesClientBeginDeleteOptions) (*policy.Request, error) { 181 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}" 182 if resourceGroupName == "" { 183 return nil, errors.New("parameter resourceGroupName cannot be empty") 184 } 185 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 186 if networkVirtualApplianceName == "" { 187 return nil, errors.New("parameter networkVirtualApplianceName cannot be empty") 188 } 189 urlPath = strings.ReplaceAll(urlPath, "{networkVirtualApplianceName}", url.PathEscape(networkVirtualApplianceName)) 190 if client.subscriptionID == "" { 191 return nil, errors.New("parameter client.subscriptionID cannot be empty") 192 } 193 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 194 req, err := runtime.NewRequest(ctx, http.MethodDelete, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 195 if err != nil { 196 return nil, err 197 } 198 reqQP := req.Raw().URL.Query() 199 reqQP.Set("api-version", "2024-05-01") 200 req.Raw().URL.RawQuery = reqQP.Encode() 201 req.Raw().Header["Accept"] = []string{"application/json"} 202 return req, nil 203 } 204 205 // Get - Gets the specified Network Virtual Appliance. 206 // If the operation fails it returns an *azcore.ResponseError type. 207 // 208 // Generated from API version 2024-05-01 209 // - resourceGroupName - The name of the resource group. 210 // - networkVirtualApplianceName - The name of Network Virtual Appliance. 211 // - options - VirtualAppliancesClientGetOptions contains the optional parameters for the VirtualAppliancesClient.Get method. 212 func (client *VirtualAppliancesClient) Get(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, options *VirtualAppliancesClientGetOptions) (VirtualAppliancesClientGetResponse, error) { 213 var err error 214 const operationName = "VirtualAppliancesClient.Get" 215 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, operationName) 216 ctx, endSpan := runtime.StartSpan(ctx, operationName, client.internal.Tracer(), nil) 217 defer func() { endSpan(err) }() 218 req, err := client.getCreateRequest(ctx, resourceGroupName, networkVirtualApplianceName, options) 219 if err != nil { 220 return VirtualAppliancesClientGetResponse{}, err 221 } 222 httpResp, err := client.internal.Pipeline().Do(req) 223 if err != nil { 224 return VirtualAppliancesClientGetResponse{}, err 225 } 226 if !runtime.HasStatusCode(httpResp, http.StatusOK) { 227 err = runtime.NewResponseError(httpResp) 228 return VirtualAppliancesClientGetResponse{}, err 229 } 230 resp, err := client.getHandleResponse(httpResp) 231 return resp, err 232 } 233 234 // getCreateRequest creates the Get request. 235 func (client *VirtualAppliancesClient) getCreateRequest(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, options *VirtualAppliancesClientGetOptions) (*policy.Request, error) { 236 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}" 237 if resourceGroupName == "" { 238 return nil, errors.New("parameter resourceGroupName cannot be empty") 239 } 240 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 241 if networkVirtualApplianceName == "" { 242 return nil, errors.New("parameter networkVirtualApplianceName cannot be empty") 243 } 244 urlPath = strings.ReplaceAll(urlPath, "{networkVirtualApplianceName}", url.PathEscape(networkVirtualApplianceName)) 245 if client.subscriptionID == "" { 246 return nil, errors.New("parameter client.subscriptionID cannot be empty") 247 } 248 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 249 req, err := runtime.NewRequest(ctx, http.MethodGet, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 250 if err != nil { 251 return nil, err 252 } 253 reqQP := req.Raw().URL.Query() 254 if options != nil && options.Expand != nil { 255 reqQP.Set("$expand", *options.Expand) 256 } 257 reqQP.Set("api-version", "2024-05-01") 258 req.Raw().URL.RawQuery = reqQP.Encode() 259 req.Raw().Header["Accept"] = []string{"application/json"} 260 return req, nil 261 } 262 263 // getHandleResponse handles the Get response. 264 func (client *VirtualAppliancesClient) getHandleResponse(resp *http.Response) (VirtualAppliancesClientGetResponse, error) { 265 result := VirtualAppliancesClientGetResponse{} 266 if err := runtime.UnmarshalAsJSON(resp, &result.VirtualAppliance); err != nil { 267 return VirtualAppliancesClientGetResponse{}, err 268 } 269 return result, nil 270 } 271 272 // NewListPager - Gets all Network Virtual Appliances in a subscription. 273 // 274 // Generated from API version 2024-05-01 275 // - options - VirtualAppliancesClientListOptions contains the optional parameters for the VirtualAppliancesClient.NewListPager 276 // method. 277 func (client *VirtualAppliancesClient) NewListPager(options *VirtualAppliancesClientListOptions) *runtime.Pager[VirtualAppliancesClientListResponse] { 278 return runtime.NewPager(runtime.PagingHandler[VirtualAppliancesClientListResponse]{ 279 More: func(page VirtualAppliancesClientListResponse) bool { 280 return page.NextLink != nil && len(*page.NextLink) > 0 281 }, 282 Fetcher: func(ctx context.Context, page *VirtualAppliancesClientListResponse) (VirtualAppliancesClientListResponse, error) { 283 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, "VirtualAppliancesClient.NewListPager") 284 nextLink := "" 285 if page != nil { 286 nextLink = *page.NextLink 287 } 288 resp, err := runtime.FetcherForNextLink(ctx, client.internal.Pipeline(), nextLink, func(ctx context.Context) (*policy.Request, error) { 289 return client.listCreateRequest(ctx, options) 290 }, nil) 291 if err != nil { 292 return VirtualAppliancesClientListResponse{}, err 293 } 294 return client.listHandleResponse(resp) 295 }, 296 Tracer: client.internal.Tracer(), 297 }) 298 } 299 300 // listCreateRequest creates the List request. 301 func (client *VirtualAppliancesClient) listCreateRequest(ctx context.Context, options *VirtualAppliancesClientListOptions) (*policy.Request, error) { 302 urlPath := "/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkVirtualAppliances" 303 if client.subscriptionID == "" { 304 return nil, errors.New("parameter client.subscriptionID cannot be empty") 305 } 306 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 307 req, err := runtime.NewRequest(ctx, http.MethodGet, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 308 if err != nil { 309 return nil, err 310 } 311 reqQP := req.Raw().URL.Query() 312 reqQP.Set("api-version", "2024-05-01") 313 req.Raw().URL.RawQuery = reqQP.Encode() 314 req.Raw().Header["Accept"] = []string{"application/json"} 315 return req, nil 316 } 317 318 // listHandleResponse handles the List response. 319 func (client *VirtualAppliancesClient) listHandleResponse(resp *http.Response) (VirtualAppliancesClientListResponse, error) { 320 result := VirtualAppliancesClientListResponse{} 321 if err := runtime.UnmarshalAsJSON(resp, &result.VirtualApplianceListResult); err != nil { 322 return VirtualAppliancesClientListResponse{}, err 323 } 324 return result, nil 325 } 326 327 // NewListByResourceGroupPager - Lists all Network Virtual Appliances in a resource group. 328 // 329 // Generated from API version 2024-05-01 330 // - resourceGroupName - The name of the resource group. 331 // - options - VirtualAppliancesClientListByResourceGroupOptions contains the optional parameters for the VirtualAppliancesClient.NewListByResourceGroupPager 332 // method. 333 func (client *VirtualAppliancesClient) NewListByResourceGroupPager(resourceGroupName string, options *VirtualAppliancesClientListByResourceGroupOptions) *runtime.Pager[VirtualAppliancesClientListByResourceGroupResponse] { 334 return runtime.NewPager(runtime.PagingHandler[VirtualAppliancesClientListByResourceGroupResponse]{ 335 More: func(page VirtualAppliancesClientListByResourceGroupResponse) bool { 336 return page.NextLink != nil && len(*page.NextLink) > 0 337 }, 338 Fetcher: func(ctx context.Context, page *VirtualAppliancesClientListByResourceGroupResponse) (VirtualAppliancesClientListByResourceGroupResponse, error) { 339 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, "VirtualAppliancesClient.NewListByResourceGroupPager") 340 nextLink := "" 341 if page != nil { 342 nextLink = *page.NextLink 343 } 344 resp, err := runtime.FetcherForNextLink(ctx, client.internal.Pipeline(), nextLink, func(ctx context.Context) (*policy.Request, error) { 345 return client.listByResourceGroupCreateRequest(ctx, resourceGroupName, options) 346 }, nil) 347 if err != nil { 348 return VirtualAppliancesClientListByResourceGroupResponse{}, err 349 } 350 return client.listByResourceGroupHandleResponse(resp) 351 }, 352 Tracer: client.internal.Tracer(), 353 }) 354 } 355 356 // listByResourceGroupCreateRequest creates the ListByResourceGroup request. 357 func (client *VirtualAppliancesClient) listByResourceGroupCreateRequest(ctx context.Context, resourceGroupName string, options *VirtualAppliancesClientListByResourceGroupOptions) (*policy.Request, error) { 358 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances" 359 if resourceGroupName == "" { 360 return nil, errors.New("parameter resourceGroupName cannot be empty") 361 } 362 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 363 if client.subscriptionID == "" { 364 return nil, errors.New("parameter client.subscriptionID cannot be empty") 365 } 366 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 367 req, err := runtime.NewRequest(ctx, http.MethodGet, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 368 if err != nil { 369 return nil, err 370 } 371 reqQP := req.Raw().URL.Query() 372 reqQP.Set("api-version", "2024-05-01") 373 req.Raw().URL.RawQuery = reqQP.Encode() 374 req.Raw().Header["Accept"] = []string{"application/json"} 375 return req, nil 376 } 377 378 // listByResourceGroupHandleResponse handles the ListByResourceGroup response. 379 func (client *VirtualAppliancesClient) listByResourceGroupHandleResponse(resp *http.Response) (VirtualAppliancesClientListByResourceGroupResponse, error) { 380 result := VirtualAppliancesClientListByResourceGroupResponse{} 381 if err := runtime.UnmarshalAsJSON(resp, &result.VirtualApplianceListResult); err != nil { 382 return VirtualAppliancesClientListByResourceGroupResponse{}, err 383 } 384 return result, nil 385 } 386 387 // BeginRestart - Restarts one or more VMs belonging to the specified Network Virtual Appliance. 388 // If the operation fails it returns an *azcore.ResponseError type. 389 // 390 // Generated from API version 2024-05-01 391 // - resourceGroupName - The name of the resource group. 392 // - networkVirtualApplianceName - The name of Network Virtual Appliance. 393 // - options - VirtualAppliancesClientBeginRestartOptions contains the optional parameters for the VirtualAppliancesClient.BeginRestart 394 // method. 395 func (client *VirtualAppliancesClient) BeginRestart(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, options *VirtualAppliancesClientBeginRestartOptions) (*runtime.Poller[VirtualAppliancesClientRestartResponse], error) { 396 if options == nil || options.ResumeToken == "" { 397 resp, err := client.restart(ctx, resourceGroupName, networkVirtualApplianceName, options) 398 if err != nil { 399 return nil, err 400 } 401 poller, err := runtime.NewPoller(resp, client.internal.Pipeline(), &runtime.NewPollerOptions[VirtualAppliancesClientRestartResponse]{ 402 FinalStateVia: runtime.FinalStateViaLocation, 403 Tracer: client.internal.Tracer(), 404 }) 405 return poller, err 406 } else { 407 return runtime.NewPollerFromResumeToken(options.ResumeToken, client.internal.Pipeline(), &runtime.NewPollerFromResumeTokenOptions[VirtualAppliancesClientRestartResponse]{ 408 Tracer: client.internal.Tracer(), 409 }) 410 } 411 } 412 413 // Restart - Restarts one or more VMs belonging to the specified Network Virtual Appliance. 414 // If the operation fails it returns an *azcore.ResponseError type. 415 // 416 // Generated from API version 2024-05-01 417 func (client *VirtualAppliancesClient) restart(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, options *VirtualAppliancesClientBeginRestartOptions) (*http.Response, error) { 418 var err error 419 const operationName = "VirtualAppliancesClient.BeginRestart" 420 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, operationName) 421 ctx, endSpan := runtime.StartSpan(ctx, operationName, client.internal.Tracer(), nil) 422 defer func() { endSpan(err) }() 423 req, err := client.restartCreateRequest(ctx, resourceGroupName, networkVirtualApplianceName, options) 424 if err != nil { 425 return nil, err 426 } 427 httpResp, err := client.internal.Pipeline().Do(req) 428 if err != nil { 429 return nil, err 430 } 431 if !runtime.HasStatusCode(httpResp, http.StatusOK, http.StatusAccepted) { 432 err = runtime.NewResponseError(httpResp) 433 return nil, err 434 } 435 return httpResp, nil 436 } 437 438 // restartCreateRequest creates the Restart request. 439 func (client *VirtualAppliancesClient) restartCreateRequest(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, options *VirtualAppliancesClientBeginRestartOptions) (*policy.Request, error) { 440 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}/restart" 441 if resourceGroupName == "" { 442 return nil, errors.New("parameter resourceGroupName cannot be empty") 443 } 444 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 445 if networkVirtualApplianceName == "" { 446 return nil, errors.New("parameter networkVirtualApplianceName cannot be empty") 447 } 448 urlPath = strings.ReplaceAll(urlPath, "{networkVirtualApplianceName}", url.PathEscape(networkVirtualApplianceName)) 449 if client.subscriptionID == "" { 450 return nil, errors.New("parameter client.subscriptionID cannot be empty") 451 } 452 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 453 req, err := runtime.NewRequest(ctx, http.MethodPost, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 454 if err != nil { 455 return nil, err 456 } 457 reqQP := req.Raw().URL.Query() 458 reqQP.Set("api-version", "2024-05-01") 459 req.Raw().URL.RawQuery = reqQP.Encode() 460 req.Raw().Header["Accept"] = []string{"application/json"} 461 if options != nil && options.NetworkVirtualApplianceInstanceIDs != nil { 462 if err := runtime.MarshalAsJSON(req, *options.NetworkVirtualApplianceInstanceIDs); err != nil { 463 return nil, err 464 } 465 return req, nil 466 } 467 return req, nil 468 } 469 470 // UpdateTags - Updates a Network Virtual Appliance. 471 // If the operation fails it returns an *azcore.ResponseError type. 472 // 473 // Generated from API version 2024-05-01 474 // - resourceGroupName - The resource group name of Network Virtual Appliance. 475 // - networkVirtualApplianceName - The name of Network Virtual Appliance being updated. 476 // - parameters - Parameters supplied to Update Network Virtual Appliance Tags. 477 // - options - VirtualAppliancesClientUpdateTagsOptions contains the optional parameters for the VirtualAppliancesClient.UpdateTags 478 // method. 479 func (client *VirtualAppliancesClient) UpdateTags(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, parameters TagsObject, options *VirtualAppliancesClientUpdateTagsOptions) (VirtualAppliancesClientUpdateTagsResponse, error) { 480 var err error 481 const operationName = "VirtualAppliancesClient.UpdateTags" 482 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, operationName) 483 ctx, endSpan := runtime.StartSpan(ctx, operationName, client.internal.Tracer(), nil) 484 defer func() { endSpan(err) }() 485 req, err := client.updateTagsCreateRequest(ctx, resourceGroupName, networkVirtualApplianceName, parameters, options) 486 if err != nil { 487 return VirtualAppliancesClientUpdateTagsResponse{}, err 488 } 489 httpResp, err := client.internal.Pipeline().Do(req) 490 if err != nil { 491 return VirtualAppliancesClientUpdateTagsResponse{}, err 492 } 493 if !runtime.HasStatusCode(httpResp, http.StatusOK) { 494 err = runtime.NewResponseError(httpResp) 495 return VirtualAppliancesClientUpdateTagsResponse{}, err 496 } 497 resp, err := client.updateTagsHandleResponse(httpResp) 498 return resp, err 499 } 500 501 // updateTagsCreateRequest creates the UpdateTags request. 502 func (client *VirtualAppliancesClient) updateTagsCreateRequest(ctx context.Context, resourceGroupName string, networkVirtualApplianceName string, parameters TagsObject, options *VirtualAppliancesClientUpdateTagsOptions) (*policy.Request, error) { 503 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}" 504 if client.subscriptionID == "" { 505 return nil, errors.New("parameter client.subscriptionID cannot be empty") 506 } 507 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 508 if resourceGroupName == "" { 509 return nil, errors.New("parameter resourceGroupName cannot be empty") 510 } 511 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 512 if networkVirtualApplianceName == "" { 513 return nil, errors.New("parameter networkVirtualApplianceName cannot be empty") 514 } 515 urlPath = strings.ReplaceAll(urlPath, "{networkVirtualApplianceName}", url.PathEscape(networkVirtualApplianceName)) 516 req, err := runtime.NewRequest(ctx, http.MethodPatch, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 517 if err != nil { 518 return nil, err 519 } 520 reqQP := req.Raw().URL.Query() 521 reqQP.Set("api-version", "2024-05-01") 522 req.Raw().URL.RawQuery = reqQP.Encode() 523 req.Raw().Header["Accept"] = []string{"application/json"} 524 if err := runtime.MarshalAsJSON(req, parameters); err != nil { 525 return nil, err 526 } 527 return req, nil 528 } 529 530 // updateTagsHandleResponse handles the UpdateTags response. 531 func (client *VirtualAppliancesClient) updateTagsHandleResponse(resp *http.Response) (VirtualAppliancesClientUpdateTagsResponse, error) { 532 result := VirtualAppliancesClientUpdateTagsResponse{} 533 if err := runtime.UnmarshalAsJSON(resp, &result.VirtualAppliance); err != nil { 534 return VirtualAppliancesClientUpdateTagsResponse{}, err 535 } 536 return result, nil 537 }