123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395 |
- // Code generated by smithy-go-codegen DO NOT EDIT.
- package sts
- import (
- "context"
- awsmiddleware "github.com/aws/aws-sdk-go-v2/aws/middleware"
- "github.com/aws/aws-sdk-go-v2/service/sts/types"
- "github.com/aws/smithy-go/middleware"
- smithyhttp "github.com/aws/smithy-go/transport/http"
- )
- // Returns a set of temporary security credentials for users who have been
- // authenticated in a mobile or web application with a web identity provider.
- // Example providers include the OAuth 2.0 providers Login with Amazon and
- // Facebook, or any OpenID Connect-compatible identity provider such as Google or
- // Amazon Cognito federated identities
- // (https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-identity.html).
- // For mobile applications, we recommend that you use Amazon Cognito. You can use
- // Amazon Cognito with the Amazon Web Services SDK for iOS Developer Guide
- // (http://aws.amazon.com/sdkforios/) and the Amazon Web Services SDK for Android
- // Developer Guide (http://aws.amazon.com/sdkforandroid/) to uniquely identify a
- // user. You can also supply the user with a consistent identity throughout the
- // lifetime of an application. To learn more about Amazon Cognito, see Amazon
- // Cognito Overview
- // (https://docs.aws.amazon.com/mobile/sdkforandroid/developerguide/cognito-auth.html#d0e840)
- // in Amazon Web Services SDK for Android Developer Guide and Amazon Cognito
- // Overview
- // (https://docs.aws.amazon.com/mobile/sdkforios/developerguide/cognito-auth.html#d0e664)
- // in the Amazon Web Services SDK for iOS Developer Guide. Calling
- // AssumeRoleWithWebIdentity does not require the use of Amazon Web Services
- // security credentials. Therefore, you can distribute an application (for example,
- // on mobile devices) that requests temporary security credentials without
- // including long-term Amazon Web Services credentials in the application. You also
- // don't need to deploy server-based proxy services that use long-term Amazon Web
- // Services credentials. Instead, the identity of the caller is validated by using
- // a token from the web identity provider. For a comparison of
- // AssumeRoleWithWebIdentity with the other API operations that produce temporary
- // credentials, see Requesting Temporary Security Credentials
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_request.html)
- // and Comparing the Amazon Web Services STS API operations
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_request.html#stsapi_comparison)
- // in the IAM User Guide. The temporary security credentials returned by this API
- // consist of an access key ID, a secret access key, and a security token.
- // Applications can use these temporary security credentials to sign calls to
- // Amazon Web Services service API operations. Session Duration By default, the
- // temporary security credentials created by AssumeRoleWithWebIdentity last for one
- // hour. However, you can use the optional DurationSeconds parameter to specify the
- // duration of your session. You can provide a value from 900 seconds (15 minutes)
- // up to the maximum session duration setting for the role. This setting can have a
- // value from 1 hour to 12 hours. To learn how to view the maximum value for your
- // role, see View the Maximum Session Duration Setting for a Role
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_use.html#id_roles_use_view-role-max-session)
- // in the IAM User Guide. The maximum session duration limit applies when you use
- // the AssumeRole* API operations or the assume-role* CLI commands. However the
- // limit does not apply when you use those operations to create a console URL. For
- // more information, see Using IAM Roles
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_use.html) in the IAM
- // User Guide. Permissions The temporary security credentials created by
- // AssumeRoleWithWebIdentity can be used to make API calls to any Amazon Web
- // Services service with the following exception: you cannot call the STS
- // GetFederationToken or GetSessionToken API operations. (Optional) You can pass
- // inline or managed session policies
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html#policies_session)
- // to this operation. You can pass a single JSON policy document to use as an
- // inline session policy. You can also specify up to 10 managed policy Amazon
- // Resource Names (ARNs) to use as managed session policies. The plaintext that you
- // use for both inline and managed session policies can't exceed 2,048 characters.
- // Passing policies to this operation returns new temporary credentials. The
- // resulting session's permissions are the intersection of the role's
- // identity-based policy and the session policies. You can use the role's temporary
- // credentials in subsequent Amazon Web Services API calls to access resources in
- // the account that owns the role. You cannot use session policies to grant more
- // permissions than those allowed by the identity-based policy of the role that is
- // being assumed. For more information, see Session Policies
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html#policies_session)
- // in the IAM User Guide. Tags (Optional) You can configure your IdP to pass
- // attributes into your web identity token as session tags. Each session tag
- // consists of a key name and an associated value. For more information about
- // session tags, see Passing Session Tags in STS
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/id_session-tags.html) in the
- // IAM User Guide. You can pass up to 50 session tags. The plaintext session tag
- // keys can’t exceed 128 characters and the values can’t exceed 256 characters. For
- // these and additional limits, see IAM and STS Character Limits
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_iam-limits.html#reference_iam-limits-entity-length)
- // in the IAM User Guide. An Amazon Web Services conversion compresses the passed
- // inline session policy, managed policy ARNs, and session tags into a packed
- // binary format that has a separate limit. Your request can fail for this limit
- // even if your plaintext meets the other requirements. The PackedPolicySize
- // response element indicates by percentage how close the policies and tags for
- // your request are to the upper size limit. You can pass a session tag with the
- // same key as a tag that is attached to the role. When you do, the session tag
- // overrides the role tag with the same key. An administrator must grant you the
- // permissions necessary to pass session tags. The administrator can also create
- // granular permissions to allow you to pass only specific session tags. For more
- // information, see Tutorial: Using Tags for Attribute-Based Access Control
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/tutorial_attribute-based-access-control.html)
- // in the IAM User Guide. You can set the session tags as transitive. Transitive
- // tags persist during role chaining. For more information, see Chaining Roles with
- // Session Tags
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/id_session-tags.html#id_session-tags_role-chaining)
- // in the IAM User Guide. Identities Before your application can call
- // AssumeRoleWithWebIdentity, you must have an identity token from a supported
- // identity provider and create a role that the application can assume. The role
- // that your application assumes must trust the identity provider that is
- // associated with the identity token. In other words, the identity provider must
- // be specified in the role's trust policy. Calling AssumeRoleWithWebIdentity can
- // result in an entry in your CloudTrail logs. The entry includes the Subject
- // (http://openid.net/specs/openid-connect-core-1_0.html#Claims) of the provided
- // web identity token. We recommend that you avoid using any personally
- // identifiable information (PII) in this field. For example, you could instead use
- // a GUID or a pairwise identifier, as suggested in the OIDC specification
- // (http://openid.net/specs/openid-connect-core-1_0.html#SubjectIDTypes). For more
- // information about how to use web identity federation and the
- // AssumeRoleWithWebIdentity API, see the following resources:
- //
- // * Using Web
- // Identity Federation API Operations for Mobile Apps
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_providers_oidc_manual.html)
- // and Federation Through a Web-based Identity Provider
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_request.html#api_assumerolewithwebidentity).
- //
- // *
- // Web Identity Federation Playground
- // (https://aws.amazon.com/blogs/aws/the-aws-web-identity-federation-playground/).
- // Walk through the process of authenticating through Login with Amazon, Facebook,
- // or Google, getting temporary security credentials, and then using those
- // credentials to make a request to Amazon Web Services.
- //
- // * Amazon Web Services SDK
- // for iOS Developer Guide (http://aws.amazon.com/sdkforios/) and Amazon Web
- // Services SDK for Android Developer Guide (http://aws.amazon.com/sdkforandroid/).
- // These toolkits contain sample apps that show how to invoke the identity
- // providers. The toolkits then show how to use the information from these
- // providers to get and use temporary security credentials.
- //
- // * Web Identity
- // Federation with Mobile Applications
- // (http://aws.amazon.com/articles/web-identity-federation-with-mobile-applications).
- // This article discusses web identity federation and shows an example of how to
- // use web identity federation to get access to content in Amazon S3.
- func (c *Client) AssumeRoleWithWebIdentity(ctx context.Context, params *AssumeRoleWithWebIdentityInput, optFns ...func(*Options)) (*AssumeRoleWithWebIdentityOutput, error) {
- if params == nil {
- params = &AssumeRoleWithWebIdentityInput{}
- }
- result, metadata, err := c.invokeOperation(ctx, "AssumeRoleWithWebIdentity", params, optFns, c.addOperationAssumeRoleWithWebIdentityMiddlewares)
- if err != nil {
- return nil, err
- }
- out := result.(*AssumeRoleWithWebIdentityOutput)
- out.ResultMetadata = metadata
- return out, nil
- }
- type AssumeRoleWithWebIdentityInput struct {
- // The Amazon Resource Name (ARN) of the role that the caller is assuming.
- //
- // This member is required.
- RoleArn *string
- // An identifier for the assumed role session. Typically, you pass the name or
- // identifier that is associated with the user who is using your application. That
- // way, the temporary security credentials that your application will use are
- // associated with that user. This session name is included as part of the ARN and
- // assumed role ID in the AssumedRoleUser response element. The regex used to
- // validate this parameter is a string of characters consisting of upper- and
- // lower-case alphanumeric characters with no spaces. You can also include
- // underscores or any of the following characters: =,.@-
- //
- // This member is required.
- RoleSessionName *string
- // The OAuth 2.0 access token or OpenID Connect ID token that is provided by the
- // identity provider. Your application must get this token by authenticating the
- // user who is using your application with a web identity provider before the
- // application makes an AssumeRoleWithWebIdentity call.
- //
- // This member is required.
- WebIdentityToken *string
- // The duration, in seconds, of the role session. The value can range from 900
- // seconds (15 minutes) up to the maximum session duration setting for the role.
- // This setting can have a value from 1 hour to 12 hours. If you specify a value
- // higher than this setting, the operation fails. For example, if you specify a
- // session duration of 12 hours, but your administrator set the maximum session
- // duration to 6 hours, your operation fails. To learn how to view the maximum
- // value for your role, see View the Maximum Session Duration Setting for a Role
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_use.html#id_roles_use_view-role-max-session)
- // in the IAM User Guide. By default, the value is set to 3600 seconds. The
- // DurationSeconds parameter is separate from the duration of a console session
- // that you might request using the returned credentials. The request to the
- // federation endpoint for a console sign-in token takes a SessionDuration
- // parameter that specifies the maximum length of the console session. For more
- // information, see Creating a URL that Enables Federated Users to Access the
- // Amazon Web Services Management Console
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_providers_enable-console-custom-url.html)
- // in the IAM User Guide.
- DurationSeconds *int32
- // An IAM policy in JSON format that you want to use as an inline session policy.
- // This parameter is optional. Passing policies to this operation returns new
- // temporary credentials. The resulting session's permissions are the intersection
- // of the role's identity-based policy and the session policies. You can use the
- // role's temporary credentials in subsequent Amazon Web Services API calls to
- // access resources in the account that owns the role. You cannot use session
- // policies to grant more permissions than those allowed by the identity-based
- // policy of the role that is being assumed. For more information, see Session
- // Policies
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html#policies_session)
- // in the IAM User Guide. The plaintext that you use for both inline and managed
- // session policies can't exceed 2,048 characters. The JSON policy characters can
- // be any ASCII character from the space character to the end of the valid
- // character list (\u0020 through \u00FF). It can also include the tab (\u0009),
- // linefeed (\u000A), and carriage return (\u000D) characters. An Amazon Web
- // Services conversion compresses the passed inline session policy, managed policy
- // ARNs, and session tags into a packed binary format that has a separate limit.
- // Your request can fail for this limit even if your plaintext meets the other
- // requirements. The PackedPolicySize response element indicates by percentage how
- // close the policies and tags for your request are to the upper size limit.
- Policy *string
- // The Amazon Resource Names (ARNs) of the IAM managed policies that you want to
- // use as managed session policies. The policies must exist in the same account as
- // the role. This parameter is optional. You can provide up to 10 managed policy
- // ARNs. However, the plaintext that you use for both inline and managed session
- // policies can't exceed 2,048 characters. For more information about ARNs, see
- // Amazon Resource Names (ARNs) and Amazon Web Services Service Namespaces
- // (https://docs.aws.amazon.com/general/latest/gr/aws-arns-and-namespaces.html) in
- // the Amazon Web Services General Reference. An Amazon Web Services conversion
- // compresses the passed inline session policy, managed policy ARNs, and session
- // tags into a packed binary format that has a separate limit. Your request can
- // fail for this limit even if your plaintext meets the other requirements. The
- // PackedPolicySize response element indicates by percentage how close the policies
- // and tags for your request are to the upper size limit. Passing policies to this
- // operation returns new temporary credentials. The resulting session's permissions
- // are the intersection of the role's identity-based policy and the session
- // policies. You can use the role's temporary credentials in subsequent Amazon Web
- // Services API calls to access resources in the account that owns the role. You
- // cannot use session policies to grant more permissions than those allowed by the
- // identity-based policy of the role that is being assumed. For more information,
- // see Session Policies
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html#policies_session)
- // in the IAM User Guide.
- PolicyArns []types.PolicyDescriptorType
- // The fully qualified host component of the domain name of the OAuth 2.0 identity
- // provider. Do not specify this value for an OpenID Connect identity provider.
- // Currently www.amazon.com and graph.facebook.com are the only supported identity
- // providers for OAuth 2.0 access tokens. Do not include URL schemes and port
- // numbers. Do not specify this value for OpenID Connect ID tokens.
- ProviderId *string
- noSmithyDocumentSerde
- }
- // Contains the response to a successful AssumeRoleWithWebIdentity request,
- // including temporary Amazon Web Services credentials that can be used to make
- // Amazon Web Services requests.
- type AssumeRoleWithWebIdentityOutput struct {
- // The Amazon Resource Name (ARN) and the assumed role ID, which are identifiers
- // that you can use to refer to the resulting temporary security credentials. For
- // example, you can reference these credentials as a principal in a resource-based
- // policy by using the ARN or assumed role ID. The ARN and ID include the
- // RoleSessionName that you specified when you called AssumeRole.
- AssumedRoleUser *types.AssumedRoleUser
- // The intended audience (also known as client ID) of the web identity token. This
- // is traditionally the client identifier issued to the application that requested
- // the web identity token.
- Audience *string
- // The temporary security credentials, which include an access key ID, a secret
- // access key, and a security token. The size of the security token that STS API
- // operations return is not fixed. We strongly recommend that you make no
- // assumptions about the maximum size.
- Credentials *types.Credentials
- // A percentage value that indicates the packed size of the session policies and
- // session tags combined passed in the request. The request fails if the packed
- // size is greater than 100 percent, which means the policies and tags exceeded the
- // allowed space.
- PackedPolicySize *int32
- // The issuing authority of the web identity token presented. For OpenID Connect ID
- // tokens, this contains the value of the iss field. For OAuth 2.0 access tokens,
- // this contains the value of the ProviderId parameter that was passed in the
- // AssumeRoleWithWebIdentity request.
- Provider *string
- // The value of the source identity that is returned in the JSON web token (JWT)
- // from the identity provider. You can require users to set a source identity value
- // when they assume a role. You do this by using the sts:SourceIdentity condition
- // key in a role trust policy. That way, actions that are taken with the role are
- // associated with that user. After the source identity is set, the value cannot be
- // changed. It is present in the request for all actions that are taken by the role
- // and persists across chained role
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_terms-and-concepts#iam-term-role-chaining)
- // sessions. You can configure your identity provider to use an attribute
- // associated with your users, like user name or email, as the source identity when
- // calling AssumeRoleWithWebIdentity. You do this by adding a claim to the JSON web
- // token. To learn more about OIDC tokens and claims, see Using Tokens with User
- // Pools
- // (https://docs.aws.amazon.com/cognito/latest/developerguide/amazon-cognito-user-pools-using-tokens-with-identity-providers.html)
- // in the Amazon Cognito Developer Guide. For more information about using source
- // identity, see Monitor and control actions taken with assumed roles
- // (https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_control-access_monitor.html)
- // in the IAM User Guide. The regex used to validate this parameter is a string of
- // characters consisting of upper- and lower-case alphanumeric characters with no
- // spaces. You can also include underscores or any of the following characters:
- // =,.@-
- SourceIdentity *string
- // The unique user identifier that is returned by the identity provider. This
- // identifier is associated with the WebIdentityToken that was submitted with the
- // AssumeRoleWithWebIdentity call. The identifier is typically unique to the user
- // and the application that acquired the WebIdentityToken (pairwise identifier).
- // For OpenID Connect ID tokens, this field contains the value returned by the
- // identity provider as the token's sub (Subject) claim.
- SubjectFromWebIdentityToken *string
- // Metadata pertaining to the operation's result.
- ResultMetadata middleware.Metadata
- noSmithyDocumentSerde
- }
- func (c *Client) addOperationAssumeRoleWithWebIdentityMiddlewares(stack *middleware.Stack, options Options) (err error) {
- err = stack.Serialize.Add(&awsAwsquery_serializeOpAssumeRoleWithWebIdentity{}, middleware.After)
- if err != nil {
- return err
- }
- err = stack.Deserialize.Add(&awsAwsquery_deserializeOpAssumeRoleWithWebIdentity{}, middleware.After)
- if err != nil {
- return err
- }
- if err = addSetLoggerMiddleware(stack, options); err != nil {
- return err
- }
- if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil {
- return err
- }
- if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil {
- return err
- }
- if err = addResolveEndpointMiddleware(stack, options); err != nil {
- return err
- }
- if err = addRetryMiddlewares(stack, options); err != nil {
- return err
- }
- if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil {
- return err
- }
- if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil {
- return err
- }
- if err = addClientUserAgent(stack); err != nil {
- return err
- }
- if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
- return err
- }
- if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
- return err
- }
- if err = addOpAssumeRoleWithWebIdentityValidationMiddleware(stack); err != nil {
- return err
- }
- if err = stack.Initialize.Add(newServiceMetadataMiddleware_opAssumeRoleWithWebIdentity(options.Region), middleware.Before); 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
- }
- return nil
- }
- func newServiceMetadataMiddleware_opAssumeRoleWithWebIdentity(region string) *awsmiddleware.RegisterServiceMetadata {
- return &awsmiddleware.RegisterServiceMetadata{
- Region: region,
- ServiceID: ServiceID,
- SigningName: "sts",
- OperationName: "AssumeRoleWithWebIdentity",
- }
- }
|