-
Notifications
You must be signed in to change notification settings - Fork 626
/
api_op_ListTagsForResource.go
149 lines (123 loc) · 4.82 KB
/
api_op_ListTagsForResource.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
package wafv2
import (
"context"
"github.com/aws/aws-sdk-go-v2/aws"
"github.com/aws/aws-sdk-go-v2/internal/awsutil"
)
type ListTagsForResourceInput struct {
_ struct{} `type:"structure"`
// The maximum number of objects that you want AWS WAF to return for this request.
// If more objects are available, in the response, AWS WAF provides a NextMarker
// value that you can use in a subsequent call to get the next batch of objects.
Limit *int64 `min:"1" type:"integer"`
// When you request a list of objects with a Limit setting, if the number of
// objects that are still available for retrieval exceeds the limit, AWS WAF
// returns a NextMarker value in the response. To retrieve the next batch of
// objects, provide the marker from the prior call in your next request.
NextMarker *string `min:"1" type:"string"`
// The Amazon Resource Name (ARN) of the resource.
//
// ResourceARN is a required field
ResourceARN *string `min:"20" type:"string" required:"true"`
}
// String returns the string representation
func (s ListTagsForResourceInput) String() string {
return awsutil.Prettify(s)
}
// Validate inspects the fields of the type to determine if they are valid.
func (s *ListTagsForResourceInput) Validate() error {
invalidParams := aws.ErrInvalidParams{Context: "ListTagsForResourceInput"}
if s.Limit != nil && *s.Limit < 1 {
invalidParams.Add(aws.NewErrParamMinValue("Limit", 1))
}
if s.NextMarker != nil && len(*s.NextMarker) < 1 {
invalidParams.Add(aws.NewErrParamMinLen("NextMarker", 1))
}
if s.ResourceARN == nil {
invalidParams.Add(aws.NewErrParamRequired("ResourceARN"))
}
if s.ResourceARN != nil && len(*s.ResourceARN) < 20 {
invalidParams.Add(aws.NewErrParamMinLen("ResourceARN", 20))
}
if invalidParams.Len() > 0 {
return invalidParams
}
return nil
}
type ListTagsForResourceOutput struct {
_ struct{} `type:"structure"`
// When you request a list of objects with a Limit setting, if the number of
// objects that are still available for retrieval exceeds the limit, AWS WAF
// returns a NextMarker value in the response. To retrieve the next batch of
// objects, provide the marker from the prior call in your next request.
NextMarker *string `min:"1" type:"string"`
// The collection of tagging definitions for the resource.
TagInfoForResource *TagInfoForResource `type:"structure"`
}
// String returns the string representation
func (s ListTagsForResourceOutput) String() string {
return awsutil.Prettify(s)
}
const opListTagsForResource = "ListTagsForResource"
// ListTagsForResourceRequest returns a request value for making API operation for
// AWS WAFV2.
//
//
// This is the latest version of AWS WAF, named AWS WAFV2, released in November,
// 2019. For information, including how to migrate your AWS WAF resources from
// the prior release, see the AWS WAF Developer Guide (https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html).
//
// Retrieves the TagInfoForResource for the specified resource.
//
// // Example sending a request using ListTagsForResourceRequest.
// req := client.ListTagsForResourceRequest(params)
// resp, err := req.Send(context.TODO())
// if err == nil {
// fmt.Println(resp)
// }
//
// Please also see https://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListTagsForResource
func (c *Client) ListTagsForResourceRequest(input *ListTagsForResourceInput) ListTagsForResourceRequest {
op := &aws.Operation{
Name: opListTagsForResource,
HTTPMethod: "POST",
HTTPPath: "/",
}
if input == nil {
input = &ListTagsForResourceInput{}
}
req := c.newRequest(op, input, &ListTagsForResourceOutput{})
return ListTagsForResourceRequest{Request: req, Input: input, Copy: c.ListTagsForResourceRequest}
}
// ListTagsForResourceRequest is the request type for the
// ListTagsForResource API operation.
type ListTagsForResourceRequest struct {
*aws.Request
Input *ListTagsForResourceInput
Copy func(*ListTagsForResourceInput) ListTagsForResourceRequest
}
// Send marshals and sends the ListTagsForResource API request.
func (r ListTagsForResourceRequest) Send(ctx context.Context) (*ListTagsForResourceResponse, error) {
r.Request.SetContext(ctx)
err := r.Request.Send()
if err != nil {
return nil, err
}
resp := &ListTagsForResourceResponse{
ListTagsForResourceOutput: r.Request.Data.(*ListTagsForResourceOutput),
response: &aws.Response{Request: r.Request},
}
return resp, nil
}
// ListTagsForResourceResponse is the response type for the
// ListTagsForResource API operation.
type ListTagsForResourceResponse struct {
*ListTagsForResourceOutput
response *aws.Response
}
// SDKResponseMetdata returns the response metadata for the
// ListTagsForResource request.
func (r *ListTagsForResourceResponse) SDKResponseMetdata() *aws.Response {
return r.response
}