-
Notifications
You must be signed in to change notification settings - Fork 598
/
api_op_RegisterCrossAccountAccessRole.go
126 lines (104 loc) · 4.25 KB
/
api_op_RegisterCrossAccountAccessRole.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
// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT.
package inspector
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"
"github.com/aws/aws-sdk-go-v2/private/protocol/jsonrpc"
)
// Please also see https://docs.aws.amazon.com/goto/WebAPI/inspector-2016-02-16/RegisterCrossAccountAccessRoleRequest
type RegisterCrossAccountAccessRoleInput struct {
_ struct{} `type:"structure"`
// The ARN of the IAM role that grants Amazon Inspector access to AWS Services
// needed to perform security assessments.
//
// RoleArn is a required field
RoleArn *string `locationName:"roleArn" min:"1" type:"string" required:"true"`
}
// String returns the string representation
func (s RegisterCrossAccountAccessRoleInput) String() string {
return awsutil.Prettify(s)
}
// Validate inspects the fields of the type to determine if they are valid.
func (s *RegisterCrossAccountAccessRoleInput) Validate() error {
invalidParams := aws.ErrInvalidParams{Context: "RegisterCrossAccountAccessRoleInput"}
if s.RoleArn == nil {
invalidParams.Add(aws.NewErrParamRequired("RoleArn"))
}
if s.RoleArn != nil && len(*s.RoleArn) < 1 {
invalidParams.Add(aws.NewErrParamMinLen("RoleArn", 1))
}
if invalidParams.Len() > 0 {
return invalidParams
}
return nil
}
// Please also see https://docs.aws.amazon.com/goto/WebAPI/inspector-2016-02-16/RegisterCrossAccountAccessRoleOutput
type RegisterCrossAccountAccessRoleOutput struct {
_ struct{} `type:"structure"`
}
// String returns the string representation
func (s RegisterCrossAccountAccessRoleOutput) String() string {
return awsutil.Prettify(s)
}
const opRegisterCrossAccountAccessRole = "RegisterCrossAccountAccessRole"
// RegisterCrossAccountAccessRoleRequest returns a request value for making API operation for
// Amazon Inspector.
//
// Registers the IAM role that grants Amazon Inspector access to AWS Services
// needed to perform security assessments.
//
// // Example sending a request using RegisterCrossAccountAccessRoleRequest.
// req := client.RegisterCrossAccountAccessRoleRequest(params)
// resp, err := req.Send(context.TODO())
// if err == nil {
// fmt.Println(resp)
// }
//
// Please also see https://docs.aws.amazon.com/goto/WebAPI/inspector-2016-02-16/RegisterCrossAccountAccessRole
func (c *Client) RegisterCrossAccountAccessRoleRequest(input *RegisterCrossAccountAccessRoleInput) RegisterCrossAccountAccessRoleRequest {
op := &aws.Operation{
Name: opRegisterCrossAccountAccessRole,
HTTPMethod: "POST",
HTTPPath: "/",
}
if input == nil {
input = &RegisterCrossAccountAccessRoleInput{}
}
req := c.newRequest(op, input, &RegisterCrossAccountAccessRoleOutput{})
req.Handlers.Unmarshal.Remove(jsonrpc.UnmarshalHandler)
req.Handlers.Unmarshal.PushBackNamed(protocol.UnmarshalDiscardBodyHandler)
return RegisterCrossAccountAccessRoleRequest{Request: req, Input: input, Copy: c.RegisterCrossAccountAccessRoleRequest}
}
// RegisterCrossAccountAccessRoleRequest is the request type for the
// RegisterCrossAccountAccessRole API operation.
type RegisterCrossAccountAccessRoleRequest struct {
*aws.Request
Input *RegisterCrossAccountAccessRoleInput
Copy func(*RegisterCrossAccountAccessRoleInput) RegisterCrossAccountAccessRoleRequest
}
// Send marshals and sends the RegisterCrossAccountAccessRole API request.
func (r RegisterCrossAccountAccessRoleRequest) Send(ctx context.Context) (*RegisterCrossAccountAccessRoleResponse, error) {
r.Request.SetContext(ctx)
err := r.Request.Send()
if err != nil {
return nil, err
}
resp := &RegisterCrossAccountAccessRoleResponse{
RegisterCrossAccountAccessRoleOutput: r.Request.Data.(*RegisterCrossAccountAccessRoleOutput),
response: &aws.Response{Request: r.Request},
}
return resp, nil
}
// RegisterCrossAccountAccessRoleResponse is the response type for the
// RegisterCrossAccountAccessRole API operation.
type RegisterCrossAccountAccessRoleResponse struct {
*RegisterCrossAccountAccessRoleOutput
response *aws.Response
}
// SDKResponseMetdata returns the response metadata for the
// RegisterCrossAccountAccessRole request.
func (r *RegisterCrossAccountAccessRoleResponse) SDKResponseMetdata() *aws.Response {
return r.response
}