-
Notifications
You must be signed in to change notification settings - Fork 597
/
api_op_EnableOrganizationAdminAccount.go
136 lines (110 loc) · 4.43 KB
/
api_op_EnableOrganizationAdminAccount.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
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
package guardduty
import (
"context"
"github.com/aws/aws-sdk-go-v2/aws"
"github.com/aws/aws-sdk-go-v2/internal/awsutil"
"github.com/aws/aws-sdk-go-v2/private/protocol"
)
type EnableOrganizationAdminAccountInput struct {
_ struct{} `type:"structure"`
// The AWS Account ID for the Organizations account to be enabled as a GuardDuty
// delegated administrator.
//
// AdminAccountId is a required field
AdminAccountId *string `locationName:"adminAccountId" type:"string" required:"true"`
}
// String returns the string representation
func (s EnableOrganizationAdminAccountInput) String() string {
return awsutil.Prettify(s)
}
// Validate inspects the fields of the type to determine if they are valid.
func (s *EnableOrganizationAdminAccountInput) Validate() error {
invalidParams := aws.ErrInvalidParams{Context: "EnableOrganizationAdminAccountInput"}
if s.AdminAccountId == nil {
invalidParams.Add(aws.NewErrParamRequired("AdminAccountId"))
}
if invalidParams.Len() > 0 {
return invalidParams
}
return nil
}
// MarshalFields encodes the AWS API shape using the passed in protocol encoder.
func (s EnableOrganizationAdminAccountInput) MarshalFields(e protocol.FieldEncoder) error {
e.SetValue(protocol.HeaderTarget, "Content-Type", protocol.StringValue("application/json"), protocol.Metadata{})
if s.AdminAccountId != nil {
v := *s.AdminAccountId
metadata := protocol.Metadata{}
e.SetValue(protocol.BodyTarget, "adminAccountId", protocol.QuotedValue{ValueMarshaler: protocol.StringValue(v)}, metadata)
}
return nil
}
type EnableOrganizationAdminAccountOutput struct {
_ struct{} `type:"structure"`
}
// String returns the string representation
func (s EnableOrganizationAdminAccountOutput) String() string {
return awsutil.Prettify(s)
}
// MarshalFields encodes the AWS API shape using the passed in protocol encoder.
func (s EnableOrganizationAdminAccountOutput) MarshalFields(e protocol.FieldEncoder) error {
return nil
}
const opEnableOrganizationAdminAccount = "EnableOrganizationAdminAccount"
// EnableOrganizationAdminAccountRequest returns a request value for making API operation for
// Amazon GuardDuty.
//
// Enables GuardDuty administrator permissions for an AWS account within the
// organization.
//
// // Example sending a request using EnableOrganizationAdminAccountRequest.
// req := client.EnableOrganizationAdminAccountRequest(params)
// resp, err := req.Send(context.TODO())
// if err == nil {
// fmt.Println(resp)
// }
//
// Please also see https://docs.aws.amazon.com/goto/WebAPI/guardduty-2017-11-28/EnableOrganizationAdminAccount
func (c *Client) EnableOrganizationAdminAccountRequest(input *EnableOrganizationAdminAccountInput) EnableOrganizationAdminAccountRequest {
op := &aws.Operation{
Name: opEnableOrganizationAdminAccount,
HTTPMethod: "POST",
HTTPPath: "/admin/enable",
}
if input == nil {
input = &EnableOrganizationAdminAccountInput{}
}
req := c.newRequest(op, input, &EnableOrganizationAdminAccountOutput{})
return EnableOrganizationAdminAccountRequest{Request: req, Input: input, Copy: c.EnableOrganizationAdminAccountRequest}
}
// EnableOrganizationAdminAccountRequest is the request type for the
// EnableOrganizationAdminAccount API operation.
type EnableOrganizationAdminAccountRequest struct {
*aws.Request
Input *EnableOrganizationAdminAccountInput
Copy func(*EnableOrganizationAdminAccountInput) EnableOrganizationAdminAccountRequest
}
// Send marshals and sends the EnableOrganizationAdminAccount API request.
func (r EnableOrganizationAdminAccountRequest) Send(ctx context.Context) (*EnableOrganizationAdminAccountResponse, error) {
r.Request.SetContext(ctx)
err := r.Request.Send()
if err != nil {
return nil, err
}
resp := &EnableOrganizationAdminAccountResponse{
EnableOrganizationAdminAccountOutput: r.Request.Data.(*EnableOrganizationAdminAccountOutput),
response: &aws.Response{Request: r.Request},
}
return resp, nil
}
// EnableOrganizationAdminAccountResponse is the response type for the
// EnableOrganizationAdminAccount API operation.
type EnableOrganizationAdminAccountResponse struct {
*EnableOrganizationAdminAccountOutput
response *aws.Response
}
// SDKResponseMetdata returns the response metadata for the
// EnableOrganizationAdminAccount request.
func (r *EnableOrganizationAdminAccountResponse) SDKResponseMetdata() *aws.Response {
return r.response
}