software.amazon.awssdk.services.databasemigration.model.DescribeConnectionsResponse 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 DescribeConnectionsResponse extends DatabaseMigrationResponse implements
ToCopyableBuilder {
private final String marker;
private final List connections;
private DescribeConnectionsResponse(BuilderImpl builder) {
super(builder);
this.marker = builder.marker;
this.connections = builder.connections;
}
/**
*
* 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;
}
/**
*
* A description of the connections.
*
*
* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
*
*
* @return A description of the connections.
*/
public List connections() {
return connections;
}
@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(connections());
return hashCode;
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof DescribeConnectionsResponse)) {
return false;
}
DescribeConnectionsResponse other = (DescribeConnectionsResponse) obj;
return Objects.equals(marker(), other.marker()) && Objects.equals(connections(), other.connections());
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder("{");
if (marker() != null) {
sb.append("Marker: ").append(marker()).append(",");
}
if (connections() != null) {
sb.append("Connections: ").append(connections()).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 "Connections":
return Optional.of(clazz.cast(connections()));
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);
/**
*
* A description of the connections.
*
*
* @param connections
* A description of the connections.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder connections(Collection connections);
/**
*
* A description of the connections.
*
*
* @param connections
* A description of the connections.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder connections(Connection... connections);
}
static final class BuilderImpl extends DatabaseMigrationResponse.BuilderImpl implements Builder {
private String marker;
private List connections;
private BuilderImpl() {
}
private BuilderImpl(DescribeConnectionsResponse model) {
marker(model.marker);
connections(model.connections);
}
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 getConnections() {
return connections != null ? connections.stream().map(Connection::toBuilder).collect(Collectors.toList()) : null;
}
@Override
public final Builder connections(Collection connections) {
this.connections = ConnectionListCopier.copy(connections);
return this;
}
@Override
@SafeVarargs
public final Builder connections(Connection... connections) {
connections(Arrays.asList(connections));
return this;
}
public final void setConnections(Collection connections) {
this.connections = ConnectionListCopier.copyFromBuilder(connections);
}
@Override
public DescribeConnectionsResponse build() {
return new DescribeConnectionsResponse(this);
}
}
}