software.amazon.awssdk.services.sts.model.GetSessionTokenRequest Maven / Gradle / Ivy
/*
* Copyright 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 software.amazon.awssdk.services.sts.model;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Consumer;
import java.util.function.Function;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.awscore.AwsRequestOverrideConfiguration;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.core.protocol.MarshallLocation;
import software.amazon.awssdk.core.protocol.MarshallingType;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;
/**
*/
@Generated("software.amazon.awssdk:codegen")
public final class GetSessionTokenRequest extends StsRequest implements
ToCopyableBuilder {
private static final SdkField DURATION_SECONDS_FIELD = SdkField. builder(MarshallingType.INTEGER)
.getter(getter(GetSessionTokenRequest::durationSeconds)).setter(setter(Builder::durationSeconds))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("DurationSeconds").build()).build();
private static final SdkField SERIAL_NUMBER_FIELD = SdkField. builder(MarshallingType.STRING)
.getter(getter(GetSessionTokenRequest::serialNumber)).setter(setter(Builder::serialNumber))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("SerialNumber").build()).build();
private static final SdkField TOKEN_CODE_FIELD = SdkField. builder(MarshallingType.STRING)
.getter(getter(GetSessionTokenRequest::tokenCode)).setter(setter(Builder::tokenCode))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("TokenCode").build()).build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(DURATION_SECONDS_FIELD,
SERIAL_NUMBER_FIELD, TOKEN_CODE_FIELD));
private final Integer durationSeconds;
private final String serialNumber;
private final String tokenCode;
private GetSessionTokenRequest(BuilderImpl builder) {
super(builder);
this.durationSeconds = builder.durationSeconds;
this.serialNumber = builder.serialNumber;
this.tokenCode = builder.tokenCode;
}
/**
*
* The duration, in seconds, that the credentials should remain valid. Acceptable durations for IAM user sessions
* range from 900 seconds (15 minutes) to 129,600 seconds (36 hours), with 43,200 seconds (12 hours) as the default.
* Sessions for AWS account owners are restricted to a maximum of 3,600 seconds (one hour). If the duration is
* longer than one hour, the session for AWS account owners defaults to one hour.
*
*
* @return The duration, in seconds, that the credentials should remain valid. Acceptable durations for IAM user
* sessions range from 900 seconds (15 minutes) to 129,600 seconds (36 hours), with 43,200 seconds (12
* hours) as the default. Sessions for AWS account owners are restricted to a maximum of 3,600 seconds (one
* hour). If the duration is longer than one hour, the session for AWS account owners defaults to one hour.
*/
public Integer durationSeconds() {
return durationSeconds;
}
/**
*
* The identification number of the MFA device that is associated with the IAM user who is making the
* GetSessionToken
call. Specify this value if the IAM user has a policy that requires MFA
* authentication. The value is either the serial number for a hardware device (such as GAHT12345678
)
* or an Amazon Resource Name (ARN) for a virtual device (such as arn:aws:iam::123456789012:mfa/user
).
* You can find the device for an IAM user by going to the AWS Management Console and viewing the user's security
* credentials.
*
*
* 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:
* =,.@:/-
*
*
* @return The identification number of the MFA device that is associated with the IAM user who is making the
* GetSessionToken
call. Specify this value if the IAM user has a policy that requires MFA
* authentication. The value is either the serial number for a hardware device (such as
* GAHT12345678
) or an Amazon Resource Name (ARN) for a virtual device (such as
* arn:aws:iam::123456789012:mfa/user
). You can find the device for an IAM user by going to the
* AWS Management Console and viewing the user's security credentials.
*
* 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: =,.@:/-
*/
public String serialNumber() {
return serialNumber;
}
/**
*
* The value provided by the MFA device, if MFA is required. If any policy requires the IAM user to submit an MFA
* code, specify this value. If MFA authentication is required, the user must provide a code when requesting a set
* of temporary security credentials. A user who fails to provide the code receives an "access denied" response when
* requesting resources that require MFA authentication.
*
*
* The format for this parameter, as described by its regex pattern, is a sequence of six numeric digits.
*
*
* @return The value provided by the MFA device, if MFA is required. If any policy requires the IAM user to submit
* an MFA code, specify this value. If MFA authentication is required, the user must provide a code when
* requesting a set of temporary security credentials. A user who fails to provide the code receives an
* "access denied" response when requesting resources that require MFA authentication.
*
* The format for this parameter, as described by its regex pattern, is a sequence of six numeric digits.
*/
public String tokenCode() {
return tokenCode;
}
@Override
public Builder toBuilder() {
return new BuilderImpl(this);
}
public static Builder builder() {
return new BuilderImpl();
}
public static Class extends Builder> serializableBuilderClass() {
return BuilderImpl.class;
}
@Override
public int hashCode() {
int hashCode = 1;
hashCode = 31 * hashCode + super.hashCode();
hashCode = 31 * hashCode + Objects.hashCode(durationSeconds());
hashCode = 31 * hashCode + Objects.hashCode(serialNumber());
hashCode = 31 * hashCode + Objects.hashCode(tokenCode());
return hashCode;
}
@Override
public boolean equals(Object obj) {
return super.equals(obj) && equalsBySdkFields(obj);
}
@Override
public boolean equalsBySdkFields(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof GetSessionTokenRequest)) {
return false;
}
GetSessionTokenRequest other = (GetSessionTokenRequest) obj;
return Objects.equals(durationSeconds(), other.durationSeconds()) && Objects.equals(serialNumber(), other.serialNumber())
&& Objects.equals(tokenCode(), other.tokenCode());
}
/**
* Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
* redacted from this string using a placeholder value.
*/
@Override
public String toString() {
return ToString.builder("GetSessionTokenRequest").add("DurationSeconds", durationSeconds())
.add("SerialNumber", serialNumber()).add("TokenCode", tokenCode()).build();
}
public Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "DurationSeconds":
return Optional.ofNullable(clazz.cast(durationSeconds()));
case "SerialNumber":
return Optional.ofNullable(clazz.cast(serialNumber()));
case "TokenCode":
return Optional.ofNullable(clazz.cast(tokenCode()));
default:
return Optional.empty();
}
}
@Override
public List> sdkFields() {
return SDK_FIELDS;
}
private static Function
*
* 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: =,.@:/-
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder serialNumber(String serialNumber);
/**
*
* The value provided by the MFA device, if MFA is required. If any policy requires the IAM user to submit an
* MFA code, specify this value. If MFA authentication is required, the user must provide a code when requesting
* a set of temporary security credentials. A user who fails to provide the code receives an "access denied"
* response when requesting resources that require MFA authentication.
*
*
* The format for this parameter, as described by its regex pattern, is a sequence of six numeric digits.
*
*
* @param tokenCode
* The value provided by the MFA device, if MFA is required. If any policy requires the IAM user to
* submit an MFA code, specify this value. If MFA authentication is required, the user must provide a
* code when requesting a set of temporary security credentials. A user who fails to provide the code
* receives an "access denied" response when requesting resources that require MFA authentication.
*
* The format for this parameter, as described by its regex pattern, is a sequence of six numeric digits.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder tokenCode(String tokenCode);
@Override
Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration);
@Override
Builder overrideConfiguration(Consumer builderConsumer);
}
static final class BuilderImpl extends StsRequest.BuilderImpl implements Builder {
private Integer durationSeconds;
private String serialNumber;
private String tokenCode;
private BuilderImpl() {
}
private BuilderImpl(GetSessionTokenRequest model) {
super(model);
durationSeconds(model.durationSeconds);
serialNumber(model.serialNumber);
tokenCode(model.tokenCode);
}
public final Integer getDurationSeconds() {
return durationSeconds;
}
@Override
public final Builder durationSeconds(Integer durationSeconds) {
this.durationSeconds = durationSeconds;
return this;
}
public final void setDurationSeconds(Integer durationSeconds) {
this.durationSeconds = durationSeconds;
}
public final String getSerialNumber() {
return serialNumber;
}
@Override
public final Builder serialNumber(String serialNumber) {
this.serialNumber = serialNumber;
return this;
}
public final void setSerialNumber(String serialNumber) {
this.serialNumber = serialNumber;
}
public final String getTokenCode() {
return tokenCode;
}
@Override
public final Builder tokenCode(String tokenCode) {
this.tokenCode = tokenCode;
return this;
}
public final void setTokenCode(String tokenCode) {
this.tokenCode = tokenCode;
}
@Override
public Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration) {
super.overrideConfiguration(overrideConfiguration);
return this;
}
@Override
public Builder overrideConfiguration(Consumer builderConsumer) {
super.overrideConfiguration(builderConsumer);
return this;
}
@Override
public GetSessionTokenRequest build() {
return new GetSessionTokenRequest(this);
}
@Override
public List> sdkFields() {
return SDK_FIELDS;
}
}
}