/
api_op_ModifyEventSubscription.go
156 lines (136 loc) · 5.02 KB
/
api_op_ModifyEventSubscription.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
150
151
152
153
154
155
156
// 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/signer/v4"
"github.com/aws/aws-sdk-go-v2/service/redshift/types"
"github.com/aws/smithy-go/middleware"
smithyhttp "github.com/aws/smithy-go/transport/http"
)
// Modifies an existing Amazon Redshift event notification subscription.
func (c *Client) ModifyEventSubscription(ctx context.Context, params *ModifyEventSubscriptionInput, optFns ...func(*Options)) (*ModifyEventSubscriptionOutput, error) {
if params == nil {
params = &ModifyEventSubscriptionInput{}
}
result, metadata, err := c.invokeOperation(ctx, "ModifyEventSubscription", params, optFns, c.addOperationModifyEventSubscriptionMiddlewares)
if err != nil {
return nil, err
}
out := result.(*ModifyEventSubscriptionOutput)
out.ResultMetadata = metadata
return out, nil
}
//
type ModifyEventSubscriptionInput struct {
// The name of the modified Amazon Redshift event notification subscription.
//
// This member is required.
SubscriptionName *string
// A Boolean value indicating if the subscription is enabled. true indicates the
// subscription is enabled
Enabled *bool
// Specifies the Amazon Redshift event categories to be published by the event
// notification subscription. Values: configuration, management, monitoring,
// security, pending
EventCategories []string
// Specifies the Amazon Redshift event severity to be published by the event
// notification subscription. Values: ERROR, INFO
Severity *string
// The Amazon Resource Name (ARN) of the SNS topic to be used by the event
// notification subscription.
SnsTopicArn *string
// A list of one or more identifiers of Amazon Redshift source objects. All of the
// objects must be of the same type as was specified in the source type parameter.
// The event subscription will return only events generated by the specified
// objects. If not specified, then events are returned for all objects within the
// source type specified. Example: my-cluster-1, my-cluster-2 Example:
// my-snapshot-20131010
SourceIds []string
// The type of source that will be generating the events. For example, if you want
// to be notified of events generated by a cluster, you would set this parameter to
// cluster. If this value is not specified, events are returned for all Amazon
// Redshift objects in your Amazon Web Services account. You must specify a source
// type in order to specify source IDs. Valid values: cluster,
// cluster-parameter-group, cluster-security-group, cluster-snapshot, and
// scheduled-action.
SourceType *string
noSmithyDocumentSerde
}
type ModifyEventSubscriptionOutput struct {
// Describes event subscriptions.
EventSubscription *types.EventSubscription
// Metadata pertaining to the operation's result.
ResultMetadata middleware.Metadata
noSmithyDocumentSerde
}
func (c *Client) addOperationModifyEventSubscriptionMiddlewares(stack *middleware.Stack, options Options) (err error) {
err = stack.Serialize.Add(&awsAwsquery_serializeOpModifyEventSubscription{}, middleware.After)
if err != nil {
return err
}
err = stack.Deserialize.Add(&awsAwsquery_deserializeOpModifyEventSubscription{}, middleware.After)
if err != nil {
return err
}
if err = addSetLoggerMiddleware(stack, options); err != nil {
return err
}
if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil {
return err
}
if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil {
return err
}
if err = addResolveEndpointMiddleware(stack, options); err != nil {
return err
}
if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil {
return err
}
if err = addRetryMiddlewares(stack, options); err != nil {
return err
}
if err = addHTTPSignerV4Middleware(stack, options); err != nil {
return err
}
if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil {
return err
}
if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil {
return err
}
if err = addClientUserAgent(stack); err != nil {
return err
}
if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
return err
}
if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
return err
}
if err = addOpModifyEventSubscriptionValidationMiddleware(stack); err != nil {
return err
}
if err = stack.Initialize.Add(newServiceMetadataMiddleware_opModifyEventSubscription(options.Region), middleware.Before); err != nil {
return err
}
if err = addRequestIDRetrieverMiddleware(stack); err != nil {
return err
}
if err = addResponseErrorMiddleware(stack); err != nil {
return err
}
if err = addRequestResponseLogging(stack, options); err != nil {
return err
}
return nil
}
func newServiceMetadataMiddleware_opModifyEventSubscription(region string) *awsmiddleware.RegisterServiceMetadata {
return &awsmiddleware.RegisterServiceMetadata{
Region: region,
ServiceID: ServiceID,
SigningName: "redshift",
OperationName: "ModifyEventSubscription",
}
}