src

Go monorepo.
git clone git://code.dwrz.net/src
Log | Files | Refs

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, &params, 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 }