github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/network/armnetwork/v6@v6.2.0/virtualapplianceskus_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 // VirtualApplianceSKUsClient contains the methods for the VirtualApplianceSKUs group. 24 // Don't use this type directly, use NewVirtualApplianceSKUsClient() instead. 25 type VirtualApplianceSKUsClient struct { 26 internal *arm.Client 27 subscriptionID string 28 } 29 30 // NewVirtualApplianceSKUsClient creates a new instance of VirtualApplianceSKUsClient 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 NewVirtualApplianceSKUsClient(subscriptionID string, credential azcore.TokenCredential, options *arm.ClientOptions) (*VirtualApplianceSKUsClient, error) { 36 cl, err := arm.NewClient(moduleName, moduleVersion, credential, options) 37 if err != nil { 38 return nil, err 39 } 40 client := &VirtualApplianceSKUsClient{ 41 subscriptionID: subscriptionID, 42 internal: cl, 43 } 44 return client, nil 45 } 46 47 // Get - Retrieves a single available sku for network virtual appliance. 48 // If the operation fails it returns an *azcore.ResponseError type. 49 // 50 // Generated from API version 2024-05-01 51 // - skuName - Name of the Sku. 52 // - options - VirtualApplianceSKUsClientGetOptions contains the optional parameters for the VirtualApplianceSKUsClient.Get 53 // method. 54 func (client *VirtualApplianceSKUsClient) Get(ctx context.Context, skuName string, options *VirtualApplianceSKUsClientGetOptions) (VirtualApplianceSKUsClientGetResponse, error) { 55 var err error 56 const operationName = "VirtualApplianceSKUsClient.Get" 57 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, operationName) 58 ctx, endSpan := runtime.StartSpan(ctx, operationName, client.internal.Tracer(), nil) 59 defer func() { endSpan(err) }() 60 req, err := client.getCreateRequest(ctx, skuName, options) 61 if err != nil { 62 return VirtualApplianceSKUsClientGetResponse{}, err 63 } 64 httpResp, err := client.internal.Pipeline().Do(req) 65 if err != nil { 66 return VirtualApplianceSKUsClientGetResponse{}, err 67 } 68 if !runtime.HasStatusCode(httpResp, http.StatusOK) { 69 err = runtime.NewResponseError(httpResp) 70 return VirtualApplianceSKUsClientGetResponse{}, err 71 } 72 resp, err := client.getHandleResponse(httpResp) 73 return resp, err 74 } 75 76 // getCreateRequest creates the Get request. 77 func (client *VirtualApplianceSKUsClient) getCreateRequest(ctx context.Context, skuName string, options *VirtualApplianceSKUsClientGetOptions) (*policy.Request, error) { 78 urlPath := "/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkVirtualApplianceSkus/{skuName}" 79 if client.subscriptionID == "" { 80 return nil, errors.New("parameter client.subscriptionID cannot be empty") 81 } 82 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 83 if skuName == "" { 84 return nil, errors.New("parameter skuName cannot be empty") 85 } 86 urlPath = strings.ReplaceAll(urlPath, "{skuName}", url.PathEscape(skuName)) 87 req, err := runtime.NewRequest(ctx, http.MethodGet, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 88 if err != nil { 89 return nil, err 90 } 91 reqQP := req.Raw().URL.Query() 92 reqQP.Set("api-version", "2024-05-01") 93 req.Raw().URL.RawQuery = reqQP.Encode() 94 req.Raw().Header["Accept"] = []string{"application/json"} 95 return req, nil 96 } 97 98 // getHandleResponse handles the Get response. 99 func (client *VirtualApplianceSKUsClient) getHandleResponse(resp *http.Response) (VirtualApplianceSKUsClientGetResponse, error) { 100 result := VirtualApplianceSKUsClientGetResponse{} 101 if err := runtime.UnmarshalAsJSON(resp, &result.VirtualApplianceSKU); err != nil { 102 return VirtualApplianceSKUsClientGetResponse{}, err 103 } 104 return result, nil 105 } 106 107 // NewListPager - List all SKUs available for a virtual appliance. 108 // 109 // Generated from API version 2024-05-01 110 // - options - VirtualApplianceSKUsClientListOptions contains the optional parameters for the VirtualApplianceSKUsClient.NewListPager 111 // method. 112 func (client *VirtualApplianceSKUsClient) NewListPager(options *VirtualApplianceSKUsClientListOptions) *runtime.Pager[VirtualApplianceSKUsClientListResponse] { 113 return runtime.NewPager(runtime.PagingHandler[VirtualApplianceSKUsClientListResponse]{ 114 More: func(page VirtualApplianceSKUsClientListResponse) bool { 115 return page.NextLink != nil && len(*page.NextLink) > 0 116 }, 117 Fetcher: func(ctx context.Context, page *VirtualApplianceSKUsClientListResponse) (VirtualApplianceSKUsClientListResponse, error) { 118 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, "VirtualApplianceSKUsClient.NewListPager") 119 nextLink := "" 120 if page != nil { 121 nextLink = *page.NextLink 122 } 123 resp, err := runtime.FetcherForNextLink(ctx, client.internal.Pipeline(), nextLink, func(ctx context.Context) (*policy.Request, error) { 124 return client.listCreateRequest(ctx, options) 125 }, nil) 126 if err != nil { 127 return VirtualApplianceSKUsClientListResponse{}, err 128 } 129 return client.listHandleResponse(resp) 130 }, 131 Tracer: client.internal.Tracer(), 132 }) 133 } 134 135 // listCreateRequest creates the List request. 136 func (client *VirtualApplianceSKUsClient) listCreateRequest(ctx context.Context, options *VirtualApplianceSKUsClientListOptions) (*policy.Request, error) { 137 urlPath := "/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkVirtualApplianceSkus" 138 if client.subscriptionID == "" { 139 return nil, errors.New("parameter client.subscriptionID cannot be empty") 140 } 141 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 142 req, err := runtime.NewRequest(ctx, http.MethodGet, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 143 if err != nil { 144 return nil, err 145 } 146 reqQP := req.Raw().URL.Query() 147 reqQP.Set("api-version", "2024-05-01") 148 req.Raw().URL.RawQuery = reqQP.Encode() 149 req.Raw().Header["Accept"] = []string{"application/json"} 150 return req, nil 151 } 152 153 // listHandleResponse handles the List response. 154 func (client *VirtualApplianceSKUsClient) listHandleResponse(resp *http.Response) (VirtualApplianceSKUsClientListResponse, error) { 155 result := VirtualApplianceSKUsClientListResponse{} 156 if err := runtime.UnmarshalAsJSON(resp, &result.VirtualApplianceSKUListResult); err != nil { 157 return VirtualApplianceSKUsClientListResponse{}, err 158 } 159 return result, nil 160 }