github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/network/armnetwork/v6@v6.2.0/defaultsecurityrules_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 // DefaultSecurityRulesClient contains the methods for the DefaultSecurityRules group. 24 // Don't use this type directly, use NewDefaultSecurityRulesClient() instead. 25 type DefaultSecurityRulesClient struct { 26 internal *arm.Client 27 subscriptionID string 28 } 29 30 // NewDefaultSecurityRulesClient creates a new instance of DefaultSecurityRulesClient 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 NewDefaultSecurityRulesClient(subscriptionID string, credential azcore.TokenCredential, options *arm.ClientOptions) (*DefaultSecurityRulesClient, error) { 36 cl, err := arm.NewClient(moduleName, moduleVersion, credential, options) 37 if err != nil { 38 return nil, err 39 } 40 client := &DefaultSecurityRulesClient{ 41 subscriptionID: subscriptionID, 42 internal: cl, 43 } 44 return client, nil 45 } 46 47 // Get - Get the specified default network security rule. 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 // - networkSecurityGroupName - The name of the network security group. 53 // - defaultSecurityRuleName - The name of the default security rule. 54 // - options - DefaultSecurityRulesClientGetOptions contains the optional parameters for the DefaultSecurityRulesClient.Get 55 // method. 56 func (client *DefaultSecurityRulesClient) Get(ctx context.Context, resourceGroupName string, networkSecurityGroupName string, defaultSecurityRuleName string, options *DefaultSecurityRulesClientGetOptions) (DefaultSecurityRulesClientGetResponse, error) { 57 var err error 58 const operationName = "DefaultSecurityRulesClient.Get" 59 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, operationName) 60 ctx, endSpan := runtime.StartSpan(ctx, operationName, client.internal.Tracer(), nil) 61 defer func() { endSpan(err) }() 62 req, err := client.getCreateRequest(ctx, resourceGroupName, networkSecurityGroupName, defaultSecurityRuleName, options) 63 if err != nil { 64 return DefaultSecurityRulesClientGetResponse{}, err 65 } 66 httpResp, err := client.internal.Pipeline().Do(req) 67 if err != nil { 68 return DefaultSecurityRulesClientGetResponse{}, err 69 } 70 if !runtime.HasStatusCode(httpResp, http.StatusOK) { 71 err = runtime.NewResponseError(httpResp) 72 return DefaultSecurityRulesClientGetResponse{}, err 73 } 74 resp, err := client.getHandleResponse(httpResp) 75 return resp, err 76 } 77 78 // getCreateRequest creates the Get request. 79 func (client *DefaultSecurityRulesClient) getCreateRequest(ctx context.Context, resourceGroupName string, networkSecurityGroupName string, defaultSecurityRuleName string, options *DefaultSecurityRulesClientGetOptions) (*policy.Request, error) { 80 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}/defaultSecurityRules/{defaultSecurityRuleName}" 81 if resourceGroupName == "" { 82 return nil, errors.New("parameter resourceGroupName cannot be empty") 83 } 84 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 85 if networkSecurityGroupName == "" { 86 return nil, errors.New("parameter networkSecurityGroupName cannot be empty") 87 } 88 urlPath = strings.ReplaceAll(urlPath, "{networkSecurityGroupName}", url.PathEscape(networkSecurityGroupName)) 89 if defaultSecurityRuleName == "" { 90 return nil, errors.New("parameter defaultSecurityRuleName cannot be empty") 91 } 92 urlPath = strings.ReplaceAll(urlPath, "{defaultSecurityRuleName}", url.PathEscape(defaultSecurityRuleName)) 93 if client.subscriptionID == "" { 94 return nil, errors.New("parameter client.subscriptionID cannot be empty") 95 } 96 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 97 req, err := runtime.NewRequest(ctx, http.MethodGet, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 98 if err != nil { 99 return nil, err 100 } 101 reqQP := req.Raw().URL.Query() 102 reqQP.Set("api-version", "2024-05-01") 103 req.Raw().URL.RawQuery = reqQP.Encode() 104 req.Raw().Header["Accept"] = []string{"application/json"} 105 return req, nil 106 } 107 108 // getHandleResponse handles the Get response. 109 func (client *DefaultSecurityRulesClient) getHandleResponse(resp *http.Response) (DefaultSecurityRulesClientGetResponse, error) { 110 result := DefaultSecurityRulesClientGetResponse{} 111 if err := runtime.UnmarshalAsJSON(resp, &result.SecurityRule); err != nil { 112 return DefaultSecurityRulesClientGetResponse{}, err 113 } 114 return result, nil 115 } 116 117 // NewListPager - Gets all default security rules in a network security group. 118 // 119 // Generated from API version 2024-05-01 120 // - resourceGroupName - The name of the resource group. 121 // - networkSecurityGroupName - The name of the network security group. 122 // - options - DefaultSecurityRulesClientListOptions contains the optional parameters for the DefaultSecurityRulesClient.NewListPager 123 // method. 124 func (client *DefaultSecurityRulesClient) NewListPager(resourceGroupName string, networkSecurityGroupName string, options *DefaultSecurityRulesClientListOptions) *runtime.Pager[DefaultSecurityRulesClientListResponse] { 125 return runtime.NewPager(runtime.PagingHandler[DefaultSecurityRulesClientListResponse]{ 126 More: func(page DefaultSecurityRulesClientListResponse) bool { 127 return page.NextLink != nil && len(*page.NextLink) > 0 128 }, 129 Fetcher: func(ctx context.Context, page *DefaultSecurityRulesClientListResponse) (DefaultSecurityRulesClientListResponse, error) { 130 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, "DefaultSecurityRulesClient.NewListPager") 131 nextLink := "" 132 if page != nil { 133 nextLink = *page.NextLink 134 } 135 resp, err := runtime.FetcherForNextLink(ctx, client.internal.Pipeline(), nextLink, func(ctx context.Context) (*policy.Request, error) { 136 return client.listCreateRequest(ctx, resourceGroupName, networkSecurityGroupName, options) 137 }, nil) 138 if err != nil { 139 return DefaultSecurityRulesClientListResponse{}, err 140 } 141 return client.listHandleResponse(resp) 142 }, 143 Tracer: client.internal.Tracer(), 144 }) 145 } 146 147 // listCreateRequest creates the List request. 148 func (client *DefaultSecurityRulesClient) listCreateRequest(ctx context.Context, resourceGroupName string, networkSecurityGroupName string, options *DefaultSecurityRulesClientListOptions) (*policy.Request, error) { 149 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}/defaultSecurityRules" 150 if resourceGroupName == "" { 151 return nil, errors.New("parameter resourceGroupName cannot be empty") 152 } 153 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 154 if networkSecurityGroupName == "" { 155 return nil, errors.New("parameter networkSecurityGroupName cannot be empty") 156 } 157 urlPath = strings.ReplaceAll(urlPath, "{networkSecurityGroupName}", url.PathEscape(networkSecurityGroupName)) 158 if client.subscriptionID == "" { 159 return nil, errors.New("parameter client.subscriptionID cannot be empty") 160 } 161 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 162 req, err := runtime.NewRequest(ctx, http.MethodGet, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 163 if err != nil { 164 return nil, err 165 } 166 reqQP := req.Raw().URL.Query() 167 reqQP.Set("api-version", "2024-05-01") 168 req.Raw().URL.RawQuery = reqQP.Encode() 169 req.Raw().Header["Accept"] = []string{"application/json"} 170 return req, nil 171 } 172 173 // listHandleResponse handles the List response. 174 func (client *DefaultSecurityRulesClient) listHandleResponse(resp *http.Response) (DefaultSecurityRulesClientListResponse, error) { 175 result := DefaultSecurityRulesClientListResponse{} 176 if err := runtime.UnmarshalAsJSON(resp, &result.SecurityRuleListResult); err != nil { 177 return DefaultSecurityRulesClientListResponse{}, err 178 } 179 return result, nil 180 }