1package frontdoor 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// 6// Code generated by Microsoft (R) AutoRest Code Generator. 7// Changes may cause incorrect behavior and will be lost if the code is regenerated. 8 9import ( 10 "context" 11 "github.com/Azure/go-autorest/autorest" 12 "github.com/Azure/go-autorest/autorest/azure" 13 "github.com/Azure/go-autorest/tracing" 14 "net/http" 15) 16 17// ManagedRuleSetsClient is the frontDoor Client 18type ManagedRuleSetsClient struct { 19 BaseClient 20} 21 22// NewManagedRuleSetsClient creates an instance of the ManagedRuleSetsClient client. 23func NewManagedRuleSetsClient(subscriptionID string) ManagedRuleSetsClient { 24 return NewManagedRuleSetsClientWithBaseURI(DefaultBaseURI, subscriptionID) 25} 26 27// NewManagedRuleSetsClientWithBaseURI creates an instance of the ManagedRuleSetsClient client using a custom endpoint. 28// Use this when interacting with an Azure cloud that uses a non-standard base URI (sovereign clouds, Azure stack). 29func NewManagedRuleSetsClientWithBaseURI(baseURI string, subscriptionID string) ManagedRuleSetsClient { 30 return ManagedRuleSetsClient{NewWithBaseURI(baseURI, subscriptionID)} 31} 32 33// List lists all available managed rule sets. 34func (client ManagedRuleSetsClient) List(ctx context.Context) (result ManagedRuleSetDefinitionListPage, err error) { 35 if tracing.IsEnabled() { 36 ctx = tracing.StartSpan(ctx, fqdn+"/ManagedRuleSetsClient.List") 37 defer func() { 38 sc := -1 39 if result.mrsdl.Response.Response != nil { 40 sc = result.mrsdl.Response.Response.StatusCode 41 } 42 tracing.EndSpan(ctx, sc, err) 43 }() 44 } 45 result.fn = client.listNextResults 46 req, err := client.ListPreparer(ctx) 47 if err != nil { 48 err = autorest.NewErrorWithError(err, "frontdoor.ManagedRuleSetsClient", "List", nil, "Failure preparing request") 49 return 50 } 51 52 resp, err := client.ListSender(req) 53 if err != nil { 54 result.mrsdl.Response = autorest.Response{Response: resp} 55 err = autorest.NewErrorWithError(err, "frontdoor.ManagedRuleSetsClient", "List", resp, "Failure sending request") 56 return 57 } 58 59 result.mrsdl, err = client.ListResponder(resp) 60 if err != nil { 61 err = autorest.NewErrorWithError(err, "frontdoor.ManagedRuleSetsClient", "List", resp, "Failure responding to request") 62 return 63 } 64 if result.mrsdl.hasNextLink() && result.mrsdl.IsEmpty() { 65 err = result.NextWithContext(ctx) 66 return 67 } 68 69 return 70} 71 72// ListPreparer prepares the List request. 73func (client ManagedRuleSetsClient) ListPreparer(ctx context.Context) (*http.Request, error) { 74 pathParameters := map[string]interface{}{ 75 "subscriptionId": autorest.Encode("path", client.SubscriptionID), 76 } 77 78 const APIVersion = "2019-10-01" 79 queryParameters := map[string]interface{}{ 80 "api-version": APIVersion, 81 } 82 83 preparer := autorest.CreatePreparer( 84 autorest.AsGet(), 85 autorest.WithBaseURL(client.BaseURI), 86 autorest.WithPathParameters("/subscriptions/{subscriptionId}/providers/Microsoft.Network/FrontDoorWebApplicationFirewallManagedRuleSets", pathParameters), 87 autorest.WithQueryParameters(queryParameters)) 88 return preparer.Prepare((&http.Request{}).WithContext(ctx)) 89} 90 91// ListSender sends the List request. The method will close the 92// http.Response Body if it receives an error. 93func (client ManagedRuleSetsClient) ListSender(req *http.Request) (*http.Response, error) { 94 return client.Send(req, azure.DoRetryWithRegistration(client.Client)) 95} 96 97// ListResponder handles the response to the List request. The method always 98// closes the http.Response Body. 99func (client ManagedRuleSetsClient) ListResponder(resp *http.Response) (result ManagedRuleSetDefinitionList, err error) { 100 err = autorest.Respond( 101 resp, 102 azure.WithErrorUnlessStatusCode(http.StatusOK), 103 autorest.ByUnmarshallingJSON(&result), 104 autorest.ByClosing()) 105 result.Response = autorest.Response{Response: resp} 106 return 107} 108 109// listNextResults retrieves the next set of results, if any. 110func (client ManagedRuleSetsClient) listNextResults(ctx context.Context, lastResults ManagedRuleSetDefinitionList) (result ManagedRuleSetDefinitionList, err error) { 111 req, err := lastResults.managedRuleSetDefinitionListPreparer(ctx) 112 if err != nil { 113 return result, autorest.NewErrorWithError(err, "frontdoor.ManagedRuleSetsClient", "listNextResults", nil, "Failure preparing next results request") 114 } 115 if req == nil { 116 return 117 } 118 resp, err := client.ListSender(req) 119 if err != nil { 120 result.Response = autorest.Response{Response: resp} 121 return result, autorest.NewErrorWithError(err, "frontdoor.ManagedRuleSetsClient", "listNextResults", resp, "Failure sending next results request") 122 } 123 result, err = client.ListResponder(resp) 124 if err != nil { 125 err = autorest.NewErrorWithError(err, "frontdoor.ManagedRuleSetsClient", "listNextResults", resp, "Failure responding to next results request") 126 } 127 return 128} 129 130// ListComplete enumerates all values, automatically crossing page boundaries as required. 131func (client ManagedRuleSetsClient) ListComplete(ctx context.Context) (result ManagedRuleSetDefinitionListIterator, err error) { 132 if tracing.IsEnabled() { 133 ctx = tracing.StartSpan(ctx, fqdn+"/ManagedRuleSetsClient.List") 134 defer func() { 135 sc := -1 136 if result.Response().Response.Response != nil { 137 sc = result.page.Response().Response.Response.StatusCode 138 } 139 tracing.EndSpan(ctx, sc, err) 140 }() 141 } 142 result.page, err = client.List(ctx) 143 return 144} 145