software.amazon.awssdk.services.databasemigration.model.DescribeReplicationInstancesResponse Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dms Show documentation
Show all versions of dms Show documentation
The AWS Java SDK for AWS Database Migration Service module holds the client classes that are used for
communicating with AWS Database Migration Service.
/*
* Copyright 2012-2017 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.databasemigration.model;
import java.util.Arrays;
import java.util.Collection;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.stream.Collectors;
import javax.annotation.Generated;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;
/**
*
*/
@Generated("software.amazon.awssdk:codegen")
public class DescribeReplicationInstancesResponse extends DatabaseMigrationResponse implements
ToCopyableBuilder {
private final String marker;
private final List replicationInstances;
private DescribeReplicationInstancesResponse(BuilderImpl builder) {
super(builder);
this.marker = builder.marker;
this.replicationInstances = builder.replicationInstances;
}
/**
*
* An optional pagination token provided by a previous request. If this parameter is specified, the response
* includes only records beyond the marker, up to the value specified by MaxRecords
.
*
*
* @return An optional pagination token provided by a previous request. If this parameter is specified, the response
* includes only records beyond the marker, up to the value specified by MaxRecords
.
*/
public String marker() {
return marker;
}
/**
*
* The replication instances described.
*
*
* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
*
*
* @return The replication instances described.
*/
public List replicationInstances() {
return replicationInstances;
}
@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(marker());
hashCode = 31 * hashCode + Objects.hashCode(replicationInstances());
return hashCode;
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof DescribeReplicationInstancesResponse)) {
return false;
}
DescribeReplicationInstancesResponse other = (DescribeReplicationInstancesResponse) obj;
return Objects.equals(marker(), other.marker()) && Objects.equals(replicationInstances(), other.replicationInstances());
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder("{");
if (marker() != null) {
sb.append("Marker: ").append(marker()).append(",");
}
if (replicationInstances() != null) {
sb.append("ReplicationInstances: ").append(replicationInstances()).append(",");
}
if (sb.length() > 1) {
sb.setLength(sb.length() - 1);
}
sb.append("}");
return sb.toString();
}
public Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "Marker":
return Optional.of(clazz.cast(marker()));
case "ReplicationInstances":
return Optional.of(clazz.cast(replicationInstances()));
default:
return Optional.empty();
}
}
public interface Builder extends DatabaseMigrationResponse.Builder,
CopyableBuilder {
/**
*
* An optional pagination token provided by a previous request. If this parameter is specified, the response
* includes only records beyond the marker, up to the value specified by MaxRecords
.
*
*
* @param marker
* An optional pagination token provided by a previous request. If this parameter is specified, the
* response includes only records beyond the marker, up to the value specified by MaxRecords
* .
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder marker(String marker);
/**
*
* The replication instances described.
*
*
* @param replicationInstances
* The replication instances described.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder replicationInstances(Collection replicationInstances);
/**
*
* The replication instances described.
*
*
* @param replicationInstances
* The replication instances described.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder replicationInstances(ReplicationInstance... replicationInstances);
}
static final class BuilderImpl extends DatabaseMigrationResponse.BuilderImpl implements Builder {
private String marker;
private List replicationInstances;
private BuilderImpl() {
}
private BuilderImpl(DescribeReplicationInstancesResponse model) {
marker(model.marker);
replicationInstances(model.replicationInstances);
}
public final String getMarker() {
return marker;
}
@Override
public final Builder marker(String marker) {
this.marker = marker;
return this;
}
public final void setMarker(String marker) {
this.marker = marker;
}
public final Collection getReplicationInstances() {
return replicationInstances != null ? replicationInstances.stream().map(ReplicationInstance::toBuilder)
.collect(Collectors.toList()) : null;
}
@Override
public final Builder replicationInstances(Collection replicationInstances) {
this.replicationInstances = ReplicationInstanceListCopier.copy(replicationInstances);
return this;
}
@Override
@SafeVarargs
public final Builder replicationInstances(ReplicationInstance... replicationInstances) {
replicationInstances(Arrays.asList(replicationInstances));
return this;
}
public final void setReplicationInstances(Collection replicationInstances) {
this.replicationInstances = ReplicationInstanceListCopier.copyFromBuilder(replicationInstances);
}
@Override
public DescribeReplicationInstancesResponse build() {
return new DescribeReplicationInstancesResponse(this);
}
}
}