api_op_ListCidrCollections.go (8313B)
1 // Code generated by smithy-go-codegen DO NOT EDIT. 2 3 package route53 4 5 import ( 6 "context" 7 "fmt" 8 awsmiddleware "github.com/aws/aws-sdk-go-v2/aws/middleware" 9 "github.com/aws/aws-sdk-go-v2/service/route53/types" 10 "github.com/aws/smithy-go/middleware" 11 smithyhttp "github.com/aws/smithy-go/transport/http" 12 ) 13 14 // Returns a paginated list of CIDR collections in the Amazon Web Services account 15 // (metadata only). 16 func (c *Client) ListCidrCollections(ctx context.Context, params *ListCidrCollectionsInput, optFns ...func(*Options)) (*ListCidrCollectionsOutput, error) { 17 if params == nil { 18 params = &ListCidrCollectionsInput{} 19 } 20 21 result, metadata, err := c.invokeOperation(ctx, "ListCidrCollections", params, optFns, c.addOperationListCidrCollectionsMiddlewares) 22 if err != nil { 23 return nil, err 24 } 25 26 out := result.(*ListCidrCollectionsOutput) 27 out.ResultMetadata = metadata 28 return out, nil 29 } 30 31 type ListCidrCollectionsInput struct { 32 33 // The maximum number of CIDR collections to return in the response. 34 MaxResults *int32 35 36 // An opaque pagination token to indicate where the service is to begin 37 // enumerating results. 38 // 39 // If no value is provided, the listing of results starts from the beginning. 40 NextToken *string 41 42 noSmithyDocumentSerde 43 } 44 45 type ListCidrCollectionsOutput struct { 46 47 // A complex type with information about the CIDR collection. 48 CidrCollections []types.CollectionSummary 49 50 // An opaque pagination token to indicate where the service is to begin 51 // enumerating results. 52 // 53 // If no value is provided, the listing of results starts from the beginning. 54 NextToken *string 55 56 // Metadata pertaining to the operation's result. 57 ResultMetadata middleware.Metadata 58 59 noSmithyDocumentSerde 60 } 61 62 func (c *Client) addOperationListCidrCollectionsMiddlewares(stack *middleware.Stack, options Options) (err error) { 63 if err := stack.Serialize.Add(&setOperationInputMiddleware{}, middleware.After); err != nil { 64 return err 65 } 66 err = stack.Serialize.Add(&awsRestxml_serializeOpListCidrCollections{}, middleware.After) 67 if err != nil { 68 return err 69 } 70 err = stack.Deserialize.Add(&awsRestxml_deserializeOpListCidrCollections{}, middleware.After) 71 if err != nil { 72 return err 73 } 74 if err := addProtocolFinalizerMiddlewares(stack, options, "ListCidrCollections"); err != nil { 75 return fmt.Errorf("add protocol finalizers: %v", err) 76 } 77 78 if err = addlegacyEndpointContextSetter(stack, options); err != nil { 79 return err 80 } 81 if err = addSetLoggerMiddleware(stack, options); err != nil { 82 return err 83 } 84 if err = addClientRequestID(stack); err != nil { 85 return err 86 } 87 if err = addComputeContentLength(stack); err != nil { 88 return err 89 } 90 if err = addResolveEndpointMiddleware(stack, options); err != nil { 91 return err 92 } 93 if err = addComputePayloadSHA256(stack); err != nil { 94 return err 95 } 96 if err = addRetry(stack, options); err != nil { 97 return err 98 } 99 if err = addRawResponseToMetadata(stack); err != nil { 100 return err 101 } 102 if err = addRecordResponseTiming(stack); err != nil { 103 return err 104 } 105 if err = addSpanRetryLoop(stack, options); err != nil { 106 return err 107 } 108 if err = addClientUserAgent(stack, options); err != nil { 109 return err 110 } 111 if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil { 112 return err 113 } 114 if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil { 115 return err 116 } 117 if err = addSetLegacyContextSigningOptionsMiddleware(stack); err != nil { 118 return err 119 } 120 if err = addTimeOffsetBuild(stack, c); err != nil { 121 return err 122 } 123 if err = addUserAgentRetryMode(stack, options); err != nil { 124 return err 125 } 126 if err = addCredentialSource(stack, options); err != nil { 127 return err 128 } 129 if err = stack.Initialize.Add(newServiceMetadataMiddleware_opListCidrCollections(options.Region), middleware.Before); err != nil { 130 return err 131 } 132 if err = addRecursionDetection(stack); err != nil { 133 return err 134 } 135 if err = addRequestIDRetrieverMiddleware(stack); err != nil { 136 return err 137 } 138 if err = addResponseErrorMiddleware(stack); err != nil { 139 return err 140 } 141 if err = addRequestResponseLogging(stack, options); err != nil { 142 return err 143 } 144 if err = addDisableHTTPSMiddleware(stack, options); err != nil { 145 return err 146 } 147 if err = addInterceptBeforeRetryLoop(stack, options); err != nil { 148 return err 149 } 150 if err = addInterceptAttempt(stack, options); err != nil { 151 return err 152 } 153 if err = addInterceptExecution(stack, options); err != nil { 154 return err 155 } 156 if err = addInterceptBeforeSerialization(stack, options); err != nil { 157 return err 158 } 159 if err = addInterceptAfterSerialization(stack, options); err != nil { 160 return err 161 } 162 if err = addInterceptBeforeSigning(stack, options); err != nil { 163 return err 164 } 165 if err = addInterceptAfterSigning(stack, options); err != nil { 166 return err 167 } 168 if err = addInterceptTransmit(stack, options); err != nil { 169 return err 170 } 171 if err = addInterceptBeforeDeserialization(stack, options); err != nil { 172 return err 173 } 174 if err = addInterceptAfterDeserialization(stack, options); err != nil { 175 return err 176 } 177 if err = addSpanInitializeStart(stack); err != nil { 178 return err 179 } 180 if err = addSpanInitializeEnd(stack); err != nil { 181 return err 182 } 183 if err = addSpanBuildRequestStart(stack); err != nil { 184 return err 185 } 186 if err = addSpanBuildRequestEnd(stack); err != nil { 187 return err 188 } 189 return nil 190 } 191 192 // ListCidrCollectionsPaginatorOptions is the paginator options for 193 // ListCidrCollections 194 type ListCidrCollectionsPaginatorOptions struct { 195 // The maximum number of CIDR collections to return in the response. 196 Limit int32 197 198 // Set to true if pagination should stop if the service returns a pagination token 199 // that matches the most recent token provided to the service. 200 StopOnDuplicateToken bool 201 } 202 203 // ListCidrCollectionsPaginator is a paginator for ListCidrCollections 204 type ListCidrCollectionsPaginator struct { 205 options ListCidrCollectionsPaginatorOptions 206 client ListCidrCollectionsAPIClient 207 params *ListCidrCollectionsInput 208 nextToken *string 209 firstPage bool 210 } 211 212 // NewListCidrCollectionsPaginator returns a new ListCidrCollectionsPaginator 213 func NewListCidrCollectionsPaginator(client ListCidrCollectionsAPIClient, params *ListCidrCollectionsInput, optFns ...func(*ListCidrCollectionsPaginatorOptions)) *ListCidrCollectionsPaginator { 214 if params == nil { 215 params = &ListCidrCollectionsInput{} 216 } 217 218 options := ListCidrCollectionsPaginatorOptions{} 219 if params.MaxResults != nil { 220 options.Limit = *params.MaxResults 221 } 222 223 for _, fn := range optFns { 224 fn(&options) 225 } 226 227 return &ListCidrCollectionsPaginator{ 228 options: options, 229 client: client, 230 params: params, 231 firstPage: true, 232 nextToken: params.NextToken, 233 } 234 } 235 236 // HasMorePages returns a boolean indicating whether more pages are available 237 func (p *ListCidrCollectionsPaginator) HasMorePages() bool { 238 return p.firstPage || (p.nextToken != nil && len(*p.nextToken) != 0) 239 } 240 241 // NextPage retrieves the next ListCidrCollections page. 242 func (p *ListCidrCollectionsPaginator) NextPage(ctx context.Context, optFns ...func(*Options)) (*ListCidrCollectionsOutput, error) { 243 if !p.HasMorePages() { 244 return nil, fmt.Errorf("no more pages available") 245 } 246 247 params := *p.params 248 params.NextToken = p.nextToken 249 250 var limit *int32 251 if p.options.Limit > 0 { 252 limit = &p.options.Limit 253 } 254 params.MaxResults = limit 255 256 optFns = append([]func(*Options){ 257 addIsPaginatorUserAgent, 258 }, optFns...) 259 result, err := p.client.ListCidrCollections(ctx, ¶ms, optFns...) 260 if err != nil { 261 return nil, err 262 } 263 p.firstPage = false 264 265 prevToken := p.nextToken 266 p.nextToken = result.NextToken 267 268 if p.options.StopOnDuplicateToken && 269 prevToken != nil && 270 p.nextToken != nil && 271 *prevToken == *p.nextToken { 272 p.nextToken = nil 273 } 274 275 return result, nil 276 } 277 278 // ListCidrCollectionsAPIClient is a client that implements the 279 // ListCidrCollections operation. 280 type ListCidrCollectionsAPIClient interface { 281 ListCidrCollections(context.Context, *ListCidrCollectionsInput, ...func(*Options)) (*ListCidrCollectionsOutput, error) 282 } 283 284 var _ ListCidrCollectionsAPIClient = (*Client)(nil) 285 286 func newServiceMetadataMiddleware_opListCidrCollections(region string) *awsmiddleware.RegisterServiceMetadata { 287 return &awsmiddleware.RegisterServiceMetadata{ 288 Region: region, 289 ServiceID: ServiceID, 290 OperationName: "ListCidrCollections", 291 } 292 }