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

software.amazon.awssdk.services.databasemigration.model.DescribeConnectionsResponse Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS Database Migration Service module holds the client classes that are used for communicating with AWS Database Migration Service.

There is a newer version: 2.0.0-preview-11
Show newest version
/*
 * 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 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); } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy