api_op_GetDelegatedAccessToken.go raw
1 // Code generated by smithy-go-codegen DO NOT EDIT.
2
3 package sts
4
5 import (
6 "context"
7 "fmt"
8 awsmiddleware "github.com/aws/aws-sdk-go-v2/aws/middleware"
9 "github.com/aws/aws-sdk-go-v2/service/sts/types"
10 "github.com/aws/smithy-go/middleware"
11 smithyhttp "github.com/aws/smithy-go/transport/http"
12 )
13
14 // Exchanges a trade-in token for temporary Amazon Web Services credentials with
15 // the permissions associated with the assumed principal. This operation allows you
16 // to obtain credentials for a specific principal based on a trade-in token,
17 // enabling delegation of access to Amazon Web Services resources.
18 func (c *Client) GetDelegatedAccessToken(ctx context.Context, params *GetDelegatedAccessTokenInput, optFns ...func(*Options)) (*GetDelegatedAccessTokenOutput, error) {
19 if params == nil {
20 params = &GetDelegatedAccessTokenInput{}
21 }
22
23 result, metadata, err := c.invokeOperation(ctx, "GetDelegatedAccessToken", params, optFns, c.addOperationGetDelegatedAccessTokenMiddlewares)
24 if err != nil {
25 return nil, err
26 }
27
28 out := result.(*GetDelegatedAccessTokenOutput)
29 out.ResultMetadata = metadata
30 return out, nil
31 }
32
33 type GetDelegatedAccessTokenInput struct {
34
35 // The token to exchange for temporary Amazon Web Services credentials. This token
36 // must be valid and unexpired at the time of the request.
37 //
38 // This member is required.
39 TradeInToken *string
40
41 noSmithyDocumentSerde
42 }
43
44 type GetDelegatedAccessTokenOutput struct {
45
46 // The Amazon Resource Name (ARN) of the principal that was assumed when obtaining
47 // the delegated access token. This ARN identifies the IAM entity whose permissions
48 // are granted by the temporary credentials.
49 AssumedPrincipal *string
50
51 // Amazon Web Services credentials for API authentication.
52 Credentials *types.Credentials
53
54 // The percentage of the maximum policy size that is used by the session policy.
55 // The policy size is calculated as the sum of all the session policies and
56 // permission boundaries attached to the session. If the packed size exceeds 100%,
57 // the request fails.
58 PackedPolicySize *int32
59
60 // Metadata pertaining to the operation's result.
61 ResultMetadata middleware.Metadata
62
63 noSmithyDocumentSerde
64 }
65
66 func (c *Client) addOperationGetDelegatedAccessTokenMiddlewares(stack *middleware.Stack, options Options) (err error) {
67 if err := stack.Serialize.Add(&setOperationInputMiddleware{}, middleware.After); err != nil {
68 return err
69 }
70 err = stack.Serialize.Add(&awsAwsquery_serializeOpGetDelegatedAccessToken{}, middleware.After)
71 if err != nil {
72 return err
73 }
74 err = stack.Deserialize.Add(&awsAwsquery_deserializeOpGetDelegatedAccessToken{}, middleware.After)
75 if err != nil {
76 return err
77 }
78 if err := addProtocolFinalizerMiddlewares(stack, options, "GetDelegatedAccessToken"); err != nil {
79 return fmt.Errorf("add protocol finalizers: %v", err)
80 }
81
82 if err = addlegacyEndpointContextSetter(stack, options); err != nil {
83 return err
84 }
85 if err = addSetLoggerMiddleware(stack, options); err != nil {
86 return err
87 }
88 if err = addClientRequestID(stack); err != nil {
89 return err
90 }
91 if err = addComputeContentLength(stack); err != nil {
92 return err
93 }
94 if err = addResolveEndpointMiddleware(stack, options); err != nil {
95 return err
96 }
97 if err = addComputePayloadSHA256(stack); err != nil {
98 return err
99 }
100 if err = addRetry(stack, options); err != nil {
101 return err
102 }
103 if err = addRawResponseToMetadata(stack); err != nil {
104 return err
105 }
106 if err = addRecordResponseTiming(stack); err != nil {
107 return err
108 }
109 if err = addSpanRetryLoop(stack, options); err != nil {
110 return err
111 }
112 if err = addClientUserAgent(stack, options); err != nil {
113 return err
114 }
115 if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
116 return err
117 }
118 if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
119 return err
120 }
121 if err = addSetLegacyContextSigningOptionsMiddleware(stack); err != nil {
122 return err
123 }
124 if err = addTimeOffsetBuild(stack, c); err != nil {
125 return err
126 }
127 if err = addUserAgentRetryMode(stack, options); err != nil {
128 return err
129 }
130 if err = addCredentialSource(stack, options); err != nil {
131 return err
132 }
133 if err = addOpGetDelegatedAccessTokenValidationMiddleware(stack); err != nil {
134 return err
135 }
136 if err = stack.Initialize.Add(newServiceMetadataMiddleware_opGetDelegatedAccessToken(options.Region), middleware.Before); err != nil {
137 return err
138 }
139 if err = addRecursionDetection(stack); err != nil {
140 return err
141 }
142 if err = addRequestIDRetrieverMiddleware(stack); err != nil {
143 return err
144 }
145 if err = addResponseErrorMiddleware(stack); err != nil {
146 return err
147 }
148 if err = addRequestResponseLogging(stack, options); err != nil {
149 return err
150 }
151 if err = addDisableHTTPSMiddleware(stack, options); err != nil {
152 return err
153 }
154 if err = addInterceptBeforeRetryLoop(stack, options); err != nil {
155 return err
156 }
157 if err = addInterceptAttempt(stack, options); err != nil {
158 return err
159 }
160 if err = addInterceptors(stack, options); err != nil {
161 return err
162 }
163 return nil
164 }
165
166 func newServiceMetadataMiddleware_opGetDelegatedAccessToken(region string) *awsmiddleware.RegisterServiceMetadata {
167 return &awsmiddleware.RegisterServiceMetadata{
168 Region: region,
169 ServiceID: ServiceID,
170 OperationName: "GetDelegatedAccessToken",
171 }
172 }
173