1// Code generated by smithy-go-codegen DO NOT EDIT.
2
3package guardduty
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/aws-sdk-go-v2/service/guardduty/types"
11	"github.com/aws/smithy-go/middleware"
12	smithyhttp "github.com/aws/smithy-go/transport/http"
13)
14
15// Creates a new IPSet, which is called a trusted IP list in the console user
16// interface. An IPSet is a list of IP addresses that are trusted for secure
17// communication with AWS infrastructure and applications. GuardDuty doesn't
18// generate findings for IP addresses that are included in IPSets. Only users from
19// the administrator account can use this operation.
20func (c *Client) CreateIPSet(ctx context.Context, params *CreateIPSetInput, optFns ...func(*Options)) (*CreateIPSetOutput, error) {
21	if params == nil {
22		params = &CreateIPSetInput{}
23	}
24
25	result, metadata, err := c.invokeOperation(ctx, "CreateIPSet", params, optFns, addOperationCreateIPSetMiddlewares)
26	if err != nil {
27		return nil, err
28	}
29
30	out := result.(*CreateIPSetOutput)
31	out.ResultMetadata = metadata
32	return out, nil
33}
34
35type CreateIPSetInput struct {
36
37	// A Boolean value that indicates whether GuardDuty is to start using the uploaded
38	// IPSet.
39	//
40	// This member is required.
41	Activate bool
42
43	// The unique ID of the detector of the GuardDuty account that you want to create
44	// an IPSet for.
45	//
46	// This member is required.
47	DetectorId *string
48
49	// The format of the file that contains the IPSet.
50	//
51	// This member is required.
52	Format types.IpSetFormat
53
54	// The URI of the file that contains the IPSet. For example:
55	// https://s3.us-west-2.amazonaws.com/my-bucket/my-object-key.
56	//
57	// This member is required.
58	Location *string
59
60	// The user-friendly name to identify the IPSet. Allowed characters are
61	// alphanumerics, spaces, hyphens (-), and underscores (_).
62	//
63	// This member is required.
64	Name *string
65
66	// The idempotency token for the create request.
67	ClientToken *string
68
69	// The tags to be added to a new IP set resource.
70	Tags map[string]string
71}
72
73type CreateIPSetOutput struct {
74
75	// The ID of the IPSet resource.
76	//
77	// This member is required.
78	IpSetId *string
79
80	// Metadata pertaining to the operation's result.
81	ResultMetadata middleware.Metadata
82}
83
84func addOperationCreateIPSetMiddlewares(stack *middleware.Stack, options Options) (err error) {
85	err = stack.Serialize.Add(&awsRestjson1_serializeOpCreateIPSet{}, middleware.After)
86	if err != nil {
87		return err
88	}
89	err = stack.Deserialize.Add(&awsRestjson1_deserializeOpCreateIPSet{}, middleware.After)
90	if err != nil {
91		return err
92	}
93	if err = addSetLoggerMiddleware(stack, options); err != nil {
94		return err
95	}
96	if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil {
97		return err
98	}
99	if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil {
100		return err
101	}
102	if err = addResolveEndpointMiddleware(stack, options); err != nil {
103		return err
104	}
105	if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil {
106		return err
107	}
108	if err = addRetryMiddlewares(stack, options); err != nil {
109		return err
110	}
111	if err = addHTTPSignerV4Middleware(stack, options); err != nil {
112		return err
113	}
114	if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil {
115		return err
116	}
117	if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil {
118		return err
119	}
120	if err = addClientUserAgent(stack); err != nil {
121		return err
122	}
123	if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
124		return err
125	}
126	if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
127		return err
128	}
129	if err = addIdempotencyToken_opCreateIPSetMiddleware(stack, options); err != nil {
130		return err
131	}
132	if err = addOpCreateIPSetValidationMiddleware(stack); err != nil {
133		return err
134	}
135	if err = stack.Initialize.Add(newServiceMetadataMiddleware_opCreateIPSet(options.Region), middleware.Before); err != nil {
136		return err
137	}
138	if err = addRequestIDRetrieverMiddleware(stack); err != nil {
139		return err
140	}
141	if err = addResponseErrorMiddleware(stack); err != nil {
142		return err
143	}
144	if err = addRequestResponseLogging(stack, options); err != nil {
145		return err
146	}
147	return nil
148}
149
150type idempotencyToken_initializeOpCreateIPSet struct {
151	tokenProvider IdempotencyTokenProvider
152}
153
154func (*idempotencyToken_initializeOpCreateIPSet) ID() string {
155	return "OperationIdempotencyTokenAutoFill"
156}
157
158func (m *idempotencyToken_initializeOpCreateIPSet) HandleInitialize(ctx context.Context, in middleware.InitializeInput, next middleware.InitializeHandler) (
159	out middleware.InitializeOutput, metadata middleware.Metadata, err error,
160) {
161	if m.tokenProvider == nil {
162		return next.HandleInitialize(ctx, in)
163	}
164
165	input, ok := in.Parameters.(*CreateIPSetInput)
166	if !ok {
167		return out, metadata, fmt.Errorf("expected middleware input to be of type *CreateIPSetInput ")
168	}
169
170	if input.ClientToken == nil {
171		t, err := m.tokenProvider.GetIdempotencyToken()
172		if err != nil {
173			return out, metadata, err
174		}
175		input.ClientToken = &t
176	}
177	return next.HandleInitialize(ctx, in)
178}
179func addIdempotencyToken_opCreateIPSetMiddleware(stack *middleware.Stack, cfg Options) error {
180	return stack.Initialize.Add(&idempotencyToken_initializeOpCreateIPSet{tokenProvider: cfg.IdempotencyTokenProvider}, middleware.Before)
181}
182
183func newServiceMetadataMiddleware_opCreateIPSet(region string) *awsmiddleware.RegisterServiceMetadata {
184	return &awsmiddleware.RegisterServiceMetadata{
185		Region:        region,
186		ServiceID:     ServiceID,
187		SigningName:   "guardduty",
188		OperationName: "CreateIPSet",
189	}
190}
191