1package cdn 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// ResourceUsageClient is the cdn Management Client 18type ResourceUsageClient struct { 19 BaseClient 20} 21 22// NewResourceUsageClient creates an instance of the ResourceUsageClient client. 23func NewResourceUsageClient(subscriptionID string) ResourceUsageClient { 24 return NewResourceUsageClientWithBaseURI(DefaultBaseURI, subscriptionID) 25} 26 27// NewResourceUsageClientWithBaseURI creates an instance of the ResourceUsageClient 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 NewResourceUsageClientWithBaseURI(baseURI string, subscriptionID string) ResourceUsageClient { 30 return ResourceUsageClient{NewWithBaseURI(baseURI, subscriptionID)} 31} 32 33// List check the quota and actual usage of the CDN profiles under the given subscription. 34func (client ResourceUsageClient) List(ctx context.Context) (result ResourceUsageListResultPage, err error) { 35 if tracing.IsEnabled() { 36 ctx = tracing.StartSpan(ctx, fqdn+"/ResourceUsageClient.List") 37 defer func() { 38 sc := -1 39 if result.rulr.Response.Response != nil { 40 sc = result.rulr.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, "cdn.ResourceUsageClient", "List", nil, "Failure preparing request") 49 return 50 } 51 52 resp, err := client.ListSender(req) 53 if err != nil { 54 result.rulr.Response = autorest.Response{Response: resp} 55 err = autorest.NewErrorWithError(err, "cdn.ResourceUsageClient", "List", resp, "Failure sending request") 56 return 57 } 58 59 result.rulr, err = client.ListResponder(resp) 60 if err != nil { 61 err = autorest.NewErrorWithError(err, "cdn.ResourceUsageClient", "List", resp, "Failure responding to request") 62 return 63 } 64 if result.rulr.hasNextLink() && result.rulr.IsEmpty() { 65 err = result.NextWithContext(ctx) 66 return 67 } 68 69 return 70} 71 72// ListPreparer prepares the List request. 73func (client ResourceUsageClient) 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-04-15" 79 queryParameters := map[string]interface{}{ 80 "api-version": APIVersion, 81 } 82 83 preparer := autorest.CreatePreparer( 84 autorest.AsPost(), 85 autorest.WithBaseURL(client.BaseURI), 86 autorest.WithPathParameters("/subscriptions/{subscriptionId}/providers/Microsoft.Cdn/checkResourceUsage", 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 ResourceUsageClient) 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 ResourceUsageClient) ListResponder(resp *http.Response) (result ResourceUsageListResult, 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 ResourceUsageClient) listNextResults(ctx context.Context, lastResults ResourceUsageListResult) (result ResourceUsageListResult, err error) { 111 req, err := lastResults.resourceUsageListResultPreparer(ctx) 112 if err != nil { 113 return result, autorest.NewErrorWithError(err, "cdn.ResourceUsageClient", "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, "cdn.ResourceUsageClient", "listNextResults", resp, "Failure sending next results request") 122 } 123 result, err = client.ListResponder(resp) 124 if err != nil { 125 err = autorest.NewErrorWithError(err, "cdn.ResourceUsageClient", "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 ResourceUsageClient) ListComplete(ctx context.Context) (result ResourceUsageListResultIterator, err error) { 132 if tracing.IsEnabled() { 133 ctx = tracing.StartSpan(ctx, fqdn+"/ResourceUsageClient.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