1// Code generated by smithy-go-codegen DO NOT EDIT.
2
3package codecommit
4
5import (
6	"context"
7	"fmt"
8	awsmiddleware "github.com/aws/aws-sdk-go-v2/aws/middleware"
9	"github.com/aws/aws-sdk-go-v2/aws/signer/v4"
10	"github.com/aws/smithy-go/middleware"
11	smithyhttp "github.com/aws/smithy-go/transport/http"
12)
13
14// Lists all repositories associated with the specified approval rule template.
15func (c *Client) ListRepositoriesForApprovalRuleTemplate(ctx context.Context, params *ListRepositoriesForApprovalRuleTemplateInput, optFns ...func(*Options)) (*ListRepositoriesForApprovalRuleTemplateOutput, error) {
16	if params == nil {
17		params = &ListRepositoriesForApprovalRuleTemplateInput{}
18	}
19
20	result, metadata, err := c.invokeOperation(ctx, "ListRepositoriesForApprovalRuleTemplate", params, optFns, c.addOperationListRepositoriesForApprovalRuleTemplateMiddlewares)
21	if err != nil {
22		return nil, err
23	}
24
25	out := result.(*ListRepositoriesForApprovalRuleTemplateOutput)
26	out.ResultMetadata = metadata
27	return out, nil
28}
29
30type ListRepositoriesForApprovalRuleTemplateInput struct {
31
32	// The name of the approval rule template for which you want to list repositories
33	// that are associated with that template.
34	//
35	// This member is required.
36	ApprovalRuleTemplateName *string
37
38	// A non-zero, non-negative integer used to limit the number of returned results.
39	MaxResults *int32
40
41	// An enumeration token that, when provided in a request, returns the next batch of
42	// the results.
43	NextToken *string
44
45	noSmithyDocumentSerde
46}
47
48type ListRepositoriesForApprovalRuleTemplateOutput struct {
49
50	// An enumeration token that allows the operation to batch the next results of the
51	// operation.
52	NextToken *string
53
54	// A list of repository names that are associated with the specified approval rule
55	// template.
56	RepositoryNames []string
57
58	// Metadata pertaining to the operation's result.
59	ResultMetadata middleware.Metadata
60
61	noSmithyDocumentSerde
62}
63
64func (c *Client) addOperationListRepositoriesForApprovalRuleTemplateMiddlewares(stack *middleware.Stack, options Options) (err error) {
65	err = stack.Serialize.Add(&awsAwsjson11_serializeOpListRepositoriesForApprovalRuleTemplate{}, middleware.After)
66	if err != nil {
67		return err
68	}
69	err = stack.Deserialize.Add(&awsAwsjson11_deserializeOpListRepositoriesForApprovalRuleTemplate{}, middleware.After)
70	if err != nil {
71		return err
72	}
73	if err = addSetLoggerMiddleware(stack, options); err != nil {
74		return err
75	}
76	if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil {
77		return err
78	}
79	if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil {
80		return err
81	}
82	if err = addResolveEndpointMiddleware(stack, options); err != nil {
83		return err
84	}
85	if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil {
86		return err
87	}
88	if err = addRetryMiddlewares(stack, options); err != nil {
89		return err
90	}
91	if err = addHTTPSignerV4Middleware(stack, options); err != nil {
92		return err
93	}
94	if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil {
95		return err
96	}
97	if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil {
98		return err
99	}
100	if err = addClientUserAgent(stack); err != nil {
101		return err
102	}
103	if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
104		return err
105	}
106	if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
107		return err
108	}
109	if err = addOpListRepositoriesForApprovalRuleTemplateValidationMiddleware(stack); err != nil {
110		return err
111	}
112	if err = stack.Initialize.Add(newServiceMetadataMiddleware_opListRepositoriesForApprovalRuleTemplate(options.Region), middleware.Before); err != nil {
113		return err
114	}
115	if err = addRequestIDRetrieverMiddleware(stack); err != nil {
116		return err
117	}
118	if err = addResponseErrorMiddleware(stack); err != nil {
119		return err
120	}
121	if err = addRequestResponseLogging(stack, options); err != nil {
122		return err
123	}
124	return nil
125}
126
127// ListRepositoriesForApprovalRuleTemplateAPIClient is a client that implements the
128// ListRepositoriesForApprovalRuleTemplate operation.
129type ListRepositoriesForApprovalRuleTemplateAPIClient interface {
130	ListRepositoriesForApprovalRuleTemplate(context.Context, *ListRepositoriesForApprovalRuleTemplateInput, ...func(*Options)) (*ListRepositoriesForApprovalRuleTemplateOutput, error)
131}
132
133var _ ListRepositoriesForApprovalRuleTemplateAPIClient = (*Client)(nil)
134
135// ListRepositoriesForApprovalRuleTemplatePaginatorOptions is the paginator options
136// for ListRepositoriesForApprovalRuleTemplate
137type ListRepositoriesForApprovalRuleTemplatePaginatorOptions struct {
138	// A non-zero, non-negative integer used to limit the number of returned results.
139	Limit int32
140
141	// Set to true if pagination should stop if the service returns a pagination token
142	// that matches the most recent token provided to the service.
143	StopOnDuplicateToken bool
144}
145
146// ListRepositoriesForApprovalRuleTemplatePaginator is a paginator for
147// ListRepositoriesForApprovalRuleTemplate
148type ListRepositoriesForApprovalRuleTemplatePaginator struct {
149	options   ListRepositoriesForApprovalRuleTemplatePaginatorOptions
150	client    ListRepositoriesForApprovalRuleTemplateAPIClient
151	params    *ListRepositoriesForApprovalRuleTemplateInput
152	nextToken *string
153	firstPage bool
154}
155
156// NewListRepositoriesForApprovalRuleTemplatePaginator returns a new
157// ListRepositoriesForApprovalRuleTemplatePaginator
158func NewListRepositoriesForApprovalRuleTemplatePaginator(client ListRepositoriesForApprovalRuleTemplateAPIClient, params *ListRepositoriesForApprovalRuleTemplateInput, optFns ...func(*ListRepositoriesForApprovalRuleTemplatePaginatorOptions)) *ListRepositoriesForApprovalRuleTemplatePaginator {
159	if params == nil {
160		params = &ListRepositoriesForApprovalRuleTemplateInput{}
161	}
162
163	options := ListRepositoriesForApprovalRuleTemplatePaginatorOptions{}
164	if params.MaxResults != nil {
165		options.Limit = *params.MaxResults
166	}
167
168	for _, fn := range optFns {
169		fn(&options)
170	}
171
172	return &ListRepositoriesForApprovalRuleTemplatePaginator{
173		options:   options,
174		client:    client,
175		params:    params,
176		firstPage: true,
177	}
178}
179
180// HasMorePages returns a boolean indicating whether more pages are available
181func (p *ListRepositoriesForApprovalRuleTemplatePaginator) HasMorePages() bool {
182	return p.firstPage || p.nextToken != nil
183}
184
185// NextPage retrieves the next ListRepositoriesForApprovalRuleTemplate page.
186func (p *ListRepositoriesForApprovalRuleTemplatePaginator) NextPage(ctx context.Context, optFns ...func(*Options)) (*ListRepositoriesForApprovalRuleTemplateOutput, error) {
187	if !p.HasMorePages() {
188		return nil, fmt.Errorf("no more pages available")
189	}
190
191	params := *p.params
192	params.NextToken = p.nextToken
193
194	var limit *int32
195	if p.options.Limit > 0 {
196		limit = &p.options.Limit
197	}
198	params.MaxResults = limit
199
200	result, err := p.client.ListRepositoriesForApprovalRuleTemplate(ctx, &params, optFns...)
201	if err != nil {
202		return nil, err
203	}
204	p.firstPage = false
205
206	prevToken := p.nextToken
207	p.nextToken = result.NextToken
208
209	if p.options.StopOnDuplicateToken && prevToken != nil && p.nextToken != nil && *prevToken == *p.nextToken {
210		p.nextToken = nil
211	}
212
213	return result, nil
214}
215
216func newServiceMetadataMiddleware_opListRepositoriesForApprovalRuleTemplate(region string) *awsmiddleware.RegisterServiceMetadata {
217	return &awsmiddleware.RegisterServiceMetadata{
218		Region:        region,
219		ServiceID:     ServiceID,
220		SigningName:   "codecommit",
221		OperationName: "ListRepositoriesForApprovalRuleTemplate",
222	}
223}
224