All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.amazonaws.services.securitytoken.model.GetFederationTokenRequest Maven / Gradle / Ivy

/*
 * Copyright 2010-2016 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License").
 * You may not use this file except in compliance with the License.
 * A copy of the License is located at
 * 
 *  http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file is distributed
 * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
 * express or implied. See the License for the specific language governing
 * permissions and limitations under the License.
 */
package com.amazonaws.services.securitytoken.model;

import java.io.Serializable;

import com.amazonaws.AmazonWebServiceRequest;

/**
 * Container for the parameters to the {@link com.amazonaws.services.securitytoken.AWSSecurityTokenService#getFederationToken(GetFederationTokenRequest) GetFederationToken operation}.
 * 

* Returns a set of temporary security credentials (consisting of an * access key ID, a secret access key, and a security token) for a * federated user. A typical use is in a proxy application that gets * temporary security credentials on behalf of distributed applications * inside a corporate network. Because you must call the * GetFederationToken action using the long-term security * credentials of an IAM user, this call is appropriate in contexts where * those credentials can be safely stored, usually in a server-based * application. *

*

* NOTE: If you are creating a mobile-based or browser-based app * that can authenticate users using a web identity provider like Login * with Amazon, Facebook, Google, or an OpenID Connect-compatible * identity provider, we recommend that you use Amazon Cognito or * AssumeRoleWithWebIdentity. For more information, see Federation * Through a Web-based Identity Provider. *

*

* The GetFederationToken action must be called by using the * long-term AWS security credentials of an IAM user. You can also call * GetFederationToken using the security credentials of an * AWS account (root), but this is not recommended. Instead, we recommend * that you create an IAM user for the purpose of the proxy application * and then attach a policy to the IAM user that limits federated users * to only the actions and resources they need access to. For more * information, see * IAM Best Practices * in the Using IAM . *

*

* The temporary security credentials that are obtained by using the * long-term credentials of an IAM user are valid for the specified * duration, between 900 seconds (15 minutes) and 129600 seconds (36 * hours). Temporary credentials that are obtained by using AWS account * (root) credentials have a maximum duration of 3600 seconds (1 hour) *

*

* Permissions *

*

* The permissions for the temporary security credentials returned by * GetFederationToken are determined by a combination of the * following: *

* *
    *
  • The policy or policies that are attached to the IAM user whose * credentials are used to call GetFederationToken .
  • *
  • The policy that is passed as a parameter in the call.
  • * *
*

* The passed policy is attached to the temporary security credentials * that result from the GetFederationToken API call--that * is, to the federated user . When the federated user makes an * AWS request, AWS evaluates the policy attached to the federated user * in combination with the policy or policies attached to the IAM user * whose credentials were used to call GetFederationToken . * AWS allows the federated user's request only when both the federated * user and the IAM user are explicitly allowed to perform the * requested action. The passed policy cannot grant more permissions than * those that are defined in the IAM user policy. *

*

* A typical use case is that the permissions of the IAM user whose * credentials are used to call GetFederationToken are * designed to allow access to all the actions and resources that any * federated user will need. Then, for individual users, you pass a * policy to the operation that scopes down the permissions to a level * that's appropriate to that individual user, using a policy that allows * only a subset of permissions that are granted to the IAM user. *

*

* If you do not pass a policy, the resulting temporary security * credentials have no effective permissions. The only exception is when * the temporary security credentials are used to access a resource that * has a resource-based policy that specifically allows the federated * user to access the resource. *

*

* For more information about how permissions work, see * Permissions for GetFederationToken . For information about using GetFederationToken to create temporary security credentials, see GetFederationToken—Federation Through a Custom Identity Broker * . *

* * @see com.amazonaws.services.securitytoken.AWSSecurityTokenService#getFederationToken(GetFederationTokenRequest) */ public class GetFederationTokenRequest extends AmazonWebServiceRequest implements Serializable { /** * The name of the federated user. The name is used as an identifier for * the temporary security credentials (such as Bob). For * example, you can reference the federated user name in a resource-based * policy, such as in an Amazon S3 bucket policy. *

* Constraints:
* Length: 2 - 32
* Pattern: [\w+=,.@-]*
*/ private String name; /** * An IAM policy in JSON format that is passed with the * GetFederationToken call and evaluated along with the * policy or policies that are attached to the IAM user whose credentials * are used to call GetFederationToken. The passed policy is * used to scope down the permissions that are available to the IAM user, * by allowing only a subset of the permissions that are granted to the * IAM user. The passed policy cannot grant more permissions than those * granted to the IAM user. The final permissions for the federated user * are the most restrictive set based on the intersection of the passed * policy and the IAM user policy.

If you do not pass a policy, the * resulting temporary security credentials have no effective * permissions. The only exception is when the temporary security * credentials are used to access a resource that has a resource-based * policy that specifically allows the federated user to access the * resource. The policy plain text must be 2048 bytes or shorter. * However, an internal conversion compresses it into a packed binary * format with a separate limit. The PackedPolicySize response element * indicates by percentage how close to the upper size limit the policy * is, with 100% equaling the maximum allowed size.

For more * information about how permissions work, see Permissions * for GetFederationToken. *

* Constraints:
* Length: 1 - 2048
* Pattern: [\u0009\u000A\u000D\u0020-\u00FF]+
*/ private String policy; /** * The duration, in seconds, that the session should last. Acceptable * durations for federation sessions range from 900 seconds (15 minutes) * to 129600 seconds (36 hours), with 43200 seconds (12 hours) as the * default. Sessions obtained using AWS account (root) credentials are * restricted to a maximum of 3600 seconds (one hour). If the specified * duration is longer than one hour, the session obtained by using AWS * account (root) credentials defaults to one hour. *

* Constraints:
* Range: 900 - 129600
*/ private Integer durationSeconds; /** * Default constructor for a new GetFederationTokenRequest object. Callers should use the * setter or fluent setter (with...) methods to initialize this object after creating it. */ public GetFederationTokenRequest() {} /** * Constructs a new GetFederationTokenRequest object. * Callers should use the setter or fluent setter (with...) methods to * initialize any additional object members. * * @param name The name of the federated user. The name is used as an * identifier for the temporary security credentials (such as * Bob). For example, you can reference the federated user * name in a resource-based policy, such as in an Amazon S3 bucket * policy. */ public GetFederationTokenRequest(String name) { setName(name); } /** * The name of the federated user. The name is used as an identifier for * the temporary security credentials (such as Bob). For * example, you can reference the federated user name in a resource-based * policy, such as in an Amazon S3 bucket policy. *

* Constraints:
* Length: 2 - 32
* Pattern: [\w+=,.@-]*
* * @return The name of the federated user. The name is used as an identifier for * the temporary security credentials (such as Bob). For * example, you can reference the federated user name in a resource-based * policy, such as in an Amazon S3 bucket policy. */ public String getName() { return name; } /** * The name of the federated user. The name is used as an identifier for * the temporary security credentials (such as Bob). For * example, you can reference the federated user name in a resource-based * policy, such as in an Amazon S3 bucket policy. *

* Constraints:
* Length: 2 - 32
* Pattern: [\w+=,.@-]*
* * @param name The name of the federated user. The name is used as an identifier for * the temporary security credentials (such as Bob). For * example, you can reference the federated user name in a resource-based * policy, such as in an Amazon S3 bucket policy. */ public void setName(String name) { this.name = name; } /** * The name of the federated user. The name is used as an identifier for * the temporary security credentials (such as Bob). For * example, you can reference the federated user name in a resource-based * policy, such as in an Amazon S3 bucket policy. *

* Returns a reference to this object so that method calls can be chained together. *

* Constraints:
* Length: 2 - 32
* Pattern: [\w+=,.@-]*
* * @param name The name of the federated user. The name is used as an identifier for * the temporary security credentials (such as Bob). For * example, you can reference the federated user name in a resource-based * policy, such as in an Amazon S3 bucket policy. * * @return A reference to this updated object so that method calls can be chained * together. */ public GetFederationTokenRequest withName(String name) { this.name = name; return this; } /** * An IAM policy in JSON format that is passed with the * GetFederationToken call and evaluated along with the * policy or policies that are attached to the IAM user whose credentials * are used to call GetFederationToken. The passed policy is * used to scope down the permissions that are available to the IAM user, * by allowing only a subset of the permissions that are granted to the * IAM user. The passed policy cannot grant more permissions than those * granted to the IAM user. The final permissions for the federated user * are the most restrictive set based on the intersection of the passed * policy and the IAM user policy.

If you do not pass a policy, the * resulting temporary security credentials have no effective * permissions. The only exception is when the temporary security * credentials are used to access a resource that has a resource-based * policy that specifically allows the federated user to access the * resource. The policy plain text must be 2048 bytes or shorter. * However, an internal conversion compresses it into a packed binary * format with a separate limit. The PackedPolicySize response element * indicates by percentage how close to the upper size limit the policy * is, with 100% equaling the maximum allowed size.

For more * information about how permissions work, see Permissions * for GetFederationToken. *

* Constraints:
* Length: 1 - 2048
* Pattern: [\u0009\u000A\u000D\u0020-\u00FF]+
* * @return An IAM policy in JSON format that is passed with the * GetFederationToken call and evaluated along with the * policy or policies that are attached to the IAM user whose credentials * are used to call GetFederationToken. The passed policy is * used to scope down the permissions that are available to the IAM user, * by allowing only a subset of the permissions that are granted to the * IAM user. The passed policy cannot grant more permissions than those * granted to the IAM user. The final permissions for the federated user * are the most restrictive set based on the intersection of the passed * policy and the IAM user policy.

If you do not pass a policy, the * resulting temporary security credentials have no effective * permissions. The only exception is when the temporary security * credentials are used to access a resource that has a resource-based * policy that specifically allows the federated user to access the * resource. The policy plain text must be 2048 bytes or shorter. * However, an internal conversion compresses it into a packed binary * format with a separate limit. The PackedPolicySize response element * indicates by percentage how close to the upper size limit the policy * is, with 100% equaling the maximum allowed size.

For more * information about how permissions work, see Permissions * for GetFederationToken. */ public String getPolicy() { return policy; } /** * An IAM policy in JSON format that is passed with the * GetFederationToken call and evaluated along with the * policy or policies that are attached to the IAM user whose credentials * are used to call GetFederationToken. The passed policy is * used to scope down the permissions that are available to the IAM user, * by allowing only a subset of the permissions that are granted to the * IAM user. The passed policy cannot grant more permissions than those * granted to the IAM user. The final permissions for the federated user * are the most restrictive set based on the intersection of the passed * policy and the IAM user policy.

If you do not pass a policy, the * resulting temporary security credentials have no effective * permissions. The only exception is when the temporary security * credentials are used to access a resource that has a resource-based * policy that specifically allows the federated user to access the * resource. The policy plain text must be 2048 bytes or shorter. * However, an internal conversion compresses it into a packed binary * format with a separate limit. The PackedPolicySize response element * indicates by percentage how close to the upper size limit the policy * is, with 100% equaling the maximum allowed size.

For more * information about how permissions work, see Permissions * for GetFederationToken. *

* Constraints:
* Length: 1 - 2048
* Pattern: [\u0009\u000A\u000D\u0020-\u00FF]+
* * @param policy An IAM policy in JSON format that is passed with the * GetFederationToken call and evaluated along with the * policy or policies that are attached to the IAM user whose credentials * are used to call GetFederationToken. The passed policy is * used to scope down the permissions that are available to the IAM user, * by allowing only a subset of the permissions that are granted to the * IAM user. The passed policy cannot grant more permissions than those * granted to the IAM user. The final permissions for the federated user * are the most restrictive set based on the intersection of the passed * policy and the IAM user policy.

If you do not pass a policy, the * resulting temporary security credentials have no effective * permissions. The only exception is when the temporary security * credentials are used to access a resource that has a resource-based * policy that specifically allows the federated user to access the * resource. The policy plain text must be 2048 bytes or shorter. * However, an internal conversion compresses it into a packed binary * format with a separate limit. The PackedPolicySize response element * indicates by percentage how close to the upper size limit the policy * is, with 100% equaling the maximum allowed size.

For more * information about how permissions work, see Permissions * for GetFederationToken. */ public void setPolicy(String policy) { this.policy = policy; } /** * An IAM policy in JSON format that is passed with the * GetFederationToken call and evaluated along with the * policy or policies that are attached to the IAM user whose credentials * are used to call GetFederationToken. The passed policy is * used to scope down the permissions that are available to the IAM user, * by allowing only a subset of the permissions that are granted to the * IAM user. The passed policy cannot grant more permissions than those * granted to the IAM user. The final permissions for the federated user * are the most restrictive set based on the intersection of the passed * policy and the IAM user policy.

If you do not pass a policy, the * resulting temporary security credentials have no effective * permissions. The only exception is when the temporary security * credentials are used to access a resource that has a resource-based * policy that specifically allows the federated user to access the * resource. The policy plain text must be 2048 bytes or shorter. * However, an internal conversion compresses it into a packed binary * format with a separate limit. The PackedPolicySize response element * indicates by percentage how close to the upper size limit the policy * is, with 100% equaling the maximum allowed size.

For more * information about how permissions work, see Permissions * for GetFederationToken. *

* Returns a reference to this object so that method calls can be chained together. *

* Constraints:
* Length: 1 - 2048
* Pattern: [\u0009\u000A\u000D\u0020-\u00FF]+
* * @param policy An IAM policy in JSON format that is passed with the * GetFederationToken call and evaluated along with the * policy or policies that are attached to the IAM user whose credentials * are used to call GetFederationToken. The passed policy is * used to scope down the permissions that are available to the IAM user, * by allowing only a subset of the permissions that are granted to the * IAM user. The passed policy cannot grant more permissions than those * granted to the IAM user. The final permissions for the federated user * are the most restrictive set based on the intersection of the passed * policy and the IAM user policy.

If you do not pass a policy, the * resulting temporary security credentials have no effective * permissions. The only exception is when the temporary security * credentials are used to access a resource that has a resource-based * policy that specifically allows the federated user to access the * resource. The policy plain text must be 2048 bytes or shorter. * However, an internal conversion compresses it into a packed binary * format with a separate limit. The PackedPolicySize response element * indicates by percentage how close to the upper size limit the policy * is, with 100% equaling the maximum allowed size.

For more * information about how permissions work, see Permissions * for GetFederationToken. * * @return A reference to this updated object so that method calls can be chained * together. */ public GetFederationTokenRequest withPolicy(String policy) { this.policy = policy; return this; } /** * The duration, in seconds, that the session should last. Acceptable * durations for federation sessions range from 900 seconds (15 minutes) * to 129600 seconds (36 hours), with 43200 seconds (12 hours) as the * default. Sessions obtained using AWS account (root) credentials are * restricted to a maximum of 3600 seconds (one hour). If the specified * duration is longer than one hour, the session obtained by using AWS * account (root) credentials defaults to one hour. *

* Constraints:
* Range: 900 - 129600
* * @return The duration, in seconds, that the session should last. Acceptable * durations for federation sessions range from 900 seconds (15 minutes) * to 129600 seconds (36 hours), with 43200 seconds (12 hours) as the * default. Sessions obtained using AWS account (root) credentials are * restricted to a maximum of 3600 seconds (one hour). If the specified * duration is longer than one hour, the session obtained by using AWS * account (root) credentials defaults to one hour. */ public Integer getDurationSeconds() { return durationSeconds; } /** * The duration, in seconds, that the session should last. Acceptable * durations for federation sessions range from 900 seconds (15 minutes) * to 129600 seconds (36 hours), with 43200 seconds (12 hours) as the * default. Sessions obtained using AWS account (root) credentials are * restricted to a maximum of 3600 seconds (one hour). If the specified * duration is longer than one hour, the session obtained by using AWS * account (root) credentials defaults to one hour. *

* Constraints:
* Range: 900 - 129600
* * @param durationSeconds The duration, in seconds, that the session should last. Acceptable * durations for federation sessions range from 900 seconds (15 minutes) * to 129600 seconds (36 hours), with 43200 seconds (12 hours) as the * default. Sessions obtained using AWS account (root) credentials are * restricted to a maximum of 3600 seconds (one hour). If the specified * duration is longer than one hour, the session obtained by using AWS * account (root) credentials defaults to one hour. */ public void setDurationSeconds(Integer durationSeconds) { this.durationSeconds = durationSeconds; } /** * The duration, in seconds, that the session should last. Acceptable * durations for federation sessions range from 900 seconds (15 minutes) * to 129600 seconds (36 hours), with 43200 seconds (12 hours) as the * default. Sessions obtained using AWS account (root) credentials are * restricted to a maximum of 3600 seconds (one hour). If the specified * duration is longer than one hour, the session obtained by using AWS * account (root) credentials defaults to one hour. *

* Returns a reference to this object so that method calls can be chained together. *

* Constraints:
* Range: 900 - 129600
* * @param durationSeconds The duration, in seconds, that the session should last. Acceptable * durations for federation sessions range from 900 seconds (15 minutes) * to 129600 seconds (36 hours), with 43200 seconds (12 hours) as the * default. Sessions obtained using AWS account (root) credentials are * restricted to a maximum of 3600 seconds (one hour). If the specified * duration is longer than one hour, the session obtained by using AWS * account (root) credentials defaults to one hour. * * @return A reference to this updated object so that method calls can be chained * together. */ public GetFederationTokenRequest withDurationSeconds(Integer durationSeconds) { this.durationSeconds = durationSeconds; return this; } /** * Returns a string representation of this object; useful for testing and * debugging. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getName() != null) sb.append("Name: " + getName() + ","); if (getPolicy() != null) sb.append("Policy: " + getPolicy() + ","); if (getDurationSeconds() != null) sb.append("DurationSeconds: " + getDurationSeconds() ); sb.append("}"); return sb.toString(); } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getName() == null) ? 0 : getName().hashCode()); hashCode = prime * hashCode + ((getPolicy() == null) ? 0 : getPolicy().hashCode()); hashCode = prime * hashCode + ((getDurationSeconds() == null) ? 0 : getDurationSeconds().hashCode()); return hashCode; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof GetFederationTokenRequest == false) return false; GetFederationTokenRequest other = (GetFederationTokenRequest)obj; if (other.getName() == null ^ this.getName() == null) return false; if (other.getName() != null && other.getName().equals(this.getName()) == false) return false; if (other.getPolicy() == null ^ this.getPolicy() == null) return false; if (other.getPolicy() != null && other.getPolicy().equals(this.getPolicy()) == false) return false; if (other.getDurationSeconds() == null ^ this.getDurationSeconds() == null) return false; if (other.getDurationSeconds() != null && other.getDurationSeconds().equals(this.getDurationSeconds()) == false) return false; return true; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy