software.amazon.awssdk.services.elasticache.model.NodeGroupMember Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of elasticache Show documentation
Show all versions of elasticache Show documentation
The AWS Java SDK for Amazon ElastiCache module holds the client classes that are used for communicating
with Amazon ElastiCache Service
/*
* Copyright 2014-2019 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.elasticache.model;
import java.io.Serializable;
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.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;
/**
*
* Represents a single node within a node group (shard).
*
*/
@Generated("software.amazon.awssdk:codegen")
public final class NodeGroupMember implements SdkPojo, Serializable, ToCopyableBuilder {
private static final SdkField CACHE_CLUSTER_ID_FIELD = SdkField. builder(MarshallingType.STRING)
.getter(getter(NodeGroupMember::cacheClusterId)).setter(setter(Builder::cacheClusterId))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("CacheClusterId").build()).build();
private static final SdkField CACHE_NODE_ID_FIELD = SdkField. builder(MarshallingType.STRING)
.getter(getter(NodeGroupMember::cacheNodeId)).setter(setter(Builder::cacheNodeId))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("CacheNodeId").build()).build();
private static final SdkField READ_ENDPOINT_FIELD = SdkField. builder(MarshallingType.SDK_POJO)
.getter(getter(NodeGroupMember::readEndpoint)).setter(setter(Builder::readEndpoint)).constructor(Endpoint::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ReadEndpoint").build()).build();
private static final SdkField PREFERRED_AVAILABILITY_ZONE_FIELD = SdkField. builder(MarshallingType.STRING)
.getter(getter(NodeGroupMember::preferredAvailabilityZone)).setter(setter(Builder::preferredAvailabilityZone))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("PreferredAvailabilityZone").build())
.build();
private static final SdkField CURRENT_ROLE_FIELD = SdkField. builder(MarshallingType.STRING)
.getter(getter(NodeGroupMember::currentRole)).setter(setter(Builder::currentRole))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("CurrentRole").build()).build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(CACHE_CLUSTER_ID_FIELD,
CACHE_NODE_ID_FIELD, READ_ENDPOINT_FIELD, PREFERRED_AVAILABILITY_ZONE_FIELD, CURRENT_ROLE_FIELD));
private static final long serialVersionUID = 1L;
private final String cacheClusterId;
private final String cacheNodeId;
private final Endpoint readEndpoint;
private final String preferredAvailabilityZone;
private final String currentRole;
private NodeGroupMember(BuilderImpl builder) {
this.cacheClusterId = builder.cacheClusterId;
this.cacheNodeId = builder.cacheNodeId;
this.readEndpoint = builder.readEndpoint;
this.preferredAvailabilityZone = builder.preferredAvailabilityZone;
this.currentRole = builder.currentRole;
}
/**
*
* The ID of the cluster to which the node belongs.
*
*
* @return The ID of the cluster to which the node belongs.
*/
public String cacheClusterId() {
return cacheClusterId;
}
/**
*
* The ID of the node within its cluster. A node ID is a numeric identifier (0001, 0002, etc.).
*
*
* @return The ID of the node within its cluster. A node ID is a numeric identifier (0001, 0002, etc.).
*/
public String cacheNodeId() {
return cacheNodeId;
}
/**
*
* The information required for client programs to connect to a node for read operations. The read endpoint is only
* applicable on Redis (cluster mode disabled) clusters.
*
*
* @return The information required for client programs to connect to a node for read operations. The read endpoint
* is only applicable on Redis (cluster mode disabled) clusters.
*/
public Endpoint readEndpoint() {
return readEndpoint;
}
/**
*
* The name of the Availability Zone in which the node is located.
*
*
* @return The name of the Availability Zone in which the node is located.
*/
public String preferredAvailabilityZone() {
return preferredAvailabilityZone;
}
/**
*
* The role that is currently assigned to the node - primary
or replica
. This member is
* only applicable for Redis (cluster mode disabled) replication groups.
*
*
* @return The role that is currently assigned to the node - primary
or replica
. This
* member is only applicable for Redis (cluster mode disabled) replication groups.
*/
public String currentRole() {
return currentRole;
}
@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 + Objects.hashCode(cacheClusterId());
hashCode = 31 * hashCode + Objects.hashCode(cacheNodeId());
hashCode = 31 * hashCode + Objects.hashCode(readEndpoint());
hashCode = 31 * hashCode + Objects.hashCode(preferredAvailabilityZone());
hashCode = 31 * hashCode + Objects.hashCode(currentRole());
return hashCode;
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof NodeGroupMember)) {
return false;
}
NodeGroupMember other = (NodeGroupMember) obj;
return Objects.equals(cacheClusterId(), other.cacheClusterId()) && Objects.equals(cacheNodeId(), other.cacheNodeId())
&& Objects.equals(readEndpoint(), other.readEndpoint())
&& Objects.equals(preferredAvailabilityZone(), other.preferredAvailabilityZone())
&& Objects.equals(currentRole(), other.currentRole());
}
/**
* 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("NodeGroupMember").add("CacheClusterId", cacheClusterId()).add("CacheNodeId", cacheNodeId())
.add("ReadEndpoint", readEndpoint()).add("PreferredAvailabilityZone", preferredAvailabilityZone())
.add("CurrentRole", currentRole()).build();
}
public Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "CacheClusterId":
return Optional.ofNullable(clazz.cast(cacheClusterId()));
case "CacheNodeId":
return Optional.ofNullable(clazz.cast(cacheNodeId()));
case "ReadEndpoint":
return Optional.ofNullable(clazz.cast(readEndpoint()));
case "PreferredAvailabilityZone":
return Optional.ofNullable(clazz.cast(preferredAvailabilityZone()));
case "CurrentRole":
return Optional.ofNullable(clazz.cast(currentRole()));
default:
return Optional.empty();
}
}
@Override
public List> sdkFields() {
return SDK_FIELDS;
}
private static Function
© 2015 - 2025 Weber Informatics LLC | Privacy Policy