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

software.amazon.awssdk.services.emr.model.SessionMappingSummary Maven / Gradle / Ivy

Go to download

The AWS Java SDK for Amazon EMR module holds the client classes that are used for communicating with Amazon Elastic MapReduce Service

There is a newer version: 2.28.3
Show newest version
/*
 * 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.emr.model;

import java.io.Serializable;
import java.time.Instant;
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.Function;
import software.amazon.awssdk.annotations.Generated;
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;

/**
 * 

* Details for an Amazon EMR Studio session mapping. The details do not include the time the session mapping was last * modified. *

*/ @Generated("software.amazon.awssdk:codegen") public final class SessionMappingSummary implements SdkPojo, Serializable, ToCopyableBuilder { private static final SdkField STUDIO_ID_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("StudioId").getter(getter(SessionMappingSummary::studioId)).setter(setter(Builder::studioId)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("StudioId").build()).build(); private static final SdkField IDENTITY_ID_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("IdentityId").getter(getter(SessionMappingSummary::identityId)).setter(setter(Builder::identityId)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("IdentityId").build()).build(); private static final SdkField IDENTITY_NAME_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("IdentityName").getter(getter(SessionMappingSummary::identityName)).setter(setter(Builder::identityName)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("IdentityName").build()).build(); private static final SdkField IDENTITY_TYPE_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("IdentityType").getter(getter(SessionMappingSummary::identityTypeAsString)) .setter(setter(Builder::identityType)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("IdentityType").build()).build(); private static final SdkField SESSION_POLICY_ARN_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("SessionPolicyArn").getter(getter(SessionMappingSummary::sessionPolicyArn)) .setter(setter(Builder::sessionPolicyArn)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("SessionPolicyArn").build()).build(); private static final SdkField CREATION_TIME_FIELD = SdkField. builder(MarshallingType.INSTANT) .memberName("CreationTime").getter(getter(SessionMappingSummary::creationTime)).setter(setter(Builder::creationTime)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("CreationTime").build()).build(); private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(STUDIO_ID_FIELD, IDENTITY_ID_FIELD, IDENTITY_NAME_FIELD, IDENTITY_TYPE_FIELD, SESSION_POLICY_ARN_FIELD, CREATION_TIME_FIELD)); private static final long serialVersionUID = 1L; private final String studioId; private final String identityId; private final String identityName; private final String identityType; private final String sessionPolicyArn; private final Instant creationTime; private SessionMappingSummary(BuilderImpl builder) { this.studioId = builder.studioId; this.identityId = builder.identityId; this.identityName = builder.identityName; this.identityType = builder.identityType; this.sessionPolicyArn = builder.sessionPolicyArn; this.creationTime = builder.creationTime; } /** *

* The ID of the Amazon EMR Studio. *

* * @return The ID of the Amazon EMR Studio. */ public final String studioId() { return studioId; } /** *

* The globally unique identifier (GUID) of the user or group from the IAM Identity Center Identity Store. *

* * @return The globally unique identifier (GUID) of the user or group from the IAM Identity Center Identity Store. */ public final String identityId() { return identityId; } /** *

* The name of the user or group. For more information, see UserName and DisplayName in the IAM Identity Center Identity Store API Reference. *

* * @return The name of the user or group. For more information, see UserName and DisplayName in the IAM Identity Center Identity Store API Reference. */ public final String identityName() { return identityName; } /** *

* Specifies whether the identity mapped to the Amazon EMR Studio is a user or a group. *

*

* If the service returns an enum value that is not available in the current SDK version, {@link #identityType} will * return {@link IdentityType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from * {@link #identityTypeAsString}. *

* * @return Specifies whether the identity mapped to the Amazon EMR Studio is a user or a group. * @see IdentityType */ public final IdentityType identityType() { return IdentityType.fromValue(identityType); } /** *

* Specifies whether the identity mapped to the Amazon EMR Studio is a user or a group. *

*

* If the service returns an enum value that is not available in the current SDK version, {@link #identityType} will * return {@link IdentityType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from * {@link #identityTypeAsString}. *

* * @return Specifies whether the identity mapped to the Amazon EMR Studio is a user or a group. * @see IdentityType */ public final String identityTypeAsString() { return identityType; } /** *

* The Amazon Resource Name (ARN) of the session policy associated with the user or group. *

* * @return The Amazon Resource Name (ARN) of the session policy associated with the user or group. */ public final String sessionPolicyArn() { return sessionPolicyArn; } /** *

* The time the session mapping was created. *

* * @return The time the session mapping was created. */ public final Instant creationTime() { return creationTime; } @Override public Builder toBuilder() { return new BuilderImpl(this); } public static Builder builder() { return new BuilderImpl(); } public static Class serializableBuilderClass() { return BuilderImpl.class; } @Override public final int hashCode() { int hashCode = 1; hashCode = 31 * hashCode + Objects.hashCode(studioId()); hashCode = 31 * hashCode + Objects.hashCode(identityId()); hashCode = 31 * hashCode + Objects.hashCode(identityName()); hashCode = 31 * hashCode + Objects.hashCode(identityTypeAsString()); hashCode = 31 * hashCode + Objects.hashCode(sessionPolicyArn()); hashCode = 31 * hashCode + Objects.hashCode(creationTime()); return hashCode; } @Override public final boolean equals(Object obj) { return equalsBySdkFields(obj); } @Override public final boolean equalsBySdkFields(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof SessionMappingSummary)) { return false; } SessionMappingSummary other = (SessionMappingSummary) obj; return Objects.equals(studioId(), other.studioId()) && Objects.equals(identityId(), other.identityId()) && Objects.equals(identityName(), other.identityName()) && Objects.equals(identityTypeAsString(), other.identityTypeAsString()) && Objects.equals(sessionPolicyArn(), other.sessionPolicyArn()) && Objects.equals(creationTime(), other.creationTime()); } /** * 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 final String toString() { return ToString.builder("SessionMappingSummary").add("StudioId", studioId()).add("IdentityId", identityId()) .add("IdentityName", identityName()).add("IdentityType", identityTypeAsString()) .add("SessionPolicyArn", sessionPolicyArn()).add("CreationTime", creationTime()).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "StudioId": return Optional.ofNullable(clazz.cast(studioId())); case "IdentityId": return Optional.ofNullable(clazz.cast(identityId())); case "IdentityName": return Optional.ofNullable(clazz.cast(identityName())); case "IdentityType": return Optional.ofNullable(clazz.cast(identityTypeAsString())); case "SessionPolicyArn": return Optional.ofNullable(clazz.cast(sessionPolicyArn())); case "CreationTime": return Optional.ofNullable(clazz.cast(creationTime())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((SessionMappingSummary) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends SdkPojo, CopyableBuilder { /** *

* The ID of the Amazon EMR Studio. *

* * @param studioId * The ID of the Amazon EMR Studio. * @return Returns a reference to this object so that method calls can be chained together. */ Builder studioId(String studioId); /** *

* The globally unique identifier (GUID) of the user or group from the IAM Identity Center Identity Store. *

* * @param identityId * The globally unique identifier (GUID) of the user or group from the IAM Identity Center Identity * Store. * @return Returns a reference to this object so that method calls can be chained together. */ Builder identityId(String identityId); /** *

* The name of the user or group. For more information, see UserName and DisplayName in the IAM Identity Center Identity Store API Reference. *

* * @param identityName * The name of the user or group. For more information, see UserName and DisplayName in the IAM Identity Center Identity Store API Reference. * @return Returns a reference to this object so that method calls can be chained together. */ Builder identityName(String identityName); /** *

* Specifies whether the identity mapped to the Amazon EMR Studio is a user or a group. *

* * @param identityType * Specifies whether the identity mapped to the Amazon EMR Studio is a user or a group. * @see IdentityType * @return Returns a reference to this object so that method calls can be chained together. * @see IdentityType */ Builder identityType(String identityType); /** *

* Specifies whether the identity mapped to the Amazon EMR Studio is a user or a group. *

* * @param identityType * Specifies whether the identity mapped to the Amazon EMR Studio is a user or a group. * @see IdentityType * @return Returns a reference to this object so that method calls can be chained together. * @see IdentityType */ Builder identityType(IdentityType identityType); /** *

* The Amazon Resource Name (ARN) of the session policy associated with the user or group. *

* * @param sessionPolicyArn * The Amazon Resource Name (ARN) of the session policy associated with the user or group. * @return Returns a reference to this object so that method calls can be chained together. */ Builder sessionPolicyArn(String sessionPolicyArn); /** *

* The time the session mapping was created. *

* * @param creationTime * The time the session mapping was created. * @return Returns a reference to this object so that method calls can be chained together. */ Builder creationTime(Instant creationTime); } static final class BuilderImpl implements Builder { private String studioId; private String identityId; private String identityName; private String identityType; private String sessionPolicyArn; private Instant creationTime; private BuilderImpl() { } private BuilderImpl(SessionMappingSummary model) { studioId(model.studioId); identityId(model.identityId); identityName(model.identityName); identityType(model.identityType); sessionPolicyArn(model.sessionPolicyArn); creationTime(model.creationTime); } public final String getStudioId() { return studioId; } public final void setStudioId(String studioId) { this.studioId = studioId; } @Override public final Builder studioId(String studioId) { this.studioId = studioId; return this; } public final String getIdentityId() { return identityId; } public final void setIdentityId(String identityId) { this.identityId = identityId; } @Override public final Builder identityId(String identityId) { this.identityId = identityId; return this; } public final String getIdentityName() { return identityName; } public final void setIdentityName(String identityName) { this.identityName = identityName; } @Override public final Builder identityName(String identityName) { this.identityName = identityName; return this; } public final String getIdentityType() { return identityType; } public final void setIdentityType(String identityType) { this.identityType = identityType; } @Override public final Builder identityType(String identityType) { this.identityType = identityType; return this; } @Override public final Builder identityType(IdentityType identityType) { this.identityType(identityType == null ? null : identityType.toString()); return this; } public final String getSessionPolicyArn() { return sessionPolicyArn; } public final void setSessionPolicyArn(String sessionPolicyArn) { this.sessionPolicyArn = sessionPolicyArn; } @Override public final Builder sessionPolicyArn(String sessionPolicyArn) { this.sessionPolicyArn = sessionPolicyArn; return this; } public final Instant getCreationTime() { return creationTime; } public final void setCreationTime(Instant creationTime) { this.creationTime = creationTime; } @Override public final Builder creationTime(Instant creationTime) { this.creationTime = creationTime; return this; } @Override public SessionMappingSummary build() { return new SessionMappingSummary(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy