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