api_op_AssumeRoleWithSAML.go (23264B)
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 // Returns a set of temporary security credentials for users who have been 15 // authenticated via a SAML authentication response. This operation provides a 16 // mechanism for tying an enterprise identity store or directory to role-based 17 // Amazon Web Services access without user-specific credentials or configuration. 18 // For a comparison of AssumeRoleWithSAML with the other API operations that 19 // produce temporary credentials, see [Requesting Temporary Security Credentials]and [Compare STS credentials] in the IAM User Guide. 20 // 21 // The temporary security credentials returned by this operation consist of an 22 // access key ID, a secret access key, and a security token. Applications can use 23 // these temporary security credentials to sign calls to Amazon Web Services 24 // services. 25 // 26 // # Session Duration 27 // 28 // By default, the temporary security credentials created by AssumeRoleWithSAML 29 // last for one hour. However, you can use the optional DurationSeconds parameter 30 // to specify the duration of your session. Your role session lasts for the 31 // duration that you specify, or until the time specified in the SAML 32 // authentication response's SessionNotOnOrAfter value, whichever is shorter. You 33 // can provide a DurationSeconds value from 900 seconds (15 minutes) up to the 34 // maximum session duration setting for the role. This setting can have a value 35 // from 1 hour to 12 hours. To learn how to view the maximum value for your role, 36 // see [View the Maximum Session Duration Setting for a Role]in the IAM User Guide. The maximum session duration limit applies when you 37 // use the AssumeRole* API operations or the assume-role* CLI commands. However 38 // the limit does not apply when you use those operations to create a console URL. 39 // For more information, see [Using IAM Roles]in the IAM User Guide. 40 // 41 // [Role chaining]limits your CLI or Amazon Web Services API role session to a maximum of one 42 // hour. When you use the AssumeRole API operation to assume a role, you can 43 // specify the duration of your role session with the DurationSeconds parameter. 44 // You can specify a parameter value of up to 43200 seconds (12 hours), depending 45 // on the maximum session duration setting for your role. However, if you assume a 46 // role using role chaining and provide a DurationSeconds parameter value greater 47 // than one hour, the operation fails. 48 // 49 // # Permissions 50 // 51 // The temporary security credentials created by AssumeRoleWithSAML can be used to 52 // make API calls to any Amazon Web Services service with the following exception: 53 // you cannot call the STS GetFederationToken or GetSessionToken API operations. 54 // 55 // (Optional) You can pass inline or managed [session policies] to this operation. You can pass a 56 // single JSON policy document to use as an inline session policy. You can also 57 // specify up to 10 managed policy Amazon Resource Names (ARNs) to use as managed 58 // session policies. The plaintext that you use for both inline and managed session 59 // policies can't exceed 2,048 characters. Passing policies to this operation 60 // returns new temporary credentials. The resulting session's permissions are the 61 // intersection of the role's identity-based policy and the session policies. You 62 // can use the role's temporary credentials in subsequent Amazon Web Services API 63 // calls to access resources in the account that owns the role. You cannot use 64 // session policies to grant more permissions than those allowed by the 65 // identity-based policy of the role that is being assumed. For more information, 66 // see [Session Policies]in the IAM User Guide. 67 // 68 // Calling AssumeRoleWithSAML does not require the use of Amazon Web Services 69 // security credentials. The identity of the caller is validated by using keys in 70 // the metadata document that is uploaded for the SAML provider entity for your 71 // identity provider. 72 // 73 // Calling AssumeRoleWithSAML can result in an entry in your CloudTrail logs. The 74 // entry includes the value in the NameID element of the SAML assertion. We 75 // recommend that you use a NameIDType that is not associated with any personally 76 // identifiable information (PII). For example, you could instead use the 77 // persistent identifier ( urn:oasis:names:tc:SAML:2.0:nameid-format:persistent ). 78 // 79 // # Tags 80 // 81 // (Optional) You can configure your IdP to pass attributes into your SAML 82 // assertion as session tags. Each session tag consists of a key name and an 83 // associated value. For more information about session tags, see [Passing Session Tags in STS]in the IAM User 84 // Guide. 85 // 86 // You can pass up to 50 session tags. The plaintext session tag keys can’t exceed 87 // 128 characters and the values can’t exceed 256 characters. For these and 88 // additional limits, see [IAM and STS Character Limits]in the IAM User Guide. 89 // 90 // An Amazon Web Services conversion compresses the passed inline session policy, 91 // managed policy ARNs, and session tags into a packed binary format that has a 92 // separate limit. Your request can fail for this limit even if your plaintext 93 // meets the other requirements. The PackedPolicySize response element indicates 94 // by percentage how close the policies and tags for your request are to the upper 95 // size limit. 96 // 97 // You can pass a session tag with the same key as a tag that is attached to the 98 // role. When you do, session tags override the role's tags with the same key. 99 // 100 // An administrator must grant you the permissions necessary to pass session tags. 101 // The administrator can also create granular permissions to allow you to pass only 102 // specific session tags. For more information, see [Tutorial: Using Tags for Attribute-Based Access Control]in the IAM User Guide. 103 // 104 // You can set the session tags as transitive. Transitive tags persist during role 105 // chaining. For more information, see [Chaining Roles with Session Tags]in the IAM User Guide. 106 // 107 // # SAML Configuration 108 // 109 // Before your application can call AssumeRoleWithSAML , you must configure your 110 // SAML identity provider (IdP) to issue the claims required by Amazon Web 111 // Services. Additionally, you must use Identity and Access Management (IAM) to 112 // create a SAML provider entity in your Amazon Web Services account that 113 // represents your identity provider. You must also create an IAM role that 114 // specifies this SAML provider in its trust policy. 115 // 116 // For more information, see the following resources: 117 // 118 // [About SAML 2.0-based Federation] 119 // - in the IAM User Guide. 120 // 121 // [Creating SAML Identity Providers] 122 // - in the IAM User Guide. 123 // 124 // [Configuring a Relying Party and Claims] 125 // - in the IAM User Guide. 126 // 127 // [Creating a Role for SAML 2.0 Federation] 128 // - in the IAM User Guide. 129 // 130 // [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 131 // [Creating a Role for SAML 2.0 Federation]: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_create_for-idp_saml.html 132 // [IAM and STS Character Limits]: https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_iam-limits.html#reference_iam-limits-entity-length 133 // [Creating SAML Identity Providers]: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_providers_create_saml.html 134 // [session policies]: https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html#policies_session 135 // [Requesting Temporary Security Credentials]: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_request.html 136 // [Compare STS credentials]: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_sts-comparison.html 137 // [Tutorial: Using Tags for Attribute-Based Access Control]: https://docs.aws.amazon.com/IAM/latest/UserGuide/tutorial_attribute-based-access-control.html 138 // [Configuring a Relying Party and Claims]: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_providers_create_saml_relying-party.html 139 // [Role chaining]: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_terms-and-concepts.html#iam-term-role-chaining 140 // [Using IAM Roles]: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_use.html 141 // [Session Policies]: https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html#policies_session 142 // [Passing Session Tags in STS]: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_session-tags.html 143 // [About SAML 2.0-based Federation]: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_providers_saml.html 144 // [Chaining Roles with Session Tags]: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_session-tags.html#id_session-tags_role-chaining 145 func (c *Client) AssumeRoleWithSAML(ctx context.Context, params *AssumeRoleWithSAMLInput, optFns ...func(*Options)) (*AssumeRoleWithSAMLOutput, error) { 146 if params == nil { 147 params = &AssumeRoleWithSAMLInput{} 148 } 149 150 result, metadata, err := c.invokeOperation(ctx, "AssumeRoleWithSAML", params, optFns, c.addOperationAssumeRoleWithSAMLMiddlewares) 151 if err != nil { 152 return nil, err 153 } 154 155 out := result.(*AssumeRoleWithSAMLOutput) 156 out.ResultMetadata = metadata 157 return out, nil 158 } 159 160 type AssumeRoleWithSAMLInput struct { 161 162 // The Amazon Resource Name (ARN) of the SAML provider in IAM that describes the 163 // IdP. 164 // 165 // This member is required. 166 PrincipalArn *string 167 168 // The Amazon Resource Name (ARN) of the role that the caller is assuming. 169 // 170 // This member is required. 171 RoleArn *string 172 173 // The base64 encoded SAML authentication response provided by the IdP. 174 // 175 // For more information, see [Configuring a Relying Party and Adding Claims] in the IAM User Guide. 176 // 177 // [Configuring a Relying Party and Adding Claims]: https://docs.aws.amazon.com/IAM/latest/UserGuide/create-role-saml-IdP-tasks.html 178 // 179 // This member is required. 180 SAMLAssertion *string 181 182 // The duration, in seconds, of the role session. Your role session lasts for the 183 // duration that you specify for the DurationSeconds parameter, or until the time 184 // specified in the SAML authentication response's SessionNotOnOrAfter value, 185 // whichever is shorter. You can provide a DurationSeconds value from 900 seconds 186 // (15 minutes) up to the maximum session duration setting for the role. This 187 // setting can have a value from 1 hour to 12 hours. If you specify a value higher 188 // than this setting, the operation fails. For example, if you specify a session 189 // duration of 12 hours, but your administrator set the maximum session duration to 190 // 6 hours, your operation fails. To learn how to view the maximum value for your 191 // role, see [View the Maximum Session Duration Setting for a Role]in the IAM User Guide. 192 // 193 // By default, the value is set to 3600 seconds. 194 // 195 // The DurationSeconds parameter is separate from the duration of a console 196 // session that you might request using the returned credentials. The request to 197 // the federation endpoint for a console sign-in token takes a SessionDuration 198 // parameter that specifies the maximum length of the console session. For more 199 // information, see [Creating a URL that Enables Federated Users to Access the Amazon Web Services Management Console]in the IAM User Guide. 200 // 201 // [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 202 // [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 203 DurationSeconds *int32 204 205 // An IAM policy in JSON format that you want to use as an inline session policy. 206 // 207 // This parameter is optional. Passing policies to this operation returns new 208 // temporary credentials. The resulting session's permissions are the intersection 209 // of the role's identity-based policy and the session policies. You can use the 210 // role's temporary credentials in subsequent Amazon Web Services API calls to 211 // access resources in the account that owns the role. You cannot use session 212 // policies to grant more permissions than those allowed by the identity-based 213 // policy of the role that is being assumed. For more information, see [Session Policies]in the IAM 214 // User Guide. 215 // 216 // The plaintext that you use for both inline and managed session policies can't 217 // exceed 2,048 characters. The JSON policy characters can be any ASCII character 218 // from the space character to the end of the valid character list (\u0020 through 219 // \u00FF). It can also include the tab (\u0009), linefeed (\u000A), and carriage 220 // return (\u000D) characters. 221 // 222 // For more information about role session permissions, see [Session policies]. 223 // 224 // An Amazon Web Services conversion compresses the passed inline session policy, 225 // managed policy ARNs, and session tags into a packed binary format that has a 226 // separate limit. Your request can fail for this limit even if your plaintext 227 // meets the other requirements. The PackedPolicySize response element indicates 228 // by percentage how close the policies and tags for your request are to the upper 229 // size limit. 230 // 231 // [Session Policies]: https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html#policies_session 232 // [Session policies]: https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html#policies_session 233 Policy *string 234 235 // The Amazon Resource Names (ARNs) of the IAM managed policies that you want to 236 // use as managed session policies. The policies must exist in the same account as 237 // the role. 238 // 239 // This parameter is optional. You can provide up to 10 managed policy ARNs. 240 // However, the plaintext that you use for both inline and managed session policies 241 // can't exceed 2,048 characters. For more information about ARNs, see [Amazon Resource Names (ARNs) and Amazon Web Services Service Namespaces]in the 242 // Amazon Web Services General Reference. 243 // 244 // An Amazon Web Services conversion compresses the passed inline session policy, 245 // managed policy ARNs, and session tags into a packed binary format that has a 246 // separate limit. Your request can fail for this limit even if your plaintext 247 // meets the other requirements. The PackedPolicySize response element indicates 248 // by percentage how close the policies and tags for your request are to the upper 249 // size limit. 250 // 251 // Passing policies to this operation returns new temporary credentials. The 252 // resulting session's permissions are the intersection of the role's 253 // identity-based policy and the session policies. You can use the role's temporary 254 // credentials in subsequent Amazon Web Services API calls to access resources in 255 // the account that owns the role. You cannot use session policies to grant more 256 // permissions than those allowed by the identity-based policy of the role that is 257 // being assumed. For more information, see [Session Policies]in the IAM User Guide. 258 // 259 // [Session Policies]: https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html#policies_session 260 // [Amazon Resource Names (ARNs) and Amazon Web Services Service Namespaces]: https://docs.aws.amazon.com/general/latest/gr/aws-arns-and-namespaces.html 261 PolicyArns []types.PolicyDescriptorType 262 263 noSmithyDocumentSerde 264 } 265 266 // Contains the response to a successful AssumeRoleWithSAML request, including temporary Amazon Web 267 // Services credentials that can be used to make Amazon Web Services requests. 268 type AssumeRoleWithSAMLOutput struct { 269 270 // The identifiers for the temporary security credentials that the operation 271 // returns. 272 AssumedRoleUser *types.AssumedRoleUser 273 274 // The value of the Recipient attribute of the SubjectConfirmationData element of 275 // the SAML assertion. 276 Audience *string 277 278 // The temporary security credentials, which include an access key ID, a secret 279 // access key, and a security (or session) token. 280 // 281 // The size of the security token that STS API operations return is not fixed. We 282 // strongly recommend that you make no assumptions about the maximum size. 283 Credentials *types.Credentials 284 285 // The value of the Issuer element of the SAML assertion. 286 Issuer *string 287 288 // A hash value based on the concatenation of the following: 289 // 290 // - The Issuer response value. 291 // 292 // - The Amazon Web Services account ID. 293 // 294 // - The friendly name (the last part of the ARN) of the SAML provider in IAM. 295 // 296 // The combination of NameQualifier and Subject can be used to uniquely identify a 297 // user. 298 // 299 // The following pseudocode shows how the hash value is calculated: 300 // 301 // BASE64 ( SHA1 ( "https://example.com/saml" + "123456789012" + "/MySAMLIdP" ) ) 302 NameQualifier *string 303 304 // A percentage value that indicates the packed size of the session policies and 305 // session tags combined passed in the request. The request fails if the packed 306 // size is greater than 100 percent, which means the policies and tags exceeded the 307 // allowed space. 308 PackedPolicySize *int32 309 310 // The value in the SourceIdentity attribute in the SAML assertion. The source 311 // identity value persists across [chained role]sessions. 312 // 313 // You can require users to set a source identity value when they assume a role. 314 // You do this by using the sts:SourceIdentity condition key in a role trust 315 // policy. That way, actions that are taken with the role are associated with that 316 // user. After the source identity is set, the value cannot be changed. It is 317 // present in the request for all actions that are taken by the role and persists 318 // across [chained role]sessions. You can configure your SAML identity provider to use an 319 // attribute associated with your users, like user name or email, as the source 320 // identity when calling AssumeRoleWithSAML . You do this by adding an attribute to 321 // the SAML assertion. For more information about using source identity, see [Monitor and control actions taken with assumed roles]in 322 // the IAM User Guide. 323 // 324 // The regex used to validate this parameter is a string of characters consisting 325 // of upper- and lower-case alphanumeric characters with no spaces. You can also 326 // include underscores or any of the following characters: =,.@- 327 // 328 // [chained role]: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles.html#id_roles_terms-and-concepts 329 // [Monitor and control actions taken with assumed roles]: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_control-access_monitor.html 330 SourceIdentity *string 331 332 // The value of the NameID element in the Subject element of the SAML assertion. 333 Subject *string 334 335 // The format of the name ID, as defined by the Format attribute in the NameID 336 // element of the SAML assertion. Typical examples of the format are transient or 337 // persistent . 338 // 339 // If the format includes the prefix urn:oasis:names:tc:SAML:2.0:nameid-format , 340 // that prefix is removed. For example, 341 // urn:oasis:names:tc:SAML:2.0:nameid-format:transient is returned as transient . 342 // If the format includes any other prefix, the format is returned with no 343 // modifications. 344 SubjectType *string 345 346 // Metadata pertaining to the operation's result. 347 ResultMetadata middleware.Metadata 348 349 noSmithyDocumentSerde 350 } 351 352 func (c *Client) addOperationAssumeRoleWithSAMLMiddlewares(stack *middleware.Stack, options Options) (err error) { 353 if err := stack.Serialize.Add(&setOperationInputMiddleware{}, middleware.After); err != nil { 354 return err 355 } 356 err = stack.Serialize.Add(&awsAwsquery_serializeOpAssumeRoleWithSAML{}, middleware.After) 357 if err != nil { 358 return err 359 } 360 err = stack.Deserialize.Add(&awsAwsquery_deserializeOpAssumeRoleWithSAML{}, middleware.After) 361 if err != nil { 362 return err 363 } 364 if err := addProtocolFinalizerMiddlewares(stack, options, "AssumeRoleWithSAML"); err != nil { 365 return fmt.Errorf("add protocol finalizers: %v", err) 366 } 367 368 if err = addlegacyEndpointContextSetter(stack, options); err != nil { 369 return err 370 } 371 if err = addSetLoggerMiddleware(stack, options); err != nil { 372 return err 373 } 374 if err = addClientRequestID(stack); err != nil { 375 return err 376 } 377 if err = addComputeContentLength(stack); err != nil { 378 return err 379 } 380 if err = addResolveEndpointMiddleware(stack, options); err != nil { 381 return err 382 } 383 if err = addRetry(stack, options); err != nil { 384 return err 385 } 386 if err = addRawResponseToMetadata(stack); err != nil { 387 return err 388 } 389 if err = addRecordResponseTiming(stack); err != nil { 390 return err 391 } 392 if err = addSpanRetryLoop(stack, options); err != nil { 393 return err 394 } 395 if err = addClientUserAgent(stack, options); err != nil { 396 return err 397 } 398 if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil { 399 return err 400 } 401 if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil { 402 return err 403 } 404 if err = addSetLegacyContextSigningOptionsMiddleware(stack); err != nil { 405 return err 406 } 407 if err = addTimeOffsetBuild(stack, c); err != nil { 408 return err 409 } 410 if err = addUserAgentRetryMode(stack, options); err != nil { 411 return err 412 } 413 if err = addCredentialSource(stack, options); err != nil { 414 return err 415 } 416 if err = addOpAssumeRoleWithSAMLValidationMiddleware(stack); err != nil { 417 return err 418 } 419 if err = stack.Initialize.Add(newServiceMetadataMiddleware_opAssumeRoleWithSAML(options.Region), middleware.Before); err != nil { 420 return err 421 } 422 if err = addRecursionDetection(stack); err != nil { 423 return err 424 } 425 if err = addRequestIDRetrieverMiddleware(stack); err != nil { 426 return err 427 } 428 if err = addResponseErrorMiddleware(stack); err != nil { 429 return err 430 } 431 if err = addRequestResponseLogging(stack, options); err != nil { 432 return err 433 } 434 if err = addDisableHTTPSMiddleware(stack, options); err != nil { 435 return err 436 } 437 if err = addInterceptBeforeRetryLoop(stack, options); err != nil { 438 return err 439 } 440 if err = addInterceptAttempt(stack, options); err != nil { 441 return err 442 } 443 if err = addInterceptExecution(stack, options); err != nil { 444 return err 445 } 446 if err = addInterceptBeforeSerialization(stack, options); err != nil { 447 return err 448 } 449 if err = addInterceptAfterSerialization(stack, options); err != nil { 450 return err 451 } 452 if err = addInterceptBeforeSigning(stack, options); err != nil { 453 return err 454 } 455 if err = addInterceptAfterSigning(stack, options); err != nil { 456 return err 457 } 458 if err = addInterceptTransmit(stack, options); err != nil { 459 return err 460 } 461 if err = addInterceptBeforeDeserialization(stack, options); err != nil { 462 return err 463 } 464 if err = addInterceptAfterDeserialization(stack, options); err != nil { 465 return err 466 } 467 if err = addSpanInitializeStart(stack); err != nil { 468 return err 469 } 470 if err = addSpanInitializeEnd(stack); err != nil { 471 return err 472 } 473 if err = addSpanBuildRequestStart(stack); err != nil { 474 return err 475 } 476 if err = addSpanBuildRequestEnd(stack); err != nil { 477 return err 478 } 479 return nil 480 } 481 482 func newServiceMetadataMiddleware_opAssumeRoleWithSAML(region string) *awsmiddleware.RegisterServiceMetadata { 483 return &awsmiddleware.RegisterServiceMetadata{ 484 Region: region, 485 ServiceID: ServiceID, 486 OperationName: "AssumeRoleWithSAML", 487 } 488 }