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

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 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 getter(Function g) { return obj -> g.apply((GetSessionTokenRequest) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends StsRequest.Builder, SdkPojo, CopyableBuilder { /** *

* 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. *

* * @param durationSeconds * 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 Returns a reference to this object so that method calls can be chained together. */ Builder durationSeconds(Integer 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: * =,.@:/- *

* * @param serialNumber * 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 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; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy