/
api_op_ModifySnapshotCopyRetentionPeriod.go
116 lines (103 loc) · 4.89 KB
/
api_op_ModifySnapshotCopyRetentionPeriod.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
// Code generated by smithy-go-codegen DO NOT EDIT.
package redshift
import (
"context"
awsmiddleware "github.com/aws/aws-sdk-go-v2/aws/middleware"
"github.com/aws/aws-sdk-go-v2/aws/retry"
"github.com/aws/aws-sdk-go-v2/aws/signer/v4"
"github.com/aws/aws-sdk-go-v2/service/redshift/types"
smithy "github.com/awslabs/smithy-go"
"github.com/awslabs/smithy-go/middleware"
smithyhttp "github.com/awslabs/smithy-go/transport/http"
)
// Modifies the number of days to retain snapshots in the destination AWS Region
// after they are copied from the source AWS Region. By default, this operation
// only changes the retention period of copied automated snapshots. The retention
// periods for both new and existing copied automated snapshots are updated with
// the new retention period. You can set the manual option to change only the
// retention periods of copied manual snapshots. If you set this option, only newly
// copied manual snapshots have the new retention period.
func (c *Client) ModifySnapshotCopyRetentionPeriod(ctx context.Context, params *ModifySnapshotCopyRetentionPeriodInput, optFns ...func(*Options)) (*ModifySnapshotCopyRetentionPeriodOutput, error) {
stack := middleware.NewStack("ModifySnapshotCopyRetentionPeriod", smithyhttp.NewStackRequest)
options := c.options.Copy()
for _, fn := range optFns {
fn(&options)
}
addawsAwsquery_serdeOpModifySnapshotCopyRetentionPeriodMiddlewares(stack)
awsmiddleware.AddRequestInvocationIDMiddleware(stack)
smithyhttp.AddContentLengthMiddleware(stack)
AddResolveEndpointMiddleware(stack, options)
v4.AddComputePayloadSHA256Middleware(stack)
retry.AddRetryMiddlewares(stack, options)
addHTTPSignerV4Middleware(stack, options)
awsmiddleware.AddAttemptClockSkewMiddleware(stack)
addClientUserAgent(stack)
smithyhttp.AddErrorCloseResponseBodyMiddleware(stack)
smithyhttp.AddCloseResponseBodyMiddleware(stack)
addOpModifySnapshotCopyRetentionPeriodValidationMiddleware(stack)
stack.Initialize.Add(newServiceMetadataMiddleware_opModifySnapshotCopyRetentionPeriod(options.Region), middleware.Before)
addRequestIDRetrieverMiddleware(stack)
addResponseErrorMiddleware(stack)
for _, fn := range options.APIOptions {
if err := fn(stack); err != nil {
return nil, err
}
}
handler := middleware.DecorateHandler(smithyhttp.NewClientHandler(options.HTTPClient), stack)
result, metadata, err := handler.Handle(ctx, params)
if err != nil {
return nil, &smithy.OperationError{
ServiceID: ServiceID,
OperationName: "ModifySnapshotCopyRetentionPeriod",
Err: err,
}
}
out := result.(*ModifySnapshotCopyRetentionPeriodOutput)
out.ResultMetadata = metadata
return out, nil
}
//
type ModifySnapshotCopyRetentionPeriodInput struct {
// The unique identifier of the cluster for which you want to change the retention
// period for either automated or manual snapshots that are copied to a destination
// AWS Region. Constraints: Must be the valid name of an existing cluster that has
// cross-region snapshot copy enabled.
//
// This member is required.
ClusterIdentifier *string
// The number of days to retain automated snapshots in the destination AWS Region
// after they are copied from the source AWS Region. By default, this only changes
// the retention period of copied automated snapshots. If you decrease the
// retention period for automated snapshots that are copied to a destination AWS
// Region, Amazon Redshift deletes any existing automated snapshots that were
// copied to the destination AWS Region and that fall outside of the new retention
// period. Constraints: Must be at least 1 and no more than 35 for automated
// snapshots. If you specify the manual option, only newly copied manual snapshots
// will have the new retention period. If you specify the value of -1 newly copied
// manual snapshots are retained indefinitely. Constraints: The number of days must
// be either -1 or an integer between 1 and 3,653 for manual snapshots.
//
// This member is required.
RetentionPeriod *int32
// Indicates whether to apply the snapshot retention period to newly copied manual
// snapshots instead of automated snapshots.
Manual *bool
}
type ModifySnapshotCopyRetentionPeriodOutput struct {
// Describes a cluster.
Cluster *types.Cluster
// Metadata pertaining to the operation's result.
ResultMetadata middleware.Metadata
}
func addawsAwsquery_serdeOpModifySnapshotCopyRetentionPeriodMiddlewares(stack *middleware.Stack) {
stack.Serialize.Add(&awsAwsquery_serializeOpModifySnapshotCopyRetentionPeriod{}, middleware.After)
stack.Deserialize.Add(&awsAwsquery_deserializeOpModifySnapshotCopyRetentionPeriod{}, middleware.After)
}
func newServiceMetadataMiddleware_opModifySnapshotCopyRetentionPeriod(region string) awsmiddleware.RegisterServiceMetadata {
return awsmiddleware.RegisterServiceMetadata{
Region: region,
ServiceID: ServiceID,
SigningName: "redshift",
OperationName: "ModifySnapshotCopyRetentionPeriod",
}
}