/
api_op_CreatePrivacyBudgetTemplate.go
171 lines (152 loc) · 5.44 KB
/
api_op_CreatePrivacyBudgetTemplate.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
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
// Code generated by smithy-go-codegen DO NOT EDIT.
package cleanrooms
import (
"context"
"fmt"
awsmiddleware "github.com/aws/aws-sdk-go-v2/aws/middleware"
"github.com/aws/aws-sdk-go-v2/service/cleanrooms/types"
"github.com/aws/smithy-go/middleware"
smithyhttp "github.com/aws/smithy-go/transport/http"
)
// Creates a privacy budget template for a specified membership. Each membership
// can have only one privacy budget template, but it can be deleted and recreated.
// If you need to change the privacy budget template for a membership, use the UpdatePrivacyBudgetTemplate
// operation.
func (c *Client) CreatePrivacyBudgetTemplate(ctx context.Context, params *CreatePrivacyBudgetTemplateInput, optFns ...func(*Options)) (*CreatePrivacyBudgetTemplateOutput, error) {
if params == nil {
params = &CreatePrivacyBudgetTemplateInput{}
}
result, metadata, err := c.invokeOperation(ctx, "CreatePrivacyBudgetTemplate", params, optFns, c.addOperationCreatePrivacyBudgetTemplateMiddlewares)
if err != nil {
return nil, err
}
out := result.(*CreatePrivacyBudgetTemplateOutput)
out.ResultMetadata = metadata
return out, nil
}
type CreatePrivacyBudgetTemplateInput struct {
// How often the privacy budget refreshes.
//
// If you plan to regularly bring new data into the collaboration, you can use
// CALENDAR_MONTH to automatically get a new privacy budget for the collaboration
// every calendar month. Choosing this option allows arbitrary amounts of
// information to be revealed about rows of the data when repeatedly queries across
// refreshes. Avoid choosing this if the same rows will be repeatedly queried
// between privacy budget refreshes.
//
// This member is required.
AutoRefresh types.PrivacyBudgetTemplateAutoRefresh
// A unique identifier for one of your memberships for a collaboration. The
// privacy budget template is created in the collaboration that this membership
// belongs to. Accepts a membership ID.
//
// This member is required.
MembershipIdentifier *string
// Specifies your parameters for the privacy budget template.
//
// This member is required.
Parameters types.PrivacyBudgetTemplateParametersInput
// Specifies the type of the privacy budget template.
//
// This member is required.
PrivacyBudgetType types.PrivacyBudgetType
// An optional label that you can assign to a resource when you create it. Each
// tag consists of a key and an optional value, both of which you define. When you
// use tagging, you can also use tag-based access control in IAM policies to
// control access to this resource.
Tags map[string]string
noSmithyDocumentSerde
}
type CreatePrivacyBudgetTemplateOutput struct {
// A summary of the elements in the privacy budget template.
//
// This member is required.
PrivacyBudgetTemplate *types.PrivacyBudgetTemplate
// Metadata pertaining to the operation's result.
ResultMetadata middleware.Metadata
noSmithyDocumentSerde
}
func (c *Client) addOperationCreatePrivacyBudgetTemplateMiddlewares(stack *middleware.Stack, options Options) (err error) {
if err := stack.Serialize.Add(&setOperationInputMiddleware{}, middleware.After); err != nil {
return err
}
err = stack.Serialize.Add(&awsRestjson1_serializeOpCreatePrivacyBudgetTemplate{}, middleware.After)
if err != nil {
return err
}
err = stack.Deserialize.Add(&awsRestjson1_deserializeOpCreatePrivacyBudgetTemplate{}, middleware.After)
if err != nil {
return err
}
if err := addProtocolFinalizerMiddlewares(stack, options, "CreatePrivacyBudgetTemplate"); err != nil {
return fmt.Errorf("add protocol finalizers: %v", err)
}
if err = addlegacyEndpointContextSetter(stack, options); err != nil {
return err
}
if err = addSetLoggerMiddleware(stack, options); err != nil {
return err
}
if err = addClientRequestID(stack); err != nil {
return err
}
if err = addComputeContentLength(stack); err != nil {
return err
}
if err = addResolveEndpointMiddleware(stack, options); err != nil {
return err
}
if err = addComputePayloadSHA256(stack); err != nil {
return err
}
if err = addRetry(stack, options); err != nil {
return err
}
if err = addRawResponseToMetadata(stack); err != nil {
return err
}
if err = addRecordResponseTiming(stack); err != nil {
return err
}
if err = addClientUserAgent(stack, options); err != nil {
return err
}
if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
return err
}
if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
return err
}
if err = addSetLegacyContextSigningOptionsMiddleware(stack); err != nil {
return err
}
if err = addOpCreatePrivacyBudgetTemplateValidationMiddleware(stack); err != nil {
return err
}
if err = stack.Initialize.Add(newServiceMetadataMiddleware_opCreatePrivacyBudgetTemplate(options.Region), middleware.Before); err != nil {
return err
}
if err = addRecursionDetection(stack); 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
}
if err = addDisableHTTPSMiddleware(stack, options); err != nil {
return err
}
return nil
}
func newServiceMetadataMiddleware_opCreatePrivacyBudgetTemplate(region string) *awsmiddleware.RegisterServiceMetadata {
return &awsmiddleware.RegisterServiceMetadata{
Region: region,
ServiceID: ServiceID,
OperationName: "CreatePrivacyBudgetTemplate",
}
}