software.amazon.awssdk.services.appstream.model.CreateUserRequest Maven / Gradle / Ivy
Show all versions of appstream Show documentation
/*
* 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.appstream.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 CreateUserRequest extends AppStreamRequest implements
ToCopyableBuilder {
private static final SdkField USER_NAME_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("UserName").getter(getter(CreateUserRequest::userName)).setter(setter(Builder::userName))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("UserName").build()).build();
private static final SdkField MESSAGE_ACTION_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("MessageAction").getter(getter(CreateUserRequest::messageActionAsString))
.setter(setter(Builder::messageAction))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("MessageAction").build()).build();
private static final SdkField FIRST_NAME_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("FirstName").getter(getter(CreateUserRequest::firstName)).setter(setter(Builder::firstName))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("FirstName").build()).build();
private static final SdkField LAST_NAME_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("LastName").getter(getter(CreateUserRequest::lastName)).setter(setter(Builder::lastName))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("LastName").build()).build();
private static final SdkField AUTHENTICATION_TYPE_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("AuthenticationType").getter(getter(CreateUserRequest::authenticationTypeAsString))
.setter(setter(Builder::authenticationType))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("AuthenticationType").build())
.build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(USER_NAME_FIELD,
MESSAGE_ACTION_FIELD, FIRST_NAME_FIELD, LAST_NAME_FIELD, AUTHENTICATION_TYPE_FIELD));
private final String userName;
private final String messageAction;
private final String firstName;
private final String lastName;
private final String authenticationType;
private CreateUserRequest(BuilderImpl builder) {
super(builder);
this.userName = builder.userName;
this.messageAction = builder.messageAction;
this.firstName = builder.firstName;
this.lastName = builder.lastName;
this.authenticationType = builder.authenticationType;
}
/**
*
* The email address of the user.
*
*
*
* Users' email addresses are case-sensitive. During login, if they specify an email address that doesn't use the
* same capitalization as the email address specified when their user pool account was created, a
* "user does not exist" error message displays.
*
*
*
* @return The email address of the user.
*
* Users' email addresses are case-sensitive. During login, if they specify an email address that doesn't
* use the same capitalization as the email address specified when their user pool account was created, a
* "user does not exist" error message displays.
*
*/
public String userName() {
return userName;
}
/**
*
* The action to take for the welcome email that is sent to a user after the user is created in the user pool. If
* you specify SUPPRESS, no email is sent. If you specify RESEND, do not specify the first name or last name of the
* user. If the value is null, the email is sent.
*
*
*
* The temporary password in the welcome email is valid for only 7 days. If users don’t set their passwords within 7
* days, you must send them a new welcome email.
*
*
*
* If the service returns an enum value that is not available in the current SDK version, {@link #messageAction}
* will return {@link MessageAction#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from
* {@link #messageActionAsString}.
*
*
* @return The action to take for the welcome email that is sent to a user after the user is created in the user
* pool. If you specify SUPPRESS, no email is sent. If you specify RESEND, do not specify the first name or
* last name of the user. If the value is null, the email is sent.
*
* The temporary password in the welcome email is valid for only 7 days. If users don’t set their passwords
* within 7 days, you must send them a new welcome email.
*
* @see MessageAction
*/
public MessageAction messageAction() {
return MessageAction.fromValue(messageAction);
}
/**
*
* The action to take for the welcome email that is sent to a user after the user is created in the user pool. If
* you specify SUPPRESS, no email is sent. If you specify RESEND, do not specify the first name or last name of the
* user. If the value is null, the email is sent.
*
*
*
* The temporary password in the welcome email is valid for only 7 days. If users don’t set their passwords within 7
* days, you must send them a new welcome email.
*
*
*
* If the service returns an enum value that is not available in the current SDK version, {@link #messageAction}
* will return {@link MessageAction#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from
* {@link #messageActionAsString}.
*
*
* @return The action to take for the welcome email that is sent to a user after the user is created in the user
* pool. If you specify SUPPRESS, no email is sent. If you specify RESEND, do not specify the first name or
* last name of the user. If the value is null, the email is sent.
*
* The temporary password in the welcome email is valid for only 7 days. If users don’t set their passwords
* within 7 days, you must send them a new welcome email.
*
* @see MessageAction
*/
public String messageActionAsString() {
return messageAction;
}
/**
*
* The first name, or given name, of the user.
*
*
* @return The first name, or given name, of the user.
*/
public String firstName() {
return firstName;
}
/**
*
* The last name, or surname, of the user.
*
*
* @return The last name, or surname, of the user.
*/
public String lastName() {
return lastName;
}
/**
*
* The authentication type for the user. You must specify USERPOOL.
*
*
* If the service returns an enum value that is not available in the current SDK version,
* {@link #authenticationType} will return {@link AuthenticationType#UNKNOWN_TO_SDK_VERSION}. The raw value returned
* by the service is available from {@link #authenticationTypeAsString}.
*
*
* @return The authentication type for the user. You must specify USERPOOL.
* @see AuthenticationType
*/
public AuthenticationType authenticationType() {
return AuthenticationType.fromValue(authenticationType);
}
/**
*
* The authentication type for the user. You must specify USERPOOL.
*
*
* If the service returns an enum value that is not available in the current SDK version,
* {@link #authenticationType} will return {@link AuthenticationType#UNKNOWN_TO_SDK_VERSION}. The raw value returned
* by the service is available from {@link #authenticationTypeAsString}.
*
*
* @return The authentication type for the user. You must specify USERPOOL.
* @see AuthenticationType
*/
public String authenticationTypeAsString() {
return authenticationType;
}
@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(userName());
hashCode = 31 * hashCode + Objects.hashCode(messageActionAsString());
hashCode = 31 * hashCode + Objects.hashCode(firstName());
hashCode = 31 * hashCode + Objects.hashCode(lastName());
hashCode = 31 * hashCode + Objects.hashCode(authenticationTypeAsString());
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 CreateUserRequest)) {
return false;
}
CreateUserRequest other = (CreateUserRequest) obj;
return Objects.equals(userName(), other.userName())
&& Objects.equals(messageActionAsString(), other.messageActionAsString())
&& Objects.equals(firstName(), other.firstName()) && Objects.equals(lastName(), other.lastName())
&& Objects.equals(authenticationTypeAsString(), other.authenticationTypeAsString());
}
/**
* 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("CreateUserRequest")
.add("UserName", userName() == null ? null : "*** Sensitive Data Redacted ***")
.add("MessageAction", messageActionAsString())
.add("FirstName", firstName() == null ? null : "*** Sensitive Data Redacted ***")
.add("LastName", lastName() == null ? null : "*** Sensitive Data Redacted ***")
.add("AuthenticationType", authenticationTypeAsString()).build();
}
public Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "UserName":
return Optional.ofNullable(clazz.cast(userName()));
case "MessageAction":
return Optional.ofNullable(clazz.cast(messageActionAsString()));
case "FirstName":
return Optional.ofNullable(clazz.cast(firstName()));
case "LastName":
return Optional.ofNullable(clazz.cast(lastName()));
case "AuthenticationType":
return Optional.ofNullable(clazz.cast(authenticationTypeAsString()));
default:
return Optional.empty();
}
}
@Override
public List> sdkFields() {
return SDK_FIELDS;
}
private static Function